]> granicus.if.org Git - clang/blob - test/CodeGen/builtins-ppc-error.c
[PowerPC] Implement vec_xxsldwi builtin.
[clang] / test / CodeGen / builtins-ppc-error.c
1 // REQUIRES: powerpc-registered-target
2
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
6
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
10
11 #include <altivec.h>
12
13 extern vector signed int vsi;
14 extern vector unsigned char vuc;
15
16 void testInsertWord(void) {
17   int index = 5;
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}}
20 }
21
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}}
28 }
29
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}}
36 }