diff mbox

[v2,3/3] hid.c: Add debug support

Message ID 1467388791-1657-4-git-send-email-programmingkidx@gmail.com (mailing list archive)
State New, archived
Headers show

Commit Message

Programmingkid July 1, 2016, 3:59 p.m. UTC
Add debug macros to the code for easier debugging.

Signed-off-by: John Arbuckle <programmingkidx@gmail.com>
---
v2 changes:
- Made DEBUG_HID() always defined

 hw/input/hid.c | 17 +++++++++++++++++
 1 file changed, 17 insertions(+)
diff mbox

Patch

diff --git a/hw/input/hid.c b/hw/input/hid.c
index 3e1b46e..b5558cd 100644
--- a/hw/input/hid.c
+++ b/hw/input/hid.c
@@ -37,6 +37,19 @@ 
 #define RELEASED -1
 #define PUSHED -2
 
+/* #define DEBUG_HID_CODE */
+#ifdef DEBUG_HID_CODE
+    #define DEBUG_HID_PRINT 1
+#else
+    #define DEBUG_HID_PRINT 0
+#endif
+#define DEBUG_HID(fmt, ...)                                 \
+    do {                                                    \
+            if (DEBUG_HID_PRINT) {                          \
+                fprintf(stderr, fmt, ## __VA_ARGS__);       \
+            }                                               \
+        } while (0)                                         \
+
 /* Translates a QKeyCode to USB HID value */
 static const uint8_t qcode_to_usb_hid[] = {
     [Q_KEY_CODE_SHIFT] = USB_HID_LEFT_SHIFT,
@@ -331,6 +344,7 @@  static void hid_keyboard_event(DeviceState *dev, QemuConsole *src,
         return;
     }
     keycode = qcode_to_usb_hid[qcode];
+    DEBUG_HID("keycode = 0x%x qcode:%d\n", keycode, qcode);
 
     count = 2;
     if (evt->u.key.data->down == false) { /* if key up event */
@@ -381,6 +395,9 @@  static void hid_keyboard_process_keycode(HIDState *hs)
     slot = hs->head & QUEUE_MASK; QUEUE_INCR(hs->head); hs->n--;
     keycode = hs->kbd.keycodes[slot];
 
+    DEBUG_HID("keycode:0x%x status:%s\n", keycode, (status == PUSHED ? "Pushed"
+              : "Released"));
+
     /* handle Control, Option, GUI/Windows/Command, and Shift keys */
     if (keycode >= 0xe0) {
         process_modifier_key(status, keycode, &(hs->kbd.modifiers));