; 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
}