1 /* { dg-do run { target i?86-*-* x86_64-*-* } } */
2 /* { dg-options "-msse2" } */
3 /* { dg-require-effective-target sse2_runtime } */
4 
5 typedef long long __m128i __attribute__ ((__vector_size__ (16),
6 __may_alias__));
7 typedef int __v4si __attribute__ ((__vector_size__ (16)));
8 typedef long long __v2di __attribute__ ((__vector_size__ (16)));
9 typedef unsigned int uint32_t;
10 
11 typedef struct {
12     uint32_t v[4];
13 } a4x32;
14 
incr(a4x32 * x)15 a4x32* incr(a4x32* x)
16 {
17   x->v[0] += 1;
18   return x;
19 }
20 
21 typedef struct {
22     __m128i m;
23 } a1xm128i;
24 
ssefunc(a1xm128i in,a1xm128i k)25 static inline  a1xm128i ssefunc( a1xm128i in,  a1xm128i k)
26 {
27   a1xm128i ret;
28   ret.m = (__m128i)__builtin_ia32_pxor128 ((__v2di)in.m, (__v2di)k.m);
29   return ret;
30 }
31 
caster(a4x32 c4x32,a1xm128i k)32 static  a4x32  caster( a4x32 c4x32,  a1xm128i k)
33 {
34   a1xm128i c1x128;
35   if( sizeof(c4x32) != sizeof(c1x128) ) __builtin_abort();
36   __builtin_memcpy(&c1x128, &c4x32, sizeof(c1x128));
37   c1x128 = ssefunc(c1x128, k);
38   __builtin_memcpy(&c4x32, &c1x128, sizeof(c4x32));
39   return c4x32;
40 }
41 
42 typedef struct  {
43     a1xm128i key;
44     a4x32 c;
45     __SIZE_TYPE__ elem;
46     a4x32 v;
47 } Engine;
48 
ctor(Engine * e)49 void ctor(Engine *e)
50 {
51   e->elem = 0;
52   e->key.m = (__m128i)(__v4si){ 0, 0, 0, 0 };
53   e->c.v[0] = 0;
54   e->c.v[1] = 0;
55   e->c.v[2] = 0;
56   e->c.v[3] = 0;
57 }
58 
method(Engine * e)59 uint32_t method( Engine *e)
60 {
61   if( e->elem == 0 )
62     {
63       e->v = caster(*incr(&e->c), e->key);
64       e->elem = 4;
65     }
66   return e->v.v[--e->elem];
67 }
68 
main()69 int main()
70 {
71   Engine e4; ctor(&e4);
72   Engine e5; ctor(&e5);
73   if(method(&e4)!=method(&e5))
74     __builtin_abort ();
75   return 0;
76 }
77