Commit 0b962c8f authored by Paul E. McKenney's avatar Paul E. McKenney

torture: Clean up after torture-test CPU hotplugging

This commit puts all CPUs back online at the end of a torture test,
and also unconditionally puts them online at the beginning of the test,
rather than just in the case of built-in tests.  This allows torture tests
to behave in a predictable manner, whether built-in or based on modules.
Signed-off-by: default avatarPaul E. McKenney <paulmck@kernel.org>
parent edf7b841
...@@ -292,34 +292,41 @@ bool torture_online(int cpu, long *n_onl_attempts, long *n_onl_successes, ...@@ -292,34 +292,41 @@ bool torture_online(int cpu, long *n_onl_attempts, long *n_onl_successes,
EXPORT_SYMBOL_GPL(torture_online); EXPORT_SYMBOL_GPL(torture_online);
/* /*
* Execute random CPU-hotplug operations at the interval specified * Get everything online at the beginning and ends of tests.
* by the onoff_interval.
*/ */
static int static void torture_online_all(char *phase)
torture_onoff(void *arg)
{ {
int cpu; int cpu;
int maxcpu = -1;
DEFINE_TORTURE_RANDOM(rand);
int ret; int ret;
VERBOSE_TOROUT_STRING("torture_onoff task started");
for_each_online_cpu(cpu)
maxcpu = cpu;
WARN_ON(maxcpu < 0);
if (!IS_MODULE(CONFIG_TORTURE_TEST)) {
for_each_possible_cpu(cpu) { for_each_possible_cpu(cpu) {
if (cpu_online(cpu)) if (cpu_online(cpu))
continue; continue;
ret = add_cpu(cpu); ret = add_cpu(cpu);
if (ret && verbose) { if (ret && verbose) {
pr_alert("%s" TORTURE_FLAG pr_alert("%s" TORTURE_FLAG
"%s: Initial online %d: errno %d\n", "%s: %s online %d: errno %d\n",
__func__, torture_type, cpu, ret); __func__, phase, torture_type, cpu, ret);
}
} }
} }
}
/*
* Execute random CPU-hotplug operations at the interval specified
* by the onoff_interval.
*/
static int
torture_onoff(void *arg)
{
int cpu;
int maxcpu = -1;
DEFINE_TORTURE_RANDOM(rand);
VERBOSE_TOROUT_STRING("torture_onoff task started");
for_each_online_cpu(cpu)
maxcpu = cpu;
WARN_ON(maxcpu < 0);
torture_online_all("Initial");
if (maxcpu == 0) { if (maxcpu == 0) {
VERBOSE_TOROUT_STRING("Only one CPU, so CPU-hotplug testing is disabled"); VERBOSE_TOROUT_STRING("Only one CPU, so CPU-hotplug testing is disabled");
goto stop; goto stop;
...@@ -347,6 +354,7 @@ torture_onoff(void *arg) ...@@ -347,6 +354,7 @@ torture_onoff(void *arg)
stop: stop:
torture_kthread_stopping("torture_onoff"); torture_kthread_stopping("torture_onoff");
torture_online_all("Final");
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment