diff options
| author | Jun Wako <wakojun@gmail.com> | 2015-09-24 12:29:11 +0900 |
|---|---|---|
| committer | Jun Wako <wakojun@gmail.com> | 2015-09-24 12:29:11 +0900 |
| commit | fdc38ef3f92af7adeeb4de49550d8838c8a39b5c (patch) | |
| tree | a20c7a06111e5f674d94e8ba48a82d16b2e3e07f /protocol/usb_hid/parser.cpp | |
| parent | f6d56675f9f981c5464f0ca7a1fbb0162154e8c5 (diff) | |
| download | qmk_firmware-fdc38ef3f92af7adeeb4de49550d8838c8a39b5c.tar.gz qmk_firmware-fdc38ef3f92af7adeeb4de49550d8838c8a39b5c.zip | |
Squashed 'tmk_core/' changes from dc0e46e..57d27a8
57d27a8 Merge branch 'core_update_150924' into core
024abe3 core: Fix NKRO ifdef
7aa2d30 core: Fix for disabling NKRO in Boot protocol
95651fd core: Fix message print of debug command
c20cd29 lufa: Fix endpoint bank mode for ATMega32u2
82ac21f next_usb: Fix next_kbd_set_leds()
537d9c7 Change to KC_BOOTLOADER(KC_BTLD)
f2b3772 Add an assignable RESET key
fc99257 Fix parenthesis
e852582 Fix weak modifier clear in action macro
c2a6c5c core: Fix lufa suspend callback(#234)
fa548c5 usb_usb: Ignore error usage(0x01-03) report
513d95c usb_usb: Support locking key indicator LED
cd78802 core: Add keymap section ldscript for ATMega32U2
70c9abd Add description for non-US keys on keycode.h
538c192 lufa: Fix console flush #223
87628c9 Revert "Make action_for_key a weak symbol"
3c0a1ba Make action_for_key a weak symbol
6bb0d7d ibm4704_usb: Fix protocol handling
b6ef5cf Add keyboard_setup() and matrix_setup()
f4bb8b2 ibm4704_usb: Fix interrupt of clock(rising edge)
0c1fcc1 usb_usb: Change debug LED pin config
595710d Reduce code size of magic commands
6bed174 Add description of AVR bootloader and boot section
54c6a01 Merge commit 'f6d56675f9f981c5464f0ca7a1fbb0162154e8c5'
d18d42e Merge branch 'core-update2' into core
febec88 Add compile options '-fdata-sections'
git-subtree-dir: tmk_core
git-subtree-split: 57d27a8e39173a589b4abae74851f95c39940174
Diffstat (limited to 'protocol/usb_hid/parser.cpp')
| -rw-r--r-- | protocol/usb_hid/parser.cpp | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/protocol/usb_hid/parser.cpp b/protocol/usb_hid/parser.cpp index 28151f9d5..1a152ff3f 100644 --- a/protocol/usb_hid/parser.cpp +++ b/protocol/usb_hid/parser.cpp | |||
| @@ -10,15 +10,24 @@ uint16_t usb_hid_time_stamp; | |||
| 10 | 10 | ||
| 11 | void KBDReportParser::Parse(HID *hid, bool is_rpt_id, uint8_t len, uint8_t *buf) | 11 | void KBDReportParser::Parse(HID *hid, bool is_rpt_id, uint8_t len, uint8_t *buf) |
| 12 | { | 12 | { |
| 13 | ::memcpy(&usb_hid_keyboard_report, buf, sizeof(report_keyboard_t)); | 13 | bool is_error = false; |
| 14 | usb_hid_time_stamp = millis(); | 14 | report_keyboard_t *report = (report_keyboard_t *)buf; |
| 15 | |||
| 16 | dprintf("KBDReport: %02X %02X", report->mods, report->reserved); | ||
| 17 | for (uint8_t i = 0; i < KEYBOARD_REPORT_KEYS; i++) { | ||
| 18 | if (IS_ERROR(report->keys[i])) { | ||
| 19 | is_error = true; | ||
| 20 | } | ||
| 21 | dprintf(" %02X", report->keys[i]); | ||
| 22 | } | ||
| 23 | dprint("\r\n"); | ||
| 15 | 24 | ||
| 16 | debug("KBDReport: "); | 25 | // ignore error and not send report to computer |
| 17 | debug_hex(usb_hid_keyboard_report.mods); | 26 | if (is_error) { |
| 18 | debug(" --"); | 27 | dprint("Error usage! \r\n"); |
| 19 | for (uint8_t i = 0; i < 6; i++) { | 28 | return; |
| 20 | debug(" "); | ||
| 21 | debug_hex(usb_hid_keyboard_report.keys[i]); | ||
| 22 | } | 29 | } |
| 23 | debug("\r\n"); | 30 | |
| 31 | ::memcpy(&usb_hid_keyboard_report, buf, sizeof(report_keyboard_t)); | ||
| 32 | usb_hid_time_stamp = millis(); | ||
| 24 | } | 33 | } |
