All of lore.kernel.org
 help / color / mirror / Atom feed
From: Alexey Perevalov <a.perevalov@samsung.com>
To: qemu-devel@nongnu.org
Cc: Alexey Perevalov <a.perevalov@samsung.com>,
	dgilbert@redhat.com, i.maximets@samsung.com, peterx@redhat.com
Subject: [Qemu-devel] [[PATCH V7] 08/11] migration: postcopy_place_page factoring out
Date: Wed, 07 Jun 2017 10:35:28 +0300	[thread overview]
Message-ID: <1496820931-27416-9-git-send-email-a.perevalov@samsung.com> (raw)
In-Reply-To: <1496820931-27416-1-git-send-email-a.perevalov@samsung.com>

Need to set copied bitmap as closer as possible to mark_postcopy_blocktime_end.
So postcopy_place_page is proper place. RAMBlock argument here could avoid
additional RAMBlock lookup as well as reduce number of arguments
(no need to pass pointer to copied bitmap).

Signed-off-by: Alexey Perevalov <a.perevalov@samsung.com>
---
 migration/postcopy-ram.c | 13 ++++++++-----
 migration/postcopy-ram.h |  4 ++--
 migration/ram.c          |  4 ++--
 3 files changed, 12 insertions(+), 9 deletions(-)

diff --git a/migration/postcopy-ram.c b/migration/postcopy-ram.c
index ade7f1c..62a272a 100644
--- a/migration/postcopy-ram.c
+++ b/migration/postcopy-ram.c
@@ -713,9 +713,10 @@ int postcopy_ram_enable_notify(MigrationIncomingState *mis)
  * returns 0 on success
  */
 int postcopy_place_page(MigrationIncomingState *mis, void *host, void *from,
-                        size_t pagesize)
+                        RAMBlock *rb)
 {
     struct uffdio_copy copy_struct;
+    size_t pagesize = qemu_ram_pagesize(rb);
 
     copy_struct.dst = (uint64_t)(uintptr_t)host;
     copy_struct.src = (uint64_t)(uintptr_t)from;
@@ -744,10 +745,12 @@ int postcopy_place_page(MigrationIncomingState *mis, void *host, void *from,
  * returns 0 on success
  */
 int postcopy_place_page_zero(MigrationIncomingState *mis, void *host,
-                             size_t pagesize)
+                             RAMBlock *rb)
 {
+    size_t pagesize;
     trace_postcopy_place_page_zero(host);
 
+    pagesize = qemu_ram_pagesize(rb);
     if (pagesize == getpagesize()) {
         struct uffdio_zeropage zero_struct;
         zero_struct.range.start = (uint64_t)(uintptr_t)host;
@@ -778,7 +781,7 @@ int postcopy_place_page_zero(MigrationIncomingState *mis, void *host,
             memset(mis->postcopy_tmp_zero_page, '\0', mis->largest_page_size);
         }
         return postcopy_place_page(mis, host, mis->postcopy_tmp_zero_page,
-                                   pagesize);
+                                   rb);
     }
 
     return 0;
@@ -841,14 +844,14 @@ int postcopy_ram_enable_notify(MigrationIncomingState *mis)
 }
 
 int postcopy_place_page(MigrationIncomingState *mis, void *host, void *from,
-                        size_t pagesize)
+                        RAMBlock *rb)
 {
     assert(0);
     return -1;
 }
 
 int postcopy_place_page_zero(MigrationIncomingState *mis, void *host,
-                        size_t pagesize)
+                        RAMBlock *rb)
 {
     assert(0);
     return -1;
diff --git a/migration/postcopy-ram.h b/migration/postcopy-ram.h
index 587a8b8..77ea0fd 100644
--- a/migration/postcopy-ram.h
+++ b/migration/postcopy-ram.h
@@ -72,14 +72,14 @@ void postcopy_discard_send_finish(MigrationState *ms,
  * returns 0 on success
  */
 int postcopy_place_page(MigrationIncomingState *mis, void *host, void *from,
-                        size_t pagesize);
+                        RAMBlock *rb);
 
 /*
  * Place a zero page at (host) atomically
  * returns 0 on success
  */
 int postcopy_place_page_zero(MigrationIncomingState *mis, void *host,
-                             size_t pagesize);
+                             RAMBlock *rb);
 
 /* The current postcopy state is read/set by postcopy_state_get/set
  * which update it atomically.
diff --git a/migration/ram.c b/migration/ram.c
index a7c0db4..a791d40 100644
--- a/migration/ram.c
+++ b/migration/ram.c
@@ -2524,10 +2524,10 @@ static int ram_load_postcopy(QEMUFile *f)
 
             if (all_zero) {
                 ret = postcopy_place_page_zero(mis, place_dest,
-                                               block->page_size);
+                                               block);
             } else {
                 ret = postcopy_place_page(mis, place_dest,
-                                          place_source, block->page_size);
+                                          place_source, block);
             }
         }
         if (!ret) {
-- 
1.9.1

  parent reply	other threads:[~2017-06-07  7:36 UTC|newest]

Thread overview: 19+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <CGME20170607073601eucas1p1b1897ed7d52d9edfed31971c592c2300@eucas1p1.samsung.com>
2017-06-07  7:35 ` [Qemu-devel] [[PATCH V7] 00/11] calculate blocktime for postcopy live migration Alexey Perevalov
     [not found]   ` <CGME20170607073601eucas1p27a31022ee4b4e82d9e887a7e4a0c7822@eucas1p2.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 01/11] userfault: add pid into uffd_msg & update UFFD_FEATURE_* Alexey Perevalov
     [not found]   ` <CGME20170607073602eucas1p292a25ea3edab8ba8eab3ae95fa2519de@eucas1p2.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 02/11] migration: pass MigrationIncomingState* into migration check functions Alexey Perevalov
     [not found]   ` <CGME20170607073602eucas1p2ab6458769c054d79742b299a1df30cea@eucas1p2.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 03/11] migration: fix hardcoded function name in error report Alexey Perevalov
2017-06-07  8:10       ` no-reply
2017-06-07  9:29       ` no-reply
     [not found]   ` <CGME20170607073603eucas1p192b908ff347cad65092412266fa0e2b0@eucas1p1.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 04/11] migration: split ufd_version_check onto receive/request features part Alexey Perevalov
     [not found]   ` <CGME20170607073603eucas1p24a33631b2bcde61e1e07d2793f5b5bd6@eucas1p2.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 05/11] migration: introduce postcopy-blocktime capability Alexey Perevalov
     [not found]   ` <CGME20170607073604eucas1p225626eb74bee996f8d8c3407b2ce8403@eucas1p2.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 06/11] migration: add postcopy blocktime ctx into MigrationIncomingState Alexey Perevalov
     [not found]   ` <CGME20170607073605eucas1p13af2f166ad184d486e43aa35dd105ac8@eucas1p1.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 07/11] migration: add bitmap for copied page Alexey Perevalov
     [not found]   ` <CGME20170607073605eucas1p23406b53a5ee9282d8440dae03ecc5273@eucas1p2.samsung.com>
2017-06-07  7:35     ` Alexey Perevalov [this message]
     [not found]   ` <CGME20170607073606eucas1p15855edc9776f50d47eb18b1d4ba3263e@eucas1p1.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 09/11] migration: calculate vCPU blocktime on dst side Alexey Perevalov
2017-06-07  8:40       ` no-reply
2017-06-07  9:24         ` Fam Zheng
2017-06-07  9:29           ` Alexey Perevalov
2017-06-07 11:14             ` Fam Zheng
2017-06-07 10:52       ` no-reply
     [not found]   ` <CGME20170607073606eucas1p28da48135181e1a31e909ba7b102ee90b@eucas1p2.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 10/11] migration: add postcopy total blocktime into query-migrate Alexey Perevalov
     [not found]   ` <CGME20170607073607eucas1p2388c85188375aa215553e3e2ff789b74@eucas1p2.samsung.com>
2017-06-07  7:35     ` [Qemu-devel] [[PATCH V7] 11/11] migration: postcopy_blocktime documentation Alexey Perevalov

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1496820931-27416-9-git-send-email-a.perevalov@samsung.com \
    --to=a.perevalov@samsung.com \
    --cc=dgilbert@redhat.com \
    --cc=i.maximets@samsung.com \
    --cc=peterx@redhat.com \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.