summaryrefslogtreecommitdiff
path: root/hid
diff options
context:
space:
mode:
Diffstat (limited to 'hid')
-rw-r--r--hid/lib/drivers/keyboard.h29
-rw-r--r--hid/src/main.cpp10
-rw-r--r--hid/src/ps2/hid.h11
-rw-r--r--hid/src/usb/hid.h11
4 files changed, 49 insertions, 12 deletions
diff --git a/hid/lib/drivers/keyboard.h b/hid/lib/drivers/keyboard.h
new file mode 100644
index 00000000..841106be
--- /dev/null
+++ b/hid/lib/drivers/keyboard.h
@@ -0,0 +1,29 @@
+/*****************************************************************************
+# #
+# KVMD - The main PiKVM daemon. #
+# #
+# Copyright (C) 2018-2022 Maxim Devaev <[email protected]> #
+# #
+# This program is free software: you can redistribute it and/or modify #
+# it under the terms of the GNU General Public License as published by #
+# the Free Software Foundation, either version 3 of the License, or #
+# (at your option) any later version. #
+# #
+# This program is distributed in the hope that it will be useful, #
+# but WITHOUT ANY WARRANTY; without even the implied warranty of #
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
+# GNU General Public License for more details. #
+# #
+# You should have received a copy of the GNU General Public License #
+# along with this program. If not, see <https://www.gnu.org/licenses/>. #
+# #
+*****************************************************************************/
+
+#pragma once
+
+typedef struct
+{
+ bool caps;
+ bool scroll;
+ bool num;
+} KeyboardLedsState;
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;
}