summaryrefslogtreecommitdiffstats
path: root/kernel/rcu
diff options
context:
space:
mode:
authorPaul E. McKenney <paulmck@kernel.org>2021-12-17 15:05:05 -0800
committerPaul E. McKenney <paulmck@kernel.org>2022-02-01 17:24:38 -0800
commit02b51a1cf47977d8772c7dcc363ef6a1e6e59f21 (patch)
tree316937d26d05beb526cd2777499976b833cc6749 /kernel/rcu
parente22ef8df415d924428e35c9c112526306e684adc (diff)
downloadlinux-stable-02b51a1cf47977d8772c7dcc363ef6a1e6e59f21.tar.gz
linux-stable-02b51a1cf47977d8772c7dcc363ef6a1e6e59f21.tar.bz2
linux-stable-02b51a1cf47977d8772c7dcc363ef6a1e6e59f21.zip
rcutorture: Add end-of-test check to rcu_torture_fwd_prog() loop
The second and subsequent forward-progress kthreads loop waiting for the first forward-progress kthread to start the next test interval. Unfortunately, if the test ends while one of those kthreads is waiting, the test will hang. This hang occurs because that wait loop fails to check for the end of the test. This commit therefore adds an end-of-test check to that wait loop. Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Diffstat (limited to 'kernel/rcu')
-rw-r--r--kernel/rcu/rcutorture.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/kernel/rcu/rcutorture.c b/kernel/rcu/rcutorture.c
index afe95c694895..e99658efd97f 100644
--- a/kernel/rcu/rcutorture.c
+++ b/kernel/rcu/rcutorture.c
@@ -2515,7 +2515,7 @@ static int rcu_torture_fwd_prog(void *args)
firsttime = false;
WRITE_ONCE(rcu_fwd_seq, rcu_fwd_seq + 1);
} else {
- while (READ_ONCE(rcu_fwd_seq) == oldseq)
+ while (READ_ONCE(rcu_fwd_seq) == oldseq && !torture_must_stop())
schedule_timeout_interruptible(1);
oldseq = READ_ONCE(rcu_fwd_seq);
}