bcma_driver_pcie2.h 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. #ifndef LINUX_BCMA_DRIVER_PCIE2_H_
  2. #define LINUX_BCMA_DRIVER_PCIE2_H_
  3. #define BCMA_CORE_PCIE2_CLK_CONTROL 0x0000
  4. #define PCIE2_CLKC_RST_OE 0x0001 /* When set, drives PCI_RESET out to pin */
  5. #define PCIE2_CLKC_RST 0x0002 /* Value driven out to pin */
  6. #define PCIE2_CLKC_SPERST 0x0004 /* SurvivePeRst */
  7. #define PCIE2_CLKC_DISABLE_L1CLK_GATING 0x0010
  8. #define PCIE2_CLKC_DLYPERST 0x0100 /* Delay PeRst to CoE Core */
  9. #define PCIE2_CLKC_DISSPROMLD 0x0200 /* DisableSpromLoadOnPerst */
  10. #define PCIE2_CLKC_WAKE_MODE_L2 0x1000 /* Wake on L2 */
  11. #define BCMA_CORE_PCIE2_RC_PM_CONTROL 0x0004
  12. #define BCMA_CORE_PCIE2_RC_PM_STATUS 0x0008
  13. #define BCMA_CORE_PCIE2_EP_PM_CONTROL 0x000C
  14. #define BCMA_CORE_PCIE2_EP_PM_STATUS 0x0010
  15. #define BCMA_CORE_PCIE2_EP_LTR_CONTROL 0x0014
  16. #define BCMA_CORE_PCIE2_EP_LTR_STATUS 0x0018
  17. #define BCMA_CORE_PCIE2_EP_OBFF_STATUS 0x001C
  18. #define BCMA_CORE_PCIE2_PCIE_ERR_STATUS 0x0020
  19. #define BCMA_CORE_PCIE2_RC_AXI_CONFIG 0x0100
  20. #define BCMA_CORE_PCIE2_EP_AXI_CONFIG 0x0104
  21. #define BCMA_CORE_PCIE2_RXDEBUG_STATUS0 0x0108
  22. #define BCMA_CORE_PCIE2_RXDEBUG_CONTROL0 0x010C
  23. #define BCMA_CORE_PCIE2_CONFIGINDADDR 0x0120
  24. #define BCMA_CORE_PCIE2_CONFIGINDDATA 0x0124
  25. #define BCMA_CORE_PCIE2_MDIOCONTROL 0x0128
  26. #define BCMA_CORE_PCIE2_MDIOWRDATA 0x012C
  27. #define BCMA_CORE_PCIE2_MDIORDDATA 0x0130
  28. #define BCMA_CORE_PCIE2_DATAINTF 0x0180
  29. #define BCMA_CORE_PCIE2_D2H_INTRLAZY_0 0x0188
  30. #define BCMA_CORE_PCIE2_H2D_INTRLAZY_0 0x018c
  31. #define BCMA_CORE_PCIE2_H2D_INTSTAT_0 0x0190
  32. #define BCMA_CORE_PCIE2_H2D_INTMASK_0 0x0194
  33. #define BCMA_CORE_PCIE2_D2H_INTSTAT_0 0x0198
  34. #define BCMA_CORE_PCIE2_D2H_INTMASK_0 0x019c
  35. #define BCMA_CORE_PCIE2_LTR_STATE 0x01A0 /* Latency Tolerance Reporting */
  36. #define PCIE2_LTR_ACTIVE 2
  37. #define PCIE2_LTR_ACTIVE_IDLE 1
  38. #define PCIE2_LTR_SLEEP 0
  39. #define PCIE2_LTR_FINAL_MASK 0x300
  40. #define PCIE2_LTR_FINAL_SHIFT 8
  41. #define BCMA_CORE_PCIE2_PWR_INT_STATUS 0x01A4
  42. #define BCMA_CORE_PCIE2_PWR_INT_MASK 0x01A8
  43. #define BCMA_CORE_PCIE2_CFG_ADDR 0x01F8
  44. #define BCMA_CORE_PCIE2_CFG_DATA 0x01FC
  45. #define BCMA_CORE_PCIE2_SYS_EQ_PAGE 0x0200
  46. #define BCMA_CORE_PCIE2_SYS_MSI_PAGE 0x0204
  47. #define BCMA_CORE_PCIE2_SYS_MSI_INTREN 0x0208
  48. #define BCMA_CORE_PCIE2_SYS_MSI_CTRL0 0x0210
  49. #define BCMA_CORE_PCIE2_SYS_MSI_CTRL1 0x0214
  50. #define BCMA_CORE_PCIE2_SYS_MSI_CTRL2 0x0218
  51. #define BCMA_CORE_PCIE2_SYS_MSI_CTRL3 0x021C
  52. #define BCMA_CORE_PCIE2_SYS_MSI_CTRL4 0x0220
  53. #define BCMA_CORE_PCIE2_SYS_MSI_CTRL5 0x0224
  54. #define BCMA_CORE_PCIE2_SYS_EQ_HEAD0 0x0250
  55. #define BCMA_CORE_PCIE2_SYS_EQ_TAIL0 0x0254
  56. #define BCMA_CORE_PCIE2_SYS_EQ_HEAD1 0x0258
  57. #define BCMA_CORE_PCIE2_SYS_EQ_TAIL1 0x025C
  58. #define BCMA_CORE_PCIE2_SYS_EQ_HEAD2 0x0260
  59. #define BCMA_CORE_PCIE2_SYS_EQ_TAIL2 0x0264
  60. #define BCMA_CORE_PCIE2_SYS_EQ_HEAD3 0x0268
  61. #define BCMA_CORE_PCIE2_SYS_EQ_TAIL3 0x026C
  62. #define BCMA_CORE_PCIE2_SYS_EQ_HEAD4 0x0270
  63. #define BCMA_CORE_PCIE2_SYS_EQ_TAIL4 0x0274
  64. #define BCMA_CORE_PCIE2_SYS_EQ_HEAD5 0x0278
  65. #define BCMA_CORE_PCIE2_SYS_EQ_TAIL5 0x027C
  66. #define BCMA_CORE_PCIE2_SYS_RC_INTX_EN 0x0330
  67. #define BCMA_CORE_PCIE2_SYS_RC_INTX_CSR 0x0334
  68. #define BCMA_CORE_PCIE2_SYS_MSI_REQ 0x0340
  69. #define BCMA_CORE_PCIE2_SYS_HOST_INTR_EN 0x0344
  70. #define BCMA_CORE_PCIE2_SYS_HOST_INTR_CSR 0x0348
  71. #define BCMA_CORE_PCIE2_SYS_HOST_INTR0 0x0350
  72. #define BCMA_CORE_PCIE2_SYS_HOST_INTR1 0x0354
  73. #define BCMA_CORE_PCIE2_SYS_HOST_INTR2 0x0358
  74. #define BCMA_CORE_PCIE2_SYS_HOST_INTR3 0x035C
  75. #define BCMA_CORE_PCIE2_SYS_EP_INT_EN0 0x0360
  76. #define BCMA_CORE_PCIE2_SYS_EP_INT_EN1 0x0364
  77. #define BCMA_CORE_PCIE2_SYS_EP_INT_CSR0 0x0370
  78. #define BCMA_CORE_PCIE2_SYS_EP_INT_CSR1 0x0374
  79. #define BCMA_CORE_PCIE2_SPROM(wordoffset) (0x0800 + ((wordoffset) * 2))
  80. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_0 0x0C00
  81. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_1 0x0C04
  82. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_2 0x0C08
  83. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_3 0x0C0C
  84. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_4 0x0C10
  85. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_5 0x0C14
  86. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_6 0x0C18
  87. #define BCMA_CORE_PCIE2_FUNC0_IMAP0_7 0x0C1C
  88. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_0 0x0C20
  89. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_1 0x0C24
  90. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_2 0x0C28
  91. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_3 0x0C2C
  92. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_4 0x0C30
  93. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_5 0x0C34
  94. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_6 0x0C38
  95. #define BCMA_CORE_PCIE2_FUNC1_IMAP0_7 0x0C3C
  96. #define BCMA_CORE_PCIE2_FUNC0_IMAP1 0x0C80
  97. #define BCMA_CORE_PCIE2_FUNC1_IMAP1 0x0C88
  98. #define BCMA_CORE_PCIE2_FUNC0_IMAP2 0x0CC0
  99. #define BCMA_CORE_PCIE2_FUNC1_IMAP2 0x0CC8
  100. #define BCMA_CORE_PCIE2_IARR0_LOWER 0x0D00
  101. #define BCMA_CORE_PCIE2_IARR0_UPPER 0x0D04
  102. #define BCMA_CORE_PCIE2_IARR1_LOWER 0x0D08
  103. #define BCMA_CORE_PCIE2_IARR1_UPPER 0x0D0C
  104. #define BCMA_CORE_PCIE2_IARR2_LOWER 0x0D10
  105. #define BCMA_CORE_PCIE2_IARR2_UPPER 0x0D14
  106. #define BCMA_CORE_PCIE2_OARR0 0x0D20
  107. #define BCMA_CORE_PCIE2_OARR1 0x0D28
  108. #define BCMA_CORE_PCIE2_OARR2 0x0D30
  109. #define BCMA_CORE_PCIE2_OMAP0_LOWER 0x0D40
  110. #define BCMA_CORE_PCIE2_OMAP0_UPPER 0x0D44
  111. #define BCMA_CORE_PCIE2_OMAP1_LOWER 0x0D48
  112. #define BCMA_CORE_PCIE2_OMAP1_UPPER 0x0D4C
  113. #define BCMA_CORE_PCIE2_OMAP2_LOWER 0x0D50
  114. #define BCMA_CORE_PCIE2_OMAP2_UPPER 0x0D54
  115. #define BCMA_CORE_PCIE2_FUNC1_IARR1_SIZE 0x0D58
  116. #define BCMA_CORE_PCIE2_FUNC1_IARR2_SIZE 0x0D5C
  117. #define BCMA_CORE_PCIE2_MEM_CONTROL 0x0F00
  118. #define BCMA_CORE_PCIE2_MEM_ECC_ERRLOG0 0x0F04
  119. #define BCMA_CORE_PCIE2_MEM_ECC_ERRLOG1 0x0F08
  120. #define BCMA_CORE_PCIE2_LINK_STATUS 0x0F0C
  121. #define BCMA_CORE_PCIE2_STRAP_STATUS 0x0F10
  122. #define BCMA_CORE_PCIE2_RESET_STATUS 0x0F14
  123. #define BCMA_CORE_PCIE2_RESETEN_IN_LINKDOWN 0x0F18
  124. #define BCMA_CORE_PCIE2_MISC_INTR_EN 0x0F1C
  125. #define BCMA_CORE_PCIE2_TX_DEBUG_CFG 0x0F20
  126. #define BCMA_CORE_PCIE2_MISC_CONFIG 0x0F24
  127. #define BCMA_CORE_PCIE2_MISC_STATUS 0x0F28
  128. #define BCMA_CORE_PCIE2_INTR_EN 0x0F30
  129. #define BCMA_CORE_PCIE2_INTR_CLEAR 0x0F34
  130. #define BCMA_CORE_PCIE2_INTR_STATUS 0x0F38
  131. /* PCIE gen2 config regs */
  132. #define PCIE2_INTSTATUS 0x090
  133. #define PCIE2_INTMASK 0x094
  134. #define PCIE2_SBMBX 0x098
  135. #define PCIE2_PMCR_REFUP 0x1814 /* Trefup time */
  136. #define PCIE2_CAP_DEVSTSCTRL2_OFFSET 0xD4
  137. #define PCIE2_CAP_DEVSTSCTRL2_LTRENAB 0x400
  138. #define PCIE2_PVT_REG_PM_CLK_PERIOD 0x184c
  139. struct bcma_drv_pcie2 {
  140. struct bcma_device *core;
  141. };
  142. #define pcie2_read16(pcie2, offset) bcma_read16((pcie2)->core, offset)
  143. #define pcie2_read32(pcie2, offset) bcma_read32((pcie2)->core, offset)
  144. #define pcie2_write16(pcie2, offset, val) bcma_write16((pcie2)->core, offset, val)
  145. #define pcie2_write32(pcie2, offset, val) bcma_write32((pcie2)->core, offset, val)
  146. #define pcie2_set32(pcie2, offset, set) bcma_set32((pcie2)->core, offset, set)
  147. #define pcie2_mask32(pcie2, offset, mask) bcma_mask32((pcie2)->core, offset, mask)
  148. void bcma_core_pcie2_init(struct bcma_drv_pcie2 *pcie2);
  149. #endif /* LINUX_BCMA_DRIVER_PCIE2_H_ */