|
@@ -280,6 +280,7 @@ int smpboot_register_percpu_thread(struct smp_hotplug_thread *plug_thread)
|
|
|
unsigned int cpu;
|
|
|
int ret = 0;
|
|
|
|
|
|
+ get_online_cpus();
|
|
|
mutex_lock(&smpboot_threads_lock);
|
|
|
for_each_online_cpu(cpu) {
|
|
|
ret = __smpboot_create_thread(plug_thread, cpu);
|
|
@@ -292,6 +293,7 @@ int smpboot_register_percpu_thread(struct smp_hotplug_thread *plug_thread)
|
|
|
list_add(&plug_thread->list, &hotplug_threads);
|
|
|
out:
|
|
|
mutex_unlock(&smpboot_threads_lock);
|
|
|
+ put_online_cpus();
|
|
|
return ret;
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(smpboot_register_percpu_thread);
|