From: Wei Wang <wei.w.wang@intel.com>
To: Peter Xu <peterx@redhat.com>
Cc: qemu-devel@nongnu.org, virtio-dev@lists.oasis-open.org,
mst@redhat.com, quintela@redhat.com, dgilbert@redhat.com,
yang.zhang.wz@gmail.com, quan.xu0@gmail.com,
liliang.opensource@gmail.com, pbonzini@redhat.com,
nilal@redhat.com
Subject: [virtio-dev] Re: [Qemu-devel] [PATCH v7 3/5] migration: API to clear bits of guest free pages from the dirty bitmap
Date: Fri, 01 Jun 2018 20:32:27 +0800 [thread overview]
Message-ID: <5B113CDB.2090109@intel.com> (raw)
In-Reply-To: <20180601100617.GK14867@xz-mi>
On 06/01/2018 06:06 PM, Peter Xu wrote:
> On Fri, Jun 01, 2018 at 03:36:01PM +0800, Wei Wang wrote:
>> On 06/01/2018 12:00 PM, Peter Xu wrote:
>>> On Tue, Apr 24, 2018 at 02:13:46PM +0800, Wei Wang wrote:
>>>> /*
>>>> + * This function clears bits of the free pages reported by the caller from the
>>>> + * migration dirty bitmap. @addr is the host address corresponding to the
>>>> + * start of the continuous guest free pages, and @len is the total bytes of
>>>> + * those pages.
>>>> + */
>>>> +void qemu_guest_free_page_hint(void *addr, size_t len)
>>>> +{
>>>> + RAMBlock *block;
>>>> + ram_addr_t offset;
>>>> + size_t used_len, start, npages;
>>> Do we need to check here on whether a migration is in progress? Since
>>> if not I'm not sure whether this hint still makes any sense any more,
>>> and more importantly it seems to me that block->bmap below at [1] is
>>> only valid during a migration. So I'm not sure whether QEMU will
>>> crash if this function is called without a running migration.
>> OK. How about just adding comments above to have users noted that this
>> function should be used during migration?
>>
>> If we want to do a sanity check here, I think it would be easier to just
>> check !block->bmap here.
> I think the faster way might be that we check against the migration
> state.
>
Sounds good. We can do a sanity check:
MigrationState *s = migrate_get_current();
if (!migration_is_setup_or_active(s->state))
return;
>>
>>>> +
>>>> + for (; len > 0; len -= used_len) {
>>>> + block = qemu_ram_block_from_host(addr, false, &offset);
>>>> + if (unlikely(!block)) {
>>>> + return;
>>> We should never reach here, should we? Assuming the callers of this
>>> function should always pass in a correct host address. If we are very
>>> sure that the host addr should be valid, could we just assert?
>> Probably not the case, because of the corner case that the memory would be
>> hot unplugged after the free page is reported to QEMU.
> Question: Do we allow to do hot plug/unplug for memory during
> migration?
I think so. From the code, I don't find where it forbids memory hotplug
during migration.
>>
>>
>>>> + }
>>>> +
>>>> + /*
>>>> + * This handles the case that the RAMBlock is resized after the free
>>>> + * page hint is reported.
>>>> + */
>>>> + if (unlikely(offset > block->used_length)) {
>>>> + return;
>>>> + }
>>>> +
>>>> + if (len <= block->used_length - offset) {
>>>> + used_len = len;
>>>> + } else {
>>>> + used_len = block->used_length - offset;
>>>> + addr += used_len;
>>>> + }
>>>> +
>>>> + start = offset >> TARGET_PAGE_BITS;
>>>> + npages = used_len >> TARGET_PAGE_BITS;
>>>> +
>>>> + qemu_mutex_lock(&ram_state->bitmap_mutex);
>>> So now I think I understand the lock can still be meaningful since
>>> this function now can be called outside the migration thread (e.g., in
>>> vcpu thread). But still it would be nice to mention it somewhere on
> (Actually after read the next patch I think it's in iothread, so I'd
> better reply with all the series read over next time :)
That's fine actually :) Whether it is called by an iothread or a vcpu
thread doesn't affect our discussion here.
I think we could just focus on the interfaces here and the usage in live
migration. I can explain more when needed.
Best,
Wei
---------------------------------------------------------------------
To unsubscribe, e-mail: virtio-dev-unsubscribe@lists.oasis-open.org
For additional commands, e-mail: virtio-dev-help@lists.oasis-open.org
WARNING: multiple messages have this Message-ID (diff)
From: Wei Wang <wei.w.wang@intel.com>
To: Peter Xu <peterx@redhat.com>
Cc: qemu-devel@nongnu.org, virtio-dev@lists.oasis-open.org,
mst@redhat.com, quintela@redhat.com, dgilbert@redhat.com,
yang.zhang.wz@gmail.com, quan.xu0@gmail.com,
liliang.opensource@gmail.com, pbonzini@redhat.com,
nilal@redhat.com
Subject: Re: [Qemu-devel] [PATCH v7 3/5] migration: API to clear bits of guest free pages from the dirty bitmap
Date: Fri, 01 Jun 2018 20:32:27 +0800 [thread overview]
Message-ID: <5B113CDB.2090109@intel.com> (raw)
In-Reply-To: <20180601100617.GK14867@xz-mi>
On 06/01/2018 06:06 PM, Peter Xu wrote:
> On Fri, Jun 01, 2018 at 03:36:01PM +0800, Wei Wang wrote:
>> On 06/01/2018 12:00 PM, Peter Xu wrote:
>>> On Tue, Apr 24, 2018 at 02:13:46PM +0800, Wei Wang wrote:
>>>> /*
>>>> + * This function clears bits of the free pages reported by the caller from the
>>>> + * migration dirty bitmap. @addr is the host address corresponding to the
>>>> + * start of the continuous guest free pages, and @len is the total bytes of
>>>> + * those pages.
>>>> + */
>>>> +void qemu_guest_free_page_hint(void *addr, size_t len)
>>>> +{
>>>> + RAMBlock *block;
>>>> + ram_addr_t offset;
>>>> + size_t used_len, start, npages;
>>> Do we need to check here on whether a migration is in progress? Since
>>> if not I'm not sure whether this hint still makes any sense any more,
>>> and more importantly it seems to me that block->bmap below at [1] is
>>> only valid during a migration. So I'm not sure whether QEMU will
>>> crash if this function is called without a running migration.
>> OK. How about just adding comments above to have users noted that this
>> function should be used during migration?
>>
>> If we want to do a sanity check here, I think it would be easier to just
>> check !block->bmap here.
> I think the faster way might be that we check against the migration
> state.
>
Sounds good. We can do a sanity check:
MigrationState *s = migrate_get_current();
if (!migration_is_setup_or_active(s->state))
return;
>>
>>>> +
>>>> + for (; len > 0; len -= used_len) {
>>>> + block = qemu_ram_block_from_host(addr, false, &offset);
>>>> + if (unlikely(!block)) {
>>>> + return;
>>> We should never reach here, should we? Assuming the callers of this
>>> function should always pass in a correct host address. If we are very
>>> sure that the host addr should be valid, could we just assert?
>> Probably not the case, because of the corner case that the memory would be
>> hot unplugged after the free page is reported to QEMU.
> Question: Do we allow to do hot plug/unplug for memory during
> migration?
I think so. From the code, I don't find where it forbids memory hotplug
during migration.
>>
>>
>>>> + }
>>>> +
>>>> + /*
>>>> + * This handles the case that the RAMBlock is resized after the free
>>>> + * page hint is reported.
>>>> + */
>>>> + if (unlikely(offset > block->used_length)) {
>>>> + return;
>>>> + }
>>>> +
>>>> + if (len <= block->used_length - offset) {
>>>> + used_len = len;
>>>> + } else {
>>>> + used_len = block->used_length - offset;
>>>> + addr += used_len;
>>>> + }
>>>> +
>>>> + start = offset >> TARGET_PAGE_BITS;
>>>> + npages = used_len >> TARGET_PAGE_BITS;
>>>> +
>>>> + qemu_mutex_lock(&ram_state->bitmap_mutex);
>>> So now I think I understand the lock can still be meaningful since
>>> this function now can be called outside the migration thread (e.g., in
>>> vcpu thread). But still it would be nice to mention it somewhere on
> (Actually after read the next patch I think it's in iothread, so I'd
> better reply with all the series read over next time :)
That's fine actually :) Whether it is called by an iothread or a vcpu
thread doesn't affect our discussion here.
I think we could just focus on the interfaces here and the usage in live
migration. I can explain more when needed.
Best,
Wei
next prev parent reply other threads:[~2018-06-01 12:28 UTC|newest]
Thread overview: 93+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-24 6:13 [virtio-dev] [PATCH v7 0/5] virtio-balloon: free page hint reporting support Wei Wang
2018-04-24 6:13 ` [Qemu-devel] " Wei Wang
2018-04-24 6:13 ` [virtio-dev] [PATCH v7 1/5] bitmap: bitmap_count_one_with_offset Wei Wang
2018-04-24 6:13 ` [Qemu-devel] " Wei Wang
2018-04-24 6:13 ` [virtio-dev] [PATCH v7 2/5] migration: use bitmap_mutex in migration_bitmap_clear_dirty Wei Wang
2018-04-24 6:13 ` [Qemu-devel] " Wei Wang
2018-06-01 3:37 ` Peter Xu
2018-04-24 6:13 ` [virtio-dev] [PATCH v7 3/5] migration: API to clear bits of guest free pages from the dirty bitmap Wei Wang
2018-04-24 6:13 ` [Qemu-devel] " Wei Wang
2018-06-01 4:00 ` Peter Xu
2018-06-01 7:36 ` [virtio-dev] " Wei Wang
2018-06-01 7:36 ` Wei Wang
2018-06-01 10:06 ` Peter Xu
2018-06-01 12:32 ` Wei Wang [this message]
2018-06-01 12:32 ` Wei Wang
2018-06-04 2:49 ` Peter Xu
2018-06-04 7:43 ` [virtio-dev] " Wei Wang
2018-06-04 7:43 ` Wei Wang
2018-04-24 6:13 ` [virtio-dev] [PATCH v7 4/5] virtio-balloon: VIRTIO_BALLOON_F_FREE_PAGE_HINT Wei Wang
2018-04-24 6:13 ` [Qemu-devel] " Wei Wang
2018-05-29 15:24 ` [virtio-dev] " Michael S. Tsirkin
2018-05-29 15:24 ` [Qemu-devel] " Michael S. Tsirkin
2018-05-30 9:12 ` [virtio-dev] " Wei Wang
2018-05-30 9:12 ` [Qemu-devel] " Wei Wang
2018-05-30 12:47 ` [virtio-dev] " Michael S. Tsirkin
2018-05-30 12:47 ` [Qemu-devel] " Michael S. Tsirkin
2018-05-31 2:27 ` [virtio-dev] " Wei Wang
2018-05-31 2:27 ` [Qemu-devel] " Wei Wang
2018-05-31 17:42 ` [virtio-dev] " Michael S. Tsirkin
2018-05-31 17:42 ` [Qemu-devel] " Michael S. Tsirkin
2018-06-01 3:18 ` [virtio-dev] " Wei Wang
2018-06-01 3:18 ` [Qemu-devel] " Wei Wang
2018-06-04 8:04 ` [virtio-dev] " Wei Wang
2018-06-04 8:04 ` [Qemu-devel] " Wei Wang
2018-06-05 6:58 ` Peter Xu
2018-06-05 13:22 ` [virtio-dev] " Wei Wang
2018-06-05 13:22 ` [Qemu-devel] " Wei Wang
2018-06-06 5:42 ` Peter Xu
2018-06-06 10:04 ` [virtio-dev] " Wei Wang
2018-06-06 10:04 ` [Qemu-devel] " Wei Wang
2018-06-06 11:02 ` Peter Xu
2018-06-07 5:24 ` [virtio-dev] " Wei Wang
2018-06-07 5:24 ` [Qemu-devel] " Wei Wang
2018-06-07 6:32 ` Peter Xu
2018-06-07 11:59 ` [virtio-dev] " Wei Wang
2018-06-07 11:59 ` [Qemu-devel] " Wei Wang
2018-06-08 2:17 ` Peter Xu
2018-06-08 7:14 ` [virtio-dev] " Wei Wang
2018-06-08 7:14 ` [Qemu-devel] " Wei Wang
2018-06-08 7:31 ` [virtio-dev] " Wei Wang
2018-06-08 7:31 ` [Qemu-devel] " Wei Wang
2018-06-06 6:43 ` Peter Xu
2018-06-06 10:11 ` [virtio-dev] " Wei Wang
2018-06-06 10:11 ` Wei Wang
2018-06-07 3:17 ` Peter Xu
2018-06-07 5:29 ` [virtio-dev] " Wei Wang
2018-06-07 5:29 ` Wei Wang
2018-06-07 6:58 ` Peter Xu
2018-06-07 12:01 ` [virtio-dev] " Wei Wang
2018-06-07 12:01 ` Wei Wang
2018-06-08 1:37 ` Peter Xu
2018-06-08 1:58 ` Peter Xu
2018-06-08 1:58 ` [virtio-dev] " Michael S. Tsirkin
2018-06-08 1:58 ` Michael S. Tsirkin
2018-06-08 2:34 ` Peter Xu
2018-06-08 2:49 ` [virtio-dev] " Michael S. Tsirkin
2018-06-08 2:49 ` Michael S. Tsirkin
2018-06-08 3:34 ` Peter Xu
2018-04-24 6:13 ` [virtio-dev] [PATCH v7 5/5] migration: use the free page hint feature from balloon Wei Wang
2018-04-24 6:13 ` [Qemu-devel] " Wei Wang
2018-04-24 6:42 ` [virtio-dev] Re: [PATCH v7 0/5] virtio-balloon: free page hint reporting support Wei Wang
2018-04-24 6:42 ` [Qemu-devel] " Wei Wang
2018-05-14 1:22 ` [virtio-dev] " Wei Wang
2018-05-14 1:22 ` [Qemu-devel] " Wei Wang
2018-05-29 15:00 ` Hailiang Zhang
2018-05-29 15:24 ` [virtio-dev] " Michael S. Tsirkin
2018-05-29 15:24 ` Michael S. Tsirkin
2018-06-01 4:58 ` Peter Xu
2018-06-01 5:07 ` Peter Xu
2018-06-01 7:29 ` [virtio-dev] " Wei Wang
2018-06-01 7:29 ` Wei Wang
2018-06-01 10:02 ` Peter Xu
2018-06-01 12:31 ` [virtio-dev] " Wei Wang
2018-06-01 12:31 ` Wei Wang
2018-06-01 7:21 ` [virtio-dev] " Wei Wang
2018-06-01 7:21 ` Wei Wang
2018-06-01 10:40 ` Peter Xu
2018-06-01 15:33 ` Dr. David Alan Gilbert
2018-06-05 6:42 ` Peter Xu
2018-06-05 14:40 ` [virtio-dev] " Michael S. Tsirkin
2018-06-05 14:40 ` Michael S. Tsirkin
2018-06-05 14:39 ` [virtio-dev] " Michael S. Tsirkin
2018-06-05 14:39 ` Michael S. Tsirkin
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=5B113CDB.2090109@intel.com \
--to=wei.w.wang@intel.com \
--cc=dgilbert@redhat.com \
--cc=liliang.opensource@gmail.com \
--cc=mst@redhat.com \
--cc=nilal@redhat.com \
--cc=pbonzini@redhat.com \
--cc=peterx@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=quan.xu0@gmail.com \
--cc=quintela@redhat.com \
--cc=virtio-dev@lists.oasis-open.org \
--cc=yang.zhang.wz@gmail.com \
/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.