OSDN Git Service

qemu-img: validate image length in img_map
authorEyal Moscovici <eyal.moscovici@oracle.com>
Wed, 13 May 2020 13:36:27 +0000 (16:36 +0300)
committerEric Blake <eblake@redhat.com>
Mon, 18 May 2020 16:02:05 +0000 (11:02 -0500)
The code handles this case correctly: we merely skip the loop. However it
is probably best to return an explicit error.

Reviewed-by: Eric Blake <eblake@redhat.com>
Acked-by: Mark Kanda <mark.kanda@oracle.com>
Signed-off-by: Eyal Moscovici <eyal.moscovici@oracle.com>
Message-Id: <20200513133629.18508-3-eyal.moscovici@oracle.com>
[eblake: commit message tweak]
Signed-off-by: Eric Blake <eblake@redhat.com>
qemu-img.c

index 5d824fc..c88f412 100644 (file)
@@ -3092,6 +3092,11 @@ static int img_map(int argc, char **argv)
     }
 
     length = blk_getlength(blk);
+    if (length < 0) {
+        error_report("Failed to get size for '%s'", filename);
+        return 1;
+    }
+
     while (curr.start + curr.length < length) {
         int64_t offset = curr.start + curr.length;
         int64_t n;