[test] Pre-commit llvm.experimental.memset.pattern tests prior to MemoryLocation...
[llvm-project.git] / llvm / test / CodeGen / Hexagon / autohvx / bitwise-pred-64b.ll
blob2265faf5c1922b1f94332e3dc8321adeced52628
1 ; RUN: llc -mtriple=hexagon < %s | FileCheck %s
3 ; CHECK-LABEL: t00
4 ; CHECK: vand(v{{[0-9:]+}},v{{[0-9:]+}})
5 define <64 x i8> @t00(<64 x i8> %a0, <64 x i8> %a1) #0 {
6   %q0 = trunc <64 x i8> %a0 to <64 x i1>
7   %q1 = trunc <64 x i8> %a1 to <64 x i1>
8   %q2 = and <64 x i1> %q0, %q1
9   %v0 = zext <64 x i1> %q2 to <64 x i8>
10   ret <64 x i8> %v0
13 ; CHECK-LABEL: t01
14 ; CHECK: vor(v{{[0-9:]+}},v{{[0-9:]+}})
15 define <64 x i8> @t01(<64 x i8> %a0, <64 x i8> %a1) #0 {
16   %q0 = trunc <64 x i8> %a0 to <64 x i1>
17   %q1 = trunc <64 x i8> %a1 to <64 x i1>
18   %q2 = or <64 x i1> %q0, %q1
19   %v0 = zext <64 x i1> %q2 to <64 x i8>
20   ret <64 x i8> %v0
23 ; CHECK-LABEL: t02
24 ; CHECK: vxor(v{{[0-9:]+}},v{{[0-9:]+}})
25 define <64 x i8> @t02(<64 x i8> %a0, <64 x i8> %a1) #0 {
26   %q0 = trunc <64 x i8> %a0 to <64 x i1>
27   %q1 = trunc <64 x i8> %a1 to <64 x i1>
28   %q2 = xor <64 x i1> %q0, %q1
29   %v0 = zext <64 x i1> %q2 to <64 x i8>
30   ret <64 x i8> %v0
33 ; CHECK-LABEL: t10
34 ; CHECK: vand(v{{[0-9:]+}},v{{[0-9:]+}})
35 define <32 x i16> @t10(<32 x i16> %a0, <32 x i16> %a1) #0 {
36   %q0 = trunc <32 x i16> %a0 to <32 x i1>
37   %q1 = trunc <32 x i16> %a1 to <32 x i1>
38   %q2 = and <32 x i1> %q0, %q1
39   %v0 = zext <32 x i1> %q2 to <32 x i16>
40   ret <32 x i16> %v0
43 ; CHECK-LABEL: t11
44 ; CHECK: vor(v{{[0-9:]+}},v{{[0-9:]+}})
45 define <32 x i16> @t11(<32 x i16> %a0, <32 x i16> %a1) #0 {
46   %q0 = trunc <32 x i16> %a0 to <32 x i1>
47   %q1 = trunc <32 x i16> %a1 to <32 x i1>
48   %q2 = or <32 x i1> %q0, %q1
49   %v0 = zext <32 x i1> %q2 to <32 x i16>
50   ret <32 x i16> %v0
53 ; CHECK-LABEL: t12
54 ; CHECK: vxor(v{{[0-9:]+}},v{{[0-9:]+}})
55 define <32 x i16> @t12(<32 x i16> %a0, <32 x i16> %a1) #0 {
56   %q0 = trunc <32 x i16> %a0 to <32 x i1>
57   %q1 = trunc <32 x i16> %a1 to <32 x i1>
58   %q2 = xor <32 x i1> %q0, %q1
59   %v0 = zext <32 x i1> %q2 to <32 x i16>
60   ret <32 x i16> %v0
63 ; CHECK-LABEL: t20
64 ; CHECK: vand(v{{[0-9:]+}},v{{[0-9:]+}})
65 define <16 x i32> @t20(<16 x i32> %a0, <16 x i32> %a1) #0 {
66   %q0 = trunc <16 x i32> %a0 to <16 x i1>
67   %q1 = trunc <16 x i32> %a1 to <16 x i1>
68   %q2 = and <16 x i1> %q0, %q1
69   %v0 = zext <16 x i1> %q2 to <16 x i32>
70   ret <16 x i32> %v0
73 ; CHECK-LABEL: t21
74 ; CHECK: vor(v{{[0-9:]+}},v{{[0-9:]+}})
75 define <16 x i32> @t21(<16 x i32> %a0, <16 x i32> %a1) #0 {
76   %q0 = trunc <16 x i32> %a0 to <16 x i1>
77   %q1 = trunc <16 x i32> %a1 to <16 x i1>
78   %q2 = or <16 x i1> %q0, %q1
79   %v0 = zext <16 x i1> %q2 to <16 x i32>
80   ret <16 x i32> %v0
83 ; CHECK-LABEL: t22
84 ; CHECK: vxor(v{{[0-9:]+}},v{{[0-9:]+}})
85 define <16 x i32> @t22(<16 x i32> %a0, <16 x i32> %a1) #0 {
86   %q0 = trunc <16 x i32> %a0 to <16 x i1>
87   %q1 = trunc <16 x i32> %a1 to <16 x i1>
88   %q2 = xor <16 x i1> %q0, %q1
89   %v0 = zext <16 x i1> %q2 to <16 x i32>
90   ret <16 x i32> %v0
93 attributes #0 = { nounwind readnone "target-cpu"="hexagonv60" "target-features"="+hvx,+hvx-length64b" }