From: "Benoît Canet" <benoit.canet@irqsave.net>
To: Max Reitz <mreitz@redhat.com>
Cc: Kevin Wolf <kwolf@redhat.com>, Jun Li <junmuzi@gmail.com>,
juli@redhat.com, qemu-devel@nongnu.org,
Stefan Hajnoczi <stefanha@redhat.com>
Subject: Re: [Qemu-devel] [PATCH 1/2] qcow2: Drop REFCOUNT_SHIFT
Date: Mon, 1 Sep 2014 13:17:58 +0200 [thread overview]
Message-ID: <20140901111758.GP15537@irqsave.net> (raw)
In-Reply-To: <1409348727-17183-2-git-send-email-mreitz@redhat.com>
The Friday 29 Aug 2014 à 23:45:26 (+0200), Max Reitz wrote :
> With BDRVQcowState.refcount_block_bits, we don't need REFCOUNT_SHIFT
> anymore.
>
> Signed-off-by: Max Reitz <mreitz@redhat.com>
> ---
> block/qcow2-refcount.c | 32 ++++++++++++++------------------
> block/qcow2.c | 2 +-
> block/qcow2.h | 2 --
> 3 files changed, 15 insertions(+), 21 deletions(-)
>
> diff --git a/block/qcow2-refcount.c b/block/qcow2-refcount.c
> index 29136ee..cd6f5a0 100644
> --- a/block/qcow2-refcount.c
> +++ b/block/qcow2-refcount.c
> @@ -102,7 +102,7 @@ static int get_refcount(BlockDriverState *bs, int64_t cluster_index)
> uint16_t *refcount_block;
> uint16_t refcount;
>
> - refcount_table_index = cluster_index >> (s->cluster_bits - REFCOUNT_SHIFT);
> + refcount_table_index = cluster_index >> s->refcount_block_bits;
> if (refcount_table_index >= s->refcount_table_size)
> return 0;
> refcount_block_offset =
> @@ -116,8 +116,7 @@ static int get_refcount(BlockDriverState *bs, int64_t cluster_index)
> return ret;
> }
>
> - block_index = cluster_index &
> - ((1 << (s->cluster_bits - REFCOUNT_SHIFT)) - 1);
> + block_index = cluster_index & (s->refcount_block_size - 1);
> refcount = be16_to_cpu(refcount_block[block_index]);
>
> ret = qcow2_cache_put(bs, s->refcount_block_cache,
> @@ -152,8 +151,8 @@ static unsigned int next_refcount_table_size(BDRVQcowState *s,
> static int in_same_refcount_block(BDRVQcowState *s, uint64_t offset_a,
> uint64_t offset_b)
> {
> - uint64_t block_a = offset_a >> (2 * s->cluster_bits - REFCOUNT_SHIFT);
> - uint64_t block_b = offset_b >> (2 * s->cluster_bits - REFCOUNT_SHIFT);
> + uint64_t block_a = offset_a >> (s->cluster_bits + s->refcount_block_bits);
> + uint64_t block_b = offset_b >> (s->cluster_bits + s->refcount_block_bits);
>
> return (block_a == block_b);
> }
> @@ -174,7 +173,7 @@ static int alloc_refcount_block(BlockDriverState *bs,
> BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_ALLOC);
>
> /* Find the refcount block for the given cluster */
> - refcount_table_index = cluster_index >> (s->cluster_bits - REFCOUNT_SHIFT);
> + refcount_table_index = cluster_index >> s->refcount_block_bits;
>
> if (refcount_table_index < s->refcount_table_size) {
>
> @@ -243,7 +242,7 @@ static int alloc_refcount_block(BlockDriverState *bs,
>
> /* The block describes itself, need to update the cache */
> int block_index = (new_block >> s->cluster_bits) &
> - ((1 << (s->cluster_bits - REFCOUNT_SHIFT)) - 1);
> + (s->refcount_block_size - 1);
> (*refcount_block)[block_index] = cpu_to_be16(1);
> } else {
> /* Described somewhere else. This can recurse at most twice before we
> @@ -315,8 +314,7 @@ static int alloc_refcount_block(BlockDriverState *bs,
> BLKDBG_EVENT(bs->file, BLKDBG_REFTABLE_GROW);
>
> /* Calculate the number of refcount blocks needed so far */
> - uint64_t refcount_block_clusters = 1 << (s->cluster_bits - REFCOUNT_SHIFT);
> - uint64_t blocks_used = DIV_ROUND_UP(cluster_index, refcount_block_clusters);
> + uint64_t blocks_used = DIV_ROUND_UP(cluster_index, s->refcount_block_size);
>
> if (blocks_used > QCOW_MAX_REFTABLE_SIZE / sizeof(uint64_t)) {
> return -EFBIG;
> @@ -330,14 +328,14 @@ static int alloc_refcount_block(BlockDriverState *bs,
> uint64_t table_clusters =
> size_to_clusters(s, table_size * sizeof(uint64_t));
> blocks_clusters = 1 +
> - ((table_clusters + refcount_block_clusters - 1)
> - / refcount_block_clusters);
> + ((table_clusters + s->refcount_block_size - 1)
> + / s->refcount_block_size);
> uint64_t meta_clusters = table_clusters + blocks_clusters;
>
> last_table_size = table_size;
> table_size = next_refcount_table_size(s, blocks_used +
> - ((meta_clusters + refcount_block_clusters - 1)
> - / refcount_block_clusters));
> + ((meta_clusters + s->refcount_block_size - 1)
> + / s->refcount_block_size));
>
> } while (last_table_size != table_size);
>
> @@ -347,7 +345,7 @@ static int alloc_refcount_block(BlockDriverState *bs,
> #endif
>
> /* Create the new refcount table and blocks */
> - uint64_t meta_offset = (blocks_used * refcount_block_clusters) *
> + uint64_t meta_offset = (blocks_used * s->refcount_block_size) *
> s->cluster_size;
> uint64_t table_offset = meta_offset + blocks_clusters * s->cluster_size;
> uint64_t *new_table = g_try_new0(uint64_t, table_size);
> @@ -546,8 +544,7 @@ static int QEMU_WARN_UNUSED_RESULT update_refcount(BlockDriverState *bs,
> {
> int block_index, refcount;
> int64_t cluster_index = cluster_offset >> s->cluster_bits;
> - int64_t table_index =
> - cluster_index >> (s->cluster_bits - REFCOUNT_SHIFT);
> + int64_t table_index = cluster_index >> s->refcount_block_bits;
>
> /* Load the refcount block and allocate it if needed */
> if (table_index != old_table_index) {
> @@ -569,8 +566,7 @@ static int QEMU_WARN_UNUSED_RESULT update_refcount(BlockDriverState *bs,
> qcow2_cache_entry_mark_dirty(s->refcount_block_cache, refcount_block);
>
> /* we can update the count and save it */
> - block_index = cluster_index &
> - ((1 << (s->cluster_bits - REFCOUNT_SHIFT)) - 1);
> + block_index = cluster_index & (s->refcount_block_size - 1);
>
> refcount = be16_to_cpu(refcount_block[block_index]);
> refcount += addend;
> diff --git a/block/qcow2.c b/block/qcow2.c
> index 82bca88..cdbcb81 100644
> --- a/block/qcow2.c
> +++ b/block/qcow2.c
> @@ -1799,7 +1799,7 @@ static int qcow2_create2(const char *filename, int64_t total_size,
> .l1_size = cpu_to_be32(0),
> .refcount_table_offset = cpu_to_be64(cluster_size),
> .refcount_table_clusters = cpu_to_be32(1),
> - .refcount_order = cpu_to_be32(3 + REFCOUNT_SHIFT),
> + .refcount_order = cpu_to_be32(4),
> .header_length = cpu_to_be32(sizeof(*header)),
> };
>
> diff --git a/block/qcow2.h b/block/qcow2.h
> index 7c01fb7..5b099cb 100644
> --- a/block/qcow2.h
> +++ b/block/qcow2.h
> @@ -59,8 +59,6 @@
> /* The cluster reads as all zeros */
> #define QCOW_OFLAG_ZERO (1ULL << 0)
>
> -#define REFCOUNT_SHIFT 1 /* refcount size is 2 bytes */
> -
> #define MIN_CLUSTER_BITS 9
> #define MAX_CLUSTER_BITS 21
>
> --
> 2.1.0
>
>
Putting Jun Li in copy because he just wrote a patch using it.
next prev parent reply other threads:[~2014-09-01 11:18 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-08-29 21:45 [Qemu-devel] [PATCH 0/2] qcow2: Drop REFCOUNT_SHIFT Max Reitz
2014-08-29 21:45 ` [Qemu-devel] [PATCH 1/2] " Max Reitz
2014-08-29 23:06 ` Eric Blake
2014-09-01 11:17 ` Benoît Canet [this message]
2014-08-29 21:45 ` [Qemu-devel] [PATCH 2/2] docs/qcow2: Correct refcount_block_entries Max Reitz
2014-08-29 22:37 ` Eric Blake
2014-09-02 18:59 ` Max Reitz
2014-09-02 19:33 ` Eric Blake
2014-09-01 10:55 ` Benoît Canet
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=20140901111758.GP15537@irqsave.net \
--to=benoit.canet@irqsave.net \
--cc=juli@redhat.com \
--cc=junmuzi@gmail.com \
--cc=kwolf@redhat.com \
--cc=mreitz@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).