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