aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorfauxpark <fauxpark@gmail.com>2019-01-22 21:43:17 +1100
committerDrashna Jaelre <drashna@live.com>2019-01-22 09:30:01 -0800
commitae79b60e6bfc03c7fa84076e508f0f2241f087c2 (patch)
treee003132a05fe290a3dc52e0200f084a6d244c98d
parent8cf7265f8fae6f94b17c5d78ed41e52b22e2b218 (diff)
downloadfirmware-ae79b60e6bfc03c7fa84076e508f0f2241f087c2.tar.gz
firmware-ae79b60e6bfc03c7fa84076e508f0f2241f087c2.tar.bz2
firmware-ae79b60e6bfc03c7fa84076e508f0f2241f087c2.zip
Always read two bytes from the endpoint if we have two bytes to read
When this if statement is false, it will cause the report ID to be read as the LED state. We already know there are two bytes in the endpoint, which is a reasonably good indicator that it contains a report ID, so we should always read both.
-rw-r--r--tmk_core/protocol/lufa/lufa.c6
1 files changed, 1 insertions, 5 deletions
diff --git a/tmk_core/protocol/lufa/lufa.c b/tmk_core/protocol/lufa/lufa.c
index cdabaf16e..f2ecf2465 100644
--- a/tmk_core/protocol/lufa/lufa.c
+++ b/tmk_core/protocol/lufa/lufa.c
@@ -519,11 +519,7 @@ void EVENT_USB_Device_ControlRequest(void)
}
if (Endpoint_BytesInEndpoint() == 2) {
- uint8_t report_id = REPORT_ID_KEYBOARD;
-
- if (keyboard_protocol) {
- report_id = Endpoint_Read_8();
- }
+ uint8_t report_id = Endpoint_Read_8();
if (report_id == REPORT_ID_KEYBOARD || report_id == REPORT_ID_NKRO) {
keyboard_led_stats = Endpoint_Read_8();