]> git.proxmox.com Git - qemu.git/commitdiff
vvfat: Fix segfault on write to read-only disk
authorKevin Wolf <mail@kevin-wolf.de>
Fri, 10 Sep 2010 10:27:02 +0000 (12:27 +0200)
committerKevin Wolf <kwolf@redhat.com>
Mon, 13 Sep 2010 12:34:56 +0000 (14:34 +0200)
vvfat tries to set the readonly flag in its open function, but nowadays
this is overwritted with the readonly=... command line option. Check in
bdrv_write if the vvfat was opened read-only and return an error in this
case.

Without this check, vvfat tries to access the qcow bs, which is NULL
without enabled write support.

Signed-off-by: Kevin Wolf <mail@kevin-wolf.de>
(cherry picked from commit bfd0049440f53745d31eb93c208f0f3ab6308027)

block/vvfat.c

index 365332aa2124d5607eeef936746d59c11d8f450c..5898d664b04ec9bc77018b9898815501f1a41a0a 100644 (file)
@@ -2665,6 +2665,11 @@ static int vvfat_write(BlockDriverState *bs, int64_t sector_num,
 
 DLOG(checkpoint());
 
+    /* Check if we're operating in read-only mode */
+    if (s->qcow == NULL) {
+        return -EACCES;
+    }
+
     vvfat_close_current_file(s);
 
     /*