Commit 9832de65 authored by Michael Ellerman's avatar Michael Ellerman

powerpc/smp: Factor out assign_threads()

Factor out the for loop that assigns CPU numbers to threads of a core.
The function takes the next CPU number to use as input, and returns the
next available CPU number after the threads has been assigned.

This will allow a subsequent change to assign threads out of order.
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://msgid.link/20231229120107.2281153-4-mpe@ellerman.id.au
parent dca79603
...@@ -411,6 +411,25 @@ static void __init cpu_init_thread_core_maps(int tpc) ...@@ -411,6 +411,25 @@ static void __init cpu_init_thread_core_maps(int tpc)
u32 *cpu_to_phys_id = NULL; u32 *cpu_to_phys_id = NULL;
static int assign_threads(unsigned int cpu, unsigned int nthreads, bool present,
const __be32 *hw_ids)
{
for (int i = 0; i < nthreads && cpu < nr_cpu_ids; i++) {
__be32 hwid;
hwid = be32_to_cpu(hw_ids[i]);
DBG(" thread %d -> cpu %d (hard id %d)\n", i, cpu, hwid);
set_cpu_present(cpu, present);
set_cpu_possible(cpu, true);
cpu_to_phys_id[cpu] = hwid;
cpu++;
}
return cpu;
}
/** /**
* setup_cpu_maps - initialize the following cpu maps: * setup_cpu_maps - initialize the following cpu maps:
* cpu_possible_mask * cpu_possible_mask
...@@ -446,7 +465,7 @@ void __init smp_setup_cpu_maps(void) ...@@ -446,7 +465,7 @@ void __init smp_setup_cpu_maps(void)
for_each_node_by_type(dn, "cpu") { for_each_node_by_type(dn, "cpu") {
const __be32 *intserv; const __be32 *intserv;
__be32 cpu_be; __be32 cpu_be;
int j, len; int len;
DBG(" * %pOF...\n", dn); DBG(" * %pOF...\n", dn);
...@@ -473,16 +492,7 @@ void __init smp_setup_cpu_maps(void) ...@@ -473,16 +492,7 @@ void __init smp_setup_cpu_maps(void)
avail = !of_property_match_string(dn, avail = !of_property_match_string(dn,
"enable-method", "spin-table"); "enable-method", "spin-table");
for (j = 0; j < nthreads && cpu < nr_cpu_ids; j++) { cpu = assign_threads(cpu, nthreads, avail, intserv);
DBG(" thread %d -> cpu %d (hard id %d)\n",
j, cpu, be32_to_cpu(intserv[j]));
set_cpu_present(cpu, avail);
set_cpu_possible(cpu, true);
cpu_to_phys_id[cpu] = be32_to_cpu(intserv[j]);
cpu++;
}
if (cpu >= nr_cpu_ids) { if (cpu >= nr_cpu_ids) {
of_node_put(dn); of_node_put(dn);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment