Re: [Qemu-devel] [PATCH 3/7] Replication/Blockjobs: Create replication jobs as internal
On Thu, Oct 13, 2016 at 06:56:58PM -0400, John Snow wrote: > Bubble up the internal interface to commit and backup jobs, then switch > replication tasks over to using this methodology. > > Signed-off-by: John Snow > --- > block/backup.c| 3 ++- > block/mirror.c| 21 ++--- > block/replication.c | 14 +++--- > blockdev.c| 11 +++ > include/block/block_int.h | 9 +++-- > qemu-img.c| 5 +++-- > 6 files changed, 36 insertions(+), 27 deletions(-) > > diff --git a/block/backup.c b/block/backup.c > index 5acb5c4..6a60ca8 100644 > --- a/block/backup.c > +++ b/block/backup.c > @@ -527,6 +527,7 @@ void backup_start(const char *job_id, BlockDriverState > *bs, >bool compress, >BlockdevOnError on_source_error, >BlockdevOnError on_target_error, > + int creation_flags, >BlockCompletionFunc *cb, void *opaque, >BlockJobTxn *txn, Error **errp) > { > @@ -596,7 +597,7 @@ void backup_start(const char *job_id, BlockDriverState > *bs, > } > > job = block_job_create(job_id, &backup_job_driver, bs, speed, > - BLOCK_JOB_DEFAULT, cb, opaque, errp); > + creation_flags, cb, opaque, errp); > if (!job) { > goto error; > } > diff --git a/block/mirror.c b/block/mirror.c > index 74c03ae..15d2d10 100644 > --- a/block/mirror.c > +++ b/block/mirror.c > @@ -906,9 +906,9 @@ static const BlockJobDriver commit_active_job_driver = { > }; > > static void mirror_start_job(const char *job_id, BlockDriverState *bs, > - BlockDriverState *target, const char *replaces, > - int64_t speed, uint32_t granularity, > - int64_t buf_size, > + int creation_flags, BlockDriverState *target, > + const char *replaces, int64_t speed, > + uint32_t granularity, int64_t buf_size, > BlockMirrorBackingMode backing_mode, > BlockdevOnError on_source_error, > BlockdevOnError on_target_error, > @@ -936,8 +936,8 @@ static void mirror_start_job(const char *job_id, > BlockDriverState *bs, > buf_size = DEFAULT_MIRROR_BUF_SIZE; > } > > -s = block_job_create(job_id, driver, bs, speed, > - BLOCK_JOB_DEFAULT, cb, opaque, errp); > +s = block_job_create(job_id, driver, bs, speed, creation_flags, > + cb, opaque, errp); > if (!s) { > return; > } > @@ -992,17 +992,16 @@ void mirror_start(const char *job_id, BlockDriverState > *bs, > } > is_none_mode = mode == MIRROR_SYNC_MODE_NONE; > base = mode == MIRROR_SYNC_MODE_TOP ? backing_bs(bs) : NULL; > -mirror_start_job(job_id, bs, target, replaces, > +mirror_start_job(job_id, bs, BLOCK_JOB_DEFAULT, target, replaces, > speed, granularity, buf_size, backing_mode, > on_source_error, on_target_error, unmap, cb, opaque, > errp, > &mirror_job_driver, is_none_mode, base, false); > } > > void commit_active_start(const char *job_id, BlockDriverState *bs, > - BlockDriverState *base, int64_t speed, > - BlockdevOnError on_error, > - BlockCompletionFunc *cb, > - void *opaque, Error **errp, > + BlockDriverState *base, int creation_flags, > + int64_t speed, BlockdevOnError on_error, > + BlockCompletionFunc *cb, void *opaque, Error **errp, > bool auto_complete) > { > int64_t length, base_length; > @@ -1041,7 +1040,7 @@ void commit_active_start(const char *job_id, > BlockDriverState *bs, > } > } > > -mirror_start_job(job_id, bs, base, NULL, speed, 0, 0, > +mirror_start_job(job_id, bs, creation_flags, base, NULL, speed, 0, 0, > MIRROR_LEAVE_BACKING_CHAIN, > on_error, on_error, false, cb, opaque, &local_err, > &commit_active_job_driver, false, base, auto_complete); > diff --git a/block/replication.c b/block/replication.c > index 3bd1cf1..d4f4a7b 100644 > --- a/block/replication.c > +++ b/block/replication.c > @@ -496,10 +496,11 @@ static void replication_start(ReplicationState *rs, > ReplicationMode mode, > bdrv_op_block_all(top_bs, s->blocker); > bdrv_op_unblock(top_bs, BLOCK_OP_TYPE_DATAPLANE, s->blocker); > > -backup_start("replication-backup", s->secondary_disk->bs, > - s->hidden_disk->bs, 0, MIRROR_SYNC_MODE_NONE, NULL, > false, > +backup_start(NULL, s->secondary_disk->bs, s-
Re: [Qemu-devel] [PATCH 3/7] Replication/Blockjobs: Create replication jobs as internal
Am 14.10.2016 um 00:56 hat John Snow geschrieben: > Bubble up the internal interface to commit and backup jobs, then switch > replication tasks over to using this methodology. > > Signed-off-by: John Snow Reviewed-by: Kevin Wolf
[Qemu-devel] [PATCH 3/7] Replication/Blockjobs: Create replication jobs as internal
Bubble up the internal interface to commit and backup jobs, then switch replication tasks over to using this methodology. Signed-off-by: John Snow --- block/backup.c| 3 ++- block/mirror.c| 21 ++--- block/replication.c | 14 +++--- blockdev.c| 11 +++ include/block/block_int.h | 9 +++-- qemu-img.c| 5 +++-- 6 files changed, 36 insertions(+), 27 deletions(-) diff --git a/block/backup.c b/block/backup.c index 5acb5c4..6a60ca8 100644 --- a/block/backup.c +++ b/block/backup.c @@ -527,6 +527,7 @@ void backup_start(const char *job_id, BlockDriverState *bs, bool compress, BlockdevOnError on_source_error, BlockdevOnError on_target_error, + int creation_flags, BlockCompletionFunc *cb, void *opaque, BlockJobTxn *txn, Error **errp) { @@ -596,7 +597,7 @@ void backup_start(const char *job_id, BlockDriverState *bs, } job = block_job_create(job_id, &backup_job_driver, bs, speed, - BLOCK_JOB_DEFAULT, cb, opaque, errp); + creation_flags, cb, opaque, errp); if (!job) { goto error; } diff --git a/block/mirror.c b/block/mirror.c index 74c03ae..15d2d10 100644 --- a/block/mirror.c +++ b/block/mirror.c @@ -906,9 +906,9 @@ static const BlockJobDriver commit_active_job_driver = { }; static void mirror_start_job(const char *job_id, BlockDriverState *bs, - BlockDriverState *target, const char *replaces, - int64_t speed, uint32_t granularity, - int64_t buf_size, + int creation_flags, BlockDriverState *target, + const char *replaces, int64_t speed, + uint32_t granularity, int64_t buf_size, BlockMirrorBackingMode backing_mode, BlockdevOnError on_source_error, BlockdevOnError on_target_error, @@ -936,8 +936,8 @@ static void mirror_start_job(const char *job_id, BlockDriverState *bs, buf_size = DEFAULT_MIRROR_BUF_SIZE; } -s = block_job_create(job_id, driver, bs, speed, - BLOCK_JOB_DEFAULT, cb, opaque, errp); +s = block_job_create(job_id, driver, bs, speed, creation_flags, + cb, opaque, errp); if (!s) { return; } @@ -992,17 +992,16 @@ void mirror_start(const char *job_id, BlockDriverState *bs, } is_none_mode = mode == MIRROR_SYNC_MODE_NONE; base = mode == MIRROR_SYNC_MODE_TOP ? backing_bs(bs) : NULL; -mirror_start_job(job_id, bs, target, replaces, +mirror_start_job(job_id, bs, BLOCK_JOB_DEFAULT, target, replaces, speed, granularity, buf_size, backing_mode, on_source_error, on_target_error, unmap, cb, opaque, errp, &mirror_job_driver, is_none_mode, base, false); } void commit_active_start(const char *job_id, BlockDriverState *bs, - BlockDriverState *base, int64_t speed, - BlockdevOnError on_error, - BlockCompletionFunc *cb, - void *opaque, Error **errp, + BlockDriverState *base, int creation_flags, + int64_t speed, BlockdevOnError on_error, + BlockCompletionFunc *cb, void *opaque, Error **errp, bool auto_complete) { int64_t length, base_length; @@ -1041,7 +1040,7 @@ void commit_active_start(const char *job_id, BlockDriverState *bs, } } -mirror_start_job(job_id, bs, base, NULL, speed, 0, 0, +mirror_start_job(job_id, bs, creation_flags, base, NULL, speed, 0, 0, MIRROR_LEAVE_BACKING_CHAIN, on_error, on_error, false, cb, opaque, &local_err, &commit_active_job_driver, false, base, auto_complete); diff --git a/block/replication.c b/block/replication.c index 3bd1cf1..d4f4a7b 100644 --- a/block/replication.c +++ b/block/replication.c @@ -496,10 +496,11 @@ static void replication_start(ReplicationState *rs, ReplicationMode mode, bdrv_op_block_all(top_bs, s->blocker); bdrv_op_unblock(top_bs, BLOCK_OP_TYPE_DATAPLANE, s->blocker); -backup_start("replication-backup", s->secondary_disk->bs, - s->hidden_disk->bs, 0, MIRROR_SYNC_MODE_NONE, NULL, false, +backup_start(NULL, s->secondary_disk->bs, s->hidden_disk->bs, 0, + MIRROR_SYNC_MODE_NONE, NULL, false, BLOCKDEV_ON_ERROR_REPORT, BLOCKDEV_ON_ERROR_REPORT, - backup_job_completed, s, NULL, &local_err); + BLOCK_JOB_INTERNAL, backup_job_completed, s, +