aboutsummaryrefslogtreecommitdiff
path: root/scripts/gdb/linux/dmesg.py
diff options
context:
space:
mode:
authorPaul E. McKenney <[email protected]>2020-01-03 14:18:12 -0800
committerPaul E. McKenney <[email protected]>2020-04-27 11:01:15 -0700
commit314eeb43e5f22856b281c91c966e51e5782a3498 (patch)
tree1ef76eb99359862ce24231fe346441f8b429db63 /scripts/gdb/linux/dmesg.py
parent2f08469563550d15cb08a60898d3549720600eee (diff)
rcu: Add *_ONCE() and data_race() to rcu_node ->exp_tasks plus locking
There are lockless loads from the rcu_node structure's ->exp_tasks field, so this commit causes all stores to use WRITE_ONCE() and all lockless loads to use READ_ONCE() or data_race(), with the latter for debug prints. This code also did a unprotected traversal of the linked list pointed into by ->exp_tasks, so this commit also acquires the rcu_node structure's ->lock to properly protect this traversal. This list was traversed unprotected only when printing an RCU CPU stall warning for an expedited grace period, so the odds of seeing this in production are not all that high. This data race was reported by KCSAN. Signed-off-by: Paul E. McKenney <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/dmesg.py')
0 files changed, 0 insertions, 0 deletions