[PATCH bpf-next/net v2 0/7] bpf: Add mptcp_subflow bpf_iter support

Matthieu Baerts (NGI0) posted 7 patches 1 day, 23 hours ago
Failed in applying to current master (apply log)
include/net/mptcp.h                                |   4 +-
kernel/bpf/cgroup.c                                |   2 +
net/core/filter.c                                  |   2 +-
net/mptcp/bpf.c                                    | 113 +++++++++++++++++-
tools/testing/selftests/bpf/bpf_experimental.h     |   8 ++
tools/testing/selftests/bpf/prog_tests/mptcp.c     | 129 ++++++++++++++++++++-
tools/testing/selftests/bpf/progs/mptcp_bpf.h      |   9 ++
.../testing/selftests/bpf/progs/mptcp_bpf_iters.c  |  63 ++++++++++
8 files changed, 318 insertions(+), 12 deletions(-)
[PATCH bpf-next/net v2 0/7] bpf: Add mptcp_subflow bpf_iter support
Posted by Matthieu Baerts (NGI0) 1 day, 23 hours ago
Here is a series from Geliang, adding mptcp_subflow bpf_iter support.

We are working on extending MPTCP with BPF, e.g. to control the path
manager -- in charge of the creation, deletion, and announcements of
subflows (paths) -- and the packet scheduler -- in charge of selecting
which available path the next data will be sent to. These extensions
need to iterate over the list of subflows attached to an MPTCP
connection, and do some specific actions via some new kfunc that will be
added later on.

This preparation work is split in different patches:

- Patch 1: extend bpf_skc_to_mptcp_sock() to be called with msk.

- Patch 2: allow using skc_to_mptcp_sock() in CGroup sockopt hooks.

- Patch 3: register some "basic" MPTCP kfunc.

- Patch 4: add mptcp_subflow bpf_iter support. Note that previous
           versions of this single patch have already been shared to the
           BPF mailing list. The changelog has been kept with a comment,
           but the version number has been reset to avoid confusions.

- Patch 5: add kfunc to make sure the msk is valid

- Patch 6: add more MPTCP endpoints in the selftests, in order to create
           more than 2 subflows.

- Patch 7: add a very simple test validating mptcp_subflow bpf_iter
           support. This test could be written without the new bpf_iter,
           but it is there only to make sure this specific feature works
           as expected.

Signed-off-by: Matthieu Baerts (NGI0) <matttbe@kernel.org>
---
Changes in v2:
- Patches 1-2: new ones.
- Patch 3: remove two kfunc, more restrictions. (Martin)
- Patch 4: add BUILD_BUG_ON(), more restrictions. (Martin)
- Patch 7: adaptations due to modifications in patches 1-4.
- Link to v1: https://lore.kernel.org/r/20241108-bpf-next-net-mptcp-bpf_iter-subflows-v1-0-cf16953035c1@kernel.org

---
Geliang Tang (7):
      bpf: Extend bpf_skc_to_mptcp_sock to MPTCP sock
      bpf: Allow use of skc_to_mptcp_sock in cg_sockopt
      bpf: Register mptcp common kfunc set
      bpf: Add mptcp_subflow bpf_iter
      bpf: Acquire and release mptcp socket
      selftests/bpf: More endpoints for endpoint_init
      selftests/bpf: Add mptcp_subflow bpf_iter subtest

 include/net/mptcp.h                                |   4 +-
 kernel/bpf/cgroup.c                                |   2 +
 net/core/filter.c                                  |   2 +-
 net/mptcp/bpf.c                                    | 113 +++++++++++++++++-
 tools/testing/selftests/bpf/bpf_experimental.h     |   8 ++
 tools/testing/selftests/bpf/prog_tests/mptcp.c     | 129 ++++++++++++++++++++-
 tools/testing/selftests/bpf/progs/mptcp_bpf.h      |   9 ++
 .../testing/selftests/bpf/progs/mptcp_bpf_iters.c  |  63 ++++++++++
 8 files changed, 318 insertions(+), 12 deletions(-)
---
base-commit: dad704ebe38642cd405e15b9c51263356391355c
change-id: 20241108-bpf-next-net-mptcp-bpf_iter-subflows-027f6d87770e

Best regards,
-- 
Matthieu Baerts (NGI0) <matttbe@kernel.org>