diff options
author | Dr. David Alan Gilbert <dgilbert@redhat.com> | 2019-10-07 11:35:07 +0100 |
---|---|---|
committer | Dr. David Alan Gilbert <dgilbert@redhat.com> | 2019-10-11 14:25:26 +0100 |
commit | fb14a42ade228e2d6123af56c0015262fd83250d (patch) | |
tree | e32bc79b7ae4b04b75388422d3b57a6cdb2facae /migration | |
parent | 694ea274d9236cada361282960e3a0aba660dee5 (diff) | |
download | qemu-fb14a42ade228e2d6123af56c0015262fd83250d.zip qemu-fb14a42ade228e2d6123af56c0015262fd83250d.tar.gz qemu-fb14a42ade228e2d6123af56c0015262fd83250d.tar.bz2 |
migration: Don't try and recover return path in non-postcopy
In normal precopy we can't do reconnection recovery - but we also
don't need to, since you can just rerun migration.
At the moment if the 'return-path' capability is on, we use
the return path in precopy to give a positive 'OK' to the end
of migration; however if migration fails then we fall into
the postcopy recovery path and hang. This fixes it by only
running the return path in the postcopy case.
Reported-by: Greg Kurz <groug@kaod.org>
Tested-by: Greg Kurz <groug@kaod.org>
Reviewed-by: Peter Xu <peterx@redhat.com>
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Diffstat (limited to 'migration')
-rw-r--r-- | migration/migration.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/migration/migration.c b/migration/migration.c index 0c51aa6..d7f8b42 100644 --- a/migration/migration.c +++ b/migration/migration.c @@ -2486,7 +2486,7 @@ retry: out: res = qemu_file_get_error(rp); if (res) { - if (res == -EIO) { + if (res == -EIO && migration_in_postcopy()) { /* * Maybe there is something we can do: it looks like a * network down issue, and we pause for a recovery. |