提交 a64241ba 编写于 作者: J Jeremy Linton 提交者: Greg Kroah-Hartman

arm64: topology: Use PPTT to determine if PE is a thread

Commit 98dc19902a0b2e5348e43d6a2c39a0a7d0fc639e upstream.

ACPI 6.3 adds a thread flag to represent if a CPU/PE is
actually a thread. Given that the MPIDR_MT bit may not
represent this information consistently on homogeneous machines
we should prefer the PPTT flag if its available.
Signed-off-by: NJeremy Linton <jeremy.linton@arm.com>
Reviewed-by: NSudeep Holla <sudeep.holla@arm.com>
Reviewed-by: NRobert Richter <rrichter@marvell.com>
[will: made acpi_cpu_is_threaded() return 'bool']
Signed-off-by: NWill Deacon <will@kernel.org>
Signed-off-by: NJohn Garry <john.garry@huawei.com>
Signed-off-by: NSasha Levin <sashal@kernel.org>
上级 b098a4cd
...@@ -340,17 +340,28 @@ void remove_cpu_topology(unsigned int cpu) ...@@ -340,17 +340,28 @@ void remove_cpu_topology(unsigned int cpu)
} }
#ifdef CONFIG_ACPI #ifdef CONFIG_ACPI
static bool __init acpi_cpu_is_threaded(int cpu)
{
int is_threaded = acpi_pptt_cpu_is_thread(cpu);
/*
* if the PPTT doesn't have thread information, assume a homogeneous
* machine and return the current CPU's thread state.
*/
if (is_threaded < 0)
is_threaded = read_cpuid_mpidr() & MPIDR_MT_BITMASK;
return !!is_threaded;
}
/* /*
* Propagate the topology information of the processor_topology_node tree to the * Propagate the topology information of the processor_topology_node tree to the
* cpu_topology array. * cpu_topology array.
*/ */
static int __init parse_acpi_topology(void) static int __init parse_acpi_topology(void)
{ {
bool is_threaded;
int cpu, topology_id; int cpu, topology_id;
is_threaded = read_cpuid_mpidr() & MPIDR_MT_BITMASK;
for_each_possible_cpu(cpu) { for_each_possible_cpu(cpu) {
int i, cache_id; int i, cache_id;
...@@ -358,7 +369,7 @@ static int __init parse_acpi_topology(void) ...@@ -358,7 +369,7 @@ static int __init parse_acpi_topology(void)
if (topology_id < 0) if (topology_id < 0)
return topology_id; return topology_id;
if (is_threaded) { if (acpi_cpu_is_threaded(cpu)) {
cpu_topology[cpu].thread_id = topology_id; cpu_topology[cpu].thread_id = topology_id;
topology_id = find_acpi_cpu_topology(cpu, 1); topology_id = find_acpi_cpu_topology(cpu, 1);
cpu_topology[cpu].core_id = topology_id; cpu_topology[cpu].core_id = topology_id;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册