[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v4 03/10] vmdk: use unsigned values for on disk head
From: |
Fam Zheng |
Subject: |
[Qemu-devel] [PATCH v4 03/10] vmdk: use unsigned values for on disk header fields |
Date: |
Tue, 6 Aug 2013 15:44:48 +0800 |
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>
---
block/vmdk.c | 24 ++++++++++++------------
1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/block/vmdk.c b/block/vmdk.c
index 8b86fe9..5d11a43 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.3.4
- [Qemu-devel] [PATCH v4 00/10] vmdk: Input validation fixes, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 01/10] vmdk: remove ret from inner scope., Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 02/10] vmdk: Make VMDK3Header and VmdkGrainMarker QEMU_PACKED, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 03/10] vmdk: use unsigned values for on disk header fields,
Fam Zheng <=
- [Qemu-devel] [PATCH v4 04/10] qemu-iotests: add poke_file utility function, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 05/10] qemu-iotests: add empty test case for vmdk, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 06/10] vmdk: check granularity field in opening, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 07/10] vmdk: check l2 table size when opening, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 08/10] vmdk: check l1 size before opening image, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 09/10] vmdk: use heap allocation for whole_grain, Fam Zheng, 2013/08/06
- [Qemu-devel] [PATCH v4 10/10] vmdk: rename num_gtes_per_gte to num_gtes_per_gt, Fam Zheng, 2013/08/06