summaryrefslogtreecommitdiff
path: root/protocol/usb_hid/parser.cpp
diff options
context:
space:
mode:
authortmk <nobody@nowhere>2012-09-04 14:24:52 +0900
committertmk <nobody@nowhere>2012-09-04 14:24:52 +0900
commitdc79a8521946a3a2e5b86945b8043b87a8b8d78c (patch)
tree737827112555c00a7f2ebbb88e61079c460be71a /protocol/usb_hid/parser.cpp
parent7350b7c6aa300a234244c264b10d1732803c27df (diff)
parent232ab308e358e41f3253d66fa009c1ebca0951a2 (diff)
Merge branch 'usb_hid'
Diffstat (limited to 'protocol/usb_hid/parser.cpp')
-rw-r--r--protocol/usb_hid/parser.cpp26
1 files changed, 26 insertions, 0 deletions
diff --git a/protocol/usb_hid/parser.cpp b/protocol/usb_hid/parser.cpp
new file mode 100644
index 0000000000..66e949518e
--- /dev/null
+++ b/protocol/usb_hid/parser.cpp
@@ -0,0 +1,26 @@
+#include <cstring.h>
+
+#include "parser.h"
+#include "usb_hid.h"
+
+#include "debug.h"
+
+
+report_keyboard_t usb_hid_keyboard_report;
+uint16_t usb_hid_time_stamp;
+
+
+void KBDReportParser::Parse(HID *hid, bool is_rpt_id, uint8_t len, uint8_t *buf)
+{
+ ::memcpy(&usb_hid_keyboard_report, buf, sizeof(report_keyboard_t));
+ usb_hid_time_stamp = millis();
+
+ debug("KBDReport: ");
+ debug_hex(usb_hid_keyboard_report.mods);
+ debug(" --");
+ for (uint8_t i = 0; i < 6; i++) {
+ debug(" ");
+ debug_hex(usb_hid_keyboard_report.keys[i]);
+ }
+ debug("\r\n");
+}