1*9880d681SAndroid Build Coastguard Worker; RUN: llc -regalloc=greedy -mtriple=x86_64-pc-windows-msvc < %s -o - | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; This test checks for proper handling of a condition where the greedy register 4*9880d681SAndroid Build Coastguard Worker; allocator encounters a very short interval that contains no uses but does 5*9880d681SAndroid Build Coastguard Worker; contain an EH pad unwind edge, which requires spilling. Previously the 6*9880d681SAndroid Build Coastguard Worker; register allocator marked a interval like this as unspillable, resulting in 7*9880d681SAndroid Build Coastguard Worker; a compilation failure. 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker; The following checks that the value %p is reloaded within the catch handler. 11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: "?catch$8@?0?test@4HA": 12*9880d681SAndroid Build Coastguard Worker; CHECK: .seh_endprologue 13*9880d681SAndroid Build Coastguard Worker; CHECK: movq -16(%rbp), %rax 14*9880d681SAndroid Build Coastguard Worker; CHECK: movb $0, (%rax) 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Workerdefine i32* @test(i32* %a) personality i8* bitcast (i32 (...)* @__CxxFrameHandler3 to i8*) { 17*9880d681SAndroid Build Coastguard Workerentry: 18*9880d681SAndroid Build Coastguard Worker %call = call i32 @f() 19*9880d681SAndroid Build Coastguard Worker %p = bitcast i32* %a to i8* 20*9880d681SAndroid Build Coastguard Worker br i1 undef, label %if.end, label %if.else 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Workerif.else: ; preds = %entry 23*9880d681SAndroid Build Coastguard Worker br i1 undef, label %cond.false.i, label %if.else.else 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Workerif.else.else: ; preds = %if.else 26*9880d681SAndroid Build Coastguard Worker br i1 undef, label %cond.true.i, label %cond.false.i 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Workercond.true.i: ; preds = %if.else.else 29*9880d681SAndroid Build Coastguard Worker br label %invoke.cont 30*9880d681SAndroid Build Coastguard Worker 31*9880d681SAndroid Build Coastguard Workercond.false.i: ; preds = %if.else.else, %if.else 32*9880d681SAndroid Build Coastguard Worker %call.i = invoke i32 @f() 33*9880d681SAndroid Build Coastguard Worker to label %invoke.cont unwind label %catch.dispatch 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Workercatch.dispatch: ; preds = %cond.false.i 36*9880d681SAndroid Build Coastguard Worker %tmp0 = catchswitch within none [label %catch] unwind label %ehcleanup 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Workercatch: ; preds = %catch.dispatch 39*9880d681SAndroid Build Coastguard Worker %tmp1 = catchpad within %tmp0 [i8* null, i32 64, i8* null] 40*9880d681SAndroid Build Coastguard Worker %p.0 = getelementptr inbounds i8, i8* %p, i64 0 41*9880d681SAndroid Build Coastguard Worker store i8 0, i8* %p.0, align 8 42*9880d681SAndroid Build Coastguard Worker invoke void @_CxxThrowException(i8* null, %eh.ThrowInfo* null) [ "funclet"(token %tmp1) ] 43*9880d681SAndroid Build Coastguard Worker to label %noexc unwind label %ehcleanup 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Workernoexc: ; preds = %catch 46*9880d681SAndroid Build Coastguard Worker unreachable 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerinvoke.cont: ; preds = %cond.false.i, %cond.true.i 49*9880d681SAndroid Build Coastguard Worker %cond.i = phi i32 [ %call, %cond.true.i ], [ %call.i, %cond.false.i ] 50*9880d681SAndroid Build Coastguard Worker %cmp = icmp eq i32 %cond.i, -1 51*9880d681SAndroid Build Coastguard Worker %tmp3 = select i1 %cmp, i32 4, i32 0 52*9880d681SAndroid Build Coastguard Worker br label %if.end 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Workerif.end: ; preds = %invoke.cont, %entry 55*9880d681SAndroid Build Coastguard Worker %state.0 = phi i32 [ %tmp3, %invoke.cont ], [ 4, %entry ] 56*9880d681SAndroid Build Coastguard Worker %p.1 = getelementptr inbounds i8, i8* %p, i64 0 57*9880d681SAndroid Build Coastguard Worker invoke void @g(i8* %p.1, i32 %state.0) 58*9880d681SAndroid Build Coastguard Worker to label %invoke.cont.1 unwind label %ehcleanup 59*9880d681SAndroid Build Coastguard Worker 60*9880d681SAndroid Build Coastguard Workerinvoke.cont.1: ; preds = %if.end 61*9880d681SAndroid Build Coastguard Worker ret i32* %a 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Workerehcleanup: ; preds = %if.end, %catch, %catch.dispatch 64*9880d681SAndroid Build Coastguard Worker %tmp4 = cleanuppad within none [] 65*9880d681SAndroid Build Coastguard Worker cleanupret from %tmp4 unwind to caller 66*9880d681SAndroid Build Coastguard Worker} 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker%eh.ThrowInfo = type { i32, i32, i32, i32 } 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Workerdeclare i32 @__CxxFrameHandler3(...) 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Workerdeclare void @_CxxThrowException(i8*, %eh.ThrowInfo*) 73*9880d681SAndroid Build Coastguard Worker 74*9880d681SAndroid Build Coastguard Workerdeclare i32 @f() 75*9880d681SAndroid Build Coastguard Workerdeclare void @g(i8*, i32) 76