1 /* 2 * Copyright IBM Corp. 1999,2009 3 * Author(s): Denis Joseph Barrow, 4 * Martin Schwidefsky <schwidefsky@de.ibm.com>, 5 * Heiko Carstens <heiko.carstens@de.ibm.com>, 6 */ 7 #ifndef __ASM_SMP_H 8 #define __ASM_SMP_H 9 10 #ifdef CONFIG_SMP 11 12 #include <asm/system.h> 13 #include <asm/sigp.h> 14 15 extern void machine_restart_smp(char *); 16 extern void machine_halt_smp(void); 17 extern void machine_power_off_smp(void); 18 19 #define raw_smp_processor_id() (S390_lowcore.cpu_nr) 20 21 extern int __cpu_disable (void); 22 extern void __cpu_die (unsigned int cpu); 23 extern int __cpu_up (unsigned int cpu); 24 25 extern struct mutex smp_cpu_state_mutex; 26 extern int smp_cpu_polarization[]; 27 28 extern void arch_send_call_function_single_ipi(int cpu); 29 extern void arch_send_call_function_ipi_mask(const struct cpumask *mask); 30 31 extern struct save_area *zfcpdump_save_areas[NR_CPUS + 1]; 32 33 extern void smp_switch_to_ipl_cpu(void (*func)(void *), void *); 34 extern void smp_switch_to_cpu(void (*)(void *), void *, unsigned long sp, 35 int from, int to); 36 extern void smp_restart_cpu(void); 37 38 /* 39 * returns 1 if (virtual) cpu is scheduled 40 * returns 0 otherwise 41 */ 42 static inline int smp_vcpu_scheduled(int cpu) 43 { 44 u32 status; 45 46 switch (sigp_ps(&status, 0, cpu, sigp_sense_running)) { 47 case sigp_status_stored: 48 /* Check for running status */ 49 if (status & 0x400) 50 return 0; 51 break; 52 case sigp_not_operational: 53 return 0; 54 default: 55 break; 56 } 57 return 1; 58 } 59 60 #else /* CONFIG_SMP */ 61 62 static inline void smp_switch_to_ipl_cpu(void (*func)(void *), void *data) 63 { 64 func(data); 65 } 66 67 #define smp_vcpu_scheduled (1) 68 69 #endif /* CONFIG_SMP */ 70 71 #ifdef CONFIG_HOTPLUG_CPU 72 extern int smp_rescan_cpus(void); 73 extern void __noreturn cpu_die(void); 74 #else 75 static inline int smp_rescan_cpus(void) { return 0; } 76 static inline void cpu_die(void) { } 77 #endif 78 79 #endif /* __ASM_SMP_H */ 80