mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

Add tests for freplace behavior with the combination of sleepable and non-sleepable global subprogs. The changes_pkt_data selftest did all the hardwork, so simply rename it and include new support for more summarization tests for might_sleep bit. Signed-off-by: Kumar Kartikeya Dwivedi <memxor@gmail.com> Link: https://lore.kernel.org/r/20250301151846.1552362-4-memxor@gmail.com Signed-off-by: Alexei Starovoitov <ast@kernel.org>
78 lines
1.1 KiB
C
78 lines
1.1 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
#include <vmlinux.h>
|
|
#include <bpf/bpf_helpers.h>
|
|
#include "bpf_misc.h"
|
|
|
|
__noinline
|
|
long changes_pkt_data(struct __sk_buff *sk)
|
|
{
|
|
return bpf_skb_pull_data(sk, 0);
|
|
}
|
|
|
|
__noinline __weak
|
|
long does_not_change_pkt_data(struct __sk_buff *sk)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
SEC("?tc")
|
|
int main_changes_with_subprogs(struct __sk_buff *sk)
|
|
{
|
|
changes_pkt_data(sk);
|
|
does_not_change_pkt_data(sk);
|
|
return 0;
|
|
}
|
|
|
|
SEC("?tc")
|
|
int main_changes(struct __sk_buff *sk)
|
|
{
|
|
bpf_skb_pull_data(sk, 0);
|
|
return 0;
|
|
}
|
|
|
|
SEC("?tc")
|
|
int main_does_not_change(struct __sk_buff *sk)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
__noinline
|
|
long might_sleep(struct pt_regs *ctx __arg_ctx)
|
|
{
|
|
int i;
|
|
|
|
bpf_copy_from_user(&i, sizeof(i), NULL);
|
|
return i;
|
|
}
|
|
|
|
__noinline __weak
|
|
long does_not_sleep(struct pt_regs *ctx __arg_ctx)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
SEC("?uprobe.s")
|
|
int main_might_sleep_with_subprogs(struct pt_regs *ctx)
|
|
{
|
|
might_sleep(ctx);
|
|
does_not_sleep(ctx);
|
|
return 0;
|
|
}
|
|
|
|
SEC("?uprobe.s")
|
|
int main_might_sleep(struct pt_regs *ctx)
|
|
{
|
|
int i;
|
|
|
|
bpf_copy_from_user(&i, sizeof(i), NULL);
|
|
return i;
|
|
}
|
|
|
|
SEC("?uprobe.s")
|
|
int main_does_not_sleep(struct pt_regs *ctx)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
char _license[] SEC("license") = "GPL";
|