From: "Benoît Canet" <benoit.canet@irqsave.net>
To: Liu Yuan <namei.unix@gmail.com>
Cc: Kevin Wolf <kwolf@redhat.com>,
sheepdog@lists.wpkg.org, qemu-devel@nongnu.org,
Stefan Hajnoczi <stefanha@redhat.com>
Subject: Re: [Qemu-devel] [PATCH 1/2] sheepdog: refactor do_sd_create()
Date: Tue, 29 Oct 2013 21:32:58 +0100 [thread overview]
Message-ID: <20131029203258.GD2948@irqsave.net> (raw)
In-Reply-To: <1383034655-12606-2-git-send-email-namei.unix@gmail.com>
>Le Tuesday 29 Oct 2013 à 16:17:34 (+0800), Liu Yuan a écrit :
> We can actually use BDRVSheepdogState *s to pass most of the parameters.
>
> Cc: Kevin Wolf <kwolf@redhat.com>
> Cc: Stefan Hajnoczi <stefanha@redhat.com>
> Signed-off-by: Liu Yuan <namei.unix@gmail.com>
> ---
> block/sheepdog.c | 37 +++++++++++++++----------------------
> 1 file changed, 15 insertions(+), 22 deletions(-)
>
> diff --git a/block/sheepdog.c b/block/sheepdog.c
> index 9f0757b..e66d2f8 100644
> --- a/block/sheepdog.c
> +++ b/block/sheepdog.c
> @@ -1348,9 +1348,7 @@ out:
> return ret;
> }
>
> -static int do_sd_create(BDRVSheepdogState *s, char *filename, int64_t vdi_size,
> - uint32_t base_vid, uint32_t *vdi_id, int snapshot,
> - uint8_t copy_policy)
> +static int do_sd_create(BDRVSheepdogState *s, uint32_t *vdi_id, int snapshot)
> {
> SheepdogVdiReq hdr;
> SheepdogVdiRsp *rsp = (SheepdogVdiRsp *)&hdr;
> @@ -1367,11 +1365,11 @@ static int do_sd_create(BDRVSheepdogState *s, char *filename, int64_t vdi_size,
> * does not fit in buf? For now, just truncate and avoid buffer overrun.
> */
> memset(buf, 0, sizeof(buf));
> - pstrcpy(buf, sizeof(buf), filename);
> + pstrcpy(buf, sizeof(buf), s->name);
>
> memset(&hdr, 0, sizeof(hdr));
> hdr.opcode = SD_OP_NEW_VDI;
> - hdr.vdi_id = base_vid;
> + hdr.vdi_id = s->inode.vdi_id;
>
> wlen = SD_MAX_VDI_LEN;
>
> @@ -1379,8 +1377,8 @@ static int do_sd_create(BDRVSheepdogState *s, char *filename, int64_t vdi_size,
> hdr.snapid = snapshot;
>
> hdr.data_length = wlen;
> - hdr.vdi_size = vdi_size;
> - hdr.copy_policy = copy_policy;
> + hdr.vdi_size = s->inode.vdi_size;
> + hdr.copy_policy = s->inode.copy_policy;
>
> ret = do_req(fd, (SheepdogReq *)&hdr, buf, &wlen, &rlen);
>
> @@ -1391,7 +1389,7 @@ static int do_sd_create(BDRVSheepdogState *s, char *filename, int64_t vdi_size,
> }
>
> if (rsp->result != SD_RES_SUCCESS) {
> - error_report("%s, %s", sd_strerror(rsp->result), filename);
> + error_report("%s, %s", sd_strerror(rsp->result), s->inode.name);
> return -EIO;
> }
>
> @@ -1452,23 +1450,21 @@ static int sd_create(const char *filename, QEMUOptionParameter *options,
> Error **errp)
> {
> int ret = 0;
> - uint32_t vid = 0, base_vid = 0;
> - int64_t vdi_size = 0;
> + uint32_t vid = 0;
> char *backing_file = NULL;
> BDRVSheepdogState *s;
> - char vdi[SD_MAX_VDI_LEN], tag[SD_MAX_VDI_TAG_LEN];
> + char tag[SD_MAX_VDI_TAG_LEN];
> uint32_t snapid;
> bool prealloc = false;
> Error *local_err = NULL;
>
> s = g_malloc0(sizeof(BDRVSheepdogState));
>
> - memset(vdi, 0, sizeof(vdi));
> memset(tag, 0, sizeof(tag));
> if (strstr(filename, "://")) {
> - ret = sd_parse_uri(s, filename, vdi, &snapid, tag);
> + ret = sd_parse_uri(s, filename, s->name, &snapid, tag);
> } else {
> - ret = parse_vdiname(s, filename, vdi, &snapid, tag);
> + ret = parse_vdiname(s, filename, s->name, &snapid, tag);
> }
> if (ret < 0) {
> goto out;
> @@ -1476,7 +1472,7 @@ static int sd_create(const char *filename, QEMUOptionParameter *options,
>
> while (options && options->name) {
> if (!strcmp(options->name, BLOCK_OPT_SIZE)) {
> - vdi_size = options->value.n;
> + s->inode.vdi_size = options->value.n;
> } else if (!strcmp(options->name, BLOCK_OPT_BACKING_FILE)) {
> backing_file = options->value.s;
> } else if (!strcmp(options->name, BLOCK_OPT_PREALLOC)) {
> @@ -1494,7 +1490,7 @@ static int sd_create(const char *filename, QEMUOptionParameter *options,
> options++;
> }
>
> - if (vdi_size > SD_MAX_VDI_SIZE) {
> + if (s->inode.vdi_size > SD_MAX_VDI_SIZE) {
> error_report("too big image size");
> ret = -EINVAL;
> goto out;
> @@ -1529,12 +1525,11 @@ static int sd_create(const char *filename, QEMUOptionParameter *options,
> goto out;
> }
>
> - base_vid = s->inode.vdi_id;
> bdrv_unref(bs);
> }
>
> /* TODO: allow users to specify copy number */
> - ret = do_sd_create(s, vdi, vdi_size, base_vid, &vid, 0, 0);
> + ret = do_sd_create(s, &vid, 0);
> if (!prealloc || ret) {
> goto out;
> }
> @@ -1723,8 +1718,7 @@ static int sd_create_branch(BDRVSheepdogState *s)
> * false bail out.
> */
> deleted = sd_delete(s);
> - ret = do_sd_create(s, s->name, s->inode.vdi_size, s->inode.vdi_id, &vid,
> - !deleted, s->inode.copy_policy);
> + ret = do_sd_create(s, &vid, !deleted);
> if (ret) {
> goto out;
> }
> @@ -2013,8 +2007,7 @@ static int sd_snapshot_create(BlockDriverState *bs, QEMUSnapshotInfo *sn_info)
> goto cleanup;
> }
>
> - ret = do_sd_create(s, s->name, s->inode.vdi_size, s->inode.vdi_id, &new_vid,
> - 1, s->inode.copy_policy);
> + ret = do_sd_create(s, &new_vid, 1);
> if (ret < 0) {
> error_report("failed to create inode for snapshot. %s",
> strerror(errno));
> --
> 1.7.9.5
>
>
Reviewed-by: Benoit Canet <benoit@irqsave.net>
next prev parent reply other threads:[~2013-10-29 20:33 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-10-29 8:17 [Qemu-devel] [PATCH 0/2] sheepdog: add user-defined redundancy option Liu Yuan
2013-10-29 8:17 ` [Qemu-devel] [PATCH 1/2] sheepdog: refactor do_sd_create() Liu Yuan
2013-10-29 20:32 ` Benoît Canet [this message]
2013-10-29 8:17 ` [Qemu-devel] [PATCH] sheepdog: support user-defined redundancy option Liu Yuan
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=20131029203258.GD2948@irqsave.net \
--to=benoit.canet@irqsave.net \
--cc=kwolf@redhat.com \
--cc=namei.unix@gmail.com \
--cc=qemu-devel@nongnu.org \
--cc=sheepdog@lists.wpkg.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).