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 8e86a6fccSAndrew Boyer #include <stdint.h> 9e86a6fccSAndrew Boyer 10e86a6fccSAndrew Boyer #include "ionic_if.h" 11e86a6fccSAndrew Boyer 12e86a6fccSAndrew Boyer struct ionic_rx_qcq; 13e86a6fccSAndrew Boyer struct ionic_tx_qcq; 14e86a6fccSAndrew Boyer struct rte_eth_dev; 15e86a6fccSAndrew Boyer struct rte_eth_rxconf; 16e86a6fccSAndrew Boyer struct rte_eth_rxq_info; 17e86a6fccSAndrew Boyer struct rte_eth_txconf; 18e86a6fccSAndrew Boyer struct rte_eth_txq_info; 19e86a6fccSAndrew Boyer struct rte_mbuf; 20e86a6fccSAndrew 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 29e86a6fccSAndrew Boyer #define IONIC_CSUM_FLAG_MASK (IONIC_RXQ_COMP_CSUM_F_VLAN - 1) 30a27d9013SAlfredo Cardigliano 31e86a6fccSAndrew Boyer extern const uint64_t ionic_csum_flags[IONIC_CSUM_FLAG_MASK]; 32e86a6fccSAndrew Boyer extern const uint32_t ionic_ptype_table[IONIC_RXQ_COMP_PKT_TYPE_MASK]; 33e86a6fccSAndrew Boyer 34e86a6fccSAndrew 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); 407bb08900SAndrew Boyer int ionic_dev_rx_queue_stop(struct rte_eth_dev *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_start(struct rte_eth_dev *dev, uint16_t tx_queue_id); 477bb08900SAndrew Boyer int ionic_dev_tx_queue_stop(struct rte_eth_dev *dev, uint16_t tx_queue_id); 487bb08900SAndrew Boyer 49*0033e92fSAndrew Boyer /* Helpers for optimized dev_start() */ 50*0033e92fSAndrew Boyer int ionic_dev_rx_queue_start_firsthalf(struct rte_eth_dev *dev, 51*0033e92fSAndrew Boyer uint16_t rx_queue_id); 52*0033e92fSAndrew Boyer int ionic_dev_rx_queue_start_secondhalf(struct rte_eth_dev *dev, 53*0033e92fSAndrew Boyer uint16_t rx_queue_id); 54*0033e92fSAndrew Boyer int ionic_dev_tx_queue_start_firsthalf(struct rte_eth_dev *dev, 55*0033e92fSAndrew Boyer uint16_t tx_queue_id); 56*0033e92fSAndrew Boyer int ionic_dev_tx_queue_start_secondhalf(struct rte_eth_dev *dev, 57*0033e92fSAndrew Boyer uint16_t tx_queue_id); 58*0033e92fSAndrew Boyer 597bb08900SAndrew Boyer /* Helpers for optimized dev_stop() */ 607bb08900SAndrew Boyer void ionic_dev_rx_queue_stop_firsthalf(struct rte_eth_dev *dev, 617bb08900SAndrew Boyer uint16_t rx_queue_id); 627bb08900SAndrew Boyer void ionic_dev_rx_queue_stop_secondhalf(struct rte_eth_dev *dev, 637bb08900SAndrew Boyer uint16_t rx_queue_id); 647bb08900SAndrew Boyer void ionic_dev_tx_queue_stop_firsthalf(struct rte_eth_dev *dev, 657bb08900SAndrew Boyer uint16_t tx_queue_id); 667bb08900SAndrew Boyer void ionic_dev_tx_queue_stop_secondhalf(struct rte_eth_dev *dev, 677bb08900SAndrew Boyer uint16_t tx_queue_id); 68a27d9013SAlfredo Cardigliano 69a27d9013SAlfredo Cardigliano void ionic_rxq_info_get(struct rte_eth_dev *dev, uint16_t queue_id, 70a27d9013SAlfredo Cardigliano struct rte_eth_rxq_info *qinfo); 71a27d9013SAlfredo Cardigliano void ionic_txq_info_get(struct rte_eth_dev *dev, uint16_t queue_id, 72a27d9013SAlfredo Cardigliano struct rte_eth_txq_info *qinfo); 73a27d9013SAlfredo Cardigliano 740983a74aSAndrew Boyer int ionic_dev_rx_descriptor_status(void *rx_queue, uint16_t offset); 7560625147SAndrew Boyer int ionic_dev_tx_descriptor_status(void *tx_queue, uint16_t offset); 760983a74aSAndrew Boyer 77ba6a168aSSivaramakrishnan Venkat const uint32_t *ionic_dev_supported_ptypes_get(struct rte_eth_dev *dev, 78ba6a168aSSivaramakrishnan Venkat size_t *no_of_elements); 79b5b56afdSAndrew Boyer 80e86a6fccSAndrew Boyer int ionic_tx_tso(struct ionic_tx_qcq *txq, struct rte_mbuf *txm); 81e86a6fccSAndrew Boyer 82e86a6fccSAndrew Boyer uint16_t ionic_prep_pkts(void *tx_queue, struct rte_mbuf **tx_pkts, 83e86a6fccSAndrew Boyer uint16_t nb_pkts); 84e86a6fccSAndrew Boyer 85e86a6fccSAndrew Boyer /* ionic_rxtx_simple.c */ 86e86a6fccSAndrew Boyer uint16_t ionic_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts, 87e86a6fccSAndrew Boyer uint16_t nb_pkts); 88e86a6fccSAndrew Boyer uint16_t ionic_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts, 89e86a6fccSAndrew Boyer uint16_t nb_pkts); 90e86a6fccSAndrew Boyer 91e86a6fccSAndrew Boyer int ionic_rx_fill(struct ionic_rx_qcq *rxq); 92e86a6fccSAndrew Boyer 93e86a6fccSAndrew Boyer /* ionic_rxtx_sg.c */ 94e86a6fccSAndrew Boyer uint16_t ionic_recv_pkts_sg(void *rx_queue, struct rte_mbuf **rx_pkts, 95e86a6fccSAndrew Boyer uint16_t nb_pkts); 96e86a6fccSAndrew Boyer uint16_t ionic_xmit_pkts_sg(void *tx_queue, struct rte_mbuf **tx_pkts, 97e86a6fccSAndrew Boyer uint16_t nb_pkts); 98e86a6fccSAndrew Boyer 99e86a6fccSAndrew Boyer int ionic_rx_fill_sg(struct ionic_rx_qcq *rxq); 100e86a6fccSAndrew Boyer 10190fa040aSNeel Patel static inline void 10290fa040aSNeel Patel ionic_rxq_flush(struct ionic_queue *q) 10390fa040aSNeel Patel { 10490fa040aSNeel Patel struct ionic_rxq_desc *desc_base = q->base; 10590fa040aSNeel Patel struct ionic_rxq_desc *cmb_desc_base = q->cmb_base; 10690fa040aSNeel Patel 10790fa040aSNeel Patel if (q->cmb_base) { 10890fa040aSNeel Patel if (q->head_idx < q->cmb_head_idx) { 10990fa040aSNeel Patel /* copy [cmb_head, num_descs) */ 11090fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx], 11190fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx], 11290fa040aSNeel Patel (q->num_descs - q->cmb_head_idx) * sizeof(*desc_base)); 11390fa040aSNeel Patel /* copy [0, head) */ 11490fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[0], 11590fa040aSNeel Patel (void *)&desc_base[0], 11690fa040aSNeel Patel q->head_idx * sizeof(*desc_base)); 11790fa040aSNeel Patel } else { 11890fa040aSNeel Patel /* copy [cmb_head, head) */ 11990fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx], 12090fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx], 12190fa040aSNeel Patel (q->head_idx - q->cmb_head_idx) * sizeof(*desc_base)); 12290fa040aSNeel Patel } 12390fa040aSNeel Patel q->cmb_head_idx = q->head_idx; 12490fa040aSNeel Patel } 12590fa040aSNeel Patel 12690fa040aSNeel Patel ionic_q_flush(q); 12790fa040aSNeel Patel } 12890fa040aSNeel Patel 12990fa040aSNeel Patel static inline void 13090fa040aSNeel Patel ionic_txq_flush(struct ionic_queue *q) 13190fa040aSNeel Patel { 13290fa040aSNeel Patel struct ionic_txq_desc *desc_base = q->base; 13390fa040aSNeel Patel struct ionic_txq_desc *cmb_desc_base = q->cmb_base; 13490fa040aSNeel Patel 13590fa040aSNeel Patel if (q->cmb_base) { 13690fa040aSNeel Patel if (q->head_idx < q->cmb_head_idx) { 13790fa040aSNeel Patel /* copy [cmb_head, num_descs) */ 13890fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx], 13990fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx], 14090fa040aSNeel Patel (q->num_descs - q->cmb_head_idx) * sizeof(*desc_base)); 14190fa040aSNeel Patel /* copy [0, head) */ 14290fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[0], 14390fa040aSNeel Patel (void *)&desc_base[0], 14490fa040aSNeel Patel q->head_idx * sizeof(*desc_base)); 14590fa040aSNeel Patel } else { 14690fa040aSNeel Patel /* copy [cmb_head, head) */ 14790fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx], 14890fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx], 14990fa040aSNeel Patel (q->head_idx - q->cmb_head_idx) * sizeof(*desc_base)); 15090fa040aSNeel Patel } 15190fa040aSNeel Patel q->cmb_head_idx = q->head_idx; 15290fa040aSNeel Patel } 15390fa040aSNeel Patel 15490fa040aSNeel Patel ionic_q_flush(q); 15590fa040aSNeel Patel } 15690fa040aSNeel Patel 157a27d9013SAlfredo Cardigliano #endif /* _IONIC_RXTX_H_ */ 158