Compiler projects using llvm
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py

; RUN: llc -verify-machineinstrs -csky-no-aliases < %s -mtriple=csky -float-abi=hard -mattr=+hard-float -mattr=+2e3 -mattr=+fpuv2_sf | FileCheck %s --check-prefix=CHECK-SF
; RUN: llc -verify-machineinstrs -csky-no-aliases < %s -mtriple=csky -float-abi=hard -mattr=+hard-float -mattr=+2e3 -mattr=+fpuv3_sf | FileCheck %s --check-prefix=CHECK-SF2


; float --> i32
define i32 @fptosiR_float_1(float %x) {
;
; CHECK-SF-LABEL: fptosiR_float_1:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstosi.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptosiR_float_1:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.s32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %fptosi = fptosi float %x to i32
  ret i32 %fptosi
}


; float --> i16
define i16 @fptosiR_float_2(float %x) {
;
; CHECK-SF-LABEL: fptosiR_float_2:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstosi.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptosiR_float_2:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.s32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %fptosi = fptosi float %x to i16
  ret i16 %fptosi
}


; float --> i8
define i8 @fptosiR_float_3(float %x) {
;
; CHECK-SF-LABEL: fptosiR_float_3:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstosi.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptosiR_float_3:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.s32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %fptosi = fptosi float %x to i8
  ret i8 %fptosi
}


; float --> i1
define i1 @fptosiR_float_4(float %x) {
;
; CHECK-SF-LABEL: fptosiR_float_4:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstosi.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptosiR_float_4:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.s32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %fptosi = fptosi float %x to i1
  ret i1 %fptosi
}




; float --> i32
define i32 @fptouiR_float_1(float %x) {
;
; CHECK-SF-LABEL: fptouiR_float_1:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstoui.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptouiR_float_1:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.u32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16


entry:
  %fptoui = fptoui float %x to i32
  ret i32 %fptoui
}



; float --> i16
define i16 @fptouiR_float_2(float %x) {
;
; CHECK-SF-LABEL: fptouiR_float_2:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstoui.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptouiR_float_2:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.u32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16


entry:
  %fptoui = fptoui float %x to i16
  ret i16 %fptoui
}



; float --> i8
define i8 @fptouiR_float_3(float %x) {
;
; CHECK-SF-LABEL: fptouiR_float_3:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstoui.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptouiR_float_3:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.u32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16


entry:
  %fptoui = fptoui float %x to i8
  ret i8 %fptoui
}


; float --> i1
define i1 @fptouiR_float_4(float %x) {
;
; CHECK-SF-LABEL: fptouiR_float_4:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fstoui.rz vr0, vr0
; CHECK-SF-NEXT:    fmfvrl a0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: fptouiR_float_4:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fftoi.f32.u32.rz vr0, vr0
; CHECK-SF2-NEXT:    fmfvr.32.1 a0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %fptoui = fptoui float %x to i1
  ret i1 %fptoui
}

; i32/i16/i8/i1 --> float

define float @sitofpR_float_0(i32 %x) {
;
; CHECK-SF-LABEL: sitofpR_float_0:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fsitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: sitofpR_float_0:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.s32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %sitofp = sitofp i32 %x to float
  ret float %sitofp
}

define float @sitofpR_float_1(i16 %x) {
;
; CHECK-SF-LABEL: sitofpR_float_1:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    sexth16 a0, a0
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fsitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: sitofpR_float_1:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    sexth16 a0, a0
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.s32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %sitofp = sitofp i16 %x to float
  ret float %sitofp
}

define float @sitofpR_float_2(i8 %x) {
;
; CHECK-SF-LABEL: sitofpR_float_2:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    sextb16 a0, a0
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fsitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: sitofpR_float_2:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    sextb16 a0, a0
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.s32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %sitofp = sitofp i8 %x to float
  ret float %sitofp
}

define float @sitofpR_float_3(i1 %x) {
;
; CHECK-SF-LABEL: sitofpR_float_3:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    sext32 a0, a0, 0, 0
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fsitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: sitofpR_float_3:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    sext32 a0, a0, 0, 0
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.s32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %sitofp = sitofp i1 %x to float
  ret float %sitofp
}

; i32/i16/i8/i1 --> float

define float @uitofpR_float_0(i32 %x) {
;
; CHECK-SF-LABEL: uitofpR_float_0:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fuitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: uitofpR_float_0:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.u32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %uitofp = uitofp i32 %x to float
  ret float %uitofp
}

define float @uitofpR_float_1(i16 %x) {
;
; CHECK-SF-LABEL: uitofpR_float_1:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    zexth16 a0, a0
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fuitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: uitofpR_float_1:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    zexth16 a0, a0
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.u32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %uitofp = uitofp i16 %x to float
  ret float %uitofp
}

define float @uitofpR_float_2(i8 %x) {
;
; CHECK-SF-LABEL: uitofpR_float_2:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    zextb16 a0, a0
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fuitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: uitofpR_float_2:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    zextb16 a0, a0
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.u32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %uitofp = uitofp i8 %x to float
  ret float %uitofp
}

define float @uitofpR_float_3(i1 %x) {
;
; CHECK-SF-LABEL: uitofpR_float_3:
; CHECK-SF:       # %bb.0: # %entry
; CHECK-SF-NEXT:    andi32 a0, a0, 1
; CHECK-SF-NEXT:    fmtvrl vr0, a0
; CHECK-SF-NEXT:    fuitos vr0, vr0
; CHECK-SF-NEXT:    rts16
;
; CHECK-SF2-LABEL: uitofpR_float_3:
; CHECK-SF2:       # %bb.0: # %entry
; CHECK-SF2-NEXT:    andi32 a0, a0, 1
; CHECK-SF2-NEXT:    fmtvr.32.1 vr0, a0
; CHECK-SF2-NEXT:    fitof.u32.f32 vr0, vr0
; CHECK-SF2-NEXT:    rts16
entry:
  %uitofp = uitofp i1 %x to float
  ret float %uitofp
}