From: Kevin Wolf <kwolf@redhat.com>
To: Daniel Henrique Barboza <danielhb413@gmail.com>
Cc: "Daniel P . Berrangé" <berrange@redhat.com>,
jsnow@redhat.com, qemu-devel@nongnu.org
Subject: Re: [PATCH v7 1/4] block: introducing 'bdrv_co_delete_file' interface
Date: Fri, 18 Oct 2019 14:24:36 +0200 [thread overview]
Message-ID: <20191018122436.GD6122@localhost.localdomain> (raw)
In-Reply-To: <20190903135708.21624-2-danielhb413@gmail.com>
Am 03.09.2019 um 15:57 hat Daniel Henrique Barboza geschrieben:
> Adding to Block Drivers the capability of being able to clean up
> its created files can be useful in certain situations. For the
> LUKS driver, for instance, a failure in one of its authentication
> steps can leave files in the host that weren't there before.
>
> This patch adds the 'bdrv_co_delete_file' interface to block
> drivers and add it to the 'file' driver in file-posix.c.The
Missing space between "file-posix.c.The"
> implementation is given by 'raw_co_delete_file'.
>
> Suggested-by: Daniel P. Berrangé <berrange@redhat.com>
> Signed-off-by: Daniel Henrique Barboza <danielhb413@gmail.com>
> ---
> block/file-posix.c | 28 ++++++++++++++++++++++++++++
> include/block/block_int.h | 6 ++++++
> 2 files changed, 34 insertions(+)
>
> diff --git a/block/file-posix.c b/block/file-posix.c
> index fbeb0068db..52756de522 100644
> --- a/block/file-posix.c
> +++ b/block/file-posix.c
> @@ -2390,6 +2390,33 @@ static int coroutine_fn raw_co_create_opts(const char *filename, QemuOpts *opts,
> return raw_co_create(&options, errp);
> }
>
> +/**
> + * Co-routine function that erases a regular file.
> + */
We don't have function comments for other BdrvDriver callbacks. It may
be appropriate to have a comment when there is something special going
on here that differs from a normal implementation. But this specific
comment is even redundant with the function name, so I think we don't
need it.
> +static int coroutine_fn raw_co_delete_file(BlockDriverState *bs,
> + Error **errp)
> +{
> + struct stat st;
> + int ret;
> +
> + if (!(stat(bs->filename, &st) == 0) || !S_ISREG(st.st_mode)) {
> + ret = -ENOENT;
> + error_setg_errno(errp, -ret, "%s is not a regular file",
> + bs->filename);
> + goto done;
There is no cleanup code, so a direct return -ENOENT would be simpler.
> + }
> +
> + ret = unlink(bs->filename);
> + if (ret < 0) {
> + ret = -errno;
> + error_setg_errno(errp, -ret, "Error when deleting file %s",
> + bs->filename);
> + }
> +
> +done:
> + return ret;
> +}
> +
> /*
> * Find allocation range in @bs around offset @start.
> * May change underlying file descriptor's file offset.
> @@ -2942,6 +2969,7 @@ BlockDriver bdrv_file = {
> .bdrv_co_block_status = raw_co_block_status,
> .bdrv_co_invalidate_cache = raw_co_invalidate_cache,
> .bdrv_co_pwrite_zeroes = raw_co_pwrite_zeroes,
> + .bdrv_co_delete_file = raw_co_delete_file,
>
> .bdrv_co_preadv = raw_co_preadv,
> .bdrv_co_pwritev = raw_co_pwritev,
> diff --git a/include/block/block_int.h b/include/block/block_int.h
> index 0422acdf1c..a959ec2d1e 100644
> --- a/include/block/block_int.h
> +++ b/include/block/block_int.h
> @@ -314,6 +314,12 @@ struct BlockDriver {
> */
> int coroutine_fn (*bdrv_co_flush)(BlockDriverState *bs);
>
> + /*
> + * Delete a local created file.
> + */
No reason to restrict this to "local", even if for now file-posix is the
only driver that implements it. This can change later.
The comment fits in a single line.
> + int coroutine_fn (*bdrv_co_delete_file)(BlockDriverState *bs,
> + Error **errp);
> +
Kevin
next prev parent reply other threads:[~2019-10-18 12:25 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-09-03 13:57 [Qemu-devel] [PATCH v7 0/4] delete created files when block_crypto_co_create_opts_luks fails Daniel Henrique Barboza
2019-09-03 13:57 ` [Qemu-devel] [PATCH v7 1/4] block: introducing 'bdrv_co_delete_file' interface Daniel Henrique Barboza
2019-10-18 12:24 ` Kevin Wolf [this message]
2019-09-03 13:57 ` [Qemu-devel] [PATCH v7 2/4] block.c: adding bdrv_delete_file Daniel Henrique Barboza
2019-10-18 12:37 ` Kevin Wolf
2019-09-03 13:57 ` [Qemu-devel] [PATCH v7 3/4] crypto.c: cleanup created file when block_crypto_co_create_opts_luks fails Daniel Henrique Barboza
2019-10-18 12:42 ` Kevin Wolf
2019-09-03 13:57 ` [Qemu-devel] [PATCH v7 4/4] qemu-iotests: adding LUKS cleanup for non-UTF8 secret error Daniel Henrique Barboza
2019-10-17 17:42 ` [PATCH v7 0/4] delete created files when block_crypto_co_create_opts_luks fails Daniel Henrique Barboza
2019-10-17 17:48 ` Daniel Henrique Barboza
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20191018122436.GD6122@localhost.localdomain \
--to=kwolf@redhat.com \
--cc=berrange@redhat.com \
--cc=danielhb413@gmail.com \
--cc=jsnow@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.