1*67e74705SXin Li // RUN: %clang_cc1 -triple=x86_64-apple-darwin10 -emit-llvm -fexceptions %s -o - |FileCheck %s 2*67e74705SXin Li // RUN: %clang_cc1 -triple=x86_64-apple-darwin10 -emit-llvm %s -o - |FileCheck -check-prefix CHECK-NOEXC %s 3*67e74705SXin Li // RUN: %clang_cc1 -triple=x86_64-apple-darwin10 -emit-llvm \ 4*67e74705SXin Li // RUN: -momit-leaf-frame-pointer -mdisable-fp-elim %s -o - \ 5*67e74705SXin Li // RUN: | FileCheck -check-prefix CHECK-FP %s 6*67e74705SXin Li 7*67e74705SXin Li struct A { 8*67e74705SXin Li A(); 9*67e74705SXin Li ~A(); 10*67e74705SXin Li }; 11*67e74705SXin Li 12*67e74705SXin Li struct B { B(); ~B(); }; 13*67e74705SXin Li 14*67e74705SXin Li struct C { void *field; }; 15*67e74705SXin Li 16*67e74705SXin Li struct D { ~D(); }; 17*67e74705SXin Li 18*67e74705SXin Li // CHECK: @__dso_handle = external global i8 19*67e74705SXin Li // CHECK: @c = global %struct.C zeroinitializer, align 8 20*67e74705SXin Li 21*67e74705SXin Li // It's okay if we ever implement the IR-generation optimization to remove this. 22*67e74705SXin Li // CHECK: @_ZN5test3L3varE = internal constant i8* getelementptr inbounds ([7 x i8], [7 x i8]* 23*67e74705SXin Li 24*67e74705SXin Li // PR6205: The casts should not require global initializers 25*67e74705SXin Li // CHECK: @_ZN6PR59741cE = external global %"struct.PR5974::C" 26*67e74705SXin Li // CHECK: @_ZN6PR59741aE = global %"struct.PR5974::A"* getelementptr inbounds (%"struct.PR5974::C", %"struct.PR5974::C"* @_ZN6PR59741cE, i32 0, i32 0) 27*67e74705SXin Li // CHECK: @_ZN6PR59741bE = global %"struct.PR5974::B"* bitcast (i8* getelementptr (i8, i8* bitcast (%"struct.PR5974::C"* @_ZN6PR59741cE to i8*), i64 4) to %"struct.PR5974::B"*), align 8 28*67e74705SXin Li 29*67e74705SXin Li // CHECK: call void @_ZN1AC1Ev(%struct.A* @a) 30*67e74705SXin Li // CHECK: call i32 @__cxa_atexit(void (i8*)* bitcast (void (%struct.A*)* @_ZN1AD1Ev to void (i8*)*), i8* getelementptr inbounds (%struct.A, %struct.A* @a, i32 0, i32 0), i8* @__dso_handle) 31*67e74705SXin Li A a; 32*67e74705SXin Li 33*67e74705SXin Li // CHECK: call void @_ZN1BC1Ev(%struct.B* @b) 34*67e74705SXin Li // CHECK: call i32 @__cxa_atexit(void (i8*)* bitcast (void (%struct.B*)* @_ZN1BD1Ev to void (i8*)*), i8* getelementptr inbounds (%struct.B, %struct.B* @b, i32 0, i32 0), i8* @__dso_handle) 35*67e74705SXin Li B b; 36*67e74705SXin Li 37*67e74705SXin Li // PR6205: this should not require a global initializer 38*67e74705SXin Li // CHECK-NOT: call void @_ZN1CC1Ev(%struct.C* @c) 39*67e74705SXin Li C c; 40*67e74705SXin Li 41*67e74705SXin Li // CHECK: call i32 @__cxa_atexit(void (i8*)* bitcast (void (%struct.D*)* @_ZN1DD1Ev to void (i8*)*), i8* getelementptr inbounds (%struct.D, %struct.D* @d, i32 0, i32 0), i8* @__dso_handle) 42*67e74705SXin Li D d; 43*67e74705SXin Li 44*67e74705SXin Li // <rdar://problem/7458115> 45*67e74705SXin Li namespace test1 { 46*67e74705SXin Li int f(); 47*67e74705SXin Li const int x = f(); // This has side-effects and gets emitted immediately. 48*67e74705SXin Li const int y = x - 1; // This gets deferred. 49*67e74705SXin Li const int z = ~y; // This also gets deferred, but gets "undeferred" before y. test()50*67e74705SXin Li int test() { return z; } 51*67e74705SXin Li // CHECK-LABEL: define i32 @_ZN5test14testEv() 52*67e74705SXin Li 53*67e74705SXin Li // All of these initializers end up delayed, so we check them later. 54*67e74705SXin Li } 55*67e74705SXin Li 56*67e74705SXin Li // <rdar://problem/8246444> 57*67e74705SXin Li namespace test2 { 58*67e74705SXin Li struct allocator { allocator(); ~allocator(); }; 59*67e74705SXin Li struct A { A(const allocator &a = allocator()); ~A(); }; 60*67e74705SXin Li 61*67e74705SXin Li A a; 62*67e74705SXin Li // CHECK: call void @_ZN5test29allocatorC1Ev( 63*67e74705SXin Li // CHECK: invoke void @_ZN5test21AC1ERKNS_9allocatorE( 64*67e74705SXin Li // CHECK: call void @_ZN5test29allocatorD1Ev( 65*67e74705SXin Li // CHECK: call i32 @__cxa_atexit({{.*}} @_ZN5test21AD1Ev {{.*}} @_ZN5test21aE 66*67e74705SXin Li } 67*67e74705SXin Li 68*67e74705SXin Li namespace test3 { 69*67e74705SXin Li // Tested at the beginning of the file. 70*67e74705SXin Li const char * const var = "string"; 71*67e74705SXin Li extern const char * const var; 72*67e74705SXin Li test()73*67e74705SXin Li const char *test() { return var; } 74*67e74705SXin Li } 75*67e74705SXin Li 76*67e74705SXin Li namespace test4 { 77*67e74705SXin Li struct A { 78*67e74705SXin Li A(); 79*67e74705SXin Li }; 80*67e74705SXin Li extern int foo(); 81*67e74705SXin Li 82*67e74705SXin Li // This needs an initialization function and guard variables. 83*67e74705SXin Li // CHECK: load i8, i8* bitcast (i64* @_ZGVN5test41xE 84*67e74705SXin Li // CHECK: [[CALL:%.*]] = call i32 @_ZN5test43fooEv 85*67e74705SXin Li // CHECK-NEXT: store i32 [[CALL]], i32* @_ZN5test41xE 86*67e74705SXin Li // CHECK-NEXT: store i64 1, i64* @_ZGVN5test41xE 87*67e74705SXin Li __attribute__((weak)) int x = foo(); 88*67e74705SXin Li } 89*67e74705SXin Li 90*67e74705SXin Li namespace PR5974 { 91*67e74705SXin Li struct A { int a; }; 92*67e74705SXin Li struct B { int b; }; 93*67e74705SXin Li struct C : A, B { int c; }; 94*67e74705SXin Li 95*67e74705SXin Li extern C c; 96*67e74705SXin Li 97*67e74705SXin Li // These should not require global initializers. 98*67e74705SXin Li A* a = &c; 99*67e74705SXin Li B* b = &c; 100*67e74705SXin Li } 101*67e74705SXin Li 102*67e74705SXin Li // PR9570: the indirect field shouldn't crash IR gen. 103*67e74705SXin Li namespace test5 { 104*67e74705SXin Li static union { 105*67e74705SXin Li unsigned bar[4096] __attribute__((aligned(128))); 106*67e74705SXin Li }; 107*67e74705SXin Li } 108*67e74705SXin Li 109*67e74705SXin Li namespace std { struct type_info; } 110*67e74705SXin Li 111*67e74705SXin Li namespace test6 { 112*67e74705SXin Li struct A { virtual ~A(); }; 113*67e74705SXin Li struct B : A {}; 114*67e74705SXin Li extern A *p; 115*67e74705SXin Li 116*67e74705SXin Li // We must emit a dynamic initializer for 'q', because it could throw. 117*67e74705SXin Li B *const q = &dynamic_cast<B&>(*p); 118*67e74705SXin Li // CHECK: call void @__cxa_bad_cast() 119*67e74705SXin Li // CHECK: store {{.*}} @_ZN5test6L1qE 120*67e74705SXin Li 121*67e74705SXin Li // We don't need to emit 'r' at all, because it has internal linkage, is 122*67e74705SXin Li // unused, and its initialization has no side-effects. 123*67e74705SXin Li B *const r = dynamic_cast<B*>(p); 124*67e74705SXin Li // CHECK-NOT: call void @__cxa_bad_cast() 125*67e74705SXin Li // CHECK-NOT: store {{.*}} @_ZN5test6L1rE 126*67e74705SXin Li 127*67e74705SXin Li // This can throw, so we need to emit it. 128*67e74705SXin Li const std::type_info *const s = &typeid(*p); 129*67e74705SXin Li // CHECK: store {{.*}} @_ZN5test6L1sE 130*67e74705SXin Li 131*67e74705SXin Li // This can't throw, so we don't. 132*67e74705SXin Li const std::type_info *const t = &typeid(p); 133*67e74705SXin Li // CHECK-NOT: @_ZN5test6L1tE 134*67e74705SXin Li 135*67e74705SXin Li extern B *volatile v; 136*67e74705SXin Li // CHECK: store {{.*}} @_ZN5test6L1wE 137*67e74705SXin Li B *const w = dynamic_cast<B*>(v); 138*67e74705SXin Li 139*67e74705SXin Li // CHECK: load volatile 140*67e74705SXin Li // CHECK: store {{.*}} @_ZN5test6L1xE 141*67e74705SXin Li const int x = *(volatile int*)0x1234; 142*67e74705SXin Li 143*67e74705SXin Li namespace { 144*67e74705SXin Li int a = int(); 145*67e74705SXin Li volatile int b = int(); 146*67e74705SXin Li int c = a; 147*67e74705SXin Li int d = b; 148*67e74705SXin Li // CHECK-NOT: store {{.*}} @_ZN5test6{{[A-Za-z0-9_]*}}1aE 149*67e74705SXin Li // CHECK-NOT: store {{.*}} @_ZN5test6{{[A-Za-z0-9_]*}}1bE 150*67e74705SXin Li // CHECK-NOT: store {{.*}} @_ZN5test6{{[A-Za-z0-9_]*}}1cE 151*67e74705SXin Li // CHECK: load volatile {{.*}} @_ZN5test6{{[A-Za-z0-9_]*}}1bE 152*67e74705SXin Li // CHECK: store {{.*}} @_ZN5test6{{[A-Za-z0-9_]*}}1dE 153*67e74705SXin Li } 154*67e74705SXin Li } 155*67e74705SXin Li 156*67e74705SXin Li namespace test7 { 157*67e74705SXin Li struct A { A(); }; 158*67e74705SXin Li struct B { ~B(); int n; }; 159*67e74705SXin Li struct C { C() = default; C(const C&); int n; }; 160*67e74705SXin Li struct D {}; 161*67e74705SXin Li 162*67e74705SXin Li // CHECK: call void @_ZN5test71AC1Ev({{.*}}@_ZN5test7L1aE) 163*67e74705SXin Li const A a = A(); 164*67e74705SXin Li 165*67e74705SXin Li // CHECK: call i32 @__cxa_atexit({{.*}} @_ZN5test71BD1Ev{{.*}} @_ZN5test7L2b1E 166*67e74705SXin Li // CHECK: call i32 @__cxa_atexit({{.*}} @_ZN5test71BD1Ev{{.*}} @_ZGRN5test72b2E 167*67e74705SXin Li // CHECK: call void @_ZN5test71BD1Ev( 168*67e74705SXin Li // CHECK: store {{.*}} @_ZN5test7L2b3E 169*67e74705SXin Li const B b1 = B(); 170*67e74705SXin Li const B &b2 = B(); 171*67e74705SXin Li const int b3 = B().n; 172*67e74705SXin Li 173*67e74705SXin Li // CHECK-NOT: @_ZN5test7L2c1E 174*67e74705SXin Li // CHECK: @_ZN5test7L2c2E 175*67e74705SXin Li // CHECK-NOT: @_ZN5test7L2c3E 176*67e74705SXin Li // CHECK: @_ZN5test7L2c4E 177*67e74705SXin Li const C c1 = C(); 178*67e74705SXin Li const C c2 = static_cast<const C&>(C()); 179*67e74705SXin Li const int c3 = C().n; 180*67e74705SXin Li const int c4 = C(C()).n; 181*67e74705SXin Li 182*67e74705SXin Li // CHECK-NOT: @_ZN5test7L1dE 183*67e74705SXin Li const D d = D(); 184*67e74705SXin Li 185*67e74705SXin Li // CHECK: store {{.*}} @_ZN5test71eE 186*67e74705SXin Li int f(), e = f(); 187*67e74705SXin Li } 188*67e74705SXin Li 189*67e74705SXin Li 190*67e74705SXin Li // At the end of the file, we check that y is initialized before z. 191*67e74705SXin Li 192*67e74705SXin Li // CHECK: define internal void [[TEST1_Z_INIT:@.*]]() 193*67e74705SXin Li // CHECK: load i32, i32* @_ZN5test1L1yE 194*67e74705SXin Li // CHECK-NEXT: xor 195*67e74705SXin Li // CHECK-NEXT: store i32 {{.*}}, i32* @_ZN5test1L1zE 196*67e74705SXin Li // CHECK: define internal void [[TEST1_Y_INIT:@.*]]() 197*67e74705SXin Li // CHECK: load i32, i32* @_ZN5test1L1xE 198*67e74705SXin Li // CHECK-NEXT: sub 199*67e74705SXin Li // CHECK-NEXT: store i32 {{.*}}, i32* @_ZN5test1L1yE 200*67e74705SXin Li 201*67e74705SXin Li // CHECK: define internal void @_GLOBAL__sub_I_global_init.cpp() #{{[0-9]+}} section "__TEXT,__StaticInit,regular,pure_instructions" { 202*67e74705SXin Li // CHECK: call void [[TEST1_Y_INIT]] 203*67e74705SXin Li // CHECK: call void [[TEST1_Z_INIT]] 204*67e74705SXin Li 205*67e74705SXin Li // rdar://problem/8090834: this should be nounwind 206*67e74705SXin Li // CHECK-NOEXC: define internal void @_GLOBAL__sub_I_global_init.cpp() [[NUW:#[0-9]+]] section "__TEXT,__StaticInit,regular,pure_instructions" { 207*67e74705SXin Li 208*67e74705SXin Li // CHECK-NOEXC: attributes [[NUW]] = { nounwind{{.*}} } 209*67e74705SXin Li 210*67e74705SXin Li // PR21811: attach the appropriate attribute to the global init function 211*67e74705SXin Li // CHECK-FP: define internal void @_GLOBAL__sub_I_global_init.cpp() [[NUX:#[0-9]+]] section "__TEXT,__StaticInit,regular,pure_instructions" { 212*67e74705SXin Li // CHECK-FP: attributes [[NUX]] = { nounwind {{.*}}"no-frame-pointer-elim-non-leaf"{{.*}} } 213