vfio/migration: Block VFIO migration with background snapshot
commit615379764ae67f30a0fcbffeb20d6645f010091c
authorAvihai Horon <avihaih@nvidia.com>
Wed, 6 Sep 2023 15:08:53 +0000 (6 18:08 +0300)
committerCédric Le Goater <clg@redhat.com>
Mon, 11 Sep 2023 06:34:06 +0000 (11 08:34 +0200)
tree8333cf2d62a68faa4bec3c698ab7469c59d10b80
parentbf7ef7a2da3e61dc104f26c679c9465e3fbe7dde
vfio/migration: Block VFIO migration with background snapshot

Background snapshot allows creating a snapshot of the VM while it's
running and keeping it small by not including dirty RAM pages.

The way it works is by first stopping the VM, saving the non-iterable
devices' state and then starting the VM and saving the RAM while write
protecting it with UFFD. The resulting snapshot represents the VM state
at snapshot start.

VFIO migration is not compatible with background snapshot.
First of all, VFIO device state is not even saved in background snapshot
because only non-iterable device state is saved. But even if it was
saved, after starting the VM, a VFIO device could dirty pages without it
being detected by UFFD write protection. This would corrupt the
snapshot, as the RAM in it would not represent the RAM at snapshot
start.

To prevent this, block VFIO migration with background snapshot.

Signed-off-by: Avihai Horon <avihaih@nvidia.com>
Reviewed-by: Peter Xu <peterx@redhat.com>
Signed-off-by: Cédric Le Goater <clg@redhat.com>
hw/vfio/migration.c