Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / VE / VELIntrinsics / insert.ll
blobfaa17be94f6e5a1efe0c20f44dd2e54588b76f48
1 ; RUN: llc < %s -mtriple=ve -mattr=+vpu | FileCheck %s
3 ;;; Test insert intrinsic instructions
4 ;;;
5 ;;; Note:
6 ;;;   We test insert_vm512u and insert_vm512l pseudo instructions.
8 ; Function Attrs: nounwind readnone
9 define fastcc <512 x i1> @insert_vm512u(<512 x i1> %0, <256 x i1> %1) {
10 ; CHECK-LABEL: insert_vm512u:
11 ; CHECK:       # %bb.0:
12 ; CHECK-NEXT:    andm %vm2, %vm0, %vm4
13 ; CHECK-NEXT:    b.l.t (, %s10)
14   %3 = tail call <512 x i1> @llvm.ve.vl.insert.vm512u(<512 x i1> %0, <256 x i1> %1)
15   ret <512 x i1> %3
18 ; Function Attrs: nounwind readnone
19 declare <512 x i1> @llvm.ve.vl.insert.vm512u(<512 x i1>, <256 x i1>)
21 ; Function Attrs: nounwind readnone
22 define fastcc <512 x i1> @insert_vm512l(<512 x i1> %0, <256 x i1> %1) {
23 ; CHECK-LABEL: insert_vm512l:
24 ; CHECK:       # %bb.0:
25 ; CHECK-NEXT:    andm %vm3, %vm0, %vm4
26 ; CHECK-NEXT:    b.l.t (, %s10)
27   %3 = tail call <512 x i1> @llvm.ve.vl.insert.vm512l(<512 x i1> %0, <256 x i1> %1)
28   ret <512 x i1> %3
31 ; Function Attrs: nounwind readnone
32 declare <512 x i1> @llvm.ve.vl.insert.vm512l(<512 x i1>, <256 x i1>)