This commit was manufactured by cvs2svn to create branch
[official-gcc.git] / gcc / testsuite / gcc.dg / simd-1b.c
blobd40fb0469caab567281240e65998a6a6986c3e50
1 /* { dg-do compile } */
2 /* { dg-options "-Wall" } */
4 /* Origin: Aldy Hernandez <aldyh@redhat.com>. */
5 /* Purpose: Program to test generic SIMD support. */
7 typedef int __attribute__((vector_size (16))) v4si;
8 typedef int __attribute__((vector_size (8))) v2si;
10 v4si a, b;
11 v2si c, d;
13 void
14 hanneke ()
16 /* Operators on compatible SIMD types. */
17 a %= b; /* { dg-bogus "invalid operands to binary %" "" { xfail *-*-* } } */
18 c &= d;
19 a |= b;
20 c ^= d;
21 a >>= b; /* { dg-bogus "invalid operands to binary >>" "" { xfail *-*-* } } */
22 c <<= d; /* { dg-bogus "invalid operands to binary <<" "" { xfail *-*-* } } */
23 a = +b;
24 c = ~d;
26 /* Operators on incompatible SIMD types. */
27 /* a = b % c; { dg*error "can't convert between vector values of different size" } */
28 a = b % c; /* { dg-bogus "invalid operands to binary %" "" { xfail *-*-* } } */
29 d = c & b; /* { dg-error "can't convert between vector values of different size" } */
30 a = b | c; /* { dg-error "can't convert between vector values of different size" } */
31 d = c ^ b; /* { dg-error "can't convert between vector values of different size" } */
32 /* a = b >> c; { dg*error "can't convert between vector values of different size" } */
33 a = b >> c; /* { dg-bogus "invalid operands to binary >>" "" { xfail *-*-* } } */
34 /* d = c << b; { dg*error "can't convert between vector values of different size" } */
35 d = c << b; /* { dg-bogus "invalid operands to binary <<" "" { xfail *-*-* } } */