#include "parser.h"
#include "usb_hid.h"
-#include "debug.h"
+#include "print.h"
-void KBDReportParser::Parse(HID *hid, bool is_rpt_id, uint8_t len, uint8_t *buf)
+void KBDReportParser::Parse(USBHID *hid, bool is_rpt_id, uint8_t len, uint8_t *buf)
{
- ::memcpy(&report, buf, sizeof(report_keyboard_t));
- time_stamp = millis();
+ xprintf("input %d:", hid->GetAddress());
+ for (uint8_t i = 0; i < len; i++) {
+ xprintf(" %02X", buf[i]);
+ }
+ xprintf("\r\n");
- dprintf("input %d: %02X %02X", hid->GetAddress(), report.mods, report.reserved);
- for (uint8_t i = 0; i < KEYBOARD_REPORT_KEYS; i++) {
- dprintf(" %02X", report.keys[i]);
+ // Rollover error
+ // Cherry: 0101010101010101
+ // https://geekhack.org/index.php?topic=69169.msg2638223#msg2638223
+ // Apple: 0000010101010101
+ // https://geekhack.org/index.php?topic=69169.msg2760969#msg2760969
+ if (buf[2] == 0x01) {
+ xprintf("Rollover error: ignored\r\n");
+ return;
}
- dprint("\r\n");
+
+ ::memcpy(&report, buf, sizeof(report_keyboard_t));
+ time_stamp = millis();
}