qemu: Clear async job when p2p migration fails early

When p2p migration fails early because qemuMigrationIsAllowed or
qemuMigrationIsSafe say migration should be cancelled, we fail to clear
the migration-out async job. As a result of that, further APIs called
for the same domain may fail with Timed out during operation: cannot
acquire state change lock.

Reported by Guido Winkelmann.
This commit is contained in:
Jiri Denemark 2012-10-17 14:08:17 +02:00
parent 997d97c34e
commit d325704a3f

View File

@ -2624,10 +2624,10 @@ qemuMigrationPerformJob(struct qemud_driver *driver,
} }
if (!qemuMigrationIsAllowed(driver, vm, NULL)) if (!qemuMigrationIsAllowed(driver, vm, NULL))
goto cleanup; goto endjob;
if (!(flags & VIR_MIGRATE_UNSAFE) && !qemuMigrationIsSafe(vm->def)) if (!(flags & VIR_MIGRATE_UNSAFE) && !qemuMigrationIsSafe(vm->def))
goto cleanup; goto endjob;
resume = virDomainObjGetState(vm, NULL) == VIR_DOMAIN_RUNNING; resume = virDomainObjGetState(vm, NULL) == VIR_DOMAIN_RUNNING;