1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc --mtriple=loongarch32 --mattr=+d < %s | FileCheck %s --check-prefix=LA32
3 ; RUN: llc --mtriple=loongarch64 --mattr=+d < %s | FileCheck %s --check-prefix=LA64
5 ;; Test double-precision floating-point values selection after comparison
7 define double @fcmp_false(double %a, double %b, double %x, double %y) {
8 ; LA32-LABEL: fcmp_false:
10 ; LA32-NEXT: fmov.d $fa0, $fa3
13 ; LA64-LABEL: fcmp_false:
15 ; LA64-NEXT: fmov.d $fa0, $fa3
17 %cmp = fcmp false double %a, %b
18 %res = select i1 %cmp, double %x, double %y
22 define double @fcmp_oeq(double %a, double %b, double %x, double %y) {
23 ; LA32-LABEL: fcmp_oeq:
25 ; LA32-NEXT: fcmp.ceq.d $fcc0, $fa0, $fa1
26 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
29 ; LA64-LABEL: fcmp_oeq:
31 ; LA64-NEXT: fcmp.ceq.d $fcc0, $fa0, $fa1
32 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
34 %cmp = fcmp oeq double %a, %b
35 %res = select i1 %cmp, double %x, double %y
39 define double @fcmp_ogt(double %a, double %b, double %x, double %y) {
40 ; LA32-LABEL: fcmp_ogt:
42 ; LA32-NEXT: fcmp.clt.d $fcc0, $fa1, $fa0
43 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
46 ; LA64-LABEL: fcmp_ogt:
48 ; LA64-NEXT: fcmp.clt.d $fcc0, $fa1, $fa0
49 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
51 %cmp = fcmp ogt double %a, %b
52 %res = select i1 %cmp, double %x, double %y
56 define double @fcmp_oge(double %a, double %b, double %x, double %y) {
57 ; LA32-LABEL: fcmp_oge:
59 ; LA32-NEXT: fcmp.cle.d $fcc0, $fa1, $fa0
60 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
63 ; LA64-LABEL: fcmp_oge:
65 ; LA64-NEXT: fcmp.cle.d $fcc0, $fa1, $fa0
66 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
68 %cmp = fcmp oge double %a, %b
69 %res = select i1 %cmp, double %x, double %y
73 define double @fcmp_olt(double %a, double %b, double %x, double %y) {
74 ; LA32-LABEL: fcmp_olt:
76 ; LA32-NEXT: fcmp.clt.d $fcc0, $fa0, $fa1
77 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
80 ; LA64-LABEL: fcmp_olt:
82 ; LA64-NEXT: fcmp.clt.d $fcc0, $fa0, $fa1
83 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
85 %cmp = fcmp olt double %a, %b
86 %res = select i1 %cmp, double %x, double %y
90 define double @fcmp_ole(double %a, double %b, double %x, double %y) {
91 ; LA32-LABEL: fcmp_ole:
93 ; LA32-NEXT: fcmp.cle.d $fcc0, $fa0, $fa1
94 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
97 ; LA64-LABEL: fcmp_ole:
99 ; LA64-NEXT: fcmp.cle.d $fcc0, $fa0, $fa1
100 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
102 %cmp = fcmp ole double %a, %b
103 %res = select i1 %cmp, double %x, double %y
107 define double @fcmp_one(double %a, double %b, double %x, double %y) {
108 ; LA32-LABEL: fcmp_one:
110 ; LA32-NEXT: fcmp.cne.d $fcc0, $fa0, $fa1
111 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
114 ; LA64-LABEL: fcmp_one:
116 ; LA64-NEXT: fcmp.cne.d $fcc0, $fa0, $fa1
117 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
119 %cmp = fcmp one double %a, %b
120 %res = select i1 %cmp, double %x, double %y
124 define double @fcmp_ord(double %a, double %b, double %x, double %y) {
125 ; LA32-LABEL: fcmp_ord:
127 ; LA32-NEXT: fcmp.cor.d $fcc0, $fa0, $fa1
128 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
131 ; LA64-LABEL: fcmp_ord:
133 ; LA64-NEXT: fcmp.cor.d $fcc0, $fa0, $fa1
134 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
136 %cmp = fcmp ord double %a, %b
137 %res = select i1 %cmp, double %x, double %y
141 define double @fcmp_ueq(double %a, double %b, double %x, double %y) {
142 ; LA32-LABEL: fcmp_ueq:
144 ; LA32-NEXT: fcmp.cueq.d $fcc0, $fa0, $fa1
145 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
148 ; LA64-LABEL: fcmp_ueq:
150 ; LA64-NEXT: fcmp.cueq.d $fcc0, $fa0, $fa1
151 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
153 %cmp = fcmp ueq double %a, %b
154 %res = select i1 %cmp, double %x, double %y
158 define double @fcmp_ugt(double %a, double %b, double %x, double %y) {
159 ; LA32-LABEL: fcmp_ugt:
161 ; LA32-NEXT: fcmp.cult.d $fcc0, $fa1, $fa0
162 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
165 ; LA64-LABEL: fcmp_ugt:
167 ; LA64-NEXT: fcmp.cult.d $fcc0, $fa1, $fa0
168 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
170 %cmp = fcmp ugt double %a, %b
171 %res = select i1 %cmp, double %x, double %y
175 define double @fcmp_uge(double %a, double %b, double %x, double %y) {
176 ; LA32-LABEL: fcmp_uge:
178 ; LA32-NEXT: fcmp.cule.d $fcc0, $fa1, $fa0
179 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
182 ; LA64-LABEL: fcmp_uge:
184 ; LA64-NEXT: fcmp.cule.d $fcc0, $fa1, $fa0
185 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
187 %cmp = fcmp uge double %a, %b
188 %res = select i1 %cmp, double %x, double %y
192 define double @fcmp_ult(double %a, double %b, double %x, double %y) {
193 ; LA32-LABEL: fcmp_ult:
195 ; LA32-NEXT: fcmp.cult.d $fcc0, $fa0, $fa1
196 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
199 ; LA64-LABEL: fcmp_ult:
201 ; LA64-NEXT: fcmp.cult.d $fcc0, $fa0, $fa1
202 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
204 %cmp = fcmp ult double %a, %b
205 %res = select i1 %cmp, double %x, double %y
209 define double @fcmp_ule(double %a, double %b, double %x, double %y) {
210 ; LA32-LABEL: fcmp_ule:
212 ; LA32-NEXT: fcmp.cule.d $fcc0, $fa0, $fa1
213 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
216 ; LA64-LABEL: fcmp_ule:
218 ; LA64-NEXT: fcmp.cule.d $fcc0, $fa0, $fa1
219 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
221 %cmp = fcmp ule double %a, %b
222 %res = select i1 %cmp, double %x, double %y
226 define double @fcmp_une(double %a, double %b, double %x, double %y) {
227 ; LA32-LABEL: fcmp_une:
229 ; LA32-NEXT: fcmp.cune.d $fcc0, $fa0, $fa1
230 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
233 ; LA64-LABEL: fcmp_une:
235 ; LA64-NEXT: fcmp.cune.d $fcc0, $fa0, $fa1
236 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
238 %cmp = fcmp une double %a, %b
239 %res = select i1 %cmp, double %x, double %y
243 define double @fcmp_uno(double %a, double %b, double %x, double %y) {
244 ; LA32-LABEL: fcmp_uno:
246 ; LA32-NEXT: fcmp.cun.d $fcc0, $fa0, $fa1
247 ; LA32-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
250 ; LA64-LABEL: fcmp_uno:
252 ; LA64-NEXT: fcmp.cun.d $fcc0, $fa0, $fa1
253 ; LA64-NEXT: fsel $fa0, $fa3, $fa2, $fcc0
255 %cmp = fcmp uno double %a, %b
256 %res = select i1 %cmp, double %x, double %y
260 define double @fcmp_true(double %a, double %b, double %x, double %y) {
261 ; LA32-LABEL: fcmp_true:
263 ; LA32-NEXT: fmov.d $fa0, $fa2
266 ; LA64-LABEL: fcmp_true:
268 ; LA64-NEXT: fmov.d $fa0, $fa2
270 %cmp = fcmp true double %a, %b
271 %res = select i1 %cmp, double %x, double %y