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
A Total Overhaul on the Lunaix's Virtual Memory Model (#26)
[lunaix-os.git]
/
lunaix-os
/
kernel
/
device
/
input.c
diff --git
a/lunaix-os/kernel/device/input.c
b/lunaix-os/kernel/device/input.c
index a96cb007f29e0e129c9d15cd0d427706fc5502a2..cc3cc1328f2f38c38c1a98af4f4f7f114d6a5c32 100644
(file)
--- a/
lunaix-os/kernel/device/input.c
+++ b/
lunaix-os/kernel/device/input.c
@@
-1,5
+1,6
@@
#include <lunaix/clock.h>
#include <lunaix/input.h>
#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>
#include <lunaix/mm/valloc.h>
#include <lunaix/spike.h>
#include <lunaix/status.h>
@@
-8,7
+9,7
@@
static DEFINE_LLIST(listener_chain);
static DEFINE_LLIST(listener_chain);
-static struct device* input_devcat = NULL;
+static struct device
_cat
* input_devcat = NULL;
void
input_init()
void
input_init()
@@
-65,11
+66,11
@@
__input_dev_read(struct device* dev, void* buf, size_t offset, size_t len)
int
__input_dev_read_pg(struct device* dev, void* buf, size_t offset)
{
int
__input_dev_read_pg(struct device* dev, void* buf, size_t offset)
{
- return __input_dev_read(dev, buf, offset, P
G
_SIZE);
+ return __input_dev_read(dev, buf, offset, P
AGE
_SIZE);
}
struct input_device*
}
struct input_device*
-input_add_device(char* name_fmt, ...)
+input_add_device(
struct devclass* class,
char* name_fmt, ...)
{
assert(input_devcat);
{
assert(input_devcat);
@@
-79,12
+80,14
@@
input_add_device(char* name_fmt, ...)
va_list args;
va_start(args, 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;
idev->dev_if = dev;
- dev->read = __input_dev_read;
- dev->read_page = __input_dev_read_pg;
+ dev->
ops.
read = __input_dev_read;
+ dev->
ops.
read_page = __input_dev_read_pg;
va_end(args);
va_end(args);