diff options
-rw-r--r-- | kvmd/apps/cleanup/__init__.py | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/kvmd/apps/cleanup/__init__.py b/kvmd/apps/cleanup/__init__.py index 8c9af7fe..dff70510 100644 --- a/kvmd/apps/cleanup/__init__.py +++ b/kvmd/apps/cleanup/__init__.py @@ -47,18 +47,21 @@ def main(argv: Optional[List[str]]=None) -> None: logger.info("Cleaning up ...") with gpio.bcm(): - for (name, pin) in [ - ("hid_reset_pin", config.hid.reset_pin), - ("msd_target_pin", config.msd.target_pin), - ("msd_reset_pin", config.msd.reset_pin), - ("atx_power_switch_pin", config.atx.power_switch_pin), - ("atx_reset_switch_pin", config.atx.reset_switch_pin), - ("streamer_cap_pin", config.streamer.cap_pin), - ("streamer_conv_pin", config.streamer.conv_pin), + for (name, pin, enabled) in [ + ("hid_reset_pin", config.hid.reset_pin, True), + ("atx_power_switch_pin", config.atx.power_switch_pin, config.atx.enabled), + ("atx_reset_switch_pin", config.atx.reset_switch_pin, config.atx.enabled), + ("msd_target_pin", config.msd.target_pin, config.msd.enabled), + ("msd_reset_pin", config.msd.reset_pin, config.msd.enabled), + ("streamer_cap_pin", config.streamer.cap_pin, True), + ("streamer_conv_pin", config.streamer.conv_pin, True), ]: - if pin >= 0: - logger.info("Writing value=0 to pin=%d (%s)", pin, name) - gpio.set_output(pin, initial=False) + if enabled and pin >= 0: + logger.info("Writing value=0 to GPIO pin=%d (%s)", pin, name) + try: + gpio.set_output(pin, initial=False) + except Exception: + logger.exception("Can't clear GPIO pin=%d (%s)", pin, name) streamer = os.path.basename(config.streamer.cmd[0]) logger.info("Trying to find and kill %r ...", streamer) |