Unify the function saving the ram pages for using in both the migration and the background snapshots.
Signed-off-by: Denis Plotnikov <dplotni...@virtuozzo.com> --- migration/ram.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/migration/ram.c b/migration/ram.c index 10b6fdf23e..b1623e96e7 100644 --- a/migration/ram.c +++ b/migration/ram.c @@ -1803,11 +1803,28 @@ static int ram_find_and_save_block(RAMState *rs, bool last_stage) if (!found) { /* priority queue empty, so just search for something dirty */ found = find_dirty_block(rs, &pss, &again); + + if (found && migrate_background_snapshot()) { + /* make a copy of the page and + * pass it to the page search status */ + int ret; + ret = ram_copy_page(pss.block, pss.page, &pss.page_copy); + if (ret == 0) { + found = false; + pages = 0; + } else if (ret < 0) { + return ret; + } + } } if (found) { pages = ram_save_host_page(rs, &pss, last_stage); } + + if (pss.page_copy) { + ram_page_buffer_decrease_used(); + } } while (!pages && again); rs->last_seen_block = pss.block; -- 2.17.0