Blame SOURCES/0001-net-nfp-configure-default-RSS-reta-table.patch

c7ffa4
From 82d2ba939b9bbd99ed25ea06d5a690cf96489ea9 Mon Sep 17 00:00:00 2001
c7ffa4
From: Alejandro Lucero <alejandro.lucero@netronome.com>
c7ffa4
Date: Fri, 24 Nov 2017 15:31:49 +0000
c7ffa4
Subject: [PATCH] net/nfp: configure default RSS reta table
c7ffa4
c7ffa4
Some apps can enable RSS but not update the reta table nor the hash.
c7ffa4
This patch adds a default reta table setup based on total number of
c7ffa4
configured rx queues. The hash key is dependent on how the app
c7ffa4
configures the rx_conf struct.
c7ffa4
c7ffa4
Signed-off-by: Alejandro Lucero <alejandro.lucero@netronome.com>
c7ffa4
(cherry picked from commit f92e94478803c2307e68bf1023e6b49106bc843d)
c7ffa4
---
c7ffa4
 drivers/net/nfp/nfp_net.c | 154 +++++++++++++++++++++++++++++++-------
c7ffa4
 1 file changed, 125 insertions(+), 29 deletions(-)
c7ffa4
c7ffa4
diff --git a/drivers/net/nfp/nfp_net.c b/drivers/net/nfp/nfp_net.c
c7ffa4
index 3a63b1ca3..559230ab6 100644
c7ffa4
--- a/drivers/net/nfp/nfp_net.c
c7ffa4
+++ b/drivers/net/nfp/nfp_net.c
c7ffa4
@@ -101,6 +101,15 @@ static void nfp_net_stop(struct rte_eth_dev *dev);
c7ffa4
 static uint16_t nfp_net_xmit_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
c7ffa4
 				  uint16_t nb_pkts);
c7ffa4
 
c7ffa4
+static int nfp_net_rss_config_default(struct rte_eth_dev *dev);
c7ffa4
+static int nfp_net_rss_hash_update(struct rte_eth_dev *dev,
c7ffa4
+				   struct rte_eth_rss_conf *rss_conf);
c7ffa4
+static int nfp_net_rss_reta_write(struct rte_eth_dev *dev,
c7ffa4
+		    struct rte_eth_rss_reta_entry64 *reta_conf,
c7ffa4
+		    uint16_t reta_size);
c7ffa4
+static int nfp_net_rss_hash_write(struct rte_eth_dev *dev,
c7ffa4
+			struct rte_eth_rss_conf *rss_conf);
c7ffa4
+
c7ffa4
 /* The offset of the queue controller queues in the PCIe Target */
c7ffa4
 #define NFP_PCIE_QUEUE(_q) (0x80000 + (NFP_QCP_QUEUE_ADDR_SZ * ((_q) & 0xff)))
c7ffa4
 
c7ffa4
@@ -721,6 +730,8 @@ nfp_net_start(struct rte_eth_dev *dev)
c7ffa4
 {
c7ffa4
 	struct rte_pci_device *pci_dev = RTE_ETH_DEV_TO_PCI(dev);
c7ffa4
 	struct rte_intr_handle *intr_handle = &pci_dev->intr_handle;
c7ffa4
+	struct rte_eth_conf *dev_conf;
c7ffa4
+	struct rte_eth_rxmode *rxmode;
c7ffa4
 	uint32_t new_ctrl, update = 0;
c7ffa4
 	struct nfp_net_hw *hw;
c7ffa4
 	uint32_t intr_vector;
c7ffa4
@@ -770,6 +781,19 @@ nfp_net_start(struct rte_eth_dev *dev)
c7ffa4
 
c7ffa4
 	rte_intr_enable(intr_handle);
c7ffa4
 
c7ffa4
+	dev_conf = &dev->data->dev_conf;
c7ffa4
+	rxmode = &dev_conf->rxmode;
c7ffa4
+
c7ffa4
+	/* Checking RX mode */
c7ffa4
+	if (rxmode->mq_mode & ETH_MQ_RX_RSS) {
c7ffa4
+		if (hw->cap & NFP_NET_CFG_CTRL_RSS) {
c7ffa4
+			if (!nfp_net_rss_config_default(dev))
c7ffa4
+				update |= NFP_NET_CFG_UPDATE_RSS;
c7ffa4
+		} else {
c7ffa4
+			PMD_INIT_LOG(INFO, "RSS not supported");
c7ffa4
+			return -EINVAL;
c7ffa4
+		}
c7ffa4
+	}
c7ffa4
 	/* Enable device */
c7ffa4
 	new_ctrl = hw->ctrl | NFP_NET_CFG_CTRL_ENABLE;
c7ffa4
 
c7ffa4
@@ -2329,22 +2353,17 @@ nfp_net_vlan_offload_set(struct rte_eth_dev *dev, int mask)
c7ffa4
 	return ret;
c7ffa4
 }
c7ffa4
 
c7ffa4
-/* Update Redirection Table(RETA) of Receive Side Scaling of Ethernet device */
c7ffa4
 static int
c7ffa4
-nfp_net_reta_update(struct rte_eth_dev *dev,
c7ffa4
+nfp_net_rss_reta_write(struct rte_eth_dev *dev,
c7ffa4
 		    struct rte_eth_rss_reta_entry64 *reta_conf,
c7ffa4
 		    uint16_t reta_size)
c7ffa4
 {
c7ffa4
 	uint32_t reta, mask;
c7ffa4
 	int i, j;
c7ffa4
 	int idx, shift;
c7ffa4
-	uint32_t update;
c7ffa4
 	struct nfp_net_hw *hw =
c7ffa4
 		NFP_NET_DEV_PRIVATE_TO_HW(dev->data->dev_private);
c7ffa4
 
c7ffa4
-	if (!(hw->ctrl & NFP_NET_CFG_CTRL_RSS))
c7ffa4
-		return -EINVAL;
c7ffa4
-
c7ffa4
 	if (reta_size != NFP_NET_CFG_RSS_ITBL_SZ) {
c7ffa4
 		RTE_LOG(ERR, PMD, "The size of hash lookup table configured "
c7ffa4
 			"(%d) doesn't match the number hardware can supported "
c7ffa4
@@ -2381,6 +2400,26 @@ nfp_net_reta_update(struct rte_eth_dev *dev,
c7ffa4
 		nn_cfg_writel(hw, NFP_NET_CFG_RSS_ITBL + (idx * 64) + shift,
c7ffa4
 			      reta);
c7ffa4
 	}
c7ffa4
+	return 0;
c7ffa4
+}
c7ffa4
+
c7ffa4
+/* Update Redirection Table(RETA) of Receive Side Scaling of Ethernet device */
c7ffa4
+static int
c7ffa4
+nfp_net_reta_update(struct rte_eth_dev *dev,
c7ffa4
+		    struct rte_eth_rss_reta_entry64 *reta_conf,
c7ffa4
+		    uint16_t reta_size)
c7ffa4
+{
c7ffa4
+	struct nfp_net_hw *hw =
c7ffa4
+		NFP_NET_DEV_PRIVATE_TO_HW(dev->data->dev_private);
c7ffa4
+	uint32_t update;
c7ffa4
+	int ret;
c7ffa4
+
c7ffa4
+	if (!(hw->ctrl & NFP_NET_CFG_CTRL_RSS))
c7ffa4
+		return -EINVAL;
c7ffa4
+
c7ffa4
+	ret = nfp_net_rss_reta_write(dev, reta_conf, reta_size);
c7ffa4
+	if (ret != 0)
c7ffa4
+		return ret;
c7ffa4
 
c7ffa4
 	update = NFP_NET_CFG_UPDATE_RSS;
c7ffa4
 
c7ffa4
@@ -2439,33 +2478,24 @@ nfp_net_reta_query(struct rte_eth_dev *dev,
c7ffa4
 }
c7ffa4
 
c7ffa4
 static int
c7ffa4
-nfp_net_rss_hash_update(struct rte_eth_dev *dev,
c7ffa4
+nfp_net_rss_hash_write(struct rte_eth_dev *dev,
c7ffa4
 			struct rte_eth_rss_conf *rss_conf)
c7ffa4
 {
c7ffa4
-	uint32_t update;
c7ffa4
+	struct nfp_net_hw *hw;
c7ffa4
+	uint64_t rss_hf;
c7ffa4
 	uint32_t cfg_rss_ctrl = 0;
c7ffa4
 	uint8_t key;
c7ffa4
-	uint64_t rss_hf;
c7ffa4
 	int i;
c7ffa4
-	struct nfp_net_hw *hw;
c7ffa4
 
c7ffa4
 	hw = NFP_NET_DEV_PRIVATE_TO_HW(dev->data->dev_private);
c7ffa4
 
c7ffa4
-	rss_hf = rss_conf->rss_hf;
c7ffa4
-
c7ffa4
-	/* Checking if RSS is enabled */
c7ffa4
-	if (!(hw->ctrl & NFP_NET_CFG_CTRL_RSS)) {
c7ffa4
-		if (rss_hf != 0) { /* Enable RSS? */
c7ffa4
-			RTE_LOG(ERR, PMD, "RSS unsupported\n");
c7ffa4
-			return -EINVAL;
c7ffa4
-		}
c7ffa4
-		return 0; /* Nothing to do */
c7ffa4
+	/* Writing the key byte a byte */
c7ffa4
+	for (i = 0; i < rss_conf->rss_key_len; i++) {
c7ffa4
+		memcpy(&key, &rss_conf->rss_key[i], 1);
c7ffa4
+		nn_cfg_writeb(hw, NFP_NET_CFG_RSS_KEY + i, key);
c7ffa4
 	}
c7ffa4
 
c7ffa4
-	if (rss_conf->rss_key_len > NFP_NET_CFG_RSS_KEY_SZ) {
c7ffa4
-		RTE_LOG(ERR, PMD, "hash key too long\n");
c7ffa4
-		return -EINVAL;
c7ffa4
-	}
c7ffa4
+	rss_hf = rss_conf->rss_hf;
c7ffa4
 
c7ffa4
 	if (rss_hf & ETH_RSS_IPV4)
c7ffa4
 		cfg_rss_ctrl |= NFP_NET_CFG_RSS_IPV4 |
c7ffa4
@@ -2483,15 +2513,40 @@ nfp_net_rss_hash_update(struct rte_eth_dev *dev,
c7ffa4
 	/* configuring where to apply the RSS hash */
c7ffa4
 	nn_cfg_writel(hw, NFP_NET_CFG_RSS_CTRL, cfg_rss_ctrl);
c7ffa4
 
c7ffa4
-	/* Writing the key byte a byte */
c7ffa4
-	for (i = 0; i < rss_conf->rss_key_len; i++) {
c7ffa4
-		memcpy(&key, &rss_conf->rss_key[i], 1);
c7ffa4
-		nn_cfg_writeb(hw, NFP_NET_CFG_RSS_KEY + i, key);
c7ffa4
-	}
c7ffa4
-
c7ffa4
 	/* Writing the key size */
c7ffa4
 	nn_cfg_writeb(hw, NFP_NET_CFG_RSS_KEY_SZ, rss_conf->rss_key_len);
c7ffa4
 
c7ffa4
+	return 0;
c7ffa4
+}
c7ffa4
+
c7ffa4
+static int
c7ffa4
+nfp_net_rss_hash_update(struct rte_eth_dev *dev,
c7ffa4
+			struct rte_eth_rss_conf *rss_conf)
c7ffa4
+{
c7ffa4
+	uint32_t update;
c7ffa4
+	uint64_t rss_hf;
c7ffa4
+	struct nfp_net_hw *hw;
c7ffa4
+
c7ffa4
+	hw = NFP_NET_DEV_PRIVATE_TO_HW(dev->data->dev_private);
c7ffa4
+
c7ffa4
+	rss_hf = rss_conf->rss_hf;
c7ffa4
+
c7ffa4
+	/* Checking if RSS is enabled */
c7ffa4
+	if (!(hw->ctrl & NFP_NET_CFG_CTRL_RSS)) {
c7ffa4
+		if (rss_hf != 0) { /* Enable RSS? */
c7ffa4
+			RTE_LOG(ERR, PMD, "RSS unsupported\n");
c7ffa4
+			return -EINVAL;
c7ffa4
+		}
c7ffa4
+		return 0; /* Nothing to do */
c7ffa4
+	}
c7ffa4
+
c7ffa4
+	if (rss_conf->rss_key_len > NFP_NET_CFG_RSS_KEY_SZ) {
c7ffa4
+		RTE_LOG(ERR, PMD, "hash key too long\n");
c7ffa4
+		return -EINVAL;
c7ffa4
+	}
c7ffa4
+
c7ffa4
+	nfp_net_rss_hash_write(dev, rss_conf);
c7ffa4
+
c7ffa4
 	update = NFP_NET_CFG_UPDATE_RSS;
c7ffa4
 
c7ffa4
 	if (nfp_net_reconfig(hw, hw->ctrl, update) < 0)
c7ffa4
@@ -2548,6 +2603,47 @@ nfp_net_rss_hash_conf_get(struct rte_eth_dev *dev,
c7ffa4
 	return 0;
c7ffa4
 }
c7ffa4
 
c7ffa4
+static int
c7ffa4
+nfp_net_rss_config_default(struct rte_eth_dev *dev)
c7ffa4
+{
c7ffa4
+	struct rte_eth_conf *dev_conf;
c7ffa4
+	struct rte_eth_rss_conf rss_conf;
c7ffa4
+	struct rte_eth_rss_reta_entry64 nfp_reta_conf[2];
c7ffa4
+	uint16_t rx_queues = dev->data->nb_rx_queues;
c7ffa4
+	uint16_t queue;
c7ffa4
+	int i, j, ret;
c7ffa4
+
c7ffa4
+	RTE_LOG(INFO, PMD, "setting default RSS conf for %u queues\n",
c7ffa4
+		rx_queues);
c7ffa4
+
c7ffa4
+	nfp_reta_conf[0].mask = ~0x0;
c7ffa4
+	nfp_reta_conf[1].mask = ~0x0;
c7ffa4
+
c7ffa4
+	queue = 0;
c7ffa4
+	for (i = 0; i < 0x40; i += 8) {
c7ffa4
+		for (j = i; j < (i + 8); j++) {
c7ffa4
+			nfp_reta_conf[0].reta[j] = queue;
c7ffa4
+			nfp_reta_conf[1].reta[j] = queue++;
c7ffa4
+			queue %= rx_queues;
c7ffa4
+		}
c7ffa4
+	}
c7ffa4
+	ret = nfp_net_rss_reta_write(dev, nfp_reta_conf, 0x80);
c7ffa4
+	if (ret != 0)
c7ffa4
+		return ret;
c7ffa4
+
c7ffa4
+	dev_conf = &dev->data->dev_conf;
c7ffa4
+	if (!dev_conf) {
c7ffa4
+		RTE_LOG(INFO, PMD, "wrong rss conf");
c7ffa4
+		return -EINVAL;
c7ffa4
+	}
c7ffa4
+	rss_conf = dev_conf->rx_adv_conf.rss_conf;
c7ffa4
+
c7ffa4
+	ret = nfp_net_rss_hash_write(dev, &rss_conf);
c7ffa4
+
c7ffa4
+	return ret;
c7ffa4
+}
c7ffa4
+
c7ffa4
+
c7ffa4
 /* Initialise and register driver with DPDK Application */
c7ffa4
 static const struct eth_dev_ops nfp_net_eth_dev_ops = {
c7ffa4
 	.dev_configure		= nfp_net_configure,
c7ffa4
-- 
c7ffa4
2.17.0
c7ffa4