diff options
author | Maxim Devaev <[email protected]> | 2022-03-31 16:17:52 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2022-03-31 16:17:52 +0300 |
commit | b775239d7265a1bcbb6e32f06546e53d389802d6 (patch) | |
tree | 98c7112425e79e0075c5e3859567b085bf9bab17 /kvmd | |
parent | ab09f88d80ac67c76f012b2fcb853f2d69ab6b7d (diff) |
refactoring
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/otg/__init__.py | 13 | ||||
-rw-r--r-- | kvmd/apps/otgconf/__init__.py | 20 | ||||
-rw-r--r-- | kvmd/apps/otgmsd/__init__.py | 15 | ||||
-rw-r--r-- | kvmd/apps/otgnet/__init__.py | 9 | ||||
-rw-r--r-- | kvmd/plugins/msd/otg/drive.py | 21 | ||||
-rw-r--r-- | kvmd/plugins/ugpio/otgbind.py | 15 | ||||
-rw-r--r-- | kvmd/usb.py | 10 |
7 files changed, 44 insertions, 59 deletions
diff --git a/kvmd/apps/otg/__init__.py b/kvmd/apps/otg/__init__.py index fba00b73..c073ed91 100644 --- a/kvmd/apps/otg/__init__.py +++ b/kvmd/apps/otg/__init__.py @@ -38,7 +38,6 @@ from ...yamlconf import Section from ...validators import ValidatorError -from ... import env from ... import usb from .. import init @@ -147,7 +146,7 @@ class _GadgetConfig: # a Microsoft-specific extension of USB. _write(join(func_path, "os_desc/interface.rndis/compatible_id"), "RNDIS") _write(join(func_path, "os_desc/interface.rndis/sub_compatible_id"), "5162001") - _symlink(self.__profile_path, join(self.__gadget_path, "os_desc/c.1")) + _symlink(self.__profile_path, join(self.__gadget_path, "os_desc", usb.G_PROFILE_NAME)) _symlink(func_path, join(self.__profile_path, func)) self.__create_meta(func, "Ethernet") @@ -207,7 +206,7 @@ def _cmd_start(config: Section) -> None: # pylint: disable=too-many-statements logger.info("Using UDC %s", udc) logger.info("Creating gadget %r ...", config.otg.gadget) - gadget_path = join(f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", config.otg.gadget) + gadget_path = usb.get_gadget_path(config.otg.gadget) _mkdir(gadget_path) _write(join(gadget_path, "idVendor"), f"0x{config.otg.vendor_id:04X}") @@ -229,7 +228,7 @@ def _cmd_start(config: Section) -> None: # pylint: disable=too-many-statements _write(join(lang_path, "product"), config.otg.product) _write(join(lang_path, "serialnumber"), config.otg.serial) - profile_path = join(gadget_path, "configs/c.1") + profile_path = join(gadget_path, usb.G_PROFILE) _mkdir(profile_path) _mkdir(join(profile_path, "strings/0x409")) _write(join(profile_path, "strings/0x409/configuration"), f"Config 1: {config.otg.config}") @@ -285,14 +284,14 @@ def _cmd_stop(config: Section) -> None: _check_config(config) - gadget_path = join(f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", config.otg.gadget) + gadget_path = usb.get_gadget_path(config.otg.gadget) logger.info("Disabling gadget %r ...", config.otg.gadget) _write(join(gadget_path, "UDC"), "\n") - _unlink(join(gadget_path, "os_desc/c.1"), True) + _unlink(join(gadget_path, "os_desc", usb.G_PROFILE_NAME), True) - profile_path = join(gadget_path, "configs/c.1") + profile_path = join(gadget_path, usb.G_PROFILE) for func in os.listdir(profile_path): if re.search(r"\.usb\d+$", func): _unlink(join(profile_path, func)) diff --git a/kvmd/apps/otgconf/__init__.py b/kvmd/apps/otgconf/__init__.py index 5e765a99..96aa83f0 100644 --- a/kvmd/apps/otgconf/__init__.py +++ b/kvmd/apps/otgconf/__init__.py @@ -31,25 +31,16 @@ from typing import Optional from ...validators.basic import valid_stripped_string_not_empty -from ... import env from ... import usb from .. import init # ===== -def _make_config_path(gadget: str, func: str) -> str: - return os.path.join(f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", gadget, "configs/c.1", func) - - -def _make_func_path(gadget: str, func: str) -> str: - return os.path.join(f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", gadget, "functions", func) - - @contextlib.contextmanager def _udc_stopped(gadget: str, udc: str) -> Generator[None, None, None]: udc = usb.find_udc(udc) - udc_path = os.path.join(f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", gadget, "UDC") + udc_path = usb.get_gadget_path(gadget, usb.G_UDC) with open(udc_path) as udc_file: enabled = bool(udc_file.read().strip()) if enabled: @@ -65,19 +56,22 @@ def _udc_stopped(gadget: str, udc: str) -> Generator[None, None, None]: def _enable_function(gadget: str, udc: str, func: str) -> None: with _udc_stopped(gadget, udc): - os.symlink(_make_func_path(gadget, func), _make_config_path(gadget, func)) + os.symlink( + usb.get_gadget_path(gadget, usb.G_FUNCTIONS, func), + usb.get_gadget_path(gadget, usb.G_PROFILE, func), + ) def _disable_function(gadget: str, udc: str, func: str) -> None: with _udc_stopped(gadget, udc): - os.unlink(_make_config_path(gadget, func)) + os.unlink(usb.get_gadget_path(gadget, usb.G_PROFILE, func)) def _list_functions(gadget: str, meta_path: str) -> None: for meta_name in sorted(os.listdir(meta_path)): with open(os.path.join(meta_path, meta_name)) as meta_file: meta = json.loads(meta_file.read()) - enabled = os.path.exists(_make_config_path(gadget, meta["func"])) + enabled = os.path.exists(usb.get_gadget_path(gadget, usb.G_PROFILE, meta["func"])) print(f"{'+' if enabled else '-'} {meta['func']} # {meta['name']}") diff --git a/kvmd/apps/otgmsd/__init__.py b/kvmd/apps/otgmsd/__init__.py index f87d5985..5187a72d 100644 --- a/kvmd/apps/otgmsd/__init__.py +++ b/kvmd/apps/otgmsd/__init__.py @@ -34,29 +34,24 @@ from ...validators.basic import valid_bool from ...validators.basic import valid_int_f0 from ...validators.os import valid_abs_file -from ... import env +from ... import usb from .. import init # ===== -def _make_param_path(gadget: str, instance: int, param: str) -> str: - return os.path.join( - f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", - gadget, - f"functions/mass_storage.usb{instance}/lun.0", - param, - ) +def _get_param_path(gadget: str, instance: int, param: str) -> str: + return usb.get_gadget_path(gadget, usb.G_FUNCTIONS, f"mass_storage.usb{instance}/lun.0", param) def _get_param(gadget: str, instance: int, param: str) -> str: - with open(_make_param_path(gadget, instance, param)) as param_file: + with open(_get_param_path(gadget, instance, param)) as param_file: return param_file.read().strip() def _set_param(gadget: str, instance: int, param: str, value: str) -> None: try: - with open(_make_param_path(gadget, instance, param), "w") as param_file: + with open(_get_param_path(gadget, instance, param), "w") as param_file: param_file.write(value + "\n") except OSError as err: if err.errno == errno.EBUSY: diff --git a/kvmd/apps/otgnet/__init__.py b/kvmd/apps/otgnet/__init__.py index ad1f6a28..3f2d99b8 100644 --- a/kvmd/apps/otgnet/__init__.py +++ b/kvmd/apps/otgnet/__init__.py @@ -20,7 +20,6 @@ # ========================================================================== # -import os import asyncio import ipaddress import dataclasses @@ -34,9 +33,9 @@ from ...logging import get_logger from ...yamlconf import Section -from ... import env from ... import tools from ... import aioproc +from ... import usb from .. import init @@ -176,11 +175,7 @@ class _Service: # pylint: disable=too-many-instance-attributes real_driver = self.__driver if self.__driver == "rndis5": real_driver = "rndis" - path = env.SYSFS_PREFIX + os.path.join( - "/sys/kernel/config/usb_gadget", - self.__gadget, - f"functions/{real_driver}.usb0/ifname", - ) + path = usb.get_gadget_path(self.__gadget, usb.G_FUNCTIONS, f"{real_driver}.usb0/ifname") logger.info("Using OTG gadget %r ...", self.__gadget) with open(path) as iface_file: iface = iface_file.read().strip() diff --git a/kvmd/plugins/msd/otg/drive.py b/kvmd/plugins/msd/otg/drive.py index 1bbb2558..ee54e5e9 100644 --- a/kvmd/plugins/msd/otg/drive.py +++ b/kvmd/plugins/msd/otg/drive.py @@ -25,7 +25,7 @@ import errno from typing import List -from .... import env +from .... import usb from .. import MsdOperationError @@ -39,23 +39,16 @@ class MsdDriveLockedError(MsdOperationError): # ===== class Drive: def __init__(self, gadget: str, instance: int, lun: int) -> None: - self.__lun_path = os.path.join( - f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", - gadget, - f"functions/mass_storage.usb{instance}/lun.{lun}", - ) - self.__configs_root_path = os.path.join( - f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", - gadget, - "configs/c.1", - ) - self.__func_path = os.path.join(self.__configs_root_path, f"mass_storage.usb{instance}") + func = f"mass_storage.usb{instance}" + self.__profile_func_path = usb.get_gadget_path(gadget, usb.G_PROFILE, func) + self.__profile_path = usb.get_gadget_path(gadget, usb.G_PROFILE) + self.__lun_path = usb.get_gadget_path(gadget, usb.G_FUNCTIONS, func, f"lun.{lun}") def is_enabled(self) -> bool: - return os.path.exists(self.__func_path) + return os.path.exists(self.__profile_func_path) def get_watchable_paths(self) -> List[str]: - return [self.__lun_path, self.__configs_root_path] + return [self.__lun_path, self.__profile_path] # ===== diff --git a/kvmd/plugins/ugpio/otgbind.py b/kvmd/plugins/ugpio/otgbind.py index 17da02a8..4be96aeb 100644 --- a/kvmd/plugins/ugpio/otgbind.py +++ b/kvmd/plugins/ugpio/otgbind.py @@ -31,7 +31,6 @@ from ...logging import get_logger from ...inotify import InotifyMask from ...inotify import Inotify -from ... import env from ... import aiotools from ... import usb @@ -53,7 +52,7 @@ class Plugin(BaseUserGpioDriver): self.__udc = udc - self.__ctl_path = f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget/{gadget}/UDC" + self.__udc_path = usb.get_gadget_path(gadget, usb.G_UDC) @classmethod def get_pin_validator(cls) -> Callable[[Any], Any]: @@ -69,12 +68,12 @@ class Plugin(BaseUserGpioDriver): try: while True: await self._notifier.notify() - if os.path.isfile(self.__ctl_path): + if os.path.isfile(self.__udc_path): break await asyncio.sleep(5) with Inotify() as inotify: - inotify.watch(os.path.dirname(self.__ctl_path), InotifyMask.ALL_MODIFY_EVENTS) + inotify.watch(os.path.dirname(self.__udc_path), InotifyMask.ALL_MODIFY_EVENTS) await self._notifier.notify() while True: need_restart = False @@ -94,13 +93,13 @@ class Plugin(BaseUserGpioDriver): async def read(self, pin: str) -> bool: _ = pin - with open(self.__ctl_path) as ctl_file: - return bool(ctl_file.read().strip()) + with open(self.__udc_path) as udc_file: + return bool(udc_file.read().strip()) async def write(self, pin: str, state: bool) -> None: _ = pin - with open(self.__ctl_path, "w") as ctl_file: - ctl_file.write(self.__udc if state else "\n") + with open(self.__udc_path, "w") as udc_file: + udc_file.write(self.__udc if state else "\n") def __str__(self) -> str: return f"GPIO({self._instance_name})" diff --git a/kvmd/usb.py b/kvmd/usb.py index 4242b1cb..4a5a130d 100644 --- a/kvmd/usb.py +++ b/kvmd/usb.py @@ -36,3 +36,13 @@ def find_udc(udc: str) -> str: elif udc not in candidates: raise RuntimeError(f"Can't find selected UDC: {udc}") return udc # fe980000.usb + + +G_UDC = "UDC" +G_FUNCTIONS = "functions" +G_PROFILE_NAME = "c.1" +G_PROFILE = f"configs/{G_PROFILE_NAME}" + + +def get_gadget_path(gadget: str, *parts: str) -> str: + return os.path.join(f"{env.SYSFS_PREFIX}/sys/kernel/config/usb_gadget", gadget, *parts) |