summaryrefslogtreecommitdiff
path: root/kvmd/plugins/hid/_mcu/__init__.py
diff options
context:
space:
mode:
Diffstat (limited to 'kvmd/plugins/hid/_mcu/__init__.py')
-rw-r--r--kvmd/plugins/hid/_mcu/__init__.py18
1 files changed, 14 insertions, 4 deletions
diff --git a/kvmd/plugins/hid/_mcu/__init__.py b/kvmd/plugins/hid/_mcu/__init__.py
index 38707572..4d3df434 100644
--- a/kvmd/plugins/hid/_mcu/__init__.py
+++ b/kvmd/plugins/hid/_mcu/__init__.py
@@ -139,6 +139,7 @@ class BaseMcuHid(BaseHid, multiprocessing.Process): # pylint: disable=too-many-
self.__notifier = aiomulti.AioProcessNotifier()
self.__state_flags = aiomulti.AioSharedFlags({
"online": 0,
+ "busy": 0,
"status": 0,
}, self.__notifier, type=int)
@@ -195,6 +196,7 @@ class BaseMcuHid(BaseHid, multiprocessing.Process): # pylint: disable=too-many-
return {
"online": online,
+ "busy": bool(state["busy"]),
"keyboard": {
"online": (online and not (pong & 0b00001000)),
"leds": {
@@ -306,9 +308,13 @@ class BaseMcuHid(BaseHid, multiprocessing.Process): # pylint: disable=too-many-
self.__process_request(conn, REQUEST_PING)
else:
if isinstance(event, _HardResetEvent):
+ self.__set_state_busy(True)
self.__gpio.reset()
- elif not self.__process_request(conn, event.make_request()):
- self.clear_events()
+ else:
+ if isinstance(event, (SetKeyboardOutputEvent, SetMouseOutputEvent)):
+ self.__set_state_busy(True)
+ if not self.__process_request(conn, event.make_request()):
+ self.clear_events()
except Exception:
self.clear_events()
logger.exception("Unexpected error in the HID loop")
@@ -382,10 +388,14 @@ class BaseMcuHid(BaseHid, multiprocessing.Process): # pylint: disable=too-many-
def __set_state_online(self, online: bool) -> None:
self.__state_flags.update(online=int(online))
+ def __set_state_busy(self, busy: bool) -> None:
+ self.__state_flags.update(busy=int(busy))
+
def __set_state_pong(self, response: bytes) -> None:
status = response[1] << 16
if len(response) > 4:
status |= (response[2] << 8) | response[3]
- self.__state_flags.update(online=1, status=status)
- if response[1] & 0b01000000: # Reset required
+ reset_required = (1 if response[1] & 0b01000000 else 0)
+ self.__state_flags.update(online=1, busy=reset_required, status=status)
+ if reset_required:
self.__gpio.reset()