1 # RUN: llc -mtriple=s390x-linux-gnu -mcpu=z14 -start-before=greedy %s -o - \
4 # Test folding of a memory operand into an fp memory instruction.
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 }
34 # Test with both orders of operands since some operations are commutative.
37 # CHECK: adb %f0, 160(%r15) # 8-byte Folded Reload
41 tracksRegLiveness: true
43 - { id: 0, class: fp64bit }
44 - { id: 1, class: fp64bit }
45 - { id: 2, class: addr64bit }
46 - { id: 3, class: vr64bit }
48 - { reg: '$f0d', virtual-reg: '%0' }
49 - { reg: '$f2d', virtual-reg: '%1' }
50 - { reg: '$r2d', virtual-reg: '%2' }
53 machineFunctionInfo: {}
56 liveins: $f0d, $f2d, $r2d
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)
70 # CHECK: adb %f0, 160(%r15) # 8-byte Folded Reload
74 tracksRegLiveness: true
76 - { id: 0, class: fp64bit }
77 - { id: 1, class: fp64bit }
78 - { id: 2, class: addr64bit }
79 - { id: 3, class: vr64bit }
81 - { reg: '$f0d', virtual-reg: '%0' }
82 - { reg: '$f2d', virtual-reg: '%1' }
83 - { reg: '$r2d', virtual-reg: '%2' }
86 machineFunctionInfo: {}
89 liveins: $f0d, $f2d, $r2d
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)
101 # ADB can't be used if one operand is a VR64 (and not FP64).
103 # CHECK: wfadb %f0, %v16, %f0
107 tracksRegLiveness: true
109 - { id: 0, class: fp64bit }
110 - { id: 1, class: vr64bit }
111 - { id: 2, class: addr64bit }
112 - { id: 3, class: vr64bit }
114 - { reg: '$f0d', virtual-reg: '%0' }
115 - { reg: '$f2d', virtual-reg: '%1' }
116 - { reg: '$r2d', virtual-reg: '%2' }
119 machineFunctionInfo: {}
122 liveins: $f0d, $f2d, $r2d
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)
136 # CHECK: aeb %f0, 164(%r15) # 4-byte Folded Reload
140 tracksRegLiveness: true
142 - { id: 0, class: fp32bit }
143 - { id: 1, class: fp32bit }
144 - { id: 2, class: addr64bit }
145 - { id: 3, class: vr32bit }
147 - { reg: '$f0s', virtual-reg: '%0' }
148 - { reg: '$f2s', virtual-reg: '%1' }
149 - { reg: '$r2d', virtual-reg: '%2' }
152 machineFunctionInfo: {}
155 liveins: $f0s, $f2s, $r2d
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)
169 # CHECK: aeb %f0, 164(%r15) # 4-byte Folded Reload
173 tracksRegLiveness: true
175 - { id: 0, class: fp32bit }
176 - { id: 1, class: fp32bit }
177 - { id: 2, class: addr64bit }
178 - { id: 3, class: vr32bit }
180 - { reg: '$f0s', virtual-reg: '%0' }
181 - { reg: '$f2s', virtual-reg: '%1' }
182 - { reg: '$r2d', virtual-reg: '%2' }
185 machineFunctionInfo: {}
188 liveins: $f0s, $f2s, $r2d
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)
201 # AEB can't be used if one operand is a VR64 (and not FP64).
203 # CHECK: wfasb %f0, %v16, %f0
207 tracksRegLiveness: true
209 - { id: 0, class: fp32bit }
210 - { id: 1, class: vr32bit }
211 - { id: 2, class: addr64bit }
212 - { id: 3, class: vr32bit }
214 - { reg: '$f0s', virtual-reg: '%0' }
215 - { reg: '$f2s', virtual-reg: '%1' }
216 - { reg: '$r2d', virtual-reg: '%2' }
219 machineFunctionInfo: {}
222 liveins: $f0s, $f2s, $r2d
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)
236 # CHECK: sdb %f0, 160(%r15) # 8-byte Folded Reload
240 tracksRegLiveness: true
242 - { id: 0, class: fp64bit }
243 - { id: 1, class: fp64bit }
244 - { id: 2, class: addr64bit }
245 - { id: 3, class: vr64bit }
247 - { reg: '$f0d', virtual-reg: '%0' }
248 - { reg: '$f2d', virtual-reg: '%1' }
249 - { reg: '$r2d', virtual-reg: '%2' }
252 machineFunctionInfo: {}
255 liveins: $f0d, $f2d, $r2d
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)
269 # CHECK: wfsdb %f0, %f1, %f0
273 tracksRegLiveness: true
275 - { id: 0, class: fp64bit }
276 - { id: 1, class: fp64bit }
277 - { id: 2, class: addr64bit }
278 - { id: 3, class: vr64bit }
280 - { reg: '$f0d', virtual-reg: '%0' }
281 - { reg: '$f2d', virtual-reg: '%1' }
282 - { reg: '$r2d', virtual-reg: '%2' }
285 machineFunctionInfo: {}
288 liveins: $f0d, $f2d, $r2d
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)
300 # SDB can't be used if one operand is a VR64 (and not FP64).
302 # CHECK: wfsdb %f0, %f0, %v16
306 tracksRegLiveness: true
308 - { id: 0, class: fp64bit }
309 - { id: 1, class: vr64bit }
310 - { id: 2, class: addr64bit }
311 - { id: 3, class: vr64bit }
313 - { reg: '$f0d', virtual-reg: '%0' }
314 - { reg: '$f2d', virtual-reg: '%1' }
315 - { reg: '$r2d', virtual-reg: '%2' }
318 machineFunctionInfo: {}
321 liveins: $f0d, $f2d, $r2d
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)
335 # CHECK: seb %f0, 164(%r15) # 4-byte Folded Reload
339 tracksRegLiveness: true
341 - { id: 0, class: fp32bit }
342 - { id: 1, class: fp32bit }
343 - { id: 2, class: addr64bit }
344 - { id: 3, class: vr32bit }
346 - { reg: '$f0s', virtual-reg: '%0' }
347 - { reg: '$f2s', virtual-reg: '%1' }
348 - { reg: '$r2d', virtual-reg: '%2' }
351 machineFunctionInfo: {}
354 liveins: $f0s, $f2s, $r2d
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)
367 # CHECK-LABEL: fun10:
368 # CHECK: wfssb %f0, %f1, %f0
372 tracksRegLiveness: true
374 - { id: 0, class: fp32bit }
375 - { id: 1, class: fp32bit }
376 - { id: 2, class: addr64bit }
377 - { id: 3, class: vr32bit }
379 - { reg: '$f0s', virtual-reg: '%0' }
380 - { reg: '$f2s', virtual-reg: '%1' }
381 - { reg: '$r2d', virtual-reg: '%2' }
384 machineFunctionInfo: {}
387 liveins: $f0s, $f2s, $r2d
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)
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
406 tracksRegLiveness: true
408 - { id: 0, class: fp32bit }
409 - { id: 1, class: vr32bit }
410 - { id: 2, class: addr64bit }
411 - { id: 3, class: vr32bit }
413 - { reg: '$f0s', virtual-reg: '%0' }
414 - { reg: '$f2s', virtual-reg: '%1' }
415 - { reg: '$r2d', virtual-reg: '%2' }
418 machineFunctionInfo: {}
421 liveins: $f0s, $f2s, $r2d
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)
433 # CHECK-LABEL: fun12:
434 # CHECK: ddb %f0, 160(%r15) # 8-byte Folded Reload
438 tracksRegLiveness: true
440 - { id: 0, class: fp64bit }
441 - { id: 1, class: fp64bit }
442 - { id: 2, class: addr64bit }
443 - { id: 3, class: vr64bit }
445 - { reg: '$f0d', virtual-reg: '%0' }
446 - { reg: '$f2d', virtual-reg: '%1' }
447 - { reg: '$r2d', virtual-reg: '%2' }
450 machineFunctionInfo: {}
453 liveins: $f0d, $f2d, $r2d
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)
466 # CHECK-LABEL: fun13:
467 # CHECK: wfddb %f0, %f1, %f0
471 tracksRegLiveness: true
473 - { id: 0, class: fp64bit }
474 - { id: 1, class: fp64bit }
475 - { id: 2, class: addr64bit }
476 - { id: 3, class: vr64bit }
478 - { reg: '$f0d', virtual-reg: '%0' }
479 - { reg: '$f2d', virtual-reg: '%1' }
480 - { reg: '$r2d', virtual-reg: '%2' }
483 machineFunctionInfo: {}
486 liveins: $f0d, $f2d, $r2d
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)
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
504 tracksRegLiveness: true
506 - { id: 0, class: fp64bit }
507 - { id: 1, class: vr64bit }
508 - { id: 2, class: addr64bit }
509 - { id: 3, class: vr64bit }
511 - { reg: '$f0d', virtual-reg: '%0' }
512 - { reg: '$f2d', virtual-reg: '%1' }
513 - { reg: '$r2d', virtual-reg: '%2' }
516 machineFunctionInfo: {}
519 liveins: $f0d, $f2d, $r2d
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)
532 # CHECK-LABEL: fun15:
533 # CHECK: deb %f0, 164(%r15) # 4-byte Folded Reload
537 tracksRegLiveness: true
539 - { id: 0, class: fp32bit }
540 - { id: 1, class: fp32bit }
541 - { id: 2, class: addr64bit }
542 - { id: 3, class: vr32bit }
544 - { reg: '$f0s', virtual-reg: '%0' }
545 - { reg: '$f2s', virtual-reg: '%1' }
546 - { reg: '$r2d', virtual-reg: '%2' }
549 machineFunctionInfo: {}
552 liveins: $f0s, $f2s, $r2d
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)
565 # CHECK-LABEL: fun16:
566 # CHECK: wfdsb %f0, %f1, %f0
570 tracksRegLiveness: true
572 - { id: 0, class: fp32bit }
573 - { id: 1, class: fp32bit }
574 - { id: 2, class: addr64bit }
575 - { id: 3, class: vr32bit }
577 - { reg: '$f0s', virtual-reg: '%0' }
578 - { reg: '$f2s', virtual-reg: '%1' }
579 - { reg: '$r2d', virtual-reg: '%2' }
582 machineFunctionInfo: {}
585 liveins: $f0s, $f2s, $r2d
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)
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
604 tracksRegLiveness: true
606 - { id: 0, class: fp32bit }
607 - { id: 1, class: vr32bit }
608 - { id: 2, class: addr64bit }
609 - { id: 3, class: vr32bit }
611 - { reg: '$f0s', virtual-reg: '%0' }
612 - { reg: '$f2s', virtual-reg: '%1' }
613 - { reg: '$r2d', virtual-reg: '%2' }
616 machineFunctionInfo: {}
619 liveins: $f0s, $f2s, $r2d
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)
632 # CHECK-LABEL: fun18:
633 # CHECK: mdb %f0, 160(%r15) # 8-byte Folded Reload
637 tracksRegLiveness: true
639 - { id: 0, class: fp64bit }
640 - { id: 1, class: fp64bit }
641 - { id: 2, class: addr64bit }
642 - { id: 3, class: vr64bit }
644 - { reg: '$f0d', virtual-reg: '%0' }
645 - { reg: '$f2d', virtual-reg: '%1' }
646 - { reg: '$r2d', virtual-reg: '%2' }
649 machineFunctionInfo: {}
652 liveins: $f0d, $f2d, $r2d
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)
665 # CHECK-LABEL: fun19:
666 # CHECK: mdb %f0, 160(%r15) # 8-byte Folded Reload
670 tracksRegLiveness: true
672 - { id: 0, class: fp64bit }
673 - { id: 1, class: fp64bit }
674 - { id: 2, class: addr64bit }
675 - { id: 3, class: vr64bit }
677 - { reg: '$f0d', virtual-reg: '%0' }
678 - { reg: '$f2d', virtual-reg: '%1' }
679 - { reg: '$r2d', virtual-reg: '%2' }
682 machineFunctionInfo: {}
685 liveins: $f0d, $f2d, $r2d
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)
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
703 tracksRegLiveness: true
705 - { id: 0, class: fp64bit }
706 - { id: 1, class: vr64bit }
707 - { id: 2, class: addr64bit }
708 - { id: 3, class: vr64bit }
710 - { reg: '$f0d', virtual-reg: '%0' }
711 - { reg: '$f2d', virtual-reg: '%1' }
712 - { reg: '$r2d', virtual-reg: '%2' }
715 machineFunctionInfo: {}
718 liveins: $f0d, $f2d, $r2d
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)
731 # CHECK-LABEL: fun21:
732 # CHECK: meeb %f0, 164(%r15) # 4-byte Folded Reload
736 tracksRegLiveness: true
738 - { id: 0, class: fp32bit }
739 - { id: 1, class: fp32bit }
740 - { id: 2, class: addr64bit }
741 - { id: 3, class: vr32bit }
743 - { reg: '$f0s', virtual-reg: '%0' }
744 - { reg: '$f2s', virtual-reg: '%1' }
745 - { reg: '$r2d', virtual-reg: '%2' }
748 machineFunctionInfo: {}
751 liveins: $f0s, $f2s, $r2d
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)
764 # CHECK-LABEL: fun22:
765 # CHECK: meeb %f0, 164(%r15) # 4-byte Folded Reload
769 tracksRegLiveness: true
771 - { id: 0, class: fp32bit }
772 - { id: 1, class: fp32bit }
773 - { id: 2, class: addr64bit }
774 - { id: 3, class: vr32bit }
776 - { reg: '$f0s', virtual-reg: '%0' }
777 - { reg: '$f2s', virtual-reg: '%1' }
778 - { reg: '$r2d', virtual-reg: '%2' }
781 machineFunctionInfo: {}
784 liveins: $f0s, $f2s, $r2d
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)
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
803 tracksRegLiveness: true
805 - { id: 0, class: fp32bit }
806 - { id: 1, class: vr32bit }
807 - { id: 2, class: addr64bit }
808 - { id: 3, class: vr32bit }
810 - { reg: '$f0s', virtual-reg: '%0' }
811 - { reg: '$f2s', virtual-reg: '%1' }
812 - { reg: '$r2d', virtual-reg: '%2' }
815 machineFunctionInfo: {}
818 liveins: $f0s, $f2s, $r2d
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)