mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
31840a62af
Phabricator review: http://reviews.llvm.org/D7616 Commiting on Nemanja's behalf. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@229694 91177308-0d34-0410-b5e6-96231b3b80d8
53 lines
1.8 KiB
LLVM
53 lines
1.8 KiB
LLVM
; Check the miscellaneous logical vector operations added in P8
|
|
;
|
|
; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr8 < %s | FileCheck %s
|
|
; RUN: llc -mtriple=powerpc64le-unknown-linux-gnu < %s | FileCheck %s
|
|
; Test x eqv y
|
|
define <4 x i32> @test_xxleqv(<4 x i32> %x, <4 x i32> %y) nounwind {
|
|
%tmp = xor <4 x i32> %x, %y
|
|
%ret_val = xor <4 x i32> %tmp, < i32 -1, i32 -1, i32 -1, i32 -1>
|
|
ret <4 x i32> %ret_val
|
|
; CHECK: xxleqv 34, 34, 35
|
|
}
|
|
|
|
; Test x xxlnand y
|
|
define <4 x i32> @test_xxlnand(<4 x i32> %x, <4 x i32> %y) nounwind {
|
|
%tmp = and <4 x i32> %x, %y
|
|
%ret_val = xor <4 x i32> %tmp, <i32 -1, i32 -1, i32 -1, i32 -1>
|
|
ret <4 x i32> %ret_val
|
|
; CHECK: xxlnand 34, 34, 35
|
|
}
|
|
|
|
; Test x xxlorc y
|
|
define <4 x i32> @test_xxlorc(<4 x i32> %x, <4 x i32> %y) nounwind {
|
|
%tmp = xor <4 x i32> %y, <i32 -1, i32 -1, i32 -1, i32 -1>
|
|
%ret_val = or <4 x i32> %x, %tmp
|
|
ret <4 x i32> %ret_val
|
|
; CHECK: xxlorc 34, 34, 35
|
|
}
|
|
|
|
; Test x eqv y
|
|
define <8 x i16> @test_xxleqvv8i16(<8 x i16> %x, <8 x i16> %y) nounwind {
|
|
%tmp = xor <8 x i16> %x, %y
|
|
%ret_val = xor <8 x i16> %tmp, <i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1>
|
|
ret <8 x i16> %ret_val
|
|
; CHECK: xxleqv 34, 34, 35
|
|
}
|
|
|
|
; Test x xxlnand y
|
|
define <8 x i16> @test_xxlnandv8i16(<8 x i16> %x, <8 x i16> %y) nounwind {
|
|
%tmp = and <8 x i16> %x, %y
|
|
%ret_val = xor <8 x i16> %tmp, <i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1>
|
|
ret <8 x i16> %ret_val
|
|
; CHECK: xxlnand 34, 34, 35
|
|
}
|
|
|
|
; Test x xxlorc y
|
|
define <8 x i16> @test_xxlorcv8i16(<8 x i16> %x, <8 x i16> %y) nounwind {
|
|
%tmp = xor <8 x i16> %y, <i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1>
|
|
%ret_val = or <8 x i16> %x, %tmp
|
|
ret <8 x i16> %ret_val
|
|
; CHECK: xxlorc 34, 34, 35
|
|
}
|
|
|