All of lore.kernel.org
 help / color / mirror / Atom feed
From: Kevin Wolf <kwolf@redhat.com>
To: qemu-block@nongnu.org
Cc: kwolf@redhat.com, mreitz@redhat.com, eblake@redhat.com,
	qemu-devel@nongnu.org
Subject: [Qemu-devel] [PATCH for-4.0? 2/4] qcow2: Fix preallocation bdrv_pwrite to wrong file
Date: Mon, 15 Apr 2019 17:54:50 +0200	[thread overview]
Message-ID: <20190415155452.5115-3-kwolf@redhat.com> (raw)
In-Reply-To: <20190415155452.5115-1-kwolf@redhat.com>

With an external data file, preallocate_co() must write the final byte
to the external data file, not to the qcow2 image file.

This is harmless for preallocation of newly created images (only the
qcow2 file size is increased to the virtual disk size while it should be
much smaller), but with preallocated resize, it could in theory cause
visible corruption if the metadata of the image is larger than the data
(e.g. lots of bitmaps).

Cc: qemu-stable@nongnu.org
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
---
 block/qcow2.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/block/qcow2.c b/block/qcow2.c
index c8400e9712..dfac74c264 100644
--- a/block/qcow2.c
+++ b/block/qcow2.c
@@ -2772,7 +2772,7 @@ static int coroutine_fn preallocate_co(BlockDriverState *bs, uint64_t offset,
      */
     if (host_offset != 0) {
         uint8_t data = 0;
-        ret = bdrv_pwrite(bs->file, (host_offset + cur_bytes) - 1,
+        ret = bdrv_pwrite(s->data_file, (host_offset + cur_bytes) - 1,
                           &data, 1);
         if (ret < 0) {
             return ret;
-- 
2.20.1

WARNING: multiple messages have this Message-ID (diff)
From: Kevin Wolf <kwolf@redhat.com>
To: qemu-block@nongnu.org
Cc: kwolf@redhat.com, qemu-devel@nongnu.org, mreitz@redhat.com
Subject: [Qemu-devel] [PATCH for-4.0? 2/4] qcow2: Fix preallocation bdrv_pwrite to wrong file
Date: Mon, 15 Apr 2019 17:54:50 +0200	[thread overview]
Message-ID: <20190415155452.5115-3-kwolf@redhat.com> (raw)
Message-ID: <20190415155450.ZQaITsbd0FTpGO390zmIN-8vElb_pLQeUbwqTCHWHj4@z> (raw)
In-Reply-To: <20190415155452.5115-1-kwolf@redhat.com>

With an external data file, preallocate_co() must write the final byte
to the external data file, not to the qcow2 image file.

This is harmless for preallocation of newly created images (only the
qcow2 file size is increased to the virtual disk size while it should be
much smaller), but with preallocated resize, it could in theory cause
visible corruption if the metadata of the image is larger than the data
(e.g. lots of bitmaps).

Cc: qemu-stable@nongnu.org
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
---
 block/qcow2.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/block/qcow2.c b/block/qcow2.c
index c8400e9712..dfac74c264 100644
--- a/block/qcow2.c
+++ b/block/qcow2.c
@@ -2772,7 +2772,7 @@ static int coroutine_fn preallocate_co(BlockDriverState *bs, uint64_t offset,
      */
     if (host_offset != 0) {
         uint8_t data = 0;
-        ret = bdrv_pwrite(bs->file, (host_offset + cur_bytes) - 1,
+        ret = bdrv_pwrite(s->data_file, (host_offset + cur_bytes) - 1,
                           &data, 1);
         if (ret < 0) {
             return ret;
-- 
2.20.1



  parent reply	other threads:[~2019-04-15 15:55 UTC|newest]

Thread overview: 20+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-04-15 15:54 [Qemu-devel] [PATCH 0/4] qcow2: Preallocation fixes Kevin Wolf
2019-04-15 15:54 ` Kevin Wolf
2019-04-15 15:54 ` [Qemu-devel] [PATCH 1/4] qcow2: Avoid COW during metadata preallocation Kevin Wolf
2019-04-15 15:54   ` Kevin Wolf
2019-04-15 16:14   ` Eric Blake
2019-04-15 16:14     ` Eric Blake
2019-04-15 15:54 ` Kevin Wolf [this message]
2019-04-15 15:54   ` [Qemu-devel] [PATCH for-4.0? 2/4] qcow2: Fix preallocation bdrv_pwrite to wrong file Kevin Wolf
2019-04-15 16:17   ` Eric Blake
2019-04-15 16:17     ` Eric Blake
2019-04-15 15:54 ` [Qemu-devel] [PATCH 3/4] qcow2: Add errp to preallocate_co() Kevin Wolf
2019-04-15 15:54   ` Kevin Wolf
2019-04-15 16:20   ` Eric Blake
2019-04-15 16:20     ` Eric Blake
2019-04-15 15:54 ` [Qemu-devel] [PATCH 4/4] qcow2: Fix full preallocation with external data file Kevin Wolf
2019-04-15 15:54   ` Kevin Wolf
2019-04-15 16:34   ` Eric Blake
2019-04-15 16:34     ` Eric Blake
2019-04-29  8:51 ` [Qemu-devel] [PATCH 0/4] qcow2: Preallocation fixes Kevin Wolf
2019-04-29  8:51   ` Kevin Wolf

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20190415155452.5115-3-kwolf@redhat.com \
    --to=kwolf@redhat.com \
    --cc=eblake@redhat.com \
    --cc=mreitz@redhat.com \
    --cc=qemu-block@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.