diff options
author | Gerd Hoffmann <kraxel@redhat.com> | 2016-03-04 11:25:16 +0100 |
---|---|---|
committer | Gerd Hoffmann <kraxel@redhat.com> | 2016-03-08 12:20:11 +0100 |
commit | a6ccabd6769b9d6e5bbc3f23bf8da58db032f3a1 (patch) | |
tree | 372f4901d1e4c1d5296845c9fa42d85f3ac03b97 /ui | |
parent | 46d921bebe4d0767a343ac81469ded6230e2defb (diff) |
input-linux: add switch to enable auto-repeat events
Enable with "-input-linux /dev/input/${device},repeat=on".
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Message-id: 1457087116-4379-4-git-send-email-kraxel@redhat.com
Diffstat (limited to 'ui')
-rw-r--r-- | ui/input-linux.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/ui/input-linux.c b/ui/input-linux.c index ad43963bd3..0bc0405ec6 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 */ } }, |