summaryrefslogtreecommitdiff
path: root/kvmd/plugins/hid
diff options
context:
space:
mode:
Diffstat (limited to 'kvmd/plugins/hid')
-rw-r--r--kvmd/plugins/hid/ch9329/__init__.py8
-rw-r--r--kvmd/plugins/hid/ch9329/chip.py12
-rw-r--r--kvmd/plugins/hid/ch9329/keyboard.py4
-rw-r--r--kvmd/plugins/hid/ch9329/mouse.py34
4 files changed, 30 insertions, 28 deletions
diff --git a/kvmd/plugins/hid/ch9329/__init__.py b/kvmd/plugins/hid/ch9329/__init__.py
index 53ac2342..1a46c10e 100644
--- a/kvmd/plugins/hid/ch9329/__init__.py
+++ b/kvmd/plugins/hid/ch9329/__init__.py
@@ -64,7 +64,7 @@ class Plugin(BaseHid, multiprocessing.Process): # pylint: disable=too-many-inst
self.__read_timeout = read_timeout
self.__reset_required_event = multiprocessing.Event()
- self.__cmd_queue: "multiprocessing.Queue[list]" = multiprocessing.Queue()
+ self.__cmd_queue: "multiprocessing.Queue[bytes]" = multiprocessing.Queue()
self.__notifier = aiomulti.AioProcessNotifier()
self.__state_flags = aiomulti.AioSharedFlags({
@@ -163,7 +163,7 @@ class Plugin(BaseHid, multiprocessing.Process): # pylint: disable=too-many-inst
def clear_events(self) -> None:
tools.clear_queue(self.__cmd_queue)
- def __queue_cmd(self, cmd: list[int], clear: bool=False) -> None:
+ def __queue_cmd(self, cmd: bytes, clear: bool=False) -> None:
if not self.__stop_event.is_set():
if clear:
# FIXME: Если очистка производится со стороны процесса хида, то возможна гонка между
@@ -196,7 +196,7 @@ class Plugin(BaseHid, multiprocessing.Process): # pylint: disable=too-many-inst
cmd = self.__cmd_queue.get(timeout=0.1)
# get_logger(0).info(f"HID : cmd = {cmd}")
except queue.Empty:
- self.__process_cmd([])
+ self.__process_cmd(b"")
else:
self.__process_cmd(cmd)
except Exception:
@@ -204,7 +204,7 @@ class Plugin(BaseHid, multiprocessing.Process): # pylint: disable=too-many-inst
get_logger(0).exception("Unexpected error in the HID loop")
time.sleep(2)
- def __process_cmd(self, cmd: list[int]) -> bool: # pylint: disable=too-many-branches
+ def __process_cmd(self, cmd: bytes) -> bool: # pylint: disable=too-many-branches
try:
led_byte = self.__chip.xfer(cmd)
except ChipResponseError as err:
diff --git a/kvmd/plugins/hid/ch9329/chip.py b/kvmd/plugins/hid/ch9329/chip.py
index 8f038042..d883099b 100644
--- a/kvmd/plugins/hid/ch9329/chip.py
+++ b/kvmd/plugins/hid/ch9329/chip.py
@@ -34,17 +34,17 @@ class Chip:
self.__tty = serial.Serial(device_path, speed, timeout=read_timeout)
self.__device_path = device_path
- def xfer(self, cmd: list[int]) -> int:
+ def xfer(self, cmd: bytes) -> int:
self.__send(cmd)
return self.__recv()
- def __send(self, cmd: list[int]) -> None:
+ def __send(self, cmd: bytes) -> None:
# RESET = [0x00,0x0F,0x00]
# GET_INFO = [0x00,0x01,0x00]
if len(cmd) == 0:
- cmd = [0x00, 0x01, 0x00]
- cmd = [0x57, 0xAB] + cmd
- cmd.append(self.__make_checksum(cmd))
+ cmd = b"\x00\x01\x00"
+ cmd = b"\x57\xAB" + cmd
+ cmd += self.__make_checksum(cmd).to_bytes()
self.__tty.write(serial.to_bytes(cmd))
def __recv(self) -> int:
@@ -64,5 +64,5 @@ class Chip:
# led_byte (info) response
return (data[7] if data[3] == 0x81 else -1)
- def __make_checksum(self, cmd: (list[int] | bytes)) -> int:
+ def __make_checksum(self, cmd: bytes) -> int:
return (sum(cmd) % 256)
diff --git a/kvmd/plugins/hid/ch9329/keyboard.py b/kvmd/plugins/hid/ch9329/keyboard.py
index 26eb7e6a..9aa16d9d 100644
--- a/kvmd/plugins/hid/ch9329/keyboard.py
+++ b/kvmd/plugins/hid/ch9329/keyboard.py
@@ -46,7 +46,7 @@ class Keyboard:
async def get_leds(self) -> dict[str, bool]:
return (await self.__leds.get())
- def process_key(self, key: str, state: bool) -> list[int]:
+ def process_key(self, key: str, state: bool) -> bytes:
code = KEYMAP[key].usb.code
is_modifier = KEYMAP[key].usb.is_modifier
if state:
@@ -65,4 +65,4 @@ class Keyboard:
]
for (index, code) in enumerate(self.__active_keys):
cmd[index + 5] = code
- return cmd
+ return bytes(cmd)
diff --git a/kvmd/plugins/hid/ch9329/mouse.py b/kvmd/plugins/hid/ch9329/mouse.py
index ea21150a..0a0cfbcc 100644
--- a/kvmd/plugins/hid/ch9329/mouse.py
+++ b/kvmd/plugins/hid/ch9329/mouse.py
@@ -32,6 +32,8 @@ class Mouse: # pylint: disable=too-many-instance-attributes
self.__buttons = 0
self.__to_x = (0, 0)
self.__to_y = (0, 0)
+ self.__delta_x = 0
+ self.__delta_y = 0
self.__wheel_y = 0
def set_absolute(self, flag: bool) -> None:
@@ -40,7 +42,7 @@ class Mouse: # pylint: disable=too-many-instance-attributes
def is_absolute(self) -> bool:
return self.__absolute
- def process_button(self, button: str, state: bool) -> list[int]:
+ def process_button(self, button: str, state: bool) -> bytes:
code = 0x00
match button:
case "left":
@@ -60,11 +62,11 @@ class Mouse: # pylint: disable=too-many-instance-attributes
self.__buttons &= ~code
self.__wheel_y = 0
if not self.__absolute:
- return self.__make_relative_cmd()
+ return self.__make_relative_cmd()
else:
- return self.__make_absolute_cmd()
+ return self.__make_absolute_cmd()
- def process_move(self, to_x: int, to_y: int) -> list[int]:
+ def process_move(self, to_x: int, to_y: int) -> bytes:
self.__to_x = self.__fix_absolute(to_x)
self.__to_y = self.__fix_absolute(to_y)
self.__wheel_y = 0
@@ -75,37 +77,37 @@ class Mouse: # pylint: disable=too-many-instance-attributes
to_fixed = math.ceil(MouseRange.remap(value, 0, MouseRange.MAX) / 8)
return (to_fixed >> 8, to_fixed & 0xFF)
- def process_wheel(self, delta_x: int, delta_y: int) -> list[int]:
+ def process_wheel(self, delta_x: int, delta_y: int) -> bytes:
_ = delta_x
assert -127 <= delta_y <= 127
self.__wheel_y = (1 if delta_y > 0 else 255)
if not self.__absolute:
- return self.__make_relative_cmd()
+ return self.__make_relative_cmd()
else:
- return self.__make_absolute_cmd()
-
- def process_relative(self, delta_x: int, delta_y: int) -> list[int]:
+ return self.__make_absolute_cmd()
+
+ def process_relative(self, delta_x: int, delta_y: int) -> bytes:
self.__delta_x = self.__fix_relative(delta_x)
self.__delta_y = self.__fix_relative(delta_y)
self.__wheel_y = 0
return self.__make_relative_cmd()
- def __make_absolute_cmd(self) -> list[int]:
- return [
+ def __make_absolute_cmd(self) -> bytes:
+ return bytes([
0, 0x04, 0x07, 0x02,
self.__buttons,
self.__to_x[1], self.__to_x[0],
self.__to_y[1], self.__to_y[0],
self.__wheel_y,
- ]
-
- def __make_relative_cmd(self) -> list[int]:
- return [
+ ])
+
+ def __make_relative_cmd(self) -> bytes:
+ return bytes([
0, 0x05, 0x05, 0x01,
self.__buttons,
self.__delta_x, self.__delta_y,
self.__wheel_y,
- ]
+ ])
def __fix_relative(self, value: int) -> int:
assert -127 <= value <= 127