[PATCH v5 35/35] net/cpfl: enable simple Tx function
Bruce Richardson
bruce.richardson at intel.com
Wed Feb 11 19:13:04 CET 2026
The common "simple Tx" function - in some ways a scalar version of the
vector Tx functions - can be used by the cpfl driver in the same way as
the idpf driver does.
Signed-off-by: Bruce Richardson <bruce.richardson at intel.com>
---
drivers/net/intel/cpfl/cpfl_rxtx.c | 39 ++++++++++++++++++++++++++----
1 file changed, 34 insertions(+), 5 deletions(-)
diff --git a/drivers/net/intel/cpfl/cpfl_rxtx.c b/drivers/net/intel/cpfl/cpfl_rxtx.c
index b5b9015310..11451e1666 100644
--- a/drivers/net/intel/cpfl/cpfl_rxtx.c
+++ b/drivers/net/intel/cpfl/cpfl_rxtx.c
@@ -1485,22 +1485,41 @@ cpfl_set_rx_function(struct rte_eth_dev *dev)
}
+static bool
+cpfl_tx_simple_allowed(struct rte_eth_dev *dev)
+{
+ struct cpfl_vport *cpfl_vport = dev->data->dev_private;
+ struct idpf_vport *vport = &cpfl_vport->base;
+ struct ci_tx_queue *txq;
+
+ if (vport->txq_model != VIRTCHNL2_QUEUE_MODEL_SINGLE)
+ return false;
+
+ for (int i = 0; i < dev->data->nb_tx_queues; i++) {
+ txq = dev->data->tx_queues[i];
+ if (txq == NULL)
+ continue;
+ if (txq->offloads != (txq->offloads & RTE_ETH_TX_OFFLOAD_MBUF_FAST_FREE) ||
+ txq->tx_rs_thresh < IDPF_VPMD_TX_MAX_BURST)
+ return false;
+ }
+ return true;
+}
+
void
cpfl_set_tx_function(struct rte_eth_dev *dev)
{
struct cpfl_vport *cpfl_vport = dev->data->dev_private;
struct idpf_vport *vport = &cpfl_vport->base;
-#ifdef RTE_ARCH_X86
-#ifdef CC_AVX512_SUPPORT
struct ci_tx_queue *txq;
int i;
-#endif /* CC_AVX512_SUPPORT */
-#endif /* RTE_ARCH_X86 */
struct idpf_adapter *ad = vport->adapter;
+ bool simple_allowed = cpfl_tx_simple_allowed(dev);
struct ci_tx_path_features req_features = {
.tx_offloads = dev->data->dev_conf.txmode.offloads,
.simd_width = RTE_VECT_SIMD_DISABLED,
- .single_queue = (vport->txq_model == VIRTCHNL2_QUEUE_MODEL_SINGLE)
+ .single_queue = (vport->txq_model == VIRTCHNL2_QUEUE_MODEL_SINGLE),
+ .simple_tx = simple_allowed
};
/* The primary process selects the tx path for all processes. */
@@ -1517,6 +1536,16 @@ cpfl_set_tx_function(struct rte_eth_dev *dev)
IDPF_TX_MAX,
IDPF_TX_DEFAULT);
+ /* Set use_vec_entry for single queue mode - only IDPF_TX_SINGLEQ uses regular entries */
+ if (vport->txq_model == VIRTCHNL2_QUEUE_MODEL_SINGLE) {
+ for (i = 0; i < dev->data->nb_tx_queues; i++) {
+ txq = dev->data->tx_queues[i];
+ if (txq == NULL)
+ continue;
+ txq->use_vec_entry = (ad->tx_func_type != IDPF_TX_SINGLEQ);
+ }
+ }
+
out:
dev->tx_pkt_burst = idpf_tx_path_infos[ad->tx_func_type].pkt_burst;
dev->tx_pkt_prepare = idpf_dp_prep_pkts;
--
2.51.0
More information about the dev
mailing list