#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;
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)
{
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)
{
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;
}
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;
}
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