[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-block] [PATCH v7 05/16] block/dirty-bitmap: add bdrv_dirty_bitmap_
From: |
Vladimir Sementsov-Ogievskiy |
Subject: |
[Qemu-block] [PATCH v7 05/16] block/dirty-bitmap: add bdrv_dirty_bitmap_enable_successor() |
Date: |
Mon, 10 Jul 2017 19:30:18 +0300 |
Enabling bitmap successor is necessary to enable successors of bitmaps
being migrated before target vm start.
Signed-off-by: Vladimir Sementsov-Ogievskiy <address@hidden>
---
block/dirty-bitmap.c | 8 ++++++++
include/block/dirty-bitmap.h | 1 +
2 files changed, 9 insertions(+)
diff --git a/block/dirty-bitmap.c b/block/dirty-bitmap.c
index 0b349f0b5a..7b598c36bf 100644
--- a/block/dirty-bitmap.c
+++ b/block/dirty-bitmap.c
@@ -237,6 +237,14 @@ int bdrv_dirty_bitmap_create_successor(BlockDriverState
*bs,
return 0;
}
+/* Called with BQL taken. */
+void bdrv_dirty_bitmap_enable_successor(BdrvDirtyBitmap *bitmap)
+{
+ qemu_mutex_lock(bitmap->mutex);
+ bdrv_enable_dirty_bitmap(bitmap->successor);
+ qemu_mutex_unlock(bitmap->mutex);
+}
+
/**
* For a bitmap with a successor, yield our name to the successor,
* delete the old bitmap, and return a handle to the new bitmap.
diff --git a/include/block/dirty-bitmap.h b/include/block/dirty-bitmap.h
index 0341a605d7..d00a7a4b7c 100644
--- a/include/block/dirty-bitmap.h
+++ b/include/block/dirty-bitmap.h
@@ -20,6 +20,7 @@ BdrvDirtyBitmap *bdrv_dirty_bitmap_abdicate(BlockDriverState
*bs,
BdrvDirtyBitmap *bdrv_reclaim_dirty_bitmap(BlockDriverState *bs,
BdrvDirtyBitmap *bitmap,
Error **errp);
+void bdrv_dirty_bitmap_enable_successor(BdrvDirtyBitmap *bitmap);
BdrvDirtyBitmap *bdrv_find_dirty_bitmap(BlockDriverState *bs,
const char *name);
void bdrv_dirty_bitmap_make_anon(BdrvDirtyBitmap *bitmap);
--
2.11.1
- Re: [Qemu-block] [PATCH v7 06/16] qapi: add dirty-bitmaps migration capability, (continued)
- [Qemu-block] [PATCH v7 02/16] migration: fix ram_save_pending, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 16/16] iotests: add dirty bitmap postcopy test, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 15/16] iotests: add dirty bitmap migration test, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 03/16] migration: split common postcopy out of ram postcopy, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 14/16] iotests: add default node-name, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 07/16] block/dirty-bitmap: add bdrv_dirty_bitmap_release_successor, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 01/16] migration: add has_postcopy savevm handler, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 05/16] block/dirty-bitmap: add bdrv_dirty_bitmap_enable_successor(),
Vladimir Sementsov-Ogievskiy <=
- [Qemu-block] [PATCH v7 11/16] block/dirty-bitmap: add bdrv_dirty_bitmap_set_frozen, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 09/16] migration/qemu-file: add qemu_put_counted_string(), Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 10/16] migration: add is_active_iterate handler, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 04/16] migration: introduce postcopy-only pending, Vladimir Sementsov-Ogievskiy, 2017/07/10
- [Qemu-block] [PATCH v7 12/16] migration: add postcopy migration of dirty bitmaps, Vladimir Sementsov-Ogievskiy, 2017/07/10