| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| ; RUN: llc -mtriple=riscv32 -mattr=+v,+m -riscv-v-vector-bits-min=128 -verify-machineinstrs < %s \ |
| ; RUN: | FileCheck %s --check-prefixes=CHECK,RV32 |
| ; RUN: llc -mtriple=riscv64 -mattr=+v,+m -riscv-v-vector-bits-min=128 -verify-machineinstrs < %s \ |
| ; RUN: | FileCheck %s --check-prefixes=CHECK,RV64 |
| |
| ; FIXME: We're missing canonicalizations of ISD::VP_SETCC equivalent to those |
| ; for ISD::SETCC, e.g., splats aren't moved to the RHS. |
| |
| declare <8 x i1> @llvm.vp.icmp.v8i7(<8 x i7>, <8 x i7>, metadata, <8 x i1>, i32) |
| |
| define <8 x i1> @icmp_eq_vv_v8i7(<8 x i7> %va, <8 x i7> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vv_v8i7: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: li a1, 127 |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, ta, mu |
| ; CHECK-NEXT: vand.vx v9, v9, a1 |
| ; CHECK-NEXT: vand.vx v8, v8, a1 |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i7(<8 x i7> %va, <8 x i7> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_v8i7(<8 x i7> %va, i7 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_v8i7: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: li a2, 127 |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, ta, mu |
| ; CHECK-NEXT: vand.vx v8, v8, a2 |
| ; CHECK-NEXT: vmv.v.x v9, a0 |
| ; CHECK-NEXT: vand.vx v9, v9, a2 |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i7> poison, i7 %b, i32 0 |
| %vb = shufflevector <8 x i7> %elt.head, <8 x i7> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i7(<8 x i7> %va, <8 x i7> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_swap_v8i7(<8 x i7> %va, i7 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_swap_v8i7: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: li a2, 127 |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, ta, mu |
| ; CHECK-NEXT: vand.vx v8, v8, a2 |
| ; CHECK-NEXT: vmv.v.x v9, a0 |
| ; CHECK-NEXT: vand.vx v9, v9, a2 |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i7> poison, i7 %b, i32 0 |
| %vb = shufflevector <8 x i7> %elt.head, <8 x i7> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i7(<8 x i7> %vb, <8 x i7> %va, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| declare <5 x i1> @llvm.vp.icmp.v5i8(<5 x i8>, <5 x i8>, metadata, <5 x i1>, i32) |
| |
| define <5 x i1> @icmp_eq_vv_v5i8(<5 x i8> %va, <5 x i8> %vb, <5 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vv_v5i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <5 x i1> @llvm.vp.icmp.v5i8(<5 x i8> %va, <5 x i8> %vb, metadata !"eq", <5 x i1> %m, i32 %evl) |
| ret <5 x i1> %v |
| } |
| |
| define <5 x i1> @icmp_eq_vx_v5i8(<5 x i8> %va, i8 %b, <5 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_v5i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <5 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <5 x i8> %elt.head, <5 x i8> poison, <5 x i32> zeroinitializer |
| %v = call <5 x i1> @llvm.vp.icmp.v5i8(<5 x i8> %va, <5 x i8> %vb, metadata !"eq", <5 x i1> %m, i32 %evl) |
| ret <5 x i1> %v |
| } |
| |
| define <5 x i1> @icmp_eq_vx_swap_v5i8(<5 x i8> %va, i8 %b, <5 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_swap_v5i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <5 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <5 x i8> %elt.head, <5 x i8> poison, <5 x i32> zeroinitializer |
| %v = call <5 x i1> @llvm.vp.icmp.v5i8(<5 x i8> %vb, <5 x i8> %va, metadata !"eq", <5 x i1> %m, i32 %evl) |
| ret <5 x i1> %v |
| } |
| |
| declare <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8>, <8 x i8>, metadata, <8 x i1>, i32) |
| |
| define <8 x i1> @icmp_eq_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmseq.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsne.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsne.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsne.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsne.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsne.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsltu.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsltu.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v0, v8, 3, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsleu.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, ta, mu |
| ; CHECK-NEXT: vmv.v.x v9, a0 |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsleu.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsleu.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v0, v8, 3, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsltu.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsltu.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v0, v8, 3, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmslt.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgt.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmslt.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v0, v8, 3, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, ta, mu |
| ; CHECK-NEXT: vmv.v.x v9, a0 |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v0, v8, 3, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmslt.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmslt.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgt.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v0, v8, 3, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vv_v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vv_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v0, v8, v9, v0.t |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vx_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vx v0, v8, a0, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vx_swap_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vx_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, ta, mu |
| ; CHECK-NEXT: vmv.v.x v9, a0 |
| ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v0, v9, v8, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vi_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vi_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v0, v8, 4, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %va, <8 x i8> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vi_swap_v8i8(<8 x i8> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vi_swap_v8i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v0, v8, 3, v0.t |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i8> poison, i8 4, i32 0 |
| %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i8(<8 x i8> %vb, <8 x i8> %va, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| declare <256 x i1> @llvm.vp.icmp.v256i8(<256 x i8>, <256 x i8>, metadata, <256 x i1>, i32) |
| |
| define <256 x i1> @icmp_eq_vv_v256i8(<256 x i8> %va, <256 x i8> %vb, <256 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vv_v256i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: addi sp, sp, -16 |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: csrr a1, vlenb |
| ; CHECK-NEXT: li a4, 24 |
| ; CHECK-NEXT: mul a1, a1, a4 |
| ; CHECK-NEXT: sub sp, sp, a1 |
| ; CHECK-NEXT: li a4, 128 |
| ; CHECK-NEXT: vsetvli zero, a4, e8, m8, ta, mu |
| ; CHECK-NEXT: vle8.v v24, (a0) |
| ; CHECK-NEXT: csrr a1, vlenb |
| ; CHECK-NEXT: slli a1, a1, 3 |
| ; CHECK-NEXT: add a1, sp, a1 |
| ; CHECK-NEXT: addi a1, a1, 16 |
| ; CHECK-NEXT: vs8r.v v24, (a1) # Unknown-size Folded Spill |
| ; CHECK-NEXT: csrr a1, vlenb |
| ; CHECK-NEXT: slli a1, a1, 4 |
| ; CHECK-NEXT: add a1, sp, a1 |
| ; CHECK-NEXT: addi a1, a1, 16 |
| ; CHECK-NEXT: vs8r.v v16, (a1) # Unknown-size Folded Spill |
| ; CHECK-NEXT: addi a0, a0, 128 |
| ; CHECK-NEXT: mv a1, a3 |
| ; CHECK-NEXT: bltu a3, a4, .LBB51_2 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: li a1, 128 |
| ; CHECK-NEXT: .LBB51_2: |
| ; CHECK-NEXT: li a4, 0 |
| ; CHECK-NEXT: vlm.v v24, (a2) |
| ; CHECK-NEXT: vle8.v v16, (a0) |
| ; CHECK-NEXT: addi a0, sp, 16 |
| ; CHECK-NEXT: vs8r.v v16, (a0) # Unknown-size Folded Spill |
| ; CHECK-NEXT: vsetvli zero, a1, e8, m8, ta, ma |
| ; CHECK-NEXT: addi a0, a3, -128 |
| ; CHECK-NEXT: csrr a1, vlenb |
| ; CHECK-NEXT: slli a1, a1, 3 |
| ; CHECK-NEXT: add a1, sp, a1 |
| ; CHECK-NEXT: addi a1, a1, 16 |
| ; CHECK-NEXT: vl8re8.v v16, (a1) # Unknown-size Folded Reload |
| ; CHECK-NEXT: vmseq.vv v1, v8, v16, v0.t |
| ; CHECK-NEXT: bltu a3, a0, .LBB51_4 |
| ; CHECK-NEXT: # %bb.3: |
| ; CHECK-NEXT: mv a4, a0 |
| ; CHECK-NEXT: .LBB51_4: |
| ; CHECK-NEXT: vsetvli zero, a4, e8, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v24 |
| ; CHECK-NEXT: csrr a0, vlenb |
| ; CHECK-NEXT: slli a0, a0, 4 |
| ; CHECK-NEXT: add a0, sp, a0 |
| ; CHECK-NEXT: addi a0, a0, 16 |
| ; CHECK-NEXT: vl8re8.v v16, (a0) # Unknown-size Folded Reload |
| ; CHECK-NEXT: addi a0, sp, 16 |
| ; CHECK-NEXT: vl8re8.v v24, (a0) # Unknown-size Folded Reload |
| ; CHECK-NEXT: vmseq.vv v8, v16, v24, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v1 |
| ; CHECK-NEXT: csrr a0, vlenb |
| ; CHECK-NEXT: li a1, 24 |
| ; CHECK-NEXT: mul a0, a0, a1 |
| ; CHECK-NEXT: add sp, sp, a0 |
| ; CHECK-NEXT: addi sp, sp, 16 |
| ; CHECK-NEXT: ret |
| %v = call <256 x i1> @llvm.vp.icmp.v256i8(<256 x i8> %va, <256 x i8> %vb, metadata !"eq", <256 x i1> %m, i32 %evl) |
| ret <256 x i1> %v |
| } |
| |
| define <256 x i1> @icmp_eq_vx_v256i8(<256 x i8> %va, i8 %b, <256 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_v256i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: li a3, 128 |
| ; CHECK-NEXT: vsetvli zero, a3, e8, m8, ta, mu |
| ; CHECK-NEXT: vlm.v v25, (a1) |
| ; CHECK-NEXT: addi a4, a2, -128 |
| ; CHECK-NEXT: vmv1r.v v24, v0 |
| ; CHECK-NEXT: li a1, 0 |
| ; CHECK-NEXT: bltu a2, a4, .LBB52_2 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: mv a1, a4 |
| ; CHECK-NEXT: .LBB52_2: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v25 |
| ; CHECK-NEXT: vmseq.vx v25, v16, a0, v0.t |
| ; CHECK-NEXT: bltu a2, a3, .LBB52_4 |
| ; CHECK-NEXT: # %bb.3: |
| ; CHECK-NEXT: li a2, 128 |
| ; CHECK-NEXT: .LBB52_4: |
| ; CHECK-NEXT: vsetvli zero, a2, e8, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v24 |
| ; CHECK-NEXT: vmseq.vx v16, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: vmv1r.v v8, v25 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <256 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <256 x i8> %elt.head, <256 x i8> poison, <256 x i32> zeroinitializer |
| %v = call <256 x i1> @llvm.vp.icmp.v256i8(<256 x i8> %va, <256 x i8> %vb, metadata !"eq", <256 x i1> %m, i32 %evl) |
| ret <256 x i1> %v |
| } |
| |
| define <256 x i1> @icmp_eq_vx_swap_v256i8(<256 x i8> %va, i8 %b, <256 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_swap_v256i8: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: li a3, 128 |
| ; CHECK-NEXT: vsetvli zero, a3, e8, m8, ta, mu |
| ; CHECK-NEXT: vlm.v v25, (a1) |
| ; CHECK-NEXT: addi a4, a2, -128 |
| ; CHECK-NEXT: vmv1r.v v24, v0 |
| ; CHECK-NEXT: li a1, 0 |
| ; CHECK-NEXT: bltu a2, a4, .LBB53_2 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: mv a1, a4 |
| ; CHECK-NEXT: .LBB53_2: |
| ; CHECK-NEXT: vsetvli zero, a1, e8, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v25 |
| ; CHECK-NEXT: vmseq.vx v25, v16, a0, v0.t |
| ; CHECK-NEXT: bltu a2, a3, .LBB53_4 |
| ; CHECK-NEXT: # %bb.3: |
| ; CHECK-NEXT: li a2, 128 |
| ; CHECK-NEXT: .LBB53_4: |
| ; CHECK-NEXT: vsetvli zero, a2, e8, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v24 |
| ; CHECK-NEXT: vmseq.vx v16, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: vmv1r.v v8, v25 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <256 x i8> poison, i8 %b, i32 0 |
| %vb = shufflevector <256 x i8> %elt.head, <256 x i8> poison, <256 x i32> zeroinitializer |
| %v = call <256 x i1> @llvm.vp.icmp.v256i8(<256 x i8> %vb, <256 x i8> %va, metadata !"eq", <256 x i1> %m, i32 %evl) |
| ret <256 x i1> %v |
| } |
| |
| declare <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32>, <8 x i32>, metadata, <8 x i1>, i32) |
| |
| define <8 x i1> @icmp_eq_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmseq.vv v12, v8, v10, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmseq.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmseq.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmseq.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmseq.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsne.vv v12, v8, v10, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsne.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsne.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsne.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsne.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsltu.vv v12, v10, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsltu.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v10, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsleu.vv v12, v10, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetivli zero, 8, e32, m2, ta, mu |
| ; CHECK-NEXT: vmv.v.x v12, a0 |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsleu.vv v10, v12, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsleu.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v10, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsltu.vv v12, v8, v10, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsltu.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v10, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmslt.vv v12, v10, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgt.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmslt.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v10, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v12, v10, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetivli zero, 8, e32, m2, ta, mu |
| ; CHECK-NEXT: vmv.v.x v12, a0 |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v10, v12, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v10, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmslt.vv v12, v8, v10, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmslt.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgt.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v10, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vv_v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vv_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v12, v8, v10, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vx_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vx v10, v8, a0, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vx_swap_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vx_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetivli zero, 8, e32, m2, ta, mu |
| ; CHECK-NEXT: vmv.v.x v12, a0 |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vv v10, v12, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vi_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vi_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsle.vi v10, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %va, <8 x i32> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vi_swap_v8i32(<8 x i32> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vi_swap_v8i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v10, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v10 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i32> poison, i32 4, i32 0 |
| %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i32(<8 x i32> %vb, <8 x i32> %va, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| declare <64 x i1> @llvm.vp.icmp.v64i32(<64 x i32>, <64 x i32>, metadata, <64 x i1>, i32) |
| |
| define <64 x i1> @icmp_eq_vv_v64i32(<64 x i32> %va, <64 x i32> %vb, <64 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vv_v64i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: addi sp, sp, -16 |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: csrr a1, vlenb |
| ; CHECK-NEXT: slli a1, a1, 3 |
| ; CHECK-NEXT: sub sp, sp, a1 |
| ; CHECK-NEXT: vmv1r.v v1, v0 |
| ; CHECK-NEXT: addi a1, sp, 16 |
| ; CHECK-NEXT: vs8r.v v8, (a1) # Unknown-size Folded Spill |
| ; CHECK-NEXT: li a3, 0 |
| ; CHECK-NEXT: li a1, 32 |
| ; CHECK-NEXT: addi a4, a0, 128 |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m8, ta, mu |
| ; CHECK-NEXT: vle32.v v24, (a4) |
| ; CHECK-NEXT: vsetivli zero, 4, e8, mf2, ta, mu |
| ; CHECK-NEXT: addi a4, a2, -32 |
| ; CHECK-NEXT: vslidedown.vi v0, v0, 4 |
| ; CHECK-NEXT: bltu a2, a4, .LBB99_2 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: mv a3, a4 |
| ; CHECK-NEXT: .LBB99_2: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m8, ta, mu |
| ; CHECK-NEXT: vle32.v v8, (a0) |
| ; CHECK-NEXT: vsetvli zero, a3, e32, m8, ta, ma |
| ; CHECK-NEXT: vmseq.vv v2, v16, v24, v0.t |
| ; CHECK-NEXT: bltu a2, a1, .LBB99_4 |
| ; CHECK-NEXT: # %bb.3: |
| ; CHECK-NEXT: li a2, 32 |
| ; CHECK-NEXT: .LBB99_4: |
| ; CHECK-NEXT: vsetvli zero, a2, e32, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v1 |
| ; CHECK-NEXT: addi a0, sp, 16 |
| ; CHECK-NEXT: vl8re8.v v24, (a0) # Unknown-size Folded Reload |
| ; CHECK-NEXT: vmseq.vv v16, v24, v8, v0.t |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, tu, mu |
| ; CHECK-NEXT: vslideup.vi v16, v2, 4 |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: csrr a0, vlenb |
| ; CHECK-NEXT: slli a0, a0, 3 |
| ; CHECK-NEXT: add sp, sp, a0 |
| ; CHECK-NEXT: addi sp, sp, 16 |
| ; CHECK-NEXT: ret |
| %v = call <64 x i1> @llvm.vp.icmp.v64i32(<64 x i32> %va, <64 x i32> %vb, metadata !"eq", <64 x i1> %m, i32 %evl) |
| ret <64 x i1> %v |
| } |
| |
| define <64 x i1> @icmp_eq_vx_v64i32(<64 x i32> %va, i32 %b, <64 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_v64i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vmv1r.v v24, v0 |
| ; CHECK-NEXT: li a2, 0 |
| ; CHECK-NEXT: vsetivli zero, 4, e8, mf2, ta, mu |
| ; CHECK-NEXT: addi a3, a1, -32 |
| ; CHECK-NEXT: vslidedown.vi v0, v0, 4 |
| ; CHECK-NEXT: bltu a1, a3, .LBB100_2 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: mv a2, a3 |
| ; CHECK-NEXT: .LBB100_2: |
| ; CHECK-NEXT: vsetvli zero, a2, e32, m8, ta, ma |
| ; CHECK-NEXT: li a2, 32 |
| ; CHECK-NEXT: vmseq.vx v25, v16, a0, v0.t |
| ; CHECK-NEXT: bltu a1, a2, .LBB100_4 |
| ; CHECK-NEXT: # %bb.3: |
| ; CHECK-NEXT: li a1, 32 |
| ; CHECK-NEXT: .LBB100_4: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v24 |
| ; CHECK-NEXT: vmseq.vx v16, v8, a0, v0.t |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, tu, mu |
| ; CHECK-NEXT: vslideup.vi v16, v25, 4 |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <64 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <64 x i32> %elt.head, <64 x i32> poison, <64 x i32> zeroinitializer |
| %v = call <64 x i1> @llvm.vp.icmp.v64i32(<64 x i32> %va, <64 x i32> %vb, metadata !"eq", <64 x i1> %m, i32 %evl) |
| ret <64 x i1> %v |
| } |
| |
| define <64 x i1> @icmp_eq_vx_swap_v64i32(<64 x i32> %va, i32 %b, <64 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vx_swap_v64i32: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vmv1r.v v24, v0 |
| ; CHECK-NEXT: li a2, 0 |
| ; CHECK-NEXT: vsetivli zero, 4, e8, mf2, ta, mu |
| ; CHECK-NEXT: addi a3, a1, -32 |
| ; CHECK-NEXT: vslidedown.vi v0, v0, 4 |
| ; CHECK-NEXT: bltu a1, a3, .LBB101_2 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: mv a2, a3 |
| ; CHECK-NEXT: .LBB101_2: |
| ; CHECK-NEXT: vsetvli zero, a2, e32, m8, ta, ma |
| ; CHECK-NEXT: li a2, 32 |
| ; CHECK-NEXT: vmseq.vx v25, v16, a0, v0.t |
| ; CHECK-NEXT: bltu a1, a2, .LBB101_4 |
| ; CHECK-NEXT: # %bb.3: |
| ; CHECK-NEXT: li a1, 32 |
| ; CHECK-NEXT: .LBB101_4: |
| ; CHECK-NEXT: vsetvli zero, a1, e32, m8, ta, ma |
| ; CHECK-NEXT: vmv1r.v v0, v24 |
| ; CHECK-NEXT: vmseq.vx v16, v8, a0, v0.t |
| ; CHECK-NEXT: vsetivli zero, 8, e8, mf2, tu, mu |
| ; CHECK-NEXT: vslideup.vi v16, v25, 4 |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <64 x i32> poison, i32 %b, i32 0 |
| %vb = shufflevector <64 x i32> %elt.head, <64 x i32> poison, <64 x i32> zeroinitializer |
| %v = call <64 x i1> @llvm.vp.icmp.v64i32(<64 x i32> %vb, <64 x i32> %va, metadata !"eq", <64 x i1> %m, i32 %evl) |
| ret <64 x i1> %v |
| } |
| |
| declare <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64>, <8 x i64>, metadata, <8 x i1>, i32) |
| |
| define <8 x i1> @icmp_eq_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmseq.vv v16, v8, v12, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_eq_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmseq.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_eq_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmseq.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_eq_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmseq.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_eq_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmseq.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmseq.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_eq_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_eq_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmseq.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"eq", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsne.vv v16, v8, v12, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_ne_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsne.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_ne_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsne.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_ne_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsne.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_ne_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsne.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsne.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ne_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ne_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsne.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"ne", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsltu.vv v16, v12, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_ugt_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsltu.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_ugt_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsgtu.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_ugt_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsltu.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_ugt_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsltu.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ugt_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ugt_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v12, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"ugt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsleu.vv v16, v12, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_uge_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsleu.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_uge_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV64-NEXT: vmv.v.x v16, a0 |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsleu.vv v12, v16, v8, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_uge_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsleu.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_uge_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsleu.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v12, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_uge_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_uge_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"uge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsltu.vv v16, v8, v12, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_ult_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsltu.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_ult_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsltu.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_ult_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsltu.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_ult_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsgtu.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsleu.vi v12, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_ult_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_ult_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsgtu.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"ult", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmslt.vv v16, v12, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_sgt_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmslt.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_sgt_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsgt.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_sgt_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmslt.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_sgt_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmslt.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sgt_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sgt_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsle.vi v12, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"sgt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsle.vv v16, v12, v8, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_sge_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsle.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_sge_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV64-NEXT: vmv.v.x v16, a0 |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsle.vv v12, v16, v8, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_sge_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsle.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_sge_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsle.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v12, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sge_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sge_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsle.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"sge", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmslt.vv v16, v8, v12, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_slt_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmslt.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_slt_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmslt.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_slt_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmslt.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_slt_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsgt.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsle.vi v12, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_slt_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_slt_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"slt", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vv_v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vv_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsle.vv v16, v8, v12, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v16 |
| ; CHECK-NEXT: ret |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_sle_vx_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsle.vv v12, v8, v16, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_sle_vx_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsle.vx v12, v8, a0, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vx_swap_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) { |
| ; RV32-LABEL: icmp_sle_vx_swap_v8i64: |
| ; RV32: # %bb.0: |
| ; RV32-NEXT: addi sp, sp, -16 |
| ; RV32-NEXT: .cfi_def_cfa_offset 16 |
| ; RV32-NEXT: sw a1, 12(sp) |
| ; RV32-NEXT: sw a0, 8(sp) |
| ; RV32-NEXT: addi a0, sp, 8 |
| ; RV32-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV32-NEXT: vlse64.v v16, (a0), zero |
| ; RV32-NEXT: vsetvli zero, a2, e64, m4, ta, ma |
| ; RV32-NEXT: vmsle.vv v12, v16, v8, v0.t |
| ; RV32-NEXT: vmv1r.v v0, v12 |
| ; RV32-NEXT: addi sp, sp, 16 |
| ; RV32-NEXT: ret |
| ; |
| ; RV64-LABEL: icmp_sle_vx_swap_v8i64: |
| ; RV64: # %bb.0: |
| ; RV64-NEXT: vsetivli zero, 8, e64, m4, ta, mu |
| ; RV64-NEXT: vmv.v.x v16, a0 |
| ; RV64-NEXT: vsetvli zero, a1, e64, m4, ta, ma |
| ; RV64-NEXT: vmsle.vv v12, v16, v8, v0.t |
| ; RV64-NEXT: vmv1r.v v0, v12 |
| ; RV64-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vi_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vi_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsle.vi v12, v8, 4, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %va, <8 x i64> %vb, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |
| |
| define <8 x i1> @icmp_sle_vi_swap_v8i64(<8 x i64> %va, <8 x i1> %m, i32 zeroext %evl) { |
| ; CHECK-LABEL: icmp_sle_vi_swap_v8i64: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma |
| ; CHECK-NEXT: vmsgt.vi v12, v8, 3, v0.t |
| ; CHECK-NEXT: vmv1r.v v0, v12 |
| ; CHECK-NEXT: ret |
| %elt.head = insertelement <8 x i64> poison, i64 4, i32 0 |
| %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer |
| %v = call <8 x i1> @llvm.vp.icmp.v8i64(<8 x i64> %vb, <8 x i64> %va, metadata !"sle", <8 x i1> %m, i32 %evl) |
| ret <8 x i1> %v |
| } |