Commit 654db05c authored by Paul E. McKenney's avatar Paul E. McKenney

rcu: Use data_race() for RCU expedited CPU stall-warning prints

Although the accesses used to determine whether or not an expedited
stall should be printed are an integral part of the concurrency algorithm
governing use of the corresponding variables, the values that are simply
printed are ancillary.  As such, it is best to use data_race() for these
accesses in order to provide the greatest latitude in the use of KCSAN
for the other accesses that are an integral part of the algorithm.  This
commit therefore changes the relevant uses of READ_ONCE() to data_race().
Signed-off-by: default avatarPaul E. McKenney <paulmck@kernel.org>
parent 35315936
...@@ -542,8 +542,8 @@ static void synchronize_rcu_expedited_wait(void) ...@@ -542,8 +542,8 @@ static void synchronize_rcu_expedited_wait(void)
} }
pr_cont(" } %lu jiffies s: %lu root: %#lx/%c\n", pr_cont(" } %lu jiffies s: %lu root: %#lx/%c\n",
jiffies - jiffies_start, rcu_state.expedited_sequence, jiffies - jiffies_start, rcu_state.expedited_sequence,
READ_ONCE(rnp_root->expmask), data_race(rnp_root->expmask),
".T"[!!rnp_root->exp_tasks]); ".T"[!!data_race(rnp_root->exp_tasks)]);
if (ndetected) { if (ndetected) {
pr_err("blocking rcu_node structures:"); pr_err("blocking rcu_node structures:");
rcu_for_each_node_breadth_first(rnp) { rcu_for_each_node_breadth_first(rnp) {
...@@ -553,8 +553,8 @@ static void synchronize_rcu_expedited_wait(void) ...@@ -553,8 +553,8 @@ static void synchronize_rcu_expedited_wait(void)
continue; continue;
pr_cont(" l=%u:%d-%d:%#lx/%c", pr_cont(" l=%u:%d-%d:%#lx/%c",
rnp->level, rnp->grplo, rnp->grphi, rnp->level, rnp->grplo, rnp->grphi,
READ_ONCE(rnp->expmask), data_race(rnp->expmask),
".T"[!!rnp->exp_tasks]); ".T"[!!data_race(rnp->exp_tasks)]);
} }
pr_cont("\n"); pr_cont("\n");
} }
......
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