1330a73a7SAndrii Nakryiko // SPDX-License-Identifier: GPL-2.0
2330a73a7SAndrii Nakryiko /* Copyright (c) 2019 Facebook */
3330a73a7SAndrii Nakryiko 
4330a73a7SAndrii Nakryiko #include <stdint.h>
5330a73a7SAndrii Nakryiko #include <stdbool.h>
6330a73a7SAndrii Nakryiko #include <linux/ptrace.h>
7330a73a7SAndrii Nakryiko #include <linux/bpf.h>
83e689141SToke Høiland-Jørgensen #include <bpf/bpf_helpers.h>
9330a73a7SAndrii Nakryiko 
10330a73a7SAndrii Nakryiko /* non-existing BPF helper, to test dead code elimination */
11330a73a7SAndrii Nakryiko static int (*bpf_missing_helper)(const void *arg1, int arg2) = (void *) 999;
12330a73a7SAndrii Nakryiko 
1381bfdd08SAndrii Nakryiko extern int LINUX_KERNEL_VERSION __kconfig;
14*ce6dc74aSAndrii Nakryiko extern int LINUX_UNKNOWN_VIRTUAL_EXTERN __kconfig __weak;
1581bfdd08SAndrii Nakryiko extern bool CONFIG_BPF_SYSCALL __kconfig; /* strong */
1681bfdd08SAndrii Nakryiko extern enum libbpf_tristate CONFIG_TRISTATE __kconfig __weak;
1781bfdd08SAndrii Nakryiko extern bool CONFIG_BOOL __kconfig __weak;
1881bfdd08SAndrii Nakryiko extern char CONFIG_CHAR __kconfig __weak;
1981bfdd08SAndrii Nakryiko extern uint16_t CONFIG_USHORT __kconfig __weak;
2081bfdd08SAndrii Nakryiko extern int CONFIG_INT __kconfig __weak;
2181bfdd08SAndrii Nakryiko extern uint64_t CONFIG_ULONG __kconfig __weak;
2281bfdd08SAndrii Nakryiko extern const char CONFIG_STR[8] __kconfig __weak;
2381bfdd08SAndrii Nakryiko extern uint64_t CONFIG_MISSING __kconfig __weak;
24330a73a7SAndrii Nakryiko 
25330a73a7SAndrii Nakryiko uint64_t kern_ver = -1;
26*ce6dc74aSAndrii Nakryiko uint64_t unkn_virt_val = -1;
27330a73a7SAndrii Nakryiko uint64_t bpf_syscall = -1;
28330a73a7SAndrii Nakryiko uint64_t tristate_val = -1;
29330a73a7SAndrii Nakryiko uint64_t bool_val = -1;
30330a73a7SAndrii Nakryiko uint64_t char_val = -1;
31330a73a7SAndrii Nakryiko uint64_t ushort_val = -1;
32330a73a7SAndrii Nakryiko uint64_t int_val = -1;
33330a73a7SAndrii Nakryiko uint64_t ulong_val = -1;
34330a73a7SAndrii Nakryiko char str_val[8] = {-1, -1, -1, -1, -1, -1, -1, -1};
35330a73a7SAndrii Nakryiko uint64_t missing_val = -1;
36330a73a7SAndrii Nakryiko 
37330a73a7SAndrii Nakryiko SEC("raw_tp/sys_enter")
handle_sys_enter(struct pt_regs * ctx)38330a73a7SAndrii Nakryiko int handle_sys_enter(struct pt_regs *ctx)
39330a73a7SAndrii Nakryiko {
40330a73a7SAndrii Nakryiko 	int i;
41330a73a7SAndrii Nakryiko 
42330a73a7SAndrii Nakryiko 	kern_ver = LINUX_KERNEL_VERSION;
43*ce6dc74aSAndrii Nakryiko 	unkn_virt_val = LINUX_UNKNOWN_VIRTUAL_EXTERN;
44330a73a7SAndrii Nakryiko 	bpf_syscall = CONFIG_BPF_SYSCALL;
45330a73a7SAndrii Nakryiko 	tristate_val = CONFIG_TRISTATE;
46330a73a7SAndrii Nakryiko 	bool_val = CONFIG_BOOL;
47330a73a7SAndrii Nakryiko 	char_val = CONFIG_CHAR;
48330a73a7SAndrii Nakryiko 	ushort_val = CONFIG_USHORT;
49330a73a7SAndrii Nakryiko 	int_val = CONFIG_INT;
50330a73a7SAndrii Nakryiko 	ulong_val = CONFIG_ULONG;
51330a73a7SAndrii Nakryiko 
52330a73a7SAndrii Nakryiko 	for (i = 0; i < sizeof(CONFIG_STR); i++) {
53330a73a7SAndrii Nakryiko 		str_val[i] = CONFIG_STR[i];
54330a73a7SAndrii Nakryiko 	}
55330a73a7SAndrii Nakryiko 
56330a73a7SAndrii Nakryiko 	if (CONFIG_MISSING)
57330a73a7SAndrii Nakryiko 		/* invalid, but dead code - never executed */
58330a73a7SAndrii Nakryiko 		missing_val = bpf_missing_helper(ctx, 123);
59330a73a7SAndrii Nakryiko 	else
60330a73a7SAndrii Nakryiko 		missing_val = 0xDEADC0DE;
61330a73a7SAndrii Nakryiko 
62330a73a7SAndrii Nakryiko 	return 0;
63330a73a7SAndrii Nakryiko }
64330a73a7SAndrii Nakryiko 
65330a73a7SAndrii Nakryiko char _license[] SEC("license") = "GPL";
66