[clang] Handle __declspec() attributes in using
[llvm-project.git] / clang / test / CodeGen / bpf-attr-preserve-access-index-5.c
blobd987e134cc1c5c4c2b303370171de248f69b523e
1 // REQUIRES: bpf-registered-target
2 // RUN: %clang_cc1 -no-opaque-pointers -triple bpf -emit-llvm -debug-info-kind=limited -disable-llvm-passes %s -o - | FileCheck %s
4 #define __reloc__ __attribute__((preserve_access_index))
6 // chain of records, attribute may be in inner record.
7 struct s1 {
8 int c;
9 } __reloc__;
10 typedef struct s1 __s1;
12 struct s2 {
13 union {
14 __s1 b[3];
15 } __reloc__;
17 typedef struct s2 __s2;
19 struct s3 {
20 __s2 a;
21 } __reloc__;
22 typedef struct s3 __s3;
24 int test(__s3 *arg) {
25 return arg->a.b[2].c;
28 // CHECK: call %struct.s2* @llvm.preserve.struct.access.index.p0s_struct.s2s.p0s_struct.s3s(%struct.s3* elementtype(%struct.s3) %{{[0-9a-z]+}}, i32 0, i32 0)
29 // CHECK-NOT: call %union.anon* @llvm.preserve.struct.access.index.p0s_union.anons.p0s_struct.s2s
30 // CHECK: call %union.anon* @llvm.preserve.union.access.index.p0s_union.anons.p0s_union.anons(%union.anon* %{{[0-9a-z]+}}, i32 0)
31 // CHECK: call %struct.s1* @llvm.preserve.array.access.index.p0s_struct.s1s.p0a3s_struct.s1s([3 x %struct.s1]* elementtype([3 x %struct.s1]) %{{[0-9a-z]+}}, i32 1, i32 2)
32 // CHECK: call i32* @llvm.preserve.struct.access.index.p0i32.p0s_struct.s1s(%struct.s1* elementtype(%struct.s1) %{{[0-9a-z]+}}, i32 0, i32 0)