summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Graf <agraf@suse.de>2017-06-22 09:41:35 +0200
committerMichael Roth <mdroth@linux.vnet.ibm.com>2017-08-24 16:59:22 -0500
commit0060a3e93632c3930ac010f4a576a6673f7dcef4 (patch)
tree644675c6a23e152de364b791d22d556a60522a1f
parente0398ccdf42e5a54c62ae617d374b5df9684ac0d (diff)
downloadqemu-0060a3e93632c3930ac010f4a576a6673f7dcef4.tar.gz
hid: Reset kbd modifiers on reset
When resetting the keyboard, we need to reset not just the pending keystrokes, but also any pending modifiers. Otherwise there's a race when we're getting reset while running an escape sequence (modifier 0x100). Cc: qemu-stable@nongnu.org Signed-off-by: Alexander Graf <agraf@suse.de> Message-id: 1498117295-162030-1-git-send-email-agraf@suse.de Signed-off-by: Gerd Hoffmann <kraxel@redhat.com> (cherry picked from commit 51dbea77a29ea46173373a6dad4ebd95d4661f42) Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
-rw-r--r--hw/input/hid.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/hw/input/hid.c b/hw/input/hid.c
index fa9cc4c616..a0892e882a 100644
--- a/hw/input/hid.c
+++ b/hw/input/hid.c
@@ -483,6 +483,7 @@ void hid_reset(HIDState *hs)
memset(hs->kbd.keycodes, 0, sizeof(hs->kbd.keycodes));
memset(hs->kbd.key, 0, sizeof(hs->kbd.key));
hs->kbd.keys = 0;
+ hs->kbd.modifiers = 0;
break;
case HID_MOUSE:
case HID_TABLET: