make log a bit verbose for some useful information
[lunaix-os.git] / lunaix-os / kernel / device / input.c
index 5ddf6a4ce3cc0067b58e2a31aa1630b3e33c9d94..cc3cc1328f2f38c38c1a98af4f4f7f114d6a5c32 100644 (file)
@@ -1,5 +1,6 @@
 #include <lunaix/clock.h>
 #include <lunaix/input.h>
+#include <lunaix/mm/pagetable.h>
 #include <lunaix/mm/valloc.h>
 #include <lunaix/spike.h>
 #include <lunaix/status.h>
@@ -8,7 +9,7 @@
 
 static DEFINE_LLIST(listener_chain);
 
-static struct device* input_devcat = NULL;
+static struct device_cat* input_devcat = NULL;
 
 void
 input_init()
@@ -62,8 +63,14 @@ __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, PAGE_SIZE);
+}
+
 struct input_device*
-input_add_device(char* name_fmt, ...)
+input_add_device(struct devclass* class, char* name_fmt, ...)
 {
     assert(input_devcat);
 
@@ -73,11 +80,14 @@ input_add_device(char* name_fmt, ...)
     va_list args;
     va_start(args, name_fmt);
 
-    struct device* dev =
-      device_add(input_devcat, idev, name_fmt, DEV_IFSEQ, args);
+    struct device* dev = device_allocseq(dev_meta(input_devcat), idev);
+
+    device_setname_vargs(dev_meta(dev), name_fmt, args);
+    register_device(dev, class, NULL);
 
     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);