[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / RISCV / miss-sp-restore-eh.ll
blobb7c0a9f292738dacad23b0d05c6578d00333df10
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv64 -mattr=+v,+m < %s \
3 ; RUN:     | FileCheck %s
6 @_ZTIi = external dso_local constant ptr
8 declare void @_Z3fooiiiiiiiiiiPi(i32 signext %0, i32 signext %1, i32 signext %2, i32 signext %3, i32 signext %4, i32 signext %5, i32 signext %6, i32 signext %7, i32 %8, i32 %9, i32 %10)
10 declare dso_local ptr @__cxa_allocate_exception(i64)
12 declare dso_local void @__cxa_throw(ptr, ptr, ptr)
14 define signext i32 @foo() #1 personality ptr @__gxx_personality_v0 {
15 ; CHECK-LABEL: foo:
16 ; CHECK:       # %bb.0: # %entry
17 ; CHECK-NEXT:    addi sp, sp, -32
18 ; CHECK-NEXT:    .cfi_def_cfa_offset 32
19 ; CHECK-NEXT:    sd ra, 24(sp) # 8-byte Folded Spill
20 ; CHECK-NEXT:    sd s0, 16(sp) # 8-byte Folded Spill
21 ; CHECK-NEXT:    sd s1, 8(sp) # 8-byte Folded Spill
22 ; CHECK-NEXT:    .cfi_offset ra, -8
23 ; CHECK-NEXT:    .cfi_offset s0, -16
24 ; CHECK-NEXT:    .cfi_offset s1, -24
25 ; CHECK-NEXT:    addi s0, sp, 32
26 ; CHECK-NEXT:    .cfi_def_cfa s0, 0
27 ; CHECK-NEXT:  .Ltmp0:
28 ; CHECK-NEXT:    addi sp, sp, -32
29 ; CHECK-NEXT:    li a0, 0
30 ; CHECK-NEXT:    li a1, 0
31 ; CHECK-NEXT:    li a2, 0
32 ; CHECK-NEXT:    li a3, 0
33 ; CHECK-NEXT:    li a4, 0
34 ; CHECK-NEXT:    li a5, 0
35 ; CHECK-NEXT:    li a6, 0
36 ; CHECK-NEXT:    li a7, 0
37 ; CHECK-NEXT:    call _Z3fooiiiiiiiiiiPi@plt
38 ; CHECK-NEXT:    addi sp, sp, 32
39 ; CHECK-NEXT:  .Ltmp1:
40 ; CHECK-NEXT:  # %bb.1: # %try.cont.unreachable
41 ; CHECK-NEXT:  .LBB0_2: # %lpad
42 ; CHECK-NEXT:  .Ltmp2:
43 ; CHECK-NEXT:    sext.w a1, a1
44 ; CHECK-NEXT:    li a2, 1
45 ; CHECK-NEXT:    bne a1, a2, .LBB0_4
46 ; CHECK-NEXT:  # %bb.3: # %catch
47 ; CHECK-NEXT:    call __cxa_begin_catch@plt
48 ; CHECK-NEXT:    lw s1, 0(a0)
49 ; CHECK-NEXT:    call __cxa_end_catch@plt
50 ; CHECK-NEXT:    mv a0, s1
51 ; CHECK-NEXT:    addi sp, s0, -32
52 ; CHECK-NEXT:    ld ra, 24(sp) # 8-byte Folded Reload
53 ; CHECK-NEXT:    ld s0, 16(sp) # 8-byte Folded Reload
54 ; CHECK-NEXT:    ld s1, 8(sp) # 8-byte Folded Reload
55 ; CHECK-NEXT:    addi sp, sp, 32
56 ; CHECK-NEXT:    ret
57 ; CHECK-NEXT:  .LBB0_4: # %ehcleanup
58 ; CHECK-NEXT:    call _Unwind_Resume@plt
59 entry:
60   invoke void @_Z3fooiiiiiiiiiiPi(i32 signext poison, i32 signext poison, i32 signext poison, i32 signext poison, i32 signext poison, i32 signext poison, i32 signext poison, i32 signext poison, i32 poison, i32 poison, i32 poison)
61           to label %try.cont.unreachable unwind label %lpad
63 lpad:
64   %0 = landingpad { ptr, i32 }
65           cleanup
66           catch ptr @_ZTIi
67   %1 = extractvalue { ptr, i32 } %0, 1
68   %2 = call i32 @llvm.eh.typeid.for(ptr nonnull @_ZTIi)
69   %matches = icmp eq i32 %1, %2
70   br i1 %matches, label %catch, label %ehcleanup
72 catch:
73   %3 = extractvalue { ptr, i32 } %0, 0
74   %4 = call ptr @__cxa_begin_catch(ptr %3)
75   %5 = load i32, ptr %4, align 4
76   call void @__cxa_end_catch()
77   ret i32 %5
79 try.cont.unreachable:
80   unreachable
82 ehcleanup:
83   resume { ptr, i32 } %0
86 declare i32 @__gxx_personality_v0(...)
88 declare i32 @llvm.eh.typeid.for(ptr)
90 declare ptr @__cxa_begin_catch(ptr)
91 declare void @__cxa_end_catch()
93 attributes #1 = { "frame-pointer"="all"}