2017-01-06 05:43:30 +08:00
|
|
|
// REQUIRES: powerpc-registered-target
|
|
|
|
|
2017-03-22 06:06:18 +08:00
|
|
|
// RUN: %clang_cc1 -target-feature +altivec -target-feature +power9-vector \
|
2017-01-06 05:43:30 +08:00
|
|
|
// RUN: -triple powerpc64-unknown-unknown -fsyntax-only \
|
|
|
|
// RUN: -Wall -Werror -verify %s
|
|
|
|
|
2017-03-22 06:06:18 +08:00
|
|
|
// RUN: %clang_cc1 -target-feature +altivec -target-feature +power9-vector \
|
2017-01-06 05:43:30 +08:00
|
|
|
// RUN: -triple powerpc64le-unknown-unknown -fsyntax-only \
|
|
|
|
// RUN: -Wall -Werror -verify %s
|
|
|
|
|
|
|
|
#include <altivec.h>
|
|
|
|
|
|
|
|
extern vector signed int vsi;
|
2017-06-15 01:23:43 +08:00
|
|
|
extern vector signed int vui;
|
|
|
|
extern vector float vf;
|
2017-01-06 05:43:30 +08:00
|
|
|
extern vector unsigned char vuc;
|
|
|
|
|
2017-05-24 23:13:32 +08:00
|
|
|
void testInsertWord(void) {
|
2017-01-06 05:43:30 +08:00
|
|
|
int index = 5;
|
|
|
|
vector unsigned char v1 = vec_insert4b(vsi, vuc, index); // expected-error {{argument to '__builtin_vsx_insertword' must be a constant integer}}
|
|
|
|
vector unsigned long long v2 = vec_extract4b(vuc, index); // expected-error {{argument to '__builtin_vsx_extractuword' must be a constant integer}}
|
|
|
|
}
|
2017-05-24 23:13:32 +08:00
|
|
|
|
|
|
|
void testXXPERMDI(int index) {
|
|
|
|
vec_xxpermdi(vsi); //expected-error {{too few arguments to function call, expected at least 3, have 1}}
|
|
|
|
vec_xxpermdi(vsi, vsi, 2, 4); //expected-error {{too many arguments to function call, expected at most 3, have 4}}
|
|
|
|
vec_xxpermdi(vsi, vsi, index); //expected-error {{argument 3 to '__builtin_vsx_xxpermdi' must be a 2-bit unsigned literal (i.e. 0, 1, 2 or 3)}}
|
|
|
|
vec_xxpermdi(1, 2, 3); //expected-error {{first two arguments to '__builtin_vsx_xxpermdi' must be vectors}}
|
|
|
|
vec_xxpermdi(vsi, vuc, 2); //expected-error {{first two arguments to '__builtin_vsx_xxpermdi' must have the same type}}
|
|
|
|
}
|
2017-05-24 23:54:13 +08:00
|
|
|
|
|
|
|
void testXXSLDWI(int index) {
|
|
|
|
vec_xxsldwi(vsi); //expected-error {{too few arguments to function call, expected at least 3, have 1}}
|
|
|
|
vec_xxsldwi(vsi, vsi, 2, 4); //expected-error {{too many arguments to function call, expected at most 3, have 4}}
|
|
|
|
vec_xxsldwi(vsi, vsi, index); //expected-error {{argument 3 to '__builtin_vsx_xxsldwi' must be a 2-bit unsigned literal (i.e. 0, 1, 2 or 3)}}
|
|
|
|
vec_xxsldwi(1, 2, 3); //expected-error {{first two arguments to '__builtin_vsx_xxsldwi' must be vectors}}
|
|
|
|
vec_xxsldwi(vsi, vuc, 2); //expected-error {{first two arguments to '__builtin_vsx_xxsldwi' must have the same type}}
|
|
|
|
}
|
2017-06-15 01:23:43 +08:00
|
|
|
|
|
|
|
void testCTF(int index) {
|
|
|
|
vec_ctf(vsi, index); //expected-error {{argument to '__builtin_altivec_vcfsx' must be a constant integer}}
|
|
|
|
vec_ctf(vui, index); //expected-error {{argument to '__builtin_altivec_vcfsx' must be a constant integer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void testVCFSX(int index) {
|
|
|
|
vec_vcfsx(vsi, index); //expected-error {{argument to '__builtin_altivec_vcfsx' must be a constant integer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void testVCFUX(int index) {
|
|
|
|
vec_vcfux(vui, index); //expected-error {{argument to '__builtin_altivec_vcfux' must be a constant integer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void testCTS(int index) {
|
|
|
|
vec_cts(vf, index); //expected-error {{argument to '__builtin_altivec_vctsxs' must be a constant integer}}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void testVCTSXS(int index) {
|
|
|
|
vec_vctsxs(vf, index); //expected-error {{argument to '__builtin_altivec_vctsxs' must be a constant integer}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void testCTU(int index) {
|
|
|
|
vec_ctu(vf, index); //expected-error {{argument to '__builtin_altivec_vctuxs' must be a constant integer}}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void testVCTUXS(int index) {
|
|
|
|
vec_vctuxs(vf, index); //expected-error {{argument to '__builtin_altivec_vctuxs' must be a constant integer}}
|
|
|
|
}
|