[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 3/3] input-linux: add switch to enable auto-repeat e
From: |
Gerd Hoffmann |
Subject: |
[Qemu-devel] [PATCH 3/3] input-linux: add switch to enable auto-repeat events |
Date: |
Fri, 4 Mar 2016 11:25:16 +0100 |
Enable with "-input-linux /dev/input/${device},repeat=on".
Signed-off-by: Gerd Hoffmann <address@hidden>
---
ui/input-linux.c | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/ui/input-linux.c b/ui/input-linux.c
index ad43963..0bc0405 100644
--- a/ui/input-linux.c
+++ b/ui/input-linux.c
@@ -132,6 +132,7 @@ typedef struct InputLinux InputLinux;
struct InputLinux {
const char *evdev;
int fd;
+ bool repeat;
bool grab_request;
bool grab_active;
bool grab_all;
@@ -188,7 +189,7 @@ static void input_linux_event_keyboard(void *opaque)
switch (event.type) {
case EV_KEY:
- if (event.value > 1) {
+ if (event.value > 2 || (event.value > 1 && !il->repeat)) {
/*
* ignore autorepeat + unknown key events
* 0 == up, 1 == down, 2 == autorepeat, other == undefined
@@ -316,6 +317,7 @@ int input_linux_init(void *opaque, QemuOpts *opts, Error
**errp)
il->evdev = qemu_opt_get(opts, "evdev");
il->grab_all = qemu_opt_get_bool(opts, "grab-all", false);
+ il->repeat = qemu_opt_get_bool(opts, "repeat", false);
if (!il->evdev) {
error_setg(errp, "no input device specified");
@@ -374,6 +376,9 @@ static QemuOptsList qemu_input_linux_opts = {
},{
.name = "grab-all",
.type = QEMU_OPT_BOOL,
+ },{
+ .name = "repeat",
+ .type = QEMU_OPT_BOOL,
},
{ /* end of list */ }
},
--
1.8.3.1