From: Peter Xu <peterx@redhat.com>
To: "Chaney, Ben" <bchaney@akamai.com>
Cc: David Hildenbrand <david@redhat.com>,
"Michael S. Tsirkin" <mst@redhat.com>,
"yury-kotov@yandex-team.ru" <yury-kotov@yandex-team.ru>,
"dgilbert@redhat.com" <dgilbert@redhat.com>,
"beata.michalska@linaro.org" <beata.michalska@linaro.org>,
"richard.henderson@linaro.org" <richard.henderson@linaro.org>,
"alex.bennee@linaro.org" <alex.bennee@linaro.org>,
"peter.maydell@linaro.org" <peter.maydell@linaro.org>,
"junyan.he@intel.com" <junyan.he@intel.com>,
"stefanha@redhat.com" <stefanha@redhat.com>,
"imammedo@redhat.com" <imammedo@redhat.com>,
"qemu-devel@nongnu.org" <qemu-devel@nongnu.org>,
"pbonzini@redhat.com" <pbonzini@redhat.com>,
"philmd@linaro.org" <philmd@linaro.org>,
"xiaoguangrong.eric@gmail.com" <xiaoguangrong.eric@gmail.com>,
"Tottenham, Max" <mtottenh@akamai.com>,
"Hunt, Joshua" <johunt@akamai.com>,
"Glasgall, Anna" <aglasgal@akamai.com>
Subject: Re: live-migration performance regression when using pmem
Date: Thu, 12 Jun 2025 12:06:53 -0400 [thread overview]
Message-ID: <aEr7Hfk1P0LNV8LE@x1.local> (raw)
In-Reply-To: <D700A742-535E-43FB-A602-9FFA4F1DAA99@akamai.com>
On Thu, Jun 12, 2025 at 03:34:35PM +0000, Chaney, Ben wrote:
> On 5/14/25, 9:59 AM, "David Hildenbrand" <david@redhat.com <mailto:david@redhat.com>> wrote:
>
>
>
> >Because we need to make sure the pmem kind memory data is synced
> >after migration, we choose to call pmem_persist() when the migration
> >finish. This will make sure the data of pmem is safe and will not
> >lose if power is off.
>
> Thank you for clarifying. I think I initially misunderstood the purpose of
> this code path.
>
> In that case, how about something like this to restrict the sync to only
> run when it would be effective? If the memory region is volatile then
> there is no benefit to syncing.
>
> Thanks,
> Ben
>
> ---
> migration/ram.c | 4 +++-
> 1 file changed, 3 insertions(+), 1 deletion(-)
>
> diff --git a/migration/ram.c b/migration/ram.c
> index f25ebd9620..24fb29f0a5 100644
> --- a/migration/ram.c
> +++ b/migration/ram.c
> @@ -3930,7 +3930,9 @@ static int ram_load_cleanup(void *opaque)
> RAMBlock *rb;
>
> RAMBLOCK_FOREACH_NOT_IGNORED(rb) {
> - qemu_ram_block_writeback(rb);
> + if (rb->mr->nonvolatile) {
> + qemu_ram_block_writeback(rb);
> + }
> }
>
> xbzrle_load_cleanup();
> --
> 2.40.1
Looks good here, I think that's what I mentioned:
https://lore.kernel.org/all/aCTHwhrXROReEPEh@x1.local/
But I guess I got the use case wrong; looks like it worked for you.
In that case please switch to memory_region_is_nonvolatile(), and add
proper Fixes, and copy stable.
Thanks,
--
Peter Xu
prev parent reply other threads:[~2025-06-12 16:07 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-05-12 15:16 live-migration performance regression when using pmem Chaney, Ben
2025-05-12 18:50 ` Peter Xu
2025-05-13 15:48 ` Chaney, Ben
2025-05-14 16:41 ` Peter Xu
2025-05-12 19:52 ` Michael S. Tsirkin
2025-05-13 17:21 ` David Hildenbrand
2025-05-13 18:40 ` Chaney, Ben
2025-05-13 20:11 ` Michael S. Tsirkin
2025-05-14 13:57 ` David Hildenbrand
2025-06-12 15:34 ` Chaney, Ben
2025-06-12 16:06 ` Peter Xu [this message]
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=aEr7Hfk1P0LNV8LE@x1.local \
--to=peterx@redhat.com \
--cc=aglasgal@akamai.com \
--cc=alex.bennee@linaro.org \
--cc=bchaney@akamai.com \
--cc=beata.michalska@linaro.org \
--cc=david@redhat.com \
--cc=dgilbert@redhat.com \
--cc=imammedo@redhat.com \
--cc=johunt@akamai.com \
--cc=junyan.he@intel.com \
--cc=mst@redhat.com \
--cc=mtottenh@akamai.com \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=philmd@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=richard.henderson@linaro.org \
--cc=stefanha@redhat.com \
--cc=xiaoguangrong.eric@gmail.com \
--cc=yury-kotov@yandex-team.ru \
/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.