1 ; RUN: llc < %s -mtriple=ve -mattr=+vpu | FileCheck %s
3 ;;; Test insert intrinsic instructions
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:
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)
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:
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)
31 ; Function Attrs: nounwind readnone
32 declare <512 x i1> @llvm.ve.vl.insert.vm512l(<512 x i1>, <256 x i1>)