1*057e6bb5SAbhina Sreeskantharajan // REQUIRES: systemz-registered-target
2*057e6bb5SAbhina Sreeskantharajan // RUN: %clang_cc1 -target-cpu z15 -triple s390x-unknown-unknown \
3*057e6bb5SAbhina Sreeskantharajan // RUN: -Wall -Wno-unused -Werror -fsyntax-only -verify %s
4*057e6bb5SAbhina Sreeskantharajan
5*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) signed char vec_schar;
6*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) signed short vec_sshort;
7*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) signed int vec_sint;
8*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) signed long long vec_slong;
9*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) unsigned char vec_uchar;
10*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) unsigned short vec_ushort;
11*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) unsigned int vec_uint;
12*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) unsigned long long vec_ulong;
13*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) double vec_double;
14*057e6bb5SAbhina Sreeskantharajan typedef __attribute__((vector_size(16))) float vec_float;
15*057e6bb5SAbhina Sreeskantharajan
16*057e6bb5SAbhina Sreeskantharajan volatile vec_schar vsc;
17*057e6bb5SAbhina Sreeskantharajan volatile vec_sshort vss;
18*057e6bb5SAbhina Sreeskantharajan volatile vec_sint vsi;
19*057e6bb5SAbhina Sreeskantharajan volatile vec_slong vsl;
20*057e6bb5SAbhina Sreeskantharajan volatile vec_uchar vuc;
21*057e6bb5SAbhina Sreeskantharajan volatile vec_ushort vus;
22*057e6bb5SAbhina Sreeskantharajan volatile vec_uint vui;
23*057e6bb5SAbhina Sreeskantharajan volatile vec_ulong vul;
24*057e6bb5SAbhina Sreeskantharajan volatile vec_double vd;
25*057e6bb5SAbhina Sreeskantharajan volatile vec_float vf;
26*057e6bb5SAbhina Sreeskantharajan
27*057e6bb5SAbhina Sreeskantharajan volatile unsigned int len;
28*057e6bb5SAbhina Sreeskantharajan int cc;
29*057e6bb5SAbhina Sreeskantharajan
test_integer(void)30*057e6bb5SAbhina Sreeskantharajan void test_integer(void) {
31*057e6bb5SAbhina Sreeskantharajan __builtin_s390_vsld(vuc, vuc, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}}
32*057e6bb5SAbhina Sreeskantharajan __builtin_s390_vsld(vuc, vuc, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}}
33*057e6bb5SAbhina Sreeskantharajan __builtin_s390_vsld(vuc, vuc, len); // expected-error {{must be a constant integer}}
34*057e6bb5SAbhina Sreeskantharajan
35*057e6bb5SAbhina Sreeskantharajan __builtin_s390_vsrd(vuc, vuc, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}}
36*057e6bb5SAbhina Sreeskantharajan __builtin_s390_vsrd(vuc, vuc, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}}
37*057e6bb5SAbhina Sreeskantharajan __builtin_s390_vsrd(vuc, vuc, len); // expected-error {{must be a constant integer}}
38*057e6bb5SAbhina Sreeskantharajan }
39*057e6bb5SAbhina Sreeskantharajan
40