[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 1/2] qed: check for header size overflow
From: |
Stefan Hajnoczi |
Subject: |
[Qemu-devel] [PATCH 1/2] qed: check for header size overflow |
Date: |
Mon, 12 Jan 2015 12:31:32 +0000 |
Header size is denoted in clusters. The maximum cluster size is 64 MB
but there is no limit on header size. Check for uint32_t overflow in
case the header size field has a whacky value.
Signed-off-by: Stefan Hajnoczi <address@hidden>
---
block/qed.c | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/block/qed.c b/block/qed.c
index 80f18d8..d2c6045 100644
--- a/block/qed.c
+++ b/block/qed.c
@@ -440,6 +440,12 @@ static int bdrv_qed_open(BlockDriverState *bs, QDict
*options, int flags,
s->l2_mask = s->table_nelems - 1;
s->l1_shift = s->l2_shift + ffs(s->table_nelems) - 1;
+ /* Header size calculation must not overflow uint32_t */
+ if ((uint64_t)s->header.cluster_size * s->header.header_size !=
+ s->header.cluster_size * s->header.header_size) {
+ return -EINVAL;
+ }
+
if ((s->header.features & QED_F_BACKING_FILE)) {
if ((uint64_t)s->header.backing_filename_offset +
s->header.backing_filename_size >
--
2.1.0