xref: /kvm-unit-tests/lib/arm/asm/smp.h (revision 00b34f5677363f85e90d44177c40a58374a3b6a3)
168ea0e0bSAndrew Jones #ifndef _ASMARM_SMP_H_
268ea0e0bSAndrew Jones #define _ASMARM_SMP_H_
368ea0e0bSAndrew Jones /*
468ea0e0bSAndrew Jones  * Copyright (C) 2015, Red Hat Inc, Andrew Jones <drjones@redhat.com>
568ea0e0bSAndrew Jones  *
668ea0e0bSAndrew Jones  * This work is licensed under the terms of the GNU LGPL, version 2.
768ea0e0bSAndrew Jones  */
868ea0e0bSAndrew Jones #include <asm/thread_info.h>
968ea0e0bSAndrew Jones #include <asm/cpumask.h>
1068ea0e0bSAndrew Jones 
1168ea0e0bSAndrew Jones #define smp_processor_id()		(current_thread_info()->cpu)
1268ea0e0bSAndrew Jones 
13ce024192SAndrew Jones extern bool cpu0_calls_idle;
14ce024192SAndrew Jones 
1568ea0e0bSAndrew Jones extern void halt(void);
169246de4cSAndrew Jones extern void do_idle(void);
1768ea0e0bSAndrew Jones 
1868ea0e0bSAndrew Jones extern cpumask_t cpu_present_mask;
1968ea0e0bSAndrew Jones extern cpumask_t cpu_online_mask;
209246de4cSAndrew Jones extern cpumask_t cpu_idle_mask;
2168ea0e0bSAndrew Jones #define cpu_present(cpu)		cpumask_test_cpu(cpu, &cpu_present_mask)
2268ea0e0bSAndrew Jones #define cpu_online(cpu)			cpumask_test_cpu(cpu, &cpu_online_mask)
239246de4cSAndrew Jones #define cpu_idle(cpu)			cpumask_test_cpu(cpu, &cpu_idle_mask)
2468ea0e0bSAndrew Jones #define for_each_present_cpu(cpu)	for_each_cpu(cpu, &cpu_present_mask)
2568ea0e0bSAndrew Jones #define for_each_online_cpu(cpu)	for_each_cpu(cpu, &cpu_online_mask)
2668ea0e0bSAndrew Jones 
2768ea0e0bSAndrew Jones static inline void set_cpu_present(int cpu, bool present)
2868ea0e0bSAndrew Jones {
2968ea0e0bSAndrew Jones 	if (present)
3068ea0e0bSAndrew Jones 		cpumask_set_cpu(cpu, &cpu_present_mask);
3168ea0e0bSAndrew Jones 	else
3268ea0e0bSAndrew Jones 		cpumask_clear_cpu(cpu, &cpu_present_mask);
3368ea0e0bSAndrew Jones }
3468ea0e0bSAndrew Jones 
3568ea0e0bSAndrew Jones static inline void set_cpu_online(int cpu, bool online)
3668ea0e0bSAndrew Jones {
3768ea0e0bSAndrew Jones 	if (online)
3868ea0e0bSAndrew Jones 		cpumask_set_cpu(cpu, &cpu_online_mask);
3968ea0e0bSAndrew Jones 	else
4068ea0e0bSAndrew Jones 		cpumask_clear_cpu(cpu, &cpu_online_mask);
4168ea0e0bSAndrew Jones }
4268ea0e0bSAndrew Jones 
439246de4cSAndrew Jones static inline void set_cpu_idle(int cpu, bool idle)
449246de4cSAndrew Jones {
459246de4cSAndrew Jones 	if (idle)
469246de4cSAndrew Jones 		cpumask_set_cpu(cpu, &cpu_idle_mask);
479246de4cSAndrew Jones 	else
489246de4cSAndrew Jones 		cpumask_clear_cpu(cpu, &cpu_idle_mask);
499246de4cSAndrew Jones }
509246de4cSAndrew Jones 
5168ea0e0bSAndrew Jones typedef void (*secondary_entry_fn)(void);
5268ea0e0bSAndrew Jones extern void smp_boot_secondary(int cpu, secondary_entry_fn entry);
53e713fd55SAndrew Jones extern void on_cpu_async(int cpu, void (*func)(void *data), void *data);
54e713fd55SAndrew Jones extern void on_cpu(int cpu, void (*func)(void *data), void *data);
55*00b34f56SAndrew Jones extern void on_cpus(void (*func)(void *data), void *data);
5668ea0e0bSAndrew Jones 
5768ea0e0bSAndrew Jones #endif /* _ASMARM_SMP_H_ */
58