提交 299c7d94 编写于 作者: P Paul E. McKenney

rcutorture: Hoist OOM registry up one level

Currently, registering and unregistering the OOM notifier is done
right before and after the test, respectively.  This will not work
well for multi-threaded tests, so this commit hoists this registering
and unregistering up into the rcu_torture_fwd_prog_init() and
rcu_torture_fwd_prog_cleanup() functions.
Signed-off-by: NPaul E. McKenney <paulmck@kernel.org>
上级 58db5785
...@@ -2110,13 +2110,11 @@ static int rcu_torture_fwd_prog(void *args) ...@@ -2110,13 +2110,11 @@ static int rcu_torture_fwd_prog(void *args)
do { do {
schedule_timeout_interruptible(fwd_progress_holdoff * HZ); schedule_timeout_interruptible(fwd_progress_holdoff * HZ);
WRITE_ONCE(rcu_fwd_emergency_stop, false); WRITE_ONCE(rcu_fwd_emergency_stop, false);
register_oom_notifier(&rcutorture_oom_nb);
if (!IS_ENABLED(CONFIG_TINY_RCU) || if (!IS_ENABLED(CONFIG_TINY_RCU) ||
rcu_inkernel_boot_has_ended()) rcu_inkernel_boot_has_ended())
rcu_torture_fwd_prog_nr(rfp, &tested, &tested_tries); rcu_torture_fwd_prog_nr(rfp, &tested, &tested_tries);
if (rcu_inkernel_boot_has_ended()) if (rcu_inkernel_boot_has_ended())
rcu_torture_fwd_prog_cr(rfp); rcu_torture_fwd_prog_cr(rfp);
unregister_oom_notifier(&rcutorture_oom_nb);
/* Avoid slow periods, better to test when busy. */ /* Avoid slow periods, better to test when busy. */
stutter_wait("rcu_torture_fwd_prog"); stutter_wait("rcu_torture_fwd_prog");
...@@ -2159,6 +2157,7 @@ static int __init rcu_torture_fwd_prog_init(void) ...@@ -2159,6 +2157,7 @@ static int __init rcu_torture_fwd_prog_init(void)
mutex_lock(&rcu_fwd_mutex); mutex_lock(&rcu_fwd_mutex);
rcu_fwds = rfp; rcu_fwds = rfp;
mutex_unlock(&rcu_fwd_mutex); mutex_unlock(&rcu_fwd_mutex);
register_oom_notifier(&rcutorture_oom_nb);
return torture_create_kthread(rcu_torture_fwd_prog, rfp, fwd_prog_task); return torture_create_kthread(rcu_torture_fwd_prog, rfp, fwd_prog_task);
} }
...@@ -2171,6 +2170,7 @@ static void rcu_torture_fwd_prog_cleanup(void) ...@@ -2171,6 +2170,7 @@ static void rcu_torture_fwd_prog_cleanup(void)
mutex_lock(&rcu_fwd_mutex); mutex_lock(&rcu_fwd_mutex);
rcu_fwds = NULL; rcu_fwds = NULL;
mutex_unlock(&rcu_fwd_mutex); mutex_unlock(&rcu_fwd_mutex);
unregister_oom_notifier(&rcutorture_oom_nb);
kfree(rfp); kfree(rfp);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册