summaryrefslogtreecommitdiff
path: root/kvmd
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2022-07-24 09:34:27 +0300
committerMaxim Devaev <[email protected]>2022-07-24 09:34:27 +0300
commitd05b46e05d6a127948b168238450541e6836512d (patch)
tree468bbc65fcfaabd4f467d9fb04baf90427b91ed9 /kvmd
parent049ea642dc7b38761d6d3bb7fd1925384554cc7c (diff)
fixed lock behaviour in read_image()
Diffstat (limited to 'kvmd')
-rw-r--r--kvmd/plugins/msd/otg/__init__.py33
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