llvm/llvm/test/CodeGen/LoongArch/lasx/intrinsic-ftint.ll

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc --mtriple=loongarch64 --mattr=+lasx < %s | FileCheck %s

declare <8 x i32> @llvm.loongarch.lasx.xvftintrne.w.s(<8 x float>)

define <8 x i32> @lasx_xvftintrne_w_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrne_w_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrne.w.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrne.w.s(<8 x float> %va)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrne.l.d(<4 x double>)

define <4 x i64> @lasx_xvftintrne_l_d(<4 x double> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrne_l_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrne.l.d $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrne.l.d(<4 x double> %va)
  ret <4 x i64> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrz.w.s(<8 x float>)

define <8 x i32> @lasx_xvftintrz_w_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrz_w_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrz.w.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrz.w.s(<8 x float> %va)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrz.l.d(<4 x double>)

define <4 x i64> @lasx_xvftintrz_l_d(<4 x double> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrz_l_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrz.l.d $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrz.l.d(<4 x double> %va)
  ret <4 x i64> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrp.w.s(<8 x float>)

define <8 x i32> @lasx_xvftintrp_w_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrp_w_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrp.w.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrp.w.s(<8 x float> %va)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrp.l.d(<4 x double>)

define <4 x i64> @lasx_xvftintrp_l_d(<4 x double> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrp_l_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrp.l.d $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrp.l.d(<4 x double> %va)
  ret <4 x i64> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrm.w.s(<8 x float>)

define <8 x i32> @lasx_xvftintrm_w_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrm_w_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrm.w.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrm.w.s(<8 x float> %va)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrm.l.d(<4 x double>)

define <4 x i64> @lasx_xvftintrm_l_d(<4 x double> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrm_l_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrm.l.d $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrm.l.d(<4 x double> %va)
  ret <4 x i64> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftint.w.s(<8 x float>)

define <8 x i32> @lasx_xvftint_w_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftint_w_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftint.w.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftint.w.s(<8 x float> %va)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftint.l.d(<4 x double>)

define <4 x i64> @lasx_xvftint_l_d(<4 x double> %va) nounwind {
; CHECK-LABEL: lasx_xvftint_l_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftint.l.d $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftint.l.d(<4 x double> %va)
  ret <4 x i64> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrz.wu.s(<8 x float>)

define <8 x i32> @lasx_xvftintrz_wu_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrz_wu_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrz.wu.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrz.wu.s(<8 x float> %va)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrz.lu.d(<4 x double>)

define <4 x i64> @lasx_xvftintrz_lu_d(<4 x double> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrz_lu_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrz.lu.d $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrz.lu.d(<4 x double> %va)
  ret <4 x i64> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftint.wu.s(<8 x float>)

define <8 x i32> @lasx_xvftint_wu_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftint_wu_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftint.wu.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftint.wu.s(<8 x float> %va)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftint.lu.d(<4 x double>)

define <4 x i64> @lasx_xvftint_lu_d(<4 x double> %va) nounwind {
; CHECK-LABEL: lasx_xvftint_lu_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftint.lu.d $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftint.lu.d(<4 x double> %va)
  ret <4 x i64> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrne.w.d(<4 x double>, <4 x double>)

define <8 x i32> @lasx_xvftintrne_w_d(<4 x double> %va, <4 x double> %vb) nounwind {
; CHECK-LABEL: lasx_xvftintrne_w_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrne.w.d $xr0, $xr0, $xr1
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrne.w.d(<4 x double> %va, <4 x double> %vb)
  ret <8 x i32> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrz.w.d(<4 x double>, <4 x double>)

define <8 x i32> @lasx_xvftintrz_w_d(<4 x double> %va, <4 x double> %vb) nounwind {
; CHECK-LABEL: lasx_xvftintrz_w_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrz.w.d $xr0, $xr0, $xr1
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrz.w.d(<4 x double> %va, <4 x double> %vb)
  ret <8 x i32> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrp.w.d(<4 x double>, <4 x double>)

define <8 x i32> @lasx_xvftintrp_w_d(<4 x double> %va, <4 x double> %vb) nounwind {
; CHECK-LABEL: lasx_xvftintrp_w_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrp.w.d $xr0, $xr0, $xr1
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrp.w.d(<4 x double> %va, <4 x double> %vb)
  ret <8 x i32> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftintrm.w.d(<4 x double>, <4 x double>)

define <8 x i32> @lasx_xvftintrm_w_d(<4 x double> %va, <4 x double> %vb) nounwind {
; CHECK-LABEL: lasx_xvftintrm_w_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrm.w.d $xr0, $xr0, $xr1
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftintrm.w.d(<4 x double> %va, <4 x double> %vb)
  ret <8 x i32> %res
}

declare <8 x i32> @llvm.loongarch.lasx.xvftint.w.d(<4 x double>, <4 x double>)

define <8 x i32> @lasx_xvftint_w_d(<4 x double> %va, <4 x double> %vb) nounwind {
; CHECK-LABEL: lasx_xvftint_w_d:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftint.w.d $xr0, $xr0, $xr1
; CHECK-NEXT:    ret
entry:
  %res = call <8 x i32> @llvm.loongarch.lasx.xvftint.w.d(<4 x double> %va, <4 x double> %vb)
  ret <8 x i32> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrnel.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrnel_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrnel_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrnel.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrnel.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrneh.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrneh_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrneh_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrneh.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrneh.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrzl.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrzl_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrzl_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrzl.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrzl.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrzh.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrzh_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrzh_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrzh.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrzh.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrpl.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrpl_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrpl_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrpl.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrpl.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrph.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrph_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrph_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrph.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrph.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrml.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrml_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrml_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrml.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrml.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintrmh.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintrmh_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintrmh_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintrmh.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintrmh.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftintl.l.s(<8 x float>)

define <4 x i64> @lasx_xvftintl_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftintl_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftintl.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftintl.l.s(<8 x float> %va)
  ret <4 x i64> %res
}

declare <4 x i64> @llvm.loongarch.lasx.xvftinth.l.s(<8 x float>)

define <4 x i64> @lasx_xvftinth_l_s(<8 x float> %va) nounwind {
; CHECK-LABEL: lasx_xvftinth_l_s:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xvftinth.l.s $xr0, $xr0
; CHECK-NEXT:    ret
entry:
  %res = call <4 x i64> @llvm.loongarch.lasx.xvftinth.l.s(<8 x float> %va)
  ret <4 x i64> %res
}