[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20230327175446.98151-1-john.fastabend@gmail.com>
Date: Mon, 27 Mar 2023 10:54:34 -0700
From: John Fastabend <john.fastabend@...il.com>
To: cong.wang@...edance.com, jakub@...udflare.com,
daniel@...earbox.net, lmb@...valent.com, edumazet@...gle.com
Cc: john.fastabend@...il.com, bpf@...r.kernel.org,
netdev@...r.kernel.org, ast@...nel.org, andrii@...nel.org,
will@...valent.com
Subject: [PATCH bpf v2 00/11] bpf sockmap fixes
Fixes for sockmap running against NGINX TCP tests and also on an
underprovisioned VM so that we hit error (ENOMEM) cases regularly.
The first 3 patches fix cases related to ENOMEM that were either
causing splats or data hangs.
Then 4-7 resolved cases found when running NGINX with its sockets
assigned to sockmap. These mostly have to do with handling fin/shutdown
incorrectly and ensuring epoll_wait works as expected.
Patches 8 and 9 extract some of the logic used for sockmap_listen tests
so that we can use it in other tests because it didn't make much
sense to me to add tests to the sockmap_listen cases when here we
are testing send/recv *basic* cases.
Finally patches 10 and 11 add the new tests to ensure we handle
ioctl(FIONREAD) and shutdown correctly.
To test the series I ran the NGINX compliance tests and the sockmap
selftests. For now our compliance test just runs with SK_PASS.
There are some more things to be done here, but these 11 patches
stand on their own in my opionion and fix issues we are having in
CI now. For bpf-next we can fixup/improve selftests to use the
ASSERT_* in sockmap_helpers, streamline some of the testing, and
add more tests. We also still are debugging a few additional flakes
patches coming soon.
v2: use skb_queue_empty instead of *_empty_lockless (Eric)
oops incorrectly updated copied_seq on DROP case (Eric)
added test for drop case copied_seq update
John Fastabend (11):
bpf: sockmap, pass skb ownership through read_skb
bpf: sockmap, convert schedule_work into delayed_work
bpf: sockmap, improved check for empty queue
bpf: sockmap, handle fin correctly
bpf: sockmap, TCP data stall on recv before accept
bpf: sockmap, wake up polling after data copy
bpf: sockmap incorrectly handling copied_seq
bpf: sockmap, pull socket helpers out of listen test for general use
bpf: sockmap, build helper to create connected socket pair
bpf: sockmap, test shutdown() correctly exits epoll and recv()=0
bpf: sockmap, test FIONREAD returns correct bytes in rx buffer
include/linux/skmsg.h | 2 +-
include/net/tcp.h | 1 +
net/core/skmsg.c | 58 ++-
net/core/sock_map.c | 3 +-
net/ipv4/tcp.c | 9 -
net/ipv4/tcp_bpf.c | 81 +++-
net/ipv4/udp.c | 5 +-
net/unix/af_unix.c | 5 +-
.../selftests/bpf/prog_tests/sockmap_basic.c | 119 +++++-
.../bpf/prog_tests/sockmap_helpers.h | 374 ++++++++++++++++++
.../selftests/bpf/prog_tests/sockmap_listen.c | 352 +----------------
.../bpf/progs/test_sockmap_pass_prog.c | 32 ++
12 files changed, 659 insertions(+), 382 deletions(-)
create mode 100644 tools/testing/selftests/bpf/prog_tests/sockmap_helpers.h
create mode 100644 tools/testing/selftests/bpf/progs/test_sockmap_pass_prog.c
--
2.33.0
Powered by blists - more mailing lists