aboutsummaryrefslogtreecommitdiffstats
path: root/tools/testing/selftests/rcutorture
diff options
context:
space:
mode:
authorIulia Manda <iulia.manda21@gmail.com>2014-03-17 15:21:21 +0200
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>2014-05-14 09:46:14 -0700
commit5ed63b199c5b58ed150ce50f1ea68de54669b13f (patch)
tree36e46770633ba73bbcd5450aa1e12ba6213a0cd7 /tools/testing/selftests/rcutorture
parentrcutorture: Make rcu_torture_reader() use cond_resched() (diff)
downloadlinux-dev-5ed63b199c5b58ed150ce50f1ea68de54669b13f.tar.xz
linux-dev-5ed63b199c5b58ed150ce50f1ea68de54669b13f.zip
torture: Notice if an all-zero cpumask is passed inside a critical section
In torture_shuffle_tasks function, the check if an all-zero mask can be passed to set_cpus_allowed_ptr() is redundant after clearing the shuffle_idle_cpu bit. If the mask had more than one bit set, after clearing a bit it has at least one bit set. If the mask had only one bit set, a check is made at the beginning, where the function returns, as there is no need to shuffle only one cpu. Also, this code is executed inside a critical section, delimited by get_online_cpus(), and put_online_cpus(), preventing CPUs from leaving between the check of num_online_cpus and the calls to set_cpus_allowed_ptr() function. 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 'tools/testing/selftests/rcutorture')
0 files changed, 0 insertions, 0 deletions