1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; 3*9880d681SAndroid Build Coastguard Worker; PR27612. The following spill is hoisted from two locations: the fall 4*9880d681SAndroid Build Coastguard Worker; through succ block and the landingpad block of a call which may throw 5*9880d681SAndroid Build Coastguard Worker; exception. If it is not hoisted before the call, the spill will be 6*9880d681SAndroid Build Coastguard Worker; missing on the landingpad path. 7*9880d681SAndroid Build Coastguard Worker; 8*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: _Z3foov: 9*9880d681SAndroid Build Coastguard Worker; CHECK: movq %rbx, (%rsp) # 8-byte Spill 10*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: callq _Z3goov 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" 13*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-unknown-linux-gnu" 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker@a = global [20 x i64] zeroinitializer, align 16 16*9880d681SAndroid Build Coastguard Worker@_ZTIi = external constant i8* 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Worker; Function Attrs: uwtable 19*9880d681SAndroid Build Coastguard Workerdefine void @_Z3foov() personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) { 20*9880d681SAndroid Build Coastguard Workerentry: 21*9880d681SAndroid Build Coastguard Worker %tmp = load i64, i64* getelementptr inbounds ([20 x i64], [20 x i64]* @a, i64 0, i64 1), align 8 22*9880d681SAndroid Build Coastguard Worker invoke void @_Z3goov() 23*9880d681SAndroid Build Coastguard Worker to label %try.cont unwind label %lpad 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Workerlpad: ; preds = %entry 26*9880d681SAndroid Build Coastguard Worker %tmp1 = landingpad { i8*, i32 } 27*9880d681SAndroid Build Coastguard Worker cleanup 28*9880d681SAndroid Build Coastguard Worker catch i8* bitcast (i8** @_ZTIi to i8*) 29*9880d681SAndroid Build Coastguard Worker %tmp2 = extractvalue { i8*, i32 } %tmp1, 1 30*9880d681SAndroid Build Coastguard Worker %tmp3 = tail call i32 @llvm.eh.typeid.for(i8* bitcast (i8** @_ZTIi to i8*)) 31*9880d681SAndroid Build Coastguard Worker %matches = icmp eq i32 %tmp2, %tmp3 32*9880d681SAndroid Build Coastguard Worker br i1 %matches, label %catch, label %ehcleanup 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Workercatch: ; preds = %lpad 35*9880d681SAndroid Build Coastguard Worker %tmp4 = extractvalue { i8*, i32 } %tmp1, 0 36*9880d681SAndroid Build Coastguard Worker %tmp5 = tail call i8* @__cxa_begin_catch(i8* %tmp4) 37*9880d681SAndroid Build Coastguard Worker store i64 %tmp, i64* getelementptr inbounds ([20 x i64], [20 x i64]* @a, i64 0, i64 2), align 16 38*9880d681SAndroid Build Coastguard Worker tail call void asm sideeffect "", "~{rax},~{rbx},~{rcx},~{rdx},~{rsi},~{rdi},~{rbp},~{r8},~{r9},~{r10},~{r11},~{r12},~{r13},~{r14},~{r15},~{memory},~{dirflag},~{fpsr},~{flags}"() 39*9880d681SAndroid Build Coastguard Worker store i64 %tmp, i64* getelementptr inbounds ([20 x i64], [20 x i64]* @a, i64 0, i64 3), align 8 40*9880d681SAndroid Build Coastguard Worker tail call void @__cxa_end_catch() 41*9880d681SAndroid Build Coastguard Worker br label %try.cont 42*9880d681SAndroid Build Coastguard Worker 43*9880d681SAndroid Build Coastguard Workertry.cont: ; preds = %catch, %entry 44*9880d681SAndroid Build Coastguard Worker store i64 %tmp, i64* getelementptr inbounds ([20 x i64], [20 x i64]* @a, i64 0, i64 4), align 16 45*9880d681SAndroid Build Coastguard Worker tail call void asm sideeffect "", "~{rax},~{rbx},~{rcx},~{rdx},~{rsi},~{rdi},~{rbp},~{r8},~{r9},~{r10},~{r11},~{r12},~{r13},~{r14},~{r15},~{memory},~{dirflag},~{fpsr},~{flags}"() 46*9880d681SAndroid Build Coastguard Worker store i64 %tmp, i64* getelementptr inbounds ([20 x i64], [20 x i64]* @a, i64 0, i64 5), align 8 47*9880d681SAndroid Build Coastguard Worker ret void 48*9880d681SAndroid Build Coastguard Worker 49*9880d681SAndroid Build Coastguard Workerehcleanup: ; preds = %lpad 50*9880d681SAndroid Build Coastguard Worker resume { i8*, i32 } %tmp1 51*9880d681SAndroid Build Coastguard Worker} 52*9880d681SAndroid Build Coastguard Worker 53*9880d681SAndroid Build Coastguard Workerdeclare void @_Z3goov() 54*9880d681SAndroid Build Coastguard Worker 55*9880d681SAndroid Build Coastguard Workerdeclare i32 @__gxx_personality_v0(...) 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind readnone 58*9880d681SAndroid Build Coastguard Workerdeclare i32 @llvm.eh.typeid.for(i8*) 59*9880d681SAndroid Build Coastguard Worker 60*9880d681SAndroid Build Coastguard Workerdeclare i8* @__cxa_begin_catch(i8*) 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Workerdeclare void @__cxa_end_catch() 63