While some drivers have specific criteria for when a vector driver can
be enabled on the Rx path, there are a number of basic criteria which
apply across all drivers. Centralize those in the _common_intel folder,
and then update drivers to use the common conditional checks. This adds
some additional restrictions to some drivers like ixgbe, where those
conditions were necessary but never checked.

Signed-off-by: Bruce Richardson <bruce.richard...@intel.com>
---
 drivers/net/_common_intel/rx.h            | 20 +++++++++++++
 drivers/net/i40e/i40e_rxtx_vec_common.h   | 35 +++++------------------
 drivers/net/iavf/iavf_rxtx.c              | 15 +---------
 drivers/net/iavf/iavf_rxtx.h              |  1 +
 drivers/net/ice/ice_rxtx_vec_common.h     | 14 +--------
 drivers/net/ixgbe/ixgbe_rxtx_vec_common.h |  7 +++++
 6 files changed, 37 insertions(+), 55 deletions(-)

diff --git a/drivers/net/_common_intel/rx.h b/drivers/net/_common_intel/rx.h
index ca0485875c..abb01ba5e7 100644
--- a/drivers/net/_common_intel/rx.h
+++ b/drivers/net/_common_intel/rx.h
@@ -8,6 +8,7 @@
 #include <stdint.h>
 #include <unistd.h>
 #include <rte_mbuf.h>
+#include <rte_ethdev.h>
 
 #define CI_RX_BURST 32
 
@@ -89,4 +90,23 @@ ci_rxq_mbuf_initializer(uint16_t port_id)
        return mb_def.rearm_data[0];
 }
 
+/* basic checks for a vector-driver capable queue.
+ * Individual drivers may have other further tests beyond this.
+ */
+static inline bool
+ci_rxq_vec_capable(uint16_t nb_desc, uint16_t rx_free_thresh, uint64_t 
offloads)
+{
+       if (!rte_is_power_of_2(nb_desc) ||
+                       rx_free_thresh < CI_RX_BURST ||
+                       (nb_desc % rx_free_thresh) != 0)
+               return false;
+
+       /* no driver supports timestamping or buffer split on vector path */
+       if ((offloads & RTE_ETH_RX_OFFLOAD_TIMESTAMP) ||
+                       (offloads & RTE_ETH_RX_OFFLOAD_BUFFER_SPLIT))
+               return false;
+
+       return true;
+}
+
 #endif /* _COMMON_INTEL_RX_H_ */
diff --git a/drivers/net/i40e/i40e_rxtx_vec_common.h 
b/drivers/net/i40e/i40e_rxtx_vec_common.h
index 1ccdbd3fdb..5d0b777e0d 100644
--- a/drivers/net/i40e/i40e_rxtx_vec_common.h
+++ b/drivers/net/i40e/i40e_rxtx_vec_common.h
@@ -61,9 +61,6 @@ i40e_rx_vec_dev_conf_condition_check_default(struct 
rte_eth_dev *dev)
        struct i40e_adapter *ad =
                I40E_DEV_PRIVATE_TO_ADAPTER(dev->data->dev_private);
        struct rte_eth_rxmode *rxmode = &dev->data->dev_conf.rxmode;
-       struct i40e_rx_queue *rxq;
-       uint16_t desc, i;
-       bool first_queue;
 
        /* no QinQ support */
        if (rxmode->offloads & RTE_ETH_RX_OFFLOAD_VLAN_EXTEND)
@@ -73,31 +70,13 @@ i40e_rx_vec_dev_conf_condition_check_default(struct 
rte_eth_dev *dev)
         * Vector mode is allowed only when number of Rx queue
         * descriptor is power of 2.
         */
-       if (!dev->data->dev_started) {
-               first_queue = true;
-               for (i = 0; i < dev->data->nb_rx_queues; i++) {
-                       rxq = dev->data->rx_queues[i];
-                       if (!rxq)
-                               continue;
-                       desc = rxq->nb_rx_desc;
-                       if (first_queue)
-                               ad->rx_vec_allowed =
-                                       rte_is_power_of_2(desc);
-                       else
-                               ad->rx_vec_allowed =
-                                       ad->rx_vec_allowed ?
-                                       rte_is_power_of_2(desc) :
-                                       ad->rx_vec_allowed;
-                       first_queue = false;
-               }
-       } else {
-               /* Only check the first queue's descriptor number */
-               for (i = 0; i < dev->data->nb_rx_queues; i++) {
-                       rxq = dev->data->rx_queues[i];
-                       if (!rxq)
-                               continue;
-                       desc = rxq->nb_rx_desc;
-                       ad->rx_vec_allowed = rte_is_power_of_2(desc);
+       ad->rx_vec_allowed = true;
+       for (uint16_t i = 0; i < dev->data->nb_rx_queues; i++) {
+               struct i40e_rx_queue *rxq = dev->data->rx_queues[i];
+               if (!rxq)
+                       continue;
+               if (!ci_rxq_vec_capable(rxq->nb_rx_desc, rxq->rx_free_thresh, 
rxq->offloads)) {
+                       ad->rx_vec_allowed = false;
                        break;
                }
        }
diff --git a/drivers/net/iavf/iavf_rxtx.c b/drivers/net/iavf/iavf_rxtx.c
index 6692f6992b..e4c4b9682c 100644
--- a/drivers/net/iavf/iavf_rxtx.c
+++ b/drivers/net/iavf/iavf_rxtx.c
@@ -199,19 +199,6 @@ check_tx_thresh(uint16_t nb_desc, uint16_t tx_rs_thresh,
        return 0;
 }
 
-static inline bool
-check_rx_vec_allow(struct iavf_rx_queue *rxq)
-{
-       if (rxq->rx_free_thresh >= IAVF_VPMD_RX_MAX_BURST &&
-           rxq->nb_rx_desc % rxq->rx_free_thresh == 0) {
-               PMD_INIT_LOG(DEBUG, "Vector Rx can be enabled on this rxq.");
-               return true;
-       }
-
-       PMD_INIT_LOG(DEBUG, "Vector Rx cannot be enabled on this rxq.");
-       return false;
-}
-
 static inline bool
 check_tx_vec_allow(struct ci_tx_queue *txq)
 {
@@ -722,7 +709,7 @@ iavf_dev_rx_queue_setup(struct rte_eth_dev *dev, uint16_t 
queue_idx,
                ad->rx_bulk_alloc_allowed = false;
        }
 
-       if (check_rx_vec_allow(rxq) == false)
+       if (!ci_rxq_vec_capable(rxq->nb_rx_desc, rxq->rx_free_thresh, 
rxq->offloads))
                ad->rx_vec_allowed = false;
 
 #if defined RTE_ARCH_X86 || defined RTE_ARCH_ARM
diff --git a/drivers/net/iavf/iavf_rxtx.h b/drivers/net/iavf/iavf_rxtx.h
index c18e01560c..774c5c3574 100644
--- a/drivers/net/iavf/iavf_rxtx.h
+++ b/drivers/net/iavf/iavf_rxtx.h
@@ -5,6 +5,7 @@
 #ifndef _IAVF_RXTX_H_
 #define _IAVF_RXTX_H_
 
+#include <_common_intel/rx.h>
 #include <_common_intel/tx.h>
 
 /* In QLEN must be whole number of 32 descriptors. */
diff --git a/drivers/net/ice/ice_rxtx_vec_common.h 
b/drivers/net/ice/ice_rxtx_vec_common.h
index d5cf0e6fca..331741e6b0 100644
--- a/drivers/net/ice/ice_rxtx_vec_common.h
+++ b/drivers/net/ice/ice_rxtx_vec_common.h
@@ -88,24 +88,12 @@ ice_rx_vec_queue_default(struct ice_rx_queue *rxq)
        if (!rxq)
                return -1;
 
-       if (!rte_is_power_of_2(rxq->nb_rx_desc))
-               return -1;
-
-       if (rxq->rx_free_thresh < ICE_VPMD_RX_BURST)
-               return -1;
-
-       if (rxq->nb_rx_desc % rxq->rx_free_thresh)
+       if (!ci_rxq_vec_capable(rxq->nb_rx_desc, rxq->rx_free_thresh, 
rxq->offloads))
                return -1;
 
        if (rxq->proto_xtr != PROTO_XTR_NONE)
                return -1;
 
-       if (rxq->offloads & RTE_ETH_RX_OFFLOAD_TIMESTAMP)
-               return -1;
-
-       if (rxq->offloads & RTE_ETH_RX_OFFLOAD_BUFFER_SPLIT)
-               return -1;
-
        if (rxq->offloads & ICE_RX_VECTOR_OFFLOAD)
                return ICE_VECTOR_OFFLOAD_PATH;
 
diff --git a/drivers/net/ixgbe/ixgbe_rxtx_vec_common.h 
b/drivers/net/ixgbe/ixgbe_rxtx_vec_common.h
index 4a4d793e20..0703d5eecf 100644
--- a/drivers/net/ixgbe/ixgbe_rxtx_vec_common.h
+++ b/drivers/net/ixgbe/ixgbe_rxtx_vec_common.h
@@ -168,6 +168,13 @@ ixgbe_rx_vec_dev_conf_condition_check_default(struct 
rte_eth_dev *dev)
        if (fconf->mode != RTE_FDIR_MODE_NONE)
                return -1;
 
+       for (uint16_t i = 0; i < dev->data->nb_rx_queues; i++) {
+               struct ixgbe_rx_queue *rxq = dev->data->rx_queues[i];
+               if (!rxq)
+                       continue;
+               if (!ci_rxq_vec_capable(rxq->nb_rx_desc, rxq->rx_free_thresh, 
rxq->offloads))
+                       return -1;
+       }
        return 0;
 #else
        RTE_SET_USED(dev);
-- 
2.43.0

Reply via email to