]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
rcu: Split rcu_report_exp_cpu_mult() mask parameter and use for tracing
authorPaul E. McKenney <paulmck@kernel.org>
Mon, 28 Oct 2024 15:39:53 +0000 (08:39 -0700)
committerBoqun Feng <boqun.feng@gmail.com>
Wed, 5 Feb 2025 05:52:38 +0000 (21:52 -0800)
This commit renames the rcu_report_exp_cpu_mult() function from "mask"
to "mask_in" and introduced a "mask" local variable to better support
upcoming event-tracing additions.

Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Cc: Frederic Weisbecker <frederic@kernel.org>
Signed-off-by: Boqun Feng <boqun.feng@gmail.com>
kernel/rcu/tree_exp.h

index 77efed89c79e3519b5cfd3c3eca8d01f9e647764..8d4895c854c5954918625cea8198ca35215f93c7 100644 (file)
@@ -230,17 +230,19 @@ static void __maybe_unused rcu_report_exp_rnp(struct rcu_node *rnp, bool wake)
  * specified leaf rcu_node structure, which is acquired by the caller.
  */
 static void rcu_report_exp_cpu_mult(struct rcu_node *rnp, unsigned long flags,
-                                   unsigned long mask, bool wake)
+                                   unsigned long mask_in, bool wake)
                                    __releases(rnp->lock)
 {
        int cpu;
+       unsigned long mask;
        struct rcu_data *rdp;
 
        raw_lockdep_assert_held_rcu_node(rnp);
-       if (!(rnp->expmask & mask)) {
+       if (!(rnp->expmask & mask_in)) {
                raw_spin_unlock_irqrestore_rcu_node(rnp, flags);
                return;
        }
+       mask = mask_in & rnp->expmask;
        WRITE_ONCE(rnp->expmask, rnp->expmask & ~mask);
        for_each_leaf_node_cpu_mask(rnp, cpu, mask) {
                rdp = per_cpu_ptr(&rcu_data, cpu);