diff options
Diffstat (limited to 'kvmd/plugins/msd/otg')
-rw-r--r-- | kvmd/plugins/msd/otg/__init__.py | 32 | ||||
-rw-r--r-- | kvmd/plugins/msd/otg/storage.py | 16 |
2 files changed, 26 insertions, 22 deletions
diff --git a/kvmd/plugins/msd/otg/__init__.py b/kvmd/plugins/msd/otg/__init__.py index 52129db5..4c0a7863 100644 --- a/kvmd/plugins/msd/otg/__init__.py +++ b/kvmd/plugins/msd/otg/__init__.py @@ -41,10 +41,8 @@ from ....validators.os import valid_command from ....validators.kvm import valid_msd_image_name from .... import aiotools -from .... import aiohelpers from .... import fstab -from .. import MsdError from .. import MsdIsBusyError from .. import MsdOfflineError from .. import MsdConnectedError @@ -139,13 +137,11 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes self.__write_chunk_size = write_chunk_size self.__sync_chunk_size = sync_chunk_size - self.__remount_cmd = remount_cmd - self.__initial_image: str = initial["image"] self.__initial_cdrom: bool = initial["cdrom"] self.__drive = Drive(gadget, instance=0, lun=0) - self.__storage = Storage(fstab.find_msd().root_path) + self.__storage = Storage(fstab.find_msd().root_path, remount_cmd) self.__reader: (MsdFileReader | None) = None self.__writer: (MsdFileWriter | None) = None @@ -235,7 +231,7 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes self.__drive.set_image_path("") self.__drive.set_cdrom_flag(False) self.__drive.set_rw_flag(False) - await self.__remount_rw(False) + await self.__storage.remount_rw(False) except Exception: get_logger(0).exception("Can't reset MSD properly") @@ -292,13 +288,13 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes self.__drive.set_rw_flag(self.__state.vd.rw) self.__drive.set_cdrom_flag(self.__state.vd.cdrom) if self.__state.vd.rw: - await self.__remount_rw(True) + await self.__state.vd.image.remount_rw(True) self.__drive.set_image_path(self.__state.vd.image.path) else: self.__STATE_check_connected() self.__drive.set_image_path("") - await self.__remount_rw(False, fatal=False) + await self.__storage.remount_rw(False, fatal=False) self.__state.vd.connected = connected @@ -333,7 +329,7 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes self.__STATE_check_disconnected() image = self.__STORAGE_create_new_image(name) - await self.__remount_rw(True) + await image.remount_rw(True) image.set_complete(False) self.__writer = await MsdFileWriter( @@ -354,7 +350,8 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes try: await aiotools.shield_fg(self.__close_writer()) finally: - await aiotools.shield_fg(self.__remount_rw(False, fatal=False)) + if image: + await aiotools.shield_fg(image.remount_rw(False, fatal=False)) finally: # Между закрытием файла и эвентом айнотифи состояние может быть не обновлено, # так что форсим обновление вручную, чтобы получить актуальное состояние. @@ -371,12 +368,12 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes if self.__state.vd.image == image: self.__state.vd.image = None - await self.__remount_rw(True) + await image.remount_rw(True) try: image.remove(fatal=True) del self.__state.storage.images[name] finally: - await self.__remount_rw(False, fatal=False) + await image.remount_rw(False, fatal=False) # ===== @@ -468,8 +465,8 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes # Если только что включились и образ не подключен - попробовать # перемонтировать хранилище (и создать images и meta). logger.info("Probing to remount storage ...") - await self.__remount_rw(True) - await self.__remount_rw(False) + await self.__storage.remount_rw(True) + await self.__storage.remount_rw(False) await self.__setup_initial() storage_state = self.__get_storage_state() @@ -532,10 +529,3 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes cdrom=self.__drive.get_cdrom_flag(), rw=self.__drive.get_rw_flag(), ) - - # ===== - - async def __remount_rw(self, rw: bool, fatal: bool=True) -> None: - if not (await aiohelpers.remount("MSD", self.__remount_cmd, rw)): - if fatal: - raise MsdError("Can't execute remount helper") diff --git a/kvmd/plugins/msd/otg/storage.py b/kvmd/plugins/msd/otg/storage.py index 23d6cc60..2820c18d 100644 --- a/kvmd/plugins/msd/otg/storage.py +++ b/kvmd/plugins/msd/otg/storage.py @@ -27,6 +27,10 @@ from typing import Optional from ....logging import get_logger +from .... import aiohelpers + +from .. import MsdError + # ===== @dataclasses.dataclass(frozen=True) @@ -70,6 +74,10 @@ class Image(_Image): def exists(self) -> bool: return os.path.exists(self.path) + async def remount_rw(self, rw: bool, fatal: bool=True) -> None: + assert self.storage + await self.storage.remount_rw(rw, fatal) + def remove(self, fatal: bool) -> None: assert self.storage is not None try: @@ -103,8 +111,9 @@ class StorageSpace: class Storage: - def __init__(self, path: str) -> None: + def __init__(self, path: str, remount_cmd: list[str]) -> None: self.__path = path + self.__remount_cmd = remount_cmd def get_watchable_paths(self) -> list[str]: return [self.__path] @@ -146,3 +155,8 @@ class Storage: size=(st.f_blocks * st.f_frsize), free=(st.f_bavail * st.f_frsize), ) + + async def remount_rw(self, rw: bool, fatal: bool=True) -> None: + if not (await aiohelpers.remount("MSD", self.__remount_cmd, rw)): + if fatal: + raise MsdError("Can't execute remount helper") |