[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v7 04/14] backup: Extract dirty bitmap handling as a
From: |
Fam Zheng |
Subject: |
[Qemu-devel] [PATCH v7 04/14] backup: Extract dirty bitmap handling as a separate function |
Date: |
Tue, 22 Sep 2015 10:46:06 +0800 |
This will be reused by the coming new transactional completion code.
Signed-off-by: Fam Zheng <address@hidden>
Reviewed-by: John Snow <address@hidden>
Reviewed-by: Max Reitz <address@hidden>
---
block/backup.c | 27 +++++++++++++++++----------
1 file changed, 17 insertions(+), 10 deletions(-)
diff --git a/block/backup.c b/block/backup.c
index 965654d..609b199 100644
--- a/block/backup.c
+++ b/block/backup.c
@@ -211,6 +211,22 @@ static void backup_iostatus_reset(BlockJob *job)
bdrv_iostatus_reset(s->target);
}
+static void backup_cleanup_sync_bitmap(BackupBlockJob *job, int ret)
+{
+ BdrvDirtyBitmap *bm;
+ BlockDriverState *bs = job->common.bs;
+
+ if (ret < 0 || block_job_is_cancelled(&job->common)) {
+ /* Merge the successor back into the parent, delete nothing. */
+ bm = bdrv_reclaim_dirty_bitmap(bs, job->sync_bitmap, NULL);
+ assert(bm);
+ } else {
+ /* Everything is fine, delete this bitmap and install the backup. */
+ bm = bdrv_dirty_bitmap_abdicate(bs, job->sync_bitmap, NULL);
+ assert(bm);
+ }
+}
+
static const BlockJobDriver backup_job_driver = {
.instance_size = sizeof(BackupBlockJob),
.job_type = BLOCK_JOB_TYPE_BACKUP,
@@ -430,16 +446,7 @@ static void coroutine_fn backup_run(void *opaque)
qemu_co_rwlock_unlock(&job->flush_rwlock);
if (job->sync_bitmap) {
- BdrvDirtyBitmap *bm;
- if (ret < 0 || block_job_is_cancelled(&job->common)) {
- /* Merge the successor back into the parent, delete nothing. */
- bm = bdrv_reclaim_dirty_bitmap(bs, job->sync_bitmap, NULL);
- assert(bm);
- } else {
- /* Everything is fine, delete this bitmap and install the backup.
*/
- bm = bdrv_dirty_bitmap_abdicate(bs, job->sync_bitmap, NULL);
- assert(bm);
- }
+ backup_cleanup_sync_bitmap(job, ret);
}
hbitmap_free(job->bitmap);
--
2.4.3
- [Qemu-devel] [PATCH v7 00/14] block: incremental backup transactions using BlockJobTxn, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 01/14] qapi: Add transaction support to block-dirty-bitmap operations, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 02/14] iotests: add transactional incremental backup test, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 04/14] backup: Extract dirty bitmap handling as a separate function,
Fam Zheng <=
- [Qemu-devel] [PATCH v7 03/14] block: rename BlkTransactionState and BdrvActionOps, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 05/14] blockjob: Introduce reference count, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 06/14] blockjob: Add .commit and .abort block job actions, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 07/14] blockjob: Add "completed" and "ret" in BlockJob, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 08/14] blockjob: Simplify block_job_finish_sync, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 09/14] block: Add block job transactions, Fam Zheng, 2015/09/21
- [Qemu-devel] [PATCH v7 10/14] blockdev: make BlockJobTxn available to qmp 'transaction', Fam Zheng, 2015/09/21