netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors
@ 2022-05-27  8:05 Íñigo Huguet
  2022-05-27  8:05 ` [PATCH net v2 1/2] sfc: fix considering that all channels have TX queues Íñigo Huguet
                   ` (2 more replies)
  0 siblings, 3 replies; 4+ messages in thread
From: Íñigo Huguet @ 2022-05-27  8:05 UTC (permalink / raw)
  To: ecree.xilinx, habetsm.xilinx
  Cc: davem, edumazet, kuba, pabeni, cmclachlan, brouer, netdev,
	Íñigo Huguet

Trying to load sfc driver with modparam efx_separate_tx_channels=1
resulted in errors during initialization and not being able to use the
NIC. This patches fix a few bugs and make it work again.

v2:
* added Martin's patch instead of a previous mine. Mine one solved some
of the initialization errors, but Martin's solves them also in all 
possible cases.
* removed whitespaces cleanup, as requested by Jakub

Martin Habets (1):
  sfc: fix considering that all channels have TX queues

Íñigo Huguet (1):
  sfc: fix wrong tx channel offset with efx_separate_tx_channels

 drivers/net/ethernet/sfc/efx_channels.c | 6 ++----
 drivers/net/ethernet/sfc/net_driver.h   | 2 +-
 2 files changed, 3 insertions(+), 5 deletions(-)

-- 
2.34.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

* [PATCH net v2 1/2] sfc: fix considering that all channels have TX queues
  2022-05-27  8:05 [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors Íñigo Huguet
@ 2022-05-27  8:05 ` Íñigo Huguet
  2022-05-27  8:05 ` [PATCH net v2 2/2] sfc: fix wrong tx channel offset with efx_separate_tx_channels Íñigo Huguet
  2022-05-29 11:20 ` [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors patchwork-bot+netdevbpf
  2 siblings, 0 replies; 4+ messages in thread
From: Íñigo Huguet @ 2022-05-27  8:05 UTC (permalink / raw)
  To: ecree.xilinx, habetsm.xilinx
  Cc: davem, edumazet, kuba, pabeni, cmclachlan, brouer, netdev,
	Tianhao Zhao, Íñigo Huguet

From: Martin Habets <habetsm.xilinx@gmail.com>

Normally, all channels have RX and TX queues, but this is not true if
modparam efx_separate_tx_channels=1 is used. In that cases, some
channels only have RX queues and others only TX queues (or more
preciselly, they have them allocated, but not initialized).

Fix efx_channel_has_tx_queues to return the correct value for this case
too.

Messages shown at probe time before the fix:
 sfc 0000:03:00.0 ens6f0np0: MC command 0x82 inlen 544 failed rc=-22 (raw=0) arg=0
 ------------[ cut here ]------------
 netdevice: ens6f0np0: failed to initialise TXQ -1
 WARNING: CPU: 1 PID: 626 at drivers/net/ethernet/sfc/ef10.c:2393 efx_ef10_tx_init+0x201/0x300 [sfc]
 [...] stripped
 RIP: 0010:efx_ef10_tx_init+0x201/0x300 [sfc]
 [...] stripped
 Call Trace:
  efx_init_tx_queue+0xaa/0xf0 [sfc]
  efx_start_channels+0x49/0x120 [sfc]
  efx_start_all+0x1f8/0x430 [sfc]
  efx_net_open+0x5a/0xe0 [sfc]
  __dev_open+0xd0/0x190
  __dev_change_flags+0x1b3/0x220
  dev_change_flags+0x21/0x60
 [...] stripped

Messages shown at remove time before the fix:
 sfc 0000:03:00.0 ens6f0np0: failed to flush 10 queues
 sfc 0000:03:00.0 ens6f0np0: failed to flush queues

Fixes: 8700aff08984 ("sfc: fix channel allocation with brute force")
Reported-by: Tianhao Zhao <tizhao@redhat.com>
Signed-off-by: Martin Habets <habetsm.xilinx@gmail.com>
Tested-by: Íñigo Huguet <ihuguet@redhat.com>
---
 drivers/net/ethernet/sfc/net_driver.h | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/net/ethernet/sfc/net_driver.h b/drivers/net/ethernet/sfc/net_driver.h
index c75dc75e2857..d7255d54707c 100644
--- a/drivers/net/ethernet/sfc/net_driver.h
+++ b/drivers/net/ethernet/sfc/net_driver.h
@@ -1535,7 +1535,7 @@ static inline bool efx_channel_is_xdp_tx(struct efx_channel *channel)
 
 static inline bool efx_channel_has_tx_queues(struct efx_channel *channel)
 {
-	return true;
+	return channel && channel->channel >= channel->efx->tx_channel_offset;
 }
 
 static inline unsigned int efx_channel_num_tx_queues(struct efx_channel *channel)
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH net v2 2/2] sfc: fix wrong tx channel offset with efx_separate_tx_channels
  2022-05-27  8:05 [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors Íñigo Huguet
  2022-05-27  8:05 ` [PATCH net v2 1/2] sfc: fix considering that all channels have TX queues Íñigo Huguet
@ 2022-05-27  8:05 ` Íñigo Huguet
  2022-05-29 11:20 ` [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors patchwork-bot+netdevbpf
  2 siblings, 0 replies; 4+ messages in thread
From: Íñigo Huguet @ 2022-05-27  8:05 UTC (permalink / raw)
  To: ecree.xilinx, habetsm.xilinx
  Cc: davem, edumazet, kuba, pabeni, cmclachlan, brouer, netdev,
	Íñigo Huguet, Tianhao Zhao

tx_channel_offset is calculated in efx_allocate_msix_channels, but it is
also calculated again in efx_set_channels because it was originally done
there, and when efx_allocate_msix_channels was introduced it was
forgotten to be removed from efx_set_channels.

Moreover, the old calculation is wrong when using
efx_separate_tx_channels because now we can have XDP channels after the
TX channels, so n_channels - n_tx_channels doesn't point to the first TX
channel.

Remove the old calculation from efx_set_channels, and add the
initialization of this variable if MSI or legacy interrupts are used,
next to the initialization of the rest of the related variables, where
it was missing.

Fixes: 3990a8fffbda ("sfc: allocate channels for XDP tx queues")
Reported-by: Tianhao Zhao <tizhao@redhat.com>
Signed-off-by: Íñigo Huguet <ihuguet@redhat.com>
---
 drivers/net/ethernet/sfc/efx_channels.c | 6 ++----
 1 file changed, 2 insertions(+), 4 deletions(-)

diff --git a/drivers/net/ethernet/sfc/efx_channels.c b/drivers/net/ethernet/sfc/efx_channels.c
index 40df910aa140..b9cf873e1e42 100644
--- a/drivers/net/ethernet/sfc/efx_channels.c
+++ b/drivers/net/ethernet/sfc/efx_channels.c
@@ -324,6 +324,7 @@ int efx_probe_interrupts(struct efx_nic *efx)
 		efx->n_channels = 1;
 		efx->n_rx_channels = 1;
 		efx->n_tx_channels = 1;
+		efx->tx_channel_offset = 0;
 		efx->n_xdp_channels = 0;
 		efx->xdp_channel_offset = efx->n_channels;
 		rc = pci_enable_msi(efx->pci_dev);
@@ -344,6 +345,7 @@ int efx_probe_interrupts(struct efx_nic *efx)
 		efx->n_channels = 1 + (efx_separate_tx_channels ? 1 : 0);
 		efx->n_rx_channels = 1;
 		efx->n_tx_channels = 1;
+		efx->tx_channel_offset = 1;
 		efx->n_xdp_channels = 0;
 		efx->xdp_channel_offset = efx->n_channels;
 		efx->legacy_irq = efx->pci_dev->irq;
@@ -979,10 +981,6 @@ int efx_set_channels(struct efx_nic *efx)
 	struct efx_channel *channel;
 	int rc;
 
-	efx->tx_channel_offset =
-		efx_separate_tx_channels ?
-		efx->n_channels - efx->n_tx_channels : 0;
-
 	if (efx->xdp_tx_queue_count) {
 		EFX_WARN_ON_PARANOID(efx->xdp_tx_queues);
 
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors
  2022-05-27  8:05 [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors Íñigo Huguet
  2022-05-27  8:05 ` [PATCH net v2 1/2] sfc: fix considering that all channels have TX queues Íñigo Huguet
  2022-05-27  8:05 ` [PATCH net v2 2/2] sfc: fix wrong tx channel offset with efx_separate_tx_channels Íñigo Huguet
@ 2022-05-29 11:20 ` patchwork-bot+netdevbpf
  2 siblings, 0 replies; 4+ messages in thread
From: patchwork-bot+netdevbpf @ 2022-05-29 11:20 UTC (permalink / raw)
  To: =?utf-8?b?w43DsWlnbyBIdWd1ZXQgPGlodWd1ZXRAcmVkaGF0LmNvbT4=?=
  Cc: ecree.xilinx, habetsm.xilinx, davem, edumazet, kuba, pabeni,
	cmclachlan, brouer, netdev

Hello:

This series was applied to netdev/net.git (master)
by David S. Miller <davem@davemloft.net>:

On Fri, 27 May 2022 10:05:27 +0200 you wrote:
> Trying to load sfc driver with modparam efx_separate_tx_channels=1
> resulted in errors during initialization and not being able to use the
> NIC. This patches fix a few bugs and make it work again.
> 
> v2:
> * added Martin's patch instead of a previous mine. Mine one solved some
> of the initialization errors, but Martin's solves them also in all
> possible cases.
> * removed whitespaces cleanup, as requested by Jakub
> 
> [...]

Here is the summary with links:
  - [net,v2,1/2] sfc: fix considering that all channels have TX queues
    https://git.kernel.org/netdev/net/c/2e102b53f8a7
  - [net,v2,2/2] sfc: fix wrong tx channel offset with efx_separate_tx_channels
    https://git.kernel.org/netdev/net/c/c308dfd1b43e

You are awesome, thank you!
-- 
Deet-doot-dot, I am a bot.
https://korg.docs.kernel.org/patchwork/pwbot.html



^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2022-05-29 11:20 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-05-27  8:05 [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors Íñigo Huguet
2022-05-27  8:05 ` [PATCH net v2 1/2] sfc: fix considering that all channels have TX queues Íñigo Huguet
2022-05-27  8:05 ` [PATCH net v2 2/2] sfc: fix wrong tx channel offset with efx_separate_tx_channels Íñigo Huguet
2022-05-29 11:20 ` [PATCH net v2 0/2] sfc: fix some efx_separate_tx_channels errors patchwork-bot+netdevbpf

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).