annotate clang/test/CodeGen/packed-arrays.c @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children c4bab56944e8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: %clang_cc1 -triple x86_64-unk-unk -emit-llvm -Os -o %t %s
anatofuz
parents:
diff changeset
2 // RUN: FileCheck < %t %s
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 struct s0 {
anatofuz
parents:
diff changeset
5 unsigned int x[2] __attribute__((packed));
anatofuz
parents:
diff changeset
6 };
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 struct s1 {
anatofuz
parents:
diff changeset
9 unsigned int x[2] __attribute__((packed));
anatofuz
parents:
diff changeset
10 unsigned int y;
anatofuz
parents:
diff changeset
11 unsigned int z __attribute__((packed));
anatofuz
parents:
diff changeset
12 };
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 struct s2 {
anatofuz
parents:
diff changeset
15 unsigned int x[2] __attribute__((packed));
anatofuz
parents:
diff changeset
16 unsigned int y __attribute__((packed));
anatofuz
parents:
diff changeset
17 unsigned int z __attribute__((packed));
anatofuz
parents:
diff changeset
18 };
anatofuz
parents:
diff changeset
19
anatofuz
parents:
diff changeset
20 struct __attribute__((packed)) s3 {
anatofuz
parents:
diff changeset
21 unsigned int x[2];
anatofuz
parents:
diff changeset
22 unsigned int y;
anatofuz
parents:
diff changeset
23 unsigned int z;
anatofuz
parents:
diff changeset
24 };
anatofuz
parents:
diff changeset
25
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
26 // CHECK: @align0 ={{.*}} local_unnamed_addr global i32 1
150
anatofuz
parents:
diff changeset
27 int align0 = __alignof(struct s0);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
28 // CHECK: @align1 ={{.*}} local_unnamed_addr global i32 4
150
anatofuz
parents:
diff changeset
29 int align1 = __alignof(struct s1);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
30 // CHECK: @align2 ={{.*}} local_unnamed_addr global i32 1
150
anatofuz
parents:
diff changeset
31 int align2 = __alignof(struct s2);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
32 // CHECK: @align3 ={{.*}} local_unnamed_addr global i32 1
150
anatofuz
parents:
diff changeset
33 int align3 = __alignof(struct s3);
anatofuz
parents:
diff changeset
34
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
35 // CHECK: @align0_x ={{.*}} local_unnamed_addr global i32 1
150
anatofuz
parents:
diff changeset
36 int align0_x = __alignof(((struct s0*) 0)->x);
anatofuz
parents:
diff changeset
37 //
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
38 // CHECK: @align1_x ={{.*}} local_unnamed_addr global i32 1
150
anatofuz
parents:
diff changeset
39 int align1_x = __alignof(((struct s1*) 0)->x);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
40 // CHECK: @align2_x ={{.*}} local_unnamed_addr global i32 1
150
anatofuz
parents:
diff changeset
41 int align2_x = __alignof(((struct s2*) 0)->x);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
42 // CHECK: @align3_x ={{.*}} local_unnamed_addr global i32 1
150
anatofuz
parents:
diff changeset
43 int align3_x = __alignof(((struct s3*) 0)->x);
anatofuz
parents:
diff changeset
44
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
45 // CHECK: @align0_x0 ={{.*}} local_unnamed_addr global i32 4
150
anatofuz
parents:
diff changeset
46 int align0_x0 = __alignof(((struct s0*) 0)->x[0]);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
47 // CHECK: @align1_x0 ={{.*}} local_unnamed_addr global i32 4
150
anatofuz
parents:
diff changeset
48 int align1_x0 = __alignof(((struct s1*) 0)->x[0]);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
49 // CHECK: @align2_x0 ={{.*}} local_unnamed_addr global i32 4
150
anatofuz
parents:
diff changeset
50 int align2_x0 = __alignof(((struct s2*) 0)->x[0]);
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
51 // CHECK: @align3_x0 ={{.*}} local_unnamed_addr global i32 4
150
anatofuz
parents:
diff changeset
52 int align3_x0 = __alignof(((struct s3*) 0)->x[0]);
anatofuz
parents:
diff changeset
53
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
54 // CHECK-LABEL: define{{.*}} i32 @f0_a
150
anatofuz
parents:
diff changeset
55 // CHECK: load i32, i32* %{{.*}}, align 1
anatofuz
parents:
diff changeset
56 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
57 // CHECK-LABEL: define{{.*}} i32 @f0_b
150
anatofuz
parents:
diff changeset
58 // CHECK: load i32, i32* %{{.*}}, align 4
anatofuz
parents:
diff changeset
59 // CHECK: }
anatofuz
parents:
diff changeset
60 int f0_a(struct s0 *a) {
anatofuz
parents:
diff changeset
61 return a->x[1];
anatofuz
parents:
diff changeset
62 }
anatofuz
parents:
diff changeset
63 int f0_b(struct s0 *a) {
anatofuz
parents:
diff changeset
64 return *(a->x + 1);
anatofuz
parents:
diff changeset
65 }
anatofuz
parents:
diff changeset
66
anatofuz
parents:
diff changeset
67 // Note that 'y' still causes struct s1 to be four-byte aligned.
anatofuz
parents:
diff changeset
68
anatofuz
parents:
diff changeset
69 // Note that we are incompatible with GCC on this example.
anatofuz
parents:
diff changeset
70 //
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
71 // CHECK-LABEL: define{{.*}} i32 @f1_a
150
anatofuz
parents:
diff changeset
72 // CHECK: load i32, i32* %{{.*}}, align 4
anatofuz
parents:
diff changeset
73 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
74 // CHECK-LABEL: define{{.*}} i32 @f1_b
150
anatofuz
parents:
diff changeset
75 // CHECK: load i32, i32* %{{.*}}, align 4
anatofuz
parents:
diff changeset
76 // CHECK: }
anatofuz
parents:
diff changeset
77
anatofuz
parents:
diff changeset
78 // Note that we are incompatible with GCC on this example.
anatofuz
parents:
diff changeset
79 //
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
80 // CHECK-LABEL: define{{.*}} i32 @f1_c
150
anatofuz
parents:
diff changeset
81 // CHECK: load i32, i32* %{{.*}}, align 4
anatofuz
parents:
diff changeset
82 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
83 // CHECK-LABEL: define{{.*}} i32 @f1_d
150
anatofuz
parents:
diff changeset
84 // CHECK: load i32, i32* %{{.*}}, align 4
anatofuz
parents:
diff changeset
85 // CHECK: }
anatofuz
parents:
diff changeset
86 int f1_a(struct s1 *a) {
anatofuz
parents:
diff changeset
87 return a->x[1];
anatofuz
parents:
diff changeset
88 }
anatofuz
parents:
diff changeset
89 int f1_b(struct s1 *a) {
anatofuz
parents:
diff changeset
90 return *(a->x + 1);
anatofuz
parents:
diff changeset
91 }
anatofuz
parents:
diff changeset
92 int f1_c(struct s1 *a) {
anatofuz
parents:
diff changeset
93 return a->y;
anatofuz
parents:
diff changeset
94 }
anatofuz
parents:
diff changeset
95 int f1_d(struct s1 *a) {
anatofuz
parents:
diff changeset
96 return a->z;
anatofuz
parents:
diff changeset
97 }
anatofuz
parents:
diff changeset
98
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
99 // CHECK-LABEL: define{{.*}} i32 @f2_a
150
anatofuz
parents:
diff changeset
100 // CHECK: load i32, i32* %{{.*}}, align 1
anatofuz
parents:
diff changeset
101 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
102 // CHECK-LABEL: define{{.*}} i32 @f2_b
150
anatofuz
parents:
diff changeset
103 // CHECK: load i32, i32* %{{.*}}, align 4
anatofuz
parents:
diff changeset
104 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
105 // CHECK-LABEL: define{{.*}} i32 @f2_c
150
anatofuz
parents:
diff changeset
106 // CHECK: load i32, i32* %{{.*}}, align 1
anatofuz
parents:
diff changeset
107 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
108 // CHECK-LABEL: define{{.*}} i32 @f2_d
150
anatofuz
parents:
diff changeset
109 // CHECK: load i32, i32* %{{.*}}, align 1
anatofuz
parents:
diff changeset
110 // CHECK: }
anatofuz
parents:
diff changeset
111 int f2_a(struct s2 *a) {
anatofuz
parents:
diff changeset
112 return a->x[1];
anatofuz
parents:
diff changeset
113 }
anatofuz
parents:
diff changeset
114 int f2_b(struct s2 *a) {
anatofuz
parents:
diff changeset
115 return *(a->x + 1);
anatofuz
parents:
diff changeset
116 }
anatofuz
parents:
diff changeset
117 int f2_c(struct s2 *a) {
anatofuz
parents:
diff changeset
118 return a->y;
anatofuz
parents:
diff changeset
119 }
anatofuz
parents:
diff changeset
120 int f2_d(struct s2 *a) {
anatofuz
parents:
diff changeset
121 return a->z;
anatofuz
parents:
diff changeset
122 }
anatofuz
parents:
diff changeset
123
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
124 // CHECK-LABEL: define{{.*}} i32 @f3_a
150
anatofuz
parents:
diff changeset
125 // CHECK: load i32, i32* %{{.*}}, align 1
anatofuz
parents:
diff changeset
126 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
127 // CHECK-LABEL: define{{.*}} i32 @f3_b
150
anatofuz
parents:
diff changeset
128 // CHECK: load i32, i32* %{{.*}}, align 4
anatofuz
parents:
diff changeset
129 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
130 // CHECK-LABEL: define{{.*}} i32 @f3_c
150
anatofuz
parents:
diff changeset
131 // CHECK: load i32, i32* %{{.*}}, align 1
anatofuz
parents:
diff changeset
132 // CHECK: }
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
133 // CHECK-LABEL: define{{.*}} i32 @f3_d
150
anatofuz
parents:
diff changeset
134 // CHECK: load i32, i32* %{{.*}}, align 1
anatofuz
parents:
diff changeset
135 // CHECK: }
anatofuz
parents:
diff changeset
136 int f3_a(struct s3 *a) {
anatofuz
parents:
diff changeset
137 return a->x[1];
anatofuz
parents:
diff changeset
138 }
anatofuz
parents:
diff changeset
139 int f3_b(struct s3 *a) {
anatofuz
parents:
diff changeset
140 return *(a->x + 1);
anatofuz
parents:
diff changeset
141 }
anatofuz
parents:
diff changeset
142 int f3_c(struct s3 *a) {
anatofuz
parents:
diff changeset
143 return a->y;
anatofuz
parents:
diff changeset
144 }
anatofuz
parents:
diff changeset
145 int f3_d(struct s3 *a) {
anatofuz
parents:
diff changeset
146 return a->z;
anatofuz
parents:
diff changeset
147 }
anatofuz
parents:
diff changeset
148
anatofuz
parents:
diff changeset
149 // Verify we don't claim things are overaligned.
anatofuz
parents:
diff changeset
150 //
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
151 // CHECK-LABEL: define{{.*}} double @f4
150
anatofuz
parents:
diff changeset
152 // CHECK: load double, double* {{.*}}, align 8
anatofuz
parents:
diff changeset
153 // CHECK: }
anatofuz
parents:
diff changeset
154 extern double g4[5] __attribute__((aligned(16)));
anatofuz
parents:
diff changeset
155 double f4() {
anatofuz
parents:
diff changeset
156 return g4[1];
anatofuz
parents:
diff changeset
157 }