[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 12/17] hw/i386/pc: Support smp.clusters for x86 PC machine
|
From: |
Zhao Liu |
|
Subject: |
[PATCH v2 12/17] hw/i386/pc: Support smp.clusters for x86 PC machine |
|
Date: |
Mon, 29 May 2023 20:30:56 +0800 |
From: Zhuocheng Ding <zhuocheng.ding@intel.com>
As module-level topology support is added to X86CPU, now we can enable
the support for the cluster parameter on PC machines. With this support,
we can define a 5-level x86 CPU topology with "-smp":
-smp cpus=*,maxcpus=*,sockets=*,dies=*,clusters=*,cores=*,threads=*.
Additionally, add the 5-level topology example in description of "-smp".
Signed-off-by: Zhuocheng Ding <zhuocheng.ding@intel.com>
Signed-off-by: Zhao Liu <zhao1.liu@intel.com>
Reviewed-by: Yanan Wang <wangyanan55@huawei.com>
---
hw/i386/pc.c | 1 +
qemu-options.hx | 10 +++++-----
2 files changed, 6 insertions(+), 5 deletions(-)
diff --git a/hw/i386/pc.c b/hw/i386/pc.c
index bb62c994fad3..e16eef1a84e1 100644
--- a/hw/i386/pc.c
+++ b/hw/i386/pc.c
@@ -1979,6 +1979,7 @@ static void pc_machine_class_init(ObjectClass *oc, void
*data)
mc->default_cpu_type = TARGET_DEFAULT_CPU_TYPE;
mc->nvdimm_supported = true;
mc->smp_props.dies_supported = true;
+ mc->smp_props.clusters_supported = true;
mc->default_ram_id = "pc.ram";
object_class_property_add(oc, PC_MACHINE_MAX_RAM_BELOW_4G, "size",
diff --git a/qemu-options.hx b/qemu-options.hx
index b37eb9662bfe..a51fab793899 100644
--- a/qemu-options.hx
+++ b/qemu-options.hx
@@ -319,14 +319,14 @@ SRST
-smp 8,sockets=2,cores=2,threads=2,maxcpus=8
The following sub-option defines a CPU topology hierarchy (2 sockets
- totally on the machine, 2 dies per socket, 2 cores per die, 2 threads
- per core) for PC machines which support sockets/dies/cores/threads.
- Some members of the option can be omitted but their values will be
- automatically computed:
+ totally on the machine, 2 dies per socket, 2 clusters per die, 2 cores per
+ cluster, 2 threads per core) for PC machines which support sockets/dies
+ /clusters/cores/threads. Some members of the option can be omitted but
+ their values will be automatically computed:
::
- -smp 16,sockets=2,dies=2,cores=2,threads=2,maxcpus=16
+ -smp 32,sockets=2,dies=2,clusters=2,cores=2,threads=2,maxcpus=32
The following sub-option defines a CPU topology hierarchy (2 sockets
totally on the machine, 2 clusters per socket, 2 cores per cluster,
--
2.34.1
- [PATCH v2 02/17] tests: Rename test-x86-cpuid.c to test-x86-topo.c, (continued)
- [PATCH v2 02/17] tests: Rename test-x86-cpuid.c to test-x86-topo.c, Zhao Liu, 2023/05/29
- [PATCH v2 06/17] i386/cpu: Consolidate the use of topo_info in cpu_x86_cpuid(), Zhao Liu, 2023/05/29
- [PATCH v2 07/17] i386: Introduce module-level cpu topology to CPUX86State, Zhao Liu, 2023/05/29
- [PATCH v2 09/17] i386: Support module_id in X86CPUTopoIDs, Zhao Liu, 2023/05/29
- [PATCH v2 05/17] i386/cpu: Use APIC ID offset to encode cache topo in CPUID[4], Zhao Liu, 2023/05/29
- [PATCH v2 10/17] i386/cpu: Introduce cluster-id to X86CPU, Zhao Liu, 2023/05/29
- [PATCH v2 11/17] tests: Add test case of APIC ID for module level parsing, Zhao Liu, 2023/05/29
- [PATCH v2 04/17] i386/cpu: Fix i/d-cache topology to core level for Intel CPU, Zhao Liu, 2023/05/29
- [PATCH v2 03/17] softmmu: Fix CPUSTATE.nr_cores' calculation, Zhao Liu, 2023/05/29
- [PATCH v2 08/17] i386: Support modules_per_die in X86CPUTopoInfo, Zhao Liu, 2023/05/29
- [PATCH v2 12/17] hw/i386/pc: Support smp.clusters for x86 PC machine,
Zhao Liu <=
- [PATCH v2 14/17] i386: Use CPUCacheInfo.share_level to encode CPUID[4], Zhao Liu, 2023/05/29
- [PATCH v2 13/17] i386: Add cache topology info in CPUCacheInfo, Zhao Liu, 2023/05/29
- [PATCH v2 15/17] i386: Fix NumSharingCache for CPUID[0x8000001D].EAX[bits 25:14], Zhao Liu, 2023/05/29
- [PATCH v2 16/17] i386: Use CPUCacheInfo.share_level to encode CPUID[0x8000001D].EAX[bits 25:14], Zhao Liu, 2023/05/29
- [PATCH v2 17/17] i386: Add new property to control L2 cache topo in CPUID.04H, Zhao Liu, 2023/05/29