Lines Matching full:cpu
3 * Common SMP CPU bringup/teardown functions
5 #include <linux/cpu.h>
30 struct task_struct *idle_thread_get(unsigned int cpu) in idle_thread_get() argument
32 struct task_struct *tsk = per_cpu(idle_threads, cpu); in idle_thread_get()
45 * idle_init - Initialize the idle thread for a cpu
46 * @cpu: The cpu for which the idle thread should be initialized
50 static __always_inline void idle_init(unsigned int cpu) in idle_init() argument
52 struct task_struct *tsk = per_cpu(idle_threads, cpu); in idle_init()
55 tsk = fork_idle(cpu); in idle_init()
57 pr_err("SMP: fork_idle() failed for CPU %u\n", cpu); in idle_init()
59 per_cpu(idle_threads, cpu) = tsk; in idle_init()
68 unsigned int cpu, boot_cpu; in idle_threads_init() local
72 for_each_possible_cpu(cpu) { in idle_threads_init()
73 if (cpu != boot_cpu) in idle_threads_init()
74 idle_init(cpu); in idle_threads_init()
85 unsigned int cpu; member
119 ht->cleanup(td->cpu, cpu_online(td->cpu)); in smpboot_thread_fn()
128 BUG_ON(td->cpu != smp_processor_id()); in smpboot_thread_fn()
129 ht->park(td->cpu); in smpboot_thread_fn()
137 BUG_ON(td->cpu != smp_processor_id()); in smpboot_thread_fn()
145 ht->setup(td->cpu); in smpboot_thread_fn()
153 ht->unpark(td->cpu); in smpboot_thread_fn()
158 if (!ht->thread_should_run(td->cpu)) { in smpboot_thread_fn()
164 ht->thread_fn(td->cpu); in smpboot_thread_fn()
170 __smpboot_create_thread(struct smp_hotplug_thread *ht, unsigned int cpu) in __smpboot_create_thread() argument
172 struct task_struct *tsk = *per_cpu_ptr(ht->store, cpu); in __smpboot_create_thread()
178 td = kzalloc_node(sizeof(*td), GFP_KERNEL, cpu_to_node(cpu)); in __smpboot_create_thread()
181 td->cpu = cpu; in __smpboot_create_thread()
184 tsk = kthread_create_on_cpu(smpboot_thread_fn, td, cpu, in __smpboot_create_thread()
190 kthread_set_per_cpu(tsk, cpu); in __smpboot_create_thread()
192 * Park the thread so that it could start right on the CPU in __smpboot_create_thread()
197 *per_cpu_ptr(ht->store, cpu) = tsk; in __smpboot_create_thread()
208 ht->create(cpu); in __smpboot_create_thread()
213 int smpboot_create_threads(unsigned int cpu) in smpboot_create_threads() argument
220 ret = __smpboot_create_thread(cur, cpu); in smpboot_create_threads()
228 static void smpboot_unpark_thread(struct smp_hotplug_thread *ht, unsigned int cpu) in smpboot_unpark_thread() argument
230 struct task_struct *tsk = *per_cpu_ptr(ht->store, cpu); in smpboot_unpark_thread()
236 int smpboot_unpark_threads(unsigned int cpu) in smpboot_unpark_threads() argument
242 smpboot_unpark_thread(cur, cpu); in smpboot_unpark_threads()
247 static void smpboot_park_thread(struct smp_hotplug_thread *ht, unsigned int cpu) in smpboot_park_thread() argument
249 struct task_struct *tsk = *per_cpu_ptr(ht->store, cpu); in smpboot_park_thread()
255 int smpboot_park_threads(unsigned int cpu) in smpboot_park_threads() argument
261 smpboot_park_thread(cur, cpu); in smpboot_park_threads()
268 unsigned int cpu; in smpboot_destroy_threads() local
271 for_each_possible_cpu(cpu) { in smpboot_destroy_threads()
272 struct task_struct *tsk = *per_cpu_ptr(ht->store, cpu); in smpboot_destroy_threads()
277 *per_cpu_ptr(ht->store, cpu) = NULL; in smpboot_destroy_threads()
291 unsigned int cpu; in smpboot_register_percpu_thread() local
296 for_each_online_cpu(cpu) { in smpboot_register_percpu_thread()
297 ret = __smpboot_create_thread(plug_thread, cpu); in smpboot_register_percpu_thread()
302 smpboot_unpark_thread(plug_thread, cpu); in smpboot_register_percpu_thread()
332 * Called to poll specified CPU's state, for example, when waiting for
333 * a CPU to come online.
335 int cpu_report_state(int cpu) in cpu_report_state() argument
337 return atomic_read(&per_cpu(cpu_hotplug_state, cpu)); in cpu_report_state()
341 * If CPU has died properly, set its state to CPU_UP_PREPARE and
342 * return success. Otherwise, return -EBUSY if the CPU died after
344 * if cpu_wait_death() timed out and the CPU still hasn't gotten around
345 * to dying. In the latter two cases, the CPU might not be set up
350 * done in architectures that do no CPU-hotplug error checking.
352 int cpu_check_up_prepare(int cpu) in cpu_check_up_prepare() argument
355 atomic_set(&per_cpu(cpu_hotplug_state, cpu), CPU_UP_PREPARE); in cpu_check_up_prepare()
359 switch (atomic_read(&per_cpu(cpu_hotplug_state, cpu))) { in cpu_check_up_prepare()
363 /* The CPU died properly, so just start it up again. */ in cpu_check_up_prepare()
364 atomic_set(&per_cpu(cpu_hotplug_state, cpu), CPU_UP_PREPARE); in cpu_check_up_prepare()
370 * Timeout during CPU death, so let caller know. in cpu_check_up_prepare()
371 * The outgoing CPU completed its processing, but after in cpu_check_up_prepare()
378 * a surviving CPU. in cpu_check_up_prepare()
386 * a timeout during CPU death, and the outgoing CPU never in cpu_check_up_prepare()
390 * immediately online that same CPU. Trying again later in cpu_check_up_prepare()
397 * Timeout while waiting for the CPU to show up. Allow to try in cpu_check_up_prepare()
410 * Mark the specified CPU online.
413 * done in architectures that do no CPU-hotplug error checking.
415 void cpu_set_state_online(int cpu) in cpu_set_state_online() argument
417 (void)atomic_xchg(&per_cpu(cpu_hotplug_state, cpu), CPU_ONLINE); in cpu_set_state_online()
423 * Wait for the specified CPU to exit the idle loop and die.
425 bool cpu_wait_death(unsigned int cpu, int seconds) in cpu_wait_death() argument
434 /* The outgoing CPU will normally get done quite quickly. */ in cpu_wait_death()
435 if (atomic_read(&per_cpu(cpu_hotplug_state, cpu)) == CPU_DEAD) in cpu_wait_death()
439 /* But if the outgoing CPU dawdles, wait increasingly long times. */ in cpu_wait_death()
440 while (atomic_read(&per_cpu(cpu_hotplug_state, cpu)) != CPU_DEAD) { in cpu_wait_death()
448 oldstate = atomic_read(&per_cpu(cpu_hotplug_state, cpu)); in cpu_wait_death()
451 /* Outgoing CPU died normally, update state. */ in cpu_wait_death()
453 atomic_set(&per_cpu(cpu_hotplug_state, cpu), CPU_POST_DEAD); in cpu_wait_death()
455 /* Outgoing CPU still hasn't died, set state accordingly. */ in cpu_wait_death()
456 if (!atomic_try_cmpxchg(&per_cpu(cpu_hotplug_state, cpu), in cpu_wait_death()
465 * Called by the outgoing CPU to report its successful death. Return
466 * false if this report follows the surviving CPU's timing out.
468 * A separate "CPU_DEAD_FROZEN" is used when the surviving CPU
477 int cpu = smp_processor_id(); in cpu_report_death() local
479 oldstate = atomic_read(&per_cpu(cpu_hotplug_state, cpu)); in cpu_report_death()
485 } while (!atomic_try_cmpxchg(&per_cpu(cpu_hotplug_state, cpu), in cpu_report_death()