regression: elf loading
[lunaix-os.git] / lunaix-os / kernel / device / devfs.c
index 73abac7d885053aac1dc830ce4fb6831a139b468..867f93d1ca76891deb65d24f33b1c65fe6fea7d4 100644 (file)
@@ -3,6 +3,8 @@
 #include <lunaix/fs/devfs.h>
 #include <lunaix/spike.h>
 
+#include <sys/dirent_defs.h>
+
 extern struct v_inode_ops devfs_inode_ops;
 extern struct v_file_ops devfs_file_ops;
 
@@ -34,6 +36,34 @@ devfs_write(struct v_inode* inode, void* buffer, size_t len, size_t fpos)
     return dev->write(dev, buffer, fpos, len);
 }
 
+int
+devfs_read_page(struct v_inode* inode, void* buffer, size_t len, size_t fpos)
+{
+    assert(inode->data);
+
+    struct device* dev = (struct device*)inode->data;
+
+    if (!dev->read_page) {
+        return ENOTSUP;
+    }
+
+    return dev->read_page(dev, buffer, fpos);
+}
+
+int
+devfs_write_page(struct v_inode* inode, void* buffer, size_t len, size_t fpos)
+{
+    assert(inode->data);
+
+    struct device* dev = (struct device*)inode->data;
+
+    if (!dev->read_page) {
+        return ENOTSUP;
+    }
+
+    return dev->read_page(dev, buffer, fpos);
+}
+
 int
 devfs_get_itype(struct device* dev)
 {
@@ -49,6 +79,18 @@ devfs_get_itype(struct device* dev)
     return itype;
 }
 
+int
+devfs_get_dtype(struct device* dev)
+{
+    switch (dev->dev_type & DEV_MSKIF) {
+        case DEV_IFCAT:
+            return DT_DIR;
+
+        default:
+            return DT_FILE;
+    }
+}
+
 int
 devfs_mknod(struct v_dnode* dnode, struct device* dev)
 {
@@ -74,7 +116,8 @@ devfs_mknod(struct v_dnode* dnode, struct device* dev)
 int
 devfs_dirlookup(struct v_inode* this, struct v_dnode* dnode)
 {
-    struct device* dev = device_getbyname(this->data, &dnode->name);
+    struct device* dev =
+      device_getbyhname((struct device*)this->data, &dnode->name);
     if (!dev) {
         return ENOENT;
     }
@@ -84,12 +127,13 @@ devfs_dirlookup(struct v_inode* this, struct v_dnode* dnode)
 int
 devfs_readdir(struct v_file* file, struct dir_context* dctx)
 {
-    struct device* dev = device_getbyoffset(file->inode->data, dctx->index);
+    struct device* dev =
+      device_getbyoffset((struct device*)(file->inode->data), dctx->index);
     if (!dev) {
         return 0;
     }
     dctx->read_complete_callback(
-      dctx, dev->name.value, dev->name.len, devfs_get_itype(dev));
+      dctx, dev->name.value, dev->name.len, devfs_get_dtype(dev));
     return 1;
 }
 
@@ -142,6 +186,8 @@ struct v_inode_ops devfs_inode_ops = { .dir_lookup = devfs_dirlookup,
 
 struct v_file_ops devfs_file_ops = { .close = default_file_close,
                                      .read = devfs_read,
+                                     .read_page = devfs_read_page,
                                      .write = devfs_write,
+                                     .write_page = devfs_write_page,
                                      .seek = default_file_seek,
                                      .readdir = devfs_readdir };
\ No newline at end of file