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