[docs] Add LICENSE.txt to the root of the mono-repo
[llvm-project.git] / clang / test / Sema / builtins-hvx-v60.c
blob9a0ec4ff9e59e3fd853de04c007eaa6653d2f34c
1 // REQUIRES: hexagon-registered-target
2 // RUN: %clang_cc1 -triple hexagon %s -target-feature +hvx-length128b -target-feature +hvxv60 -target-cpu hexagonv60 -verify -S -o - -DTEST_HVXV60
3 // RUN: %clang_cc1 -triple hexagon %s -target-feature +hvx-length128b -target-feature +hvxv60 -target-cpu hexagonv60 -verify -S -o - -DTEST_HVXV62
4 // RUN: %clang_cc1 -triple hexagon %s -target-feature +hvx-length128b -target-feature +hvxv60 -target-cpu hexagonv60 -verify -S -o - -DTEST_HVXV65
6 typedef long Vect1024 __attribute__((__vector_size__(128)))
7 __attribute__((aligned(128)));
8 typedef long Vect2048 __attribute__((__vector_size__(256)))
9 __attribute__((aligned(128)));
11 typedef Vect1024 HVX_Vector;
12 typedef Vect2048 HVX_VectorPair;
14 #ifdef TEST_HVXV60
15 HVX_Vector builtin_needs_v60(HVX_VectorPair a) {
16 // expected-no-diagnostics
17 return __builtin_HEXAGON_V6_hi_128B(a);
19 #endif
21 #ifdef TEST_HVXV62
22 HVX_Vector builtin_needs_v62(char a) {
23 // expected-error-re@+1 {{'__builtin_HEXAGON_V6_lvsplatb_128B' needs target feature hvxv62|{{.*}}}}
24 return __builtin_HEXAGON_V6_lvsplatb_128B(a);
26 #endif
28 #ifdef TEST_HVXV65
29 HVX_VectorPair builtin_needs_v65() {
30 // expected-error-re@+1 {{'__builtin_HEXAGON_V6_vdd0_128B' needs target feature hvxv65|{{.*}}}}
31 return __builtin_HEXAGON_V6_vdd0_128B();
33 #endif