summaryrefslogtreecommitdiff
path: root/hid/src
diff options
context:
space:
mode:
Diffstat (limited to 'hid/src')
-rw-r--r--hid/src/main.cpp10
-rw-r--r--hid/src/ps2/hid.h11
-rw-r--r--hid/src/usb/hid.h11
3 files changed, 20 insertions, 12 deletions
diff --git a/hid/src/main.cpp b/hid/src/main.cpp
index 162636ab..7d575b54 100644
--- a/hid/src/main.cpp
+++ b/hid/src/main.cpp
@@ -285,11 +285,17 @@ static void _sendResponse(uint8_t code) {
# endif
if (_usb_kbd) {
response[1] |= _usb_kbd->isOffline() ? PROTO::PONG::KEYBOARD_OFFLINE : 0;
- response[1] |= _usb_kbd->getLedsAs(PROTO::PONG::CAPS, PROTO::PONG::SCROLL, PROTO::PONG::NUM);
+ KeyboardLedsState leds = _usb_kbd->getLeds();
+ response[1] |= leds.caps ? PROTO::PONG::CAPS : 0;
+ response[1] |= leds.num ? PROTO::PONG::NUM : 0;
+ response[1] |= leds.scroll ? PROTO::PONG::SCROLL : 0;
response[2] |= PROTO::OUTPUTS1::KEYBOARD::USB;
} else if (_ps2_kbd) {
response[1] |= _ps2_kbd->isOffline() ? PROTO::PONG::KEYBOARD_OFFLINE : 0;
- response[1] |= _ps2_kbd->getLedsAs(PROTO::PONG::CAPS, PROTO::PONG::SCROLL, PROTO::PONG::NUM);
+ KeyboardLedsState leds = _usb_kbd->getLeds();
+ response[1] |= leds.caps ? PROTO::PONG::CAPS : 0;
+ response[1] |= leds.num ? PROTO::PONG::NUM : 0;
+ response[1] |= leds.scroll ? PROTO::PONG::SCROLL : 0;
response[2] |= PROTO::OUTPUTS1::KEYBOARD::PS2;
}
if (_usb_mouse_abs) {
diff --git a/hid/src/ps2/hid.h b/hid/src/ps2/hid.h
index ec55b80a..db7247e4 100644
--- a/hid/src/ps2/hid.h
+++ b/hid/src/ps2/hid.h
@@ -25,6 +25,7 @@
#include <Arduino.h>
#include <ps2dev.h>
+#include "keyboard.h"
#include "keymap.h"
// #define HID_PS2_KBD_CLOCK_PIN 7
@@ -78,13 +79,13 @@ class Ps2Keyboard {
return false;
}
- uint8_t getLedsAs(uint8_t caps, uint8_t scroll, uint8_t num) {
- uint8_t result = 0;
+ KeyboardLedsState getLeds() {
+ KeyboardLedsState result;
periodic();
- if (_leds & 0b00000100) result |= caps;
- if (_leds & 0b00000001) result |= scroll;
- if (_leds & 0b00000010) result |= num;
+ result.caps = _leds & 0b00000100;
+ result.scroll = _leds & 0b00000001;
+ result.num = _leds & 0b00000010;
return result;
}
diff --git a/hid/src/usb/hid.h b/hid/src/usb/hid.h
index 9d5ab75e..ac35179e 100644
--- a/hid/src/usb/hid.h
+++ b/hid/src/usb/hid.h
@@ -25,6 +25,7 @@
#include <Arduino.h>
#include <HID-Project.h>
+#include "keyboard.h"
#include "../tools.h"
#ifdef AUM
# include "../aum.h"
@@ -104,12 +105,12 @@ class UsbKeyboard {
CLS_IS_OFFLINE(_kbd)
- uint8_t getLedsAs(uint8_t caps, uint8_t scroll, uint8_t num) {
+ KeyboardLedsState getLeds() {
uint8_t leds = _kbd.getLeds();
- uint8_t result = 0;
- if (leds & LED_CAPS_LOCK) result |= caps;
- if (leds & LED_SCROLL_LOCK) result |= scroll;
- if (leds & LED_NUM_LOCK) result |= num;
+ KeyboardLedsState result;
+ result.caps = leds & LED_CAPS_LOCK;
+ result.scroll = leds & LED_SCROLL_LOCK;
+ result.num = leds & LED_NUM_LOCK;
return result;
}