bcma_driver_pci.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. #ifndef LINUX_BCMA_DRIVER_PCI_H_
  2. #define LINUX_BCMA_DRIVER_PCI_H_
  3. #include <linux/types.h>
  4. struct pci_dev;
  5. /** PCI core registers. **/
  6. #define BCMA_CORE_PCI_CTL 0x0000 /* PCI Control */
  7. #define BCMA_CORE_PCI_CTL_RST_OE 0x00000001 /* PCI_RESET Output Enable */
  8. #define BCMA_CORE_PCI_CTL_RST 0x00000002 /* PCI_RESET driven out to pin */
  9. #define BCMA_CORE_PCI_CTL_CLK_OE 0x00000004 /* Clock gate Output Enable */
  10. #define BCMA_CORE_PCI_CTL_CLK 0x00000008 /* Gate for clock driven out to pin */
  11. #define BCMA_CORE_PCI_ARBCTL 0x0010 /* PCI Arbiter Control */
  12. #define BCMA_CORE_PCI_ARBCTL_INTERN 0x00000001 /* Use internal arbiter */
  13. #define BCMA_CORE_PCI_ARBCTL_EXTERN 0x00000002 /* Use external arbiter */
  14. #define BCMA_CORE_PCI_ARBCTL_PARKID 0x00000006 /* Mask, selects which agent is parked on an idle bus */
  15. #define BCMA_CORE_PCI_ARBCTL_PARKID_LAST 0x00000000 /* Last requestor */
  16. #define BCMA_CORE_PCI_ARBCTL_PARKID_4710 0x00000002 /* 4710 */
  17. #define BCMA_CORE_PCI_ARBCTL_PARKID_EXT0 0x00000004 /* External requestor 0 */
  18. #define BCMA_CORE_PCI_ARBCTL_PARKID_EXT1 0x00000006 /* External requestor 1 */
  19. #define BCMA_CORE_PCI_ISTAT 0x0020 /* Interrupt status */
  20. #define BCMA_CORE_PCI_ISTAT_INTA 0x00000001 /* PCI INTA# */
  21. #define BCMA_CORE_PCI_ISTAT_INTB 0x00000002 /* PCI INTB# */
  22. #define BCMA_CORE_PCI_ISTAT_SERR 0x00000004 /* PCI SERR# (write to clear) */
  23. #define BCMA_CORE_PCI_ISTAT_PERR 0x00000008 /* PCI PERR# (write to clear) */
  24. #define BCMA_CORE_PCI_ISTAT_PME 0x00000010 /* PCI PME# */
  25. #define BCMA_CORE_PCI_IMASK 0x0024 /* Interrupt mask */
  26. #define BCMA_CORE_PCI_IMASK_INTA 0x00000001 /* PCI INTA# */
  27. #define BCMA_CORE_PCI_IMASK_INTB 0x00000002 /* PCI INTB# */
  28. #define BCMA_CORE_PCI_IMASK_SERR 0x00000004 /* PCI SERR# */
  29. #define BCMA_CORE_PCI_IMASK_PERR 0x00000008 /* PCI PERR# */
  30. #define BCMA_CORE_PCI_IMASK_PME 0x00000010 /* PCI PME# */
  31. #define BCMA_CORE_PCI_MBOX 0x0028 /* Backplane to PCI Mailbox */
  32. #define BCMA_CORE_PCI_MBOX_F0_0 0x00000100 /* PCI function 0, INT 0 */
  33. #define BCMA_CORE_PCI_MBOX_F0_1 0x00000200 /* PCI function 0, INT 1 */
  34. #define BCMA_CORE_PCI_MBOX_F1_0 0x00000400 /* PCI function 1, INT 0 */
  35. #define BCMA_CORE_PCI_MBOX_F1_1 0x00000800 /* PCI function 1, INT 1 */
  36. #define BCMA_CORE_PCI_MBOX_F2_0 0x00001000 /* PCI function 2, INT 0 */
  37. #define BCMA_CORE_PCI_MBOX_F2_1 0x00002000 /* PCI function 2, INT 1 */
  38. #define BCMA_CORE_PCI_MBOX_F3_0 0x00004000 /* PCI function 3, INT 0 */
  39. #define BCMA_CORE_PCI_MBOX_F3_1 0x00008000 /* PCI function 3, INT 1 */
  40. #define BCMA_CORE_PCI_BCAST_ADDR 0x0050 /* Backplane Broadcast Address */
  41. #define BCMA_CORE_PCI_BCAST_ADDR_MASK 0x000000FF
  42. #define BCMA_CORE_PCI_BCAST_DATA 0x0054 /* Backplane Broadcast Data */
  43. #define BCMA_CORE_PCI_GPIO_IN 0x0060 /* rev >= 2 only */
  44. #define BCMA_CORE_PCI_GPIO_OUT 0x0064 /* rev >= 2 only */
  45. #define BCMA_CORE_PCI_GPIO_ENABLE 0x0068 /* rev >= 2 only */
  46. #define BCMA_CORE_PCI_GPIO_CTL 0x006C /* rev >= 2 only */
  47. #define BCMA_CORE_PCI_SBTOPCI0 0x0100 /* Backplane to PCI translation 0 (sbtopci0) */
  48. #define BCMA_CORE_PCI_SBTOPCI0_MASK 0xFC000000
  49. #define BCMA_CORE_PCI_SBTOPCI1 0x0104 /* Backplane to PCI translation 1 (sbtopci1) */
  50. #define BCMA_CORE_PCI_SBTOPCI1_MASK 0xFC000000
  51. #define BCMA_CORE_PCI_SBTOPCI2 0x0108 /* Backplane to PCI translation 2 (sbtopci2) */
  52. #define BCMA_CORE_PCI_SBTOPCI2_MASK 0xC0000000
  53. #define BCMA_CORE_PCI_CONFIG_ADDR 0x0120 /* pcie config space access */
  54. #define BCMA_CORE_PCI_CONFIG_DATA 0x0124 /* pcie config space access */
  55. #define BCMA_CORE_PCI_MDIO_CONTROL 0x0128 /* controls the mdio access */
  56. #define BCMA_CORE_PCI_MDIOCTL_DIVISOR_MASK 0x7f /* clock to be used on MDIO */
  57. #define BCMA_CORE_PCI_MDIOCTL_DIVISOR_VAL 0x2
  58. #define BCMA_CORE_PCI_MDIOCTL_PREAM_EN 0x80 /* Enable preamble sequnce */
  59. #define BCMA_CORE_PCI_MDIOCTL_ACCESS_DONE 0x100 /* Tranaction complete */
  60. #define BCMA_CORE_PCI_MDIO_DATA 0x012c /* Data to the mdio access */
  61. #define BCMA_CORE_PCI_MDIODATA_MASK 0x0000ffff /* data 2 bytes */
  62. #define BCMA_CORE_PCI_MDIODATA_TA 0x00020000 /* Turnaround */
  63. #define BCMA_CORE_PCI_MDIODATA_REGADDR_SHF_OLD 18 /* Regaddr shift (rev < 10) */
  64. #define BCMA_CORE_PCI_MDIODATA_REGADDR_MASK_OLD 0x003c0000 /* Regaddr Mask (rev < 10) */
  65. #define BCMA_CORE_PCI_MDIODATA_DEVADDR_SHF_OLD 22 /* Physmedia devaddr shift (rev < 10) */
  66. #define BCMA_CORE_PCI_MDIODATA_DEVADDR_MASK_OLD 0x0fc00000 /* Physmedia devaddr Mask (rev < 10) */
  67. #define BCMA_CORE_PCI_MDIODATA_REGADDR_SHF 18 /* Regaddr shift */
  68. #define BCMA_CORE_PCI_MDIODATA_REGADDR_MASK 0x007c0000 /* Regaddr Mask */
  69. #define BCMA_CORE_PCI_MDIODATA_DEVADDR_SHF 23 /* Physmedia devaddr shift */
  70. #define BCMA_CORE_PCI_MDIODATA_DEVADDR_MASK 0x0f800000 /* Physmedia devaddr Mask */
  71. #define BCMA_CORE_PCI_MDIODATA_WRITE 0x10000000 /* write Transaction */
  72. #define BCMA_CORE_PCI_MDIODATA_READ 0x20000000 /* Read Transaction */
  73. #define BCMA_CORE_PCI_MDIODATA_START 0x40000000 /* start of Transaction */
  74. #define BCMA_CORE_PCI_MDIODATA_DEV_ADDR 0x0 /* dev address for serdes */
  75. #define BCMA_CORE_PCI_MDIODATA_BLK_ADDR 0x1F /* blk address for serdes */
  76. #define BCMA_CORE_PCI_MDIODATA_DEV_PLL 0x1d /* SERDES PLL Dev */
  77. #define BCMA_CORE_PCI_MDIODATA_DEV_TX 0x1e /* SERDES TX Dev */
  78. #define BCMA_CORE_PCI_MDIODATA_DEV_RX 0x1f /* SERDES RX Dev */
  79. #define BCMA_CORE_PCI_PCIEIND_ADDR 0x0130 /* indirect access to the internal register */
  80. #define BCMA_CORE_PCI_PCIEIND_DATA 0x0134 /* Data to/from the internal regsiter */
  81. #define BCMA_CORE_PCI_CLKREQENCTRL 0x0138 /* >= rev 6, Clkreq rdma control */
  82. #define BCMA_CORE_PCI_PCICFG0 0x0400 /* PCI config space 0 (rev >= 8) */
  83. #define BCMA_CORE_PCI_PCICFG1 0x0500 /* PCI config space 1 (rev >= 8) */
  84. #define BCMA_CORE_PCI_PCICFG2 0x0600 /* PCI config space 2 (rev >= 8) */
  85. #define BCMA_CORE_PCI_PCICFG3 0x0700 /* PCI config space 3 (rev >= 8) */
  86. #define BCMA_CORE_PCI_SPROM(wordoffset) (0x0800 + ((wordoffset) * 2)) /* SPROM shadow area (72 bytes) */
  87. #define BCMA_CORE_PCI_SPROM_PI_OFFSET 0 /* first word */
  88. #define BCMA_CORE_PCI_SPROM_PI_MASK 0xf000 /* bit 15:12 */
  89. #define BCMA_CORE_PCI_SPROM_PI_SHIFT 12 /* bit 15:12 */
  90. #define BCMA_CORE_PCI_SPROM_MISC_CONFIG 5 /* word 5 */
  91. #define BCMA_CORE_PCI_SPROM_L23READY_EXIT_NOPERST 0x8000 /* bit 15 */
  92. #define BCMA_CORE_PCI_SPROM_CLKREQ_OFFSET_REV5 20 /* word 20 for srom rev <= 5 */
  93. #define BCMA_CORE_PCI_SPROM_CLKREQ_ENB 0x0800 /* bit 11 */
  94. /* SBtoPCIx */
  95. #define BCMA_CORE_PCI_SBTOPCI_MEM 0x00000000
  96. #define BCMA_CORE_PCI_SBTOPCI_IO 0x00000001
  97. #define BCMA_CORE_PCI_SBTOPCI_CFG0 0x00000002
  98. #define BCMA_CORE_PCI_SBTOPCI_CFG1 0x00000003
  99. #define BCMA_CORE_PCI_SBTOPCI_PREF 0x00000004 /* Prefetch enable */
  100. #define BCMA_CORE_PCI_SBTOPCI_BURST 0x00000008 /* Burst enable */
  101. #define BCMA_CORE_PCI_SBTOPCI_MRM 0x00000020 /* Memory Read Multiple */
  102. #define BCMA_CORE_PCI_SBTOPCI_RC 0x00000030 /* Read Command mask (rev >= 11) */
  103. #define BCMA_CORE_PCI_SBTOPCI_RC_READ 0x00000000 /* Memory read */
  104. #define BCMA_CORE_PCI_SBTOPCI_RC_READL 0x00000010 /* Memory read line */
  105. #define BCMA_CORE_PCI_SBTOPCI_RC_READM 0x00000020 /* Memory read multiple */
  106. /* PCIE protocol PHY diagnostic registers */
  107. #define BCMA_CORE_PCI_PLP_MODEREG 0x200 /* Mode */
  108. #define BCMA_CORE_PCI_PLP_STATUSREG 0x204 /* Status */
  109. #define BCMA_CORE_PCI_PLP_POLARITYINV_STAT 0x10 /* Status reg PCIE_PLP_STATUSREG */
  110. #define BCMA_CORE_PCI_PLP_LTSSMCTRLREG 0x208 /* LTSSM control */
  111. #define BCMA_CORE_PCI_PLP_LTLINKNUMREG 0x20c /* Link Training Link number */
  112. #define BCMA_CORE_PCI_PLP_LTLANENUMREG 0x210 /* Link Training Lane number */
  113. #define BCMA_CORE_PCI_PLP_LTNFTSREG 0x214 /* Link Training N_FTS */
  114. #define BCMA_CORE_PCI_PLP_ATTNREG 0x218 /* Attention */
  115. #define BCMA_CORE_PCI_PLP_ATTNMASKREG 0x21C /* Attention Mask */
  116. #define BCMA_CORE_PCI_PLP_RXERRCTR 0x220 /* Rx Error */
  117. #define BCMA_CORE_PCI_PLP_RXFRMERRCTR 0x224 /* Rx Framing Error */
  118. #define BCMA_CORE_PCI_PLP_RXERRTHRESHREG 0x228 /* Rx Error threshold */
  119. #define BCMA_CORE_PCI_PLP_TESTCTRLREG 0x22C /* Test Control reg */
  120. #define BCMA_CORE_PCI_PLP_SERDESCTRLOVRDREG 0x230 /* SERDES Control Override */
  121. #define BCMA_CORE_PCI_PLP_TIMINGOVRDREG 0x234 /* Timing param override */
  122. #define BCMA_CORE_PCI_PLP_RXTXSMDIAGREG 0x238 /* RXTX State Machine Diag */
  123. #define BCMA_CORE_PCI_PLP_LTSSMDIAGREG 0x23C /* LTSSM State Machine Diag */
  124. /* PCIE protocol DLLP diagnostic registers */
  125. #define BCMA_CORE_PCI_DLLP_LCREG 0x100 /* Link Control */
  126. #define BCMA_CORE_PCI_DLLP_LSREG 0x104 /* Link Status */
  127. #define BCMA_CORE_PCI_DLLP_LAREG 0x108 /* Link Attention */
  128. #define BCMA_CORE_PCI_DLLP_LSREG_LINKUP (1 << 16)
  129. #define BCMA_CORE_PCI_DLLP_LAMASKREG 0x10C /* Link Attention Mask */
  130. #define BCMA_CORE_PCI_DLLP_NEXTTXSEQNUMREG 0x110 /* Next Tx Seq Num */
  131. #define BCMA_CORE_PCI_DLLP_ACKEDTXSEQNUMREG 0x114 /* Acked Tx Seq Num */
  132. #define BCMA_CORE_PCI_DLLP_PURGEDTXSEQNUMREG 0x118 /* Purged Tx Seq Num */
  133. #define BCMA_CORE_PCI_DLLP_RXSEQNUMREG 0x11C /* Rx Sequence Number */
  134. #define BCMA_CORE_PCI_DLLP_LRREG 0x120 /* Link Replay */
  135. #define BCMA_CORE_PCI_DLLP_LACKTOREG 0x124 /* Link Ack Timeout */
  136. #define BCMA_CORE_PCI_DLLP_PMTHRESHREG 0x128 /* Power Management Threshold */
  137. #define BCMA_CORE_PCI_ASPMTIMER_EXTEND 0x01000000 /* > rev7: enable extend ASPM timer */
  138. #define BCMA_CORE_PCI_DLLP_RTRYWPREG 0x12C /* Retry buffer write ptr */
  139. #define BCMA_CORE_PCI_DLLP_RTRYRPREG 0x130 /* Retry buffer Read ptr */
  140. #define BCMA_CORE_PCI_DLLP_RTRYPPREG 0x134 /* Retry buffer Purged ptr */
  141. #define BCMA_CORE_PCI_DLLP_RTRRWREG 0x138 /* Retry buffer Read/Write */
  142. #define BCMA_CORE_PCI_DLLP_ECTHRESHREG 0x13C /* Error Count Threshold */
  143. #define BCMA_CORE_PCI_DLLP_TLPERRCTRREG 0x140 /* TLP Error Counter */
  144. #define BCMA_CORE_PCI_DLLP_ERRCTRREG 0x144 /* Error Counter */
  145. #define BCMA_CORE_PCI_DLLP_NAKRXCTRREG 0x148 /* NAK Received Counter */
  146. #define BCMA_CORE_PCI_DLLP_TESTREG 0x14C /* Test */
  147. #define BCMA_CORE_PCI_DLLP_PKTBIST 0x150 /* Packet BIST */
  148. #define BCMA_CORE_PCI_DLLP_PCIE11 0x154 /* DLLP PCIE 1.1 reg */
  149. /* SERDES RX registers */
  150. #define BCMA_CORE_PCI_SERDES_RX_CTRL 1 /* Rx cntrl */
  151. #define BCMA_CORE_PCI_SERDES_RX_CTRL_FORCE 0x80 /* rxpolarity_force */
  152. #define BCMA_CORE_PCI_SERDES_RX_CTRL_POLARITY 0x40 /* rxpolarity_value */
  153. #define BCMA_CORE_PCI_SERDES_RX_TIMER1 2 /* Rx Timer1 */
  154. #define BCMA_CORE_PCI_SERDES_RX_CDR 6 /* CDR */
  155. #define BCMA_CORE_PCI_SERDES_RX_CDRBW 7 /* CDR BW */
  156. /* SERDES PLL registers */
  157. #define BCMA_CORE_PCI_SERDES_PLL_CTRL 1 /* PLL control reg */
  158. #define BCMA_CORE_PCI_PLL_CTRL_FREQDET_EN 0x4000 /* bit 14 is FREQDET on */
  159. /* PCIcore specific boardflags */
  160. #define BCMA_CORE_PCI_BFL_NOPCI 0x00000400 /* Board leaves PCI floating */
  161. /* PCIE Config space accessing MACROS */
  162. #define BCMA_CORE_PCI_CFG_BUS_SHIFT 24 /* Bus shift */
  163. #define BCMA_CORE_PCI_CFG_SLOT_SHIFT 19 /* Slot/Device shift */
  164. #define BCMA_CORE_PCI_CFG_FUN_SHIFT 16 /* Function shift */
  165. #define BCMA_CORE_PCI_CFG_OFF_SHIFT 0 /* Register shift */
  166. #define BCMA_CORE_PCI_CFG_BUS_MASK 0xff /* Bus mask */
  167. #define BCMA_CORE_PCI_CFG_SLOT_MASK 0x1f /* Slot/Device mask */
  168. #define BCMA_CORE_PCI_CFG_FUN_MASK 7 /* Function mask */
  169. #define BCMA_CORE_PCI_CFG_OFF_MASK 0xfff /* Register mask */
  170. #define BCMA_CORE_PCI_CFG_DEVCTRL 0xd8
  171. #define BCMA_CORE_PCI_
  172. /* MDIO devices (SERDES modules) */
  173. #define BCMA_CORE_PCI_MDIO_IEEE0 0x000
  174. #define BCMA_CORE_PCI_MDIO_IEEE1 0x001
  175. #define BCMA_CORE_PCI_MDIO_BLK0 0x800
  176. #define BCMA_CORE_PCI_MDIO_BLK1 0x801
  177. #define BCMA_CORE_PCI_MDIO_BLK1_MGMT0 0x16
  178. #define BCMA_CORE_PCI_MDIO_BLK1_MGMT1 0x17
  179. #define BCMA_CORE_PCI_MDIO_BLK1_MGMT2 0x18
  180. #define BCMA_CORE_PCI_MDIO_BLK1_MGMT3 0x19
  181. #define BCMA_CORE_PCI_MDIO_BLK1_MGMT4 0x1A
  182. #define BCMA_CORE_PCI_MDIO_BLK2 0x802
  183. #define BCMA_CORE_PCI_MDIO_BLK3 0x803
  184. #define BCMA_CORE_PCI_MDIO_BLK4 0x804
  185. #define BCMA_CORE_PCI_MDIO_TXPLL 0x808 /* TXPLL register block idx */
  186. #define BCMA_CORE_PCI_MDIO_TXCTRL0 0x820
  187. #define BCMA_CORE_PCI_MDIO_SERDESID 0x831
  188. #define BCMA_CORE_PCI_MDIO_RXCTRL0 0x840
  189. /* PCIE Root Capability Register bits (Host mode only) */
  190. #define BCMA_CORE_PCI_RC_CRS_VISIBILITY 0x0001
  191. struct bcma_drv_pci;
  192. struct bcma_bus;
  193. #ifdef CONFIG_BCMA_DRIVER_PCI_HOSTMODE
  194. struct bcma_drv_pci_host {
  195. struct bcma_drv_pci *pdev;
  196. u32 host_cfg_addr;
  197. spinlock_t cfgspace_lock;
  198. struct pci_controller pci_controller;
  199. struct pci_ops pci_ops;
  200. struct resource mem_resource;
  201. struct resource io_resource;
  202. };
  203. #endif
  204. struct bcma_drv_pci {
  205. struct bcma_device *core;
  206. u8 early_setup_done:1;
  207. u8 setup_done:1;
  208. u8 hostmode:1;
  209. #ifdef CONFIG_BCMA_DRIVER_PCI_HOSTMODE
  210. struct bcma_drv_pci_host *host_controller;
  211. #endif
  212. };
  213. /* Register access */
  214. #define pcicore_read16(pc, offset) bcma_read16((pc)->core, offset)
  215. #define pcicore_read32(pc, offset) bcma_read32((pc)->core, offset)
  216. #define pcicore_write16(pc, offset, val) bcma_write16((pc)->core, offset, val)
  217. #define pcicore_write32(pc, offset, val) bcma_write32((pc)->core, offset, val)
  218. #ifdef CONFIG_BCMA_DRIVER_PCI
  219. extern void bcma_core_pci_power_save(struct bcma_bus *bus, bool up);
  220. #else
  221. static inline void bcma_core_pci_power_save(struct bcma_bus *bus, bool up)
  222. {
  223. }
  224. #endif
  225. #ifdef CONFIG_BCMA_DRIVER_PCI_HOSTMODE
  226. extern int bcma_core_pci_pcibios_map_irq(const struct pci_dev *dev);
  227. extern int bcma_core_pci_plat_dev_init(struct pci_dev *dev);
  228. #else
  229. static inline int bcma_core_pci_pcibios_map_irq(const struct pci_dev *dev)
  230. {
  231. return -ENOTSUPP;
  232. }
  233. static inline int bcma_core_pci_plat_dev_init(struct pci_dev *dev)
  234. {
  235. return -ENOTSUPP;
  236. }
  237. #endif
  238. #endif /* LINUX_BCMA_DRIVER_PCI_H_ */