X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/5ea8e2ba737f903db81d49b56778e883634512a5..f6ab9c9ababa2cf6e5c723b83ffb9362094054e8:/lunaix-os/kernel/device/input.c diff --git a/lunaix-os/kernel/device/input.c b/lunaix-os/kernel/device/input.c index 5ddf6a4..0680fef 100644 --- a/lunaix-os/kernel/device/input.c +++ b/lunaix-os/kernel/device/input.c @@ -1,5 +1,6 @@ #include #include +#include #include #include #include @@ -14,6 +15,13 @@ void input_init() { input_devcat = device_addcat(NULL, "input"); + + int i; + ptr_t input_dev_init; + ldga_foreach(inputdev, ptr_t, i, input_dev_init) + { + ((void (*)())input_dev_init)(); + } } void @@ -62,6 +70,12 @@ __input_dev_read(struct device* dev, void* buf, size_t offset, size_t len) return sizeof(struct input_evt_pkt); } +int +__input_dev_read_pg(struct device* dev, void* buf, size_t offset) +{ + return __input_dev_read(dev, buf, offset, PG_SIZE); +} + struct input_device* input_add_device(char* name_fmt, ...) { @@ -77,7 +91,8 @@ input_add_device(char* name_fmt, ...) device_add(input_devcat, idev, name_fmt, DEV_IFSEQ, args); idev->dev_if = dev; - dev->read = __input_dev_read; + dev->ops.read = __input_dev_read; + dev->ops.read_page = __input_dev_read_pg; va_end(args);