[PATCH 2/2] input: make the Input Core be the last in the poller queue
Aleksey Kuleshov
rndfax at yandex.ru
Thu Mar 3 07:17:10 PST 2016
This prevents the case when Input Core and event providers
have to run "at one time" so Input Core will work with non-relevant
data since it will be called first.
---
drivers/input/input.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/drivers/input/input.c b/drivers/input/input.c
index 31a9c22..1a8efc6 100644
--- a/drivers/input/input.c
+++ b/drivers/input/input.c
@@ -178,11 +178,13 @@ static void input_console_notify(struct input_notifier *in,
if (ev->value) {
kfifo_putc(ic->fifo, ascii);
ic->current_key = ascii;
+ poller_async_register(&ic->poller);
poller_call_async(&ic->poller, 400 * MSECOND,
input_console_repeat, ic);
} else {
ic->current_key = 0;
poller_async_cancel(&ic->poller);
+ poller_async_unregister(&ic->poller);
}
}
@@ -199,7 +201,6 @@ static int input_init(void)
ic->fifo = kfifo_alloc(32);
ic->notifier.notify = input_console_notify;
input_register_notfier(&ic->notifier);
- poller_async_register(&ic->poller);
return console_register(&ic->console);
}
--
2.6.2
More information about the barebox
mailing list