Skip to content

Commit ba8ea72

Browse files
sm00thanakryiko
authored andcommitted
bpf: Change syscall_nr type to int in struct syscall_tp_t
linux-rt-devel tree contains a patch (b1773ea ("sched: Add support for lazy preemption")) that adds an extra member to struct trace_entry. This causes the offset of args field in struct trace_event_raw_sys_enter be different from the one in struct syscall_trace_enter: struct trace_event_raw_sys_enter { struct trace_entry ent; /* 0 12 */ /* XXX last struct has 3 bytes of padding */ /* XXX 4 bytes hole, try to pack */ long int id; /* 16 8 */ long unsigned int args[6]; /* 24 48 */ /* --- cacheline 1 boundary (64 bytes) was 8 bytes ago --- */ char __data[]; /* 72 0 */ /* size: 72, cachelines: 2, members: 4 */ /* sum members: 68, holes: 1, sum holes: 4 */ /* paddings: 1, sum paddings: 3 */ /* last cacheline: 8 bytes */ }; struct syscall_trace_enter { struct trace_entry ent; /* 0 12 */ /* XXX last struct has 3 bytes of padding */ int nr; /* 12 4 */ long unsigned int args[]; /* 16 0 */ /* size: 16, cachelines: 1, members: 3 */ /* paddings: 1, sum paddings: 3 */ /* last cacheline: 16 bytes */ }; This, in turn, causes perf_event_set_bpf_prog() fail while running bpf test_profiler testcase because max_ctx_offset is calculated based on the former struct, while off on the latter: 10488 if (is_tracepoint || is_syscall_tp) { 10489 int off = trace_event_get_offsets(event->tp_event); 10490 10491 if (prog->aux->max_ctx_offset > off) 10492 return -EACCES; 10493 } What bpf program is actually getting is a pointer to struct syscall_tp_t, defined in kernel/trace/trace_syscalls.c. This patch fixes the problem by aligning struct syscall_tp_t with struct syscall_trace_(enter|exit) and changing the tests to use these structs to dereference context. Signed-off-by: Artem Savkov <asavkov@redhat.com> Signed-off-by: Andrii Nakryiko <andrii@kernel.org> Acked-by: Steven Rostedt (Google) <rostedt@goodmis.org> Link: https://lore.kernel.org/bpf/20231013054219.172920-1-asavkov@redhat.com
1 parent 9c1292e commit ba8ea72

File tree

3 files changed

+5
-5
lines changed

3 files changed

+5
-5
lines changed

kernel/trace/trace_syscalls.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -556,7 +556,7 @@ static int perf_call_bpf_enter(struct trace_event_call *call, struct pt_regs *re
556556
{
557557
struct syscall_tp_t {
558558
struct trace_entry ent;
559-
unsigned long syscall_nr;
559+
int syscall_nr;
560560
unsigned long args[SYSCALL_DEFINE_MAXARGS];
561561
} __aligned(8) param;
562562
int i;
@@ -661,7 +661,7 @@ static int perf_call_bpf_exit(struct trace_event_call *call, struct pt_regs *reg
661661
{
662662
struct syscall_tp_t {
663663
struct trace_entry ent;
664-
unsigned long syscall_nr;
664+
int syscall_nr;
665665
unsigned long ret;
666666
} __aligned(8) param;
667667

tools/testing/selftests/bpf/progs/profiler.inc.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -609,7 +609,7 @@ ssize_t BPF_KPROBE(kprobe__proc_sys_write,
609609
}
610610

611611
SEC("tracepoint/syscalls/sys_enter_kill")
612-
int tracepoint__syscalls__sys_enter_kill(struct trace_event_raw_sys_enter* ctx)
612+
int tracepoint__syscalls__sys_enter_kill(struct syscall_trace_enter* ctx)
613613
{
614614
struct bpf_func_stats_ctx stats_ctx;
615615

tools/testing/selftests/bpf/progs/test_vmlinux.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -16,12 +16,12 @@ bool kprobe_called = false;
1616
bool fentry_called = false;
1717

1818
SEC("tp/syscalls/sys_enter_nanosleep")
19-
int handle__tp(struct trace_event_raw_sys_enter *args)
19+
int handle__tp(struct syscall_trace_enter *args)
2020
{
2121
struct __kernel_timespec *ts;
2222
long tv_nsec;
2323

24-
if (args->id != __NR_nanosleep)
24+
if (args->nr != __NR_nanosleep)
2525
return 0;
2626

2727
ts = (void *)args->args[0];

0 commit comments

Comments
 (0)