mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 14:57:42 +00:00
e5a0579996
This patch addresses the same aspects on PPC the bug 1103314 addressed on x86. PCI expander bus creates multiple primary PCI busses, where each of these busses can be assigned a specific NUMA affinity, which, on x86 is advertised through ACPI on a per-bus basis. For SPAPR, a PHB's NUMA affinities are assigned on a per-PHB basis, and there is no mechanism for advertising NUMA affinities to a guest on a per-bus basis. So, even if qemu-ppc manages to get some sort of multi-bus topology working using PXB, there is no way to expose the affinities of these busses to the guest. It can only be exposed on a per-PHB/per-domain basis. So patch enables NUMA node tag in pci-root controller on PPC. The way to set the NUMA node is through the numa_node option of spapr-pci-host-bridge device. However for the implicit PHB, the only way to set the numa_node is from the -global option. The -global option applies to all the PHBs unless explicitly specified with the option on the respective PHB of CLI. The default PHB has the emulated devices only, so the patch prevents setting the NUMA node for the default PHB. Signed-off-by: Shivaprasad G Bhat <sbhat@linux.vnet.ibm.com> Reviewed-by: Andrea Bolognani <abologna@redhat.com>
42 lines
1.2 KiB
XML
42 lines
1.2 KiB
XML
<domain type='qemu'>
|
|
<name>QEMUGuest1</name>
|
|
<uuid>87eedafe-eedc-4336-8130-ed9fe5dc90c8</uuid>
|
|
<memory unit='KiB'>2097152</memory>
|
|
<vcpu placement='static'>8</vcpu>
|
|
<numatune>
|
|
<memnode cellid="0" mode="strict" nodeset="1"/>
|
|
<memnode cellid="1" mode="strict" nodeset="2"/>
|
|
</numatune>
|
|
<cpu>
|
|
<topology sockets='2' cores='1' threads='4'/>
|
|
<numa>
|
|
<cell id='0' cpus='0-3' memory='1048576' unit='KiB'/>
|
|
<cell id='1' cpus='4-7' memory='1048576' unit='KiB'/>
|
|
</numa>
|
|
</cpu>
|
|
<os>
|
|
<type arch='ppc64' machine='pseries'>hvm</type>
|
|
</os>
|
|
<devices>
|
|
<emulator>/usr/bin/qemu-system-ppc64</emulator>
|
|
<controller type='usb' model='none' index='0'/>
|
|
<controller type='pci' index='0' model='pci-root'>
|
|
<target index='0'/>
|
|
</controller>
|
|
<controller type='pci' index='1' model='pci-root'>
|
|
<target index='1'>
|
|
<node>1</node>
|
|
</target>
|
|
</controller>
|
|
<controller type='pci' index='2' model='pci-root'>
|
|
<target index='2'/>
|
|
</controller>
|
|
<controller type='pci' index='3' model='pci-root'>
|
|
<target index='3'>
|
|
<node>0</node>
|
|
</target>
|
|
</controller>
|
|
<memballoon model='none'/>
|
|
</devices>
|
|
</domain>
|