common.h 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #ifndef __ARCH_MACH_COMMON_H
  2. #define __ARCH_MACH_COMMON_H
  3. extern void shmobile_earlytimer_init(void);
  4. extern void shmobile_timer_init(void);
  5. extern void shmobile_setup_delay(unsigned int max_cpu_core_mhz,
  6. unsigned int mult, unsigned int div);
  7. struct twd_local_timer;
  8. extern void shmobile_setup_console(void);
  9. extern void shmobile_secondary_vector(void);
  10. struct clk;
  11. extern int shmobile_clk_init(void);
  12. extern void shmobile_handle_irq_intc(struct pt_regs *);
  13. extern struct platform_suspend_ops shmobile_suspend_ops;
  14. struct cpuidle_driver;
  15. struct cpuidle_device;
  16. extern int shmobile_enter_wfi(struct cpuidle_device *dev,
  17. struct cpuidle_driver *drv, int index);
  18. extern void shmobile_cpuidle_set_driver(struct cpuidle_driver *drv);
  19. extern void sh7372_init_irq(void);
  20. extern void sh7372_map_io(void);
  21. extern void sh7372_earlytimer_init(void);
  22. extern void sh7372_add_early_devices(void);
  23. extern void sh7372_add_standard_devices(void);
  24. extern void sh7372_add_early_devices_dt(void);
  25. extern void sh7372_add_standard_devices_dt(void);
  26. extern void sh7372_clock_init(void);
  27. extern void sh7372_pinmux_init(void);
  28. extern void sh7372_pm_init(void);
  29. extern void sh7372_resume_core_standby_sysc(void);
  30. extern int sh7372_do_idle_sysc(unsigned long sleep_mode);
  31. extern struct clk sh7372_extal1_clk;
  32. extern struct clk sh7372_extal2_clk;
  33. extern void sh73a0_init_irq(void);
  34. extern void sh73a0_map_io(void);
  35. extern void sh73a0_earlytimer_init(void);
  36. extern void sh73a0_add_early_devices(void);
  37. extern void sh73a0_add_standard_devices(void);
  38. extern void sh73a0_clock_init(void);
  39. extern void sh73a0_pinmux_init(void);
  40. extern void sh73a0_pm_init(void);
  41. extern struct clk sh73a0_extal1_clk;
  42. extern struct clk sh73a0_extal2_clk;
  43. extern struct clk sh73a0_extcki_clk;
  44. extern struct clk sh73a0_extalr_clk;
  45. extern void r8a7740_init_irq(void);
  46. extern void r8a7740_map_io(void);
  47. extern void r8a7740_add_early_devices(void);
  48. extern void r8a7740_add_standard_devices(void);
  49. extern void r8a7740_clock_init(u8 md_ck);
  50. extern void r8a7740_pinmux_init(void);
  51. extern void r8a7740_pm_init(void);
  52. extern void r8a7779_init_irq(void);
  53. extern void r8a7779_map_io(void);
  54. extern void r8a7779_earlytimer_init(void);
  55. extern void r8a7779_add_early_devices(void);
  56. extern void r8a7779_add_standard_devices(void);
  57. extern void r8a7779_clock_init(void);
  58. extern void r8a7779_pinmux_init(void);
  59. extern void r8a7779_pm_init(void);
  60. extern void r8a7740_meram_workaround(void);
  61. extern void r8a7779_register_twd(void);
  62. #ifdef CONFIG_SUSPEND
  63. int shmobile_suspend_init(void);
  64. #else
  65. static inline int shmobile_suspend_init(void) { return 0; }
  66. #endif
  67. #ifdef CONFIG_CPU_IDLE
  68. int shmobile_cpuidle_init(void);
  69. #else
  70. static inline int shmobile_cpuidle_init(void) { return 0; }
  71. #endif
  72. extern void shmobile_cpu_die(unsigned int cpu);
  73. extern int shmobile_cpu_disable(unsigned int cpu);
  74. #ifdef CONFIG_HOTPLUG_CPU
  75. extern int shmobile_cpu_is_dead(unsigned int cpu);
  76. #else
  77. static inline int shmobile_cpu_is_dead(unsigned int cpu) { return 1; }
  78. #endif
  79. extern void shmobile_smp_init_cpus(unsigned int ncores);
  80. static inline void __init shmobile_init_late(void)
  81. {
  82. shmobile_suspend_init();
  83. shmobile_cpuidle_init();
  84. }
  85. #endif /* __ARCH_MACH_COMMON_H */