summaryrefslogtreecommitdiffstats
path: root/block.c
diff options
context:
space:
mode:
authorDaniel Henrique Barboza2020-01-30 22:39:05 +0100
committerKevin Wolf2020-03-11 15:54:38 +0100
commite1d7f8bb1ec0c6911dcea81641ce6139dbded02d (patch)
tree75543ff6a5a7d2191d600f12ad00a20595835380 /block.c
parentblock: introducing 'bdrv_co_delete_file' interface (diff)
downloadqemu-e1d7f8bb1ec0c6911dcea81641ce6139dbded02d.tar.gz
qemu-e1d7f8bb1ec0c6911dcea81641ce6139dbded02d.tar.xz
qemu-e1d7f8bb1ec0c6911dcea81641ce6139dbded02d.zip
block.c: adding bdrv_co_delete_file
Using the new 'bdrv_co_delete_file' interface, a pure co_routine function 'bdrv_co_delete_file' inside block.c can can be used in a way similar of the existing bdrv_create_file to to clean up a created file. We're creating a pure co_routine because the only caller of 'bdrv_co_delete_file' will be already in co_routine context, thus there is no need to add all the machinery to check for qemu_in_coroutine() and create a separated co_routine to do the job. Suggested-by: Daniel P. Berrangé <berrange@redhat.com> Signed-off-by: Daniel Henrique Barboza <danielhb413@gmail.com> Message-Id: <20200130213907.2830642-3-danielhb413@gmail.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'block.c')
-rw-r--r--block.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/block.c b/block.c
index 8fc7b56937..a2542c977b 100644
--- a/block.c
+++ b/block.c
@@ -668,6 +668,32 @@ int bdrv_create_file(const char *filename, QemuOpts *opts, Error **errp)
}
}
+int coroutine_fn bdrv_co_delete_file(BlockDriverState *bs, Error **errp)
+{
+ Error *local_err = NULL;
+ int ret;
+
+ assert(bs != NULL);
+
+ if (!bs->drv) {
+ error_setg(errp, "Block node '%s' is not opened", bs->filename);
+ return -ENOMEDIUM;
+ }
+
+ if (!bs->drv->bdrv_co_delete_file) {
+ error_setg(errp, "Driver '%s' does not support image deletion",
+ bs->drv->format_name);
+ return -ENOTSUP;
+ }
+
+ ret = bs->drv->bdrv_co_delete_file(bs, &local_err);
+ if (ret < 0) {
+ error_propagate(errp, local_err);
+ }
+
+ return ret;
+}
+
/**
* Try to get @bs's logical and physical block size.
* On success, store them in @bsz struct and return 0.