blob: 60872a614e4c836ad5845b77f5ad22e87575fdb2 [file] [log] [blame]
Kit Bartone50adcb2015-03-30 19:40:59 +00001// 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
11void 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 };
30vector 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
40vector 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