designware.h 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. /*
  2. * (C) Copyright 2010
  3. * Vipin Kumar, ST Micoelectronics, vipin.kumar@st.com.
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef _DW_ETH_H
  8. #define _DW_ETH_H
  9. #define CONFIG_TX_DESCR_NUM 16
  10. #define CONFIG_RX_DESCR_NUM 16
  11. #define CONFIG_ETH_BUFSIZE 2048
  12. #define TX_TOTAL_BUFSIZE (CONFIG_ETH_BUFSIZE * CONFIG_TX_DESCR_NUM)
  13. #define RX_TOTAL_BUFSIZE (CONFIG_ETH_BUFSIZE * CONFIG_RX_DESCR_NUM)
  14. #define CONFIG_MACRESET_TIMEOUT (3 * CONFIG_SYS_HZ)
  15. #define CONFIG_MDIO_TIMEOUT (3 * CONFIG_SYS_HZ)
  16. struct eth_mac_regs {
  17. u32 conf; /* 0x00 */
  18. u32 framefilt; /* 0x04 */
  19. u32 hashtablehigh; /* 0x08 */
  20. u32 hashtablelow; /* 0x0c */
  21. u32 miiaddr; /* 0x10 */
  22. u32 miidata; /* 0x14 */
  23. u32 flowcontrol; /* 0x18 */
  24. u32 vlantag; /* 0x1c */
  25. u32 version; /* 0x20 */
  26. u8 reserved_1[20];
  27. u32 intreg; /* 0x38 */
  28. u32 intmask; /* 0x3c */
  29. u32 macaddr0hi; /* 0x40 */
  30. u32 macaddr0lo; /* 0x44 */
  31. };
  32. /* MAC configuration register definitions */
  33. #define FRAMEBURSTENABLE (1 << 21)
  34. #define MII_PORTSELECT (1 << 15)
  35. #define FES_100 (1 << 14)
  36. #define DISABLERXOWN (1 << 13)
  37. #define FULLDPLXMODE (1 << 11)
  38. #define RXENABLE (1 << 2)
  39. #define TXENABLE (1 << 3)
  40. /* MII address register definitions */
  41. #define MII_BUSY (1 << 0)
  42. #define MII_WRITE (1 << 1)
  43. #define MII_CLKRANGE_60_100M (0)
  44. #define MII_CLKRANGE_100_150M (0x4)
  45. #define MII_CLKRANGE_20_35M (0x8)
  46. #define MII_CLKRANGE_35_60M (0xC)
  47. #define MII_CLKRANGE_150_250M (0x10)
  48. #define MII_CLKRANGE_250_300M (0x14)
  49. #define MIIADDRSHIFT (11)
  50. #define MIIREGSHIFT (6)
  51. #define MII_REGMSK (0x1F << 6)
  52. #define MII_ADDRMSK (0x1F << 11)
  53. struct eth_dma_regs {
  54. u32 busmode; /* 0x00 */
  55. u32 txpolldemand; /* 0x04 */
  56. u32 rxpolldemand; /* 0x08 */
  57. u32 rxdesclistaddr; /* 0x0c */
  58. u32 txdesclistaddr; /* 0x10 */
  59. u32 status; /* 0x14 */
  60. u32 opmode; /* 0x18 */
  61. u32 intenable; /* 0x1c */
  62. u32 reserved1[2];
  63. u32 axibus; /* 0x28 */
  64. u32 reserved2[7];
  65. u32 currhosttxdesc; /* 0x48 */
  66. u32 currhostrxdesc; /* 0x4c */
  67. u32 currhosttxbuffaddr; /* 0x50 */
  68. u32 currhostrxbuffaddr; /* 0x54 */
  69. };
  70. #define DW_DMA_BASE_OFFSET (0x1000)
  71. /* Default DMA Burst length */
  72. #ifndef CONFIG_DW_GMAC_DEFAULT_DMA_PBL
  73. #define CONFIG_DW_GMAC_DEFAULT_DMA_PBL 8
  74. #endif
  75. /* Bus mode register definitions */
  76. #define FIXEDBURST (1 << 16)
  77. #define PRIORXTX_41 (3 << 14)
  78. #define PRIORXTX_31 (2 << 14)
  79. #define PRIORXTX_21 (1 << 14)
  80. #define PRIORXTX_11 (0 << 14)
  81. #define DMA_PBL (CONFIG_DW_GMAC_DEFAULT_DMA_PBL<<8)
  82. #define RXHIGHPRIO (1 << 1)
  83. #define DMAMAC_SRST (1 << 0)
  84. /* Poll demand definitions */
  85. #define POLL_DATA (0xFFFFFFFF)
  86. /* Operation mode definitions */
  87. #define STOREFORWARD (1 << 21)
  88. #define FLUSHTXFIFO (1 << 20)
  89. #define TXSTART (1 << 13)
  90. #define TXSECONDFRAME (1 << 2)
  91. #define RXSTART (1 << 1)
  92. /* Descriptior related definitions */
  93. #define MAC_MAX_FRAME_SZ (1600)
  94. struct dmamacdescr {
  95. u32 txrx_status;
  96. u32 dmamac_cntl;
  97. void *dmamac_addr;
  98. struct dmamacdescr *dmamac_next;
  99. } __aligned(ARCH_DMA_MINALIGN);
  100. /*
  101. * txrx_status definitions
  102. */
  103. /* tx status bits definitions */
  104. #if defined(CONFIG_DW_ALTDESCRIPTOR)
  105. #define DESC_TXSTS_OWNBYDMA (1 << 31)
  106. #define DESC_TXSTS_TXINT (1 << 30)
  107. #define DESC_TXSTS_TXLAST (1 << 29)
  108. #define DESC_TXSTS_TXFIRST (1 << 28)
  109. #define DESC_TXSTS_TXCRCDIS (1 << 27)
  110. #define DESC_TXSTS_TXPADDIS (1 << 26)
  111. #define DESC_TXSTS_TXCHECKINSCTRL (3 << 22)
  112. #define DESC_TXSTS_TXRINGEND (1 << 21)
  113. #define DESC_TXSTS_TXCHAIN (1 << 20)
  114. #define DESC_TXSTS_MSK (0x1FFFF << 0)
  115. #else
  116. #define DESC_TXSTS_OWNBYDMA (1 << 31)
  117. #define DESC_TXSTS_MSK (0x1FFFF << 0)
  118. #endif
  119. /* rx status bits definitions */
  120. #define DESC_RXSTS_OWNBYDMA (1 << 31)
  121. #define DESC_RXSTS_DAFILTERFAIL (1 << 30)
  122. #define DESC_RXSTS_FRMLENMSK (0x3FFF << 16)
  123. #define DESC_RXSTS_FRMLENSHFT (16)
  124. #define DESC_RXSTS_ERROR (1 << 15)
  125. #define DESC_RXSTS_RXTRUNCATED (1 << 14)
  126. #define DESC_RXSTS_SAFILTERFAIL (1 << 13)
  127. #define DESC_RXSTS_RXIPC_GIANTFRAME (1 << 12)
  128. #define DESC_RXSTS_RXDAMAGED (1 << 11)
  129. #define DESC_RXSTS_RXVLANTAG (1 << 10)
  130. #define DESC_RXSTS_RXFIRST (1 << 9)
  131. #define DESC_RXSTS_RXLAST (1 << 8)
  132. #define DESC_RXSTS_RXIPC_GIANT (1 << 7)
  133. #define DESC_RXSTS_RXCOLLISION (1 << 6)
  134. #define DESC_RXSTS_RXFRAMEETHER (1 << 5)
  135. #define DESC_RXSTS_RXWATCHDOG (1 << 4)
  136. #define DESC_RXSTS_RXMIIERROR (1 << 3)
  137. #define DESC_RXSTS_RXDRIBBLING (1 << 2)
  138. #define DESC_RXSTS_RXCRC (1 << 1)
  139. /*
  140. * dmamac_cntl definitions
  141. */
  142. /* tx control bits definitions */
  143. #if defined(CONFIG_DW_ALTDESCRIPTOR)
  144. #define DESC_TXCTRL_SIZE1MASK (0x1FFF << 0)
  145. #define DESC_TXCTRL_SIZE1SHFT (0)
  146. #define DESC_TXCTRL_SIZE2MASK (0x1FFF << 16)
  147. #define DESC_TXCTRL_SIZE2SHFT (16)
  148. #else
  149. #define DESC_TXCTRL_TXINT (1 << 31)
  150. #define DESC_TXCTRL_TXLAST (1 << 30)
  151. #define DESC_TXCTRL_TXFIRST (1 << 29)
  152. #define DESC_TXCTRL_TXCHECKINSCTRL (3 << 27)
  153. #define DESC_TXCTRL_TXCRCDIS (1 << 26)
  154. #define DESC_TXCTRL_TXRINGEND (1 << 25)
  155. #define DESC_TXCTRL_TXCHAIN (1 << 24)
  156. #define DESC_TXCTRL_SIZE1MASK (0x7FF << 0)
  157. #define DESC_TXCTRL_SIZE1SHFT (0)
  158. #define DESC_TXCTRL_SIZE2MASK (0x7FF << 11)
  159. #define DESC_TXCTRL_SIZE2SHFT (11)
  160. #endif
  161. /* rx control bits definitions */
  162. #if defined(CONFIG_DW_ALTDESCRIPTOR)
  163. #define DESC_RXCTRL_RXINTDIS (1 << 31)
  164. #define DESC_RXCTRL_RXRINGEND (1 << 15)
  165. #define DESC_RXCTRL_RXCHAIN (1 << 14)
  166. #define DESC_RXCTRL_SIZE1MASK (0x1FFF << 0)
  167. #define DESC_RXCTRL_SIZE1SHFT (0)
  168. #define DESC_RXCTRL_SIZE2MASK (0x1FFF << 16)
  169. #define DESC_RXCTRL_SIZE2SHFT (16)
  170. #else
  171. #define DESC_RXCTRL_RXINTDIS (1 << 31)
  172. #define DESC_RXCTRL_RXRINGEND (1 << 25)
  173. #define DESC_RXCTRL_RXCHAIN (1 << 24)
  174. #define DESC_RXCTRL_SIZE1MASK (0x7FF << 0)
  175. #define DESC_RXCTRL_SIZE1SHFT (0)
  176. #define DESC_RXCTRL_SIZE2MASK (0x7FF << 11)
  177. #define DESC_RXCTRL_SIZE2SHFT (11)
  178. #endif
  179. struct dw_eth_dev {
  180. struct dmamacdescr tx_mac_descrtable[CONFIG_TX_DESCR_NUM];
  181. struct dmamacdescr rx_mac_descrtable[CONFIG_RX_DESCR_NUM];
  182. char txbuffs[TX_TOTAL_BUFSIZE] __aligned(ARCH_DMA_MINALIGN);
  183. char rxbuffs[RX_TOTAL_BUFSIZE] __aligned(ARCH_DMA_MINALIGN);
  184. u32 interface;
  185. u32 tx_currdescnum;
  186. u32 rx_currdescnum;
  187. struct eth_mac_regs *mac_regs_p;
  188. struct eth_dma_regs *dma_regs_p;
  189. #ifndef CONFIG_DM_ETH
  190. struct eth_device *dev;
  191. #endif
  192. struct phy_device *phydev;
  193. struct mii_dev *bus;
  194. };
  195. #endif