Commit 3ab33d6dc3e9 ("powerpc/smp: Optimize update_mask_by_l2")
introduced submask_fn in update_mask_by_l2 to track the right submask.
However commit f6606cfdfbcd ("powerpc/smp: Dont assume l2-cache to be
superset of sibling") introduced sibling_mask in update_mask_by_l2 to
track the same submask. Remove sibling_mask in favour of submask_fn.

Signed-off-by: Srikar Dronamraju <[email protected]>
Cc: linuxppc-dev <[email protected]>
Cc: LKML <[email protected]>
Cc: Michael Ellerman <[email protected]>
Cc: Nathan Lynch <[email protected]>
Cc: Gautham R Shenoy <[email protected]>
Cc: Ingo Molnar <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Cc: Valentin Schneider <[email protected]>
Cc: Qian Cai <[email protected]>
---
 arch/powerpc/kernel/smp.c | 13 ++++---------
 1 file changed, 4 insertions(+), 9 deletions(-)

diff --git a/arch/powerpc/kernel/smp.c b/arch/powerpc/kernel/smp.c
index 8d1c401f4617..a864b9b3228c 100644
--- a/arch/powerpc/kernel/smp.c
+++ b/arch/powerpc/kernel/smp.c
@@ -1264,18 +1264,16 @@ static bool update_mask_by_l2(int cpu)
        cpumask_var_t mask;
        int i;
 
+       if (has_big_cores)
+               submask_fn = cpu_smallcore_mask;
+
        l2_cache = cpu_to_l2cache(cpu);
        if (!l2_cache) {
-               struct cpumask *(*sibling_mask)(int) = cpu_sibling_mask;
-
                /*
                 * If no l2cache for this CPU, assume all siblings to share
                 * cache with this CPU.
                 */
-               if (has_big_cores)
-                       sibling_mask = cpu_smallcore_mask;
-
-               for_each_cpu(i, sibling_mask(cpu))
+               for_each_cpu(i, submask_fn(cpu))
                        set_cpus_related(cpu, i, cpu_l2_cache_mask);
 
                return false;
@@ -1284,9 +1282,6 @@ static bool update_mask_by_l2(int cpu)
        alloc_cpumask_var_node(&mask, GFP_KERNEL, cpu_to_node(cpu));
        cpumask_and(mask, cpu_online_mask, cpu_cpu_mask(cpu));
 
-       if (has_big_cores)
-               submask_fn = cpu_smallcore_mask;
-
        /* Update l2-cache mask with all the CPUs that are part of submask */
        or_cpumasks_related(cpu, cpu, submask_fn, cpu_l2_cache_mask);
 
-- 
2.18.2

Reply via email to