xref: /dpdk/drivers/net/ngbe/ngbe_rxtx.h (revision 3eba2f2888a31dc275d37203c9d03e23604822ea)
143b7e5eaSJiawen Wu /* SPDX-License-Identifier: BSD-3-Clause
243b7e5eaSJiawen Wu  * Copyright(c) 2018-2021 Beijing WangXun Technology Co., Ltd.
343b7e5eaSJiawen Wu  * Copyright(c) 2010-2017 Intel Corporation
443b7e5eaSJiawen Wu  */
543b7e5eaSJiawen Wu 
643b7e5eaSJiawen Wu #ifndef _NGBE_RXTX_H_
743b7e5eaSJiawen Wu #define _NGBE_RXTX_H_
843b7e5eaSJiawen Wu 
943b7e5eaSJiawen Wu /*****************************************************************************
1043b7e5eaSJiawen Wu  * Receive Descriptor
1143b7e5eaSJiawen Wu  *****************************************************************************/
1243b7e5eaSJiawen Wu struct ngbe_rx_desc {
1343b7e5eaSJiawen Wu 	struct {
1443b7e5eaSJiawen Wu 		union {
1543b7e5eaSJiawen Wu 			rte_le32_t dw0;
1643b7e5eaSJiawen Wu 			struct {
1743b7e5eaSJiawen Wu 				rte_le16_t pkt;
1843b7e5eaSJiawen Wu 				rte_le16_t hdr;
1943b7e5eaSJiawen Wu 			} lo;
2043b7e5eaSJiawen Wu 		};
2143b7e5eaSJiawen Wu 		union {
2243b7e5eaSJiawen Wu 			rte_le32_t dw1;
2343b7e5eaSJiawen Wu 			struct {
2443b7e5eaSJiawen Wu 				rte_le16_t ipid;
2543b7e5eaSJiawen Wu 				rte_le16_t csum;
2643b7e5eaSJiawen Wu 			} hi;
2743b7e5eaSJiawen Wu 		};
2843b7e5eaSJiawen Wu 	} qw0; /* also as r.pkt_addr */
2943b7e5eaSJiawen Wu 	struct {
3043b7e5eaSJiawen Wu 		union {
3143b7e5eaSJiawen Wu 			rte_le32_t dw2;
3243b7e5eaSJiawen Wu 			struct {
3343b7e5eaSJiawen Wu 				rte_le32_t status;
3443b7e5eaSJiawen Wu 			} lo;
3543b7e5eaSJiawen Wu 		};
3643b7e5eaSJiawen Wu 		union {
3743b7e5eaSJiawen Wu 			rte_le32_t dw3;
3843b7e5eaSJiawen Wu 			struct {
3943b7e5eaSJiawen Wu 				rte_le16_t len;
4043b7e5eaSJiawen Wu 				rte_le16_t tag;
4143b7e5eaSJiawen Wu 			} hi;
4243b7e5eaSJiawen Wu 		};
4343b7e5eaSJiawen Wu 	} qw1; /* also as r.hdr_addr */
4443b7e5eaSJiawen Wu };
4543b7e5eaSJiawen Wu 
4662fc35e6SJiawen Wu /* @ngbe_rx_desc.qw0 */
4762fc35e6SJiawen Wu #define NGBE_RXD_PKTADDR(rxd, v)  \
4862fc35e6SJiawen Wu 	(((volatile __le64 *)(rxd))[0] = cpu_to_le64(v))
4962fc35e6SJiawen Wu 
5062fc35e6SJiawen Wu /* @ngbe_rx_desc.qw1 */
5162fc35e6SJiawen Wu #define NGBE_RXD_HDRADDR(rxd, v)  \
5262fc35e6SJiawen Wu 	(((volatile __le64 *)(rxd))[1] = cpu_to_le64(v))
5362fc35e6SJiawen Wu 
5493dfebd2SJiawen Wu /* @ngbe_rx_desc.dw0 */
5593dfebd2SJiawen Wu #define NGBE_RXD_RSSTYPE(dw)      RS(dw, 0, 0xF)
5693dfebd2SJiawen Wu #define   NGBE_RSSTYPE_NONE       0
5793dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV4TCP    1
5893dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV4       2
5993dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV6TCP    3
6093dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV4SCTP   4
6193dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV6       5
6293dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV6SCTP   6
6393dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV4UDP    7
6493dfebd2SJiawen Wu #define   NGBE_RSSTYPE_IPV6UDP    8
6593dfebd2SJiawen Wu #define   NGBE_RSSTYPE_FDIR       15
6693dfebd2SJiawen Wu #define NGBE_RXD_SECTYPE(dw)      RS(dw, 4, 0x3)
6793dfebd2SJiawen Wu #define NGBE_RXD_SECTYPE_NONE     LS(0, 4, 0x3)
6893dfebd2SJiawen Wu #define NGBE_RXD_SECTYPE_IPSECESP LS(2, 4, 0x3)
6993dfebd2SJiawen Wu #define NGBE_RXD_SECTYPE_IPSECAH  LS(3, 4, 0x3)
7093dfebd2SJiawen Wu #define NGBE_RXD_TPIDSEL(dw)      RS(dw, 6, 0x7)
7193dfebd2SJiawen Wu #define NGBE_RXD_PTID(dw)         RS(dw, 9, 0xFF)
7293dfebd2SJiawen Wu #define NGBE_RXD_RSCCNT(dw)       RS(dw, 17, 0xF)
7393dfebd2SJiawen Wu #define NGBE_RXD_HDRLEN(dw)       RS(dw, 21, 0x3FF)
7493dfebd2SJiawen Wu #define NGBE_RXD_SPH              MS(31, 0x1)
7593dfebd2SJiawen Wu 
7693dfebd2SJiawen Wu /* @ngbe_rx_desc.dw1 */
7793dfebd2SJiawen Wu /** bit 0-31, as rss hash when  **/
7893dfebd2SJiawen Wu #define NGBE_RXD_RSSHASH(rxd)     ((rxd)->qw0.dw1)
7993dfebd2SJiawen Wu 
8093dfebd2SJiawen Wu /** bit 0-31, as ip csum when  **/
8193dfebd2SJiawen Wu #define NGBE_RXD_IPID(rxd)        ((rxd)->qw0.hi.ipid)
8293dfebd2SJiawen Wu #define NGBE_RXD_CSUM(rxd)        ((rxd)->qw0.hi.csum)
8393dfebd2SJiawen Wu 
8493dfebd2SJiawen Wu /* @ngbe_rx_desc.dw2 */
8593dfebd2SJiawen Wu #define NGBE_RXD_STATUS(rxd)      ((rxd)->qw1.lo.status)
8693dfebd2SJiawen Wu /** bit 0-1 **/
8793dfebd2SJiawen Wu #define NGBE_RXD_STAT_DD          MS(0, 0x1) /* Descriptor Done */
8893dfebd2SJiawen Wu #define NGBE_RXD_STAT_EOP         MS(1, 0x1) /* End of Packet */
8993dfebd2SJiawen Wu /** bit 2-31, when EOP=0 **/
9093dfebd2SJiawen Wu #define NGBE_RXD_NEXTP_RESV(v)    LS(v, 2, 0x3)
9193dfebd2SJiawen Wu #define NGBE_RXD_NEXTP(dw)        RS(dw, 4, 0xFFFF) /* Next Descriptor */
9293dfebd2SJiawen Wu /** bit 2-31, when EOP=1 **/
9393dfebd2SJiawen Wu #define NGBE_RXD_PKT_CLS_MASK     MS(2, 0x7) /* Packet Class */
9493dfebd2SJiawen Wu #define NGBE_RXD_PKT_CLS_TC_RSS   LS(0, 2, 0x7) /* RSS Hash */
9593dfebd2SJiawen Wu #define NGBE_RXD_PKT_CLS_FLM      LS(1, 2, 0x7) /* FDir Match */
9693dfebd2SJiawen Wu #define NGBE_RXD_PKT_CLS_SYN      LS(2, 2, 0x7) /* TCP Sync */
9793dfebd2SJiawen Wu #define NGBE_RXD_PKT_CLS_5TUPLE   LS(3, 2, 0x7) /* 5 Tuple */
9893dfebd2SJiawen Wu #define NGBE_RXD_PKT_CLS_ETF      LS(4, 2, 0x7) /* Ethertype Filter */
9993dfebd2SJiawen Wu #define NGBE_RXD_STAT_VLAN        MS(5, 0x1) /* IEEE VLAN Packet */
10093dfebd2SJiawen Wu #define NGBE_RXD_STAT_UDPCS       MS(6, 0x1) /* UDP xsum calculated */
10193dfebd2SJiawen Wu #define NGBE_RXD_STAT_L4CS        MS(7, 0x1) /* L4 xsum calculated */
10293dfebd2SJiawen Wu #define NGBE_RXD_STAT_IPCS        MS(8, 0x1) /* IP xsum calculated */
10393dfebd2SJiawen Wu #define NGBE_RXD_STAT_PIF         MS(9, 0x1) /* Non-unicast address */
10493dfebd2SJiawen Wu #define NGBE_RXD_STAT_EIPCS       MS(10, 0x1) /* Encap IP xsum calculated */
10593dfebd2SJiawen Wu #define NGBE_RXD_STAT_VEXT        MS(11, 0x1) /* Multi-VLAN */
10693dfebd2SJiawen Wu #define NGBE_RXD_STAT_IPV6EX      MS(12, 0x1) /* IPv6 with option header */
10793dfebd2SJiawen Wu #define NGBE_RXD_STAT_LLINT       MS(13, 0x1) /* Pkt caused LLI */
10893dfebd2SJiawen Wu #define NGBE_RXD_STAT_1588        MS(14, 0x1) /* IEEE1588 Time Stamp */
10993dfebd2SJiawen Wu #define NGBE_RXD_STAT_SECP        MS(15, 0x1) /* Security Processing */
11093dfebd2SJiawen Wu #define NGBE_RXD_STAT_LB          MS(16, 0x1) /* Loopback Status */
11193dfebd2SJiawen Wu /*** bit 17-30, when PTYPE=IP ***/
11293dfebd2SJiawen Wu #define NGBE_RXD_STAT_BMC         MS(17, 0x1) /* PTYPE=IP, BMC status */
11393dfebd2SJiawen Wu #define NGBE_RXD_ERR_HBO          MS(23, 0x1) /* Header Buffer Overflow */
11493dfebd2SJiawen Wu #define NGBE_RXD_ERR_EIPCS        MS(26, 0x1) /* Encap IP header error */
11593dfebd2SJiawen Wu #define NGBE_RXD_ERR_SECERR       MS(27, 0x1) /* macsec or ipsec error */
11693dfebd2SJiawen Wu #define NGBE_RXD_ERR_RXE          MS(29, 0x1) /* Any MAC Error */
11793dfebd2SJiawen Wu #define NGBE_RXD_ERR_L4CS         MS(30, 0x1) /* TCP/UDP xsum error */
11893dfebd2SJiawen Wu #define NGBE_RXD_ERR_IPCS         MS(31, 0x1) /* IP xsum error */
11993dfebd2SJiawen Wu #define NGBE_RXD_ERR_CSUM(dw)     RS(dw, 30, 0x3)
12093dfebd2SJiawen Wu 
12193dfebd2SJiawen Wu /* @ngbe_rx_desc.dw3 */
12293dfebd2SJiawen Wu #define NGBE_RXD_LENGTH(rxd)           ((rxd)->qw1.hi.len)
12393dfebd2SJiawen Wu #define NGBE_RXD_VLAN(rxd)             ((rxd)->qw1.hi.tag)
12493dfebd2SJiawen Wu 
125a58e7c31SJiawen Wu /*****************************************************************************
126a58e7c31SJiawen Wu  * Transmit Descriptor
127a58e7c31SJiawen Wu  *****************************************************************************/
128a58e7c31SJiawen Wu /**
129a58e7c31SJiawen Wu  * Transmit Context Descriptor (NGBE_TXD_TYP=CTXT)
130a58e7c31SJiawen Wu  **/
131a58e7c31SJiawen Wu struct ngbe_tx_ctx_desc {
132a58e7c31SJiawen Wu 	rte_le32_t dw0; /* w.vlan_macip_lens  */
133a58e7c31SJiawen Wu 	rte_le32_t dw1; /* w.seqnum_seed      */
134a58e7c31SJiawen Wu 	rte_le32_t dw2; /* w.type_tucmd_mlhl  */
135a58e7c31SJiawen Wu 	rte_le32_t dw3; /* w.mss_l4len_idx    */
136a58e7c31SJiawen Wu };
137a58e7c31SJiawen Wu 
1389f320614SJiawen Wu /* @ngbe_tx_ctx_desc.dw0 */
1399f320614SJiawen Wu #define NGBE_TXD_IPLEN(v)         LS(v, 0, 0x1FF) /* ip/fcoe header end */
1409f320614SJiawen Wu #define NGBE_TXD_MACLEN(v)        LS(v, 9, 0x7F) /* desc mac len */
1419f320614SJiawen Wu #define NGBE_TXD_VLAN(v)          LS(v, 16, 0xFFFF) /* vlan tag */
1429f320614SJiawen Wu 
1439f320614SJiawen Wu /* @ngbe_tx_ctx_desc.dw1 */
1449f320614SJiawen Wu /*** bit 0-31, when NGBE_TXD_DTYP_FCOE=0 ***/
1459f320614SJiawen Wu #define NGBE_TXD_IPSEC_SAIDX(v)   LS(v, 0, 0x3FF) /* ipsec SA index */
1469f320614SJiawen Wu #define NGBE_TXD_ETYPE(v)         LS(v, 11, 0x1) /* tunnel type */
1479f320614SJiawen Wu #define NGBE_TXD_ETYPE_UDP        LS(0, 11, 0x1)
1489f320614SJiawen Wu #define NGBE_TXD_ETYPE_GRE        LS(1, 11, 0x1)
1499f320614SJiawen Wu #define NGBE_TXD_EIPLEN(v)        LS(v, 12, 0x7F) /* tunnel ip header */
1509f320614SJiawen Wu #define NGBE_TXD_DTYP_FCOE        MS(16, 0x1) /* FCoE/IP descriptor */
1519f320614SJiawen Wu #define NGBE_TXD_ETUNLEN(v)       LS(v, 21, 0xFF) /* tunnel header */
1529f320614SJiawen Wu #define NGBE_TXD_DECTTL(v)        LS(v, 29, 0xF) /* decrease ip TTL */
1539f320614SJiawen Wu 
1549f320614SJiawen Wu /* @ngbe_tx_ctx_desc.dw2 */
1559f320614SJiawen Wu #define NGBE_TXD_IPSEC_ESPLEN(v)  LS(v, 1, 0x1FF) /* ipsec ESP length */
1569f320614SJiawen Wu #define NGBE_TXD_SNAP             MS(10, 0x1) /* SNAP indication */
1579f320614SJiawen Wu #define NGBE_TXD_TPID_SEL(v)      LS(v, 11, 0x7) /* vlan tag index */
1589f320614SJiawen Wu #define NGBE_TXD_IPSEC_ESP        MS(14, 0x1) /* ipsec type: esp=1 ah=0 */
1599f320614SJiawen Wu #define NGBE_TXD_IPSEC_ESPENC     MS(15, 0x1) /* ESP encrypt */
1609f320614SJiawen Wu #define NGBE_TXD_CTXT             MS(20, 0x1) /* context descriptor */
1619f320614SJiawen Wu #define NGBE_TXD_PTID(v)          LS(v, 24, 0xFF) /* packet type */
162a58e7c31SJiawen Wu /* @ngbe_tx_ctx_desc.dw3 */
163a58e7c31SJiawen Wu #define NGBE_TXD_DD               MS(0, 0x1) /* descriptor done */
1649f320614SJiawen Wu #define NGBE_TXD_IDX(v)           LS(v, 4, 0x1) /* ctxt desc index */
1659f320614SJiawen Wu #define NGBE_TXD_L4LEN(v)         LS(v, 8, 0xFF) /* l4 header length */
1669f320614SJiawen Wu #define NGBE_TXD_MSS(v)           LS(v, 16, 0xFFFF) /* l4 MSS */
167a58e7c31SJiawen Wu 
168a58e7c31SJiawen Wu /**
169a58e7c31SJiawen Wu  * Transmit Data Descriptor (NGBE_TXD_TYP=DATA)
170a58e7c31SJiawen Wu  **/
171a58e7c31SJiawen Wu struct ngbe_tx_desc {
172a58e7c31SJiawen Wu 	rte_le64_t qw0; /* r.buffer_addr ,  w.reserved    */
173a58e7c31SJiawen Wu 	rte_le32_t dw2; /* r.cmd_type_len,  w.nxtseq_seed */
174a58e7c31SJiawen Wu 	rte_le32_t dw3; /* r.olinfo_status, w.status      */
175a58e7c31SJiawen Wu };
176a58e7c31SJiawen Wu 
177aad91eddSJiawen Wu /* @ngbe_tx_desc.dw2 */
178aad91eddSJiawen Wu #define NGBE_TXD_DATLEN(v)        ((0xFFFF & (v))) /* data buffer length */
179aad91eddSJiawen Wu #define NGBE_TXD_1588             ((0x1) << 19) /* IEEE1588 time stamp */
180aad91eddSJiawen Wu #define NGBE_TXD_DATA             ((0x0) << 20) /* data descriptor */
181aad91eddSJiawen Wu #define NGBE_TXD_EOP              ((0x1) << 24) /* End of Packet */
182aad91eddSJiawen Wu #define NGBE_TXD_FCS              ((0x1) << 25) /* Insert FCS */
183aad91eddSJiawen Wu #define NGBE_TXD_LINKSEC          ((0x1) << 26) /* Insert LinkSec */
184aad91eddSJiawen Wu #define NGBE_TXD_ECU              ((0x1) << 28) /* forward to ECU */
185aad91eddSJiawen Wu #define NGBE_TXD_CNTAG            ((0x1) << 29) /* insert CN tag */
186aad91eddSJiawen Wu #define NGBE_TXD_VLE              ((0x1) << 30) /* insert VLAN tag */
187aad91eddSJiawen Wu #define NGBE_TXD_TSE              ((0x1) << 31) /* transmit segmentation */
188aad91eddSJiawen Wu 
189aad91eddSJiawen Wu #define NGBE_TXD_FLAGS (NGBE_TXD_FCS | NGBE_TXD_EOP)
190aad91eddSJiawen Wu 
191aad91eddSJiawen Wu /* @ngbe_tx_desc.dw3 */
192aad91eddSJiawen Wu #define NGBE_TXD_DD_UNUSED        NGBE_TXD_DD
193aad91eddSJiawen Wu #define NGBE_TXD_IDX_UNUSED(v)    NGBE_TXD_IDX(v)
194aad91eddSJiawen Wu #define NGBE_TXD_CC               ((0x1) << 7) /* check context */
195aad91eddSJiawen Wu #define NGBE_TXD_IPSEC            ((0x1) << 8) /* request ipsec offload */
196aad91eddSJiawen Wu #define NGBE_TXD_L4CS             ((0x1) << 9) /* insert TCP/UDP/SCTP csum */
197aad91eddSJiawen Wu #define NGBE_TXD_IPCS             ((0x1) << 10) /* insert IPv4 csum */
198aad91eddSJiawen Wu #define NGBE_TXD_EIPCS            ((0x1) << 11) /* insert outer IP csum */
199aad91eddSJiawen Wu #define NGBE_TXD_MNGFLT           ((0x1) << 12) /* enable management filter */
200aad91eddSJiawen Wu #define NGBE_TXD_PAYLEN(v)        ((0x7FFFF & (v)) << 13) /* payload length */
201aad91eddSJiawen Wu 
202aad91eddSJiawen Wu #define RTE_PMD_NGBE_TX_MAX_BURST 32
20343b7e5eaSJiawen Wu #define RTE_PMD_NGBE_RX_MAX_BURST 32
204aad91eddSJiawen Wu #define RTE_NGBE_TX_MAX_FREE_BUF_SZ 64
20543b7e5eaSJiawen Wu 
206e94c20c3SJiawen Wu #define RTE_NGBE_DESCS_PER_LOOP    4
207e94c20c3SJiawen Wu 
20843b7e5eaSJiawen Wu #define RX_RING_SZ ((NGBE_RING_DESC_MAX + RTE_PMD_NGBE_RX_MAX_BURST) * \
20943b7e5eaSJiawen Wu 		    sizeof(struct ngbe_rx_desc))
21043b7e5eaSJiawen Wu 
21193dfebd2SJiawen Wu #define rte_packet_prefetch(p)  rte_prefetch1(p)
21293dfebd2SJiawen Wu 
213001c7823SJiawen Wu #define RTE_NGBE_REGISTER_POLL_WAIT_10_MS  10
214001c7823SJiawen Wu #define RTE_NGBE_WAIT_100_US               100
215001c7823SJiawen Wu 
216a58e7c31SJiawen Wu #define NGBE_TX_MAX_SEG                    40
217a58e7c31SJiawen Wu 
218a58e7c31SJiawen Wu #ifndef DEFAULT_TX_FREE_THRESH
219a58e7c31SJiawen Wu #define DEFAULT_TX_FREE_THRESH 32
220a58e7c31SJiawen Wu #endif
22143b7e5eaSJiawen Wu 
22243b7e5eaSJiawen Wu /**
22343b7e5eaSJiawen Wu  * Structure associated with each descriptor of the Rx ring of a Rx queue.
22443b7e5eaSJiawen Wu  */
22543b7e5eaSJiawen Wu struct ngbe_rx_entry {
22643b7e5eaSJiawen Wu 	struct rte_mbuf *mbuf; /**< mbuf associated with Rx descriptor. */
22743b7e5eaSJiawen Wu };
22843b7e5eaSJiawen Wu 
22943b7e5eaSJiawen Wu struct ngbe_scattered_rx_entry {
23043b7e5eaSJiawen Wu 	struct rte_mbuf *fbuf; /**< First segment of the fragmented packet. */
23143b7e5eaSJiawen Wu };
23243b7e5eaSJiawen Wu 
23343b7e5eaSJiawen Wu /**
234a58e7c31SJiawen Wu  * Structure associated with each descriptor of the Tx ring of a Tx queue.
235a58e7c31SJiawen Wu  */
236a58e7c31SJiawen Wu struct ngbe_tx_entry {
237a58e7c31SJiawen Wu 	struct rte_mbuf *mbuf; /**< mbuf associated with Tx desc, if any. */
238a58e7c31SJiawen Wu 	uint16_t next_id; /**< Index of next descriptor in ring. */
239a58e7c31SJiawen Wu 	uint16_t last_id; /**< Index of last scattered descriptor. */
240a58e7c31SJiawen Wu };
241a58e7c31SJiawen Wu 
242a58e7c31SJiawen Wu /**
243e94c20c3SJiawen Wu  * Structure associated with each descriptor of the Tx ring of a Tx queue.
244e94c20c3SJiawen Wu  */
245e94c20c3SJiawen Wu struct ngbe_tx_entry_v {
246e94c20c3SJiawen Wu 	struct rte_mbuf *mbuf; /**< mbuf associated with Tx desc, if any. */
247e94c20c3SJiawen Wu };
248e94c20c3SJiawen Wu 
249e94c20c3SJiawen Wu /**
25043b7e5eaSJiawen Wu  * Structure associated with each Rx queue.
25143b7e5eaSJiawen Wu  */
25243b7e5eaSJiawen Wu struct ngbe_rx_queue {
25343b7e5eaSJiawen Wu 	struct rte_mempool   *mb_pool; /**< mbuf pool to populate Rx ring */
25443b7e5eaSJiawen Wu 	uint64_t             rx_ring_phys_addr; /**< Rx ring DMA address */
25543b7e5eaSJiawen Wu 	volatile uint32_t    *rdt_reg_addr; /**< RDT register address */
25643b7e5eaSJiawen Wu 	volatile uint32_t    *rdh_reg_addr; /**< RDH register address */
25743b7e5eaSJiawen Wu 
25843b7e5eaSJiawen Wu 	volatile struct ngbe_rx_desc   *rx_ring; /**< Rx ring virtual address */
25943b7e5eaSJiawen Wu 	/** address of Rx software ring */
26043b7e5eaSJiawen Wu 	struct ngbe_rx_entry           *sw_ring;
26143b7e5eaSJiawen Wu 	/** address of scattered Rx software ring */
26243b7e5eaSJiawen Wu 	struct ngbe_scattered_rx_entry *sw_sc_ring;
26343b7e5eaSJiawen Wu 
26443b7e5eaSJiawen Wu 	struct rte_mbuf *pkt_first_seg; /**< First segment of current packet */
26543b7e5eaSJiawen Wu 	struct rte_mbuf *pkt_last_seg; /**< Last segment of current packet */
266e94c20c3SJiawen Wu 	uint64_t        mbuf_initializer; /**< value to init mbufs */
26743b7e5eaSJiawen Wu 	uint16_t        nb_rx_desc; /**< number of Rx descriptors */
26843b7e5eaSJiawen Wu 	uint16_t        rx_tail;  /**< current value of RDT register */
26943b7e5eaSJiawen Wu 	uint16_t        nb_rx_hold; /**< number of held free Rx desc */
27043b7e5eaSJiawen Wu 
27143b7e5eaSJiawen Wu 	uint16_t rx_nb_avail; /**< nr of staged pkts ready to ret to app */
27243b7e5eaSJiawen Wu 	uint16_t rx_next_avail; /**< idx of next staged pkt to ret to app */
27343b7e5eaSJiawen Wu 	uint16_t rx_free_trigger; /**< triggers rx buffer allocation */
27443b7e5eaSJiawen Wu 
275e94c20c3SJiawen Wu 	uint8_t         rx_using_sse;   /**< indicates that vector Rx is in use */
276e94c20c3SJiawen Wu #if defined(RTE_ARCH_X86) || defined(RTE_ARCH_ARM)
277e94c20c3SJiawen Wu 	uint16_t        rxrearm_nb;     /**< number of remaining to be re-armed */
278e94c20c3SJiawen Wu 	uint16_t        rxrearm_start;  /**< the idx we start the re-arming from */
279e94c20c3SJiawen Wu #endif
28043b7e5eaSJiawen Wu 	uint16_t        rx_free_thresh; /**< max free Rx desc to hold */
28143b7e5eaSJiawen Wu 	uint16_t        queue_id; /**< RX queue index */
28243b7e5eaSJiawen Wu 	uint16_t        reg_idx;  /**< RX queue register index */
28343b7e5eaSJiawen Wu 	uint16_t        port_id;  /**< Device port identifier */
28464b36e4aSJiawen Wu 	uint8_t         crc_len;  /**< 0 if CRC stripped, 4 otherwise. */
28543b7e5eaSJiawen Wu 	uint8_t         drop_en;  /**< If not 0, set SRRCTL.Drop_En */
28643b7e5eaSJiawen Wu 	uint8_t         rx_deferred_start; /**< not in global dev start */
28759b46438SJiawen Wu 	/** flags to set in mbuf when a vlan is detected */
28859b46438SJiawen Wu 	uint64_t        vlan_flags;
28959b46438SJiawen Wu 	uint64_t	offloads; /**< Rx offloads with RTE_ETH_RX_OFFLOAD_* */
29043b7e5eaSJiawen Wu 	/** need to alloc dummy mbuf, for wraparound when scanning hw ring */
29143b7e5eaSJiawen Wu 	struct rte_mbuf fake_mbuf;
29243b7e5eaSJiawen Wu 	/** hold packets to return to application */
29343b7e5eaSJiawen Wu 	struct rte_mbuf *rx_stage[RTE_PMD_NGBE_RX_MAX_BURST * 2];
294fea7422fSJiawen Wu 	const struct rte_memzone *mz;
29543b7e5eaSJiawen Wu };
29643b7e5eaSJiawen Wu 
297a58e7c31SJiawen Wu /**
298a58e7c31SJiawen Wu  * NGBE CTX Constants
299a58e7c31SJiawen Wu  */
300a58e7c31SJiawen Wu enum ngbe_ctx_num {
301a58e7c31SJiawen Wu 	NGBE_CTX_0    = 0, /**< CTX0 */
302a58e7c31SJiawen Wu 	NGBE_CTX_1    = 1, /**< CTX1  */
303a58e7c31SJiawen Wu 	NGBE_CTX_NUM  = 2, /**< CTX NUMBER  */
304a58e7c31SJiawen Wu };
305a58e7c31SJiawen Wu 
3069f320614SJiawen Wu /** Offload features */
3079f320614SJiawen Wu union ngbe_tx_offload {
3089f320614SJiawen Wu 	uint64_t data[2];
3099f320614SJiawen Wu 	struct {
3109f320614SJiawen Wu 		uint64_t ptid:8; /**< Packet Type Identifier. */
3119f320614SJiawen Wu 		uint64_t l2_len:7; /**< L2 (MAC) Header Length. */
3129f320614SJiawen Wu 		uint64_t l3_len:9; /**< L3 (IP) Header Length. */
3139f320614SJiawen Wu 		uint64_t l4_len:8; /**< L4 (TCP/UDP) Header Length. */
3149f320614SJiawen Wu 		uint64_t tso_segsz:16; /**< TCP TSO segment size */
3159f320614SJiawen Wu 		uint64_t vlan_tci:16;
3169f320614SJiawen Wu 		/**< VLAN Tag Control Identifier (CPU order). */
3179f320614SJiawen Wu 
3189f320614SJiawen Wu 		/* fields for TX offloading of tunnels */
3199f320614SJiawen Wu 		uint64_t outer_tun_len:8; /**< Outer TUN (Tunnel) Hdr Length. */
3209f320614SJiawen Wu 		uint64_t outer_l2_len:8; /**< Outer L2 (MAC) Hdr Length. */
3219f320614SJiawen Wu 		uint64_t outer_l3_len:16; /**< Outer L3 (IP) Hdr Length. */
3229f320614SJiawen Wu 	};
3239f320614SJiawen Wu };
3249f320614SJiawen Wu 
325a58e7c31SJiawen Wu /**
326a58e7c31SJiawen Wu  * Structure to check if new context need be built
327a58e7c31SJiawen Wu  */
328a58e7c31SJiawen Wu struct ngbe_ctx_info {
329a58e7c31SJiawen Wu 	uint64_t flags;           /**< ol_flags for context build. */
3309f320614SJiawen Wu 	/**< tx offload: vlan, tso, l2-l3-l4 lengths. */
3319f320614SJiawen Wu 	union ngbe_tx_offload tx_offload;
3329f320614SJiawen Wu 	/** compare mask for tx offload. */
3339f320614SJiawen Wu 	union ngbe_tx_offload tx_offload_mask;
334a58e7c31SJiawen Wu };
335a58e7c31SJiawen Wu 
336a58e7c31SJiawen Wu /**
337a58e7c31SJiawen Wu  * Structure associated with each Tx queue.
338a58e7c31SJiawen Wu  */
339a58e7c31SJiawen Wu struct ngbe_tx_queue {
340a58e7c31SJiawen Wu 	/** Tx ring virtual address */
341a58e7c31SJiawen Wu 	volatile struct ngbe_tx_desc *tx_ring;
342a58e7c31SJiawen Wu 
343a58e7c31SJiawen Wu 	uint64_t             tx_ring_phys_addr; /**< Tx ring DMA address */
344e94c20c3SJiawen Wu 	union {
345e94c20c3SJiawen Wu 		/**< address of SW ring for scalar PMD. */
346e94c20c3SJiawen Wu 		struct ngbe_tx_entry *sw_ring;
347e94c20c3SJiawen Wu 		/**< address of SW ring for vector PMD */
348e94c20c3SJiawen Wu 		struct ngbe_tx_entry_v *sw_ring_v;
349e94c20c3SJiawen Wu 	};
350a58e7c31SJiawen Wu 	volatile uint32_t    *tdt_reg_addr; /**< Address of TDT register */
351a58e7c31SJiawen Wu 	volatile uint32_t    *tdc_reg_addr; /**< Address of TDC register */
352a58e7c31SJiawen Wu 	uint16_t             nb_tx_desc;    /**< number of Tx descriptors */
353a58e7c31SJiawen Wu 	uint16_t             tx_tail;       /**< current value of TDT reg */
354a58e7c31SJiawen Wu 	/**
355a58e7c31SJiawen Wu 	 * Start freeing Tx buffers if there are less free descriptors than
356a58e7c31SJiawen Wu 	 * this value.
357a58e7c31SJiawen Wu 	 */
358a58e7c31SJiawen Wu 	uint16_t             tx_free_thresh;
359a58e7c31SJiawen Wu 	/** Index to last Tx descriptor to have been cleaned */
360a58e7c31SJiawen Wu 	uint16_t             last_desc_cleaned;
361a58e7c31SJiawen Wu 	/** Total number of Tx descriptors ready to be allocated */
362a58e7c31SJiawen Wu 	uint16_t             nb_tx_free;
363a58e7c31SJiawen Wu 	uint16_t             tx_next_dd;    /**< next desc to scan for DD bit */
364a58e7c31SJiawen Wu 	uint16_t             queue_id;      /**< Tx queue index */
365a58e7c31SJiawen Wu 	uint16_t             reg_idx;       /**< Tx queue register index */
366a58e7c31SJiawen Wu 	uint16_t             port_id;       /**< Device port identifier */
367a58e7c31SJiawen Wu 	uint8_t              pthresh;       /**< Prefetch threshold register */
368a58e7c31SJiawen Wu 	uint8_t              hthresh;       /**< Host threshold register */
369a58e7c31SJiawen Wu 	uint8_t              wthresh;       /**< Write-back threshold reg */
3709f320614SJiawen Wu 	uint64_t             offloads;      /**< Tx offload flags */
371a58e7c31SJiawen Wu 	uint32_t             ctx_curr;      /**< Hardware context states */
372a58e7c31SJiawen Wu 	/** Hardware context0 history */
373a58e7c31SJiawen Wu 	struct ngbe_ctx_info ctx_cache[NGBE_CTX_NUM];
374a58e7c31SJiawen Wu 	uint8_t              tx_deferred_start; /**< not in global dev start */
375a58e7c31SJiawen Wu 
376a58e7c31SJiawen Wu 	const struct ngbe_txq_ops *ops;       /**< txq ops */
377fea7422fSJiawen Wu 	const struct rte_memzone *mz;
378*3eba2f28SJiawen Wu 	uint64_t            desc_error;
379a58e7c31SJiawen Wu };
380a58e7c31SJiawen Wu 
381a58e7c31SJiawen Wu struct ngbe_txq_ops {
382a58e7c31SJiawen Wu 	void (*release_mbufs)(struct ngbe_tx_queue *txq);
383a58e7c31SJiawen Wu 	void (*free_swring)(struct ngbe_tx_queue *txq);
384a58e7c31SJiawen Wu 	void (*reset)(struct ngbe_tx_queue *txq);
385a58e7c31SJiawen Wu };
386a58e7c31SJiawen Wu 
3879f320614SJiawen Wu /* Takes an ethdev and a queue and sets up the tx function to be used based on
3889f320614SJiawen Wu  * the queue parameters. Used in tx_queue_setup by primary process and then
3899f320614SJiawen Wu  * in dev_init by secondary process when attaching to an existing ethdev.
3909f320614SJiawen Wu  */
3919f320614SJiawen Wu void ngbe_set_tx_function(struct rte_eth_dev *dev, struct ngbe_tx_queue *txq);
3929f320614SJiawen Wu 
39379f3128dSJiawen Wu void ngbe_set_rx_function(struct rte_eth_dev *dev);
394e94c20c3SJiawen Wu uint16_t ngbe_recv_pkts_vec(void *rx_queue, struct rte_mbuf **rx_pkts,
395e94c20c3SJiawen Wu 			    uint16_t nb_pkts);
396e94c20c3SJiawen Wu uint16_t ngbe_recv_scattered_pkts_vec(void *rx_queue,
397e94c20c3SJiawen Wu 		struct rte_mbuf **rx_pkts, uint16_t nb_pkts);
398e94c20c3SJiawen Wu int ngbe_rx_vec_dev_conf_condition_check(struct rte_eth_dev *dev);
399e94c20c3SJiawen Wu int ngbe_rxq_vec_setup(struct ngbe_rx_queue *rxq);
400e94c20c3SJiawen Wu void ngbe_rx_queue_release_mbufs_vec(struct ngbe_rx_queue *rxq);
401e94c20c3SJiawen Wu uint16_t ngbe_xmit_fixed_burst_vec(void *tx_queue, struct rte_mbuf **tx_pkts,
402e94c20c3SJiawen Wu 				   uint16_t nb_pkts);
403e94c20c3SJiawen Wu int ngbe_txq_vec_setup(struct ngbe_tx_queue *txq);
404d0759b50SJiawen Wu int ngbe_dev_tx_done_cleanup(void *tx_queue, uint32_t free_cnt);
40579f3128dSJiawen Wu 
4069f320614SJiawen Wu uint64_t ngbe_get_tx_port_offloads(struct rte_eth_dev *dev);
40759b46438SJiawen Wu uint64_t ngbe_get_rx_queue_offloads(struct rte_eth_dev *dev);
40879f3128dSJiawen Wu uint64_t ngbe_get_rx_port_offloads(struct rte_eth_dev *dev);
40979f3128dSJiawen Wu 
41043b7e5eaSJiawen Wu #endif /* _NGBE_RXTX_H_ */
411