Jiri Slaby 74cda9
From: Corinna Vinschen <vinschen@redhat.com>
Jiri Slaby 74cda9
Date: Mon, 3 Apr 2023 14:11:20 +0200
Jiri Slaby 74cda9
Subject: [PATCH] net: stmmac: fix up RX flow hash indirection table when
Jiri Slaby 74cda9
 setting channels
Jiri Slaby 74cda9
References: bsc#1012628
Jiri Slaby 74cda9
Patch-mainline: 6.2.11
Jiri Slaby 74cda9
Git-commit: 218c597325f4faf7b7a6049233a30d7842b5b2dc
Jiri Slaby 74cda9
Jiri Slaby 74cda9
[ Upstream commit 218c597325f4faf7b7a6049233a30d7842b5b2dc ]
Jiri Slaby 74cda9
Jiri Slaby 74cda9
stmmac_reinit_queues() fails to fix up the RX hash.  Even if the number
Jiri Slaby 74cda9
of channels gets restricted, the output of `ethtool -x' indicates that
Jiri Slaby 74cda9
all RX queues are used:
Jiri Slaby 74cda9
Jiri Slaby 74cda9
  $ ethtool -l enp0s29f2
Jiri Slaby 74cda9
  Channel parameters for enp0s29f2:
Jiri Slaby 74cda9
  Pre-set maximums:
Jiri Slaby 74cda9
  RX:		8
Jiri Slaby 74cda9
  TX:		8
Jiri Slaby 74cda9
  Other:		n/a
Jiri Slaby 74cda9
  Combined:	n/a
Jiri Slaby 74cda9
  Current hardware settings:
Jiri Slaby 74cda9
  RX:		8
Jiri Slaby 74cda9
  TX:		8
Jiri Slaby 74cda9
  Other:		n/a
Jiri Slaby 74cda9
  Combined:	n/a
Jiri Slaby 74cda9
  $ ethtool -x enp0s29f2
Jiri Slaby 74cda9
  RX flow hash indirection table for enp0s29f2 with 8 RX ring(s):
Jiri Slaby 74cda9
      0:      0     1     2     3     4     5     6     7
Jiri Slaby 74cda9
      8:      0     1     2     3     4     5     6     7
Jiri Slaby 74cda9
  [...]
Jiri Slaby 74cda9
  $ ethtool -L enp0s29f2 rx 3
Jiri Slaby 74cda9
  $ ethtool -x enp0s29f2
Jiri Slaby 74cda9
  RX flow hash indirection table for enp0s29f2 with 3 RX ring(s):
Jiri Slaby 74cda9
      0:      0     1     2     3     4     5     6     7
Jiri Slaby 74cda9
      8:      0     1     2     3     4     5     6     7
Jiri Slaby 74cda9
  [...]
Jiri Slaby 74cda9
Jiri Slaby 74cda9
Fix this by setting the indirection table according to the number
Jiri Slaby 74cda9
of specified queues.  The result is now as expected:
Jiri Slaby 74cda9
Jiri Slaby 74cda9
  $ ethtool -L enp0s29f2 rx 3
Jiri Slaby 74cda9
  $ ethtool -x enp0s29f2
Jiri Slaby 74cda9
  RX flow hash indirection table for enp0s29f2 with 3 RX ring(s):
Jiri Slaby 74cda9
      0:      0     1     2     0     1     2     0     1
Jiri Slaby 74cda9
      8:      2     0     1     2     0     1     2     0
Jiri Slaby 74cda9
  [...]
Jiri Slaby 74cda9
Jiri Slaby 74cda9
Tested on Intel Elkhart Lake.
Jiri Slaby 74cda9
Jiri Slaby 74cda9
Fixes: 0366f7e06a6b ("net: stmmac: add ethtool support for get/set channels")
Jiri Slaby 74cda9
Signed-off-by: Corinna Vinschen <vinschen@redhat.com>
Jiri Slaby 74cda9
Link: https://lore.kernel.org/r/20230403121120.489138-1-vinschen@redhat.com
Jiri Slaby 74cda9
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Jiri Slaby 74cda9
Signed-off-by: Sasha Levin <sashal@kernel.org>
Jiri Slaby 74cda9
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Jiri Slaby 74cda9
---
Jiri Slaby 74cda9
 drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 6 +++++-
Jiri Slaby 74cda9
 1 file changed, 5 insertions(+), 1 deletion(-)
Jiri Slaby 74cda9
Jiri Slaby 74cda9
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
Jiri Slaby 74cda9
index 20b51a39..4888536a 100644
Jiri Slaby 74cda9
--- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
Jiri Slaby 74cda9
+++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
Jiri Slaby 74cda9
@@ -6948,7 +6948,7 @@ static void stmmac_napi_del(struct net_device *dev)
Jiri Slaby 74cda9
 int stmmac_reinit_queues(struct net_device *dev, u32 rx_cnt, u32 tx_cnt)
Jiri Slaby 74cda9
 {
Jiri Slaby 74cda9
 	struct stmmac_priv *priv = netdev_priv(dev);
Jiri Slaby 74cda9
-	int ret = 0;
Jiri Slaby 74cda9
+	int ret = 0, i;
Jiri Slaby 74cda9
 
Jiri Slaby 74cda9
 	if (netif_running(dev))
Jiri Slaby 74cda9
 		stmmac_release(dev);
Jiri Slaby 74cda9
@@ -6957,6 +6957,10 @@ int stmmac_reinit_queues(struct net_device *dev, u32 rx_cnt, u32 tx_cnt)
Jiri Slaby 74cda9
 
Jiri Slaby 74cda9
 	priv->plat->rx_queues_to_use = rx_cnt;
Jiri Slaby 74cda9
 	priv->plat->tx_queues_to_use = tx_cnt;
Jiri Slaby 74cda9
+	if (!netif_is_rxfh_configured(dev))
Jiri Slaby 74cda9
+		for (i = 0; i < ARRAY_SIZE(priv->rss.table); i++)
Jiri Slaby 74cda9
+			priv->rss.table[i] = ethtool_rxfh_indir_default(i,
Jiri Slaby 74cda9
+									rx_cnt);
Jiri Slaby 74cda9
 
Jiri Slaby 74cda9
 	stmmac_napi_add(dev);
Jiri Slaby 74cda9
 
Jiri Slaby 74cda9
-- 
Jiri Slaby 74cda9
2.35.3
Jiri Slaby 74cda9