llvm-project/llvm/test/CodeGen/PowerPC/xxeval-and-nand.ll

190 lines
5.6 KiB
LLVM

; RUN: llc -verify-machineinstrs -mcpu=pwr10 -mtriple=powerpc64le-unknown-unknown \
; RUN: -ppc-asm-full-reg-names --ppc-vsr-nums-as-vr < %s | FileCheck %s
; Function Attrs: nounwind
; CHECK-LABEL: and_not
; CHECK: xxlandc v2, v2, v3
; CHECK-NEXT: blr
define dso_local <4 x i32> @and_not(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%neg = xor <4 x i32> %B, <i32 -1, i32 -1, i32 -1, i32 -1>
%and = and <4 x i32> %neg, %A
ret <4 x i32> %and
}
; Function Attrs: nounwind
; CHECK-LABEL: and_and8
; CHECK: xxeval v2, v3, v2, v4, 1
; CHECK-NEXT: blr
define dso_local <16 x i8> @and_and8(<16 x i8> %A, <16 x i8> %B, <16 x i8> %C) local_unnamed_addr #0 {
entry:
%and = and <16 x i8> %B, %A
%and1 = and <16 x i8> %and, %C
ret <16 x i8> %and1
}
; Function Attrs: nounwind
; CHECK-LABEL: and_and16
; CHECK: xxeval v2, v3, v2, v4, 1
; CHECK-NEXT: blr
define dso_local <8 x i16> @and_and16(<8 x i16> %A, <8 x i16> %B, <8 x i16> %C) local_unnamed_addr #0 {
entry:
%and = and <8 x i16> %B, %A
%and1 = and <8 x i16> %and, %C
ret <8 x i16> %and1
}
; Function Attrs: nounwind
; CHECK-LABEL: and_and32
; CHECK: xxeval v2, v3, v2, v4, 1
; CHECK-NEXT: blr
define dso_local <4 x i32> @and_and32(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%and = and <4 x i32> %B, %A
%and1 = and <4 x i32> %and, %C
ret <4 x i32> %and1
}
; Function Attrs: nounwind
; CHECK-LABEL: and_and64
; CHECK: xxeval v2, v3, v2, v4, 1
; CHECK-NEXT: blr
define dso_local <2 x i64> @and_and64(<2 x i64> %A, <2 x i64> %B, <2 x i64> %C) local_unnamed_addr #0 {
entry:
%and = and <2 x i64> %B, %A
%and1 = and <2 x i64> %and, %C
ret <2 x i64> %and1
}
; Function Attrs: nounwind
; CHECK-LABEL: and_nand
; CHECK: xxeval v2, v2, v4, v3, 14
; CHECK-NEXT: blr
define dso_local <4 x i32> @and_nand(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%and = and <4 x i32> %C, %B
%neg = xor <4 x i32> %and, <i32 -1, i32 -1, i32 -1, i32 -1>
%and1 = and <4 x i32> %neg, %A
ret <4 x i32> %and1
}
; Function Attrs: nounwind
; CHECK-LABEL: and_or
; CHECK: xxeval v2, v2, v4, v3, 7
; CHECK-NEXT: blr
define dso_local <4 x i32> @and_or(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%or = or <4 x i32> %C, %B
%and = and <4 x i32> %or, %A
ret <4 x i32> %and
}
; Function Attrs: nounwind
; CHECK-LABEL: and_nor
; CHECK: xxeval v2, v2, v4, v3, 8
; CHECK-NEXT: blr
define dso_local <4 x i32> @and_nor(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%or = or <4 x i32> %C, %B
%neg = xor <4 x i32> %or, <i32 -1, i32 -1, i32 -1, i32 -1>
%and = and <4 x i32> %neg, %A
ret <4 x i32> %and
}
; Function Attrs: nounwind
; CHECK-LABEL: and_xor
; CHECK: xxeval v2, v2, v4, v3, 6
; CHECK-NEXT: blr
define dso_local <4 x i32> @and_xor(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%xor = xor <4 x i32> %C, %B
%and = and <4 x i32> %xor, %A
ret <4 x i32> %and
}
; Function Attrs: nounwind
; CHECK-LABEL: and_eqv
; CHECK: xxeval v2, v2, v3, v4, 9
; CHECK-NEXT: blr
define dso_local <4 x i32> @and_eqv(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%xor = xor <4 x i32> %B, <i32 -1, i32 -1, i32 -1, i32 -1>
%neg = xor <4 x i32> %xor, %C
%and = and <4 x i32> %neg, %A
ret <4 x i32> %and
}
; Function Attrs: nounwind
; CHECK-LABEL: nand_nand
; CHECK: xxeval v2, v2, v4, v3, 241
; CHECK-NEXT: blr
define dso_local <4 x i32> @nand_nand(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%and = and <4 x i32> %C, %B
%A.not = xor <4 x i32> %A, <i32 -1, i32 -1, i32 -1, i32 -1>
%neg2 = or <4 x i32> %and, %A.not
ret <4 x i32> %neg2
}
; Function Attrs: nounwind
; CHECK-LABEL: nand_and
; CHECK: xxeval v2, v3, v2, v4, 254
; CHECK-NEXT: blr
define dso_local <4 x i32> @nand_and(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%and = and <4 x i32> %B, %A
%and1 = and <4 x i32> %and, %C
%neg = xor <4 x i32> %and1, <i32 -1, i32 -1, i32 -1, i32 -1>
ret <4 x i32> %neg
}
; Function Attrs: nounwind
; CHECK-LABEL: nand_xor
; CHECK: xxeval v2, v2, v4, v3, 249
; CHECK-NEXT: blr
define dso_local <4 x i32> @nand_xor(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%xor = xor <4 x i32> %C, %B
%and = and <4 x i32> %xor, %A
%neg = xor <4 x i32> %and, <i32 -1, i32 -1, i32 -1, i32 -1>
ret <4 x i32> %neg
}
; Function Attrs: nounwind
; CHECK-LABEL: nand_eqv
; CHECK: xxeval v2, v2, v4, v3, 246
; CHECK-NEXT: blr
define dso_local <4 x i32> @nand_eqv(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%xor = xor <4 x i32> %C, %B
%A.not = xor <4 x i32> %A, <i32 -1, i32 -1, i32 -1, i32 -1>
%neg1 = or <4 x i32> %xor, %A.not
ret <4 x i32> %neg1
}
; Function Attrs: nounwind
; CHECK-LABEL: nand_or
; CHECK: xxeval v2, v2, v4, v3, 248
; CHECK-NEXT: blr
define dso_local <4 x i32> @nand_or(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%or = or <4 x i32> %C, %B
%and = and <4 x i32> %or, %A
%neg = xor <4 x i32> %and, <i32 -1, i32 -1, i32 -1, i32 -1>
ret <4 x i32> %neg
}
; Function Attrs: nounwind
; CHECK-LABEL: nand_nor
; CHECK: xxeval v2, v2, v3, v4, 247
; CHECK-NEXT: blr
define dso_local <4 x i32> @nand_nor(<4 x i32> %A, <4 x i32> %B, <4 x i32> %C) local_unnamed_addr #0 {
entry:
%A.not = xor <4 x i32> %A, <i32 -1, i32 -1, i32 -1, i32 -1>
%or = or <4 x i32> %A.not, %B
%neg1 = or <4 x i32> %or, %C
ret <4 x i32> %neg1
}
attributes #0 = { nounwind }