ddf19c
From 50127f0ff9e13a15fd5bfeb2662e2404ff20f364 Mon Sep 17 00:00:00 2001
ddf19c
From: Kevin Wolf <kwolf@redhat.com>
ddf19c
Date: Mon, 8 Jun 2020 15:01:31 +0100
ddf19c
Subject: [PATCH 03/17] block: Add flags to bdrv(_co)_truncate()
ddf19c
ddf19c
RH-Author: Kevin Wolf <kwolf@redhat.com>
ddf19c
Message-id: <20200608150140.38218-3-kwolf@redhat.com>
ddf19c
Patchwork-id: 97445
ddf19c
O-Subject: [RHEL-AV-8.2.1 qemu-kvm PATCH 02/11] block: Add flags to bdrv(_co)_truncate()
ddf19c
Bugzilla: 1780574
ddf19c
RH-Acked-by: Sergio Lopez Pascual <slp@redhat.com>
ddf19c
RH-Acked-by: Eric Blake <eblake@redhat.com>
ddf19c
RH-Acked-by: Max Reitz <mreitz@redhat.com>
ddf19c
ddf19c
Now that block drivers can support flags for .bdrv_co_truncate, expose
ddf19c
the parameter in the node level interfaces bdrv_co_truncate() and
ddf19c
bdrv_truncate().
ddf19c
ddf19c
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
ddf19c
Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
ddf19c
Reviewed-by: Alberto Garcia <berto@igalia.com>
ddf19c
Reviewed-by: Max Reitz <mreitz@redhat.com>
ddf19c
Message-Id: <20200424125448.63318-3-kwolf@redhat.com>
ddf19c
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
ddf19c
(cherry picked from commit 7b8e4857426f2e2de2441749996c6161b550bada)
ddf19c
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
ddf19c
Signed-off-by: Danilo C. L. de Paula <ddepaula@redhat.com>
ddf19c
---
ddf19c
 block/block-backend.c       |  2 +-
ddf19c
 block/crypto.c              |  2 +-
ddf19c
 block/io.c                  | 12 +++++++-----
ddf19c
 block/parallels.c           |  6 +++---
ddf19c
 block/qcow.c                |  4 ++--
ddf19c
 block/qcow2-refcount.c      |  2 +-
ddf19c
 block/qcow2.c               | 15 +++++++++------
ddf19c
 block/raw-format.c          |  2 +-
ddf19c
 block/vhdx-log.c            |  2 +-
ddf19c
 block/vhdx.c                |  2 +-
ddf19c
 block/vmdk.c                |  2 +-
ddf19c
 include/block/block.h       |  5 +++--
ddf19c
 tests/test-block-iothread.c |  6 +++---
ddf19c
 13 files changed, 34 insertions(+), 28 deletions(-)
ddf19c
ddf19c
diff --git a/block/block-backend.c b/block/block-backend.c
ddf19c
index 38ae413..8be2006 100644
ddf19c
--- a/block/block-backend.c
ddf19c
+++ b/block/block-backend.c
ddf19c
@@ -2144,7 +2144,7 @@ int blk_truncate(BlockBackend *blk, int64_t offset, bool exact,
ddf19c
         return -ENOMEDIUM;
ddf19c
     }
ddf19c
 
ddf19c
-    return bdrv_truncate(blk->root, offset, exact, prealloc, errp);
ddf19c
+    return bdrv_truncate(blk->root, offset, exact, prealloc, 0, errp);
ddf19c
 }
ddf19c
 
ddf19c
 int blk_save_vmstate(BlockBackend *blk, const uint8_t *buf,
ddf19c
diff --git a/block/crypto.c b/block/crypto.c
ddf19c
index 6e4b726..fcb4a97 100644
ddf19c
--- a/block/crypto.c
ddf19c
+++ b/block/crypto.c
ddf19c
@@ -313,7 +313,7 @@ block_crypto_co_truncate(BlockDriverState *bs, int64_t offset, bool exact,
ddf19c
 
ddf19c
     offset += payload_offset;
ddf19c
 
ddf19c
-    return bdrv_co_truncate(bs->file, offset, exact, prealloc, errp);
ddf19c
+    return bdrv_co_truncate(bs->file, offset, exact, prealloc, 0, errp);
ddf19c
 }
ddf19c
 
ddf19c
 static void block_crypto_close(BlockDriverState *bs)
ddf19c
diff --git a/block/io.c b/block/io.c
ddf19c
index 549e5a4..3235ce5 100644
ddf19c
--- a/block/io.c
ddf19c
+++ b/block/io.c
ddf19c
@@ -3315,12 +3315,12 @@ static void bdrv_parent_cb_resize(BlockDriverState *bs)
ddf19c
  * 'offset' bytes in length.
ddf19c
  */
ddf19c
 int coroutine_fn bdrv_co_truncate(BdrvChild *child, int64_t offset, bool exact,
ddf19c
-                                  PreallocMode prealloc, Error **errp)
ddf19c
+                                  PreallocMode prealloc, BdrvRequestFlags flags,
ddf19c
+                                  Error **errp)
ddf19c
 {
ddf19c
     BlockDriverState *bs = child->bs;
ddf19c
     BlockDriver *drv = bs->drv;
ddf19c
     BdrvTrackedRequest req;
ddf19c
-    BdrvRequestFlags flags = 0;
ddf19c
     int64_t old_size, new_bytes;
ddf19c
     int ret;
ddf19c
 
ddf19c
@@ -3378,7 +3378,7 @@ int coroutine_fn bdrv_co_truncate(BdrvChild *child, int64_t offset, bool exact,
ddf19c
         }
ddf19c
         ret = drv->bdrv_co_truncate(bs, offset, exact, prealloc, flags, errp);
ddf19c
     } else if (bs->file && drv->is_filter) {
ddf19c
-        ret = bdrv_co_truncate(bs->file, offset, exact, prealloc, errp);
ddf19c
+        ret = bdrv_co_truncate(bs->file, offset, exact, prealloc, flags, errp);
ddf19c
     } else {
ddf19c
         error_setg(errp, "Image format driver does not support resize");
ddf19c
         ret = -ENOTSUP;
ddf19c
@@ -3411,6 +3411,7 @@ typedef struct TruncateCo {
ddf19c
     int64_t offset;
ddf19c
     bool exact;
ddf19c
     PreallocMode prealloc;
ddf19c
+    BdrvRequestFlags flags;
ddf19c
     Error **errp;
ddf19c
     int ret;
ddf19c
 } TruncateCo;
ddf19c
@@ -3419,12 +3420,12 @@ static void coroutine_fn bdrv_truncate_co_entry(void *opaque)
ddf19c
 {
ddf19c
     TruncateCo *tco = opaque;
ddf19c
     tco->ret = bdrv_co_truncate(tco->child, tco->offset, tco->exact,
ddf19c
-                                tco->prealloc, tco->errp);
ddf19c
+                                tco->prealloc, tco->flags, tco->errp);
ddf19c
     aio_wait_kick();
ddf19c
 }
ddf19c
 
ddf19c
 int bdrv_truncate(BdrvChild *child, int64_t offset, bool exact,
ddf19c
-                  PreallocMode prealloc, Error **errp)
ddf19c
+                  PreallocMode prealloc, BdrvRequestFlags flags, Error **errp)
ddf19c
 {
ddf19c
     Coroutine *co;
ddf19c
     TruncateCo tco = {
ddf19c
@@ -3432,6 +3433,7 @@ int bdrv_truncate(BdrvChild *child, int64_t offset, bool exact,
ddf19c
         .offset     = offset,
ddf19c
         .exact      = exact,
ddf19c
         .prealloc   = prealloc,
ddf19c
+        .flags      = flags,
ddf19c
         .errp       = errp,
ddf19c
         .ret        = NOT_DONE,
ddf19c
     };
ddf19c
diff --git a/block/parallels.c b/block/parallels.c
ddf19c
index 6d4ed77..2be92cf 100644
ddf19c
--- a/block/parallels.c
ddf19c
+++ b/block/parallels.c
ddf19c
@@ -203,7 +203,7 @@ static int64_t allocate_clusters(BlockDriverState *bs, int64_t sector_num,
ddf19c
         } else {
ddf19c
             ret = bdrv_truncate(bs->file,
ddf19c
                                 (s->data_end + space) << BDRV_SECTOR_BITS,
ddf19c
-                                false, PREALLOC_MODE_OFF, NULL);
ddf19c
+                                false, PREALLOC_MODE_OFF, 0, NULL);
ddf19c
         }
ddf19c
         if (ret < 0) {
ddf19c
             return ret;
ddf19c
@@ -493,7 +493,7 @@ static int coroutine_fn parallels_co_check(BlockDriverState *bs,
ddf19c
              * That means we have to pass exact=true.
ddf19c
              */
ddf19c
             ret = bdrv_truncate(bs->file, res->image_end_offset, true,
ddf19c
-                                PREALLOC_MODE_OFF, &local_err);
ddf19c
+                                PREALLOC_MODE_OFF, 0, &local_err);
ddf19c
             if (ret < 0) {
ddf19c
                 error_report_err(local_err);
ddf19c
                 res->check_errors++;
ddf19c
@@ -889,7 +889,7 @@ static void parallels_close(BlockDriverState *bs)
ddf19c
 
ddf19c
         /* errors are ignored, so we might as well pass exact=true */
ddf19c
         bdrv_truncate(bs->file, s->data_end << BDRV_SECTOR_BITS, true,
ddf19c
-                      PREALLOC_MODE_OFF, NULL);
ddf19c
+                      PREALLOC_MODE_OFF, 0, NULL);
ddf19c
     }
ddf19c
 
ddf19c
     g_free(s->bat_dirty_bmap);
ddf19c
diff --git a/block/qcow.c b/block/qcow.c
ddf19c
index 8973e4e..6b5f226 100644
ddf19c
--- a/block/qcow.c
ddf19c
+++ b/block/qcow.c
ddf19c
@@ -480,7 +480,7 @@ static int get_cluster_offset(BlockDriverState *bs,
ddf19c
                     return -E2BIG;
ddf19c
                 }
ddf19c
                 ret = bdrv_truncate(bs->file, cluster_offset + s->cluster_size,
ddf19c
-                                    false, PREALLOC_MODE_OFF, NULL);
ddf19c
+                                    false, PREALLOC_MODE_OFF, 0, NULL);
ddf19c
                 if (ret < 0) {
ddf19c
                     return ret;
ddf19c
                 }
ddf19c
@@ -1035,7 +1035,7 @@ static int qcow_make_empty(BlockDriverState *bs)
ddf19c
             l1_length) < 0)
ddf19c
         return -1;
ddf19c
     ret = bdrv_truncate(bs->file, s->l1_table_offset + l1_length, false,
ddf19c
-                        PREALLOC_MODE_OFF, NULL);
ddf19c
+                        PREALLOC_MODE_OFF, 0, NULL);
ddf19c
     if (ret < 0)
ddf19c
         return ret;
ddf19c
 
ddf19c
diff --git a/block/qcow2-refcount.c b/block/qcow2-refcount.c
ddf19c
index f67ac6b..3a90d75 100644
ddf19c
--- a/block/qcow2-refcount.c
ddf19c
+++ b/block/qcow2-refcount.c
ddf19c
@@ -2017,7 +2017,7 @@ static int check_refblocks(BlockDriverState *bs, BdrvCheckResult *res,
ddf19c
                 }
ddf19c
 
ddf19c
                 ret = bdrv_truncate(bs->file, offset + s->cluster_size, false,
ddf19c
-                                    PREALLOC_MODE_OFF, &local_err);
ddf19c
+                                    PREALLOC_MODE_OFF, 0, &local_err);
ddf19c
                 if (ret < 0) {
ddf19c
                     error_report_err(local_err);
ddf19c
                     goto resize_fail;
ddf19c
diff --git a/block/qcow2.c b/block/qcow2.c
ddf19c
index 977445e..c0fdcb9 100644
ddf19c
--- a/block/qcow2.c
ddf19c
+++ b/block/qcow2.c
ddf19c
@@ -3082,7 +3082,7 @@ static int coroutine_fn preallocate_co(BlockDriverState *bs, uint64_t offset,
ddf19c
             mode = PREALLOC_MODE_OFF;
ddf19c
         }
ddf19c
         ret = bdrv_co_truncate(s->data_file, host_offset + cur_bytes, false,
ddf19c
-                               mode, errp);
ddf19c
+                               mode, 0, errp);
ddf19c
         if (ret < 0) {
ddf19c
             return ret;
ddf19c
         }
ddf19c
@@ -4044,7 +4044,7 @@ static int coroutine_fn qcow2_co_truncate(BlockDriverState *bs, int64_t offset,
ddf19c
              * always fulfilled, so there is no need to pass it on.)
ddf19c
              */
ddf19c
             bdrv_co_truncate(bs->file, (last_cluster + 1) * s->cluster_size,
ddf19c
-                             false, PREALLOC_MODE_OFF, &local_err);
ddf19c
+                             false, PREALLOC_MODE_OFF, 0, &local_err);
ddf19c
             if (local_err) {
ddf19c
                 warn_reportf_err(local_err,
ddf19c
                                  "Failed to truncate the tail of the image: ");
ddf19c
@@ -4066,7 +4066,8 @@ static int coroutine_fn qcow2_co_truncate(BlockDriverState *bs, int64_t offset,
ddf19c
              * file should be resized to the exact target size, too,
ddf19c
              * so we pass @exact here.
ddf19c
              */
ddf19c
-            ret = bdrv_co_truncate(s->data_file, offset, exact, prealloc, errp);
ddf19c
+            ret = bdrv_co_truncate(s->data_file, offset, exact, prealloc, 0,
ddf19c
+                                   errp);
ddf19c
             if (ret < 0) {
ddf19c
                 goto fail;
ddf19c
             }
ddf19c
@@ -4152,7 +4153,8 @@ static int coroutine_fn qcow2_co_truncate(BlockDriverState *bs, int64_t offset,
ddf19c
         new_file_size = allocation_start +
ddf19c
                         nb_new_data_clusters * s->cluster_size;
ddf19c
         /* Image file grows, so @exact does not matter */
ddf19c
-        ret = bdrv_co_truncate(bs->file, new_file_size, false, prealloc, errp);
ddf19c
+        ret = bdrv_co_truncate(bs->file, new_file_size, false, prealloc, 0,
ddf19c
+                               errp);
ddf19c
         if (ret < 0) {
ddf19c
             error_prepend(errp, "Failed to resize underlying file: ");
ddf19c
             qcow2_free_clusters(bs, allocation_start,
ddf19c
@@ -4255,7 +4257,8 @@ qcow2_co_pwritev_compressed_part(BlockDriverState *bs,
ddf19c
         if (len < 0) {
ddf19c
             return len;
ddf19c
         }
ddf19c
-        return bdrv_co_truncate(bs->file, len, false, PREALLOC_MODE_OFF, NULL);
ddf19c
+        return bdrv_co_truncate(bs->file, len, false, PREALLOC_MODE_OFF, 0,
ddf19c
+                                NULL);
ddf19c
     }
ddf19c
 
ddf19c
     if (offset_into_cluster(s, offset)) {
ddf19c
@@ -4493,7 +4496,7 @@ static int make_completely_empty(BlockDriverState *bs)
ddf19c
     }
ddf19c
 
ddf19c
     ret = bdrv_truncate(bs->file, (3 + l1_clusters) * s->cluster_size, false,
ddf19c
-                        PREALLOC_MODE_OFF, &local_err);
ddf19c
+                        PREALLOC_MODE_OFF, 0, &local_err);
ddf19c
     if (ret < 0) {
ddf19c
         error_report_err(local_err);
ddf19c
         goto fail;
ddf19c
diff --git a/block/raw-format.c b/block/raw-format.c
ddf19c
index f994c4a..c3acf9a 100644
ddf19c
--- a/block/raw-format.c
ddf19c
+++ b/block/raw-format.c
ddf19c
@@ -387,7 +387,7 @@ static int coroutine_fn raw_co_truncate(BlockDriverState *bs, int64_t offset,
ddf19c
 
ddf19c
     s->size = offset;
ddf19c
     offset += s->offset;
ddf19c
-    return bdrv_co_truncate(bs->file, offset, exact, prealloc, errp);
ddf19c
+    return bdrv_co_truncate(bs->file, offset, exact, prealloc, 0, errp);
ddf19c
 }
ddf19c
 
ddf19c
 static void raw_eject(BlockDriverState *bs, bool eject_flag)
ddf19c
diff --git a/block/vhdx-log.c b/block/vhdx-log.c
ddf19c
index 13a49c2..404fb5f 100644
ddf19c
--- a/block/vhdx-log.c
ddf19c
+++ b/block/vhdx-log.c
ddf19c
@@ -558,7 +558,7 @@ static int vhdx_log_flush(BlockDriverState *bs, BDRVVHDXState *s,
ddf19c
                     goto exit;
ddf19c
                 }
ddf19c
                 ret = bdrv_truncate(bs->file, new_file_size, false,
ddf19c
-                                    PREALLOC_MODE_OFF, NULL);
ddf19c
+                                    PREALLOC_MODE_OFF, 0, NULL);
ddf19c
                 if (ret < 0) {
ddf19c
                     goto exit;
ddf19c
                 }
ddf19c
diff --git a/block/vhdx.c b/block/vhdx.c
ddf19c
index 33e57cd..5dfbb20 100644
ddf19c
--- a/block/vhdx.c
ddf19c
+++ b/block/vhdx.c
ddf19c
@@ -1264,7 +1264,7 @@ static int vhdx_allocate_block(BlockDriverState *bs, BDRVVHDXState *s,
ddf19c
     }
ddf19c
 
ddf19c
     return bdrv_truncate(bs->file, *new_offset + s->block_size, false,
ddf19c
-                         PREALLOC_MODE_OFF, NULL);
ddf19c
+                         PREALLOC_MODE_OFF, 0, NULL);
ddf19c
 }
ddf19c
 
ddf19c
 /*
ddf19c
diff --git a/block/vmdk.c b/block/vmdk.c
ddf19c
index eb726f2..1bbf937 100644
ddf19c
--- a/block/vmdk.c
ddf19c
+++ b/block/vmdk.c
ddf19c
@@ -2077,7 +2077,7 @@ vmdk_co_pwritev_compressed(BlockDriverState *bs, uint64_t offset,
ddf19c
             }
ddf19c
             length = QEMU_ALIGN_UP(length, BDRV_SECTOR_SIZE);
ddf19c
             ret = bdrv_truncate(s->extents[i].file, length, false,
ddf19c
-                                PREALLOC_MODE_OFF, NULL);
ddf19c
+                                PREALLOC_MODE_OFF, 0, NULL);
ddf19c
             if (ret < 0) {
ddf19c
                 return ret;
ddf19c
             }
ddf19c
diff --git a/include/block/block.h b/include/block/block.h
ddf19c
index b2a3074..4913596 100644
ddf19c
--- a/include/block/block.h
ddf19c
+++ b/include/block/block.h
ddf19c
@@ -348,9 +348,10 @@ BlockDriverState *bdrv_find_backing_image(BlockDriverState *bs,
ddf19c
 void bdrv_refresh_filename(BlockDriverState *bs);
ddf19c
 
ddf19c
 int coroutine_fn bdrv_co_truncate(BdrvChild *child, int64_t offset, bool exact,
ddf19c
-                                  PreallocMode prealloc, Error **errp);
ddf19c
+                                  PreallocMode prealloc, BdrvRequestFlags flags,
ddf19c
+                                  Error **errp);
ddf19c
 int bdrv_truncate(BdrvChild *child, int64_t offset, bool exact,
ddf19c
-                  PreallocMode prealloc, Error **errp);
ddf19c
+                  PreallocMode prealloc, BdrvRequestFlags flags, Error **errp);
ddf19c
 
ddf19c
 int64_t bdrv_nb_sectors(BlockDriverState *bs);
ddf19c
 int64_t bdrv_getlength(BlockDriverState *bs);
ddf19c
diff --git a/tests/test-block-iothread.c b/tests/test-block-iothread.c
ddf19c
index 2f3b763..71e9bce 100644
ddf19c
--- a/tests/test-block-iothread.c
ddf19c
+++ b/tests/test-block-iothread.c
ddf19c
@@ -186,18 +186,18 @@ static void test_sync_op_truncate(BdrvChild *c)
ddf19c
     int ret;
ddf19c
 
ddf19c
     /* Normal success path */
ddf19c
-    ret = bdrv_truncate(c, 65536, false, PREALLOC_MODE_OFF, NULL);
ddf19c
+    ret = bdrv_truncate(c, 65536, false, PREALLOC_MODE_OFF, 0, NULL);
ddf19c
     g_assert_cmpint(ret, ==, 0);
ddf19c
 
ddf19c
     /* Early error: Negative offset */
ddf19c
-    ret = bdrv_truncate(c, -2, false, PREALLOC_MODE_OFF, NULL);
ddf19c
+    ret = bdrv_truncate(c, -2, false, PREALLOC_MODE_OFF, 0, NULL);
ddf19c
     g_assert_cmpint(ret, ==, -EINVAL);
ddf19c
 
ddf19c
     /* Error: Read-only image */
ddf19c
     c->bs->read_only = true;
ddf19c
     c->bs->open_flags &= ~BDRV_O_RDWR;
ddf19c
 
ddf19c
-    ret = bdrv_truncate(c, 65536, false, PREALLOC_MODE_OFF, NULL);
ddf19c
+    ret = bdrv_truncate(c, 65536, false, PREALLOC_MODE_OFF, 0, NULL);
ddf19c
     g_assert_cmpint(ret, ==, -EACCES);
ddf19c
 
ddf19c
     c->bs->read_only = false;
ddf19c
-- 
ddf19c
1.8.3.1
ddf19c