Skip to content

Commit fecce22

Browse files
Geliang Tangmatttbe
authored andcommitted
bpf: Export mptcp packet scheduler helpers
This patch adds a new struct btf_kfunc_id_set for MPTCP scheduler. Add mptcp_subflow_set_scheduled() and mptcp_sched_data_set_contexts() helpers into this id_set, and register it in bpf_mptcp_kfunc_init() to make sure these helpers can be accessed from the BPF context. Reviewed-by: Mat Martineau <[email protected]> Signed-off-by: Geliang Tang <[email protected]>
1 parent e45e5e8 commit fecce22

File tree

3 files changed

+76
-2
lines changed

3 files changed

+76
-2
lines changed

net/mptcp/bpf.c

Lines changed: 72 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -219,6 +219,27 @@ struct bpf_iter_mptcp_subflow_kern {
219219

220220
__bpf_kfunc_start_defs();
221221

222+
__bpf_kfunc static struct mptcp_subflow_context *
223+
bpf_mptcp_subflow_ctx(const struct sock *sk__ign)
224+
{
225+
const struct sock *sk = sk__ign;
226+
227+
if (sk && sk_fullsock(sk) &&
228+
sk->sk_protocol == IPPROTO_TCP && sk_is_mptcp(sk))
229+
return mptcp_subflow_ctx(sk);
230+
231+
return NULL;
232+
}
233+
234+
__bpf_kfunc static struct sock *
235+
bpf_mptcp_subflow_tcp_sock(const struct mptcp_subflow_context *subflow)
236+
{
237+
if (!subflow)
238+
return NULL;
239+
240+
return mptcp_subflow_tcp_sock(subflow);
241+
}
242+
222243
__bpf_kfunc static int
223244
bpf_iter_mptcp_subflow_new(struct bpf_iter_mptcp_subflow *it,
224245
struct sock *sk)
@@ -263,6 +284,22 @@ bpf_iter_mptcp_subflow_destroy(struct bpf_iter_mptcp_subflow *it)
263284
{
264285
}
265286

287+
__bpf_kfunc static bool bpf_mptcp_subflow_queues_empty(struct sock *sk)
288+
{
289+
return tcp_rtx_queue_empty(sk);
290+
}
291+
292+
__bpf_kfunc static bool bpf_sk_stream_memory_free(const struct sock *sk__ign)
293+
{
294+
const struct sock *sk = sk__ign;
295+
296+
if (sk && sk_fullsock(sk) &&
297+
sk->sk_protocol == IPPROTO_TCP && sk_is_mptcp(sk))
298+
return sk_stream_memory_free(sk);
299+
300+
return NULL;
301+
}
302+
266303
__bpf_kfunc_end_defs();
267304

268305
BTF_KFUNCS_START(bpf_mptcp_iter_kfunc_ids)
@@ -276,13 +313,48 @@ static const struct btf_kfunc_id_set bpf_mptcp_iter_kfunc_set = {
276313
.set = &bpf_mptcp_iter_kfunc_ids,
277314
};
278315

316+
BTF_KFUNCS_START(bpf_mptcp_common_kfunc_ids)
317+
BTF_ID_FLAGS(func, bpf_mptcp_subflow_ctx, KF_RET_NULL)
318+
BTF_ID_FLAGS(func, bpf_mptcp_subflow_tcp_sock, KF_RET_NULL)
319+
BTF_ID_FLAGS(func, mptcp_subflow_set_scheduled)
320+
BTF_ID_FLAGS(func, mptcp_subflow_active)
321+
BTF_ID_FLAGS(func, mptcp_set_timeout)
322+
BTF_ID_FLAGS(func, mptcp_wnd_end)
323+
BTF_ID_FLAGS(func, bpf_sk_stream_memory_free, KF_RET_NULL)
324+
BTF_ID_FLAGS(func, bpf_mptcp_subflow_queues_empty)
325+
BTF_ID_FLAGS(func, mptcp_pm_subflow_chk_stale, KF_SLEEPABLE)
326+
BTF_KFUNCS_END(bpf_mptcp_common_kfunc_ids)
327+
328+
static int bpf_mptcp_common_kfunc_filter(const struct bpf_prog *prog, u32 kfunc_id)
329+
{
330+
if (!btf_id_set8_contains(&bpf_mptcp_common_kfunc_ids, kfunc_id))
331+
return 0;
332+
333+
if (prog->type != BPF_PROG_TYPE_STRUCT_OPS)
334+
return -EACCES;
335+
336+
#ifdef CONFIG_BPF_JIT
337+
if (prog->aux->st_ops == &bpf_mptcp_sched_ops)
338+
return 0;
339+
#endif
340+
return -EACCES;
341+
}
342+
343+
static const struct btf_kfunc_id_set bpf_mptcp_common_kfunc_set = {
344+
.owner = THIS_MODULE,
345+
.set = &bpf_mptcp_common_kfunc_ids,
346+
.filter = bpf_mptcp_common_kfunc_filter,
347+
};
348+
279349
static int __init bpf_mptcp_kfunc_init(void)
280350
{
281351
int ret;
282352

283353
ret = register_btf_fmodret_id_set(&bpf_mptcp_fmodret_set);
284354
ret = ret ?: register_btf_kfunc_id_set(BPF_PROG_TYPE_STRUCT_OPS,
285355
&bpf_mptcp_iter_kfunc_set);
356+
ret = ret ?: register_btf_kfunc_id_set(BPF_PROG_TYPE_STRUCT_OPS,
357+
&bpf_mptcp_common_kfunc_set);
286358
#ifdef CONFIG_BPF_JIT
287359
ret = ret ?: register_bpf_struct_ops(&bpf_mptcp_sched_ops, mptcp_sched_ops);
288360
#endif

net/mptcp/protocol.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -53,7 +53,7 @@ DEFINE_PER_CPU(struct mptcp_delegated_action, mptcp_delegated_actions) = {
5353
static struct net_device *mptcp_napi_dev;
5454

5555
/* Returns end sequence number of the receiver's advertised window */
56-
static u64 mptcp_wnd_end(const struct mptcp_sock *msk)
56+
u64 mptcp_wnd_end(const struct mptcp_sock *msk)
5757
{
5858
return READ_ONCE(msk->wnd_end);
5959
}
@@ -448,7 +448,7 @@ static long mptcp_timeout_from_subflow(const struct mptcp_subflow_context *subfl
448448
icsk_timeout(inet_csk(ssk)) - jiffies : 0;
449449
}
450450

451-
static void mptcp_set_timeout(struct sock *sk)
451+
void mptcp_set_timeout(struct sock *sk)
452452
{
453453
struct mptcp_subflow_context *subflow;
454454
long tout = 0;

net/mptcp/protocol.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -737,6 +737,8 @@ void __mptcp_subflow_send_ack(struct sock *ssk);
737737
void mptcp_subflow_reset(struct sock *ssk);
738738
void mptcp_subflow_queue_clean(struct sock *sk, struct sock *ssk);
739739
void mptcp_sock_graft(struct sock *sk, struct socket *parent);
740+
u64 mptcp_wnd_end(const struct mptcp_sock *msk);
741+
void mptcp_set_timeout(struct sock *sk);
740742
struct sock *__mptcp_nmpc_sk(struct mptcp_sock *msk);
741743
bool __mptcp_close(struct sock *sk, long timeout);
742744
void mptcp_cancel_work(struct sock *sk);

0 commit comments

Comments
 (0)