OSDN Git Service

gcc/
[pf3gnuchains/gcc-fork.git] / gcc / testsuite / gcc.target / i386 / sse5-shift3-vector.c
1 /* Test that the compiler properly optimizes vector shift instructions into
2    psha/pshl on SSE5 systems.  */
3
4 /* { dg-do compile } */
5 /* { dg-require-effective-target lp64 } */
6 /* { dg-options "-O2 -msse5 -ftree-vectorize" } */
7
8 extern void exit (int);
9
10 typedef long __m128i  __attribute__ ((__vector_size__ (16), __may_alias__));
11
12 #define SIZE 10240
13
14 union {
15   __m128i i_align;
16   int i32[SIZE];
17   unsigned u32[SIZE];
18 } a, b, c;
19
20 void
21 right_uns_shift32 (void)
22 {
23   int i;
24
25   for (i = 0; i < SIZE; i++)
26     a.u32[i] = b.u32[i] >> c.i32[i];
27 }
28
29 int main ()
30 {
31   right_uns_shfit32 ();
32   exit (0);
33 }
34
35 /* { dg-final { scan-assembler "pshld" } } */