| // SPDX-License-Identifier: GPL-2.0 |
| /* Copyright (c) 2019 Facebook */ |
| |
| #include <stdbool.h> |
| #include <linux/bpf.h> |
| #include <bpf/bpf_helpers.h> |
| |
| #define __read_mostly SEC(".data.read_mostly") |
| |
| struct s { |
| int a; |
| long long b; |
| } __attribute__((packed)); |
| |
| /* .data section */ |
| int in1 = -1; |
| long long in2 = -1; |
| |
| /* .bss section */ |
| char in3 = '\0'; |
| long long in4 __attribute__((aligned(64))) = 0; |
| struct s in5 = {}; |
| |
| /* .rodata section */ |
| const volatile struct { |
| const int in6; |
| } in = {}; |
| |
| /* .data section */ |
| int out1 = -1; |
| long long out2 = -1; |
| |
| /* .bss section */ |
| char out3 = 0; |
| long long out4 = 0; |
| int out6 = 0; |
| |
| extern bool CONFIG_BPF_SYSCALL __kconfig; |
| extern int LINUX_KERNEL_VERSION __kconfig; |
| bool bpf_syscall = 0; |
| int kern_ver = 0; |
| |
| struct s out5 = {}; |
| |
| |
| const volatile int in_dynarr_sz SEC(".rodata.dyn"); |
| const volatile int in_dynarr[4] SEC(".rodata.dyn") = { -1, -2, -3, -4 }; |
| |
| int out_dynarr[4] SEC(".data.dyn") = { 1, 2, 3, 4 }; |
| |
| int read_mostly_var __read_mostly; |
| int out_mostly_var; |
| |
| char huge_arr[16 * 1024 * 1024]; |
| |
| SEC("raw_tp/sys_enter") |
| int handler(const void *ctx) |
| { |
| int i; |
| |
| out1 = in1; |
| out2 = in2; |
| out3 = in3; |
| out4 = in4; |
| out5 = in5; |
| out6 = in.in6; |
| |
| bpf_syscall = CONFIG_BPF_SYSCALL; |
| kern_ver = LINUX_KERNEL_VERSION; |
| |
| for (i = 0; i < in_dynarr_sz; i++) |
| out_dynarr[i] = in_dynarr[i]; |
| |
| out_mostly_var = read_mostly_var; |
| |
| huge_arr[sizeof(huge_arr) - 1] = 123; |
| |
| return 0; |
| } |
| |
| char _license[] SEC("license") = "GPL"; |