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