ssb_private.h 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  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. #endif
  149. /* scan.c */
  150. extern const char *ssb_core_name(u16 coreid);
  151. extern int ssb_bus_scan(struct ssb_bus *bus,
  152. unsigned long baseaddr);
  153. extern void ssb_iounmap(struct ssb_bus *ssb);
  154. /* sprom.c */
  155. extern
  156. ssize_t ssb_attr_sprom_show(struct ssb_bus *bus, char *buf,
  157. int (*sprom_read)(struct ssb_bus *bus, u16 *sprom));
  158. extern
  159. ssize_t ssb_attr_sprom_store(struct ssb_bus *bus,
  160. const char *buf, size_t count,
  161. int (*sprom_check_crc)(const u16 *sprom, size_t size),
  162. int (*sprom_write)(struct ssb_bus *bus, const u16 *sprom));
  163. extern int ssb_fill_sprom_with_fallback(struct ssb_bus *bus,
  164. struct ssb_sprom *out);
  165. /* core.c */
  166. extern u32 ssb_calc_clock_rate(u32 plltype, u32 n, u32 m);
  167. extern struct ssb_bus *ssb_pci_dev_to_bus(struct pci_dev *pdev);
  168. int ssb_for_each_bus_call(unsigned long data,
  169. int (*func)(struct ssb_bus *bus, unsigned long data));
  170. extern struct ssb_bus *ssb_pcmcia_dev_to_bus(struct pcmcia_device *pdev);
  171. struct ssb_freeze_context {
  172. /* Pointer to the bus */
  173. struct ssb_bus *bus;
  174. /* Boolean list to indicate whether a device is frozen on this bus. */
  175. bool device_frozen[SSB_MAX_NR_CORES];
  176. };
  177. extern int ssb_devices_freeze(struct ssb_bus *bus, struct ssb_freeze_context *ctx);
  178. extern int ssb_devices_thaw(struct ssb_freeze_context *ctx);
  179. /* b43_pci_bridge.c */
  180. #ifdef CONFIG_SSB_B43_PCI_BRIDGE
  181. extern int __init b43_pci_ssb_bridge_init(void);
  182. extern void __exit b43_pci_ssb_bridge_exit(void);
  183. #else /* CONFIG_SSB_B43_PCI_BRIDGE */
  184. static inline int b43_pci_ssb_bridge_init(void)
  185. {
  186. return 0;
  187. }
  188. static inline void b43_pci_ssb_bridge_exit(void)
  189. {
  190. }
  191. #endif /* CONFIG_SSB_B43_PCI_BRIDGE */
  192. /* driver_chipcommon_pmu.c */
  193. extern u32 ssb_pmu_get_cpu_clock(struct ssb_chipcommon *cc);
  194. extern u32 ssb_pmu_get_controlclock(struct ssb_chipcommon *cc);
  195. extern u32 ssb_pmu_get_alp_clock(struct ssb_chipcommon *cc);
  196. extern u32 ssb_chipco_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt,
  197. u32 ticks);
  198. extern u32 ssb_chipco_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms);
  199. /* driver_chipcommon_sflash.c */
  200. #ifdef CONFIG_SSB_SFLASH
  201. int ssb_sflash_init(struct ssb_chipcommon *cc);
  202. #else
  203. static inline int ssb_sflash_init(struct ssb_chipcommon *cc)
  204. {
  205. pr_err("Serial flash not supported\n");
  206. return 0;
  207. }
  208. #endif /* CONFIG_SSB_SFLASH */
  209. #ifdef CONFIG_SSB_DRIVER_MIPS
  210. extern struct platform_device ssb_pflash_dev;
  211. #endif
  212. #ifdef CONFIG_SSB_SFLASH
  213. extern struct platform_device ssb_sflash_dev;
  214. #endif
  215. #ifdef CONFIG_SSB_DRIVER_EXTIF
  216. extern u32 ssb_extif_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt, u32 ticks);
  217. extern u32 ssb_extif_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms);
  218. #else
  219. static inline u32 ssb_extif_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt,
  220. u32 ticks)
  221. {
  222. return 0;
  223. }
  224. static inline u32 ssb_extif_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt,
  225. u32 ms)
  226. {
  227. return 0;
  228. }
  229. #endif
  230. #ifdef CONFIG_SSB_EMBEDDED
  231. extern int ssb_watchdog_register(struct ssb_bus *bus);
  232. #else /* CONFIG_SSB_EMBEDDED */
  233. static inline int ssb_watchdog_register(struct ssb_bus *bus)
  234. {
  235. return 0;
  236. }
  237. #endif /* CONFIG_SSB_EMBEDDED */
  238. #ifdef CONFIG_SSB_DRIVER_EXTIF
  239. extern void ssb_extif_init(struct ssb_extif *extif);
  240. #else
  241. static inline void ssb_extif_init(struct ssb_extif *extif)
  242. {
  243. }
  244. #endif
  245. #ifdef CONFIG_SSB_DRIVER_GPIO
  246. extern int ssb_gpio_init(struct ssb_bus *bus);
  247. extern int ssb_gpio_unregister(struct ssb_bus *bus);
  248. #else /* CONFIG_SSB_DRIVER_GPIO */
  249. static inline int ssb_gpio_init(struct ssb_bus *bus)
  250. {
  251. return -ENOTSUPP;
  252. }
  253. static inline int ssb_gpio_unregister(struct ssb_bus *bus)
  254. {
  255. return 0;
  256. }
  257. #endif /* CONFIG_SSB_DRIVER_GPIO */
  258. #endif /* LINUX_SSB_PRIVATE_H_ */