OSDN Git Service

gcc/
[pf3gnuchains/gcc-fork.git] / gcc / testsuite / gcc.target / i386 / sse2-init-v16qi-1.c
1 /* { dg-do run } */
2 /* { dg-options "-O2 -msse2" } */
3
4 #include "sse2-check.h"
5
6 #ifdef DEBUG
7 #include <stdio.h>
8 #endif
9
10 #include <emmintrin.h>
11
12 static void
13 __attribute__((noinline))
14 check (__m128i x, unsigned char *v, int j)
15 {
16   union
17     {
18       __m128i x;
19       unsigned char i[16];
20     } u;
21   unsigned int i;
22
23   u.x = x;
24   
25   for (i = 0; i < sizeof (v) / sizeof (v[0]); i++)
26     if (i == j)
27       {
28         if (v[i] != u.i[i])
29           {
30 #ifdef DEBUG
31             printf ("%i: 0x%x != 0x%x\n", i, v[i], u.i[i]);
32 #endif
33             abort ();
34           }
35       }
36     else if (u.i[i] != 0)
37       {
38 #ifdef DEBUG
39         printf ("%i: 0x%x != 0\n", i, u.i[i]);
40 #endif
41         abort ();
42       }
43 }
44
45 static void
46 __attribute__((noinline))
47 test (unsigned char *v)
48 {
49   __m128i x;
50
51   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, v[0]);
52   check (x, v, 0);
53   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, v[1], 0);
54   check (x, v, 1);
55   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, v[2], 0, 0);
56   check (x, v, 2);
57   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, v[3], 0, 0, 0);
58   check (x, v, 3);
59   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, v[4], 0, 0, 0, 0);
60   check (x, v, 4);
61   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, v[5], 0, 0, 0, 0, 0);
62   check (x, v, 5);
63   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, 0, v[6], 0, 0, 0, 0, 0, 0);
64   check (x, v, 6);
65   x = _mm_set_epi8 (0, 0, 0, 0, 0, 0, 0, 0, v[7], 0, 0, 0, 0, 0, 0, 0);
66   check (x, v, 7);
67 }
68
69 static void
70 sse2_test (void)
71 {
72   unsigned char v[16]
73     = { 0x7B, 0x5B, 0x54, 0x65, 0x73, 0x74, 0x56, 0x65,
74         0x63, 0x74, 0x6F, 0x72, 0x5D, 0x53, 0x47, 0x5D };
75   test (v);
76 }