eddbe8e652
Add a selftest for commit e21aa34178
("bpf: Fix fexit trampoline.")
to make sure that attaching fexit prog to a sleeping kernel function
will trigger appropriate trampoline and program destruction.
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Link: https://lore.kernel.org/bpf/20210318004523.55908-1-alexei.starovoitov@gmail.com
32 lines
612 B
C
32 lines
612 B
C
// SPDX-License-Identifier: GPL-2.0
|
|
/* Copyright (c) 2021 Facebook */
|
|
#include "vmlinux.h"
|
|
#include <bpf/bpf_helpers.h>
|
|
#include <bpf/bpf_tracing.h>
|
|
|
|
char LICENSE[] SEC("license") = "GPL";
|
|
|
|
int pid = 0;
|
|
int fentry_cnt = 0;
|
|
int fexit_cnt = 0;
|
|
|
|
SEC("fentry/__x64_sys_nanosleep")
|
|
int BPF_PROG(nanosleep_fentry, const struct pt_regs *regs)
|
|
{
|
|
if ((int)bpf_get_current_pid_tgid() != pid)
|
|
return 0;
|
|
|
|
fentry_cnt++;
|
|
return 0;
|
|
}
|
|
|
|
SEC("fexit/__x64_sys_nanosleep")
|
|
int BPF_PROG(nanosleep_fexit, const struct pt_regs *regs, int ret)
|
|
{
|
|
if ((int)bpf_get_current_pid_tgid() != pid)
|
|
return 0;
|
|
|
|
fexit_cnt++;
|
|
return 0;
|
|
}
|