mbox series

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

Message ID 20241219-bpf-next-net-mptcp-bpf_iter-subflows-v2-0-ae244d3cdbbc@kernel.org (mailing list archive)
Headers show
Series bpf: Add mptcp_subflow bpf_iter support | expand

Message

Matthieu Baerts Dec. 19, 2024, 3:46 p.m. UTC
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,

Comments

Matthieu Baerts Jan. 15, 2025, 9:39 a.m. UTC | #1
Hello BPF maintainers and reviewers,

On 19/12/2024 16:46, Matthieu Baerts (NGI0) wrote:
> 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.

(...)

> 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

The v2 of this series didn't get any reviews, probably because it has
been sent the week before Xmas. Do you prefer if I resend it?

There is no hurry, I can also re-send it later if "now" is not a good time.

Cheers,
Matt