162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/* Copyright (c) 2020 Facebook */
362306a36Sopenharmony_ci
462306a36Sopenharmony_ci#include "vmlinux.h"
562306a36Sopenharmony_ci#include <asm/unistd.h>
662306a36Sopenharmony_ci#include <bpf/bpf_helpers.h>
762306a36Sopenharmony_ci#include <bpf/bpf_tracing.h>
862306a36Sopenharmony_ci#include <bpf/bpf_core_read.h>
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#define MY_TV_NSEC 1337
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cibool tp_called = false;
1362306a36Sopenharmony_cibool raw_tp_called = false;
1462306a36Sopenharmony_cibool tp_btf_called = false;
1562306a36Sopenharmony_cibool kprobe_called = false;
1662306a36Sopenharmony_cibool fentry_called = false;
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ciSEC("tp/syscalls/sys_enter_nanosleep")
1962306a36Sopenharmony_ciint handle__tp(struct trace_event_raw_sys_enter *args)
2062306a36Sopenharmony_ci{
2162306a36Sopenharmony_ci	struct __kernel_timespec *ts;
2262306a36Sopenharmony_ci	long tv_nsec;
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci	if (args->id != __NR_nanosleep)
2562306a36Sopenharmony_ci		return 0;
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci	ts = (void *)args->args[0];
2862306a36Sopenharmony_ci	if (bpf_probe_read_user(&tv_nsec, sizeof(ts->tv_nsec), &ts->tv_nsec) ||
2962306a36Sopenharmony_ci	    tv_nsec != MY_TV_NSEC)
3062306a36Sopenharmony_ci		return 0;
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci	tp_called = true;
3362306a36Sopenharmony_ci	return 0;
3462306a36Sopenharmony_ci}
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ciSEC("raw_tp/sys_enter")
3762306a36Sopenharmony_ciint BPF_PROG(handle__raw_tp, struct pt_regs *regs, long id)
3862306a36Sopenharmony_ci{
3962306a36Sopenharmony_ci	struct __kernel_timespec *ts;
4062306a36Sopenharmony_ci	long tv_nsec;
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci	if (id != __NR_nanosleep)
4362306a36Sopenharmony_ci		return 0;
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci	ts = (void *)PT_REGS_PARM1_CORE_SYSCALL(regs);
4662306a36Sopenharmony_ci	if (bpf_probe_read_user(&tv_nsec, sizeof(ts->tv_nsec), &ts->tv_nsec) ||
4762306a36Sopenharmony_ci	    tv_nsec != MY_TV_NSEC)
4862306a36Sopenharmony_ci		return 0;
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci	raw_tp_called = true;
5162306a36Sopenharmony_ci	return 0;
5262306a36Sopenharmony_ci}
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ciSEC("tp_btf/sys_enter")
5562306a36Sopenharmony_ciint BPF_PROG(handle__tp_btf, struct pt_regs *regs, long id)
5662306a36Sopenharmony_ci{
5762306a36Sopenharmony_ci	struct __kernel_timespec *ts;
5862306a36Sopenharmony_ci	long tv_nsec;
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci	if (id != __NR_nanosleep)
6162306a36Sopenharmony_ci		return 0;
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci	ts = (void *)PT_REGS_PARM1_CORE_SYSCALL(regs);
6462306a36Sopenharmony_ci	if (bpf_probe_read_user(&tv_nsec, sizeof(ts->tv_nsec), &ts->tv_nsec) ||
6562306a36Sopenharmony_ci	    tv_nsec != MY_TV_NSEC)
6662306a36Sopenharmony_ci		return 0;
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci	tp_btf_called = true;
6962306a36Sopenharmony_ci	return 0;
7062306a36Sopenharmony_ci}
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_ciSEC("kprobe/hrtimer_start_range_ns")
7362306a36Sopenharmony_ciint BPF_KPROBE(handle__kprobe, struct hrtimer *timer, ktime_t tim, u64 delta_ns,
7462306a36Sopenharmony_ci	       const enum hrtimer_mode mode)
7562306a36Sopenharmony_ci{
7662306a36Sopenharmony_ci	if (tim == MY_TV_NSEC)
7762306a36Sopenharmony_ci		kprobe_called = true;
7862306a36Sopenharmony_ci	return 0;
7962306a36Sopenharmony_ci}
8062306a36Sopenharmony_ci
8162306a36Sopenharmony_ciSEC("fentry/hrtimer_start_range_ns")
8262306a36Sopenharmony_ciint BPF_PROG(handle__fentry, struct hrtimer *timer, ktime_t tim, u64 delta_ns,
8362306a36Sopenharmony_ci	     const enum hrtimer_mode mode)
8462306a36Sopenharmony_ci{
8562306a36Sopenharmony_ci	if (tim == MY_TV_NSEC)
8662306a36Sopenharmony_ci		fentry_called = true;
8762306a36Sopenharmony_ci	return 0;
8862306a36Sopenharmony_ci}
8962306a36Sopenharmony_ci
9062306a36Sopenharmony_cichar _license[] SEC("license") = "GPL";
91