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