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:
Michal Privoznik 2024-04-22 11:55:46 +02:00
parent 3c948ef699
commit da95bcb6b2

View File

@ -2334,6 +2334,8 @@ qemuProcessDetectIOThreadPIDs(virDomainObj *vm,
static int static int
qemuProcessGetAllCpuAffinity(virBitmap **cpumapRet) qemuProcessGetAllCpuAffinity(virBitmap **cpumapRet)
{ {
g_autoptr(virBitmap) isolCpus = NULL;
*cpumapRet = NULL; *cpumapRet = NULL;
if (!virHostCPUHasBitmap()) if (!virHostCPUHasBitmap())
@ -2342,6 +2344,13 @@ qemuProcessGetAllCpuAffinity(virBitmap **cpumapRet)
if (!(*cpumapRet = virHostCPUGetOnlineBitmap())) if (!(*cpumapRet = virHostCPUGetOnlineBitmap()))
return -1; return -1;
if (virHostCPUGetIsolated(&isolCpus) < 0)
return -1;
if (isolCpus) {
virBitmapSubtract(*cpumapRet, isolCpus);
}
return 0; return 0;
} }