Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / CodeGen / RISCV / frameaddr-returnaddr.ll
blob478c8457997ae31965d9ab90d6faf81f52e78a1a
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv32 -verify-machineinstrs < %s \
3 ; RUN:   | FileCheck -check-prefix=RV32I %s
4 ; RUN: llc -mtriple=riscv64 -verify-machineinstrs < %s \
5 ; RUN:   | FileCheck -check-prefix=RV64I %s
7 declare void @notdead(ptr)
8 declare ptr @llvm.frameaddress(i32)
9 declare ptr @llvm.returnaddress(i32)
11 define ptr @test_frameaddress_0() nounwind {
12 ; RV32I-LABEL: test_frameaddress_0:
13 ; RV32I:       # %bb.0:
14 ; RV32I-NEXT:    addi sp, sp, -16
15 ; RV32I-NEXT:    sw ra, 12(sp) # 4-byte Folded Spill
16 ; RV32I-NEXT:    sw s0, 8(sp) # 4-byte Folded Spill
17 ; RV32I-NEXT:    addi s0, sp, 16
18 ; RV32I-NEXT:    mv a0, s0
19 ; RV32I-NEXT:    lw ra, 12(sp) # 4-byte Folded Reload
20 ; RV32I-NEXT:    lw s0, 8(sp) # 4-byte Folded Reload
21 ; RV32I-NEXT:    addi sp, sp, 16
22 ; RV32I-NEXT:    ret
24 ; RV64I-LABEL: test_frameaddress_0:
25 ; RV64I:       # %bb.0:
26 ; RV64I-NEXT:    addi sp, sp, -16
27 ; RV64I-NEXT:    sd ra, 8(sp) # 8-byte Folded Spill
28 ; RV64I-NEXT:    sd s0, 0(sp) # 8-byte Folded Spill
29 ; RV64I-NEXT:    addi s0, sp, 16
30 ; RV64I-NEXT:    mv a0, s0
31 ; RV64I-NEXT:    ld ra, 8(sp) # 8-byte Folded Reload
32 ; RV64I-NEXT:    ld s0, 0(sp) # 8-byte Folded Reload
33 ; RV64I-NEXT:    addi sp, sp, 16
34 ; RV64I-NEXT:    ret
35   %1 = call ptr @llvm.frameaddress(i32 0)
36   ret ptr %1
39 define ptr @test_frameaddress_2() nounwind {
40 ; RV32I-LABEL: test_frameaddress_2:
41 ; RV32I:       # %bb.0:
42 ; RV32I-NEXT:    addi sp, sp, -16
43 ; RV32I-NEXT:    sw ra, 12(sp) # 4-byte Folded Spill
44 ; RV32I-NEXT:    sw s0, 8(sp) # 4-byte Folded Spill
45 ; RV32I-NEXT:    addi s0, sp, 16
46 ; RV32I-NEXT:    lw a0, -8(s0)
47 ; RV32I-NEXT:    lw a0, -8(a0)
48 ; RV32I-NEXT:    lw ra, 12(sp) # 4-byte Folded Reload
49 ; RV32I-NEXT:    lw s0, 8(sp) # 4-byte Folded Reload
50 ; RV32I-NEXT:    addi sp, sp, 16
51 ; RV32I-NEXT:    ret
53 ; RV64I-LABEL: test_frameaddress_2:
54 ; RV64I:       # %bb.0:
55 ; RV64I-NEXT:    addi sp, sp, -16
56 ; RV64I-NEXT:    sd ra, 8(sp) # 8-byte Folded Spill
57 ; RV64I-NEXT:    sd s0, 0(sp) # 8-byte Folded Spill
58 ; RV64I-NEXT:    addi s0, sp, 16
59 ; RV64I-NEXT:    ld a0, -16(s0)
60 ; RV64I-NEXT:    ld a0, -16(a0)
61 ; RV64I-NEXT:    ld ra, 8(sp) # 8-byte Folded Reload
62 ; RV64I-NEXT:    ld s0, 0(sp) # 8-byte Folded Reload
63 ; RV64I-NEXT:    addi sp, sp, 16
64 ; RV64I-NEXT:    ret
65   %1 = call ptr @llvm.frameaddress(i32 2)
66   ret ptr %1
69 define ptr @test_frameaddress_3_alloca() nounwind {
70 ; RV32I-LABEL: test_frameaddress_3_alloca:
71 ; RV32I:       # %bb.0:
72 ; RV32I-NEXT:    addi sp, sp, -112
73 ; RV32I-NEXT:    sw ra, 108(sp) # 4-byte Folded Spill
74 ; RV32I-NEXT:    sw s0, 104(sp) # 4-byte Folded Spill
75 ; RV32I-NEXT:    addi s0, sp, 112
76 ; RV32I-NEXT:    addi a0, s0, -108
77 ; RV32I-NEXT:    call notdead
78 ; RV32I-NEXT:    lw a0, -8(s0)
79 ; RV32I-NEXT:    lw a0, -8(a0)
80 ; RV32I-NEXT:    lw a0, -8(a0)
81 ; RV32I-NEXT:    lw ra, 108(sp) # 4-byte Folded Reload
82 ; RV32I-NEXT:    lw s0, 104(sp) # 4-byte Folded Reload
83 ; RV32I-NEXT:    addi sp, sp, 112
84 ; RV32I-NEXT:    ret
86 ; RV64I-LABEL: test_frameaddress_3_alloca:
87 ; RV64I:       # %bb.0:
88 ; RV64I-NEXT:    addi sp, sp, -128
89 ; RV64I-NEXT:    sd ra, 120(sp) # 8-byte Folded Spill
90 ; RV64I-NEXT:    sd s0, 112(sp) # 8-byte Folded Spill
91 ; RV64I-NEXT:    addi s0, sp, 128
92 ; RV64I-NEXT:    addi a0, s0, -116
93 ; RV64I-NEXT:    call notdead
94 ; RV64I-NEXT:    ld a0, -16(s0)
95 ; RV64I-NEXT:    ld a0, -16(a0)
96 ; RV64I-NEXT:    ld a0, -16(a0)
97 ; RV64I-NEXT:    ld ra, 120(sp) # 8-byte Folded Reload
98 ; RV64I-NEXT:    ld s0, 112(sp) # 8-byte Folded Reload
99 ; RV64I-NEXT:    addi sp, sp, 128
100 ; RV64I-NEXT:    ret
101   %1 = alloca [100 x i8]
102   call void @notdead(ptr %1)
103   %2 = call ptr @llvm.frameaddress(i32 3)
104   ret ptr %2
107 define ptr @test_returnaddress_0() nounwind {
108 ; RV32I-LABEL: test_returnaddress_0:
109 ; RV32I:       # %bb.0:
110 ; RV32I-NEXT:    mv a0, ra
111 ; RV32I-NEXT:    ret
113 ; RV64I-LABEL: test_returnaddress_0:
114 ; RV64I:       # %bb.0:
115 ; RV64I-NEXT:    mv a0, ra
116 ; RV64I-NEXT:    ret
117   %1 = call ptr @llvm.returnaddress(i32 0)
118   ret ptr %1
121 define ptr @test_returnaddress_2() nounwind {
122 ; RV32I-LABEL: test_returnaddress_2:
123 ; RV32I:       # %bb.0:
124 ; RV32I-NEXT:    addi sp, sp, -16
125 ; RV32I-NEXT:    sw ra, 12(sp) # 4-byte Folded Spill
126 ; RV32I-NEXT:    sw s0, 8(sp) # 4-byte Folded Spill
127 ; RV32I-NEXT:    addi s0, sp, 16
128 ; RV32I-NEXT:    lw a0, -8(s0)
129 ; RV32I-NEXT:    lw a0, -8(a0)
130 ; RV32I-NEXT:    lw a0, -4(a0)
131 ; RV32I-NEXT:    lw ra, 12(sp) # 4-byte Folded Reload
132 ; RV32I-NEXT:    lw s0, 8(sp) # 4-byte Folded Reload
133 ; RV32I-NEXT:    addi sp, sp, 16
134 ; RV32I-NEXT:    ret
136 ; RV64I-LABEL: test_returnaddress_2:
137 ; RV64I:       # %bb.0:
138 ; RV64I-NEXT:    addi sp, sp, -16
139 ; RV64I-NEXT:    sd ra, 8(sp) # 8-byte Folded Spill
140 ; RV64I-NEXT:    sd s0, 0(sp) # 8-byte Folded Spill
141 ; RV64I-NEXT:    addi s0, sp, 16
142 ; RV64I-NEXT:    ld a0, -16(s0)
143 ; RV64I-NEXT:    ld a0, -16(a0)
144 ; RV64I-NEXT:    ld a0, -8(a0)
145 ; RV64I-NEXT:    ld ra, 8(sp) # 8-byte Folded Reload
146 ; RV64I-NEXT:    ld s0, 0(sp) # 8-byte Folded Reload
147 ; RV64I-NEXT:    addi sp, sp, 16
148 ; RV64I-NEXT:    ret
149   %1 = call ptr @llvm.returnaddress(i32 2)
150   ret ptr %1