Compiler projects using llvm
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -O0 -mtriple=mipsel-linux-gnu -global-isel \
; RUN:     -verify-machineinstrs %s -o -| FileCheck %s
; RUN: llc -O0 -mtriple=mipsel-linux-gnu -mattr=+fp64,+mips32r2 -global-isel \
; RUN:     -verify-machineinstrs %s -o -| FileCheck %s

define i1 @false_s(float %x, float %y) {
; CHECK-LABEL: false_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    ori $2, $zero, 0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp false float %x, %y
  ret i1 %cmp
}
define i1 @true_s(float %x, float %y) {
; CHECK-LABEL: true_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    ori $2, $zero, 1
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp true float %x, %y
  ret i1 %cmp
}


define i1 @uno_s(float %x, float %y) {
; CHECK-LABEL: uno_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.un.s $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp uno float %x, %y
  ret i1 %cmp
}
define i1 @ord_s(float %x, float %y) {
; CHECK-LABEL: ord_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.un.s $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ord float %x, %y
  ret i1 %cmp
}


define i1 @oeq_s(float %x, float %y) {
; CHECK-LABEL: oeq_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.eq.s $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp oeq float %x, %y
  ret i1 %cmp
}
define i1 @une_s(float %x, float %y) {
; CHECK-LABEL: une_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.eq.s $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp une float %x, %y
  ret i1 %cmp
}


define i1 @ueq_s(float %x, float %y) {
; CHECK-LABEL: ueq_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ueq.s $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ueq float %x, %y
  ret i1 %cmp
}
define i1 @one_s(float %x, float %y) {
; CHECK-LABEL: one_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ueq.s $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp one float %x, %y
  ret i1 %cmp
}


define i1 @olt_s(float %x, float %y) {
; CHECK-LABEL: olt_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.olt.s $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp olt float %x, %y
  ret i1 %cmp
}
define i1 @uge_s(float %x, float %y) {
; CHECK-LABEL: uge_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.olt.s $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp uge float %x, %y
  ret i1 %cmp
}


define i1 @ult_s(float %x, float %y) {
; CHECK-LABEL: ult_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ult.s $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ult float %x, %y
  ret i1 %cmp
}
define i1 @oge_s(float %x, float %y) {
; CHECK-LABEL: oge_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ult.s $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp oge float %x, %y
  ret i1 %cmp
}


define i1 @ole_s(float %x, float %y) {
; CHECK-LABEL: ole_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ole.s $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ole float %x, %y
  ret i1 %cmp
}
define i1 @ugt_s(float %x, float %y) {
; CHECK-LABEL: ugt_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ole.s $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ugt float %x, %y
  ret i1 %cmp
}


define i1 @ule_s(float %x, float %y) {
; CHECK-LABEL: ule_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ule.s $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ule float %x, %y
  ret i1 %cmp
}
define i1 @ogt_s(float %x, float %y) {
; CHECK-LABEL: ogt_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ule.s $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ogt float %x, %y
  ret i1 %cmp
}


define i1 @false_d(double %x, double %y) {
; CHECK-LABEL: false_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    ori $2, $zero, 0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp false double %x, %y
  ret i1 %cmp
}
define i1 @true_d(double %x, double %y) {
; CHECK-LABEL: true_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    ori $2, $zero, 1
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp true double %x, %y
  ret i1 %cmp
}


define i1 @uno_d(double %x, double %y) {
; CHECK-LABEL: uno_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.un.d $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp uno double %x, %y
  ret i1 %cmp
}
define i1 @ord_d(double %x, double %y) {
; CHECK-LABEL: ord_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.un.d $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ord double %x, %y
  ret i1 %cmp
}


define i1 @oeq_d(double %x, double %y) {
; CHECK-LABEL: oeq_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.eq.d $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp oeq double %x, %y
  ret i1 %cmp
}
define i1 @une_d(double %x, double %y) {
; CHECK-LABEL: une_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.eq.d $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp une double %x, %y
  ret i1 %cmp
}


define i1 @ueq_d(double %x, double %y) {
; CHECK-LABEL: ueq_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ueq.d $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ueq double %x, %y
  ret i1 %cmp
}
define i1 @one_d(double %x, double %y) {
; CHECK-LABEL: one_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ueq.d $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp one double %x, %y
  ret i1 %cmp
}


define i1 @olt_d(double %x, double %y) {
; CHECK-LABEL: olt_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.olt.d $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp olt double %x, %y
  ret i1 %cmp
}
define i1 @uge_d(double %x, double %y) {
; CHECK-LABEL: uge_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.olt.d $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp uge double %x, %y
  ret i1 %cmp
}


define i1 @ult_d(double %x, double %y) {
; CHECK-LABEL: ult_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ult.d $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ult double %x, %y
  ret i1 %cmp
}
define i1 @oge_d(double %x, double %y) {
; CHECK-LABEL: oge_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ult.d $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp oge double %x, %y
  ret i1 %cmp
}


define i1 @ole_d(double %x, double %y) {
; CHECK-LABEL: ole_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ole.d $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ole double %x, %y
  ret i1 %cmp
}
define i1 @ugt_d(double %x, double %y) {
; CHECK-LABEL: ugt_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ole.d $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ugt double %x, %y
  ret i1 %cmp
}


define i1 @ule_d(double %x, double %y) {
; CHECK-LABEL: ule_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ule.d $f12, $f14
; CHECK-NEXT:    movf $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ule double %x, %y
  ret i1 %cmp
}
define i1 @ogt_d(double %x, double %y) {
; CHECK-LABEL: ogt_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    addiu $2, $zero, 1
; CHECK-NEXT:    c.ule.d $f12, $f14
; CHECK-NEXT:    movt $2, $zero, $fcc0
; CHECK-NEXT:    jr $ra
; CHECK-NEXT:    nop
entry:
  %cmp = fcmp ogt double %x, %y
  ret i1 %cmp
}