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-FPELIM %s
4 ; RUN: llc -mtriple=riscv32 -verify-machineinstrs -frame-pointer=all < %s \
5 ; RUN: | FileCheck -check-prefix=RV32I-WITHFP %s
7 ; TODO: the quality of the generated code is poor
10 ; RV32I-FPELIM-LABEL: test:
11 ; RV32I-FPELIM: # %bb.0:
12 ; RV32I-FPELIM-NEXT: lui a0, 74565
13 ; RV32I-FPELIM-NEXT: addi a0, a0, 1664
14 ; RV32I-FPELIM-NEXT: sub sp, sp, a0
15 ; RV32I-FPELIM-NEXT: .cfi_def_cfa_offset 305419904
16 ; RV32I-FPELIM-NEXT: lui a0, 74565
17 ; RV32I-FPELIM-NEXT: addi a0, a0, 1664
18 ; RV32I-FPELIM-NEXT: add sp, sp, a0
19 ; RV32I-FPELIM-NEXT: ret
21 ; RV32I-WITHFP-LABEL: test:
22 ; RV32I-WITHFP: # %bb.0:
23 ; RV32I-WITHFP-NEXT: addi sp, sp, -2032
24 ; RV32I-WITHFP-NEXT: .cfi_def_cfa_offset 2032
25 ; RV32I-WITHFP-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
26 ; RV32I-WITHFP-NEXT: sw s0, 2024(sp) # 4-byte Folded Spill
27 ; RV32I-WITHFP-NEXT: .cfi_offset ra, -4
28 ; RV32I-WITHFP-NEXT: .cfi_offset s0, -8
29 ; RV32I-WITHFP-NEXT: addi s0, sp, 2032
30 ; RV32I-WITHFP-NEXT: .cfi_def_cfa s0, 0
31 ; RV32I-WITHFP-NEXT: lui a0, 74565
32 ; RV32I-WITHFP-NEXT: addi a0, a0, -352
33 ; RV32I-WITHFP-NEXT: sub sp, sp, a0
34 ; RV32I-WITHFP-NEXT: lui a0, 74565
35 ; RV32I-WITHFP-NEXT: addi a0, a0, -352
36 ; RV32I-WITHFP-NEXT: add sp, sp, a0
37 ; RV32I-WITHFP-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
38 ; RV32I-WITHFP-NEXT: lw s0, 2024(sp) # 4-byte Folded Reload
39 ; RV32I-WITHFP-NEXT: addi sp, sp, 2032
40 ; RV32I-WITHFP-NEXT: ret
41 %tmp = alloca [ 305419896 x i8 ] , align 4
45 ; This test case artificially produces register pressure which should force
46 ; use of the emergency spill slot.
48 define void @test_emergency_spill_slot(i32 %a) {
49 ; RV32I-FPELIM-LABEL: test_emergency_spill_slot:
50 ; RV32I-FPELIM: # %bb.0:
51 ; RV32I-FPELIM-NEXT: addi sp, sp, -2032
52 ; RV32I-FPELIM-NEXT: .cfi_def_cfa_offset 2032
53 ; RV32I-FPELIM-NEXT: sw s0, 2028(sp) # 4-byte Folded Spill
54 ; RV32I-FPELIM-NEXT: sw s1, 2024(sp) # 4-byte Folded Spill
55 ; RV32I-FPELIM-NEXT: .cfi_offset s0, -4
56 ; RV32I-FPELIM-NEXT: .cfi_offset s1, -8
57 ; RV32I-FPELIM-NEXT: lui a1, 97
58 ; RV32I-FPELIM-NEXT: addi a1, a1, 672
59 ; RV32I-FPELIM-NEXT: sub sp, sp, a1
60 ; RV32I-FPELIM-NEXT: .cfi_def_cfa_offset 400016
61 ; RV32I-FPELIM-NEXT: lui a1, 78
62 ; RV32I-FPELIM-NEXT: addi a2, sp, 8
63 ; RV32I-FPELIM-NEXT: add a1, a2, a1
64 ; RV32I-FPELIM-NEXT: #APP
65 ; RV32I-FPELIM-NEXT: nop
66 ; RV32I-FPELIM-NEXT: #NO_APP
67 ; RV32I-FPELIM-NEXT: sw a0, 512(a1)
68 ; RV32I-FPELIM-NEXT: #APP
69 ; RV32I-FPELIM-NEXT: nop
70 ; RV32I-FPELIM-NEXT: #NO_APP
71 ; RV32I-FPELIM-NEXT: lui a0, 97
72 ; RV32I-FPELIM-NEXT: addi a0, a0, 672
73 ; RV32I-FPELIM-NEXT: add sp, sp, a0
74 ; RV32I-FPELIM-NEXT: lw s0, 2028(sp) # 4-byte Folded Reload
75 ; RV32I-FPELIM-NEXT: lw s1, 2024(sp) # 4-byte Folded Reload
76 ; RV32I-FPELIM-NEXT: addi sp, sp, 2032
77 ; RV32I-FPELIM-NEXT: ret
79 ; RV32I-WITHFP-LABEL: test_emergency_spill_slot:
80 ; RV32I-WITHFP: # %bb.0:
81 ; RV32I-WITHFP-NEXT: addi sp, sp, -2032
82 ; RV32I-WITHFP-NEXT: .cfi_def_cfa_offset 2032
83 ; RV32I-WITHFP-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
84 ; RV32I-WITHFP-NEXT: sw s0, 2024(sp) # 4-byte Folded Spill
85 ; RV32I-WITHFP-NEXT: sw s1, 2020(sp) # 4-byte Folded Spill
86 ; RV32I-WITHFP-NEXT: sw s2, 2016(sp) # 4-byte Folded Spill
87 ; RV32I-WITHFP-NEXT: .cfi_offset ra, -4
88 ; RV32I-WITHFP-NEXT: .cfi_offset s0, -8
89 ; RV32I-WITHFP-NEXT: .cfi_offset s1, -12
90 ; RV32I-WITHFP-NEXT: .cfi_offset s2, -16
91 ; RV32I-WITHFP-NEXT: addi s0, sp, 2032
92 ; RV32I-WITHFP-NEXT: .cfi_def_cfa s0, 0
93 ; RV32I-WITHFP-NEXT: lui a1, 97
94 ; RV32I-WITHFP-NEXT: addi a1, a1, 688
95 ; RV32I-WITHFP-NEXT: sub sp, sp, a1
96 ; RV32I-WITHFP-NEXT: lui a1, 78
97 ; RV32I-WITHFP-NEXT: lui a2, 98
98 ; RV32I-WITHFP-NEXT: addi a2, a2, -1388
99 ; RV32I-WITHFP-NEXT: sub a2, s0, a2
100 ; RV32I-WITHFP-NEXT: add a1, a2, a1
101 ; RV32I-WITHFP-NEXT: #APP
102 ; RV32I-WITHFP-NEXT: nop
103 ; RV32I-WITHFP-NEXT: #NO_APP
104 ; RV32I-WITHFP-NEXT: sw a0, 512(a1)
105 ; RV32I-WITHFP-NEXT: #APP
106 ; RV32I-WITHFP-NEXT: nop
107 ; RV32I-WITHFP-NEXT: #NO_APP
108 ; RV32I-WITHFP-NEXT: lui a0, 97
109 ; RV32I-WITHFP-NEXT: addi a0, a0, 688
110 ; RV32I-WITHFP-NEXT: add sp, sp, a0
111 ; RV32I-WITHFP-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
112 ; RV32I-WITHFP-NEXT: lw s0, 2024(sp) # 4-byte Folded Reload
113 ; RV32I-WITHFP-NEXT: lw s1, 2020(sp) # 4-byte Folded Reload
114 ; RV32I-WITHFP-NEXT: lw s2, 2016(sp) # 4-byte Folded Reload
115 ; RV32I-WITHFP-NEXT: addi sp, sp, 2032
116 ; RV32I-WITHFP-NEXT: ret
117 %data = alloca [ 100000 x i32 ] , align 4
118 %ptr = getelementptr inbounds [100000 x i32], ptr %data, i32 0, i32 80000
119 %1 = tail call { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } asm sideeffect "nop", "=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r"()
120 %asmresult0 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 0
121 %asmresult1 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 1
122 %asmresult2 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 2
123 %asmresult3 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 3
124 %asmresult4 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 4
125 %asmresult5 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 5
126 %asmresult6 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 6
127 %asmresult7 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 7
128 %asmresult8 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 8
129 %asmresult9 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 9
130 %asmresult10 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 10
131 %asmresult11 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 11
132 %asmresult12 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 12
133 %asmresult13 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 13
134 %asmresult14 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 14
135 store volatile i32 %a, ptr %ptr
136 tail call void asm sideeffect "nop", "r,r,r,r,r,r,r,r,r,r,r,r,r,r,r"(i32 %asmresult0, i32 %asmresult1, i32 %asmresult2, i32 %asmresult3, i32 %asmresult4, i32 %asmresult5, i32 %asmresult6, i32 %asmresult7, i32 %asmresult8, i32 %asmresult9, i32 %asmresult10, i32 %asmresult11, i32 %asmresult12, i32 %asmresult13, i32 %asmresult14)