|
@@ -1,156 +1,167 @@
|
|
-#include <stdio.h>
|
|
+#include <stdio.h>
|
|
-#include "pico/stdlib.h"
|
|
+#include "pico/stdlib.h"
|
|
-
|
|
+
|
|
-#include "hardware/pio.h"
|
|
+#include "hardware/pio.h"
|
|
-#include "bsp/board_api.h"
|
|
+#include "bsp/board_api.h"
|
|
-#include "tusb.h"
|
|
+#include "tusb.h"
|
|
-#include "usb_descriptors.h"
|
|
+#include "usb_descriptors.h"
|
|
-
|
|
+
|
|
-#include "keypad.h"
|
|
+#include "keypad.h"
|
|
-#include "keymap.h"
|
|
+#include "keymap.h"
|
|
-#include "display.h"
|
|
+#include "display.h"
|
|
-
|
|
+
|
|
-#define KEYBOARD_REPORT_COUNT 6
|
|
+#define KEYBOARD_REPORT_COUNT 6
|
|
-uint8_t key_report[KEYBOARD_REPORT_COUNT] = {0,0,0,0,0,0};
|
|
+uint8_t key_report[KEYBOARD_REPORT_COUNT] = {0,0,0,0,0,0};
|
|
-
|
|
+
|
|
-char report_str[OLED_WIDTH/FONT_WIDTH];
|
|
+char report_str[OLED_WIDTH/FONT_WIDTH];
|
|
-char indicator_str[OLED_WIDTH/FONT_WIDTH];
|
|
+char indicator_str[OLED_WIDTH/FONT_WIDTH];
|
|
-
|
|
+char debug_str[OLED_WIDTH/FONT_WIDTH];
|
|
-
|
|
+
|
|
-inline void clear_key_report(void)
|
|
+
|
|
-{
|
|
+inline void clear_key_report(void)
|
|
- for(int i = 0; i < KEYBOARD_REPORT_COUNT; i++){
|
|
+{
|
|
- key_report[i] = 0;
|
|
+ for(int i = 0; i < KEYBOARD_REPORT_COUNT; i++){
|
|
- }
|
|
+ key_report[i] = 0;
|
|
-}
|
|
+ }
|
|
-
|
|
+}
|
|
-
|
|
+
|
|
-void tud_mount_cb(void)
|
|
+
|
|
-{
|
|
+void tud_mount_cb(void)
|
|
- clear_key_report();
|
|
+{
|
|
-}
|
|
+ clear_key_report();
|
|
-
|
|
+}
|
|
-
|
|
+
|
|
-void tud_umount_cb(void)
|
|
+
|
|
-{
|
|
+void tud_umount_cb(void)
|
|
- clear_key_report();
|
|
+{
|
|
-}
|
|
+ clear_key_report();
|
|
-
|
|
+}
|
|
-
|
|
+
|
|
-void tud_suspend_cb(bool remote_wakeup_en)
|
|
+
|
|
-{
|
|
+void tud_suspend_cb(bool remote_wakeup_en)
|
|
- (void) remote_wakeup_en;
|
|
+{
|
|
-
|
|
+ (void) remote_wakeup_en;
|
|
-}
|
|
+
|
|
-
|
|
+}
|
|
-
|
|
+
|
|
-void tud_resume_cb(void)
|
|
+
|
|
-{
|
|
+void tud_resume_cb(void)
|
|
-
|
|
+{
|
|
-}
|
|
+
|
|
-
|
|
+}
|
|
-
|
|
+
|
|
-
|
|
+
|
|
-void tud_hid_report_complete_cb(uint8_t instance, uint8_t const* report, uint16_t len)
|
|
+
|
|
-{
|
|
+void tud_hid_report_complete_cb(uint8_t instance, uint8_t const* report, uint16_t len)
|
|
- (void) instance;
|
|
+{
|
|
- (void) len;
|
|
+ (void) instance;
|
|
- (void) report;
|
|
+ (void) len;
|
|
-
|
|
+ (void) report;
|
|
-}
|
|
+
|
|
-
|
|
+}
|
|
-
|
|
+
|
|
-
|
|
+
|
|
-uint16_t tud_hid_get_report_cb(uint8_t instance, uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen)
|
|
+
|
|
-{
|
|
+
|
|
-
|
|
+uint16_t tud_hid_get_report_cb(uint8_t instance, uint8_t report_id, hid_report_type_t report_type, uint8_t* buffer, uint16_t reqlen)
|
|
- (void) instance;
|
|
+{
|
|
- (void) report_id;
|
|
+ (void) instance;
|
|
- (void) report_type;
|
|
+ (void) report_id;
|
|
- (void) buffer;
|
|
+ (void) report_type;
|
|
- (void) reqlen;
|
|
+
|
|
-
|
|
+ if(reqlen < sizeof(hid_keyboard_report_t) ) {
|
|
- return 0;
|
|
+ buffer[0] = 0;
|
|
-}
|
|
+ return 1;
|
|
-
|
|
+ }
|
|
-
|
|
+ else {
|
|
-
|
|
+ hid_keyboard_report_t report;
|
|
-void tud_hid_set_report_cb(uint8_t instance, uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize)
|
|
+ report.modifier = 0;
|
|
-{
|
|
+ report.reserved = 0;
|
|
- (void) instance;
|
|
+ memcpy(report.keycode, key_report, KEYBOARD_REPORT_COUNT );
|
|
-
|
|
+ memcpy(buffer, &report, sizeof(hid_keyboard_report_t));
|
|
- if( bufsize < 1 ) return;
|
|
+
|
|
-
|
|
+ return sizeof(hid_keyboard_report_t);
|
|
- if(report_type == HID_REPORT_TYPE_OUTPUT) {
|
|
+ }
|
|
- if(report_id == REPORT_ID_KEYBOARD) {
|
|
+}
|
|
- uint8_t leds = buffer[0];
|
|
+
|
|
-
|
|
+
|
|
- sprintf(indicator_str, "%s %s %s",
|
|
+
|
|
- leds & KEYBOARD_LED_CAPSLOCK ? "CAP" : " ",
|
|
+void tud_hid_set_report_cb(uint8_t instance, uint8_t report_id, hid_report_type_t report_type, uint8_t const* buffer, uint16_t bufsize)
|
|
- leds & KEYBOARD_LED_NUMLOCK ? "NUM" : " ",
|
|
+{
|
|
- leds & KEYBOARD_LED_SCROLLLOCK ? "SCR" : " "
|
|
+ (void) instance;
|
|
-
|
|
+
|
|
-
|
|
+ if( bufsize < 1 ) return;
|
|
- );
|
|
+
|
|
- display_putstr(indicator_str, 0, 0, false);
|
|
+ if(report_type == HID_REPORT_TYPE_OUTPUT) {
|
|
- }
|
|
+ if(report_id == REPORT_ID_KEYBOARD) {
|
|
- }
|
|
+ uint8_t leds = buffer[0];
|
|
-}
|
|
+
|
|
-
|
|
+ sprintf(indicator_str, "%s %s %s",
|
|
-
|
|
+ leds & KEYBOARD_LED_CAPSLOCK ? "CAP" : " ",
|
|
-void display_report(void)
|
|
+ leds & KEYBOARD_LED_NUMLOCK ? "NUM" : " ",
|
|
-{
|
|
+ leds & KEYBOARD_LED_SCROLLLOCK ? "SCR" : " "
|
|
- sprintf(report_str,"%02x%02x%02x%02x%02x%02x", key_report[0],key_report[1],key_report[2],key_report[3],key_report[4],key_report[5]);
|
|
+
|
|
- display_putstr(report_str, 0, 3, false);
|
|
+
|
|
-}
|
|
+ );
|
|
-
|
|
+ display_putstr(indicator_str, 0, 0, false);
|
|
-
|
|
+ }
|
|
-int main()
|
|
+ }
|
|
-{
|
|
+}
|
|
-
|
|
+
|
|
- board_init();
|
|
+
|
|
- tud_init(BOARD_TUD_RHPORT);
|
|
+void display_report(void)
|
|
- if (board_init_after_tusb) {
|
|
+{
|
|
- board_init_after_tusb();
|
|
+ sprintf(report_str,"%02x%02x%02x%02x%02x%02x", key_report[0],key_report[1],key_report[2],key_report[3],key_report[4],key_report[5]);
|
|
- }
|
|
+ display_putstr(report_str, 0, 3, false);
|
|
-
|
|
+}
|
|
- stdio_init_all();
|
|
+
|
|
-
|
|
+
|
|
- display_init();
|
|
+int main()
|
|
- display_report();
|
|
+{
|
|
-
|
|
+
|
|
- keypad_init();
|
|
+ board_init();
|
|
-
|
|
+ tud_init(BOARD_TUD_RHPORT);
|
|
- while (true) {
|
|
+ if (board_init_after_tusb) {
|
|
- tud_task();
|
|
+ board_init_after_tusb();
|
|
-
|
|
+ }
|
|
- key_t key = get_key();
|
|
+
|
|
- if(tud_mounted()) {
|
|
+ stdio_init_all();
|
|
- if(key.state != KEYPAD_INVALID) {
|
|
+
|
|
- uint8_t scancode = keymap[key.code];
|
|
+ display_init();
|
|
- if(tud_suspended())
|
|
+ display_report();
|
|
- tud_remote_wakeup();
|
|
+
|
|
-
|
|
+ keypad_init();
|
|
- if(key.state == KEYPAD_PUSH) {
|
|
+
|
|
- for(int i = 0; i < KEYBOARD_REPORT_COUNT; i++) {
|
|
+ while (true) {
|
|
- if(key_report[i] == 0) {
|
|
+ tud_task();
|
|
- key_report[i] = scancode;
|
|
+
|
|
- break;
|
|
+ key_t key = get_key();
|
|
- }
|
|
+ if(tud_mounted()) {
|
|
- }
|
|
+ if(key.state != KEYPAD_INVALID) {
|
|
- }
|
|
+ uint8_t scancode = keymap[key.code];
|
|
- else {
|
|
+ if(tud_suspended())
|
|
- for(int i = 0; i < KEYBOARD_REPORT_COUNT; i++) {
|
|
+ tud_remote_wakeup();
|
|
- if(key_report[i] == scancode)
|
|
+
|
|
- key_report[i] = 0;
|
|
+ if(key.state == KEYPAD_PUSH) {
|
|
- }
|
|
+ for(int i = 0; i < KEYBOARD_REPORT_COUNT; i++) {
|
|
- }
|
|
+ if(key_report[i] == 0) {
|
|
-
|
|
+ key_report[i] = scancode;
|
|
- display_report();
|
|
+ break;
|
|
-
|
|
+ }
|
|
- if(tud_hid_ready())
|
|
+ }
|
|
- tud_hid_keyboard_report(REPORT_ID_KEYBOARD,0, key_report);
|
|
+ }
|
|
- }
|
|
+ else {
|
|
- }
|
|
+ for(int i = 0; i < KEYBOARD_REPORT_COUNT; i++) {
|
|
- }
|
|
+ if(key_report[i] == scancode)
|
|
-}
|
|
+ key_report[i] = 0;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ display_report();
|
|
|
|
+
|
|
|
|
+ if(tud_hid_ready())
|
|
|
|
+ tud_hid_keyboard_report(REPORT_ID_KEYBOARD,0, key_report);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+}
|