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
490033e92fSAndrew Boyer /* Helpers for optimized dev_start() */
500033e92fSAndrew Boyer int ionic_dev_rx_queue_start_firsthalf(struct rte_eth_dev *dev,
510033e92fSAndrew Boyer uint16_t rx_queue_id);
520033e92fSAndrew Boyer int ionic_dev_rx_queue_start_secondhalf(struct rte_eth_dev *dev,
530033e92fSAndrew Boyer uint16_t rx_queue_id);
540033e92fSAndrew Boyer int ionic_dev_tx_queue_start_firsthalf(struct rte_eth_dev *dev,
550033e92fSAndrew Boyer uint16_t tx_queue_id);
560033e92fSAndrew Boyer int ionic_dev_tx_queue_start_secondhalf(struct rte_eth_dev *dev,
570033e92fSAndrew Boyer uint16_t tx_queue_id);
580033e92fSAndrew 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
ionic_rxq_flush(struct ionic_queue * q)10290fa040aSNeel Patel ionic_rxq_flush(struct ionic_queue *q)
10390fa040aSNeel Patel {
104*fffea1aeSAndrew Boyer #ifndef RTE_LIBRTE_IONIC_PMD_EMBEDDED
10590fa040aSNeel Patel struct ionic_rxq_desc *desc_base = q->base;
10690fa040aSNeel Patel struct ionic_rxq_desc *cmb_desc_base = q->cmb_base;
10790fa040aSNeel Patel
10890fa040aSNeel Patel if (q->cmb_base) {
10990fa040aSNeel Patel if (q->head_idx < q->cmb_head_idx) {
11090fa040aSNeel Patel /* copy [cmb_head, num_descs) */
11190fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx],
11290fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx],
11390fa040aSNeel Patel (q->num_descs - q->cmb_head_idx) * sizeof(*desc_base));
11490fa040aSNeel Patel /* copy [0, head) */
11590fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[0],
11690fa040aSNeel Patel (void *)&desc_base[0],
11790fa040aSNeel Patel q->head_idx * sizeof(*desc_base));
11890fa040aSNeel Patel } else {
11990fa040aSNeel Patel /* copy [cmb_head, head) */
12090fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx],
12190fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx],
12290fa040aSNeel Patel (q->head_idx - q->cmb_head_idx) * sizeof(*desc_base));
12390fa040aSNeel Patel }
12490fa040aSNeel Patel q->cmb_head_idx = q->head_idx;
12590fa040aSNeel Patel }
126*fffea1aeSAndrew Boyer #endif /* RTE_LIBRTE_IONIC_PMD_EMBEDDED */
12790fa040aSNeel Patel
12890fa040aSNeel Patel ionic_q_flush(q);
12990fa040aSNeel Patel }
13090fa040aSNeel Patel
13190fa040aSNeel Patel static inline void
ionic_txq_flush(struct ionic_queue * q)13290fa040aSNeel Patel ionic_txq_flush(struct ionic_queue *q)
13390fa040aSNeel Patel {
134*fffea1aeSAndrew Boyer #ifndef RTE_LIBRTE_IONIC_PMD_EMBEDDED
13590fa040aSNeel Patel struct ionic_txq_desc *desc_base = q->base;
13690fa040aSNeel Patel struct ionic_txq_desc *cmb_desc_base = q->cmb_base;
13790fa040aSNeel Patel
13890fa040aSNeel Patel if (q->cmb_base) {
13990fa040aSNeel Patel if (q->head_idx < q->cmb_head_idx) {
14090fa040aSNeel Patel /* copy [cmb_head, num_descs) */
14190fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx],
14290fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx],
14390fa040aSNeel Patel (q->num_descs - q->cmb_head_idx) * sizeof(*desc_base));
14490fa040aSNeel Patel /* copy [0, head) */
14590fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[0],
14690fa040aSNeel Patel (void *)&desc_base[0],
14790fa040aSNeel Patel q->head_idx * sizeof(*desc_base));
14890fa040aSNeel Patel } else {
14990fa040aSNeel Patel /* copy [cmb_head, head) */
15090fa040aSNeel Patel rte_memcpy((void *)&cmb_desc_base[q->cmb_head_idx],
15190fa040aSNeel Patel (void *)&desc_base[q->cmb_head_idx],
15290fa040aSNeel Patel (q->head_idx - q->cmb_head_idx) * sizeof(*desc_base));
15390fa040aSNeel Patel }
15490fa040aSNeel Patel q->cmb_head_idx = q->head_idx;
15590fa040aSNeel Patel }
156*fffea1aeSAndrew Boyer #endif /* RTE_LIBRTE_IONIC_PMD_EMBEDDED */
15790fa040aSNeel Patel
15890fa040aSNeel Patel ionic_q_flush(q);
15990fa040aSNeel Patel }
16090fa040aSNeel Patel
161a27d9013SAlfredo Cardigliano #endif /* _IONIC_RXTX_H_ */
162