+ assert(inode->data);
+
+ struct device* dev = resolve_device(inode->data);
+
+ if (!dev || !dev->ops.read_page) {
+ return ENOTSUP;
+ }
+
+ return dev->ops.read_page(dev, buffer, fpos);
+}
+
+int
+devfs_write_page(struct v_inode* inode, void* buffer, size_t fpos)
+{
+ assert(inode->data);
+
+ struct device* dev = resolve_device(inode->data);
+
+ if (!dev || !dev->ops.read_page) {
+ return ENOTSUP;
+ }
+
+ return dev->ops.read_page(dev, buffer, fpos);
+}
+
+int
+devfs_get_itype(morph_t* obj)
+{
+ int itype = VFS_IFDEV;
+
+ if (morph_type_of(obj, devcat_morpher)) {
+ return VFS_IFDIR;
+ }
+
+ struct device* dev = resolve_device(obj);
+
+ if (!dev) {
+ return itype;
+ }
+