summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--kvmd/apps/otg/__init__.py33
1 files changed, 15 insertions, 18 deletions
diff --git a/kvmd/apps/otg/__init__.py b/kvmd/apps/otg/__init__.py
index 44b1bd84..cbf7a197 100644
--- a/kvmd/apps/otg/__init__.py
+++ b/kvmd/apps/otg/__init__.py
@@ -31,6 +31,7 @@ from os.path import join # pylint: disable=ungrouped-imports
from typing import List
from typing import Optional
+from typing import Union
from ...logging import get_logger
@@ -77,14 +78,10 @@ def _unlink(path: str, optional: bool=False) -> None:
os.unlink(path)
-def _write(path: str, text: str, optional: bool=False) -> None:
- logger = get_logger()
- if optional and not os.access(path, os.F_OK):
- logger.info("SKIP ---- %s", path)
- return
- logger.info("WRITE --- %s", path)
+def _write(path: str, value: Union[str, int]) -> None:
+ get_logger().info("WRITE --- %s", path)
with open(path, "w") as param_file:
- param_file.write(text)
+ param_file.write(str(value))
def _write_bytes(path: str, data: bytes) -> None:
@@ -161,12 +158,12 @@ class _GadgetConfig:
func = f"hid.usb{self.__hid_instance}"
func_path = join(self.__gadget_path, "functions", func)
_mkdir(func_path)
- _write(join(func_path, "no_out_endpoint"), "1", optional=True)
+ _write(join(func_path, "no_out_endpoint"), "1")
if remote_wakeup:
- _write(join(func_path, "wakeup_on_write"), "1", optional=True)
- _write(join(func_path, "protocol"), str(hid.protocol))
- _write(join(func_path, "subclass"), str(hid.subclass))
- _write(join(func_path, "report_length"), str(hid.report_length))
+ _write(join(func_path, "wakeup_on_write"), "1")
+ _write(join(func_path, "protocol"), hid.protocol)
+ _write(join(func_path, "subclass"), hid.subclass)
+ _write(join(func_path, "report_length"), hid.report_length)
_write_bytes(join(func_path, "report_desc"), hid.report_descriptor)
_symlink(func_path, join(self.__profile_path, func))
self.__create_meta(func, name)
@@ -176,11 +173,11 @@ class _GadgetConfig:
func = f"mass_storage.usb{self.__msd_instance}"
func_path = join(self.__gadget_path, "functions", func)
_mkdir(func_path)
- _write(join(func_path, "stall"), str(int(stall)))
- _write(join(func_path, "lun.0/cdrom"), str(int(cdrom)))
- _write(join(func_path, "lun.0/ro"), str(int(not rw)))
- _write(join(func_path, "lun.0/removable"), str(int(removable)))
- _write(join(func_path, "lun.0/nofua"), str(int(not fua)))
+ _write(join(func_path, "stall"), int(stall))
+ _write(join(func_path, "lun.0/cdrom"), int(cdrom))
+ _write(join(func_path, "lun.0/ro"), int(not rw))
+ _write(join(func_path, "lun.0/removable"), int(removable))
+ _write(join(func_path, "lun.0/nofua"), int(not fua))
if user != "root":
_chown(join(func_path, "lun.0/cdrom"), user)
_chown(join(func_path, "lun.0/ro"), user)
@@ -238,7 +235,7 @@ def _cmd_start(config: Section) -> None: # pylint: disable=too-many-statements,
_mkdir(profile_path)
_mkdir(join(profile_path, "strings/0x409"))
_write(join(profile_path, "strings/0x409/configuration"), f"Config 1: {config.otg.config}")
- _write(join(profile_path, "MaxPower"), str(config.otg.max_power))
+ _write(join(profile_path, "MaxPower"), config.otg.max_power)
if config.otg.remote_wakeup:
# XXX: Should we use MaxPower=100 with Remote Wakeup?
_write(join(profile_path, "bmAttributes"), "0xA0")