[ARM] Cortex-M4 schedule additions
[llvm-complete.git] / test / CodeGen / Mips / msa / bmzi_bmnzi.ll
blob6e1f720967025babb030c652f8c163675aebd098
1 ; RUN: llc -march=mipsel -mattr=+msa,+fp64,+mips32r2 -relocation-model=pic < %s | FileCheck %s
3 @llvm_mips_bmnzi_b_ARG1 = global <16 x i8> <i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15, i8 15>, align 16
4 @llvm_mips_bmnzi_b_ARG2 = global <16 x i8> zeroinitializer, align 16
5 @llvm_mips_bmnzi_b_RES = global <16 x i8> zeroinitializer, align 16
7 define void @llvm_mips_bmnzi_b_test() nounwind {
8 entry:
9   %0 = load <16 x i8>, <16 x i8>* @llvm_mips_bmnzi_b_ARG1
10   %1 = load <16 x i8>, <16 x i8>* @llvm_mips_bmnzi_b_ARG2
11   %2 = tail call <16 x i8> @llvm.mips.bmnzi.b(<16 x i8> %0, <16 x i8> %1, i32 240)
12   store volatile <16 x i8> %2, <16 x i8>* @llvm_mips_bmnzi_b_RES
13   %3 = tail call <16 x i8> @llvm.mips.bmnzi.b(<16 x i8> %0, <16 x i8> %1, i32 15)
14   store volatile <16 x i8> %3, <16 x i8>* @llvm_mips_bmnzi_b_RES
15   %4 = tail call <16 x i8> @llvm.mips.bmnzi.b(<16 x i8> %0, <16 x i8> %1, i32 170)
16   store <16 x i8> %4, <16 x i8>* @llvm_mips_bmnzi_b_RES
17   ret void
19 ; CHECK-LABEL: llvm_mips_bmnzi_b_test:
20 ; CHECK: lw [[R0:\$[0-9]+]], %got(llvm_mips_bmnzi_b_RES)(
21 ; CHECK: lw [[R1:\$[0-9]+]], %got(llvm_mips_bmnzi_b_ARG1)(
22 ; CHECK: lw [[R2:\$[0-9]+]], %got(llvm_mips_bmnzi_b_ARG2)(
23 ; CHECK: ld.b [[R3:\$w[0-9]+]], 0([[R2]])
24 ; CHECK: ld.b [[R4:\$w[0-9]+]], 0([[R1]])
25 ; CHECK: move.v [[R5:\$w[0-9]+]], [[R4]]
26 ; CHECK: binsli.b [[R5]], [[R3]], 3
27 ; CHECK: binsri.b [[R5]], [[R3]], 3
28 ; CHECK: bmnzi.b [[R4]], [[R3]], 170
30 define void @llvm_mips_bmzi_b_test() nounwind {
31 entry:
32   %0 = load <16 x i8>, <16 x i8>* @llvm_mips_bmnzi_b_ARG1
33   %1 = load <16 x i8>, <16 x i8>* @llvm_mips_bmnzi_b_ARG2
34   %2 = tail call <16 x i8> @llvm.mips.bmzi.b(<16 x i8> %0, <16 x i8> %1, i32 240)
35   store volatile <16 x i8> %2, <16 x i8>* @llvm_mips_bmnzi_b_RES
36   %3 = tail call <16 x i8> @llvm.mips.bmzi.b(<16 x i8> %0, <16 x i8> %1, i32 15)
37   store volatile <16 x i8> %3, <16 x i8>* @llvm_mips_bmnzi_b_RES
38   %4 = tail call <16 x i8> @llvm.mips.bmzi.b(<16 x i8> %0, <16 x i8> %1, i32 170)
39   store <16 x i8> %4, <16 x i8>* @llvm_mips_bmnzi_b_RES
40   ret void
42 ; CHECK-LABEL: llvm_mips_bmzi_b_test:
43 ; CHECK: lw [[R0:\$[0-9]+]], %got(llvm_mips_bmnzi_b_RES)(
44 ; CHECK: lw [[R1:\$[0-9]+]], %got(llvm_mips_bmnzi_b_ARG2)(
45 ; CHECK: lw [[R2:\$[0-9]+]], %got(llvm_mips_bmnzi_b_ARG1)(
46 ; CHECK: ld.b [[R3:\$w[0-9]+]], 0([[R2]])
47 ; CHECK: ld.b [[R4:\$w[0-9]+]], 0([[R1]])
48 ; CHECK: move.v [[R5:\$w[0-9]+]], [[R4]]
49 ; CHECK: binsli.b [[R5]], [[R3]], 3
50 ; CHECK: binsri.b [[R5]], [[R3]], 3
51 ; bmnzi.b is the same as bmzi.b with ws and wd_in swapped
52 ; CHECK: bmnzi.b [[R4]], [[R3]], 170
54 declare <16 x i8> @llvm.mips.bmnzi.b(<16 x i8>, <16 x i8>, i32) nounwind
55 declare <16 x i8> @llvm.mips.bmzi.b(<16 x i8>, <16 x i8>, i32) nounwind