llvm-project/clang/test/CodeGen/builtins-ppc-p10vector.c

149 lines
4.5 KiB
C

// REQUIRES: powerpc-registered-target
// RUN: %clang_cc1 -target-feature +vsx -target-feature +altivec \
// RUN: -target-cpu pwr10 -triple powerpc64le-unknown-unknown -emit-llvm %s \
// RUN: -o - | FileCheck %s
#include <altivec.h>
vector signed char vsca;
vector unsigned char vuca, vucb, vucc;
vector unsigned short vusa, vusb, vusc;
vector unsigned int vuia, vuib, vuic;
vector unsigned long long vulla, vullb, vullc;
vector unsigned __int128 vui128a, vui128b, vui128c;
unsigned int uia;
vector unsigned long long test_vpdepd(void) {
// CHECK: @llvm.ppc.altivec.vpdepd(<2 x i64>
// CHECK-NEXT: ret <2 x i64>
return vec_pdep(vulla, vullb);
}
vector unsigned long long test_vpextd(void) {
// CHECK: @llvm.ppc.altivec.vpextd(<2 x i64>
// CHECK-NEXT: ret <2 x i64>
return vec_pext(vulla, vullb);
}
vector unsigned long long test_vcfuged(void) {
// CHECK: @llvm.ppc.altivec.vcfuged(<2 x i64>
// CHECK-NEXT: ret <2 x i64>
return vec_cfuge(vulla, vullb);
}
unsigned long long test_vgnb_1(void) {
// CHECK: @llvm.ppc.altivec.vgnb(<1 x i128> %{{.+}}, i32 2)
// CHECK-NEXT: ret i64
return vec_gnb(vui128a, 2);
}
unsigned long long test_vgnb_2(void) {
// CHECK: @llvm.ppc.altivec.vgnb(<1 x i128> %{{.+}}, i32 7)
// CHECK-NEXT: ret i64
return vec_gnb(vui128a, 7);
}
unsigned long long test_vgnb_3(void) {
// CHECK: @llvm.ppc.altivec.vgnb(<1 x i128> %{{.+}}, i32 5)
// CHECK-NEXT: ret i64
return vec_gnb(vui128a, 5);
}
vector unsigned char test_xxeval_uc(void) {
// CHECK: @llvm.ppc.vsx.xxeval(<2 x i64> %{{.+}}, <2 x i64> %{{.+}}, <2 x i64> %{{.+}}, i32 0)
// CHECK: ret <16 x i8>
return vec_ternarylogic(vuca, vucb, vucc, 0);
}
vector unsigned short test_xxeval_us(void) {
// CHECK: @llvm.ppc.vsx.xxeval(<2 x i64> %{{.+}}, <2 x i64> %{{.+}}, <2 x i64> %{{.+}}, i32 255)
// CHECK: ret <8 x i16>
return vec_ternarylogic(vusa, vusb, vusc, 255);
}
vector unsigned int test_xxeval_ui(void) {
// CHECK: @llvm.ppc.vsx.xxeval(<2 x i64> %{{.+}}, <2 x i64> %{{.+}}, <2 x i64> %{{.+}}, i32 150)
// CHECK: ret <4 x i32>
return vec_ternarylogic(vuia, vuib, vuic, 150);
}
vector unsigned long long test_xxeval_ull(void) {
// CHECK: @llvm.ppc.vsx.xxeval(<2 x i64> %{{.+}}, <2 x i64> %{{.+}}, <2 x i64> %{{.+}}, i32 1)
// CHECK: ret <2 x i64>
return vec_ternarylogic(vulla, vullb, vullc, 1);
}
vector unsigned __int128 test_xxeval_ui128(void) {
// CHECK: @llvm.ppc.vsx.xxeval(<2 x i64> %{{.+}}, <2 x i64> %{{.+}}, <2 x i64> %{{.+}}, i32 246)
// CHECK: ret <1 x i128>
return vec_ternarylogic(vui128a, vui128b, vui128c, 246);
}
vector unsigned char test_xxgenpcvbm(void) {
// CHECK: @llvm.ppc.vsx.xxgenpcvbm(<16 x i8> %{{.+}}, i32
// CHECK-NEXT: ret <16 x i8>
return vec_genpcvm(vuca, 0);
}
vector unsigned short test_xxgenpcvhm(void) {
// CHECK: @llvm.ppc.vsx.xxgenpcvhm(<8 x i16> %{{.+}}, i32
// CHECK-NEXT: ret <8 x i16>
return vec_genpcvm(vusa, 0);
}
vector unsigned int test_xxgenpcvwm(void) {
// CHECK: @llvm.ppc.vsx.xxgenpcvwm(<4 x i32> %{{.+}}, i32
// CHECK-NEXT: ret <4 x i32>
return vec_genpcvm(vuia, 0);
}
vector unsigned long long test_xxgenpcvdm(void) {
// CHECK: @llvm.ppc.vsx.xxgenpcvdm(<2 x i64> %{{.+}}, i32
// CHECK-NEXT: ret <2 x i64>
return vec_genpcvm(vulla, 0);
}
vector signed char test_vec_vclrl_sc(void) {
// CHECK-BE: @llvm.ppc.altivec.vclrlb(<16 x i8>
// CHECK-BE-NEXT: ret <16 x i8>
// CHECK-LE: @llvm.ppc.altivec.vclrrb(<16 x i8>
// CHECK-LE-NEXT: ret <16 x i8>
return vec_clrl(vsca, uia);
}
vector unsigned char test_vec_clrl_uc(void) {
// CHECK-BE: @llvm.ppc.altivec.vclrlb(<16 x i8>
// CHECK-BE-NEXT: ret <16 x i8>
// CHECK-LE: @llvm.ppc.altivec.vclrrb(<16 x i8>
// CHECK-LE-NEXT: ret <16 x i8>
return vec_clrl(vuca, uia);
}
vector signed char test_vec_vclrr_sc(void) {
// CHECK-BE: @llvm.ppc.altivec.vclrrb(<16 x i8>
// CHECK-BE-NEXT: ret <16 x i8>
// CHECK-LE: @llvm.ppc.altivec.vclrlb(<16 x i8>
// CHECK-LE-NEXT: ret <16 x i8>
return vec_clrr(vsca, uia);
}
vector unsigned char test_vec_clrr_uc(void) {
// CHECK-BE: @llvm.ppc.altivec.vclrrb(<16 x i8>
// CHECK-BE-NEXT: ret <16 x i8>
// CHECK-LE: @llvm.ppc.altivec.vclrlb(<16 x i8>
// CHECK-LE-NEXT: ret <16 x i8>
return vec_clrr(vuca, uia);
}
vector unsigned long long test_vclzdm(void) {
// CHECK: @llvm.ppc.altivec.vclzdm(<2 x i64>
// CHECK-NEXT: ret <2 x i64>
return vec_cntlzm(vulla, vullb);
}
vector unsigned long long test_vctzdm(void) {
// CHECK: @llvm.ppc.altivec.vctzdm(<2 x i64>
// CHECK-NEXT: ret <2 x i64>
return vec_cnttzm(vulla, vullb);
}