1*f4db3dd5SYonghong Song // SPDX-License-Identifier: GPL-2.0
2*f4db3dd5SYonghong Song /* Copyright (c) 2022 Meta Platforms, Inc. and affiliates. */
3*f4db3dd5SYonghong Song 
4*f4db3dd5SYonghong Song #include <linux/bpf.h>
5*f4db3dd5SYonghong Song #include <stdint.h>
6*f4db3dd5SYonghong Song #include <stdbool.h>
7*f4db3dd5SYonghong Song #include <bpf/bpf_helpers.h>
8*f4db3dd5SYonghong Song #include <bpf/bpf_core_read.h>
9*f4db3dd5SYonghong Song 
10*f4db3dd5SYonghong Song char _license[] SEC("license") = "GPL";
11*f4db3dd5SYonghong Song 
12*f4db3dd5SYonghong Song struct {
13*f4db3dd5SYonghong Song 	char in[256];
14*f4db3dd5SYonghong Song 	char out[256];
15*f4db3dd5SYonghong Song 	bool skip;
16*f4db3dd5SYonghong Song } data = {};
17*f4db3dd5SYonghong Song 
18*f4db3dd5SYonghong Song enum named_unsigned_enum64 {
19*f4db3dd5SYonghong Song 	UNSIGNED_ENUM64_VAL1 = 0x1ffffffffULL,
20*f4db3dd5SYonghong Song 	UNSIGNED_ENUM64_VAL2 = 0x2ffffffffULL,
21*f4db3dd5SYonghong Song 	UNSIGNED_ENUM64_VAL3 = 0x3ffffffffULL,
22*f4db3dd5SYonghong Song };
23*f4db3dd5SYonghong Song 
24*f4db3dd5SYonghong Song enum named_signed_enum64 {
25*f4db3dd5SYonghong Song 	SIGNED_ENUM64_VAL1 = 0x1ffffffffLL,
26*f4db3dd5SYonghong Song 	SIGNED_ENUM64_VAL2 = -2,
27*f4db3dd5SYonghong Song 	SIGNED_ENUM64_VAL3 = 0x3ffffffffLL,
28*f4db3dd5SYonghong Song };
29*f4db3dd5SYonghong Song 
30*f4db3dd5SYonghong Song struct core_reloc_enum64val_output {
31*f4db3dd5SYonghong Song 	bool unsigned_val1_exists;
32*f4db3dd5SYonghong Song 	bool unsigned_val2_exists;
33*f4db3dd5SYonghong Song 	bool unsigned_val3_exists;
34*f4db3dd5SYonghong Song 	bool signed_val1_exists;
35*f4db3dd5SYonghong Song 	bool signed_val2_exists;
36*f4db3dd5SYonghong Song 	bool signed_val3_exists;
37*f4db3dd5SYonghong Song 
38*f4db3dd5SYonghong Song 	long unsigned_val1;
39*f4db3dd5SYonghong Song 	long unsigned_val2;
40*f4db3dd5SYonghong Song 	long signed_val1;
41*f4db3dd5SYonghong Song 	long signed_val2;
42*f4db3dd5SYonghong Song };
43*f4db3dd5SYonghong Song 
44*f4db3dd5SYonghong Song SEC("raw_tracepoint/sys_enter")
test_core_enum64val(void * ctx)45*f4db3dd5SYonghong Song int test_core_enum64val(void *ctx)
46*f4db3dd5SYonghong Song {
47*f4db3dd5SYonghong Song #if __clang_major__ >= 15
48*f4db3dd5SYonghong Song 	struct core_reloc_enum64val_output *out = (void *)&data.out;
49*f4db3dd5SYonghong Song 	enum named_unsigned_enum64 named_unsigned = 0;
50*f4db3dd5SYonghong Song 	enum named_signed_enum64 named_signed = 0;
51*f4db3dd5SYonghong Song 
52*f4db3dd5SYonghong Song 	out->unsigned_val1_exists = bpf_core_enum_value_exists(named_unsigned, UNSIGNED_ENUM64_VAL1);
53*f4db3dd5SYonghong Song 	out->unsigned_val2_exists = bpf_core_enum_value_exists(enum named_unsigned_enum64, UNSIGNED_ENUM64_VAL2);
54*f4db3dd5SYonghong Song 	out->unsigned_val3_exists = bpf_core_enum_value_exists(enum named_unsigned_enum64, UNSIGNED_ENUM64_VAL3);
55*f4db3dd5SYonghong Song 	out->signed_val1_exists = bpf_core_enum_value_exists(named_signed, SIGNED_ENUM64_VAL1);
56*f4db3dd5SYonghong Song 	out->signed_val2_exists = bpf_core_enum_value_exists(enum named_signed_enum64, SIGNED_ENUM64_VAL2);
57*f4db3dd5SYonghong Song 	out->signed_val3_exists = bpf_core_enum_value_exists(enum named_signed_enum64, SIGNED_ENUM64_VAL3);
58*f4db3dd5SYonghong Song 
59*f4db3dd5SYonghong Song 	out->unsigned_val1 = bpf_core_enum_value(named_unsigned, UNSIGNED_ENUM64_VAL1);
60*f4db3dd5SYonghong Song 	out->unsigned_val2 = bpf_core_enum_value(named_unsigned, UNSIGNED_ENUM64_VAL2);
61*f4db3dd5SYonghong Song 	out->signed_val1 = bpf_core_enum_value(named_signed, SIGNED_ENUM64_VAL1);
62*f4db3dd5SYonghong Song 	out->signed_val2 = bpf_core_enum_value(named_signed, SIGNED_ENUM64_VAL2);
63*f4db3dd5SYonghong Song 	/* NAMED_ENUM64_VAL3 value is optional */
64*f4db3dd5SYonghong Song 
65*f4db3dd5SYonghong Song #else
66*f4db3dd5SYonghong Song 	data.skip = true;
67*f4db3dd5SYonghong Song #endif
68*f4db3dd5SYonghong Song 
69*f4db3dd5SYonghong Song 	return 0;
70*f4db3dd5SYonghong Song }
71