176668754SAndrew Boyer /* SPDX-License-Identifier: BSD-3-Clause 2a5205992SAndrew Boyer * Copyright 2018-2022 Advanced Micro Devices, Inc. 3a27d9013SAlfredo Cardigliano */ 4a27d9013SAlfredo Cardigliano 5a27d9013SAlfredo Cardigliano #ifndef _IONIC_RXTX_H_ 6a27d9013SAlfredo Cardigliano #define _IONIC_RXTX_H_ 7a27d9013SAlfredo Cardigliano 8*e86a6fccSAndrew Boyer #include <stdint.h> 9*e86a6fccSAndrew Boyer 10*e86a6fccSAndrew Boyer #include "ionic_if.h" 11*e86a6fccSAndrew Boyer 12*e86a6fccSAndrew Boyer struct ionic_rx_qcq; 13*e86a6fccSAndrew Boyer struct ionic_tx_qcq; 14*e86a6fccSAndrew Boyer struct rte_eth_dev; 15*e86a6fccSAndrew Boyer struct rte_eth_rxconf; 16*e86a6fccSAndrew Boyer struct rte_eth_rxq_info; 17*e86a6fccSAndrew Boyer struct rte_eth_txconf; 18*e86a6fccSAndrew Boyer struct rte_eth_txq_info; 19*e86a6fccSAndrew Boyer struct rte_mbuf; 20*e86a6fccSAndrew Boyer struct rte_mempool; 21a27d9013SAlfredo Cardigliano 22a27d9013SAlfredo Cardigliano struct ionic_rx_service { 23a27d9013SAlfredo Cardigliano /* cb in */ 24a27d9013SAlfredo Cardigliano struct rte_mbuf **rx_pkts; 25a27d9013SAlfredo Cardigliano /* cb out */ 26a27d9013SAlfredo Cardigliano uint16_t nb_rx; 27a27d9013SAlfredo Cardigliano }; 28a27d9013SAlfredo Cardigliano 29*e86a6fccSAndrew Boyer #define IONIC_CSUM_FLAG_MASK (IONIC_RXQ_COMP_CSUM_F_VLAN - 1) 30a27d9013SAlfredo Cardigliano 31*e86a6fccSAndrew Boyer extern const uint64_t ionic_csum_flags[IONIC_CSUM_FLAG_MASK]; 32*e86a6fccSAndrew Boyer extern const uint32_t ionic_ptype_table[IONIC_RXQ_COMP_PKT_TYPE_MASK]; 33*e86a6fccSAndrew Boyer 34*e86a6fccSAndrew Boyer /* ionic_rxtx.c */ 35a27d9013SAlfredo Cardigliano int ionic_dev_rx_queue_setup(struct rte_eth_dev *dev, uint16_t rx_queue_id, 36a27d9013SAlfredo Cardigliano uint16_t nb_desc, uint32_t socket_id, 37a27d9013SAlfredo Cardigliano const struct rte_eth_rxconf *rx_conf, struct rte_mempool *mp); 387483341aSXueming Li void ionic_dev_rx_queue_release(struct rte_eth_dev *dev, uint16_t qid); 39a27d9013SAlfredo Cardigliano int ionic_dev_rx_queue_start(struct rte_eth_dev *dev, uint16_t rx_queue_id); 40a27d9013SAlfredo Cardigliano int ionic_dev_rx_queue_stop(struct rte_eth_dev *eth_dev, uint16_t rx_queue_id); 41a27d9013SAlfredo Cardigliano 42a27d9013SAlfredo Cardigliano int ionic_dev_tx_queue_setup(struct rte_eth_dev *dev, uint16_t tx_queue_id, 43a27d9013SAlfredo Cardigliano uint16_t nb_desc, uint32_t socket_id, 44a27d9013SAlfredo Cardigliano const struct rte_eth_txconf *tx_conf); 457483341aSXueming Li void ionic_dev_tx_queue_release(struct rte_eth_dev *dev, uint16_t qid); 46a27d9013SAlfredo Cardigliano int ionic_dev_tx_queue_stop(struct rte_eth_dev *eth_dev, uint16_t tx_queue_id); 47a27d9013SAlfredo Cardigliano int ionic_dev_tx_queue_start(struct rte_eth_dev *dev, uint16_t tx_queue_id); 48a27d9013SAlfredo Cardigliano 49a27d9013SAlfredo Cardigliano void ionic_rxq_info_get(struct rte_eth_dev *dev, uint16_t queue_id, 50a27d9013SAlfredo Cardigliano struct rte_eth_rxq_info *qinfo); 51a27d9013SAlfredo Cardigliano void ionic_txq_info_get(struct rte_eth_dev *dev, uint16_t queue_id, 52a27d9013SAlfredo Cardigliano struct rte_eth_txq_info *qinfo); 53a27d9013SAlfredo Cardigliano 540983a74aSAndrew Boyer int ionic_dev_rx_descriptor_status(void *rx_queue, uint16_t offset); 5560625147SAndrew Boyer int ionic_dev_tx_descriptor_status(void *tx_queue, uint16_t offset); 560983a74aSAndrew Boyer 57b5b56afdSAndrew Boyer const uint32_t *ionic_dev_supported_ptypes_get(struct rte_eth_dev *dev); 58b5b56afdSAndrew Boyer 59*e86a6fccSAndrew Boyer int ionic_tx_tso(struct ionic_tx_qcq *txq, struct rte_mbuf *txm); 60*e86a6fccSAndrew Boyer 61*e86a6fccSAndrew Boyer uint16_t ionic_prep_pkts(void *tx_queue, struct rte_mbuf **tx_pkts, 62*e86a6fccSAndrew Boyer uint16_t nb_pkts); 63*e86a6fccSAndrew Boyer 64*e86a6fccSAndrew Boyer /* ionic_rxtx_simple.c */ 65*e86a6fccSAndrew Boyer uint16_t ionic_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts, 66*e86a6fccSAndrew Boyer uint16_t nb_pkts); 67*e86a6fccSAndrew Boyer uint16_t ionic_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts, 68*e86a6fccSAndrew Boyer uint16_t nb_pkts); 69*e86a6fccSAndrew Boyer 70*e86a6fccSAndrew Boyer int ionic_rx_fill(struct ionic_rx_qcq *rxq); 71*e86a6fccSAndrew Boyer 72*e86a6fccSAndrew Boyer /* ionic_rxtx_sg.c */ 73*e86a6fccSAndrew Boyer uint16_t ionic_recv_pkts_sg(void *rx_queue, struct rte_mbuf **rx_pkts, 74*e86a6fccSAndrew Boyer uint16_t nb_pkts); 75*e86a6fccSAndrew Boyer uint16_t ionic_xmit_pkts_sg(void *tx_queue, struct rte_mbuf **tx_pkts, 76*e86a6fccSAndrew Boyer uint16_t nb_pkts); 77*e86a6fccSAndrew Boyer 78*e86a6fccSAndrew Boyer int ionic_rx_fill_sg(struct ionic_rx_qcq *rxq); 79*e86a6fccSAndrew Boyer 80a27d9013SAlfredo Cardigliano #endif /* _IONIC_RXTX_H_ */ 81