mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-27 04:13:53 -06:00
block-coroutine-wrapper: Add no_co_wrapper_bdrv_rdlock functions
Add a new wrapper type for GRAPH_RDLOCK functions that should be called from coroutine context. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Message-ID: <20230929145157.45443-3-kwolf@redhat.com> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
903df115aa
commit
e84c07bc73
2 changed files with 12 additions and 5 deletions
|
@ -87,8 +87,9 @@ class FuncDecl:
|
|||
raise ValueError(f"Invalid no_co function name: {self.name}")
|
||||
if not self.create_only_co:
|
||||
raise ValueError(f"no_co function can't be mixed: {self.name}")
|
||||
if self.graph_rdlock:
|
||||
raise ValueError(f"no_co function can't be rdlock: {self.name}")
|
||||
if self.graph_rdlock and self.graph_wrlock:
|
||||
raise ValueError("function can't be both rdlock and wrlock: "
|
||||
f"{self.name}")
|
||||
self.target_name = f'{subsystem}_{subname}'
|
||||
|
||||
self.ctx = self.gen_ctx()
|
||||
|
@ -256,7 +257,10 @@ def gen_no_co_wrapper(func: FuncDecl) -> str:
|
|||
|
||||
graph_lock=''
|
||||
graph_unlock=''
|
||||
if func.graph_wrlock:
|
||||
if func.graph_rdlock:
|
||||
graph_lock=' bdrv_graph_rdlock_main_loop();'
|
||||
graph_unlock=' bdrv_graph_rdunlock_main_loop();'
|
||||
elif func.graph_wrlock:
|
||||
graph_lock=' bdrv_graph_wrlock(NULL);'
|
||||
graph_unlock=' bdrv_graph_wrunlock();'
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue