; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \ ; RUN: -mcpu=pwr8 < %s | FileCheck %s --check-prefixes=CHECK-LE-P8 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \ ; RUN: -mcpu=pwr9 < %s | FileCheck %s --check-prefixes=CHECK-P9 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu \ ; RUN: -mcpu=pwr8 < %s | FileCheck %s --check-prefixes=CHECK-BE-P8 define <16 x i8> @test_vpermxorb() local_unnamed_addr { ; CHECK-LE-P8-LABEL: test_vpermxorb: ; CHECK-LE-P8: # %bb.0: # %entry ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI0_0@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI0_0@toc@l ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI0_1@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI0_1@toc@l ; CHECK-LE-P8-NEXT: xxswapd 34, 0 ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: xxswapd 35, 0 ; CHECK-LE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-LE-P8-NEXT: blr ; ; CHECK-P9-LABEL: test_vpermxorb: ; CHECK-P9: # %bb.0: # %entry ; CHECK-P9-NEXT: addis 3, 2, .LCPI0_0@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI0_0@toc@l ; CHECK-P9-NEXT: lxv 34, 0(3) ; CHECK-P9-NEXT: addis 3, 2, .LCPI0_1@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI0_1@toc@l ; CHECK-P9-NEXT: lxv 35, 0(3) ; CHECK-P9-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-P9-NEXT: blr ; ; CHECK-BE-P8-LABEL: test_vpermxorb: ; CHECK-BE-P8: # %bb.0: # %entry ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI0_0@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI0_0@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 34, 0, 3 ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI0_1@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI0_1@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 35, 0, 3 ; CHECK-BE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-BE-P8-NEXT: blr entry: %0 = tail call <16 x i8> @llvm.ppc.altivec.crypto.vpermxor.be(<16 x i8> , <16 x i8> , <16 x i8> ) ret <16 x i8> %0 } declare <16 x i8> @llvm.ppc.altivec.crypto.vpermxor.be(<16 x i8>, <16 x i8>, <16 x i8>) define <8 x i16> @test_vpermxorh() local_unnamed_addr { ; CHECK-LE-P8-LABEL: test_vpermxorh: ; CHECK-LE-P8: # %bb.0: # %entry ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI1_0@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI1_0@toc@l ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI1_1@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI1_1@toc@l ; CHECK-LE-P8-NEXT: xxswapd 34, 0 ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: xxswapd 35, 0 ; CHECK-LE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-LE-P8-NEXT: blr ; ; CHECK-P9-LABEL: test_vpermxorh: ; CHECK-P9: # %bb.0: # %entry ; CHECK-P9-NEXT: addis 3, 2, .LCPI1_0@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI1_0@toc@l ; CHECK-P9-NEXT: lxv 34, 0(3) ; CHECK-P9-NEXT: addis 3, 2, .LCPI1_1@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI1_1@toc@l ; CHECK-P9-NEXT: lxv 35, 0(3) ; CHECK-P9-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-P9-NEXT: blr ; ; CHECK-BE-P8-LABEL: test_vpermxorh: ; CHECK-BE-P8: # %bb.0: # %entry ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI1_0@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI1_0@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 34, 0, 3 ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI1_1@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI1_1@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 35, 0, 3 ; CHECK-BE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-BE-P8-NEXT: blr entry: %0 = tail call <16 x i8> @llvm.ppc.altivec.crypto.vpermxor.be(<16 x i8> , <16 x i8> , <16 x i8> ) %1 = bitcast <16 x i8> %0 to <8 x i16> ret <8 x i16> %1 } define <4 x i32> @test_vpermxorw() local_unnamed_addr { ; CHECK-LE-P8-LABEL: test_vpermxorw: ; CHECK-LE-P8: # %bb.0: # %entry ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI2_0@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI2_0@toc@l ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI2_1@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI2_1@toc@l ; CHECK-LE-P8-NEXT: xxswapd 34, 0 ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: xxswapd 35, 0 ; CHECK-LE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-LE-P8-NEXT: blr ; ; CHECK-P9-LABEL: test_vpermxorw: ; CHECK-P9: # %bb.0: # %entry ; CHECK-P9-NEXT: addis 3, 2, .LCPI2_0@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI2_0@toc@l ; CHECK-P9-NEXT: lxv 34, 0(3) ; CHECK-P9-NEXT: addis 3, 2, .LCPI2_1@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI2_1@toc@l ; CHECK-P9-NEXT: lxv 35, 0(3) ; CHECK-P9-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-P9-NEXT: blr ; ; CHECK-BE-P8-LABEL: test_vpermxorw: ; CHECK-BE-P8: # %bb.0: # %entry ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI2_0@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI2_0@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 34, 0, 3 ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI2_1@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI2_1@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 35, 0, 3 ; CHECK-BE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-BE-P8-NEXT: blr entry: %0 = tail call <16 x i8> @llvm.ppc.altivec.crypto.vpermxor.be(<16 x i8> , <16 x i8> , <16 x i8> ) %1 = bitcast <16 x i8> %0 to <4 x i32> ret <4 x i32> %1 } define <2 x i64> @test_vpermxord() local_unnamed_addr { ; CHECK-LE-P8-LABEL: test_vpermxord: ; CHECK-LE-P8: # %bb.0: # %entry ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI3_0@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI3_0@toc@l ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: addis 3, 2, .LCPI3_1@toc@ha ; CHECK-LE-P8-NEXT: addi 3, 3, .LCPI3_1@toc@l ; CHECK-LE-P8-NEXT: xxswapd 34, 0 ; CHECK-LE-P8-NEXT: lxvd2x 0, 0, 3 ; CHECK-LE-P8-NEXT: xxswapd 35, 0 ; CHECK-LE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-LE-P8-NEXT: blr ; ; CHECK-P9-LABEL: test_vpermxord: ; CHECK-P9: # %bb.0: # %entry ; CHECK-P9-NEXT: addis 3, 2, .LCPI3_0@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI3_0@toc@l ; CHECK-P9-NEXT: lxv 34, 0(3) ; CHECK-P9-NEXT: addis 3, 2, .LCPI3_1@toc@ha ; CHECK-P9-NEXT: addi 3, 3, .LCPI3_1@toc@l ; CHECK-P9-NEXT: lxv 35, 0(3) ; CHECK-P9-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-P9-NEXT: blr ; ; CHECK-BE-P8-LABEL: test_vpermxord: ; CHECK-BE-P8: # %bb.0: # %entry ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI3_0@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI3_0@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 34, 0, 3 ; CHECK-BE-P8-NEXT: addis 3, 2, .LCPI3_1@toc@ha ; CHECK-BE-P8-NEXT: addi 3, 3, .LCPI3_1@toc@l ; CHECK-BE-P8-NEXT: lxvw4x 35, 0, 3 ; CHECK-BE-P8-NEXT: vpermxor 2, 3, 2, 2 ; CHECK-BE-P8-NEXT: blr entry: %0 = tail call <16 x i8> @llvm.ppc.altivec.crypto.vpermxor.be(<16 x i8> , <16 x i8> , <16 x i8> ) %1 = bitcast <16 x i8> %0 to <2 x i64> ret <2 x i64> %1 }