]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
padata: use cpumask_nth()
authorYury Norov <yury.norov@gmail.com>
Wed, 4 Jun 2025 23:58:01 +0000 (19:58 -0400)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 13 Jun 2025 09:26:17 +0000 (17:26 +0800)
padata_do_parallel() and padata_index_to_cpu() duplicate cpumask_nth().
Fix both and use the generic helper.

Signed-off-by: Yury Norov <yury.norov@gmail.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
kernel/padata.c

index 25cd3406477ab8acce96357848177f7e867dec2b..f85f8bd788d0da75f7ed37a968af1673bd957f8b 100644 (file)
@@ -63,17 +63,6 @@ static inline void padata_put_pd(struct parallel_data *pd)
        padata_put_pd_cnt(pd, 1);
 }
 
-static int padata_index_to_cpu(struct parallel_data *pd, int cpu_index)
-{
-       int cpu, target_cpu;
-
-       target_cpu = cpumask_first(pd->cpumask.pcpu);
-       for (cpu = 0; cpu < cpu_index; cpu++)
-               target_cpu = cpumask_next(target_cpu, pd->cpumask.pcpu);
-
-       return target_cpu;
-}
-
 static int padata_cpu_hash(struct parallel_data *pd, unsigned int seq_nr)
 {
        /*
@@ -82,7 +71,7 @@ static int padata_cpu_hash(struct parallel_data *pd, unsigned int seq_nr)
         */
        int cpu_index = seq_nr % cpumask_weight(pd->cpumask.pcpu);
 
-       return padata_index_to_cpu(pd, cpu_index);
+       return cpumask_nth(cpu_index, pd->cpumask.pcpu);
 }
 
 static struct padata_work *padata_work_alloc(void)
@@ -192,9 +181,9 @@ int padata_do_parallel(struct padata_shell *ps,
                       struct padata_priv *padata, int *cb_cpu)
 {
        struct padata_instance *pinst = ps->pinst;
-       int i, cpu, cpu_index, err;
        struct parallel_data *pd;
        struct padata_work *pw;
+       int cpu_index, err;
 
        rcu_read_lock_bh();
 
@@ -210,12 +199,7 @@ int padata_do_parallel(struct padata_shell *ps,
 
                /* Select an alternate fallback CPU and notify the caller. */
                cpu_index = *cb_cpu % cpumask_weight(pd->cpumask.cbcpu);
-
-               cpu = cpumask_first(pd->cpumask.cbcpu);
-               for (i = 0; i < cpu_index; i++)
-                       cpu = cpumask_next(cpu, pd->cpumask.cbcpu);
-
-               *cb_cpu = cpu;
+               *cb_cpu = cpumask_nth(cpu_index, pd->cpumask.cbcpu);
        }
 
        err = -EBUSY;