blob: 309025efd4cf29df8fecee49e05ddf883e10be04 [file] [log] [blame]
Magnus Dammc793c1b2010-02-05 11:14:49 +00001#ifndef __ARCH_MACH_COMMON_H
2#define __ARCH_MACH_COMMON_H
3
Magnus Damm08ad42f2012-03-06 17:36:14 +09004extern void shmobile_earlytimer_init(void);
Magnus Dammc39dae32014-03-06 12:28:24 +09005extern void shmobile_init_delay(void);
Marc Zyngier4200b162012-01-10 19:44:19 +00006struct twd_local_timer;
Magnus Damm4ae04ac2010-02-08 11:02:54 +00007extern void shmobile_setup_console(void);
Magnus Dammebe72ab2013-06-10 18:19:36 +09008extern void shmobile_boot_vector(void);
9extern unsigned long shmobile_boot_fn;
10extern unsigned long shmobile_boot_arg;
Magnus Damma84a5ab2013-08-08 07:14:07 +090011extern unsigned long shmobile_boot_size;
Magnus Dammcc615912013-08-01 03:38:18 +090012extern void shmobile_smp_boot(void);
13extern void shmobile_smp_sleep(void);
14extern void shmobile_smp_hook(unsigned int cpu, unsigned long fn,
15 unsigned long arg);
Magnus Damm5c4dfcd2013-08-08 07:13:30 +090016extern int shmobile_smp_cpu_disable(unsigned int cpu);
Magnus Damm87a08ca2013-08-08 07:13:58 +090017extern void shmobile_invalidate_start(void);
Magnus Dammbfabbcc2013-06-10 18:19:46 +090018extern void shmobile_boot_scu(void);
Magnus Dammc970d4e2013-07-31 16:07:12 +090019extern void shmobile_smp_scu_prepare_cpus(unsigned int max_cpus);
Magnus Damme7b1c962013-07-31 16:07:49 +090020extern void shmobile_smp_scu_cpu_die(unsigned int cpu);
21extern int shmobile_smp_scu_cpu_kill(unsigned int cpu);
Magnus Damm83ca5c82010-05-20 14:45:03 +000022struct clk;
Magnus Damm6b6a4c02012-02-29 21:41:30 +090023extern int shmobile_clk_init(void);
Magnus Damm863b1712010-12-28 08:27:01 +000024extern void shmobile_handle_irq_intc(struct pt_regs *);
Magnus Dammc3dada12011-04-29 02:23:28 +090025extern struct platform_suspend_ops shmobile_suspend_ops;
Magnus Dammb73b5c42011-11-11 14:01:30 +090026struct cpuidle_driver;
Rafael J. Wysocki5b411472012-08-15 20:58:19 +020027extern void shmobile_cpuidle_set_driver(struct cpuidle_driver *drv);
Magnus Damme47bb512010-05-12 14:21:24 +000028
Shawn Guo21cc1b72012-04-26 21:58:41 +080029#ifdef CONFIG_SUSPEND
30int shmobile_suspend_init(void);
keita kobayashid6d757c2014-05-29 16:24:27 +090031void shmobile_smp_apmu_suspend_init(void);
Shawn Guo21cc1b72012-04-26 21:58:41 +080032#else
33static inline int shmobile_suspend_init(void) { return 0; }
Simon Hormanecdaca42014-06-16 20:21:13 +090034static inline void shmobile_smp_apmu_suspend_init(void) { }
Shawn Guo21cc1b72012-04-26 21:58:41 +080035#endif
36
37#ifdef CONFIG_CPU_IDLE
38int shmobile_cpuidle_init(void);
39#else
40static inline int shmobile_cpuidle_init(void) { return 0; }
41#endif
42
Gaku Inami06e32c92014-06-03 21:02:45 +090043#ifdef CONFIG_CPU_FREQ
44int shmobile_cpufreq_init(void);
45#else
46static inline int shmobile_cpufreq_init(void) { return 0; }
47#endif
48
Magnus Damm4c822842013-02-13 22:47:17 +090049extern void __iomem *shmobile_scu_base;
Marc Zyngiera62580e2011-09-08 13:15:22 +010050
Arnd Bergmannb3796d92012-09-23 22:36:35 +000051static inline void __init shmobile_init_late(void)
Rafael J. Wysocki35f2b0b2012-08-15 20:57:27 +020052{
53 shmobile_suspend_init();
54 shmobile_cpuidle_init();
Gaku Inami06e32c92014-06-03 21:02:45 +090055 shmobile_cpufreq_init();
Rafael J. Wysocki35f2b0b2012-08-15 20:57:27 +020056}
57
Magnus Dammc793c1b2010-02-05 11:14:49 +000058#endif /* __ARCH_MACH_COMMON_H */