| ; RUN: llc < %s -mtriple=ve-unknown-unknown | FileCheck %s |
| |
| define float @selectccaf(float, float, float, float) { |
| ; CHECK-LABEL: selectccaf: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp false float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccat(float, float, float, float) { |
| ; CHECK-LABEL: selectccat: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: or %s0, 0, %s2 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp true float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccoeq(float, float, float, float) { |
| ; CHECK-LABEL: selectccoeq: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.eq %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp oeq float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccone(float, float, float, float) { |
| ; CHECK-LABEL: selectccone: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.ne %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp one float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccogt(float, float, float, float) { |
| ; CHECK-LABEL: selectccogt: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.gt %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp ogt float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccoge(float, float, float, float) { |
| ; CHECK-LABEL: selectccoge: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.ge %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp oge float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccolt(float, float, float, float) { |
| ; CHECK-LABEL: selectccolt: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.lt %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp olt float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccole(float, float, float, float) { |
| ; CHECK-LABEL: selectccole: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.le %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp ole float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccord(float, float, float, float) { |
| ; CHECK-LABEL: selectccord: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.num %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp ord float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccuno(float, float, float, float) { |
| ; CHECK-LABEL: selectccuno: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.nan %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp uno float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccueq(float, float, float, float) { |
| ; CHECK-LABEL: selectccueq: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.eqnan %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp ueq float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccune(float, float, float, float) { |
| ; CHECK-LABEL: selectccune: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.nenan %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp une float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccugt(float, float, float, float) { |
| ; CHECK-LABEL: selectccugt: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.gtnan %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp ugt float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccuge(float, float, float, float) { |
| ; CHECK-LABEL: selectccuge: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.genan %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp uge float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccult(float, float, float, float) { |
| ; CHECK-LABEL: selectccult: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.ltnan %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp ult float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |
| |
| define float @selectccule(float, float, float, float) { |
| ; CHECK-LABEL: selectccule: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: fcmp.s %s0, %s0, %s1 |
| ; CHECK-NEXT: cmov.s.lenan %s3, %s2, %s0 |
| ; CHECK-NEXT: or %s0, 0, %s3 |
| ; CHECK-NEXT: b.l.t (, %s10) |
| %5 = fcmp ule float %0, %1 |
| %6 = select i1 %5, float %2, float %3 |
| ret float %6 |
| } |