|
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 |
|