descs.h 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*******************************************************************************
  3. Header File to describe the DMA descriptors and related definitions.
  4. This is for DWMAC100 and 1000 cores.
  5. Author: Giuseppe Cavallaro <[email protected]>
  6. *******************************************************************************/
  7. #ifndef __DESCS_H__
  8. #define __DESCS_H__
  9. #include <linux/bitops.h>
  10. /* Normal receive descriptor defines */
  11. /* RDES0 */
  12. #define RDES0_PAYLOAD_CSUM_ERR BIT(0)
  13. #define RDES0_CRC_ERROR BIT(1)
  14. #define RDES0_DRIBBLING BIT(2)
  15. #define RDES0_MII_ERROR BIT(3)
  16. #define RDES0_RECEIVE_WATCHDOG BIT(4)
  17. #define RDES0_FRAME_TYPE BIT(5)
  18. #define RDES0_COLLISION BIT(6)
  19. #define RDES0_IPC_CSUM_ERROR BIT(7)
  20. #define RDES0_LAST_DESCRIPTOR BIT(8)
  21. #define RDES0_FIRST_DESCRIPTOR BIT(9)
  22. #define RDES0_VLAN_TAG BIT(10)
  23. #define RDES0_OVERFLOW_ERROR BIT(11)
  24. #define RDES0_LENGTH_ERROR BIT(12)
  25. #define RDES0_SA_FILTER_FAIL BIT(13)
  26. #define RDES0_DESCRIPTOR_ERROR BIT(14)
  27. #define RDES0_ERROR_SUMMARY BIT(15)
  28. #define RDES0_FRAME_LEN_MASK GENMASK(29, 16)
  29. #define RDES0_FRAME_LEN_SHIFT 16
  30. #define RDES0_DA_FILTER_FAIL BIT(30)
  31. #define RDES0_OWN BIT(31)
  32. /* RDES1 */
  33. #define RDES1_BUFFER1_SIZE_MASK GENMASK(10, 0)
  34. #define RDES1_BUFFER2_SIZE_MASK GENMASK(21, 11)
  35. #define RDES1_BUFFER2_SIZE_SHIFT 11
  36. #define RDES1_SECOND_ADDRESS_CHAINED BIT(24)
  37. #define RDES1_END_RING BIT(25)
  38. #define RDES1_DISABLE_IC BIT(31)
  39. /* Enhanced receive descriptor defines */
  40. /* RDES0 (similar to normal RDES) */
  41. #define ERDES0_RX_MAC_ADDR BIT(0)
  42. /* RDES1: completely differ from normal desc definitions */
  43. #define ERDES1_BUFFER1_SIZE_MASK GENMASK(12, 0)
  44. #define ERDES1_SECOND_ADDRESS_CHAINED BIT(14)
  45. #define ERDES1_END_RING BIT(15)
  46. #define ERDES1_BUFFER2_SIZE_MASK GENMASK(28, 16)
  47. #define ERDES1_BUFFER2_SIZE_SHIFT 16
  48. #define ERDES1_DISABLE_IC BIT(31)
  49. /* Normal transmit descriptor defines */
  50. /* TDES0 */
  51. #define TDES0_DEFERRED BIT(0)
  52. #define TDES0_UNDERFLOW_ERROR BIT(1)
  53. #define TDES0_EXCESSIVE_DEFERRAL BIT(2)
  54. #define TDES0_COLLISION_COUNT_MASK GENMASK(6, 3)
  55. #define TDES0_VLAN_FRAME BIT(7)
  56. #define TDES0_EXCESSIVE_COLLISIONS BIT(8)
  57. #define TDES0_LATE_COLLISION BIT(9)
  58. #define TDES0_NO_CARRIER BIT(10)
  59. #define TDES0_LOSS_CARRIER BIT(11)
  60. #define TDES0_PAYLOAD_ERROR BIT(12)
  61. #define TDES0_FRAME_FLUSHED BIT(13)
  62. #define TDES0_JABBER_TIMEOUT BIT(14)
  63. #define TDES0_ERROR_SUMMARY BIT(15)
  64. #define TDES0_IP_HEADER_ERROR BIT(16)
  65. #define TDES0_TIME_STAMP_STATUS BIT(17)
  66. #define TDES0_OWN ((u32)BIT(31)) /* silence sparse */
  67. /* TDES1 */
  68. #define TDES1_BUFFER1_SIZE_MASK GENMASK(10, 0)
  69. #define TDES1_BUFFER2_SIZE_MASK GENMASK(21, 11)
  70. #define TDES1_BUFFER2_SIZE_SHIFT 11
  71. #define TDES1_TIME_STAMP_ENABLE BIT(22)
  72. #define TDES1_DISABLE_PADDING BIT(23)
  73. #define TDES1_SECOND_ADDRESS_CHAINED BIT(24)
  74. #define TDES1_END_RING BIT(25)
  75. #define TDES1_CRC_DISABLE BIT(26)
  76. #define TDES1_CHECKSUM_INSERTION_MASK GENMASK(28, 27)
  77. #define TDES1_CHECKSUM_INSERTION_SHIFT 27
  78. #define TDES1_FIRST_SEGMENT BIT(29)
  79. #define TDES1_LAST_SEGMENT BIT(30)
  80. #define TDES1_INTERRUPT BIT(31)
  81. /* Enhanced transmit descriptor defines */
  82. /* TDES0 */
  83. #define ETDES0_DEFERRED BIT(0)
  84. #define ETDES0_UNDERFLOW_ERROR BIT(1)
  85. #define ETDES0_EXCESSIVE_DEFERRAL BIT(2)
  86. #define ETDES0_COLLISION_COUNT_MASK GENMASK(6, 3)
  87. #define ETDES0_VLAN_FRAME BIT(7)
  88. #define ETDES0_EXCESSIVE_COLLISIONS BIT(8)
  89. #define ETDES0_LATE_COLLISION BIT(9)
  90. #define ETDES0_NO_CARRIER BIT(10)
  91. #define ETDES0_LOSS_CARRIER BIT(11)
  92. #define ETDES0_PAYLOAD_ERROR BIT(12)
  93. #define ETDES0_FRAME_FLUSHED BIT(13)
  94. #define ETDES0_JABBER_TIMEOUT BIT(14)
  95. #define ETDES0_ERROR_SUMMARY BIT(15)
  96. #define ETDES0_IP_HEADER_ERROR BIT(16)
  97. #define ETDES0_TIME_STAMP_STATUS BIT(17)
  98. #define ETDES0_SECOND_ADDRESS_CHAINED BIT(20)
  99. #define ETDES0_END_RING BIT(21)
  100. #define ETDES0_CHECKSUM_INSERTION_MASK GENMASK(23, 22)
  101. #define ETDES0_CHECKSUM_INSERTION_SHIFT 22
  102. #define ETDES0_TIME_STAMP_ENABLE BIT(25)
  103. #define ETDES0_DISABLE_PADDING BIT(26)
  104. #define ETDES0_CRC_DISABLE BIT(27)
  105. #define ETDES0_FIRST_SEGMENT BIT(28)
  106. #define ETDES0_LAST_SEGMENT BIT(29)
  107. #define ETDES0_INTERRUPT BIT(30)
  108. #define ETDES0_OWN ((u32)BIT(31)) /* silence sparse */
  109. /* TDES1 */
  110. #define ETDES1_BUFFER1_SIZE_MASK GENMASK(12, 0)
  111. #define ETDES1_BUFFER2_SIZE_MASK GENMASK(28, 16)
  112. #define ETDES1_BUFFER2_SIZE_SHIFT 16
  113. /* Extended Receive descriptor definitions */
  114. #define ERDES4_IP_PAYLOAD_TYPE_MASK GENMASK(6, 2)
  115. #define ERDES4_IP_HDR_ERR BIT(3)
  116. #define ERDES4_IP_PAYLOAD_ERR BIT(4)
  117. #define ERDES4_IP_CSUM_BYPASSED BIT(5)
  118. #define ERDES4_IPV4_PKT_RCVD BIT(6)
  119. #define ERDES4_IPV6_PKT_RCVD BIT(7)
  120. #define ERDES4_MSG_TYPE_MASK GENMASK(11, 8)
  121. #define ERDES4_PTP_FRAME_TYPE BIT(12)
  122. #define ERDES4_PTP_VER BIT(13)
  123. #define ERDES4_TIMESTAMP_DROPPED BIT(14)
  124. #define ERDES4_AV_PKT_RCVD BIT(16)
  125. #define ERDES4_AV_TAGGED_PKT_RCVD BIT(17)
  126. #define ERDES4_VLAN_TAG_PRI_VAL_MASK GENMASK(20, 18)
  127. #define ERDES4_L3_FILTER_MATCH BIT(24)
  128. #define ERDES4_L4_FILTER_MATCH BIT(25)
  129. #define ERDES4_L3_L4_FILT_NO_MATCH_MASK GENMASK(27, 26)
  130. /* Extended RDES4 message type definitions */
  131. #define RDES_EXT_NO_PTP 0x0
  132. #define RDES_EXT_SYNC 0x1
  133. #define RDES_EXT_FOLLOW_UP 0x2
  134. #define RDES_EXT_DELAY_REQ 0x3
  135. #define RDES_EXT_DELAY_RESP 0x4
  136. #define RDES_EXT_PDELAY_REQ 0x5
  137. #define RDES_EXT_PDELAY_RESP 0x6
  138. #define RDES_EXT_PDELAY_FOLLOW_UP 0x7
  139. #define RDES_PTP_ANNOUNCE 0x8
  140. #define RDES_PTP_MANAGEMENT 0x9
  141. #define RDES_PTP_SIGNALING 0xa
  142. #define RDES_PTP_PKT_RESERVED_TYPE 0xf
  143. /* Basic descriptor structure for normal and alternate descriptors */
  144. struct dma_desc {
  145. __le32 des0;
  146. __le32 des1;
  147. __le32 des2;
  148. __le32 des3;
  149. };
  150. /* Extended descriptor structure (e.g. >= databook 3.50a) */
  151. struct dma_extended_desc {
  152. struct dma_desc basic; /* Basic descriptors */
  153. __le32 des4; /* Extended Status */
  154. __le32 des5; /* Reserved */
  155. __le32 des6; /* Tx/Rx Timestamp Low */
  156. __le32 des7; /* Tx/Rx Timestamp High */
  157. };
  158. /* Enhanced descriptor for TBS */
  159. struct dma_edesc {
  160. __le32 des4;
  161. __le32 des5;
  162. __le32 des6;
  163. __le32 des7;
  164. struct dma_desc basic;
  165. };
  166. /* Transmit checksum insertion control */
  167. #define TX_CIC_FULL 3 /* Include IP header and pseudoheader */
  168. #endif /* __DESCS_H__ */