1 ; Check the miscellaneous logical vector operations added in P8
3 ; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr8 < %s | FileCheck %s
4 ; RUN: llc -mtriple=powerpc64le-unknown-linux-gnu < %s | FileCheck %s
6 define <4 x i32> @test_xxleqv(<4 x i32> %x, <4 x i32> %y) nounwind {
7 %tmp = xor <4 x i32> %x, %y
8 %ret_val = xor <4 x i32> %tmp, < i32 -1, i32 -1, i32 -1, i32 -1>
10 ; CHECK: xxleqv 34, 34, 35
14 define <4 x i32> @test_xxlnand(<4 x i32> %x, <4 x i32> %y) nounwind {
15 %tmp = and <4 x i32> %x, %y
16 %ret_val = xor <4 x i32> %tmp, <i32 -1, i32 -1, i32 -1, i32 -1>
17 ret <4 x i32> %ret_val
18 ; CHECK: xxlnand 34, 34, 35
22 define <4 x i32> @test_xxlorc(<4 x i32> %x, <4 x i32> %y) nounwind {
23 %tmp = xor <4 x i32> %y, <i32 -1, i32 -1, i32 -1, i32 -1>
24 %ret_val = or <4 x i32> %x, %tmp
25 ret <4 x i32> %ret_val
26 ; CHECK: xxlorc 34, 34, 35
30 define <8 x i16> @test_xxleqvv8i16(<8 x i16> %x, <8 x i16> %y) nounwind {
31 %tmp = xor <8 x i16> %x, %y
32 %ret_val = xor <8 x i16> %tmp, <i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1>
33 ret <8 x i16> %ret_val
34 ; CHECK: xxleqv 34, 34, 35
38 define <8 x i16> @test_xxlnandv8i16(<8 x i16> %x, <8 x i16> %y) nounwind {
39 %tmp = and <8 x i16> %x, %y
40 %ret_val = xor <8 x i16> %tmp, <i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1>
41 ret <8 x i16> %ret_val
42 ; CHECK: xxlnand 34, 34, 35
46 define <8 x i16> @test_xxlorcv8i16(<8 x i16> %x, <8 x i16> %y) nounwind {
47 %tmp = xor <8 x i16> %y, <i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1>
48 %ret_val = or <8 x i16> %x, %tmp
49 ret <8 x i16> %ret_val
50 ; CHECK: xxlorc 34, 34, 35