summaryrefslogtreecommitdiffstats
path: root/kernel/cgroup_freezer.c
diff options
context:
space:
mode:
authorPaul E. McKenney <paulmck@linux.vnet.ibm.com>2015-04-14 21:28:22 +0200
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>2015-05-27 21:59:58 +0200
commitca1d51ed9809a99d71c23a343b3acd3fd4ad8cbe (patch)
tree2e0339669a97ba352d477fb5ba60a98b7f1ba8c4 /kernel/cgroup_freezer.c
parentrcutorture: Replace barriers with smp_store_release() and smp_load_acquire() (diff)
downloadlinux-ca1d51ed9809a99d71c23a343b3acd3fd4ad8cbe.tar.xz
linux-ca1d51ed9809a99d71c23a343b3acd3fd4ad8cbe.zip
rcutorture: Test SRCU cleanup code path
The current rcutorture testing does not do any cleanup operations. This works because the srcu_struct is statically allocated, but it does represent a memory leak of the associated dynamically allocated ->per_cpu_ref per-CPU variables. However, rcutorture currently uses a statically allocated srcu_struct, which cannot legally be passed to cleanup_srcu_struct(). Therefore, this commit adds a second form of srcu (called srcud) that dynamically allocates and frees the associated per-CPU variables. This commit also adds a ->cleanup() member to rcu_torture_ops that is invoked at the end of the test, after ->cb_barriers(). This ->cleanup() pointer is NULL for all existing tests, and thus only used for scrud. Finally, the SRCU-P torture-test configuration selects scrud instead of srcu, with SRCU-N continuing to use srcu, thereby testing both static and dynamic srcu_struct structures. Reported-by: "Ahmed, Iftekhar" <ahmedi@onid.oregonstate.edu> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Reviewed-by: Josh Triplett <josh@joshtriplett.org>
Diffstat (limited to 'kernel/cgroup_freezer.c')
0 files changed, 0 insertions, 0 deletions