From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
To: Wen Congyang <wency@cn.fujitsu.com>
Cc: Kevin Wolf <kwolf@redhat.com>, Fam Zheng <famz@redhat.com>,
zhanghailiang <zhang.zhanghailiang@huawei.com>,
qemu block <qemu-block@nongnu.org>, Jeff Cody <jcody@redhat.com>,
Jiang Yunhong <yunhong.jiang@intel.com>,
Dong Eddie <eddie.dong@intel.com>,
qemu devel <qemu-devel@nongnu.org>,
"Michael R. Hines" <mrhines@linux.vnet.ibm.com>,
Max Reitz <mreitz@redhat.com>, Gonglei <arei.gonglei@huawei.com>,
Stefan Hajnoczi <stefanha@redhat.com>,
Paolo Bonzini <pbonzini@redhat.com>,
Yang Hongyang <yanghy@cn.fujitsu.com>
Subject: Re: [Qemu-devel] [PATCH COLO-BLOCK v8 09/18] Backup: clear all bitmap when doing block checkpoint
Date: Thu, 9 Jul 2015 02:28:23 +0100 [thread overview]
Message-ID: <20150709012822.GE2741@work-vm> (raw)
In-Reply-To: <1436258596-1253-10-git-send-email-wency@cn.fujitsu.com>
* Wen Congyang (wency@cn.fujitsu.com) wrote:
> Signed-off-by: Wen Congyang <wency@cn.fujitsu.com>
> Signed-off-by: zhanghailiang <zhang.zhanghailiang@huawei.com>
> Signed-off-by: Gonglei <arei.gonglei@huawei.com>
> Cc: Jeff Cody <jcody@redhat.com>
> ---
> block/backup.c | 13 +++++++++++++
> blockjob.c | 10 ++++++++++
> include/block/blockjob.h | 12 ++++++++++++
> 3 files changed, 35 insertions(+)
>
> diff --git a/block/backup.c b/block/backup.c
> index d3c7d9f..ebb8a88 100644
> --- a/block/backup.c
> +++ b/block/backup.c
> @@ -211,11 +211,24 @@ static void backup_iostatus_reset(BlockJob *job)
> bdrv_iostatus_reset(s->target);
> }
>
> +static void backup_do_checkpoint(BlockJob *job, Error **errp)
> +{
> + BackupBlockJob *backup_job = container_of(job, BackupBlockJob, common);
> +
> + if (backup_job->sync_mode != MIRROR_SYNC_MODE_NONE) {
> + error_setg(errp, "this feature or command is not currently supported");
You use this text in a few different errors in the block code; we've currently
got one test machine which is producing it and we haven't yet figured out
which one of the exit paths is doing it. Please make each one unique and state
an identifier; e.g. "checkpoint on block backup in sync ... for blockjob ..."
(I'm not sure what exaclty makes sense for block jobs - but something like that).
Dave
> + return;
> + }
> +
> + hbitmap_reset_all(backup_job->bitmap);
> +}
> +
> static const BlockJobDriver backup_job_driver = {
> .instance_size = sizeof(BackupBlockJob),
> .job_type = BLOCK_JOB_TYPE_BACKUP,
> .set_speed = backup_set_speed,
> .iostatus_reset = backup_iostatus_reset,
> + .do_checkpoint = backup_do_checkpoint,
> };
>
> static BlockErrorAction backup_error_action(BackupBlockJob *job,
> diff --git a/blockjob.c b/blockjob.c
> index ec46fad..cb412d1 100644
> --- a/blockjob.c
> +++ b/blockjob.c
> @@ -400,3 +400,13 @@ void block_job_defer_to_main_loop(BlockJob *job,
>
> qemu_bh_schedule(data->bh);
> }
> +
> +void block_job_do_checkpoint(BlockJob *job, Error **errp)
> +{
> + if (!job->driver->do_checkpoint) {
> + error_setg(errp, "this feature or command is not currently supported");
> + return;
> + }
> +
> + job->driver->do_checkpoint(job, errp);
> +}
> diff --git a/include/block/blockjob.h b/include/block/blockjob.h
> index 57d8ef1..b832dc3 100644
> --- a/include/block/blockjob.h
> +++ b/include/block/blockjob.h
> @@ -50,6 +50,9 @@ typedef struct BlockJobDriver {
> * manually.
> */
> void (*complete)(BlockJob *job, Error **errp);
> +
> + /** Optional callback for job types that support checkpoint. */
> + void (*do_checkpoint)(BlockJob *job, Error **errp);
> } BlockJobDriver;
>
> /**
> @@ -348,4 +351,13 @@ void block_job_defer_to_main_loop(BlockJob *job,
> BlockJobDeferToMainLoopFn *fn,
> void *opaque);
>
> +/**
> + * block_job_do_checkpoint:
> + * @job: The job.
> + * @errp: Error object.
> + *
> + * Do block checkpoint on the specified job.
> + */
> +void block_job_do_checkpoint(BlockJob *job, Error **errp);
> +
> #endif
> --
> 2.4.3
>
--
Dr. David Alan Gilbert / dgilbert@redhat.com / Manchester, UK
next prev parent reply other threads:[~2015-07-09 1:28 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-07 8:42 [Qemu-devel] [PATCH COLO-BLOCK v8 00/18] Block replication for continuous checkpoints Wen Congyang
2015-07-07 8:42 ` [Qemu-devel] [PATCH COLO-BLOCK v8 01/18] Add new block driver interface to add/delete a BDS's child Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 02/18] quorum: implement block driver interfaces " Wen Congyang
2015-08-05 12:19 ` Alberto Garcia
2015-08-06 3:15 ` Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 03/18] hmp: add monitor command to add/remove a child Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 04/18] introduce a new API qemu_opts_absorb_qdict_by_index() Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 05/18] quorum: allow ignoring child errors Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 06/18] introduce a new API to enable/disable attach device model Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 07/18] introduce a new API to check if blk is attached Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 08/18] block: make bdrv_put_ref_bh_schedule() as a public API Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 09/18] Backup: clear all bitmap when doing block checkpoint Wen Congyang
2015-07-09 1:28 ` Dr. David Alan Gilbert [this message]
2015-07-09 1:41 ` Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 10/18] allow writing to the backing file Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 11/18] Allow creating backup jobs when opening BDS Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 12/18] block: Allow references for backing files Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 13/18] docs: block replication's description Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 14/18] Add new block driver interfaces to control block replication Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 15/18] skip nbd_target when starting " Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 16/18] quorum: implement block driver interfaces for " Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 17/18] Implement new driver " Wen Congyang
2015-07-07 8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 18/18] Add a new API to start/stop replication, do checkpoint to all BDSes Wen Congyang
2015-07-28 4:01 ` [Qemu-devel] [PATCH COLO-BLOCK v8 00/18] Block replication for continuous checkpoints Wen Congyang
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=20150709012822.GE2741@work-vm \
--to=dgilbert@redhat.com \
--cc=arei.gonglei@huawei.com \
--cc=eddie.dong@intel.com \
--cc=famz@redhat.com \
--cc=jcody@redhat.com \
--cc=kwolf@redhat.com \
--cc=mreitz@redhat.com \
--cc=mrhines@linux.vnet.ibm.com \
--cc=pbonzini@redhat.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.com \
--cc=wency@cn.fujitsu.com \
--cc=yanghy@cn.fujitsu.com \
--cc=yunhong.jiang@intel.com \
--cc=zhang.zhanghailiang@huawei.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).