[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v6 07/14] block: distinguish between bdrv_create running in c
From: |
Vladimir Sementsov-Ogievskiy |
Subject: |
Re: [PATCH v6 07/14] block: distinguish between bdrv_create running in coroutine and not |
Date: |
Fri, 25 Nov 2022 21:03:29 +0300 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.2.2 |
On 11/25/22 16:35, Emanuele Giuseppe Esposito wrote:
Call two different functions depending on whether bdrv_create
is in coroutine or not, following the same pattern as
generated_co_wrapper functions.
This allows to also call the coroutine function directly,
without using CreateCo or relying in bdrv_create().
Signed-off-by: Emanuele Giuseppe Esposito <eesposit@redhat.com>
Reviewed-by: Kevin Wolf <kwolf@redhat.com>
---
block.c | 71 +++++++++++++++++++++++++++++----------------------------
1 file changed, 36 insertions(+), 35 deletions(-)
diff --git a/block.c b/block.c
index 9d51e7b6e5..2cf50b37c4 100644
--- a/block.c
+++ b/block.c
@@ -528,63 +528,64 @@ typedef struct CreateCo {
Error *err;
} CreateCo;
-static void coroutine_fn bdrv_create_co_entry(void *opaque)
+static int coroutine_fn bdrv_co_create(BlockDriver *drv, const char *filename,
+ QemuOpts *opts, Error **errp)
{
- Error *local_err = NULL;
int ret;
+ GLOBAL_STATE_CODE();
+ ERRP_GUARD();
+ assert(*errp == NULL);
+ assert(drv);
Why we need these two assertions? These are general assumptions, and we don't
assert it in all functions. Dereference of NULL will crash not worse than
assertion. I'd drop them.
+
+ if (!drv->bdrv_co_create_opts) {
+ error_setg(errp, "Driver '%s' does not support image creation",
+ drv->format_name);
+ return -ENOTSUP;
+ }
+
+ ret = drv->bdrv_co_create_opts(drv, filename, opts, errp);
and this empty line, looks accidental.
Offtopic: hope one day we fix *open* functions to always set errp on error
paths.
+ if (ret < 0 && !*errp) {
+ error_setg_errno(errp, -ret, "Could not create image");
+ }
+
+ return ret;
+}
+
+static void coroutine_fn bdrv_create_co_entry(void *opaque)
+{
CreateCo *cco = opaque;
- assert(cco->drv);
GLOBAL_STATE_CODE();
- ret = cco->drv->bdrv_co_create_opts(cco->drv,
- cco->filename, cco->opts, &local_err);
- error_propagate(&cco->err, local_err);
- cco->ret = ret;
+ cco->ret = bdrv_co_create(cco->drv, cco->filename, cco->opts, &cco->err);
We need aio_wait_kick() call here, like in other co_entry() functions.
Otherwise we may stuck in aio_poll()
with it:
Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
Hmm actually, we can simply merge this patch into patch 13 (and move 08 to be
after 13). Why to refactor bdrv_create twice?
--
Best regards,
Vladimir
- [PATCH v6 10/14] block-coroutine-wrapper.py: introduce co_wrapper, (continued)
- [PATCH v6 10/14] block-coroutine-wrapper.py: introduce co_wrapper, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 11/14] block-coroutine-wrapper.py: default to main loop aiocontext if function does not have a BlockDriverState parameter, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 01/14] block-io: introduce coroutine_fn duplicates for bdrv_common_block_status_above callers, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 02/14] block-copy: add missing coroutine_fn annotations, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 07/14] block: distinguish between bdrv_create running in coroutine and not, Emanuele Giuseppe Esposito, 2022/11/25
- Re: [PATCH v6 07/14] block: distinguish between bdrv_create running in coroutine and not,
Vladimir Sementsov-Ogievskiy <=
- [PATCH v6 13/14] block: convert bdrv_create to co_wrapper, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 12/14] block-coroutine-wrapper.py: support also basic return types, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 09/14] block: rename generated_co_wrapper in co_wrapper_mixed, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 08/14] block: bdrv_create_file is a coroutine_fn, Emanuele Giuseppe Esposito, 2022/11/25
- [PATCH v6 14/14] block/dirty-bitmap: convert coroutine-only functions to co_wrapper, Emanuele Giuseppe Esposito, 2022/11/25