mbox series

[net-next,v4,0/6] tsnep: XDP socket zero-copy support

Message ID 20230421194656.48063-1-gerhard@engleder-embedded.com (mailing list archive)
Headers show
Series tsnep: XDP socket zero-copy support | expand

Message

Gerhard Engleder April 21, 2023, 7:46 p.m. UTC
Implement XDP socket zero-copy support for tsnep driver. I tried to
follow existing drivers like igc as far as possible. But one main
difference is that tsnep does not need any reconfiguration for XDP BPF
program setup. So I decided to keep this behavior no matter if a XSK
pool is used or not. As a result, tsnep starts using the XSK pool even
if no XDP BPF program is available.

Another difference is that I tried to prevent potentially failing
allocations during XSK pool setup. E.g. both memory models for page pool
and XSK pool are registered all the time. Thus, XSK pool setup cannot
end up with not working queues.

Some prework is done to reduce the last two XSK commits to actual XSK
changes.

v4:
- move l2fwd ZC numbers to last commit (Maciej Fijalkowski)
- mention frame size of measurements (Maciej Fijalkowski)
- add NETDEV_XDP_ACT_XSK_ZEROCOPY flag with last commit (Maciej
  Fijalkowski)

v3:
- use __netif_tx_lock_bh() (Paolo Abeni)
- comment that rx->page_buffer is always zero terminated (Paolo Abeni)

v2:
- eliminate modulo op in TX/RX path (Maciej Fijalkowski)
- eliminate retval variable in tsnep_rx_alloc_zc() (Maciej Fijalkowski)
- scope variable entry within loop (Maciej Fijalkowski)
- use DMA_ATTR_SKIP_CPU_SYNC directly (Maciej Fijalkowski)
- union for page/xdp in tsnep_rx_entry (Maciej Fijalkowski)
- provide performance numbers (Maciej Fijalkowski)
- use xsk_buff_alloc_batch() (Maciej Fijalkowski)
- use xsk_tx_peek_release_desc_batch() (Maciej Fijalkowski)
- don't call tsnep_rx_reopen() if netdev is down
- init adapter pointer of queue only once

Gerhard Engleder (6):
  tsnep: Replace modulo operation with mask
  tsnep: Rework TX/RX queue initialization
  tsnep: Add functions for queue enable/disable
  tsnep: Move skb receive action to separate function
  tsnep: Add XDP socket zero-copy RX support
  tsnep: Add XDP socket zero-copy TX support

 drivers/net/ethernet/engleder/tsnep.h      |  16 +-
 drivers/net/ethernet/engleder/tsnep_main.c | 863 ++++++++++++++++++---
 drivers/net/ethernet/engleder/tsnep_xdp.c  |  66 ++
 3 files changed, 822 insertions(+), 123 deletions(-)

Comments

patchwork-bot+netdevbpf@kernel.org April 25, 2023, 1:50 a.m. UTC | #1
Hello:

This series was applied to netdev/net-next.git (main)
by Jakub Kicinski <kuba@kernel.org>:

On Fri, 21 Apr 2023 21:46:50 +0200 you wrote:
> Implement XDP socket zero-copy support for tsnep driver. I tried to
> follow existing drivers like igc as far as possible. But one main
> difference is that tsnep does not need any reconfiguration for XDP BPF
> program setup. So I decided to keep this behavior no matter if a XSK
> pool is used or not. As a result, tsnep starts using the XSK pool even
> if no XDP BPF program is available.
> 
> [...]

Here is the summary with links:
  - [net-next,v4,1/6] tsnep: Replace modulo operation with mask
    https://git.kernel.org/netdev/net-next/c/42fb2962b4a6
  - [net-next,v4,2/6] tsnep: Rework TX/RX queue initialization
    https://git.kernel.org/netdev/net-next/c/33b0ee02c84c
  - [net-next,v4,3/6] tsnep: Add functions for queue enable/disable
    https://git.kernel.org/netdev/net-next/c/2ea0a282ba09
  - [net-next,v4,4/6] tsnep: Move skb receive action to separate function
    https://git.kernel.org/netdev/net-next/c/c2d64697f41b
  - [net-next,v4,5/6] tsnep: Add XDP socket zero-copy RX support
    https://git.kernel.org/netdev/net-next/c/3fc2333933fd
  - [net-next,v4,6/6] tsnep: Add XDP socket zero-copy TX support
    https://git.kernel.org/netdev/net-next/c/cd275c236b3f

You are awesome, thank you!