1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright (c) 2019 Facebook */
3 
4 #include <stdint.h>
5 #include <stdbool.h>
6 #include <linux/ptrace.h>
7 #include <linux/bpf.h>
8 #include <bpf/bpf_helpers.h>
9 
10 /* non-existing BPF helper, to test dead code elimination */
11 static int (*bpf_missing_helper)(const void *arg1, int arg2) = (void *) 999;
12 
13 extern int LINUX_KERNEL_VERSION __kconfig;
14 extern bool CONFIG_BPF_SYSCALL __kconfig; /* strong */
15 extern enum libbpf_tristate CONFIG_TRISTATE __kconfig __weak;
16 extern bool CONFIG_BOOL __kconfig __weak;
17 extern char CONFIG_CHAR __kconfig __weak;
18 extern uint16_t CONFIG_USHORT __kconfig __weak;
19 extern int CONFIG_INT __kconfig __weak;
20 extern uint64_t CONFIG_ULONG __kconfig __weak;
21 extern const char CONFIG_STR[8] __kconfig __weak;
22 extern uint64_t CONFIG_MISSING __kconfig __weak;
23 
24 uint64_t kern_ver = -1;
25 uint64_t bpf_syscall = -1;
26 uint64_t tristate_val = -1;
27 uint64_t bool_val = -1;
28 uint64_t char_val = -1;
29 uint64_t ushort_val = -1;
30 uint64_t int_val = -1;
31 uint64_t ulong_val = -1;
32 char str_val[8] = {-1, -1, -1, -1, -1, -1, -1, -1};
33 uint64_t missing_val = -1;
34 
35 SEC("raw_tp/sys_enter")
36 int handle_sys_enter(struct pt_regs *ctx)
37 {
38 	int i;
39 
40 	kern_ver = LINUX_KERNEL_VERSION;
41 	bpf_syscall = CONFIG_BPF_SYSCALL;
42 	tristate_val = CONFIG_TRISTATE;
43 	bool_val = CONFIG_BOOL;
44 	char_val = CONFIG_CHAR;
45 	ushort_val = CONFIG_USHORT;
46 	int_val = CONFIG_INT;
47 	ulong_val = CONFIG_ULONG;
48 
49 	for (i = 0; i < sizeof(CONFIG_STR); i++) {
50 		str_val[i] = CONFIG_STR[i];
51 	}
52 
53 	if (CONFIG_MISSING)
54 		/* invalid, but dead code - never executed */
55 		missing_val = bpf_missing_helper(ctx, 123);
56 	else
57 		missing_val = 0xDEADC0DE;
58 
59 	return 0;
60 }
61 
62 char _license[] SEC("license") = "GPL";
63