X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/eb1d71eb06e977f9ea61f6f43e5ce65342faf1cc..b3b42765712afed5a35c9be5c832f4a06bd85e7a:/lunaix-os/includes/lunaix/device.h diff --git a/lunaix-os/includes/lunaix/device.h b/lunaix-os/includes/lunaix/device.h index 414809a..8171600 100644 --- a/lunaix-os/includes/lunaix/device.h +++ b/lunaix-os/includes/lunaix/device.h @@ -5,24 +5,36 @@ #include #include +#include + +#define DEV_MSKIF 0x00000003 + +#define DEV_IFVOL 0x0 // volumetric (block) device +#define DEV_IFSEQ 0x1 // sequential (character) device +#define DEV_IFCAT 0x2 // a device category (as device groupping) typedef unsigned int dev_t; struct device { - struct llist_header dev_list; + struct llist_header siblings; + struct llist_header children; struct device* parent; struct hstr name; dev_t dev_id; + int dev_type; char name_val[DEVICE_NAME_SIZE]; void* underlay; - void* fs_node; int (*read)(struct device* dev, void* buf, size_t offset, size_t len); int (*write)(struct device* dev, void* buf, size_t offset, size_t len); }; -void -device_init(); +struct device* +device_add(struct device* parent, + void* underlay, + char* name_fmt, + uint32_t type, + va_list args); struct device* device_addseq(struct device* parent, void* underlay, char* name_fmt, ...); @@ -30,7 +42,22 @@ device_addseq(struct device* parent, void* underlay, char* name_fmt, ...); struct device* device_addvol(struct device* parent, void* underlay, char* name_fmt, ...); +struct device* +device_addcat(struct device* parent, char* name_fmt, ...); + void device_remove(struct device* dev); +struct device* +device_getbyid(struct llist_header* devlist, dev_t id); + +struct device* +device_getbyhname(struct llist_header* devlist, struct hstr* name); + +struct device* +device_getbyname(struct llist_header* devlist, const char* name, size_t len); + +struct device* +device_getbyoffset(struct llist_header* devlist, int pos); + #endif /* __LUNAIX_DEVICE_H */