"Dr. David Alan Gilbert" <dgilb...@redhat.com> writes: > * Markus Armbruster (arm...@redhat.com) wrote: >> We appear to use migration blockers in two ways: >> >> (1) Prevent migration for an indefinite time, typically due to use of >> some feature that isn't compatible with migration. >> >> (2) Delay migration for a short time. >> >> Option -only-migrate is designed for (1). It interferes with (2). >> >> Example for (1): device "x-pci-proxy-dev" doesn't support migration. It >> adds a migration blocker on realize, and deletes it on unrealize. With >> -only-migrate, device realize fails. Works as designed. >> >> Example for (2): spapr_mce_req_event() makes an effort to prevent >> migration degrate the reporting of FWNMIs. It adds a migration blocker >> when it receives one, and deletes it when it's done handling it. This >> is a best effort; if migration is already in progress by the time FWNMI >> is received, we simply carry on, and that's okay. However, option >> -only-migrate sabotages the best effort entirely. > > That's interesting; it's the first time I've heard of anyone using it as > 'best effort'. I've always regarded blockers as blocking.
Me too, until I found this one. >> While this isn't exactly terrible, it may be a weakness in our thinking >> and our infrastructure. I'm bringing it up so the people in charge are >> aware :) > > Thanks. > > It almost feels like they need a way to temporarily hold off > 'completion' of migratio - i.e. the phase where we stop the CPU and > write the device data; mind you you'd also probably want it to stop > cold-migrates/snapshots? Yes, a proper way to delay 'completion' for a bit would be clearer, and wouldn't let -only-migrate interfere.