0001
0002 #ifndef __ARCH_MACH_COMMON_H
0003 #define __ARCH_MACH_COMMON_H
0004
0005 extern void shmobile_init_delay(void);
0006 extern void shmobile_boot_vector(void);
0007 extern unsigned long shmobile_boot_fn;
0008 extern unsigned long shmobile_boot_size;
0009 extern void shmobile_boot_vector_gen2(void);
0010 extern unsigned long shmobile_boot_fn_gen2;
0011 extern unsigned long shmobile_boot_cpu_gen2;
0012 extern unsigned long shmobile_boot_size_gen2;
0013 extern void shmobile_smp_boot(void);
0014 extern void shmobile_smp_sleep(void);
0015 extern void shmobile_smp_hook(unsigned int cpu, unsigned long fn,
0016 unsigned long arg);
0017 extern bool shmobile_smp_cpu_can_disable(unsigned int cpu);
0018 extern void shmobile_boot_apmu(void);
0019 extern void shmobile_boot_scu(void);
0020 extern void shmobile_smp_scu_prepare_cpus(phys_addr_t scu_base_phys,
0021 unsigned int max_cpus);
0022 extern void shmobile_smp_scu_cpu_die(unsigned int cpu);
0023 extern int shmobile_smp_scu_cpu_kill(unsigned int cpu);
0024 extern struct platform_suspend_ops shmobile_suspend_ops;
0025
0026 #ifdef CONFIG_SUSPEND
0027 int shmobile_suspend_init(void);
0028 void shmobile_smp_apmu_suspend_init(void);
0029 #else
0030 static inline int shmobile_suspend_init(void) { return 0; }
0031 static inline void shmobile_smp_apmu_suspend_init(void) { }
0032 #endif
0033
0034 static inline void __init shmobile_init_late(void)
0035 {
0036 shmobile_suspend_init();
0037 }
0038
0039 #endif