提交 6d646947 编写于 作者: J Jiri Denemark

qemu: Preserve original error during migration

In some cases (spotted with broken connection during tunneled migration)
we were overwriting the original error with worse or even misleading
errors generated when we were cleaning up after failed migration.
上级 6446a9e2
...@@ -1733,6 +1733,7 @@ qemuMigrationRun(struct qemud_driver *driver, ...@@ -1733,6 +1733,7 @@ qemuMigrationRun(struct qemud_driver *driver,
qemuMigrationIOThreadPtr iothread = NULL; qemuMigrationIOThreadPtr iothread = NULL;
int fd = -1; int fd = -1;
unsigned long migrate_speed = resource ? resource : priv->migMaxBandwidth; unsigned long migrate_speed = resource ? resource : priv->migMaxBandwidth;
virErrorPtr orig_err = NULL;
VIR_DEBUG("driver=%p, vm=%p, cookiein=%s, cookieinlen=%d, " VIR_DEBUG("driver=%p, vm=%p, cookiein=%s, cookieinlen=%d, "
"cookieout=%p, cookieoutlen=%p, flags=%lx, resource=%lu, " "cookieout=%p, cookieoutlen=%p, flags=%lx, resource=%lu, "
...@@ -1874,6 +1875,9 @@ qemuMigrationRun(struct qemud_driver *driver, ...@@ -1874,6 +1875,9 @@ qemuMigrationRun(struct qemud_driver *driver,
ret = 0; ret = 0;
cleanup: cleanup:
if (ret < 0 && !orig_err)
orig_err = virSaveLastError();
if (spec->fwdType != MIGRATION_FWD_DIRECT) { if (spec->fwdType != MIGRATION_FWD_DIRECT) {
/* Close now to ensure the IO thread quits & is joinable */ /* Close now to ensure the IO thread quits & is joinable */
VIR_FORCE_CLOSE(fd); VIR_FORCE_CLOSE(fd);
...@@ -1888,9 +1892,16 @@ cleanup: ...@@ -1888,9 +1892,16 @@ cleanup:
qemuMigrationCookieFree(mig); qemuMigrationCookieFree(mig);
if (orig_err) {
virSetError(orig_err);
virFreeError(orig_err);
}
return ret; return ret;
cancel: cancel:
orig_err = virSaveLastError();
if (virDomainObjIsActive(vm)) { if (virDomainObjIsActive(vm)) {
if (qemuDomainObjEnterMonitorAsync(driver, vm, if (qemuDomainObjEnterMonitorAsync(driver, vm,
QEMU_ASYNC_JOB_MIGRATION_OUT) == 0) { QEMU_ASYNC_JOB_MIGRATION_OUT) == 0) {
...@@ -2495,6 +2506,7 @@ qemuMigrationPerformJob(struct qemud_driver *driver, ...@@ -2495,6 +2506,7 @@ qemuMigrationPerformJob(struct qemud_driver *driver,
virDomainEventPtr event = NULL; virDomainEventPtr event = NULL;
int ret = -1; int ret = -1;
int resume = 0; int resume = 0;
virErrorPtr orig_err = NULL;
if (qemuMigrationJobStart(driver, vm, QEMU_ASYNC_JOB_MIGRATION_OUT) < 0) if (qemuMigrationJobStart(driver, vm, QEMU_ASYNC_JOB_MIGRATION_OUT) < 0)
goto cleanup; goto cleanup;
...@@ -2540,6 +2552,9 @@ qemuMigrationPerformJob(struct qemud_driver *driver, ...@@ -2540,6 +2552,9 @@ qemuMigrationPerformJob(struct qemud_driver *driver,
resume = 0; resume = 0;
endjob: endjob:
if (ret < 0)
orig_err = virSaveLastError();
if (resume && virDomainObjGetState(vm, NULL) == VIR_DOMAIN_PAUSED) { if (resume && virDomainObjGetState(vm, NULL) == VIR_DOMAIN_PAUSED) {
/* we got here through some sort of failure; start the domain again */ /* we got here through some sort of failure; start the domain again */
if (qemuProcessStartCPUs(driver, vm, conn, if (qemuProcessStartCPUs(driver, vm, conn,
...@@ -2569,6 +2584,11 @@ endjob: ...@@ -2569,6 +2584,11 @@ endjob:
vm = NULL; vm = NULL;
} }
if (orig_err) {
virSetError(orig_err);
virFreeError(orig_err);
}
cleanup: cleanup:
if (vm) if (vm)
virDomainObjUnlock(vm); virDomainObjUnlock(vm);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册