aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/RISCV/machine-outliner-throw.ll
blob: 2de29fe2fa68a96514373fdfd3c191f779ae7b6f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -verify-machineinstrs -enable-machine-outliner -mattr=+m -mtriple=riscv64 < %s | FileCheck %s

; Ensure that we won't outline CFIs when they are needed in unwinding.

define i32 @func1(i32 %x) #0 {
; CHECK-LABEL: func1:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addi sp, sp, -16
; CHECK-NEXT:    .cfi_def_cfa_offset 16
; CHECK-NEXT:    sd ra, 8(sp) # 8-byte Folded Spill
; CHECK-NEXT:    sd s0, 0(sp) # 8-byte Folded Spill
; CHECK-NEXT:    .cfi_offset ra, -8
; CHECK-NEXT:    .cfi_offset s0, -16
; CHECK-NEXT:    mul a0, a0, a0
; CHECK-NEXT:    addi s0, a0, 1
; CHECK-NEXT:    li a0, 4
; CHECK-NEXT:    call __cxa_allocate_exception
; CHECK-NEXT:    sw s0, 0(a0)
; CHECK-NEXT:    lui a1, %hi(_ZTIi)
; CHECK-NEXT:    addi a1, a1, %lo(_ZTIi)
; CHECK-NEXT:    li a2, 0
; CHECK-NEXT:    call __cxa_throw
entry:
  %mul = mul i32 %x, %x
  %add = add i32 %mul, 1
  %exception = tail call ptr @__cxa_allocate_exception(i64 4)
  store i32 %add, ptr %exception
  tail call void @__cxa_throw(ptr %exception, ptr @_ZTIi, ptr null)
  unreachable
}

define i32 @func2(i32 %x) #0 {
; CHECK-LABEL: func2:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addi sp, sp, -16
; CHECK-NEXT:    .cfi_def_cfa_offset 16
; CHECK-NEXT:    sd ra, 8(sp) # 8-byte Folded Spill
; CHECK-NEXT:    sd s0, 0(sp) # 8-byte Folded Spill
; CHECK-NEXT:    .cfi_offset ra, -8
; CHECK-NEXT:    .cfi_offset s0, -16
; CHECK-NEXT:    mul a0, a0, a0
; CHECK-NEXT:    addi s0, a0, 1
; CHECK-NEXT:    li a0, 4
; CHECK-NEXT:    call __cxa_allocate_exception
; CHECK-NEXT:    sw s0, 0(a0)
; CHECK-NEXT:    lui a1, %hi(_ZTIi)
; CHECK-NEXT:    addi a1, a1, %lo(_ZTIi)
; CHECK-NEXT:    li a2, 0
; CHECK-NEXT:    call __cxa_throw
entry:
  %mul = mul i32 %x, %x
  %add = add i32 %mul, 1
  %exception = tail call ptr @__cxa_allocate_exception(i64 4)
  store i32 %add, ptr %exception
  tail call void @__cxa_throw(ptr %exception, ptr @_ZTIi, ptr null)
  unreachable
}

@_ZTIi = external constant ptr
declare ptr @__cxa_allocate_exception(i64)
declare void @__cxa_throw(ptr, ptr, ptr)

attributes #0 = { minsize noreturn }