From: Jeff Cody <jcody@redhat.com>
To: Bharata B Rao <bharata@linux.vnet.ibm.com>
Cc: kwolf@redhat.com, qemu-devel@nongnu.org, stefanha@redhat.com
Subject: Re: [Qemu-devel] [RFC PATCH v0 3/3] gluster: Add support for creating zero-filled image
Date: Wed, 4 Dec 2013 14:00:36 -0500 [thread overview]
Message-ID: <20131204190036.GC3780@localhost.localdomain> (raw)
In-Reply-To: <1385104578-19369-4-git-send-email-bharata@linux.vnet.ibm.com>
On Fri, Nov 22, 2013 at 12:46:18PM +0530, Bharata B Rao wrote:
> GlusterFS supports creation of zero-filled file on GlusterFS volume
> by means of an API called glfs_zerofill(). Use this API from QEMU to
> create an image that is filled with zeroes by using the preallocation
> option of qemu-img.
>
> qemu-img create gluster://server/volume/image -o preallocation=full 10G
>
> The allowed values for preallocation are 'full' and 'off'. By default
> preallocation is off and image is not zero-filled.
>
> glfs_zerofill() offloads the writing of zeroes to the server and if
> the storage supports SCSI WRITESAME, GlusterFS server can issue
> BLKZEROOUT ioctl to achieve the zeroing.
>
> Signed-off-by: Bharata B Rao <bharata@linux.vnet.ibm.com>
> ---
> block/gluster.c | 45 +++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 45 insertions(+)
>
> diff --git a/block/gluster.c b/block/gluster.c
> index 15f5dfb..2368997 100644
> --- a/block/gluster.c
> +++ b/block/gluster.c
> @@ -381,6 +381,29 @@ out:
> qemu_aio_release(acb);
> return ret;
> }
> +
> +static inline int gluster_supports_zerofill(void)
> +{
> + return 1;
> +}
> +
> +static inline int qemu_gluster_zerofill(struct glfs_fd *fd, int64_t offset,
> + int64_t size)
> +{
> + return glfs_zerofill(fd, offset, size);
> +}
> +
> +#else
> +static inline int gluster_supports_zerofill(void)
> +{
> + return 0;
> +}
> +
> +static inline int qemu_gluster_zerofill(struct glfs_fd *fd, int64_t offset,
> + int64_t size)
> +{
> + return 0;
> +}
> #endif
>
> static int qemu_gluster_create(const char *filename,
> @@ -389,6 +412,7 @@ static int qemu_gluster_create(const char *filename,
> struct glfs *glfs;
> struct glfs_fd *fd;
> int ret = 0;
> + int prealloc = 0;
> int64_t total_size = 0;
> GlusterConf *gconf = g_malloc0(sizeof(GlusterConf));
>
> @@ -401,6 +425,18 @@ static int qemu_gluster_create(const char *filename,
> while (options && options->name) {
> if (!strcmp(options->name, BLOCK_OPT_SIZE)) {
> total_size = options->value.n / BDRV_SECTOR_SIZE;
> + } else if (!strcmp(options->name, BLOCK_OPT_PREALLOC)) {
> + if (!options->value.s || !strcmp(options->value.s, "off")) {
> + prealloc = 0;
> + } else if (!strcmp(options->value.s, "full") &&
> + gluster_supports_zerofill()) {
> + prealloc = 1;
> + } else {
> + error_setg(errp, "Invalid preallocation mode: '%s'"
> + " or GlusterFS doesn't support zerofill API",
> + options->value.s);
> + return -EINVAL;
This leaks gconf. While probably not a huge deal for a .bdrv_create()
implementation, you should still set ret, and perform a 'goto out' here.
> + }
> }
> options++;
> }
> @@ -413,6 +449,10 @@ static int qemu_gluster_create(const char *filename,
> if (glfs_ftruncate(fd, total_size * BDRV_SECTOR_SIZE) != 0) {
> ret = -errno;
> }
> + if (prealloc && qemu_gluster_zerofill(fd, 0,
> + total_size * BDRV_SECTOR_SIZE)) {
> + ret = -errno;
> + }
> if (glfs_close(fd) != 0) {
> ret = -errno;
> }
> @@ -595,6 +635,11 @@ static QEMUOptionParameter qemu_gluster_create_options[] = {
> .type = OPT_SIZE,
> .help = "Virtual disk size"
> },
> + {
> + .name = BLOCK_OPT_PREALLOC,
> + .type = OPT_STRING,
> + .help = "Preallocation mode (allowed values: off, on)"
> + },
> { NULL }
> };
>
> --
> 1.7.11.7
>
>
prev parent reply other threads:[~2013-12-04 19:00 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-22 7:16 [Qemu-devel] [RFC PATCH v0 0/3] gluster: conversion to coroutines and supporting write_zeroes Bharata B Rao
2013-11-22 7:16 ` [Qemu-devel] [RFC PATCH v0 1/3] gluster: Convert aio routines into coroutines Bharata B Rao
2013-12-03 14:04 ` Stefan Hajnoczi
2013-12-05 10:42 ` Bharata B Rao
2013-11-22 7:16 ` [Qemu-devel] [RFC PATCH v0 2/3] gluster: Implement .bdrv_co_write_zeroes for gluster Bharata B Rao
2013-12-04 19:16 ` Jeff Cody
2013-12-05 10:45 ` Bharata B Rao
2013-11-22 7:16 ` [Qemu-devel] [RFC PATCH v0 3/3] gluster: Add support for creating zero-filled image Bharata B Rao
2013-12-04 19:00 ` Jeff Cody [this message]
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=20131204190036.GC3780@localhost.localdomain \
--to=jcody@redhat.com \
--cc=bharata@linux.vnet.ibm.com \
--cc=kwolf@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.com \
/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).