diff options
author | Iulia Manda <iulia.manda21@gmail.com> | 2014-03-11 09:22:28 -0400 |
---|---|---|
committer | Paul E. McKenney <paulmck@linux.vnet.ibm.com> | 2014-04-29 11:43:45 -0400 |
commit | 4fc5b75537d4f56577ad00355b4cd09627deb3c3 (patch) | |
tree | 08b95f7d425cd0f610dd545fbe8fbea282a7f87f /kernel/rcu | |
parent | 9b67122ae3da3018c966148233739116ed89502a (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.c | 12 |
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 | /* |