X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/96e23fa3c6eabf8a6efebac24b740c5d4a2a1050..2a49908006b177c4d6354309333d06b1b96e4887:/lunaix-os/kernel/device/devfs.c diff --git a/lunaix-os/kernel/device/devfs.c b/lunaix-os/kernel/device/devfs.c index 73abac7..fdb8b47 100644 --- a/lunaix-os/kernel/device/devfs.c +++ b/lunaix-os/kernel/device/devfs.c @@ -3,6 +3,8 @@ #include #include +#include + 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