bcm-sf2-eth-gmac.h 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /*
  2. * Copyright 2014 Broadcom Corporation.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #ifndef _BCM_SF2_ETH_GMAC_H_
  7. #define _BCM_SF2_ETH_GMAC_H_
  8. #define BCM_SF2_ETH_MAC_NAME "gmac"
  9. #ifndef ETHHW_PORT_INT
  10. #define ETHHW_PORT_INT 8
  11. #endif
  12. #define GMAC0_REG_BASE 0x18042000
  13. #define GMAC0_DEV_CTRL_ADDR GMAC0_REG_BASE
  14. #define GMAC0_INT_STATUS_ADDR (GMAC0_REG_BASE + 0x020)
  15. #define GMAC0_INTR_RECV_LAZY_ADDR (GMAC0_REG_BASE + 0x100)
  16. #define GMAC0_PHY_CTRL_ADDR (GMAC0_REG_BASE + 0x188)
  17. #define GMAC_DMA_PTR_OFFSET 0x04
  18. #define GMAC_DMA_ADDR_LOW_OFFSET 0x08
  19. #define GMAC_DMA_ADDR_HIGH_OFFSET 0x0c
  20. #define GMAC_DMA_STATUS0_OFFSET 0x10
  21. #define GMAC_DMA_STATUS1_OFFSET 0x14
  22. #define GMAC0_DMA_TX_CTRL_ADDR (GMAC0_REG_BASE + 0x200)
  23. #define GMAC0_DMA_TX_PTR_ADDR \
  24. (GMAC0_DMA_TX_CTRL_ADDR + GMAC_DMA_PTR_OFFSET)
  25. #define GMAC0_DMA_TX_ADDR_LOW_ADDR \
  26. (GMAC0_DMA_TX_CTRL_ADDR + GMAC_DMA_ADDR_LOW_OFFSET)
  27. #define GMAC0_DMA_TX_ADDR_HIGH_ADDR \
  28. (GMAC0_DMA_TX_CTRL_ADDR + GMAC_DMA_ADDR_HIGH_OFFSET)
  29. #define GMAC0_DMA_TX_STATUS0_ADDR \
  30. (GMAC0_DMA_TX_CTRL_ADDR + GMAC_DMA_STATUS0_OFFSET)
  31. #define GMAC0_DMA_TX_STATUS1_ADDR \
  32. (GMAC0_DMA_TX_CTRL_ADDR + GMAC_DMA_STATUS1_OFFSET)
  33. #define GMAC0_DMA_RX_CTRL_ADDR (GMAC0_REG_BASE + 0x220)
  34. #define GMAC0_DMA_RX_PTR_ADDR \
  35. (GMAC0_DMA_RX_CTRL_ADDR + GMAC_DMA_PTR_OFFSET)
  36. #define GMAC0_DMA_RX_ADDR_LOW_ADDR \
  37. (GMAC0_DMA_RX_CTRL_ADDR + GMAC_DMA_ADDR_LOW_OFFSET)
  38. #define GMAC0_DMA_RX_ADDR_HIGH_ADDR \
  39. (GMAC0_DMA_RX_CTRL_ADDR + GMAC_DMA_ADDR_HIGH_OFFSET)
  40. #define GMAC0_DMA_RX_STATUS0_ADDR \
  41. (GMAC0_DMA_RX_CTRL_ADDR + GMAC_DMA_STATUS0_OFFSET)
  42. #define GMAC0_DMA_RX_STATUS1_ADDR \
  43. (GMAC0_DMA_RX_CTRL_ADDR + GMAC_DMA_STATUS1_OFFSET)
  44. #define UNIMAC0_CMD_CFG_ADDR (GMAC0_REG_BASE + 0x808)
  45. #define UNIMAC0_MAC_MSB_ADDR (GMAC0_REG_BASE + 0x80c)
  46. #define UNIMAC0_MAC_LSB_ADDR (GMAC0_REG_BASE + 0x810)
  47. #define UNIMAC0_FRM_LENGTH_ADDR (GMAC0_REG_BASE + 0x814)
  48. #define GMAC0_IRL_FRAMECOUNT_SHIFT 24
  49. /* transmit channel control */
  50. /* transmit enable */
  51. #define D64_XC_XE 0x00000001
  52. /* transmit suspend request */
  53. #define D64_XC_SE 0x00000002
  54. /* parity check disable */
  55. #define D64_XC_PD 0x00000800
  56. /* BurstLen bits */
  57. #define D64_XC_BL_MASK 0x001C0000
  58. #define D64_XC_BL_SHIFT 18
  59. /* transmit descriptor table pointer */
  60. /* last valid descriptor */
  61. #define D64_XP_LD_MASK 0x00001fff
  62. /* transmit channel status */
  63. /* transmit state */
  64. #define D64_XS0_XS_MASK 0xf0000000
  65. #define D64_XS0_XS_SHIFT 28
  66. #define D64_XS0_XS_DISABLED 0x00000000
  67. #define D64_XS0_XS_ACTIVE 0x10000000
  68. #define D64_XS0_XS_IDLE 0x20000000
  69. #define D64_XS0_XS_STOPPED 0x30000000
  70. #define D64_XS0_XS_SUSP 0x40000000
  71. /* receive channel control */
  72. /* receive enable */
  73. #define D64_RC_RE 0x00000001
  74. /* address extension bits */
  75. #define D64_RC_AE 0x00030000
  76. /* overflow continue */
  77. #define D64_RC_OC 0x00000400
  78. /* parity check disable */
  79. #define D64_RC_PD 0x00000800
  80. /* receive frame offset */
  81. #define D64_RC_RO_MASK 0x000000fe
  82. #define D64_RC_RO_SHIFT 1
  83. /* BurstLen bits */
  84. #define D64_RC_BL_MASK 0x001C0000
  85. #define D64_RC_BL_SHIFT 18
  86. /* flags for dma controller */
  87. /* partity enable */
  88. #define DMA_CTRL_PEN (1 << 0)
  89. /* rx overflow continue */
  90. #define DMA_CTRL_ROC (1 << 1)
  91. /* receive descriptor table pointer */
  92. /* last valid descriptor */
  93. #define D64_RP_LD_MASK 0x00001fff
  94. /* receive channel status */
  95. /* current descriptor pointer */
  96. #define D64_RS0_CD_MASK 0x00001fff
  97. /* receive state */
  98. #define D64_RS0_RS_MASK 0xf0000000
  99. #define D64_RS0_RS_SHIFT 28
  100. #define D64_RS0_RS_DISABLED 0x00000000
  101. #define D64_RS0_RS_ACTIVE 0x10000000
  102. #define D64_RS0_RS_IDLE 0x20000000
  103. #define D64_RS0_RS_STOPPED 0x30000000
  104. #define D64_RS0_RS_SUSP 0x40000000
  105. /* descriptor control flags 1 */
  106. /* core specific flags */
  107. #define D64_CTRL_COREFLAGS 0x0ff00000
  108. /* end of descriptor table */
  109. #define D64_CTRL1_EOT ((uint32_t)1 << 28)
  110. /* interrupt on completion */
  111. #define D64_CTRL1_IOC ((uint32_t)1 << 29)
  112. /* end of frame */
  113. #define D64_CTRL1_EOF ((uint32_t)1 << 30)
  114. /* start of frame */
  115. #define D64_CTRL1_SOF ((uint32_t)1 << 31)
  116. /* descriptor control flags 2 */
  117. /* buffer byte count. real data len must <= 16KB */
  118. #define D64_CTRL2_BC_MASK 0x00007fff
  119. /* address extension bits */
  120. #define D64_CTRL2_AE 0x00030000
  121. #define D64_CTRL2_AE_SHIFT 16
  122. /* parity bit */
  123. #define D64_CTRL2_PARITY 0x00040000
  124. /* control flags in the range [27:20] are core-specific and not defined here */
  125. #define D64_CTRL_CORE_MASK 0x0ff00000
  126. #define DC_MROR 0x00000010
  127. #define PC_MTE 0x00800000
  128. /* command config */
  129. #define CC_TE 0x00000001
  130. #define CC_RE 0x00000002
  131. #define CC_ES_MASK 0x0000000c
  132. #define CC_ES_SHIFT 2
  133. #define CC_PROM 0x00000010
  134. #define CC_PAD_EN 0x00000020
  135. #define CC_CF 0x00000040
  136. #define CC_PF 0x00000080
  137. #define CC_RPI 0x00000100
  138. #define CC_TAI 0x00000200
  139. #define CC_HD 0x00000400
  140. #define CC_HD_SHIFT 10
  141. #define CC_SR 0x00002000
  142. #define CC_ML 0x00008000
  143. #define CC_AE 0x00400000
  144. #define CC_CFE 0x00800000
  145. #define CC_NLC 0x01000000
  146. #define CC_RL 0x02000000
  147. #define CC_RED 0x04000000
  148. #define CC_PE 0x08000000
  149. #define CC_TPI 0x10000000
  150. #define CC_AT 0x20000000
  151. #define I_PDEE 0x00000400
  152. #define I_PDE 0x00000800
  153. #define I_DE 0x00001000
  154. #define I_RDU 0x00002000
  155. #define I_RFO 0x00004000
  156. #define I_XFU 0x00008000
  157. #define I_RI 0x00010000
  158. #define I_XI0 0x01000000
  159. #define I_XI1 0x02000000
  160. #define I_XI2 0x04000000
  161. #define I_XI3 0x08000000
  162. #define I_ERRORS (I_PDEE | I_PDE | I_DE | I_RDU | I_RFO | I_XFU)
  163. #define DEF_INTMASK (I_XI0 | I_XI1 | I_XI2 | I_XI3 | I_RI | I_ERRORS)
  164. #define I_INTMASK 0x0f01fcff
  165. #define CHIP_DRU_BASE 0x0301d000
  166. #define CRMU_CHIP_IO_PAD_CONTROL_ADDR (CHIP_DRU_BASE + 0x0bc)
  167. #define SWITCH_GLOBAL_CONFIG_ADDR (CHIP_DRU_BASE + 0x194)
  168. #define CDRU_IOMUX_FORCE_PAD_IN_SHIFT 0
  169. #define CDRU_SWITCH_BYPASS_SWITCH_SHIFT 13
  170. #define AMAC0_IDM_RESET_ADDR 0x18110800
  171. #define AMAC0_IO_CTRL_DIRECT_ADDR 0x18110408
  172. #define AMAC0_IO_CTRL_CLK_250_SEL_SHIFT 6
  173. #define AMAC0_IO_CTRL_GMII_MODE_SHIFT 5
  174. #define AMAC0_IO_CTRL_DEST_SYNC_MODE_EN_SHIFT 3
  175. #define CHIPA_CHIP_ID_ADDR 0x18000000
  176. #define CHIPID (readl(CHIPA_CHIP_ID_ADDR) & 0xFFFF)
  177. #define CHIPREV (((readl(CHIPA_CHIP_ID_ADDR) >> 16) & 0xF)
  178. #define CHIPSKU (((readl(CHIPA_CHIP_ID_ADDR) >> 20) & 0xF)
  179. #define GMAC_MII_CTRL_ADDR 0x18002000
  180. #define GMAC_MII_CTRL_BYP_SHIFT 10
  181. #define GMAC_MII_CTRL_EXT_SHIFT 9
  182. #define GMAC_MII_DATA_ADDR 0x18002004
  183. #define GMAC_MII_DATA_READ_CMD 0x60020000
  184. #define GMAC_MII_DATA_WRITE_CMD 0x50020000
  185. #define GMAC_MII_BUSY_SHIFT 8
  186. #define GMAC_MII_PHY_ADDR_SHIFT 23
  187. #define GMAC_MII_PHY_REG_SHIFT 18
  188. #define GMAC_RESET_DELAY 2
  189. #define HWRXOFF 30
  190. #define MAXNAMEL 8
  191. #define NUMTXQ 4
  192. int gmac_add(struct eth_device *dev);
  193. #endif /* _BCM_SF2_ETH_GMAC_H_ */