mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 07:17:44 +00:00
Fix QEMU tunnelled migration FD handling
The two ends of the pipe used for feeding QEMU tunnelled migration data were interchanged, so QEMU got given the "write" end instead of the "read" end. The qemuMigrationPrepareTunnel method was also immediately closing the "write" end of the pipe, so the stream failed to actually write anything. * src/qemu/qemu_migration.c: Swap tunnelled migration pipe FDs & don't close pipe given to stream
This commit is contained in:
parent
1fc288e1e2
commit
29fca78541
@ -301,7 +301,7 @@ qemuMigrationPrepareTunnel(struct qemud_driver *driver,
|
|||||||
vm->def->id = -1;
|
vm->def->id = -1;
|
||||||
|
|
||||||
if (pipe(dataFD) < 0 ||
|
if (pipe(dataFD) < 0 ||
|
||||||
virSetCloseExec(dataFD[0]) < 0) {
|
virSetCloseExec(dataFD[1]) < 0) {
|
||||||
virReportSystemError(errno, "%s",
|
virReportSystemError(errno, "%s",
|
||||||
_("cannot create pipe for tunnelled migration"));
|
_("cannot create pipe for tunnelled migration"));
|
||||||
goto endjob;
|
goto endjob;
|
||||||
@ -318,7 +318,7 @@ qemuMigrationPrepareTunnel(struct qemud_driver *driver,
|
|||||||
/* Start the QEMU daemon, with the same command-line arguments plus
|
/* Start the QEMU daemon, with the same command-line arguments plus
|
||||||
* -incoming stdio (which qemu_command might convert to exec:cat or fd:n)
|
* -incoming stdio (which qemu_command might convert to exec:cat or fd:n)
|
||||||
*/
|
*/
|
||||||
internalret = qemuProcessStart(dconn, driver, vm, "stdio", true, dataFD[1],
|
internalret = qemuProcessStart(dconn, driver, vm, "stdio", true, dataFD[0],
|
||||||
NULL, VIR_VM_OP_MIGRATE_IN_START);
|
NULL, VIR_VM_OP_MIGRATE_IN_START);
|
||||||
if (internalret < 0) {
|
if (internalret < 0) {
|
||||||
qemuAuditDomainStart(vm, "migrated", false);
|
qemuAuditDomainStart(vm, "migrated", false);
|
||||||
@ -332,7 +332,7 @@ qemuMigrationPrepareTunnel(struct qemud_driver *driver,
|
|||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virFDStreamOpen(st, dataFD[0]) < 0) {
|
if (virFDStreamOpen(st, dataFD[1]) < 0) {
|
||||||
qemuAuditDomainStart(vm, "migrated", false);
|
qemuAuditDomainStart(vm, "migrated", false);
|
||||||
qemuProcessStop(driver, vm, 0);
|
qemuProcessStop(driver, vm, 0);
|
||||||
if (!vm->persistent) {
|
if (!vm->persistent) {
|
||||||
@ -344,6 +344,7 @@ qemuMigrationPrepareTunnel(struct qemud_driver *driver,
|
|||||||
_("cannot pass pipe for tunnelled migration"));
|
_("cannot pass pipe for tunnelled migration"));
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
dataFD[1] = -1; /* 'st' owns the FD now & will close it */
|
||||||
|
|
||||||
qemuAuditDomainStart(vm, "migrated", true);
|
qemuAuditDomainStart(vm, "migrated", true);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user