diff options
author | Kevin Wolf | 2012-12-07 18:08:42 +0100 |
---|---|---|
committer | Kevin Wolf | 2012-12-13 15:37:59 +0100 |
commit | 1d3afd649bc77aa14bc2741e2da6475822d41c5f (patch) | |
tree | 48d6c4f5fb3371a92b9e9c824e133cd121fa808f /block/qcow2-cluster.c | |
parent | atapi: reset cdrom tray statuses on ide_reset (diff) | |
download | qemu-1d3afd649bc77aa14bc2741e2da6475822d41c5f.tar.gz qemu-1d3afd649bc77aa14bc2741e2da6475822d41c5f.tar.xz qemu-1d3afd649bc77aa14bc2741e2da6475822d41c5f.zip |
qcow2: Round QCowL2Meta.offset down to cluster boundary
The offset within the cluster is already present as n_start and this is
what the code uses. QCowL2Meta.offset is only needed at a cluster
granularity.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'block/qcow2-cluster.c')
-rw-r--r-- | block/qcow2-cluster.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/block/qcow2-cluster.c b/block/qcow2-cluster.c index e179211c57..d17a37c2fa 100644 --- a/block/qcow2-cluster.c +++ b/block/qcow2-cluster.c @@ -631,7 +631,7 @@ int qcow2_alloc_cluster_link_l2(BlockDriverState *bs, QCowL2Meta *m) old_cluster = g_malloc(m->nb_clusters * sizeof(uint64_t)); /* copy content of unmodified sectors */ - start_sect = (m->offset & ~(s->cluster_size - 1)) >> 9; + start_sect = m->offset >> 9; if (m->n_start) { cow = true; qemu_co_mutex_unlock(&s->lock); @@ -966,7 +966,7 @@ again: .cluster_offset = keep_clusters == 0 ? alloc_cluster_offset : cluster_offset, .alloc_offset = alloc_cluster_offset, - .offset = alloc_offset, + .offset = alloc_offset & ~(s->cluster_size - 1), .n_start = keep_clusters == 0 ? n_start : 0, .nb_clusters = nb_clusters, .nb_available = MIN(requested_sectors, avail_sectors), |