129e1c668SAndrii Nakryiko // SPDX-License-Identifier: GPL-2.0
229e1c668SAndrii Nakryiko // Copyright (c) 2019 Facebook
329e1c668SAndrii Nakryiko 
429e1c668SAndrii Nakryiko #include <linux/bpf.h>
529e1c668SAndrii 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>
829e1c668SAndrii Nakryiko 
929e1c668SAndrii Nakryiko char _license[] SEC("license") = "GPL";
1029e1c668SAndrii Nakryiko 
11393cdfbeSAndrii Nakryiko struct {
1229e1c668SAndrii Nakryiko 	char in[256];
1329e1c668SAndrii Nakryiko 	char out[256];
14393cdfbeSAndrii Nakryiko } data = {};
1529e1c668SAndrii Nakryiko 
1629e1c668SAndrii Nakryiko struct core_reloc_misc_output {
1729e1c668SAndrii Nakryiko 	int a, b, c;
1829e1c668SAndrii Nakryiko };
1929e1c668SAndrii Nakryiko 
2029e1c668SAndrii Nakryiko struct core_reloc_misc___a {
2129e1c668SAndrii Nakryiko 	int a1;
2229e1c668SAndrii Nakryiko 	int a2;
2329e1c668SAndrii Nakryiko };
2429e1c668SAndrii Nakryiko 
2529e1c668SAndrii Nakryiko struct core_reloc_misc___b {
2629e1c668SAndrii Nakryiko 	int b1;
2729e1c668SAndrii Nakryiko 	int b2;
2829e1c668SAndrii Nakryiko };
2929e1c668SAndrii Nakryiko 
3029e1c668SAndrii Nakryiko /* fixed two first members, can be extended with new fields */
3129e1c668SAndrii Nakryiko struct core_reloc_misc_extensible {
3229e1c668SAndrii Nakryiko 	int a;
3329e1c668SAndrii Nakryiko 	int b;
3429e1c668SAndrii Nakryiko };
3529e1c668SAndrii Nakryiko 
36694731e8SAndrii Nakryiko #define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
37694731e8SAndrii Nakryiko 
3829e1c668SAndrii Nakryiko SEC("raw_tracepoint/sys_enter")
test_core_misc(void * ctx)3929e1c668SAndrii Nakryiko int test_core_misc(void *ctx)
4029e1c668SAndrii Nakryiko {
4129e1c668SAndrii Nakryiko 	struct core_reloc_misc___a *in_a = (void *)&data.in;
4229e1c668SAndrii Nakryiko 	struct core_reloc_misc___b *in_b = (void *)&data.in;
4329e1c668SAndrii Nakryiko 	struct core_reloc_misc_extensible *in_ext = (void *)&data.in;
4429e1c668SAndrii Nakryiko 	struct core_reloc_misc_output *out = (void *)&data.out;
4529e1c668SAndrii Nakryiko 
4629e1c668SAndrii Nakryiko 	/* record two different relocations with the same accessor string */
47694731e8SAndrii Nakryiko 	if (CORE_READ(&out->a, &in_a->a1) ||		/* accessor: 0:0 */
48694731e8SAndrii Nakryiko 	    CORE_READ(&out->b, &in_b->b1))		/* accessor: 0:0 */
4929e1c668SAndrii Nakryiko 		return 1;
5029e1c668SAndrii Nakryiko 
5129e1c668SAndrii Nakryiko 	/* Validate relocations capture array-only accesses for structs with
5229e1c668SAndrii Nakryiko 	 * fixed header, but with potentially extendable tail. This will read
5329e1c668SAndrii Nakryiko 	 * first 4 bytes of 2nd element of in_ext array of potentially
5429e1c668SAndrii Nakryiko 	 * variably sized struct core_reloc_misc_extensible. */
55694731e8SAndrii Nakryiko 	if (CORE_READ(&out->c, &in_ext[2]))		/* accessor: 2 */
5629e1c668SAndrii Nakryiko 		return 1;
5729e1c668SAndrii Nakryiko 
5829e1c668SAndrii Nakryiko 	return 0;
5929e1c668SAndrii Nakryiko }
6029e1c668SAndrii Nakryiko 
61