aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/rcu
diff options
context:
space:
mode:
authorIulia Manda <iulia.manda21@gmail.com>2014-03-11 09:22:28 -0400
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>2014-04-29 11:43:45 -0400
commit4fc5b75537d4f56577ad00355b4cd09627deb3c3 (patch)
tree08b95f7d425cd0f610dd545fbe8fbea282a7f87f /kernel/rcu
parent9b67122ae3da3018c966148233739116ed89502a (diff)
rcu: Protect uses of jiffies_stall field with ACCESS_ONCE()
Some of the uses of the rcu_state structure's ->jiffies_stall field do not use ACCESS_ONCE(), despite there being unprotected accesses. This commit therefore uses the ACCESS_ONCE() macro to protect this field. Signed-off-by: Iulia Manda <iulia.manda21@gmail.com> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Reviewed-by: Josh Triplett <josh@joshtriplett.org>
Diffstat (limited to 'kernel/rcu')
-rw-r--r--kernel/rcu/tree.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c
index 2cc39c781085..c624415f8386 100644
--- a/kernel/rcu/tree.c
+++ b/kernel/rcu/tree.c
@@ -865,7 +865,7 @@ static void record_gp_stall_check_time(struct rcu_state *rsp)
865 rsp->gp_start = j; 865 rsp->gp_start = j;
866 smp_wmb(); /* Record start time before stall time. */ 866 smp_wmb(); /* Record start time before stall time. */
867 j1 = rcu_jiffies_till_stall_check(); 867 j1 = rcu_jiffies_till_stall_check();
868 rsp->jiffies_stall = j + j1; 868 ACCESS_ONCE(rsp->jiffies_stall) = j + j1;
869 rsp->jiffies_resched = j + j1 / 2; 869 rsp->jiffies_resched = j + j1 / 2;
870} 870}
871 871
@@ -904,12 +904,12 @@ static void print_other_cpu_stall(struct rcu_state *rsp)
904 /* Only let one CPU complain about others per time interval. */ 904 /* Only let one CPU complain about others per time interval. */
905 905
906 raw_spin_lock_irqsave(&rnp->lock, flags); 906 raw_spin_lock_irqsave(&rnp->lock, flags);
907 delta = jiffies - rsp->jiffies_stall; 907 delta = jiffies - ACCESS_ONCE(rsp->jiffies_stall);
908 if (delta < RCU_STALL_RAT_DELAY || !rcu_gp_in_progress(rsp)) { 908 if (delta < RCU_STALL_RAT_DELAY || !rcu_gp_in_progress(rsp)) {
909 raw_spin_unlock_irqrestore(&rnp->lock, flags); 909 raw_spin_unlock_irqrestore(&rnp->lock, flags);
910 return; 910 return;
911 } 911 }
912 rsp->jiffies_stall = jiffies + 3 * rcu_jiffies_till_stall_check() + 3; 912 ACCESS_ONCE(rsp->jiffies_stall) = jiffies + 3 * rcu_jiffies_till_stall_check() + 3;
913 raw_spin_unlock_irqrestore(&rnp->lock, flags); 913 raw_spin_unlock_irqrestore(&rnp->lock, flags);
914 914
915 /* 915 /*
@@ -992,8 +992,8 @@ static void print_cpu_stall(struct rcu_state *rsp)
992 dump_stack(); 992 dump_stack();
993 993
994 raw_spin_lock_irqsave(&rnp->lock, flags); 994 raw_spin_lock_irqsave(&rnp->lock, flags);
995 if (ULONG_CMP_GE(jiffies, rsp->jiffies_stall)) 995 if (ULONG_CMP_GE(jiffies, ACCESS_ONCE(rsp->jiffies_stall)))
996 rsp->jiffies_stall = jiffies + 996 ACCESS_ONCE(rsp->jiffies_stall) = jiffies +
997 3 * rcu_jiffies_till_stall_check() + 3; 997 3 * rcu_jiffies_till_stall_check() + 3;
998 raw_spin_unlock_irqrestore(&rnp->lock, flags); 998 raw_spin_unlock_irqrestore(&rnp->lock, flags);
999 999
@@ -1077,7 +1077,7 @@ void rcu_cpu_stall_reset(void)
1077 struct rcu_state *rsp; 1077 struct rcu_state *rsp;
1078 1078
1079 for_each_rcu_flavor(rsp) 1079 for_each_rcu_flavor(rsp)
1080 rsp->jiffies_stall = jiffies + ULONG_MAX / 2; 1080 ACCESS_ONCE(rsp->jiffies_stall) = jiffies + ULONG_MAX / 2;
1081} 1081}
1082 1082
1083/* 1083/*