qemu: avoid closing fd more than once

If we migrate to fd, spec->fwdType is not MIGRATION_FWD_DIRECT,
we will close spec->dest.fd.local in qemuMigrationRun(). So we
should set spec->dest.fd.local to -1 in qemuMigrationRun().

Bug present since 0.9.5 (commit 326176179).
This commit is contained in:
Wen Congyang 2012-05-30 17:20:44 +08:00 committed by Eric Blake
parent 746ff701e8
commit b19c236d69

View File

@ -1910,8 +1910,10 @@ qemuMigrationRun(struct qemud_driver *driver,
break; break;
case MIGRATION_DEST_FD: case MIGRATION_DEST_FD:
if (spec->fwdType != MIGRATION_FWD_DIRECT) if (spec->fwdType != MIGRATION_FWD_DIRECT) {
fd = spec->dest.fd.local; fd = spec->dest.fd.local;
spec->dest.fd.local = -1;
}
ret = qemuMonitorMigrateToFd(priv->mon, migrate_flags, ret = qemuMonitorMigrateToFd(priv->mon, migrate_flags,
spec->dest.fd.qemu); spec->dest.fd.qemu);
VIR_FORCE_CLOSE(spec->dest.fd.qemu); VIR_FORCE_CLOSE(spec->dest.fd.qemu);