aboutsummaryrefslogtreecommitdiffstats
path: root/net/mptcp/bpf.c
diff options
context:
space:
mode:
authorGeliang Tang <[email protected]>2022-05-19 23:30:10 +0000
committerAndrii Nakryiko <[email protected]>2022-05-20 22:29:00 +0000
commit3bc253c2e652cf5f12cd8c00d80d8ec55d67d1a7 (patch)
treed5a148b96341eef26393448300dc927ee298a84b /net/mptcp/bpf.c
parentselftests/bpf: Fix some bugs in map_lookup_percpu_elem testcase (diff)
downloadkernel-3bc253c2e652cf5f12cd8c00d80d8ec55d67d1a7.tar.gz
kernel-3bc253c2e652cf5f12cd8c00d80d8ec55d67d1a7.zip
bpf: Add bpf_skc_to_mptcp_sock_proto
This patch implements a new struct bpf_func_proto, named bpf_skc_to_mptcp_sock_proto. Define a new bpf_id BTF_SOCK_TYPE_MPTCP, and a new helper bpf_skc_to_mptcp_sock(), which invokes another new helper bpf_mptcp_sock_from_subflow() in net/mptcp/bpf.c to get struct mptcp_sock from a given subflow socket. v2: Emit BTF type, add func_id checks in verifier.c and bpf_trace.c, remove build check for CONFIG_BPF_JIT v5: Drop EXPORT_SYMBOL (Martin) Co-developed-by: Nicolas Rybowski <[email protected]> Co-developed-by: Matthieu Baerts <[email protected]> Signed-off-by: Nicolas Rybowski <[email protected]> Signed-off-by: Matthieu Baerts <[email protected]> Signed-off-by: Geliang Tang <[email protected]> Signed-off-by: Mat Martineau <[email protected]> Signed-off-by: Andrii Nakryiko <[email protected]> Link: https://lore.kernel.org/bpf/[email protected]
Diffstat (limited to 'net/mptcp/bpf.c')
-rw-r--r--net/mptcp/bpf.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/net/mptcp/bpf.c b/net/mptcp/bpf.c
new file mode 100644
index 000000000000..5a0a84ad94af
--- /dev/null
+++ b/net/mptcp/bpf.c
@@ -0,0 +1,21 @@
+// SPDX-License-Identifier: GPL-2.0
+/* Multipath TCP
+ *
+ * Copyright (c) 2020, Tessares SA.
+ * Copyright (c) 2022, SUSE.
+ *
+ * Author: Nicolas Rybowski <[email protected]>
+ */
+
+#define pr_fmt(fmt) "MPTCP: " fmt
+
+#include <linux/bpf.h>
+#include "protocol.h"
+
+struct mptcp_sock *bpf_mptcp_sock_from_subflow(struct sock *sk)
+{
+ if (sk && sk_fullsock(sk) && sk->sk_protocol == IPPROTO_TCP && sk_is_mptcp(sk))
+ return mptcp_sk(mptcp_subflow_ctx(sk)->conn);
+
+ return NULL;
+}