12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- /*
- * Copyright IBM Corp. 1999,2009
- * Author(s): Denis Joseph Barrow,
- * Martin Schwidefsky <schwidefsky@de.ibm.com>,
- * Heiko Carstens <heiko.carstens@de.ibm.com>,
- */
- #ifndef __ASM_SMP_H
- #define __ASM_SMP_H
- #ifdef CONFIG_SMP
- #include <asm/system.h>
- #include <asm/sigp.h>
- extern void machine_restart_smp(char *);
- extern void machine_halt_smp(void);
- extern void machine_power_off_smp(void);
- #define raw_smp_processor_id() (S390_lowcore.cpu_nr)
- extern int __cpu_disable (void);
- extern void __cpu_die (unsigned int cpu);
- extern int __cpu_up (unsigned int cpu);
- extern struct mutex smp_cpu_state_mutex;
- extern int smp_cpu_polarization[];
- extern void arch_send_call_function_single_ipi(int cpu);
- extern void arch_send_call_function_ipi_mask(const struct cpumask *mask);
- extern struct save_area *zfcpdump_save_areas[NR_CPUS + 1];
- extern void smp_switch_to_ipl_cpu(void (*func)(void *), void *);
- extern void smp_switch_to_cpu(void (*)(void *), void *, unsigned long sp,
- int from, int to);
- extern void smp_restart_cpu(void);
- /*
- * returns 1 if (virtual) cpu is scheduled
- * returns 0 otherwise
- */
- static inline int smp_vcpu_scheduled(int cpu)
- {
- u32 status;
- switch (sigp_ps(&status, 0, cpu, sigp_sense_running)) {
- case sigp_status_stored:
- /* Check for running status */
- if (status & 0x400)
- return 0;
- break;
- case sigp_not_operational:
- return 0;
- default:
- break;
- }
- return 1;
- }
- #else /* CONFIG_SMP */
- static inline void smp_switch_to_ipl_cpu(void (*func)(void *), void *data)
- {
- func(data);
- }
- #define smp_vcpu_scheduled (1)
- #endif /* CONFIG_SMP */
- #ifdef CONFIG_HOTPLUG_CPU
- extern int smp_rescan_cpus(void);
- extern void __noreturn cpu_die(void);
- #else
- static inline int smp_rescan_cpus(void) { return 0; }
- static inline void cpu_die(void) { }
- #endif
- #endif /* __ASM_SMP_H */
|