2013-05-25 18:38:28 +00:00
|
|
|
From 4c62f3e4b8f0c014306c4e5dae4eb8c59289d562 Mon Sep 17 00:00:00 2001
|
2013-05-23 01:48:57 +00:00
|
|
|
From: Paolo Bonzini <pbonzini@redhat.com>
|
|
|
|
Date: Fri, 22 Feb 2013 17:36:24 +0100
|
2013-05-25 18:38:28 +00:00
|
|
|
Subject: [PATCH] block-migration: document usage of state across threads
|
2013-05-23 01:48:57 +00:00
|
|
|
|
|
|
|
Reviewed-by: Orit Wasserman <owasserm@redhat.com>
|
|
|
|
Reviewed-by: Juan Quintela <quintela@redhat.com>
|
|
|
|
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
|
|
|
|
Signed-off-by: Juan Quintela <quintela@redhat.com>
|
2013-05-25 18:38:28 +00:00
|
|
|
(cherry picked from commit 323920c4eac01de74cf2b5e941c97ca9b2d36b7f)
|
2013-05-23 01:48:57 +00:00
|
|
|
---
|
|
|
|
block-migration.c | 23 ++++++++++++++++++-----
|
|
|
|
1 file changed, 18 insertions(+), 5 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/block-migration.c b/block-migration.c
|
|
|
|
index 9a40edd..d62a8b8 100644
|
|
|
|
--- a/block-migration.c
|
|
|
|
+++ b/block-migration.c
|
|
|
|
@@ -43,18 +43,24 @@
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef struct BlkMigDevState {
|
|
|
|
+ /* Written during setup phase. Can be read without a lock. */
|
|
|
|
BlockDriverState *bs;
|
|
|
|
- int bulk_completed;
|
|
|
|
int shared_base;
|
|
|
|
- int64_t cur_sector;
|
|
|
|
- int64_t cur_dirty;
|
|
|
|
- int64_t completed_sectors;
|
|
|
|
int64_t total_sectors;
|
|
|
|
QSIMPLEQ_ENTRY(BlkMigDevState) entry;
|
|
|
|
+
|
|
|
|
+ /* Only used by migration thread. Does not need a lock. */
|
|
|
|
+ int bulk_completed;
|
|
|
|
+ int64_t cur_sector;
|
|
|
|
+ int64_t cur_dirty;
|
|
|
|
+
|
|
|
|
+ /* Protected by iothread lock. */
|
|
|
|
unsigned long *aio_bitmap;
|
|
|
|
+ int64_t completed_sectors;
|
|
|
|
} BlkMigDevState;
|
|
|
|
|
|
|
|
typedef struct BlkMigBlock {
|
|
|
|
+ /* Only used by migration thread. */
|
|
|
|
uint8_t *buf;
|
|
|
|
BlkMigDevState *bmds;
|
|
|
|
int64_t sector;
|
|
|
|
@@ -62,19 +68,26 @@ typedef struct BlkMigBlock {
|
|
|
|
struct iovec iov;
|
|
|
|
QEMUIOVector qiov;
|
|
|
|
BlockDriverAIOCB *aiocb;
|
|
|
|
+
|
|
|
|
+ /* Protected by iothread lock. */
|
|
|
|
int ret;
|
|
|
|
QSIMPLEQ_ENTRY(BlkMigBlock) entry;
|
|
|
|
} BlkMigBlock;
|
|
|
|
|
|
|
|
typedef struct BlkMigState {
|
|
|
|
+ /* Written during setup phase. Can be read without a lock. */
|
|
|
|
int blk_enable;
|
|
|
|
int shared_base;
|
|
|
|
QSIMPLEQ_HEAD(bmds_list, BlkMigDevState) bmds_list;
|
|
|
|
+ int64_t total_sector_sum;
|
|
|
|
+
|
|
|
|
+ /* Protected by iothread lock. */
|
|
|
|
QSIMPLEQ_HEAD(blk_list, BlkMigBlock) blk_list;
|
|
|
|
int submitted;
|
|
|
|
int read_done;
|
|
|
|
+
|
|
|
|
+ /* Only used by migration thread. Does not need a lock. */
|
|
|
|
int transferred;
|
|
|
|
- int64_t total_sector_sum;
|
|
|
|
int prev_progress;
|
|
|
|
int bulk_completed;
|
|
|
|
} BlkMigState;
|