Commit 70a94089 authored by Srikar Dronamraju's avatar Srikar Dronamraju Committed by Michael Ellerman

powerpc/smp: Optimize update_coregroup_mask

All threads of a SMT4/SMT8 core can either be part of CPU's coregroup
mask or outside the coregroup. Use this relation to reduce the
number of iterations needed to find all the CPUs that share the same
coregroup

Use a temporary mask to iterate through the CPUs that may share
coregroup mask. Also instead of setting one CPU at a time into
cpu_coregroup_mask, copy the SMT4/SMT8/submask at one shot.
Signed-off-by: default avatarSrikar Dronamraju <srikar@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20200921095653.9701-12-srikar@linux.vnet.ibm.com
parent b8a97cb4
...@@ -1339,19 +1339,33 @@ static inline void add_cpu_to_smallcore_masks(int cpu) ...@@ -1339,19 +1339,33 @@ static inline void add_cpu_to_smallcore_masks(int cpu)
static void update_coregroup_mask(int cpu) static void update_coregroup_mask(int cpu)
{ {
int first_thread = cpu_first_thread_sibling(cpu); struct cpumask *(*submask_fn)(int) = cpu_sibling_mask;
cpumask_var_t mask;
int coregroup_id = cpu_to_coregroup_id(cpu); int coregroup_id = cpu_to_coregroup_id(cpu);
int i; int i;
cpumask_set_cpu(cpu, cpu_coregroup_mask(cpu)); alloc_cpumask_var_node(&mask, GFP_KERNEL, cpu_to_node(cpu));
for_each_cpu_and(i, cpu_online_mask, cpu_cpu_mask(cpu)) { cpumask_and(mask, cpu_online_mask, cpu_cpu_mask(cpu));
int fcpu = cpu_first_thread_sibling(i);
if (shared_caches)
submask_fn = cpu_l2_cache_mask;
/* Update coregroup mask with all the CPUs that are part of submask */
or_cpumasks_related(cpu, cpu, submask_fn, cpu_coregroup_mask);
/* Skip all CPUs already part of coregroup mask */
cpumask_andnot(mask, mask, cpu_coregroup_mask(cpu));
if (fcpu == first_thread) for_each_cpu(i, mask) {
set_cpus_related(cpu, i, cpu_coregroup_mask); /* Skip all CPUs not part of this coregroup */
else if (coregroup_id == cpu_to_coregroup_id(i)) if (coregroup_id == cpu_to_coregroup_id(i)) {
set_cpus_related(cpu, i, cpu_coregroup_mask); or_cpumasks_related(cpu, i, submask_fn, cpu_coregroup_mask);
cpumask_andnot(mask, mask, submask_fn(i));
} else {
cpumask_andnot(mask, mask, cpu_coregroup_mask(i));
}
} }
free_cpumask_var(mask);
} }
static void add_cpu_to_masks(int cpu) static void add_cpu_to_masks(int cpu)
......
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