common.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. #ifndef __ARCH_MACH_COMMON_H
  2. #define __ARCH_MACH_COMMON_H
  3. extern void shmobile_earlytimer_init(void);
  4. extern void shmobile_setup_delay(unsigned int max_cpu_core_mhz,
  5. unsigned int mult, unsigned int div);
  6. struct twd_local_timer;
  7. extern void shmobile_setup_console(void);
  8. extern void shmobile_boot_vector(void);
  9. extern unsigned long shmobile_boot_fn;
  10. extern unsigned long shmobile_boot_arg;
  11. extern void shmobile_smp_boot(void);
  12. extern void shmobile_smp_sleep(void);
  13. extern void shmobile_smp_hook(unsigned int cpu, unsigned long fn,
  14. unsigned long arg);
  15. extern void shmobile_boot_scu(void);
  16. extern void shmobile_smp_scu_prepare_cpus(unsigned int max_cpus);
  17. extern int shmobile_smp_scu_boot_secondary(unsigned int cpu,
  18. struct task_struct *idle);
  19. extern void shmobile_smp_scu_cpu_die(unsigned int cpu);
  20. extern int shmobile_smp_scu_cpu_kill(unsigned int cpu);
  21. struct clk;
  22. extern int shmobile_clk_init(void);
  23. extern void shmobile_handle_irq_intc(struct pt_regs *);
  24. extern struct platform_suspend_ops shmobile_suspend_ops;
  25. struct cpuidle_driver;
  26. extern void shmobile_cpuidle_set_driver(struct cpuidle_driver *drv);
  27. #ifdef CONFIG_SUSPEND
  28. int shmobile_suspend_init(void);
  29. #else
  30. static inline int shmobile_suspend_init(void) { return 0; }
  31. #endif
  32. #ifdef CONFIG_CPU_IDLE
  33. int shmobile_cpuidle_init(void);
  34. #else
  35. static inline int shmobile_cpuidle_init(void) { return 0; }
  36. #endif
  37. extern void __iomem *shmobile_scu_base;
  38. extern void shmobile_smp_init_cpus(unsigned int ncores);
  39. static inline void __init shmobile_init_late(void)
  40. {
  41. shmobile_suspend_init();
  42. shmobile_cpuidle_init();
  43. }
  44. #endif /* __ARCH_MACH_COMMON_H */