git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
feat: owloysius - dynamic init function invocator
[lunaix-os.git]
/
lunaix-os
/
kernel
/
device
/
devfs.c
diff --git
a/lunaix-os/kernel/device/devfs.c
b/lunaix-os/kernel/device/devfs.c
index f586addca408066d9c44ee2d0a470df02e0d4af1..350bbd65e447ab64ed5b50de1757490ef75a27a4 100644
(file)
--- a/
lunaix-os/kernel/device/devfs.c
+++ b/
lunaix-os/kernel/device/devfs.c
@@
-13,9
+13,9
@@
devfs_read(struct v_inode* inode, void* buffer, size_t len, size_t fpos)
{
assert(inode->data);
{
assert(inode->data);
- struct device* dev =
(struct device*)inode->data
;
+ struct device* dev =
resolve_device(inode->data)
;
- if (!dev->ops.read) {
+ if (!dev
|| !dev
->ops.read) {
return ENOTSUP;
}
return ENOTSUP;
}
@@
-27,9
+27,9
@@
devfs_write(struct v_inode* inode, void* buffer, size_t len, size_t fpos)
{
assert(inode->data);
{
assert(inode->data);
- struct device* dev =
(struct device*)inode->data
;
+ struct device* dev =
resolve_device(inode->data)
;
- if (!dev->ops.write) {
+ if (!dev
|| !dev
->ops.write) {
return ENOTSUP;
}
return ENOTSUP;
}
@@
-41,9
+41,9
@@
devfs_read_page(struct v_inode* inode, void* buffer, size_t fpos)
{
assert(inode->data);
{
assert(inode->data);
- struct device* dev =
(struct device*)inode->data
;
+ struct device* dev =
resolve_device(inode->data)
;
- if (!dev->ops.read_page) {
+ if (!dev
|| !dev
->ops.read_page) {
return ENOTSUP;
}
return ENOTSUP;
}
@@
-55,9
+55,9
@@
devfs_write_page(struct v_inode* inode, void* buffer, size_t fpos)
{
assert(inode->data);
{
assert(inode->data);
- struct device* dev =
(struct device*)inode->data
;
+ struct device* dev =
resolve_device(inode->data)
;
- if (!dev->ops.read_page) {
+ if (!dev
|| !dev
->ops.read_page) {
return ENOTSUP;
}
return ENOTSUP;
}
@@
-65,13
+65,18
@@
devfs_write_page(struct v_inode* inode, void* buffer, size_t fpos)
}
int
}
int
-devfs_get_itype(struct device
* dev
)
+devfs_get_itype(struct device
_meta* dm
)
{
int itype = VFS_IFFILE;
{
int itype = VFS_IFFILE;
+
+ if (valid_device_subtype_ref(dm, DEV_CAT)) {
+ return VFS_IFDIR;
+ }
+
+ struct device* dev = resolve_device(dm);
int dev_if = dev->dev_type & DEV_MSKIF;
int dev_if = dev->dev_type & DEV_MSKIF;
- if (dev_if == DEV_IFCAT) {
- itype = VFS_IFDIR;
- } else if (dev_if == DEV_IFVOL) {
+
+ if (dev_if == DEV_IFVOL) {
itype |= VFS_IFVOLDEV;
} else if (dev_if == DEV_IFSEQ) {
itype |= VFS_IFSEQDEV;
itype |= VFS_IFVOLDEV;
} else if (dev_if == DEV_IFSEQ) {
itype |= VFS_IFSEQDEV;
@@
-82,19
+87,16
@@
devfs_get_itype(struct device* dev)
}
int
}
int
-devfs_get_dtype(struct device* dev)
+devfs_get_dtype(struct device
_meta
* dev)
{
{
- switch (dev->dev_type & DEV_MSKIF) {
- case DEV_IFCAT:
- return DT_DIR;
-
- default:
- return DT_FILE;
+ if (valid_device_subtype_ref(dev, DEV_CAT)) {
+ return DT_DIR;
}
}
+ return DT_FILE;
}
int
}
int
-devfs_mknod(struct v_dnode* dnode, struct device* dev)
+devfs_mknod(struct v_dnode* dnode, struct device
_meta
* dev)
{
assert(dev);
{
assert(dev);
@@
-118,22
+120,40
@@
devfs_mknod(struct v_dnode* dnode, struct device* dev)
int
devfs_dirlookup(struct v_inode* this, struct v_dnode* dnode)
{
int
devfs_dirlookup(struct v_inode* this, struct v_dnode* dnode)
{
- struct device* dev =
- device_getbyhname((struct device*)this->data, &dnode->name);
+ void* data = this->data;
+ struct device_meta* rootdev = resolve_device_meta(data);
+
+ if (data && !rootdev) {
+ return ENOTDIR;
+ }
+
+ struct device_meta* dev =
+ device_getbyhname(rootdev, &dnode->name);
+
if (!dev) {
return ENOENT;
}
if (!dev) {
return ENOENT;
}
+
return devfs_mknod(dnode, dev);
}
int
devfs_readdir(struct v_file* file, struct dir_context* dctx)
{
return devfs_mknod(dnode, dev);
}
int
devfs_readdir(struct v_file* file, struct dir_context* dctx)
{
- struct device* dev =
- device_getbyoffset((struct device*)(file->inode->data), dctx->index);
+ void* data = file->inode->data;
+ struct device_meta* rootdev = resolve_device_meta(data);
+
+ if (data && !rootdev) {
+ return ENOTDIR;
+ }
+
+ struct device_meta* dev =
+ device_getbyoffset(rootdev, dctx->index);
+
if (!dev) {
return 0;
}
if (!dev) {
return 0;
}
+
dctx->read_complete_callback(
dctx, dev->name.value, dev->name.len, devfs_get_dtype(dev));
return 1;
dctx->read_complete_callback(
dctx, dev->name.value, dev->name.len, devfs_get_dtype(dev));
return 1;