14.09.2021 20:15, Hanna Reitz wrote:
On 14.09.21 14:24, Vladimir Sementsov-Ogievskiy wrote:
Signed-off-by: Vladimir Sementsov-Ogievskiy <vsement...@virtuozzo.com>
Reviewed-by: Eric Blake <ebl...@redhat.com>
Tested-by: Kirill Tkhai <ktk...@virtuozzo.com>
Reviewed-by: Hanna Reitz <hre...@redhat.com>
---
block/qcow2.h | 1 +
block/qcow2-refcount.c | 12 +++++++++++-
2 files changed, 12 insertions(+), 1 deletion(-)
diff --git a/block/qcow2.h b/block/qcow2.h
index c0e1e83796..b8b1093b61 100644
--- a/block/qcow2.h
+++ b/block/qcow2.h
@@ -587,6 +587,7 @@ typedef enum QCow2MetadataOverlap {
#define L1E_OFFSET_MASK 0x00fffffffffffe00ULL
#define L2E_OFFSET_MASK 0x00fffffffffffe00ULL
+#define L2E_STD_RESERVED_MASK 0x3f000000000001feULL
#define REFT_OFFSET_MASK 0xfffffffffffffe00ULL
diff --git a/block/qcow2-refcount.c b/block/qcow2-refcount.c
index 9a5ae3cac4..5d57e677bc 100644
--- a/block/qcow2-refcount.c
+++ b/block/qcow2-refcount.c
@@ -1682,8 +1682,18 @@ static int check_refcounts_l2(BlockDriverState *bs,
BdrvCheckResult *res,
int csize;
l2_entry = get_l2_entry(s, l2_table, i);
l2_bitmap = get_l2_bitmap(s, l2_table, i);
+ QCow2ClusterType type = qcow2_get_cluster_type(bs, l2_entry);
Oh :(
Hm, with l2_bitmap being declared next to l2_entry, this is now the patch that
adds a declaration after a statement here.
(The possible resolutions seem to be the same, either move the declaration up
to the function’s root block, or move l2_entry and l2_bitmap’s declarations
here...)
(I don’t think we need a v5 for this, it should be fine if you tell me which
way you prefer.)
I'd keep type here:
QCow2ClusterType type;
l2_entry = ...
l2_bitmap = ...
type = qcow2_get_cluster_type(bs, l2_entry);
--
Best regards,
Vladimir