Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / SystemZ / foldmemop-vec-binops.mir
blob6ef9de775fb012dcd4b8cce1566bffa64eebe3bd
1 # RUN: llc -mtriple=s390x-linux-gnu -mcpu=z14 -start-before=greedy %s -o - \
2 # RUN:   | FileCheck %s
4 # Test folding of a memory operand into an fp memory instruction.
6 --- |
7   define void @fun0(double %arg0, double %arg1, double* %Dst) { ret void }
8   define void @fun1(double %arg0, double %arg1, double* %Dst) { ret void }
9   define void @fun2(double %arg0, double %arg1, double* %Dst) { ret void }
10   define void @fun3(float %arg0, float %arg1, float* %Dst) { ret void }
11   define void @fun4(float %arg0, float %arg1, float* %Dst) { ret void }
12   define void @fun5(float %arg0, float %arg1, float* %Dst) { ret void }
13   define void @fun6(double %arg0, double %arg1, double* %Dst) { ret void }
14   define void @fun7(double %arg0, double %arg1, double* %Dst) { ret void }
15   define void @fun8(double %arg0, double %arg1, double* %Dst) { ret void }
16   define void @fun9(float %arg0, float %arg1, float* %Dst) { ret void }
17   define void @fun10(float %arg0, float %arg1, float* %Dst) { ret void }
18   define void @fun11(float %arg0, float %arg1, float* %Dst) { ret void }
19   define void @fun12(double %arg0, double %arg1, double* %Dst) { ret void }
20   define void @fun13(double %arg0, double %arg1, double* %Dst) { ret void }
21   define void @fun14(double %arg0, double %arg1, double* %Dst) { ret void }
22   define void @fun15(float %arg0, float %arg1, float* %Dst) { ret void }
23   define void @fun16(float %arg0, float %arg1, float* %Dst) { ret void }
24   define void @fun17(float %arg0, float %arg1, float* %Dst) { ret void }
25   define void @fun18(double %arg0, double %arg1, double* %Dst) { ret void }
26   define void @fun19(double %arg0, double %arg1, double* %Dst) { ret void }
27   define void @fun20(double %arg0, double %arg1, double* %Dst) { ret void }
28   define void @fun21(float %arg0, float %arg1, float* %Dst) { ret void }
29   define void @fun22(float %arg0, float %arg1, float* %Dst) { ret void }
30   define void @fun23(float %arg0, float %arg1, float* %Dst) { ret void }
32 ...
34 # Test with both orders of operands since some operations are commutative.
36 # CHECK-LABEL: fun0:
37 # CHECK: adb     %f0, 160(%r15)                  # 8-byte Folded Reload
38 ---
39 name:            fun0
40 alignment:       16
41 tracksRegLiveness: true
42 registers:
43   - { id: 0, class: fp64bit }
44   - { id: 1, class: fp64bit }
45   - { id: 2, class: addr64bit }
46   - { id: 3, class: vr64bit }
47 liveins:
48   - { reg: '$f0d', virtual-reg: '%0' }
49   - { reg: '$f2d', virtual-reg: '%1' }
50   - { reg: '$r2d', virtual-reg: '%2' }
51 frameInfo:
52   maxAlignment:    1
53 machineFunctionInfo: {}
54 body:             |
55   bb.0:
56     liveins: $f0d, $f2d, $r2d
57   
58     %2:addr64bit = COPY $r2d
59     %1:fp64bit = COPY $f2d
60     %0:fp64bit = COPY $f0d
61     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
62     %3:vr64bit = nofpexcept WFADB %0, %1, implicit $fpc
63     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
64     Return
66 ...
69 # CHECK-LABEL: fun1:
70 # CHECK: adb     %f0, 160(%r15)                  # 8-byte Folded Reload
71 ---
72 name:            fun1
73 alignment:       16
74 tracksRegLiveness: true
75 registers:
76   - { id: 0, class: fp64bit }
77   - { id: 1, class: fp64bit }
78   - { id: 2, class: addr64bit }
79   - { id: 3, class: vr64bit }
80 liveins:
81   - { reg: '$f0d', virtual-reg: '%0' }
82   - { reg: '$f2d', virtual-reg: '%1' }
83   - { reg: '$r2d', virtual-reg: '%2' }
84 frameInfo:
85   maxAlignment:    1
86 machineFunctionInfo: {}
87 body:             |
88   bb.0:
89     liveins: $f0d, $f2d, $r2d
90   
91     %2:addr64bit = COPY $r2d
92     %1:fp64bit = COPY $f2d
93     %0:fp64bit = COPY $f0d
94     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
95     %3:vr64bit = nofpexcept WFADB %1, %0, implicit $fpc
96     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
97     Return
99 ...
101 # ADB can't be used if one operand is a VR64 (and not FP64).
102 # CHECK-LABEL: fun2:
103 # CHECK: wfadb   %f0, %v16, %f0
105 name:            fun2
106 alignment:       16
107 tracksRegLiveness: true
108 registers:
109   - { id: 0, class: fp64bit }
110   - { id: 1, class: vr64bit }
111   - { id: 2, class: addr64bit }
112   - { id: 3, class: vr64bit }
113 liveins:
114   - { reg: '$f0d', virtual-reg: '%0' }
115   - { reg: '$f2d', virtual-reg: '%1' }
116   - { reg: '$r2d', virtual-reg: '%2' }
117 frameInfo:
118   maxAlignment:    1
119 machineFunctionInfo: {}
120 body:             |
121   bb.0:
122     liveins: $f0d, $f2d, $r2d
123   
124     %2:addr64bit = COPY $r2d
125     %1:vr64bit = COPY $f2d
126     %0:fp64bit = COPY $f0d
127     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
128     %3:vr64bit = nofpexcept WFADB %1, %0, implicit $fpc
129     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
130     Return
135 # CHECK-LABEL: fun3:
136 # CHECK: aeb     %f0, 164(%r15)                  # 4-byte Folded Reload
138 name:            fun3
139 alignment:       16
140 tracksRegLiveness: true
141 registers:
142   - { id: 0, class: fp32bit }
143   - { id: 1, class: fp32bit }
144   - { id: 2, class: addr64bit }
145   - { id: 3, class: vr32bit }
146 liveins:
147   - { reg: '$f0s', virtual-reg: '%0' }
148   - { reg: '$f2s', virtual-reg: '%1' }
149   - { reg: '$r2d', virtual-reg: '%2' }
150 frameInfo:
151   maxAlignment:    1
152 machineFunctionInfo: {}
153 body:             |
154   bb.0:
155     liveins: $f0s, $f2s, $r2d
156   
157     %2:addr64bit = COPY $r2d
158     %1:fp32bit = COPY $f2s
159     %0:fp32bit = COPY $f0s
160     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
161     %3:vr32bit = nofpexcept WFASB %0, %1, implicit $fpc
162     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
163     Return
168 # CHECK-LABEL: fun4:
169 # CHECK: aeb     %f0, 164(%r15)                  # 4-byte Folded Reload
171 name:            fun4
172 alignment:       16
173 tracksRegLiveness: true
174 registers:
175   - { id: 0, class: fp32bit }
176   - { id: 1, class: fp32bit }
177   - { id: 2, class: addr64bit }
178   - { id: 3, class: vr32bit }
179 liveins:
180   - { reg: '$f0s', virtual-reg: '%0' }
181   - { reg: '$f2s', virtual-reg: '%1' }
182   - { reg: '$r2d', virtual-reg: '%2' }
183 frameInfo:
184   maxAlignment:    1
185 machineFunctionInfo: {}
186 body:             |
187   bb.0:
188     liveins: $f0s, $f2s, $r2d
189   
190     %2:addr64bit = COPY $r2d
191     %1:fp32bit = COPY $f2s
192     %0:fp32bit = COPY $f0s
193     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
194     %3:vr32bit = nofpexcept WFASB %1, %0, implicit $fpc
195     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
196     Return
201 # AEB can't be used if one operand is a VR64 (and not FP64).
202 # CHECK-LABEL: fun5:
203 # CHECK: wfasb   %f0, %v16, %f0
205 name:            fun5
206 alignment:       16
207 tracksRegLiveness: true
208 registers:
209   - { id: 0, class: fp32bit }
210   - { id: 1, class: vr32bit }
211   - { id: 2, class: addr64bit }
212   - { id: 3, class: vr32bit }
213 liveins:
214   - { reg: '$f0s', virtual-reg: '%0' }
215   - { reg: '$f2s', virtual-reg: '%1' }
216   - { reg: '$r2d', virtual-reg: '%2' }
217 frameInfo:
218   maxAlignment:    1
219 machineFunctionInfo: {}
220 body:             |
221   bb.0:
222     liveins: $f0s, $f2s, $r2d
223   
224     %2:addr64bit = COPY $r2d
225     %1:vr32bit = COPY $f2s
226     %0:fp32bit = COPY $f0s
227     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
228     %3:vr32bit = nofpexcept WFASB %1, %0, implicit $fpc
229     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
230     Return
235 # CHECK-LABEL: fun6:
236 # CHECK: sdb     %f0, 160(%r15)                  # 8-byte Folded Reload
238 name:            fun6
239 alignment:       16
240 tracksRegLiveness: true
241 registers:
242   - { id: 0, class: fp64bit }
243   - { id: 1, class: fp64bit }
244   - { id: 2, class: addr64bit }
245   - { id: 3, class: vr64bit }
246 liveins:
247   - { reg: '$f0d', virtual-reg: '%0' }
248   - { reg: '$f2d', virtual-reg: '%1' }
249   - { reg: '$r2d', virtual-reg: '%2' }
250 frameInfo:
251   maxAlignment:    1
252 machineFunctionInfo: {}
253 body:             |
254   bb.0:
255     liveins: $f0d, $f2d, $r2d
256   
257     %2:addr64bit = COPY $r2d
258     %1:fp64bit = COPY $f2d
259     %0:fp64bit = COPY $f0d
260     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
261     %3:vr64bit = nofpexcept WFSDB %0, %1, implicit $fpc
262     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
263     Return
268 # CHECK-LABEL: fun7:
269 # CHECK: wfsdb   %f0, %f1, %f0
271 name:            fun7
272 alignment:       16
273 tracksRegLiveness: true
274 registers:
275   - { id: 0, class: fp64bit }
276   - { id: 1, class: fp64bit }
277   - { id: 2, class: addr64bit }
278   - { id: 3, class: vr64bit }
279 liveins:
280   - { reg: '$f0d', virtual-reg: '%0' }
281   - { reg: '$f2d', virtual-reg: '%1' }
282   - { reg: '$r2d', virtual-reg: '%2' }
283 frameInfo:
284   maxAlignment:    1
285 machineFunctionInfo: {}
286 body:             |
287   bb.0:
288     liveins: $f0d, $f2d, $r2d
289   
290     %2:addr64bit = COPY $r2d
291     %1:fp64bit = COPY $f2d
292     %0:fp64bit = COPY $f0d
293     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
294     %3:vr64bit = nofpexcept WFSDB %1, %0, implicit $fpc
295     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
296     Return
300 # SDB can't be used if one operand is a VR64 (and not FP64).
301 # CHECK-LABEL: fun8:
302 # CHECK: wfsdb   %f0, %f0, %v16
304 name:            fun8
305 alignment:       16
306 tracksRegLiveness: true
307 registers:
308   - { id: 0, class: fp64bit }
309   - { id: 1, class: vr64bit }
310   - { id: 2, class: addr64bit }
311   - { id: 3, class: vr64bit }
312 liveins:
313   - { reg: '$f0d', virtual-reg: '%0' }
314   - { reg: '$f2d', virtual-reg: '%1' }
315   - { reg: '$r2d', virtual-reg: '%2' }
316 frameInfo:
317   maxAlignment:    1
318 machineFunctionInfo: {}
319 body:             |
320   bb.0:
321     liveins: $f0d, $f2d, $r2d
322   
323     %2:addr64bit = COPY $r2d
324     %1:vr64bit = COPY $f2d
325     %0:fp64bit = COPY $f0d
326     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
327     %3:vr64bit = nofpexcept WFSDB %0, %1, implicit $fpc
328     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
329     Return
334 # CHECK-LABEL: fun9:
335 # CHECK: seb     %f0, 164(%r15)                  # 4-byte Folded Reload
337 name:            fun9
338 alignment:       16
339 tracksRegLiveness: true
340 registers:
341   - { id: 0, class: fp32bit }
342   - { id: 1, class: fp32bit }
343   - { id: 2, class: addr64bit }
344   - { id: 3, class: vr32bit }
345 liveins:
346   - { reg: '$f0s', virtual-reg: '%0' }
347   - { reg: '$f2s', virtual-reg: '%1' }
348   - { reg: '$r2d', virtual-reg: '%2' }
349 frameInfo:
350   maxAlignment:    1
351 machineFunctionInfo: {}
352 body:             |
353   bb.0:
354     liveins: $f0s, $f2s, $r2d
355   
356     %2:addr64bit = COPY $r2d
357     %1:fp32bit = COPY $f2s
358     %0:fp32bit = COPY $f0s
359     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
360     %3:vr32bit = nofpexcept WFSSB %0, %1, implicit $fpc
361     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
362     Return
367 # CHECK-LABEL: fun10:
368 # CHECK: wfssb   %f0, %f1, %f0
370 name:            fun10
371 alignment:       16
372 tracksRegLiveness: true
373 registers:
374   - { id: 0, class: fp32bit }
375   - { id: 1, class: fp32bit }
376   - { id: 2, class: addr64bit }
377   - { id: 3, class: vr32bit }
378 liveins:
379   - { reg: '$f0s', virtual-reg: '%0' }
380   - { reg: '$f2s', virtual-reg: '%1' }
381   - { reg: '$r2d', virtual-reg: '%2' }
382 frameInfo:
383   maxAlignment:    1
384 machineFunctionInfo: {}
385 body:             |
386   bb.0:
387     liveins: $f0s, $f2s, $r2d
388   
389     %2:addr64bit = COPY $r2d
390     %1:fp32bit = COPY $f2s
391     %0:fp32bit = COPY $f0s
392     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
393     %3:vr32bit = nofpexcept WFSSB %1, %0, implicit $fpc
394     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
395     Return
400 # SEB can't be used if one operand is a VR32 (and not FP32).
401 # CHECK-LABEL: fun11:
402 # CHECK: wfssb   %f0, %f0, %v16
404 name:            fun11
405 alignment:       16
406 tracksRegLiveness: true
407 registers:
408   - { id: 0, class: fp32bit }
409   - { id: 1, class: vr32bit }
410   - { id: 2, class: addr64bit }
411   - { id: 3, class: vr32bit }
412 liveins:
413   - { reg: '$f0s', virtual-reg: '%0' }
414   - { reg: '$f2s', virtual-reg: '%1' }
415   - { reg: '$r2d', virtual-reg: '%2' }
416 frameInfo:
417   maxAlignment:    1
418 machineFunctionInfo: {}
419 body:             |
420   bb.0:
421     liveins: $f0s, $f2s, $r2d
422   
423     %2:addr64bit = COPY $r2d
424     %1:vr32bit = COPY $f2s
425     %0:fp32bit = COPY $f0s
426     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
427     %3:vr32bit = nofpexcept WFSSB %0, %1, implicit $fpc
428     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
429     Return
433 # CHECK-LABEL: fun12:
434 # CHECK: ddb     %f0, 160(%r15)                  # 8-byte Folded Reload
436 name:            fun12
437 alignment:       16
438 tracksRegLiveness: true
439 registers:
440   - { id: 0, class: fp64bit }
441   - { id: 1, class: fp64bit }
442   - { id: 2, class: addr64bit }
443   - { id: 3, class: vr64bit }
444 liveins:
445   - { reg: '$f0d', virtual-reg: '%0' }
446   - { reg: '$f2d', virtual-reg: '%1' }
447   - { reg: '$r2d', virtual-reg: '%2' }
448 frameInfo:
449   maxAlignment:    1
450 machineFunctionInfo: {}
451 body:             |
452   bb.0:
453     liveins: $f0d, $f2d, $r2d
454   
455     %2:addr64bit = COPY $r2d
456     %1:fp64bit = COPY $f2d
457     %0:fp64bit = COPY $f0d
458     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
459     %3:vr64bit = nofpexcept WFDDB %0, %1, implicit $fpc
460     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
461     Return
466 # CHECK-LABEL: fun13:
467 # CHECK: wfddb   %f0, %f1, %f0
469 name:            fun13
470 alignment:       16
471 tracksRegLiveness: true
472 registers:
473   - { id: 0, class: fp64bit }
474   - { id: 1, class: fp64bit }
475   - { id: 2, class: addr64bit }
476   - { id: 3, class: vr64bit }
477 liveins:
478   - { reg: '$f0d', virtual-reg: '%0' }
479   - { reg: '$f2d', virtual-reg: '%1' }
480   - { reg: '$r2d', virtual-reg: '%2' }
481 frameInfo:
482   maxAlignment:    1
483 machineFunctionInfo: {}
484 body:             |
485   bb.0:
486     liveins: $f0d, $f2d, $r2d
487   
488     %2:addr64bit = COPY $r2d
489     %1:fp64bit = COPY $f2d
490     %0:fp64bit = COPY $f0d
491     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
492     %3:vr64bit = nofpexcept WFDDB %1, %0, implicit $fpc
493     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
494     Return
498 # DDB can't be used if one operand is a VR64 (and not FP64).
499 # CHECK-LABEL: fun14:
500 # CHECK: wfddb   %f0, %f0, %v16
502 name:            fun14
503 alignment:       16
504 tracksRegLiveness: true
505 registers:
506   - { id: 0, class: fp64bit }
507   - { id: 1, class: vr64bit }
508   - { id: 2, class: addr64bit }
509   - { id: 3, class: vr64bit }
510 liveins:
511   - { reg: '$f0d', virtual-reg: '%0' }
512   - { reg: '$f2d', virtual-reg: '%1' }
513   - { reg: '$r2d', virtual-reg: '%2' }
514 frameInfo:
515   maxAlignment:    1
516 machineFunctionInfo: {}
517 body:             |
518   bb.0:
519     liveins: $f0d, $f2d, $r2d
520   
521     %2:addr64bit = COPY $r2d
522     %1:vr64bit = COPY $f2d
523     %0:fp64bit = COPY $f0d
524     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
525     %3:vr64bit = nofpexcept WFDDB %0, %1, implicit $fpc
526     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
527     Return
532 # CHECK-LABEL: fun15:
533 # CHECK: deb     %f0, 164(%r15)                  # 4-byte Folded Reload
535 name:            fun15
536 alignment:       16
537 tracksRegLiveness: true
538 registers:
539   - { id: 0, class: fp32bit }
540   - { id: 1, class: fp32bit }
541   - { id: 2, class: addr64bit }
542   - { id: 3, class: vr32bit }
543 liveins:
544   - { reg: '$f0s', virtual-reg: '%0' }
545   - { reg: '$f2s', virtual-reg: '%1' }
546   - { reg: '$r2d', virtual-reg: '%2' }
547 frameInfo:
548   maxAlignment:    1
549 machineFunctionInfo: {}
550 body:             |
551   bb.0:
552     liveins: $f0s, $f2s, $r2d
553   
554     %2:addr64bit = COPY $r2d
555     %1:fp32bit = COPY $f2s
556     %0:fp32bit = COPY $f0s
557     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
558     %3:vr32bit = nofpexcept WFDSB %0, %1, implicit $fpc
559     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
560     Return
565 # CHECK-LABEL: fun16:
566 # CHECK: wfdsb   %f0, %f1, %f0
568 name:            fun16
569 alignment:       16
570 tracksRegLiveness: true
571 registers:
572   - { id: 0, class: fp32bit }
573   - { id: 1, class: fp32bit }
574   - { id: 2, class: addr64bit }
575   - { id: 3, class: vr32bit }
576 liveins:
577   - { reg: '$f0s', virtual-reg: '%0' }
578   - { reg: '$f2s', virtual-reg: '%1' }
579   - { reg: '$r2d', virtual-reg: '%2' }
580 frameInfo:
581   maxAlignment:    1
582 machineFunctionInfo: {}
583 body:             |
584   bb.0:
585     liveins: $f0s, $f2s, $r2d
586   
587     %2:addr64bit = COPY $r2d
588     %1:fp32bit = COPY $f2s
589     %0:fp32bit = COPY $f0s
590     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
591     %3:vr32bit = nofpexcept WFDSB %1, %0, implicit $fpc
592     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
593     Return
598 # DEB can't be used if one operand is a VR32 (and not FP32).
599 # CHECK-LABEL: fun17:
600 # CHECK: wfdsb   %f0, %f0, %v16
602 name:            fun17
603 alignment:       16
604 tracksRegLiveness: true
605 registers:
606   - { id: 0, class: fp32bit }
607   - { id: 1, class: vr32bit }
608   - { id: 2, class: addr64bit }
609   - { id: 3, class: vr32bit }
610 liveins:
611   - { reg: '$f0s', virtual-reg: '%0' }
612   - { reg: '$f2s', virtual-reg: '%1' }
613   - { reg: '$r2d', virtual-reg: '%2' }
614 frameInfo:
615   maxAlignment:    1
616 machineFunctionInfo: {}
617 body:             |
618   bb.0:
619     liveins: $f0s, $f2s, $r2d
620   
621     %2:addr64bit = COPY $r2d
622     %1:vr32bit = COPY $f2s
623     %0:fp32bit = COPY $f0s
624     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
625     %3:vr32bit = nofpexcept WFDSB %0, %1, implicit $fpc
626     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
627     Return
632 # CHECK-LABEL: fun18:
633 # CHECK: mdb     %f0, 160(%r15)                  # 8-byte Folded Reload
635 name:            fun18
636 alignment:       16
637 tracksRegLiveness: true
638 registers:
639   - { id: 0, class: fp64bit }
640   - { id: 1, class: fp64bit }
641   - { id: 2, class: addr64bit }
642   - { id: 3, class: vr64bit }
643 liveins:
644   - { reg: '$f0d', virtual-reg: '%0' }
645   - { reg: '$f2d', virtual-reg: '%1' }
646   - { reg: '$r2d', virtual-reg: '%2' }
647 frameInfo:
648   maxAlignment:    1
649 machineFunctionInfo: {}
650 body:             |
651   bb.0:
652     liveins: $f0d, $f2d, $r2d
653   
654     %2:addr64bit = COPY $r2d
655     %1:fp64bit = COPY $f2d
656     %0:fp64bit = COPY $f0d
657     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
658     %3:vr64bit = nofpexcept WFMDB %0, %1, implicit $fpc
659     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
660     Return
665 # CHECK-LABEL: fun19:
666 # CHECK: mdb     %f0, 160(%r15)                  # 8-byte Folded Reload
668 name:            fun19
669 alignment:       16
670 tracksRegLiveness: true
671 registers:
672   - { id: 0, class: fp64bit }
673   - { id: 1, class: fp64bit }
674   - { id: 2, class: addr64bit }
675   - { id: 3, class: vr64bit }
676 liveins:
677   - { reg: '$f0d', virtual-reg: '%0' }
678   - { reg: '$f2d', virtual-reg: '%1' }
679   - { reg: '$r2d', virtual-reg: '%2' }
680 frameInfo:
681   maxAlignment:    1
682 machineFunctionInfo: {}
683 body:             |
684   bb.0:
685     liveins: $f0d, $f2d, $r2d
686   
687     %2:addr64bit = COPY $r2d
688     %1:fp64bit = COPY $f2d
689     %0:fp64bit = COPY $f0d
690     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
691     %3:vr64bit = nofpexcept WFMDB %1, %0, implicit $fpc
692     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
693     Return
697 # MDB can't be used if one operand is a VR64 (and not FP64).
698 # CHECK-LABEL: fun20:
699 # CHECK: wfmdb   %f0, %v16, %f0
701 name:            fun20
702 alignment:       16
703 tracksRegLiveness: true
704 registers:
705   - { id: 0, class: fp64bit }
706   - { id: 1, class: vr64bit }
707   - { id: 2, class: addr64bit }
708   - { id: 3, class: vr64bit }
709 liveins:
710   - { reg: '$f0d', virtual-reg: '%0' }
711   - { reg: '$f2d', virtual-reg: '%1' }
712   - { reg: '$r2d', virtual-reg: '%2' }
713 frameInfo:
714   maxAlignment:    1
715 machineFunctionInfo: {}
716 body:             |
717   bb.0:
718     liveins: $f0d, $f2d, $r2d
719   
720     %2:addr64bit = COPY $r2d
721     %1:vr64bit = COPY $f2d
722     %0:fp64bit = COPY $f0d
723     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
724     %3:vr64bit = nofpexcept WFMDB %1, %0, implicit $fpc
725     VST64 %3, %2, 0, $noreg :: (store (s64) into %ir.Dst)
726     Return
731 # CHECK-LABEL: fun21:
732 # CHECK: meeb    %f0, 164(%r15)                  # 4-byte Folded Reload
734 name:            fun21
735 alignment:       16
736 tracksRegLiveness: true
737 registers:
738   - { id: 0, class: fp32bit }
739   - { id: 1, class: fp32bit }
740   - { id: 2, class: addr64bit }
741   - { id: 3, class: vr32bit }
742 liveins:
743   - { reg: '$f0s', virtual-reg: '%0' }
744   - { reg: '$f2s', virtual-reg: '%1' }
745   - { reg: '$r2d', virtual-reg: '%2' }
746 frameInfo:
747   maxAlignment:    1
748 machineFunctionInfo: {}
749 body:             |
750   bb.0:
751     liveins: $f0s, $f2s, $r2d
752   
753     %2:addr64bit = COPY $r2d
754     %1:fp32bit = COPY $f2s
755     %0:fp32bit = COPY $f0s
756     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
757     %3:vr32bit = nofpexcept WFMSB %0, %1, implicit $fpc
758     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
759     Return
764 # CHECK-LABEL: fun22:
765 # CHECK: meeb    %f0, 164(%r15)                  # 4-byte Folded Reload
767 name:            fun22
768 alignment:       16
769 tracksRegLiveness: true
770 registers:
771   - { id: 0, class: fp32bit }
772   - { id: 1, class: fp32bit }
773   - { id: 2, class: addr64bit }
774   - { id: 3, class: vr32bit }
775 liveins:
776   - { reg: '$f0s', virtual-reg: '%0' }
777   - { reg: '$f2s', virtual-reg: '%1' }
778   - { reg: '$r2d', virtual-reg: '%2' }
779 frameInfo:
780   maxAlignment:    1
781 machineFunctionInfo: {}
782 body:             |
783   bb.0:
784     liveins: $f0s, $f2s, $r2d
785   
786     %2:addr64bit = COPY $r2d
787     %1:fp32bit = COPY $f2s
788     %0:fp32bit = COPY $f0s
789     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
790     %3:vr32bit = nofpexcept WFMSB %1, %0, implicit $fpc
791     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
792     Return
797 # MEEB can't be used if one operand is a VR32 (and not FP32).
798 # CHECK-LABEL: fun23:
799 # CHECK: wfmsb   %f0, %v16, %f0
801 name:            fun23
802 alignment:       16
803 tracksRegLiveness: true
804 registers:
805   - { id: 0, class: fp32bit }
806   - { id: 1, class: vr32bit }
807   - { id: 2, class: addr64bit }
808   - { id: 3, class: vr32bit }
809 liveins:
810   - { reg: '$f0s', virtual-reg: '%0' }
811   - { reg: '$f2s', virtual-reg: '%1' }
812   - { reg: '$r2d', virtual-reg: '%2' }
813 frameInfo:
814   maxAlignment:    1
815 machineFunctionInfo: {}
816 body:             |
817   bb.0:
818     liveins: $f0s, $f2s, $r2d
819   
820     %2:addr64bit = COPY $r2d
821     %1:vr32bit = COPY $f2s
822     %0:fp32bit = COPY $f0s
823     INLINEASM &"", 1, 12, implicit-def dead early-clobber $r0d, 12, implicit-def dead early-clobber $r1d, 12, implicit-def dead early-clobber $r2d, 12, implicit-def dead early-clobber $r3d, 12, implicit-def dead early-clobber $r4d, 12, implicit-def dead early-clobber $r5d, 12, implicit-def dead early-clobber $r6d, 12, implicit-def dead early-clobber $r7d, 12, implicit-def dead early-clobber $r8d, 12, implicit-def dead early-clobber $r9d, 12, implicit-def dead early-clobber $r10d, 12, implicit-def dead early-clobber $r11d, 12, implicit-def dead early-clobber $r12d, 12, implicit-def dead early-clobber $r13d, 12, implicit-def dead early-clobber $r14d, 12, implicit-def dead early-clobber $f1d, 12, implicit-def dead early-clobber $f2d, 12, implicit-def dead early-clobber $f3d, 12, implicit-def dead early-clobber $f4d, 12, implicit-def dead early-clobber $f5d, 12, implicit-def dead early-clobber $f6d, 12, implicit-def dead early-clobber $f7d, 12, implicit-def dead early-clobber $f8d, 12, implicit-def dead early-clobber $f9d, 12, implicit-def dead early-clobber $f10d, 12, implicit-def dead early-clobber $f11d, 12, implicit-def dead early-clobber $f12d, 12, implicit-def dead early-clobber $f13d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f14d, 12, implicit-def dead early-clobber $f15d
824     %3:vr32bit = nofpexcept WFMSB %1, %0, implicit $fpc
825     VST32 %3, %2, 0, $noreg :: (store (s32) into %ir.Dst)
826     Return