[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the
From: |
Jason Gunthorpe |
Subject: |
Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped |
Date: |
Tue, 18 Oct 2022 09:22:43 -0300 |
On Fri, Oct 14, 2022 at 01:29:51PM +0100, Joao Martins wrote:
> On 14/10/2022 12:28, Juan Quintela wrote:
> > Joao Martins <joao.m.martins@oracle.com> wrote:
> >> On 13/10/2022 17:08, Juan Quintela wrote:
> >>> Oops. My understanding was that once the guest is stopped you can say
> >>> how big is it.
> >
> > Hi
> >
> >> It's worth keeping in mind that conceptually a VF won't stop (e.g. DMA)
> >> until
> >> really told through VFIO. So, stopping CPUs (guest) just means that guest
> >> code
> >> does not arm the VF for more I/O but still is a weak guarantee as VF still
> >> has
> >> outstanding I/O to deal with until VFIO tells it to quiesce DMA (for
> >> devices
> >> that support it).
> >
> > How can we make sure about that?
> >
> > i.e. I know I have a vfio device. I need two things:
> > - in the iterative stage, I eed to check the size, but a estimate is ok.
> > for example with RAM, we use whatever is the size of the dirty bitmap
> > at that moment.
> > If the estimated size is smaller than the theshold, we
> > * stop the guest
> > * sync dirty bitmap
> > * now we test the (real) dirty bitmap size
> >
> > How can we do something like that with a vfio device.
> >
> You would have an extra intermediate step that stops the VF prior to asking
> the device state length. What I am not sure is whether stopping
> vCPUs can be skipped as an optimization.
It cannot, if you want to stop the VFIO device you must also stop the
vCPUs because the device is not required to respond properly to MMIO
operations when stopped.
> > My understanding from NVidia folks was that newer firmware have an ioctl
> > to return than information.
>
> Maybe there's something new. I was thinking from this here:
Juan is talking about the ioctl we had in the pre-copy series.
I expect it to come into some different form to support this RFC.
Jason
- [RFC 4/7] migration: Split save_live_pending() into state_pending_*, (continued)
- [RFC 4/7] migration: Split save_live_pending() into state_pending_*, Juan Quintela, 2022/10/02
- [RFC 2/7] migration: No save_live_pending() method uses the QEMUFile parameter, Juan Quintela, 2022/10/02
- [RFC 5/7] migration: Remove unused threshold_size parameter, Juan Quintela, 2022/10/02
- [RFC 6/7] migration: simplify migration_iteration_run(), Juan Quintela, 2022/10/02
- [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Juan Quintela, 2022/10/02
- Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Joao Martins, 2022/10/13
- Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Juan Quintela, 2022/10/13
- Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Joao Martins, 2022/10/14
- Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Juan Quintela, 2022/10/14
- Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Joao Martins, 2022/10/14
- Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped,
Jason Gunthorpe <=
- RE: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Yishai Hadas, 2022/10/19
- Re: [RFC 7/7] migration: call qemu_savevm_state_pending_exact() with the guest stopped, Jason Gunthorpe, 2022/10/15
RE: [RFC 0/7] migration patches for VFIO, Yishai Hadas, 2022/10/20