Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / SystemZ / frame-27.mir
blob4cb0206e7210c9676db03dc35d868be8d787790d
1 # RUN: llc -mtriple=s390x-linux-gnu -start-before=prologepilog %s -o - -mcpu=z14 \
2 # RUN:   -debug-only=prologepilog -print-after=prologepilog -verify-machineinstrs 2>&1 \
3 # RUN:   | FileCheck %s
4 # REQUIRES: asserts
6 # Test that stack objects are ordered in a good way with respect to the
7 # displacement operands of users.
9 --- |
10   define void @f1() { ret void }
11   define void @f2() { ret void }
12   define void @f3() { ret void }
13   define void @f4() { ret void }
14   define void @f5() { ret void }
15   define void @f6() { ret void }
17 ...
19 ### Test that %stack.0 is placed close to its D12 user.
20 # CHECK:      alloc FI(1) at SP[-4255]
21 # CHECK-NEXT: alloc FI(0) at SP[-4271]
22 # CHECK-NEXT: alloc FI(2) at SP[-4280]
23 # CHECK-NEXT: alloc FI(3) at SP[-4288]
24 # CHECK-NEXT: # *** IR Dump After Prologue/Epilogue Insertion & Frame Finalization
25 # CHECK-NEXT: # Machine code for function f1: IsSSA, NoPHIs, TracksLiveness, NoVRegs
26 # CHECK-NOT:  LAY
27 # CHECK:      VL32
28 ---
29 name:            f1
30 tracksRegLiveness: true
31 stack:
32   - { id: 0, size: 16 }
33   - { id: 1, size: 4095 }
34 machineFunctionInfo: {}
35 body:             |
36   bb.0:
37     renamable $f0s = VL32 %stack.0, 0, $noreg
38     Return
40 ...
42 ### Test that %stack.1 is placed close to its D12 user.
43 # CHECK:      alloc FI(0) at SP[-176]
44 # CHECK-NEXT: alloc FI(1) at SP[-4271]
45 # CHECK-NEXT: alloc FI(2) at SP[-4280]
46 # CHECK-NEXT: alloc FI(3) at SP[-4288]
47 # CHECK-NEXT: # *** IR Dump After Prologue/Epilogue Insertion & Frame Finalization
48 # CHECK-NEXT: # Machine code for function f2: IsSSA, NoPHIs, TracksLiveness, NoVRegs
49 # CHECK-NOT:  LAY
50 # CHECK:      VL32
51 ---
52 name:            f2
53 tracksRegLiveness: true
54 stack:
55   - { id: 0, size: 16 }
56   - { id: 1, size: 4095 }
57 machineFunctionInfo: {}
58 body:             |
59   bb.0:
60     renamable $f0s = VL32 %stack.1, 3916, $noreg
61     Return
63 ...
65 ### Swap the order of the objects so that both accesses are in range.
66 # CHECK:      alloc FI(1) at SP[-8350]
67 # CHECK-NEXT: alloc FI(0) at SP[-12445]
68 # CHECK-NEXT: alloc FI(2) at SP[-12456]
69 # CHECK-NEXT: alloc FI(3) at SP[-12464]
70 # CHECK-NEXT: # *** IR Dump After Prologue/Epilogue Insertion & Frame Finalization
71 # CHECK-NEXT: # Machine code for function f3: IsSSA, NoPHIs, TracksLiveness, NoVRegs
72 # CHECK-NOT:  LAY
73 # CHECK:      VL32
74 # CHECK-NOT:  LAY
75 # CHECK:      LEY
76 ---
77 name:            f3
78 tracksRegLiveness: true
79 stack:
80   - { id: 0, size: 4095 }
81   - { id: 1, size: 8190 }
82 machineFunctionInfo: {}
83 body:             |
84   bb.0:
85     renamable $f0s = VL32 %stack.0, 0, $noreg
86     renamable $f0s = LE %stack.1, 0, $noreg
87     Return
89 ...
91 ### Reorder the objects so that all accesses are in range.
92 # CHECK:      alloc FI(0) at SP[-8350]
93 # CHECK-NEXT: alloc FI(2) at SP[-16540]
94 # CHECK-NEXT: alloc FI(3) at SP[-24730]
95 # CHECK-NEXT: alloc FI(1) at SP[-26777]
96 # CHECK-NEXT: alloc FI(4) at SP[-28824]
97 # CHECK-NEXT: alloc FI(5) at SP[-28832]
98 # CHECK-NEXT: alloc FI(6) at SP[-28840]
99 # CHECK-NEXT: # *** IR Dump After Prologue/Epilogue Insertion & Frame Finalization
100 # CHECK-NEXT: # Machine code for function f4: IsSSA, NoPHIs, TracksLiveness, NoVRegs
101 # CHECK-NOT:  LAY
102 # CHECK:      LEY
103 # CHECK-NEXT: VL32
104 # CHECK-NEXT: LEY
105 # CHECK-NEXT: LEY
106 # CHECK-NEXT: VL32
108 name:            f4
109 tracksRegLiveness: true
110 stack:
111   - { id: 0, size: 8190 }
112   - { id: 1, size: 2047 }
113   - { id: 2, size: 8190 }
114   - { id: 3, size: 8190 }
115   - { id: 4, size: 2047 }
116 machineFunctionInfo: {}
117 body:             |
118   bb.0:
119     renamable $f2s = LE %stack.0, 0, $noreg
120     renamable $f0s = VL32 %stack.1, 0, $noreg
121     renamable $f3s = LEY %stack.2, 0, $noreg
122     renamable $f4s = LE %stack.3, 0, $noreg
123     renamable $f1s = VL32 %stack.4, 0, $noreg
124     Return
128 ### Reorder the objects so that the VL32 object is in range and the LYs are
129 ### shortened to Ls (STOC cannot be shortened).
130 # CHECK:      alloc FI(0) at SP[-8350]
131 # CHECK-NEXT: alloc FI(1) at SP[-16540]
132 # CHECK-NEXT: alloc FI(2) at SP[-24730]
133 # CHECK-NEXT: alloc FI(3) at SP[-26777]
134 # CHECK-NEXT: alloc FI(4) at SP[-26792]
135 # CHECK-NEXT: alloc FI(5) at SP[-26800]
136 # CHECK-NEXT: # *** IR Dump After Prologue/Epilogue Insertion & Frame Finalization
137 # CHECK-NEXT: # Machine code for function f5: IsSSA, NoPHIs, TracksLiveness, NoVRegs
138 # CHECK-NOT:  LAY
139 # CHECK:      $r1l = L $r15
140 # CHECK-NEXT: $r1l = L $r15
141 # CHECK-NEXT: IMPLICIT_DEF
142 # CHECK-NEXT: STOC
143 # CHECK-NEXT: STOC
144 # CHECK-NEXT: VL32
146 name:            f5
147 tracksRegLiveness: true
148 stack:
149   - { id: 0, size: 8190 }
150   - { id: 1, size: 8190 }
151   - { id: 2, size: 8190 }
152   - { id: 3, size: 2047 }
153 machineFunctionInfo: {}
154 body:             |
155   bb.0:
156     $r1l = LY %stack.2, 0, $noreg
157     $r1l = LY %stack.2, 0, $noreg
158     $cc = IMPLICIT_DEF
159     STOC $r1l, %stack.0, 0, 14, 8, implicit $cc
160     STOC $r1l, %stack.1, 0, 14, 8, implicit $cc
161     renamable $f3s = VL32 %stack.3, 0, $noreg
162     Return
166 ### Test handling of a variable sized object.
167 # CHECK:      alloc FI(1) at SP[-476]
168 # CHECK-NEXT: alloc FI(0) at SP[-776]
169 # CHECK-NEXT: alloc FI(2) at SP[-776]
170 # CHECK-NEXT: # *** IR Dump After Prologue/Epilogue Insertion & Frame Finalization
171 # CHECK-NEXT: # Machine code for function f6: IsSSA, NoPHIs, TracksLiveness, NoVRegs
173 # CHECK:  $r15d = AGHI $r15d(tied-def 0), -776, implicit-def dead $cc
174 # CHECK:  $r11d = LGR $r15d
175 # CHECK:  renamable $r2d = ADJDYNALLOC renamable $r1d, 0, $noreg
176 # CHECK:  VST64 renamable $f0d, $r11d, 160, $noreg
177 # CHECK:  VST32 renamable $f1s, $r11d, 460, $noreg
178 # CHECK:  VST32 killed renamable $f0s, killed renamable $r2d, 0, $noreg
180 name:            f6
181 tracksRegLiveness: true
182 stack:
183   - { id: 0, size: 300 }
184   - { id: 1, size: 316 }
185   - { id: 2, type: variable-sized }
186 machineFunctionInfo: {}
187 body:             |
188   bb.0 (%ir-block.0):
189     liveins: $f0d, $f0s, $f1s, $r2l
191     renamable $r2l = KILL $r2l, implicit-def $r2d
192     renamable $r1d = RISBGN undef renamable $r1d, killed renamable $r2d, 30, 189, 2
193     renamable $r0d = nuw LA killed renamable $r1d, 7, $noreg
194     renamable $r0d = RISBGN undef renamable $r0d, killed renamable $r0d, 29, 188, 0
195     renamable $r1d = SGRK $r15d, killed renamable $r0d, implicit-def dead $cc
196     renamable $r2d = ADJDYNALLOC renamable $r1d, 0, $noreg
197     $r15d = COPY killed renamable $r1d
198     VST64 renamable $f0d, %stack.0, 0, $noreg
199     VST32 renamable $f1s, %stack.1, 0, $noreg
200     VST32 killed renamable $f0s, killed renamable $r2d, 0, $noreg
201     Return