summaryrefslogtreecommitdiffstats
path: root/net/bpfilter
diff options
context:
space:
mode:
authorMaciej Fijalkowski <maciej.fijalkowski@intel.com>2022-08-30 14:17:05 +0200
committerDaniel Borkmann <daniel@iogearbox.net>2022-08-31 20:52:09 +0200
commitc00c4461689e15ac2cc3b9a595a54e4d8afd3d77 (patch)
treeb4e8546be8db0cf7599ab421b2c749f9a04ca236 /net/bpfilter
parentc829dba797360d9a266cabfaac16d1cd80abfc2b (diff)
downloadlinux-stable-c00c4461689e15ac2cc3b9a595a54e4d8afd3d77.tar.gz
linux-stable-c00c4461689e15ac2cc3b9a595a54e4d8afd3d77.tar.bz2
linux-stable-c00c4461689e15ac2cc3b9a595a54e4d8afd3d77.zip
xsk: Fix backpressure mechanism on Tx
Commit d678cbd2f867 ("xsk: Fix handling of invalid descriptors in XSK TX batching API") fixed batch API usage against set of descriptors with invalid ones but introduced a problem when AF_XDP SW rings are smaller than HW ones. Mismatch of reported Tx'ed frames between HW generator and user space app was observed. It turned out that backpressure mechanism became a bottleneck when the amount of produced descriptors to CQ is lower than what we grabbed from XSK Tx ring. Say that 512 entries had been taken from XSK Tx ring but we had only 490 free entries in CQ. Then callsite (ZC driver) will produce only 490 entries onto HW Tx ring but 512 entries will be released from Tx ring and this is what will be seen by the user space. In order to fix this case, mix XSK Tx/CQ ring interractions by moving around internal functions and changing call order: * pull out xskq_prod_nb_free() from xskq_prod_reserve_addr_batch() up to xsk_tx_peek_release_desc_batch(); ** move xskq_cons_release_n() into xskq_cons_read_desc_batch() After doing so, algorithm can be described as follows: 1. lookup Tx entries 2. use value from 1. to reserve space in CQ (*) 3. Read from Tx ring as much descriptors as value from 2 3a. release descriptors from XSK Tx ring (**) 4. Finally produce addresses to CQ Fixes: d678cbd2f867 ("xsk: Fix handling of invalid descriptors in XSK TX batching API") Signed-off-by: Magnus Karlsson <magnus.karlsson@intel.com> Signed-off-by: Maciej Fijalkowski <maciej.fijalkowski@intel.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Link: https://lore.kernel.org/bpf/20220830121705.8618-1-maciej.fijalkowski@intel.com
Diffstat (limited to 'net/bpfilter')
0 files changed, 0 insertions, 0 deletions