ssb_private.h 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  1. #ifndef LINUX_SSB_PRIVATE_H_
  2. #define LINUX_SSB_PRIVATE_H_
  3. #include <linux/ssb/ssb.h>
  4. #include <linux/types.h>
  5. #include <linux/bcm47xx_wdt.h>
  6. #define PFX "ssb: "
  7. #ifdef CONFIG_SSB_SILENT
  8. # define ssb_printk(fmt, ...) \
  9. do { if (0) printk(fmt, ##__VA_ARGS__); } while (0)
  10. #else
  11. # define ssb_printk(fmt, ...) \
  12. printk(fmt, ##__VA_ARGS__)
  13. #endif /* CONFIG_SSB_SILENT */
  14. #define ssb_emerg(fmt, ...) ssb_printk(KERN_EMERG PFX fmt, ##__VA_ARGS__)
  15. #define ssb_err(fmt, ...) ssb_printk(KERN_ERR PFX fmt, ##__VA_ARGS__)
  16. #define ssb_warn(fmt, ...) ssb_printk(KERN_WARNING PFX fmt, ##__VA_ARGS__)
  17. #define ssb_notice(fmt, ...) ssb_printk(KERN_NOTICE PFX fmt, ##__VA_ARGS__)
  18. #define ssb_info(fmt, ...) ssb_printk(KERN_INFO PFX fmt, ##__VA_ARGS__)
  19. #define ssb_cont(fmt, ...) ssb_printk(KERN_CONT fmt, ##__VA_ARGS__)
  20. /* dprintk: Debugging printk; vanishes for non-debug compilation */
  21. #ifdef CONFIG_SSB_DEBUG
  22. # define ssb_dbg(fmt, ...) \
  23. ssb_printk(KERN_DEBUG PFX fmt, ##__VA_ARGS__)
  24. #else
  25. # define ssb_dbg(fmt, ...) \
  26. do { if (0) printk(KERN_DEBUG PFX fmt, ##__VA_ARGS__); } while (0)
  27. #endif
  28. #ifdef CONFIG_SSB_DEBUG
  29. # define SSB_WARN_ON(x) WARN_ON(x)
  30. # define SSB_BUG_ON(x) BUG_ON(x)
  31. #else
  32. static inline int __ssb_do_nothing(int x) { return x; }
  33. # define SSB_WARN_ON(x) __ssb_do_nothing(unlikely(!!(x)))
  34. # define SSB_BUG_ON(x) __ssb_do_nothing(unlikely(!!(x)))
  35. #endif
  36. /* pci.c */
  37. #ifdef CONFIG_SSB_PCIHOST
  38. extern int ssb_pci_switch_core(struct ssb_bus *bus,
  39. struct ssb_device *dev);
  40. extern int ssb_pci_switch_coreidx(struct ssb_bus *bus,
  41. u8 coreidx);
  42. extern int ssb_pci_xtal(struct ssb_bus *bus, u32 what,
  43. int turn_on);
  44. extern int ssb_pci_get_invariants(struct ssb_bus *bus,
  45. struct ssb_init_invariants *iv);
  46. extern void ssb_pci_exit(struct ssb_bus *bus);
  47. extern int ssb_pci_init(struct ssb_bus *bus);
  48. extern const struct ssb_bus_ops ssb_pci_ops;
  49. #else /* CONFIG_SSB_PCIHOST */
  50. static inline int ssb_pci_switch_core(struct ssb_bus *bus,
  51. struct ssb_device *dev)
  52. {
  53. return 0;
  54. }
  55. static inline int ssb_pci_switch_coreidx(struct ssb_bus *bus,
  56. u8 coreidx)
  57. {
  58. return 0;
  59. }
  60. static inline int ssb_pci_xtal(struct ssb_bus *bus, u32 what,
  61. int turn_on)
  62. {
  63. return 0;
  64. }
  65. static inline void ssb_pci_exit(struct ssb_bus *bus)
  66. {
  67. }
  68. static inline int ssb_pci_init(struct ssb_bus *bus)
  69. {
  70. return 0;
  71. }
  72. #endif /* CONFIG_SSB_PCIHOST */
  73. /* pcmcia.c */
  74. #ifdef CONFIG_SSB_PCMCIAHOST
  75. extern int ssb_pcmcia_switch_coreidx(struct ssb_bus *bus,
  76. u8 coreidx);
  77. extern int ssb_pcmcia_switch_segment(struct ssb_bus *bus,
  78. u8 seg);
  79. extern int ssb_pcmcia_get_invariants(struct ssb_bus *bus,
  80. struct ssb_init_invariants *iv);
  81. extern int ssb_pcmcia_hardware_setup(struct ssb_bus *bus);
  82. extern void ssb_pcmcia_exit(struct ssb_bus *bus);
  83. extern int ssb_pcmcia_init(struct ssb_bus *bus);
  84. extern int ssb_host_pcmcia_init(void);
  85. extern void ssb_host_pcmcia_exit(void);
  86. extern const struct ssb_bus_ops ssb_pcmcia_ops;
  87. #else /* CONFIG_SSB_PCMCIAHOST */
  88. static inline int ssb_pcmcia_switch_coreidx(struct ssb_bus *bus,
  89. u8 coreidx)
  90. {
  91. return 0;
  92. }
  93. static inline int ssb_pcmcia_switch_segment(struct ssb_bus *bus,
  94. u8 seg)
  95. {
  96. return 0;
  97. }
  98. static inline int ssb_pcmcia_hardware_setup(struct ssb_bus *bus)
  99. {
  100. return 0;
  101. }
  102. static inline void ssb_pcmcia_exit(struct ssb_bus *bus)
  103. {
  104. }
  105. static inline int ssb_pcmcia_init(struct ssb_bus *bus)
  106. {
  107. return 0;
  108. }
  109. static inline int ssb_host_pcmcia_init(void)
  110. {
  111. return 0;
  112. }
  113. static inline void ssb_host_pcmcia_exit(void)
  114. {
  115. }
  116. #endif /* CONFIG_SSB_PCMCIAHOST */
  117. /* sdio.c */
  118. #ifdef CONFIG_SSB_SDIOHOST
  119. extern int ssb_sdio_get_invariants(struct ssb_bus *bus,
  120. struct ssb_init_invariants *iv);
  121. extern u32 ssb_sdio_scan_read32(struct ssb_bus *bus, u16 offset);
  122. extern int ssb_sdio_scan_switch_coreidx(struct ssb_bus *bus, u8 coreidx);
  123. extern void ssb_sdio_exit(struct ssb_bus *bus);
  124. extern int ssb_sdio_init(struct ssb_bus *bus);
  125. extern const struct ssb_bus_ops ssb_sdio_ops;
  126. #else /* CONFIG_SSB_SDIOHOST */
  127. static inline u32 ssb_sdio_scan_read32(struct ssb_bus *bus, u16 offset)
  128. {
  129. return 0;
  130. }
  131. static inline int ssb_sdio_scan_switch_coreidx(struct ssb_bus *bus, u8 coreidx)
  132. {
  133. return 0;
  134. }
  135. static inline void ssb_sdio_exit(struct ssb_bus *bus)
  136. {
  137. }
  138. static inline int ssb_sdio_init(struct ssb_bus *bus)
  139. {
  140. return 0;
  141. }
  142. #endif /* CONFIG_SSB_SDIOHOST */
  143. /**************************************************
  144. * host_soc.c
  145. **************************************************/
  146. #ifdef CONFIG_SSB_HOST_SOC
  147. extern const struct ssb_bus_ops ssb_host_soc_ops;
  148. extern int ssb_host_soc_get_invariants(struct ssb_bus *bus,
  149. struct ssb_init_invariants *iv);
  150. #endif
  151. /* scan.c */
  152. extern const char *ssb_core_name(u16 coreid);
  153. extern int ssb_bus_scan(struct ssb_bus *bus,
  154. unsigned long baseaddr);
  155. extern void ssb_iounmap(struct ssb_bus *ssb);
  156. /* sprom.c */
  157. extern
  158. ssize_t ssb_attr_sprom_show(struct ssb_bus *bus, char *buf,
  159. int (*sprom_read)(struct ssb_bus *bus, u16 *sprom));
  160. extern
  161. ssize_t ssb_attr_sprom_store(struct ssb_bus *bus,
  162. const char *buf, size_t count,
  163. int (*sprom_check_crc)(const u16 *sprom, size_t size),
  164. int (*sprom_write)(struct ssb_bus *bus, const u16 *sprom));
  165. extern int ssb_fill_sprom_with_fallback(struct ssb_bus *bus,
  166. struct ssb_sprom *out);
  167. /* core.c */
  168. extern u32 ssb_calc_clock_rate(u32 plltype, u32 n, u32 m);
  169. extern struct ssb_bus *ssb_pci_dev_to_bus(struct pci_dev *pdev);
  170. int ssb_for_each_bus_call(unsigned long data,
  171. int (*func)(struct ssb_bus *bus, unsigned long data));
  172. extern struct ssb_bus *ssb_pcmcia_dev_to_bus(struct pcmcia_device *pdev);
  173. struct ssb_freeze_context {
  174. /* Pointer to the bus */
  175. struct ssb_bus *bus;
  176. /* Boolean list to indicate whether a device is frozen on this bus. */
  177. bool device_frozen[SSB_MAX_NR_CORES];
  178. };
  179. extern int ssb_devices_freeze(struct ssb_bus *bus, struct ssb_freeze_context *ctx);
  180. extern int ssb_devices_thaw(struct ssb_freeze_context *ctx);
  181. /* b43_pci_bridge.c */
  182. #ifdef CONFIG_SSB_B43_PCI_BRIDGE
  183. extern int __init b43_pci_ssb_bridge_init(void);
  184. extern void __exit b43_pci_ssb_bridge_exit(void);
  185. #else /* CONFIG_SSB_B43_PCI_BRIDGE */
  186. static inline int b43_pci_ssb_bridge_init(void)
  187. {
  188. return 0;
  189. }
  190. static inline void b43_pci_ssb_bridge_exit(void)
  191. {
  192. }
  193. #endif /* CONFIG_SSB_B43_PCI_BRIDGE */
  194. /* driver_chipcommon_pmu.c */
  195. extern u32 ssb_pmu_get_cpu_clock(struct ssb_chipcommon *cc);
  196. extern u32 ssb_pmu_get_controlclock(struct ssb_chipcommon *cc);
  197. extern u32 ssb_pmu_get_alp_clock(struct ssb_chipcommon *cc);
  198. extern u32 ssb_chipco_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt,
  199. u32 ticks);
  200. extern u32 ssb_chipco_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms);
  201. /* driver_chipcommon_sflash.c */
  202. #ifdef CONFIG_SSB_SFLASH
  203. int ssb_sflash_init(struct ssb_chipcommon *cc);
  204. #else
  205. static inline int ssb_sflash_init(struct ssb_chipcommon *cc)
  206. {
  207. pr_err("Serial flash not supported\n");
  208. return 0;
  209. }
  210. #endif /* CONFIG_SSB_SFLASH */
  211. #ifdef CONFIG_SSB_DRIVER_MIPS
  212. extern struct platform_device ssb_pflash_dev;
  213. #endif
  214. #ifdef CONFIG_SSB_SFLASH
  215. extern struct platform_device ssb_sflash_dev;
  216. #endif
  217. #ifdef CONFIG_SSB_DRIVER_EXTIF
  218. extern u32 ssb_extif_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt, u32 ticks);
  219. extern u32 ssb_extif_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms);
  220. #else
  221. static inline u32 ssb_extif_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt,
  222. u32 ticks)
  223. {
  224. return 0;
  225. }
  226. static inline u32 ssb_extif_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt,
  227. u32 ms)
  228. {
  229. return 0;
  230. }
  231. #endif
  232. #ifdef CONFIG_SSB_EMBEDDED
  233. extern int ssb_watchdog_register(struct ssb_bus *bus);
  234. #else /* CONFIG_SSB_EMBEDDED */
  235. static inline int ssb_watchdog_register(struct ssb_bus *bus)
  236. {
  237. return 0;
  238. }
  239. #endif /* CONFIG_SSB_EMBEDDED */
  240. #ifdef CONFIG_SSB_DRIVER_EXTIF
  241. extern void ssb_extif_init(struct ssb_extif *extif);
  242. #else
  243. static inline void ssb_extif_init(struct ssb_extif *extif)
  244. {
  245. }
  246. #endif
  247. #ifdef CONFIG_SSB_DRIVER_GPIO
  248. extern int ssb_gpio_init(struct ssb_bus *bus);
  249. extern int ssb_gpio_unregister(struct ssb_bus *bus);
  250. #else /* CONFIG_SSB_DRIVER_GPIO */
  251. static inline int ssb_gpio_init(struct ssb_bus *bus)
  252. {
  253. return -ENOTSUPP;
  254. }
  255. static inline int ssb_gpio_unregister(struct ssb_bus *bus)
  256. {
  257. return 0;
  258. }
  259. #endif /* CONFIG_SSB_DRIVER_GPIO */
  260. #endif /* LINUX_SSB_PRIVATE_H_ */