1 // RUN: %clang_cc1 -triple x86_64-unknown-unknown %s -Wno-strict-prototypes -emit-llvm -o - | FileCheck %s
7 int y
=__alignof__(zxcv
);
18 int test2(void) { if (test2b
); return 0; }
22 const unsigned char *bp
;
26 // PR2080 - sizeof void
27 int t1
= sizeof(void);
28 int t2
= __alignof__(void);
31 t2
= __alignof__(void);
34 t2
= __alignof__(test4());
37 // 'const float' promotes to double in varargs.
38 int test5(const float x
, float float_number
) {
39 return __builtin_isless(x
, float_number
);
42 // this one shouldn't fold
45 if ((0, (int)a
) & 2) { return 1; }
49 // this one shouldn't fold as well
57 void f0(void (*fp
)(void), void (*fp2
)(void)) {
61 // noop casts as lvalues.
67 return ((struct X
)foo()).Y
+ 1;
70 // PR3809: INC/DEC of function pointers.
73 void (*fp
)(void) = f2
;
82 union f3_x
{int x
; float y
;};
83 int f3(void) {return ((union f3_x
)2).x
;}
85 union f4_y
{int x
; _Complex
float y
;};
86 _Complex
float f4(void) {return ((union f4_y
)(_Complex
float)2.0).y
;}
88 struct f5_a
{ int a
; } f5_a
;
89 union f5_z
{int x
; struct f5_a y
;};
90 struct f5_a
f5(void) {return ((union f5_z
)f5_a
).y
;}
93 struct s6
{ int f0
; };
94 int f6(int a0
, struct s6 a1
, struct s6 a2
) {
95 return (a0
? a1
: a2
).f0
;
105 return ({ foo(); }).Y
;
114 struct S
{ struct C c
; };
115 void f9(struct S
*x
) {
116 foo(((void)1, x
->c
).tab
[0]);
124 // CHECK-LABEL: define{{.*}} i32 @f11
129 // CHECK: [[Xaddr:%[^ ]+]] = alloca i64, align 8
130 // CHECK: [[A:%.*]] = alloca [100 x i32], align
131 // CHECK: [[X:%.*]] = load {{.*}}, ptr [[Xaddr]]
132 // CHECK-NEXT: [[T0:%.*]] = getelementptr inbounds [100 x i32], ptr [[A]], i64 0, i64 [[X]]
133 // CHECK-NEXT: load i32, ptr [[T0]], align 4
138 // CHECK-LABEL: define{{.*}} i32 @f12
143 // Make sure negate of fp uses -0.0 for proper -0 handling.
144 double f13(double X
) {
145 // CHECK-LABEL: define{{.*}} double @f13
146 // CHECK: fneg double
150 // Check operations on incomplete types.
151 void f14(struct s14
*a
) {
155 // CHECK-LABEL: define{{.*}} void @f15
157 extern void f15_start(void);
159 // CHECK: call void @f15_start()
161 extern void *f15_v(void);
162 extern const void *f15_cv(void);
163 extern volatile void *f15_vv(void);
164 *f15_v(); *f15_v(), *f15_v(); f15_v() ? *f15_v() : *f15_v();
165 *f15_cv(); *f15_cv(), *f15_cv(); f15_cv() ? *f15_cv() : *f15_cv();
166 *f15_vv(); *f15_vv(), *f15_vv(); f15_vv() ? *f15_vv() : *f15_vv();
171 // PR8967: this was crashing
172 // CHECK-LABEL: define{{.*}} void @f16()
174 __extension__({ goto lbl
; });
179 // PR13704: negative increment in i128 is not preserved.
180 // CHECK-LABEL: define{{.*}} void @f17()
182 extern void extfunc(__int128
);
186 // CHECK: add nsw i128 %{{.}}, -1
189 // PR23597: We should evaluate union cast operands even if the cast is unused.
193 int returns_int(void);
195 (strct
)returns_int();
197 // CHECK-LABEL: define{{.*}} void @f18()
198 // CHECK: call i32 @returns_int()
200 // Ensure the right stmt is returned
204 // CHECK-LABEL: define{{.*}} i32 @f19()
205 // CHECK: [[T:%.*]] = alloca i32
206 // CHECK: store i32 4, ptr [[T]]
207 // CHECK: [[L:%.*]] = load i32, ptr [[T]]
208 // CHECK: ret i32 [[L]]