1 // REQUIRES: powerpc-registered-target
3 // RUN: %clang_cc1 -target-feature +altivec -target-feature +power9-vector \
4 // RUN: -triple powerpc64-unknown-unknown -fsyntax-only \
5 // RUN: -Wall -Werror -verify %s
7 // RUN: %clang_cc1 -target-feature +altivec -target-feature +power9-vector \
8 // RUN: -triple powerpc64le-unknown-unknown -fsyntax-only \
9 // RUN: -Wall -Werror -verify %s
13 extern vector signed int vsi;
14 extern vector unsigned char vuc;
16 void testInsertWord(void) {
18 vector unsigned char v1 = vec_insert4b(vsi, vuc, index); // expected-error {{argument to '__builtin_vsx_insertword' must be a constant integer}}
19 vector unsigned long long v2 = vec_extract4b(vuc, index); // expected-error {{argument to '__builtin_vsx_extractuword' must be a constant integer}}
22 void testXXPERMDI(int index) {
23 vec_xxpermdi(vsi); //expected-error {{too few arguments to function call, expected at least 3, have 1}}
24 vec_xxpermdi(vsi, vsi, 2, 4); //expected-error {{too many arguments to function call, expected at most 3, have 4}}
25 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)}}
26 vec_xxpermdi(1, 2, 3); //expected-error {{first two arguments to '__builtin_vsx_xxpermdi' must be vectors}}
27 vec_xxpermdi(vsi, vuc, 2); //expected-error {{first two arguments to '__builtin_vsx_xxpermdi' must have the same type}}
30 void testXXSLDWI(int index) {
31 vec_xxsldwi(vsi); //expected-error {{too few arguments to function call, expected at least 3, have 1}}
32 vec_xxsldwi(vsi, vsi, 2, 4); //expected-error {{too many arguments to function call, expected at most 3, have 4}}
33 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)}}
34 vec_xxsldwi(1, 2, 3); //expected-error {{first two arguments to '__builtin_vsx_xxsldwi' must be vectors}}
35 vec_xxsldwi(vsi, vuc, 2); //expected-error {{first two arguments to '__builtin_vsx_xxsldwi' must have the same type}}