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:
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
24 ; RV64I-LABEL: test_frameaddress_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
35 %1 = call ptr @llvm.frameaddress(i32 0)
39 define ptr @test_frameaddress_2() nounwind {
40 ; RV32I-LABEL: test_frameaddress_2:
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
53 ; RV64I-LABEL: test_frameaddress_2:
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
65 %1 = call ptr @llvm.frameaddress(i32 2)
69 define ptr @test_frameaddress_3_alloca() nounwind {
70 ; RV32I-LABEL: test_frameaddress_3_alloca:
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@plt
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
86 ; RV64I-LABEL: test_frameaddress_3_alloca:
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@plt
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
101 %1 = alloca [100 x i8]
102 call void @notdead(ptr %1)
103 %2 = call ptr @llvm.frameaddress(i32 3)
107 define ptr @test_returnaddress_0() nounwind {
108 ; RV32I-LABEL: test_returnaddress_0:
110 ; RV32I-NEXT: mv a0, ra
113 ; RV64I-LABEL: test_returnaddress_0:
115 ; RV64I-NEXT: mv a0, ra
117 %1 = call ptr @llvm.returnaddress(i32 0)
121 define ptr @test_returnaddress_2() nounwind {
122 ; RV32I-LABEL: test_returnaddress_2:
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
136 ; RV64I-LABEL: test_returnaddress_2:
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
149 %1 = call ptr @llvm.returnaddress(i32 2)