[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PULL 07/14] vmdk: use unsigned values for on disk header f
From: |
Kevin Wolf |
Subject: |
[Qemu-devel] [PULL 07/14] vmdk: use unsigned values for on disk header fields |
Date: |
Tue, 6 Aug 2013 16:39:43 +0200 |
From: Fam Zheng <address@hidden>
The size and offset fields are all non-negative values, use uint64_t for
them to avoid getting negative in memory value by int overflow.
Signed-off-by: Fam Zheng <address@hidden>
Signed-off-by: Kevin Wolf <address@hidden>
---
block/vmdk.c | 24 ++++++++++++------------
1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/block/vmdk.c b/block/vmdk.c
index 5c3c240..2c925da 100644
--- a/block/vmdk.c
+++ b/block/vmdk.c
@@ -67,14 +67,14 @@ typedef struct {
typedef struct {
uint32_t version;
uint32_t flags;
- int64_t capacity;
- int64_t granularity;
- int64_t desc_offset;
- int64_t desc_size;
- int32_t num_gtes_per_gte;
- int64_t rgd_offset;
- int64_t gd_offset;
- int64_t grain_offset;
+ uint64_t capacity;
+ uint64_t granularity;
+ uint64_t desc_offset;
+ uint64_t desc_size;
+ uint32_t num_gtes_per_gte;
+ uint64_t rgd_offset;
+ uint64_t gd_offset;
+ uint64_t grain_offset;
char filler[1];
char check_bytes[4];
uint16_t compressAlgorithm;
@@ -109,7 +109,7 @@ typedef struct VmdkExtent {
typedef struct BDRVVmdkState {
CoMutex lock;
- int desc_offset;
+ uint64_t desc_offset;
bool cid_updated;
uint32_t parent_cid;
int num_extents;
@@ -490,7 +490,7 @@ static int vmdk_open_vmdk3(BlockDriverState *bs,
}
static int vmdk_open_desc_file(BlockDriverState *bs, int flags,
- int64_t desc_offset);
+ uint64_t desc_offset);
static int vmdk_open_vmdk4(BlockDriverState *bs,
BlockDriverState *file,
@@ -508,7 +508,7 @@ static int vmdk_open_vmdk4(BlockDriverState *bs,
return ret;
}
if (header.capacity == 0) {
- int64_t desc_offset = le64_to_cpu(header.desc_offset);
+ uint64_t desc_offset = le64_to_cpu(header.desc_offset);
if (desc_offset) {
return vmdk_open_desc_file(bs, flags, desc_offset << 9);
}
@@ -728,7 +728,7 @@ next_line:
}
static int vmdk_open_desc_file(BlockDriverState *bs, int flags,
- int64_t desc_offset)
+ uint64_t desc_offset)
{
int ret;
char *buf = NULL;
--
1.8.1.4
- [Qemu-devel] [PULL 00/14] Block fixes for 1.6, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 02/14] ignore SIGPIPE in qemu-img and qemu-io, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 03/14] iov: handle EOF in iov_send_recv, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 01/14] qemu-img: Error out for excess arguments, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 05/14] sheepdog: add missing .bdrv_has_zero_init, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 04/14] qemu-iotests: filter QEMU version in monitor banner, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 09/14] qemu-iotests: add empty test case for vmdk, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 07/14] vmdk: use unsigned values for on disk header fields,
Kevin Wolf <=
- [Qemu-devel] [PULL 08/14] qemu-iotests: add poke_file utility function, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 11/14] vmdk: check l2 table size when opening, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 12/14] vmdk: check l1 size before opening image, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 14/14] vmdk: rename num_gtes_per_gte to num_gtes_per_gt, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 13/14] vmdk: use heap allocation for whole_grain, Kevin Wolf, 2013/08/06
- [Qemu-devel] [PULL 10/14] vmdk: check granularity field in opening, Kevin Wolf, 2013/08/06