|
|
ae23c9 |
From 9d75983943f6510a804b2b9c48efa1eb3dcb41a2 Mon Sep 17 00:00:00 2001
|
|
|
ae23c9 |
From: John Snow <jsnow@redhat.com>
|
|
|
ae23c9 |
Date: Tue, 20 Nov 2018 18:18:06 +0000
|
|
|
ae23c9 |
Subject: [PATCH 12/35] block: simplify code around releasing bitmaps
|
|
|
ae23c9 |
|
|
|
ae23c9 |
RH-Author: John Snow <jsnow@redhat.com>
|
|
|
ae23c9 |
Message-id: <20181120181828.15132-3-jsnow@redhat.com>
|
|
|
ae23c9 |
Patchwork-id: 83053
|
|
|
ae23c9 |
O-Subject: [RHEL8/rhel qemu-kvm PATCH 02/24] block: simplify code around releasing bitmaps
|
|
|
ae23c9 |
Bugzilla: 1518989
|
|
|
ae23c9 |
RH-Acked-by: Laurent Vivier <lvivier@redhat.com>
|
|
|
ae23c9 |
RH-Acked-by: Max Reitz <mreitz@redhat.com>
|
|
|
ae23c9 |
RH-Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
ae23c9 |
|
|
|
ae23c9 |
From: Paolo Bonzini <pbonzini@redhat.com>
|
|
|
ae23c9 |
|
|
|
ae23c9 |
QLIST_REMOVE does not require walking the list, and once the "bitmap"
|
|
|
ae23c9 |
argument is removed from bdrv_do_release_matching_dirty_bitmap_locked
|
|
|
ae23c9 |
the code simplifies a lot and it is worth inlining everything in the
|
|
|
ae23c9 |
callers of bdrv_do_release_matching_dirty_bitmap.
|
|
|
ae23c9 |
|
|
|
ae23c9 |
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
|
|
|
ae23c9 |
Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
|
|
|
ae23c9 |
Reviewed-by: John Snow <jsnow@redhat.com>
|
|
|
ae23c9 |
Message-id: 20180326104037.6894-1-pbonzini@redhat.com
|
|
|
ae23c9 |
Signed-off-by: John Snow <jsnow@redhat.com>
|
|
|
ae23c9 |
(cherry picked from commit b133c27f5dc59969574b0715e5837d32c99caa86)
|
|
|
ae23c9 |
Signed-off-by: John Snow <jsnow@redhat.com>
|
|
|
ae23c9 |
Signed-off-by: Danilo C. L. de Paula <ddepaula@redhat.com>
|
|
|
ae23c9 |
---
|
|
|
ae23c9 |
block/dirty-bitmap.c | 84 ++++++++++++++++++++--------------------------------
|
|
|
ae23c9 |
1 file changed, 32 insertions(+), 52 deletions(-)
|
|
|
ae23c9 |
|
|
|
ae23c9 |
diff --git a/block/dirty-bitmap.c b/block/dirty-bitmap.c
|
|
|
ae23c9 |
index 634f143..dac8d74 100644
|
|
|
ae23c9 |
--- a/block/dirty-bitmap.c
|
|
|
ae23c9 |
+++ b/block/dirty-bitmap.c
|
|
|
ae23c9 |
@@ -256,49 +256,16 @@ void bdrv_dirty_bitmap_enable_successor(BdrvDirtyBitmap *bitmap)
|
|
|
ae23c9 |
qemu_mutex_unlock(bitmap->mutex);
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
|
|
|
ae23c9 |
-/* Called within bdrv_dirty_bitmap_lock..unlock */
|
|
|
ae23c9 |
-static void bdrv_do_release_matching_dirty_bitmap_locked(
|
|
|
ae23c9 |
- BlockDriverState *bs, BdrvDirtyBitmap *bitmap,
|
|
|
ae23c9 |
- bool (*cond)(BdrvDirtyBitmap *bitmap))
|
|
|
ae23c9 |
+/* Called within bdrv_dirty_bitmap_lock..unlock and with BQL taken. */
|
|
|
ae23c9 |
+static void bdrv_release_dirty_bitmap_locked(BdrvDirtyBitmap *bitmap)
|
|
|
ae23c9 |
{
|
|
|
ae23c9 |
- BdrvDirtyBitmap *bm, *next;
|
|
|
ae23c9 |
-
|
|
|
ae23c9 |
- QLIST_FOREACH_SAFE(bm, &bs->dirty_bitmaps, list, next) {
|
|
|
ae23c9 |
- if ((!bitmap || bm == bitmap) && (!cond || cond(bm))) {
|
|
|
ae23c9 |
- assert(!bm->active_iterators);
|
|
|
ae23c9 |
- assert(!bdrv_dirty_bitmap_frozen(bm));
|
|
|
ae23c9 |
- assert(!bm->meta);
|
|
|
ae23c9 |
- QLIST_REMOVE(bm, list);
|
|
|
ae23c9 |
- hbitmap_free(bm->bitmap);
|
|
|
ae23c9 |
- g_free(bm->name);
|
|
|
ae23c9 |
- g_free(bm);
|
|
|
ae23c9 |
-
|
|
|
ae23c9 |
- if (bitmap) {
|
|
|
ae23c9 |
- return;
|
|
|
ae23c9 |
- }
|
|
|
ae23c9 |
- }
|
|
|
ae23c9 |
- }
|
|
|
ae23c9 |
-
|
|
|
ae23c9 |
- if (bitmap) {
|
|
|
ae23c9 |
- abort();
|
|
|
ae23c9 |
- }
|
|
|
ae23c9 |
-}
|
|
|
ae23c9 |
-
|
|
|
ae23c9 |
-/* Called with BQL taken. */
|
|
|
ae23c9 |
-static void bdrv_do_release_matching_dirty_bitmap(
|
|
|
ae23c9 |
- BlockDriverState *bs, BdrvDirtyBitmap *bitmap,
|
|
|
ae23c9 |
- bool (*cond)(BdrvDirtyBitmap *bitmap))
|
|
|
ae23c9 |
-{
|
|
|
ae23c9 |
- bdrv_dirty_bitmaps_lock(bs);
|
|
|
ae23c9 |
- bdrv_do_release_matching_dirty_bitmap_locked(bs, bitmap, cond);
|
|
|
ae23c9 |
- bdrv_dirty_bitmaps_unlock(bs);
|
|
|
ae23c9 |
-}
|
|
|
ae23c9 |
-
|
|
|
ae23c9 |
-/* Called within bdrv_dirty_bitmap_lock..unlock */
|
|
|
ae23c9 |
-static void bdrv_release_dirty_bitmap_locked(BlockDriverState *bs,
|
|
|
ae23c9 |
- BdrvDirtyBitmap *bitmap)
|
|
|
ae23c9 |
-{
|
|
|
ae23c9 |
- bdrv_do_release_matching_dirty_bitmap_locked(bs, bitmap, NULL);
|
|
|
ae23c9 |
+ assert(!bitmap->active_iterators);
|
|
|
ae23c9 |
+ assert(!bdrv_dirty_bitmap_frozen(bitmap));
|
|
|
ae23c9 |
+ assert(!bitmap->meta);
|
|
|
ae23c9 |
+ QLIST_REMOVE(bitmap, list);
|
|
|
ae23c9 |
+ hbitmap_free(bitmap->bitmap);
|
|
|
ae23c9 |
+ g_free(bitmap->name);
|
|
|
ae23c9 |
+ g_free(bitmap);
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
|
|
|
ae23c9 |
/**
|
|
|
ae23c9 |
@@ -351,7 +318,7 @@ BdrvDirtyBitmap *bdrv_reclaim_dirty_bitmap_locked(BlockDriverState *bs,
|
|
|
ae23c9 |
error_setg(errp, "Merging of parent and successor bitmap failed");
|
|
|
ae23c9 |
return NULL;
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
- bdrv_release_dirty_bitmap_locked(bs, successor);
|
|
|
ae23c9 |
+ bdrv_release_dirty_bitmap_locked(successor);
|
|
|
ae23c9 |
parent->successor = NULL;
|
|
|
ae23c9 |
|
|
|
ae23c9 |
return parent;
|
|
|
ae23c9 |
@@ -389,15 +356,12 @@ void bdrv_dirty_bitmap_truncate(BlockDriverState *bs, int64_t bytes)
|
|
|
ae23c9 |
bdrv_dirty_bitmaps_unlock(bs);
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
|
|
|
ae23c9 |
-static bool bdrv_dirty_bitmap_has_name(BdrvDirtyBitmap *bitmap)
|
|
|
ae23c9 |
-{
|
|
|
ae23c9 |
- return !!bdrv_dirty_bitmap_name(bitmap);
|
|
|
ae23c9 |
-}
|
|
|
ae23c9 |
-
|
|
|
ae23c9 |
/* Called with BQL taken. */
|
|
|
ae23c9 |
void bdrv_release_dirty_bitmap(BlockDriverState *bs, BdrvDirtyBitmap *bitmap)
|
|
|
ae23c9 |
{
|
|
|
ae23c9 |
- bdrv_do_release_matching_dirty_bitmap(bs, bitmap, NULL);
|
|
|
ae23c9 |
+ bdrv_dirty_bitmaps_lock(bs);
|
|
|
ae23c9 |
+ bdrv_release_dirty_bitmap_locked(bitmap);
|
|
|
ae23c9 |
+ bdrv_dirty_bitmaps_unlock(bs);
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
|
|
|
ae23c9 |
/**
|
|
|
ae23c9 |
@@ -408,7 +372,15 @@ void bdrv_release_dirty_bitmap(BlockDriverState *bs, BdrvDirtyBitmap *bitmap)
|
|
|
ae23c9 |
*/
|
|
|
ae23c9 |
void bdrv_release_named_dirty_bitmaps(BlockDriverState *bs)
|
|
|
ae23c9 |
{
|
|
|
ae23c9 |
- bdrv_do_release_matching_dirty_bitmap(bs, NULL, bdrv_dirty_bitmap_has_name);
|
|
|
ae23c9 |
+ BdrvDirtyBitmap *bm, *next;
|
|
|
ae23c9 |
+
|
|
|
ae23c9 |
+ bdrv_dirty_bitmaps_lock(bs);
|
|
|
ae23c9 |
+ QLIST_FOREACH_SAFE(bm, &bs->dirty_bitmaps, list, next) {
|
|
|
ae23c9 |
+ if (bdrv_dirty_bitmap_name(bm)) {
|
|
|
ae23c9 |
+ bdrv_release_dirty_bitmap_locked(bm);
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ bdrv_dirty_bitmaps_unlock(bs);
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
|
|
|
ae23c9 |
/**
|
|
|
ae23c9 |
@@ -416,11 +388,19 @@ void bdrv_release_named_dirty_bitmaps(BlockDriverState *bs)
|
|
|
ae23c9 |
* bdrv_inactivate_recurse()).
|
|
|
ae23c9 |
* There must not be any frozen bitmaps attached.
|
|
|
ae23c9 |
* This function does not remove persistent bitmaps from the storage.
|
|
|
ae23c9 |
+ * Called with BQL taken.
|
|
|
ae23c9 |
*/
|
|
|
ae23c9 |
void bdrv_release_persistent_dirty_bitmaps(BlockDriverState *bs)
|
|
|
ae23c9 |
{
|
|
|
ae23c9 |
- bdrv_do_release_matching_dirty_bitmap(bs, NULL,
|
|
|
ae23c9 |
- bdrv_dirty_bitmap_get_persistance);
|
|
|
ae23c9 |
+ BdrvDirtyBitmap *bm, *next;
|
|
|
ae23c9 |
+
|
|
|
ae23c9 |
+ bdrv_dirty_bitmaps_lock(bs);
|
|
|
ae23c9 |
+ QLIST_FOREACH_SAFE(bm, &bs->dirty_bitmaps, list, next) {
|
|
|
ae23c9 |
+ if (bdrv_dirty_bitmap_get_persistance(bm)) {
|
|
|
ae23c9 |
+ bdrv_release_dirty_bitmap_locked(bm);
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ }
|
|
|
ae23c9 |
+ bdrv_dirty_bitmaps_unlock(bs);
|
|
|
ae23c9 |
}
|
|
|
ae23c9 |
|
|
|
ae23c9 |
/**
|
|
|
ae23c9 |
--
|
|
|
ae23c9 |
1.8.3.1
|
|
|
ae23c9 |
|