1 // REQUIRES: powerpc-registered-target 2 // RUN: %clang_cc1 -faltivec -target-feature +htm \ 3 // RUN: -triple powerpc64-unknown-unknown -DTEST_HTM -fsyntax-only \ 4 // RUN: -verify %s 5 6 // RUN: %clang_cc1 -faltivec -target-feature +crypto \ 7 // RUN: -triple powerpc64le-unknown-unknown -DTEST_CRYPTO -fsyntax-only \ 8 // RUN: -verify %s 9 10 #ifdef TEST_HTM 11 void test_htm() { 12 __builtin_tbegin(4); // expected-error {{argument should be a value from 0 to 1}} 13 __builtin_tend(-1); // expected-error {{argument should be a value from 0 to 1}} 14 __builtin_tsr(55); // expected-error {{argument should be a value from 0 to 7}} 15 __builtin_tabortwc(-5, 2, 3); // expected-error {{argument should be a value from 0 to 31}} 16 __builtin_tabortdc(55, 2, 3); // expected-error {{argument should be a value from 0 to 31}} 17 __builtin_tabortwci(-5, 2, 5); // expected-error {{argument should be a value from 0 to 31}} 18 __builtin_tabortwci(5, 2, 55); // expected-error {{argument should be a value from 0 to 31}} 19 __builtin_tabortdci(-5, 2, 5); // expected-error {{argument should be a value from 0 to 31}} 20 __builtin_tabortdci(5, 2, 55); // expected-error {{argument should be a value from 0 to 31}} 21 } 22 #endif 23 24 25 #ifdef TEST_CRYPTO 26 #include <altivec.h> 27 28 #define W_INIT { 0x01020304, 0x05060708, 0x090A0B0C, 0x0D0E0F10 }; 29 #define D_INIT { 0x0102030405060708, 0x090A0B0C0D0E0F10 }; 30 vector unsigned int test_vshasigmaw_or(void) 31 { 32 vector unsigned int a = W_INIT 33 vector unsigned int b = __builtin_crypto_vshasigmaw(a, 2, 15); // expected-error {{argument should be a value from 0 to 1}} 34 vector unsigned int c = __builtin_crypto_vshasigmaw(a, -1, 15); // expected-error {{argument should be a value from 0 to 1}} 35 vector unsigned int d = __builtin_crypto_vshasigmaw(a, 0, 85); // expected-error {{argument should be a value from 0 to 15}} 36 vector unsigned int e = __builtin_crypto_vshasigmaw(a, 1, -15); // expected-error {{argument should be a value from 0 to 15}} 37 return __builtin_crypto_vshasigmaw(a, 1, 15); 38 } 39 40 vector unsigned long long test_vshasigmad_or(void) 41 { 42 vector unsigned long long a = D_INIT 43 vector unsigned long long b = __builtin_crypto_vshasigmad(a, 2, 15); // expected-error {{argument should be a value from 0 to 1}} 44 vector unsigned long long c = __builtin_crypto_vshasigmad(a, -1, 15); // expected-error {{argument should be a value from 0 to 1}} 45 vector unsigned long long d = __builtin_crypto_vshasigmad(a, 0, 85); // expected-error {{argument should be a value from 0 to 1}} 46 vector unsigned long long e = __builtin_crypto_vshasigmad(a, 1, -15); // expected-error {{argument should be a value from 0 to 1}} 47 return __builtin_crypto_vshasigmad(a, 0, 15); 48 } 49 50 #endif 51 52