From: Luiz Capitulino Date: Mon, 30 Dec 2013 03:39:58 +0000 (-0500) Subject: migration: qmp_migrate(): keep working after syntax error X-Git-Tag: v1.7.1~24 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=15a14f2eeb76f82b742d009cf320972e7d173f49;p=thirdparty%2Fqemu.git migration: qmp_migrate(): keep working after syntax error If a user or QMP client enter a bad syntax for the migrate command in QMP/HMP, then the migrate command will never succeed from that point on. For example, if you enter: (qemu) migrate tcp;0:4444 migrate: Parameter 'uri' expects a valid migration protocol Then the migrate command will always fail from now on: (qemu) migrate tcp:0:4444 migrate: There's a migration process in progress The problem is that qmp_migrate() sets the migration status to MIG_STATE_SETUP and doesn't reset it on syntax error. This bug was introduced by commit 29ae8a4133082e16970c9d4be09f4b6a15034617. Reviewed-by: Michael R. Hines Signed-off-by: Luiz Capitulino (cherry picked from commit c950114286ea358a93ce632db0421945e1008395) Signed-off-by: Michael Roth --- diff --git a/migration.c b/migration.c index ff00bfbe365..79c86c92daf 100644 --- a/migration.c +++ b/migration.c @@ -437,6 +437,7 @@ void qmp_migrate(const char *uri, bool has_blk, bool blk, #endif } else { error_set(errp, QERR_INVALID_PARAMETER_VALUE, "uri", "a valid migration protocol"); + s->state = MIG_STATE_ERROR; return; }