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>,
12 #include <asm/system.h>
15 extern void machine_restart_smp(char *);
16 extern void machine_halt_smp(void);
17 extern void machine_power_off_smp(void);
19 #define raw_smp_processor_id() (S390_lowcore.cpu_nr)
21 extern int __cpu_disable (void);
22 extern void __cpu_die (unsigned int cpu
);
23 extern int __cpu_up (unsigned int cpu
);
25 extern struct mutex smp_cpu_state_mutex
;
26 extern int smp_cpu_polarization
[];
28 extern void arch_send_call_function_single_ipi(int cpu
);
29 extern void arch_send_call_function_ipi_mask(const struct cpumask
*mask
);
31 extern struct save_area
*zfcpdump_save_areas
[NR_CPUS
+ 1];
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
,
36 extern void smp_restart_cpu(void);
39 * returns 1 if (virtual) cpu is scheduled
42 static inline int smp_vcpu_scheduled(int cpu
)
46 switch (sigp_ps(&status
, 0, cpu
, sigp_sense_running
)) {
47 case sigp_status_stored
:
48 /* Check for running status */
52 case sigp_not_operational
:
60 #else /* CONFIG_SMP */
62 static inline void smp_switch_to_ipl_cpu(void (*func
)(void *), void *data
)
67 #define smp_vcpu_scheduled (1)
69 #endif /* CONFIG_SMP */
71 #ifdef CONFIG_HOTPLUG_CPU
72 extern int smp_rescan_cpus(void);
73 extern void __noreturn
cpu_die(void);
75 static inline int smp_rescan_cpus(void) { return 0; }
76 static inline void cpu_die(void) { }
79 #endif /* __ASM_SMP_H */