diff options
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/__init__.py | 68 | ||||
-rw-r--r-- | kvmd/apps/otg/__init__.py | 26 |
2 files changed, 55 insertions, 39 deletions
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py index a760d188..2473fa72 100644 --- a/kvmd/apps/__init__.py +++ b/kvmd/apps/__init__.py @@ -144,6 +144,7 @@ def _init_config(config_path: str, override_options: List[str], **load_flags: bo try: tools.merge(raw_config, (raw_config.pop("override", {}) or {})) tools.merge(raw_config, build_raw_from_options(override_options)) + _patch_raw(raw_config) config = make_config(raw_config, scheme) if _patch_dynamic(raw_config, config, scheme, **load_flags): @@ -154,6 +155,19 @@ def _init_config(config_path: str, override_options: List[str], **load_flags: bo raise SystemExit(f"Config error: {err}") +def _patch_raw(raw_config: Dict) -> None: + if isinstance(raw_config.get("otg"), dict): + for (old, new) in [ + ("msd", "msd"), + ("acm", "serial"), + ("drives", "drives"), + ]: + if old in raw_config["otg"]: + if not isinstance(raw_config["otg"].get("devices"), dict): + raw_config["otg"]["devices"] = {} + raw_config["otg"]["devices"][new] = raw_config["otg"].pop(old) + + def _patch_dynamic( # pylint: disable=too-many-locals raw_config: Dict, config: Section, @@ -372,36 +386,38 @@ def _get_config_scheme() -> Dict: "udc": Option("", type=valid_stripped_string), "init_delay": Option(3.0, type=valid_float_f01), - "msd": { - "user": Option("kvmd", type=valid_user), - "default": { - "stall": Option(False, type=valid_bool), - "cdrom": Option(True, type=valid_bool), - "rw": Option(False, type=valid_bool), - "removable": Option(True, type=valid_bool), - "fua": Option(True, type=valid_bool), + "devices": { + "msd": { + "user": Option("kvmd", type=valid_user), + "default": { + "stall": Option(False, type=valid_bool), + "cdrom": Option(True, type=valid_bool), + "rw": Option(False, type=valid_bool), + "removable": Option(True, type=valid_bool), + "fua": Option(True, type=valid_bool), + }, }, - }, - "acm": { - "enabled": Option(False, type=valid_bool), - }, + "serial": { + "enabled": Option(False, type=valid_bool), + }, - "ethernet": { - "enabled": Option(False, type=valid_bool), - "host_mac": Option("", type=valid_mac, only_if="enabled"), - "kvm_mac": Option("", type=valid_mac, only_if="enabled"), - }, + "ethernet": { + "enabled": Option(False, type=valid_bool), + "host_mac": Option("", type=valid_mac, only_if="enabled"), + "kvm_mac": Option("", type=valid_mac, only_if="enabled"), + }, - "drives": { - "enabled": Option(False, type=valid_bool), - "count": Option(1, type=valid_int_f1), - "default": { - "stall": Option(False, type=valid_bool), - "cdrom": Option(False, type=valid_bool), - "rw": Option(True, type=valid_bool), - "removable": Option(True, type=valid_bool), - "fua": Option(True, type=valid_bool), + "drives": { + "enabled": Option(False, type=valid_bool), + "count": Option(1, type=valid_int_f1), + "default": { + "stall": Option(False, type=valid_bool), + "cdrom": Option(False, type=valid_bool), + "rw": Option(True, type=valid_bool), + "removable": Option(True, type=valid_bool), + "fua": Option(True, type=valid_bool), + }, }, }, }, diff --git a/kvmd/apps/otg/__init__.py b/kvmd/apps/otg/__init__.py index 2085134b..85db4b9d 100644 --- a/kvmd/apps/otg/__init__.py +++ b/kvmd/apps/otg/__init__.py @@ -96,8 +96,8 @@ def _find_udc(udc: str) -> str: def _check_config(config: Section) -> None: if ( - not config.otg.acm.enabled - and not config.otg.ethernet.enabled + not config.otg.devices.serial.enabled + and not config.otg.devices.ethernet.enabled and config.kvmd.hid.type != "otg" and config.kvmd.msd.type != "otg" ): @@ -105,7 +105,7 @@ def _check_config(config: Section) -> None: # ===== -def _create_acm(gadget_path: str, config_path: str) -> None: +def _create_serial(gadget_path: str, config_path: str) -> None: func_path = join(gadget_path, "functions/acm.usb0") _mkdir(func_path) _symlink(func_path, join(config_path, "acm.usb0")) @@ -188,13 +188,13 @@ def _cmd_start(config: Section) -> None: _write(join(config_path, "strings/0x409/configuration"), "Config 1: ECM network") _write(join(config_path, "MaxPower"), "250") - if config.otg.acm.enabled: - logger.info("Required ACM") - _create_acm(gadget_path, config_path) + if config.otg.devices.serial.enabled: + logger.info("Required Serial") + _create_serial(gadget_path, config_path) - if config.otg.ethernet.enabled: + if config.otg.devices.ethernet.enabled: logger.info("Required Ethernet") - _create_ethernet(gadget_path, config_path, config.otg.ethernet.host_mac, config.otg.ethernet.kvm_mac) + _create_ethernet(gadget_path, config_path, **config.otg.devices.ethernet._unpack(ignore=["enabled"])) if config.kvmd.hid.type == "otg": logger.info("Required HID") @@ -203,11 +203,11 @@ def _cmd_start(config: Section) -> None: if config.kvmd.msd.type == "otg": logger.info("Required MSD") - _create_msd(gadget_path, config_path, 0, config.otg.msd.user, **config.otg.msd.default._unpack()) # pylint: disable=protected-access - if config.otg.drives.enabled: - logger.info("Required MSD extra drives: %d", config.otg.drives.count) - for instance in range(config.otg.drives.count): - _create_msd(gadget_path, config_path, instance + 1, "root", **config.otg.drives.default._unpack()) # pylint: disable=protected-access + _create_msd(gadget_path, config_path, 0, config.otg.devices.msd.user, **config.otg.devices.msd.default._unpack()) + if config.otg.devices.drives.enabled: + logger.info("Required MSD extra drives: %d", config.otg.devices.drives.count) + for instance in range(config.otg.devices.drives.count): + _create_msd(gadget_path, config_path, instance + 1, "root", **config.otg.devices.drives.default._unpack()) logger.info("Enabling the gadget ...") _write(join(gadget_path, "UDC"), udc) |