xref: /dpdk/drivers/net/ionic/ionic_rxtx.h (revision e86a6fcc7cf3774bf13b96778afec64df4d7f4ae)
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