diff options
author | Maxim Devaev <[email protected]> | 2021-08-28 19:01:13 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2021-08-28 19:01:13 +0300 |
commit | 2db0656df3ecd7c1f4502591c1a734905613e7ec (patch) | |
tree | 7ccf1cbd9a2e09ca12710302b6bc8fb3dc6b729e /kvmd/plugins/ugpio/otgbind.py | |
parent | 08dad87fea9cd3b5ced5642864c5e8c359e8b1cc (diff) |
unified udc code and automatic driver detection
Diffstat (limited to 'kvmd/plugins/ugpio/otgbind.py')
-rw-r--r-- | kvmd/plugins/ugpio/otgbind.py | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/kvmd/plugins/ugpio/otgbind.py b/kvmd/plugins/ugpio/otgbind.py index 5d80e516..de8ed5b6 100644 --- a/kvmd/plugins/ugpio/otgbind.py +++ b/kvmd/plugins/ugpio/otgbind.py @@ -32,6 +32,7 @@ from ...inotify import Inotify from ... import env from ... import aiotools +from ... import usb from . import BaseUserGpioDriver @@ -49,6 +50,7 @@ class Plugin(BaseUserGpioDriver): super().__init__(instance_name, notifier) self.__udc = udc + self.__driver = "" def register_input(self, pin: int, debounce: float) -> None: _ = pin @@ -59,13 +61,7 @@ class Plugin(BaseUserGpioDriver): _ = initial def prepare(self) -> None: - candidates = sorted(os.listdir(f"{env.SYSFS_PREFIX}/sys/class/udc")) - if not self.__udc: - if len(candidates) == 0: - raise RuntimeError("Can't find any UDC") - self.__udc = candidates[0] - elif self.__udc not in candidates: - raise RuntimeError(f"Can't find selected UDC: {self.__udc}") + (self.__udc, self.__driver) = usb.find_udc(self.__udc) get_logger().info("Using UDC %s", self.__udc) async def run(self) -> None: @@ -110,7 +106,8 @@ class Plugin(BaseUserGpioDriver): ctl_file.write(f"{self.__udc}\n") def __get_driver_path(self, name: str="") -> str: - path = f"{env.SYSFS_PREFIX}/sys/bus/platform/drivers/dwc2" + assert self.__driver + path = f"{env.SYSFS_PREFIX}/sys/bus/platform/drivers/{self.__driver}" return (os.path.join(path, name) if name else path) def __str__(self) -> str: |