aboutsummaryrefslogtreecommitdiff
path: root/block.c
diff options
context:
space:
mode:
authorPeter Lieven <pl@kamp.de>2013-10-24 12:06:54 +0200
committerKevin Wolf <kwolf@redhat.com>2013-11-28 10:30:51 +0100
commit4ce786914b745a144a9eda1ea33f3ff98328c527 (patch)
tree2c20f0622ce18189318f265ab2224f7732b692fa /block.c
parente1a5c4bed44bc23f69f53883c657e31e150cab30 (diff)
downloadqemu-4ce786914b745a144a9eda1ea33f3ff98328c527.zip
qemu-4ce786914b745a144a9eda1ea33f3ff98328c527.tar.gz
qemu-4ce786914b745a144a9eda1ea33f3ff98328c527.tar.bz2
block: add wrappers for logical block provisioning information
This adds 2 wrappers to read the unallocated_blocks_are_zero and can_write_zeroes_with_unmap info from the BDI. The wrappers are required to check for the existence of a backing_hd and if the devices are opened with the correct flags. Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Peter Lieven <pl@kamp.de> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Diffstat (limited to 'block.c')
-rw-r--r--block.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/block.c b/block.c
index d34e974..3759582 100644
--- a/block.c
+++ b/block.c
@@ -3103,6 +3103,36 @@ int bdrv_has_zero_init(BlockDriverState *bs)
return 0;
}
+bool bdrv_unallocated_blocks_are_zero(BlockDriverState *bs)
+{
+ BlockDriverInfo bdi;
+
+ if (bs->backing_hd) {
+ return false;
+ }
+
+ if (bdrv_get_info(bs, &bdi) == 0) {
+ return bdi.unallocated_blocks_are_zero;
+ }
+
+ return false;
+}
+
+bool bdrv_can_write_zeroes_with_unmap(BlockDriverState *bs)
+{
+ BlockDriverInfo bdi;
+
+ if (bs->backing_hd || !(bs->open_flags & BDRV_O_UNMAP)) {
+ return false;
+ }
+
+ if (bdrv_get_info(bs, &bdi) == 0) {
+ return bdi.can_write_zeroes_with_unmap;
+ }
+
+ return false;
+}
+
typedef struct BdrvCoGetBlockStatusData {
BlockDriverState *bs;
BlockDriverState *base;