torture: Notice if an all-zero cpumask is passed inside a critical section
authorIulia Manda <iulia.manda21@gmail.com>
Mon, 17 Mar 2014 13:21:21 +0000 (15:21 +0200)
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>
Wed, 14 May 2014 16:46:14 +0000 (09:46 -0700)
commit5ed63b199c5b58ed150ce50f1ea68de54669b13f
tree36e46770633ba73bbcd5450aa1e12ba6213a0cd7
parent64e4b43ae050146fcfafe696e61efc306f73d449
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>
kernel/torture.c