1 // SPDX-License-Identifier: GPL-2.0
2 // Copyright (c) 2019 Facebook
3
4 #include <linux/bpf.h>
5 #include <stdint.h>
6 #include <bpf/bpf_helpers.h>
7 #include <bpf/bpf_core_read.h>
8
9 char _license[] SEC("license") = "GPL";
10
11 struct {
12 char in[256];
13 char out[256];
14 } data = {};
15
16 struct core_reloc_mods_output {
17 int a, b, c, d, e, f, g, h;
18 };
19
20 typedef const int int_t;
21 typedef const char *char_ptr_t;
22 typedef const int arr_t[7];
23
24 struct core_reloc_mods_substruct {
25 int x;
26 int y;
27 };
28
29 typedef struct {
30 int x;
31 int y;
32 } core_reloc_mods_substruct_t;
33
34 struct core_reloc_mods {
35 int a;
36 int_t b;
37 char *c;
38 char_ptr_t d;
39 int e[3];
40 arr_t f;
41 struct core_reloc_mods_substruct g;
42 core_reloc_mods_substruct_t h;
43 };
44
45 #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
46 #define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
47 #else
48 #define CORE_READ(dst, src) ({ \
49 int __sz = sizeof(*(dst)) < sizeof(*(src)) ? sizeof(*(dst)) : \
50 sizeof(*(src)); \
51 bpf_core_read((char *)(dst) + sizeof(*(dst)) - __sz, __sz, \
52 (const char *)(src) + sizeof(*(src)) - __sz); \
53 })
54 #endif
55
56 SEC("raw_tracepoint/sys_enter")
test_core_mods(void * ctx)57 int test_core_mods(void *ctx)
58 {
59 struct core_reloc_mods *in = (void *)&data.in;
60 struct core_reloc_mods_output *out = (void *)&data.out;
61
62 if (CORE_READ(&out->a, &in->a) ||
63 CORE_READ(&out->b, &in->b) ||
64 CORE_READ(&out->c, &in->c) ||
65 CORE_READ(&out->d, &in->d) ||
66 CORE_READ(&out->e, &in->e[2]) ||
67 CORE_READ(&out->f, &in->f[1]) ||
68 CORE_READ(&out->g, &in->g.x) ||
69 CORE_READ(&out->h, &in->h.y))
70 return 1;
71
72 return 0;
73 }
74
75