mirror of https://github.com/xemu-project/xemu.git
block/backup: Rely on commit/abort for cleanup
Switch over to the new .commit/.abort handlers for cleaning up incremental bitmaps. [split up from a patch originally by Stefan and Fam. --js] Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Signed-off-by: Fam Zheng <famz@redhat.com> Signed-off-by: John Snow <jsnow@redhat.com> Signed-off-by: John Snow <jsnow@redhat.com> Message-id: 1446765200-3054-11-git-send-email-jsnow@redhat.com Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
c55a832fdd
commit
c347b2c62a
|
@ -237,11 +237,29 @@ static void backup_cleanup_sync_bitmap(BackupBlockJob *job, int ret)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void backup_commit(BlockJob *job)
|
||||||
|
{
|
||||||
|
BackupBlockJob *s = container_of(job, BackupBlockJob, common);
|
||||||
|
if (s->sync_bitmap) {
|
||||||
|
backup_cleanup_sync_bitmap(s, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void backup_abort(BlockJob *job)
|
||||||
|
{
|
||||||
|
BackupBlockJob *s = container_of(job, BackupBlockJob, common);
|
||||||
|
if (s->sync_bitmap) {
|
||||||
|
backup_cleanup_sync_bitmap(s, -1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static const BlockJobDriver backup_job_driver = {
|
static const BlockJobDriver backup_job_driver = {
|
||||||
.instance_size = sizeof(BackupBlockJob),
|
.instance_size = sizeof(BackupBlockJob),
|
||||||
.job_type = BLOCK_JOB_TYPE_BACKUP,
|
.job_type = BLOCK_JOB_TYPE_BACKUP,
|
||||||
.set_speed = backup_set_speed,
|
.set_speed = backup_set_speed,
|
||||||
.iostatus_reset = backup_iostatus_reset,
|
.iostatus_reset = backup_iostatus_reset,
|
||||||
|
.commit = backup_commit,
|
||||||
|
.abort = backup_abort,
|
||||||
};
|
};
|
||||||
|
|
||||||
static BlockErrorAction backup_error_action(BackupBlockJob *job,
|
static BlockErrorAction backup_error_action(BackupBlockJob *job,
|
||||||
|
@ -457,10 +475,6 @@ static void coroutine_fn backup_run(void *opaque)
|
||||||
/* wait until pending backup_do_cow() calls have completed */
|
/* wait until pending backup_do_cow() calls have completed */
|
||||||
qemu_co_rwlock_wrlock(&job->flush_rwlock);
|
qemu_co_rwlock_wrlock(&job->flush_rwlock);
|
||||||
qemu_co_rwlock_unlock(&job->flush_rwlock);
|
qemu_co_rwlock_unlock(&job->flush_rwlock);
|
||||||
|
|
||||||
if (job->sync_bitmap) {
|
|
||||||
backup_cleanup_sync_bitmap(job, ret);
|
|
||||||
}
|
|
||||||
hbitmap_free(job->bitmap);
|
hbitmap_free(job->bitmap);
|
||||||
|
|
||||||
if (target->blk) {
|
if (target->blk) {
|
||||||
|
|
Loading…
Reference in New Issue