From: Peter Lieven <pl@kamp.de>
To: qemu-block@nongnu.org
Cc: qemu-devel@nongnu.org, kwolf@redhat.com, lersek@redhat.com,
den@openvz.org, mreitz@redhat.com, eblake@redhat.com,
berrange@redhat.com, Peter Lieven <pl@kamp.de>
Subject: [Qemu-devel] [PATCH V5 00/10] add Qcow2 compress format extension
Date: Tue, 25 Jul 2017 16:41:29 +0200 [thread overview]
Message-ID: <1500993699-19299-1-git-send-email-pl@kamp.de> (raw)
this adds a create option for Qcow2 images to specify the compression format
and level for compressed clusters. The series adds 2 algorithms to choose from:
zlib and lzo. zlib is the current default, but with unoptimal settings.
If no compress.format option is specified the old zlib with the old parameters
is used and the created images are backwards compatible with older QEMU version.
As soon as a compression format is specified a new compress format header extension
is written and the Qcow2 images are incompatible with older QEMU versions.
Some numbers for an uncompressed Debian 9 QCOW2 image (size 1148MB):
compress.format compress time compressed size decompress time
none 35.7s 339MB 3.4s
zlib (default) 30.5s 320MB 3.2s
zlib (level 1) 12.8s 348MB 3.2s
lzo 4.2s 429MB 1.6s
Changes V4->V5: (thanks to Eric for his various comments)
patch 1: rename format from zlib -> deflate
add windows size to header
define default values (deflate, level 0, window_size 12)
patch 2: move level param to Qcow2CompressDeflate
add window-size to Qcow2CompressDeflate
patch 3: set default values in the parameter check function, pass Qcow2Compress struct
patch 4: mention compress.window-size and the old default values
patch 5: use Qcow2Compress struct inside BDRVQcow2State
set default values (deflate/0/12) in qcow2_do_open
patch 9: fix docs/interop/qcow2.txt
Changes V3->V4:
- reduce the compress format name to 15 bytes [Eric]
- explain the default compression level for zlib [Eric]
- explain the difference between zlib with default compression
and the old default [Eric]
- added Patch 10
Changes V2->V3:
- rebase to current master (qcow2 crypto extension)
- patch 1: explicitly list valid format names, list valid compression levels,
remove extra_data and extra_data_size for now [Kevin]
- patch 2: don't hook the compression options in the blockdev-add options [Kevin, Daniel]
- patch 3: parse compress settings from the qapi struct [Daniel]
- patch 4: mention valid values for zlib, mention incompatiblity for QEMU < 2.10 [Kevin]
- patch 5: use qapi to parse the compress format from header [Daniel]
- added patch 6
Changes V1->V2:
- split the series into more patches
- added an qapi scheme for the compression settings
- renamed compression_algorithm to compress.format and added compress.level+
- updated the header extension to carry a variable extra payload and compress
level.
- removed extra reservations for header extensions
- added missing lzo_init and fixed compress overhead for lzo
Peter Lieven (10):
specs/qcow2: add compress format extension
qapi/block-core: add Qcow2Compress parameters
block/qcow2: parse compress create options
qemu-img: add documentation for compress settings
block/qcow2: read and write the compress format extension
block/qcow2: simplify ret usage in qcow2_create
block/qcow2: optimize qcow2_co_pwritev_compressed
block/qcow2: start using the compress format extension
block/qcow2: add lzo compress format
block/qcow2: add compress info to image specific info
block/qcow2-cluster.c | 73 ++++++++----
block/qcow2.c | 282 +++++++++++++++++++++++++++++++++++++++-------
block/qcow2.h | 21 +++-
configure | 2 +-
docs/interop/qcow2.txt | 53 ++++++++-
include/block/block_int.h | 39 ++++---
qapi/block-core.json | 55 ++++++++-
qemu-img.texi | 27 +++++
roms/ipxe | 2 +-
9 files changed, 461 insertions(+), 93 deletions(-)
--
1.9.1
next reply other threads:[~2017-07-25 14:41 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-07-25 14:41 Peter Lieven [this message]
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 01/10] specs/qcow2: add compress format extension Peter Lieven
2017-07-25 15:03 ` Eric Blake
2017-07-25 20:29 ` Peter Lieven
2017-07-25 21:01 ` Eric Blake
2017-09-11 14:22 ` Kevin Wolf
2017-09-18 10:09 ` Peter Lieven
2017-09-18 10:50 ` Kevin Wolf
2017-12-13 16:43 ` Peter Lieven
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 02/10] qapi/block-core: add Qcow2Compress parameters Peter Lieven
2017-07-25 21:21 ` Eric Blake
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 03/10] block/qcow2: parse compress create options Peter Lieven
2017-07-25 21:26 ` Eric Blake
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 04/10] qemu-img: add documentation for compress settings Peter Lieven
2017-07-25 21:34 ` Eric Blake
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 05/10] block/qcow2: read and write the compress format extension Peter Lieven
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 06/10] block/qcow2: simplify ret usage in qcow2_create Peter Lieven
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 07/10] block/qcow2: optimize qcow2_co_pwritev_compressed Peter Lieven
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 08/10] block/qcow2: start using the compress format extension Peter Lieven
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 09/10] block/qcow2: add lzo compress format Peter Lieven
2017-07-25 21:41 ` Eric Blake
2017-07-25 14:41 ` [Qemu-devel] [PATCH V5 10/10] block/qcow2: add compress info to image specific info Peter Lieven
2017-07-25 21:55 ` Eric Blake
2017-07-26 9:05 ` Peter Lieven
2017-08-03 18:59 ` Peter Lieven
2017-09-11 14:08 ` 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=1500993699-19299-1-git-send-email-pl@kamp.de \
--to=pl@kamp.de \
--cc=berrange@redhat.com \
--cc=den@openvz.org \
--cc=eblake@redhat.com \
--cc=kwolf@redhat.com \
--cc=lersek@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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).