xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/regalloc-spill-at-ehpad.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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