diff options
author | Maxim Devaev <[email protected]> | 2022-07-24 09:34:27 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2022-07-24 09:34:27 +0300 |
commit | d05b46e05d6a127948b168238450541e6836512d (patch) | |
tree | 468bbc65fcfaabd4f467d9fb04baf90427b91ed9 /kvmd | |
parent | 049ea642dc7b38761d6d3bb7fd1925384554cc7c (diff) |
fixed lock behaviour in read_image()
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/plugins/msd/otg/__init__.py | 33 |
1 files changed, 20 insertions, 13 deletions
diff --git a/kvmd/plugins/msd/otg/__init__.py b/kvmd/plugins/msd/otg/__init__.py index 962502cd..e26aac44 100644 --- a/kvmd/plugins/msd/otg/__init__.py +++ b/kvmd/plugins/msd/otg/__init__.py @@ -329,22 +329,29 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes @contextlib.asynccontextmanager async def read_image(self, name: str) -> AsyncGenerator[int, None]: - async with self.__state.busy(): - assert self.__state.storage - assert self.__state.vd + try: + async with self.__state._region: # pylint: disable=protected-access + try: + async with self.__state._lock: # pylint: disable=protected-access + await self.__notifier.notify() + assert self.__state.storage + assert self.__state.vd - if self.__state.vd.connected or self.__drive.get_image_path(): - raise MsdConnectedError() + if self.__state.vd.connected or self.__drive.get_image_path(): + raise MsdConnectedError() - path = os.path.join(self.__images_path, name) - if name not in self.__state.storage.images or not os.path.exists(path): - raise MsdUnknownImageError() + path = os.path.join(self.__images_path, name) + if name not in self.__state.storage.images or not os.path.exists(path): + raise MsdUnknownImageError() - try: - self.__reader = await MsdImageReader(path, self.__read_chunk_size).open() - yield self.__reader.get_size() - finally: - await self.__close_reader() + self.__reader = await MsdImageReader(path, self.__read_chunk_size).open() + + yield self.__reader.get_size() + + finally: + await self.__close_reader() + finally: + await self.__notifier.notify() async def read_image_chunk(self) -> bytes: assert self.__reader |