blob: 8ee818bed9107772a1a25d4fbddc7d28931a3d27 [file] [log] [blame]
Alex Bradbury9fea4882018-01-10 19:53:46 +00001; 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
5; TODO: the quality of the generated code is poor
6
7define void @test() nounwind {
8; RV32I-LABEL: test:
9; RV32I: # %bb.0:
10; RV32I-NEXT: lui a0, 74565
Alex Bradbury0715d352018-01-11 11:17:19 +000011; RV32I-NEXT: addi a0, a0, 1680
Alex Bradbury9fea4882018-01-10 19:53:46 +000012; RV32I-NEXT: sub sp, sp, a0
13; RV32I-NEXT: lui a0, 74565
Alex Bradbury0715d352018-01-11 11:17:19 +000014; RV32I-NEXT: addi a0, a0, 1676
Alex Bradbury9fea4882018-01-10 19:53:46 +000015; RV32I-NEXT: add a0, sp, a0
16; RV32I-NEXT: sw ra, 0(a0)
17; RV32I-NEXT: lui a0, 74565
Alex Bradbury0715d352018-01-11 11:17:19 +000018; RV32I-NEXT: addi a0, a0, 1672
Alex Bradbury9fea4882018-01-10 19:53:46 +000019; RV32I-NEXT: add a0, sp, a0
20; RV32I-NEXT: sw s0, 0(a0)
21; RV32I-NEXT: lui a0, 74565
Alex Bradbury0715d352018-01-11 11:17:19 +000022; RV32I-NEXT: addi a0, a0, 1680
Alex Bradbury9fea4882018-01-10 19:53:46 +000023; RV32I-NEXT: add s0, sp, a0
24; RV32I-NEXT: lui a0, 74565
Alex Bradbury0715d352018-01-11 11:17:19 +000025; RV32I-NEXT: addi a0, a0, 1672
Alex Bradbury9fea4882018-01-10 19:53:46 +000026; RV32I-NEXT: add a0, sp, a0
27; RV32I-NEXT: lw s0, 0(a0)
28; RV32I-NEXT: lui a0, 74565
Alex Bradbury0715d352018-01-11 11:17:19 +000029; RV32I-NEXT: addi a0, a0, 1676
Alex Bradbury9fea4882018-01-10 19:53:46 +000030; RV32I-NEXT: add a0, sp, a0
31; RV32I-NEXT: lw ra, 0(a0)
32; RV32I-NEXT: lui a0, 74565
Alex Bradbury0715d352018-01-11 11:17:19 +000033; RV32I-NEXT: addi a0, a0, 1680
Alex Bradbury9fea4882018-01-10 19:53:46 +000034; RV32I-NEXT: add sp, sp, a0
35; RV32I-NEXT: ret
36 %tmp = alloca [ 305419896 x i8 ] , align 4
37 ret void
38}
Alex Bradbury0715d352018-01-11 11:17:19 +000039
40; This test case artificially produces register pressure which should force
41; use of the emergency spill slot.
42
43define void @test_emergency_spill_slot(i32 %a) nounwind {
44; RV32I-LABEL: test_emergency_spill_slot:
45; RV32I: # %bb.0:
46; RV32I-NEXT: lui a1, 98
47; RV32I-NEXT: addi a1, a1, -1376
48; RV32I-NEXT: sub sp, sp, a1
49; RV32I-NEXT: lui a1, 98
50; RV32I-NEXT: addi a1, a1, -1380
51; RV32I-NEXT: add a1, sp, a1
52; RV32I-NEXT: sw ra, 0(a1)
53; RV32I-NEXT: lui a1, 98
54; RV32I-NEXT: addi a1, a1, -1384
55; RV32I-NEXT: add a1, sp, a1
56; RV32I-NEXT: sw s0, 0(a1)
57; RV32I-NEXT: lui a1, 98
58; RV32I-NEXT: addi a1, a1, -1388
59; RV32I-NEXT: add a1, sp, a1
60; RV32I-NEXT: sw s1, 0(a1)
61; RV32I-NEXT: lui a1, 98
62; RV32I-NEXT: addi a1, a1, -1392
63; RV32I-NEXT: add a1, sp, a1
64; RV32I-NEXT: sw s2, 0(a1)
65; RV32I-NEXT: lui a1, 98
66; RV32I-NEXT: addi a1, a1, -1376
67; RV32I-NEXT: add s0, sp, a1
68; RV32I-NEXT: lui a1, 78
69; RV32I-NEXT: addi a1, a1, 512
70; RV32I-NEXT: lui a2, 1048478
71; RV32I-NEXT: addi a2, a2, 1388
72; RV32I-NEXT: add a2, s0, a2
73; RV32I-NEXT: mv a2, a2
74; RV32I-NEXT: add a1, a2, a1
75; RV32I-NEXT: #APP
76; RV32I-NEXT: nop
77; RV32I-NEXT: #NO_APP
78; RV32I-NEXT: sw a0, 0(a1)
79; RV32I-NEXT: #APP
80; RV32I-NEXT: nop
81; RV32I-NEXT: #NO_APP
82; RV32I-NEXT: lui a0, 98
83; RV32I-NEXT: addi a0, a0, -1392
84; RV32I-NEXT: add a0, sp, a0
85; RV32I-NEXT: lw s2, 0(a0)
86; RV32I-NEXT: lui a0, 98
87; RV32I-NEXT: addi a0, a0, -1388
88; RV32I-NEXT: add a0, sp, a0
89; RV32I-NEXT: lw s1, 0(a0)
90; RV32I-NEXT: lui a0, 98
91; RV32I-NEXT: addi a0, a0, -1384
92; RV32I-NEXT: add a0, sp, a0
93; RV32I-NEXT: lw s0, 0(a0)
94; RV32I-NEXT: lui a0, 98
95; RV32I-NEXT: addi a0, a0, -1380
96; RV32I-NEXT: add a0, sp, a0
97; RV32I-NEXT: lw ra, 0(a0)
98; RV32I-NEXT: lui a0, 98
99; RV32I-NEXT: addi a0, a0, -1376
100; RV32I-NEXT: add sp, sp, a0
101; RV32I-NEXT: ret
102 %data = alloca [ 100000 x i32 ] , align 4
103 %ptr = getelementptr inbounds [100000 x i32], [100000 x i32]* %data, i32 0, i32 80000
104 %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"()
105 %asmresult0 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 0
106 %asmresult1 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 1
107 %asmresult2 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 2
108 %asmresult3 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 3
109 %asmresult4 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 4
110 %asmresult5 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 5
111 %asmresult6 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 6
112 %asmresult7 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 7
113 %asmresult8 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 8
114 %asmresult9 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 9
115 %asmresult10 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 10
116 %asmresult11 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 11
117 %asmresult12 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 12
118 %asmresult13 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 13
119 %asmresult14 = extractvalue { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } %1, 14
120 store volatile i32 %a, i32* %ptr
121 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)
122 ret void
123}