URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Go to most recent revision |
Only display areas with differences |
Details |
Blame |
View Log
Rev 149 |
Rev 154 |
/* { dg-do run } */
|
/* { dg-do run } */
|
/* { dg-options "-O2 -w" } */
|
/* { dg-options "-O2 -w" } */
|
|
|
extern void abort (void);
|
extern void abort (void);
|
|
|
typedef int __m128i __attribute__ ((__vector_size__ (16)));
|
typedef int __m128i __attribute__ ((__vector_size__ (16)));
|
|
|
__m128i
|
__m128i
|
foo (void)
|
foo (void)
|
{
|
{
|
__m128i x = { 0x11111111, 0x22222222, 0x44444444 };
|
__m128i x = { 0x11111111, 0x22222222, 0x44444444 };
|
return x;
|
return x;
|
}
|
}
|
|
|
__m128i
|
__m128i
|
bar (void)
|
bar (void)
|
{
|
{
|
__m128i x = { 0x11111111, 0x22222222, 0x44444444 };
|
__m128i x = { 0x11111111, 0x22222222, 0x44444444 };
|
return ~x;
|
return ~x;
|
}
|
}
|
|
|
int
|
int
|
main (void)
|
main (void)
|
{
|
{
|
union { __m128i v; int i[sizeof (__m128i) / sizeof (int)]; } u, v;
|
union { __m128i v; int i[sizeof (__m128i) / sizeof (int)]; } u, v;
|
int i;
|
int i;
|
|
|
u.v = foo ();
|
u.v = foo ();
|
v.v = bar ();
|
v.v = bar ();
|
for (i = 0; i < sizeof (u.i) / sizeof (u.i[0]); i++)
|
for (i = 0; i < sizeof (u.i) / sizeof (u.i[0]); i++)
|
{
|
{
|
if (u.i[i] != ~v.i[i])
|
if (u.i[i] != ~v.i[i])
|
abort ();
|
abort ();
|
if (i < 3)
|
if (i < 3)
|
{
|
{
|
if (u.i[i] != (0x11111111 << i))
|
if (u.i[i] != (0x11111111 << i))
|
abort ();
|
abort ();
|
}
|
}
|
else if (u.i[i])
|
else if (u.i[i])
|
abort ();
|
abort ();
|
}
|
}
|
return 0;
|
return 0;
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.