mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-23 13:05:27 +00:00
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.
This commit is contained in:
parent
5531a13c5f
commit
d63f0754e3
@ -1732,6 +1732,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, "
|
||||||
@ -1873,6 +1874,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);
|
||||||
@ -1887,9 +1891,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) {
|
||||||
@ -2494,6 +2505,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;
|
||||||
@ -2539,6 +2551,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,
|
||||||
@ -2568,6 +2583,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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user