diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2012-10-23 14:54:21 +0200 |
---|---|---|
committer | Luiz Capitulino <lcapitulino@redhat.com> | 2012-10-24 11:27:33 -0200 |
commit | 1e9981465f05a0f103d7e09afd975c9c0ff6d132 (patch) | |
tree | 614b2fb31ba681b4bde1d2ed2f3a97b9f790227a /qerror.h | |
parent | 852bef0e0c03e2de9d6441471219cd3bc1bf45b5 (diff) | |
download | qemu-1e9981465f05a0f103d7e09afd975c9c0ff6d132.zip qemu-1e9981465f05a0f103d7e09afd975c9c0ff6d132.tar.gz qemu-1e9981465f05a0f103d7e09afd975c9c0ff6d132.tar.bz2 |
qmp: handle stop/cont in INMIGRATE state
Right now, stop followed by an incoming migration will let the
virtual machine start. cont before an incoming migration instead
will fail.
This is bad because the actual behavior is not predictable; it is
racy with respect to the start of the incoming migration. That's
because incoming migration is blocking, and thus will delay the
processing of stop/cont until the end of the migration.
In addition, there's nothing that really prevents the user from
typing the block device's passwords before incoming migration is
done, so returning the DeviceEncrypted error is also helpful in
the QMP case.
Both things can be fixed by just toggling the autostart variable when
stop/cont are called in INMIGRATE state.
Note that libvirt is currently working around the race by looping
if the MigrationExpected answer is returned. After this patch, the
command will return right away without ever raising an error.
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
Diffstat (limited to 'qerror.h')
-rw-r--r-- | qerror.h | 3 |
1 files changed, 0 insertions, 3 deletions
@@ -165,9 +165,6 @@ void assert_no_error(Error *err); #define QERR_MIGRATION_NOT_SUPPORTED \ ERROR_CLASS_GENERIC_ERROR, "State blocked by non-migratable device '%s'" -#define QERR_MIGRATION_EXPECTED \ - ERROR_CLASS_MIGRATION_EXPECTED, "An incoming migration is expected before this command can be executed" - #define QERR_MISSING_PARAMETER \ ERROR_CLASS_GENERIC_ERROR, "Parameter '%s' is missing" |