[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v2 2/5] vpc: Ignore geometry for large images
From: |
Peter Lieven |
Subject: |
[Qemu-devel] [PATCH v2 2/5] vpc: Ignore geometry for large images |
Date: |
Tue, 3 Mar 2015 11:41:53 +0100 |
From: Kevin Wolf <address@hidden>
The CHS calculation as done per the VHD spec imposes a maximum image
size of ~127 GB. Real VHD images exist that are larger than that.
Apparently there are two separate non-standard ways to achieve this:
You could use more heads than the spec does - this is the option that
qemu-img create chooses.
However, other images exist where the geometry is set to the maximum
(65535/16/255), but the actual image size is larger. Until now, such
images are truncated at 127 GB when opening them with qemu.
This patch changes the vpc driver to ignore geometry in this case and
only trust the size field in the header.
Signed-off-by: Kevin Wolf <address@hidden>
[PL: Fixed maximum geometry in the commit msg]
Signed-off-by: Peter Lieven <address@hidden>
---
block/vpc.c | 10 ++++------
1 file changed, 4 insertions(+), 6 deletions(-)
diff --git a/block/vpc.c b/block/vpc.c
index c8e17cb..1c9592c 100644
--- a/block/vpc.c
+++ b/block/vpc.c
@@ -215,12 +215,10 @@ static int vpc_open(BlockDriverState *bs, QDict *options,
int flags,
bs->total_sectors = (int64_t)
be16_to_cpu(footer->cyls) * footer->heads * footer->secs_per_cyl;
- /* images created with disk2vhd report a far higher virtual size
- * than expected with the cyls * heads * sectors_per_cyl formula.
- * use the footer->size instead if the image was created with
- * disk2vhd.
- */
- if (!strncmp(footer->creator_app, "d2v", 4)) {
+ /* Images that have exactly the maximum geometry are probably bigger and
+ * would be truncated if we adhered to the geometry for them. Rely on
+ * footer->size for them. */
+ if (bs->total_sectors == 65535ULL * 16 * 255) {
bs->total_sectors = be64_to_cpu(footer->size) / BDRV_SECTOR_SIZE;
}
--
1.9.1
- [Qemu-devel] [PATCH v2 0/5] block/vpc optimizations, Peter Lieven, 2015/03/03
- [Qemu-devel] [PATCH v2 4/5] block/vpc: rename footer->size -> footer->current_size, Peter Lieven, 2015/03/03
- [Qemu-devel] [PATCH v2 3/5] block/vpc: make calculate_geometry spec conform, Peter Lieven, 2015/03/03
- [Qemu-devel] [PATCH v2 1/5] block/vpc: optimize vpc_co_get_block_status, Peter Lieven, 2015/03/03
- [Qemu-devel] [PATCH v2 2/5] vpc: Ignore geometry for large images,
Peter Lieven <=
- [Qemu-devel] [PATCH v2 5/5] block/vpc: remove disabled code from get_sector_offset, Peter Lieven, 2015/03/03
- Re: [Qemu-devel] [PATCH v2 0/5] block/vpc optimizations, Max Reitz, 2015/03/03