mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 20:45:18 +00:00
qemu: Re-detect virtual cpu threads after cpu hot (un)plug.
After a cpu hotplug the qemu driver did not refresh information about virtual processors used by qemu and their corresponding threads. This patch forces a re-detection as is done on start of QEMU. This ensures that correct information is reported by the virDomainGetVcpus API and "virsh vcpuinfo". A failure to obtain the thread<->vcpu mapping is treated non-fatal and the mapping is not updated in a case of failure as not all versions of QEMU report this in the info cpus command. (cherry picked from commit 3163682b585da7e894c9ea069741755fc316bdb3)
This commit is contained in:
parent
a0be049f67
commit
6ef9ea9bbf
@ -3335,6 +3335,8 @@ static int qemudDomainHotplugVcpus(struct qemud_driver *driver,
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
int oldvcpus = vm->def->vcpus;
|
int oldvcpus = vm->def->vcpus;
|
||||||
int vcpus = oldvcpus;
|
int vcpus = oldvcpus;
|
||||||
|
pid_t *cpupids = NULL;
|
||||||
|
int ncpupids;
|
||||||
|
|
||||||
qemuDomainObjEnterMonitor(driver, vm);
|
qemuDomainObjEnterMonitor(driver, vm);
|
||||||
|
|
||||||
@ -3365,11 +3367,38 @@ static int qemudDomainHotplugVcpus(struct qemud_driver *driver,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* hotplug succeeded */
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
|
/* After hotplugging the CPUs we need to re-detect threads corresponding
|
||||||
|
* to the virtual CPUs. Some older versions don't provide the thread ID
|
||||||
|
* or don't have the "info cpus" command (and they don't support multiple
|
||||||
|
* CPUs anyways), so errors in the re-detection will not be treated
|
||||||
|
* fatal */
|
||||||
|
if ((ncpupids = qemuMonitorGetCPUInfo(priv->mon, &cpupids)) <= 0) {
|
||||||
|
virResetLastError();
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ncpupids != vcpus) {
|
||||||
|
qemuReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
|
_("got wrong number of vCPU pids from QEMU monitor. "
|
||||||
|
"got %d, wanted %d"),
|
||||||
|
ncpupids, vcpus);
|
||||||
|
ret = -1;
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
priv->nvcpupids = ncpupids;
|
||||||
|
VIR_FREE(priv->vcpupids);
|
||||||
|
priv->vcpupids = cpupids;
|
||||||
|
cpupids = NULL;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
qemuDomainObjExitMonitor(driver, vm);
|
qemuDomainObjExitMonitor(driver, vm);
|
||||||
vm->def->vcpus = vcpus;
|
vm->def->vcpus = vcpus;
|
||||||
|
VIR_FREE(cpupids);
|
||||||
virDomainAuditVcpu(vm, oldvcpus, nvcpus, "update", rc == 1);
|
virDomainAuditVcpu(vm, oldvcpus, nvcpus, "update", rc == 1);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user