blob: c590f76856f1ecd53af5a27ddef1e8e36dc5c525 [file] [log] [blame]
Paul Mundt3366e352010-03-30 12:38:01 +09001#ifndef __ASM_SH_SMP_OPS_H
2#define __ASM_SH_SMP_OPS_H
3
4struct plat_smp_ops {
5 void (*smp_setup)(void);
6 unsigned int (*smp_processor_id)(void);
7 void (*prepare_cpus)(unsigned int max_cpus);
8 void (*start_cpu)(unsigned int cpu, unsigned long entry_point);
9 void (*send_ipi)(unsigned int cpu, unsigned int message);
Paul Mundt763142d2010-04-26 19:08:55 +090010 int (*cpu_disable)(unsigned int cpu);
11 void (*cpu_die)(unsigned int cpu);
12 void (*play_dead)(void);
Paul Mundt3366e352010-03-30 12:38:01 +090013};
14
Paul Mundt763142d2010-04-26 19:08:55 +090015extern struct plat_smp_ops *mp_ops;
Paul Mundt3366e352010-03-30 12:38:01 +090016extern struct plat_smp_ops shx3_smp_ops;
17
18#ifdef CONFIG_SMP
19
20static inline void plat_smp_setup(void)
21{
Paul Mundt3366e352010-03-30 12:38:01 +090022 BUG_ON(!mp_ops);
23 mp_ops->smp_setup();
24}
25
Paul Mundt763142d2010-04-26 19:08:55 +090026static inline void play_dead(void)
27{
28 mp_ops->play_dead();
29}
30
Paul Mundt3366e352010-03-30 12:38:01 +090031extern void register_smp_ops(struct plat_smp_ops *ops);
32
33#else
34
35static inline void plat_smp_setup(void)
36{
37 /* UP, nothing to do ... */
38}
39
40static inline void register_smp_ops(struct plat_smp_ops *ops)
41{
42}
43
Paul Mundt763142d2010-04-26 19:08:55 +090044static inline void play_dead(void)
45{
46 BUG();
47}
48
Paul Mundt3366e352010-03-30 12:38:01 +090049#endif /* CONFIG_SMP */
50
51#endif /* __ASM_SH_SMP_OPS_H */