mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-22 05:35:25 +00:00
qemu: Substract isolcpus from all online affinity
When starting a domain and there's no vCPU/emulator pinning set, we query the list of all online physical CPUs and set affinity of the child process (which eventually becomes QEMU) to that list. We can't assume libvirtd itself had affinity to all online CPUs and since affinity of the child process is inherited, we should fix it afterwards. But that's not necessarily correct. Users might isolate some physical CPUs and we should avoid touching them unless explicitly told so (i.e. vCPU/emulator pinning told us so). Therefore, when attempting to set affinity to all online CPUs subtract the isolated ones. Before this commit: root@localhost:~# cat /sys/devices/system/cpu/isolated 19,21,23 root@virtlab414:~# taskset -cp $(pgrep qemu) pid 14835's current affinity list: 0-23 After: root@virtlab414:~# taskset -cp $(pgrep qemu) pid 17153's current affinity list: 0-18,20,22 Resolves: https://issues.redhat.com/browse/RHEL-33082 Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
This commit is contained in:
parent
3c948ef699
commit
da95bcb6b2
@ -2334,6 +2334,8 @@ qemuProcessDetectIOThreadPIDs(virDomainObj *vm,
|
||||
static int
|
||||
qemuProcessGetAllCpuAffinity(virBitmap **cpumapRet)
|
||||
{
|
||||
g_autoptr(virBitmap) isolCpus = NULL;
|
||||
|
||||
*cpumapRet = NULL;
|
||||
|
||||
if (!virHostCPUHasBitmap())
|
||||
@ -2342,6 +2344,13 @@ qemuProcessGetAllCpuAffinity(virBitmap **cpumapRet)
|
||||
if (!(*cpumapRet = virHostCPUGetOnlineBitmap()))
|
||||
return -1;
|
||||
|
||||
if (virHostCPUGetIsolated(&isolCpus) < 0)
|
||||
return -1;
|
||||
|
||||
if (isolCpus) {
|
||||
virBitmapSubtract(*cpumapRet, isolCpus);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user