URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 297 |
Rev 338 |
extern void abort (void);
|
extern void abort (void);
|
|
|
typedef int V2SI __attribute__ ((vector_size (8)));
|
typedef int V2SI __attribute__ ((vector_size (8)));
|
typedef unsigned int V2USI __attribute__ ((vector_size (8)));
|
typedef unsigned int V2USI __attribute__ ((vector_size (8)));
|
typedef short V2HI __attribute__ ((vector_size (4)));
|
typedef short V2HI __attribute__ ((vector_size (4)));
|
typedef unsigned int V2UHI __attribute__ ((vector_size (4)));
|
typedef unsigned int V2UHI __attribute__ ((vector_size (4)));
|
|
|
V2USI
|
V2USI
|
test1 (V2SI x)
|
test1 (V2SI x)
|
{
|
{
|
return (V2USI) (V2SI) (long long) x;
|
return (V2USI) (V2SI) (long long) x;
|
}
|
}
|
|
|
long long
|
long long
|
test2 (V2SI x)
|
test2 (V2SI x)
|
{
|
{
|
return (long long) (V2USI) (V2SI) (long long) x;
|
return (long long) (V2USI) (V2SI) (long long) x;
|
}
|
}
|
|
|
int
|
int
|
main (void)
|
main (void)
|
{
|
{
|
if (sizeof (short) != 2 || sizeof (int) != 4 || sizeof (long long) != 8)
|
if (sizeof (short) != 2 || sizeof (int) != 4 || sizeof (long long) != 8)
|
return 0;
|
return 0;
|
|
|
union { V2SI x; int y[2]; V2USI z; long long l; } u;
|
union { V2SI x; int y[2]; V2USI z; long long l; } u;
|
V2SI a = { -3, -3 };
|
V2SI a = { -3, -3 };
|
u.z = test1 (a);
|
u.z = test1 (a);
|
if (u.y[0] != -3 || u.y[1] != -3)
|
if (u.y[0] != -3 || u.y[1] != -3)
|
abort ();
|
abort ();
|
|
|
u.l = test2 (a);
|
u.l = test2 (a);
|
if (u.y[0] != -3 || u.y[1] != -3)
|
if (u.y[0] != -3 || u.y[1] != -3)
|
abort ();
|
abort ();
|
return 0;
|
return 0;
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.