120a9ad2eSAndrii Nakryiko // SPDX-License-Identifier: GPL-2.0
220a9ad2eSAndrii Nakryiko // Copyright (c) 2019 Facebook
320a9ad2eSAndrii Nakryiko 
420a9ad2eSAndrii Nakryiko #include <linux/bpf.h>
520a9ad2eSAndrii Nakryiko #include <stdint.h>
63e689141SToke Høiland-Jørgensen #include <bpf/bpf_helpers.h>
73e689141SToke Høiland-Jørgensen #include <bpf/bpf_core_read.h>
820a9ad2eSAndrii Nakryiko 
920a9ad2eSAndrii Nakryiko char _license[] SEC("license") = "GPL";
1020a9ad2eSAndrii Nakryiko 
11393cdfbeSAndrii Nakryiko struct {
1220a9ad2eSAndrii Nakryiko 	char in[256];
1320a9ad2eSAndrii Nakryiko 	char out[256];
14393cdfbeSAndrii Nakryiko } data = {};
1520a9ad2eSAndrii Nakryiko 
1620a9ad2eSAndrii Nakryiko struct core_reloc_arrays_output {
1720a9ad2eSAndrii Nakryiko 	int a2;
1820a9ad2eSAndrii Nakryiko 	char b123;
1920a9ad2eSAndrii Nakryiko 	int c1c;
2020a9ad2eSAndrii Nakryiko 	int d00d;
215f2eecefSAndrii Nakryiko 	int f01c;
2220a9ad2eSAndrii Nakryiko };
2320a9ad2eSAndrii Nakryiko 
2420a9ad2eSAndrii Nakryiko struct core_reloc_arrays_substruct {
2520a9ad2eSAndrii Nakryiko 	int c;
2620a9ad2eSAndrii Nakryiko 	int d;
2720a9ad2eSAndrii Nakryiko };
2820a9ad2eSAndrii Nakryiko 
2920a9ad2eSAndrii Nakryiko struct core_reloc_arrays {
3020a9ad2eSAndrii Nakryiko 	int a[5];
3120a9ad2eSAndrii Nakryiko 	char b[2][3][4];
3220a9ad2eSAndrii Nakryiko 	struct core_reloc_arrays_substruct c[3];
3320a9ad2eSAndrii Nakryiko 	struct core_reloc_arrays_substruct d[1][2];
345f2eecefSAndrii Nakryiko 	struct core_reloc_arrays_substruct f[][2];
3520a9ad2eSAndrii Nakryiko };
3620a9ad2eSAndrii Nakryiko 
37694731e8SAndrii Nakryiko #define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
38694731e8SAndrii Nakryiko 
3920a9ad2eSAndrii Nakryiko SEC("raw_tracepoint/sys_enter")
test_core_arrays(void * ctx)4020a9ad2eSAndrii Nakryiko int test_core_arrays(void *ctx)
4120a9ad2eSAndrii Nakryiko {
4220a9ad2eSAndrii Nakryiko 	struct core_reloc_arrays *in = (void *)&data.in;
4320a9ad2eSAndrii Nakryiko 	struct core_reloc_arrays_output *out = (void *)&data.out;
4420a9ad2eSAndrii Nakryiko 
45694731e8SAndrii Nakryiko 	if (CORE_READ(&out->a2, &in->a[2]))
4620a9ad2eSAndrii Nakryiko 		return 1;
47694731e8SAndrii Nakryiko 	if (CORE_READ(&out->b123, &in->b[1][2][3]))
4820a9ad2eSAndrii Nakryiko 		return 1;
49694731e8SAndrii Nakryiko 	if (CORE_READ(&out->c1c, &in->c[1].c))
5020a9ad2eSAndrii Nakryiko 		return 1;
51694731e8SAndrii Nakryiko 	if (CORE_READ(&out->d00d, &in->d[0][0].d))
5220a9ad2eSAndrii Nakryiko 		return 1;
535f2eecefSAndrii Nakryiko 	if (CORE_READ(&out->f01c, &in->f[0][1].c))
545f2eecefSAndrii Nakryiko 		return 1;
5520a9ad2eSAndrii Nakryiko 
5620a9ad2eSAndrii Nakryiko 	return 0;
5720a9ad2eSAndrii Nakryiko }
5820a9ad2eSAndrii Nakryiko 
59