URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 318 |
Rev 384 |
/* PR target/6753
|
/* PR target/6753
|
This testcase was miscompiled because sse_mov?fcc_const0*
|
This testcase was miscompiled because sse_mov?fcc_const0*
|
patterns were missing earlyclobber. */
|
patterns were missing earlyclobber. */
|
|
|
/* { dg-do run } */
|
/* { dg-do run } */
|
/* { dg-options "-O2 -msse -mfpmath=sse -ffast-math" } */
|
/* { dg-options "-O2 -msse -mfpmath=sse -ffast-math" } */
|
/* { dg-require-effective-target sse } */
|
/* { dg-require-effective-target sse } */
|
|
|
#include "sse-check.h"
|
#include "sse-check.h"
|
|
|
float one = 1.f;
|
float one = 1.f;
|
|
|
void bar (float f)
|
void bar (float f)
|
{
|
{
|
if (__builtin_memcmp (&one, &f, sizeof (float)))
|
if (__builtin_memcmp (&one, &f, sizeof (float)))
|
abort ();
|
abort ();
|
}
|
}
|
|
|
float foo (void)
|
float foo (void)
|
{
|
{
|
return 1.f;
|
return 1.f;
|
}
|
}
|
|
|
typedef struct
|
typedef struct
|
{
|
{
|
float t;
|
float t;
|
} T;
|
} T;
|
|
|
static void
|
static void
|
sse_test (void)
|
sse_test (void)
|
{
|
{
|
int i;
|
int i;
|
T x[1];
|
T x[1];
|
|
|
for (i = 0; i < 1; i++)
|
for (i = 0; i < 1; i++)
|
{
|
{
|
x[i].t = foo ();
|
x[i].t = foo ();
|
x[i].t = 0.f > x[i].t ? 0.f : x[i].t;
|
x[i].t = 0.f > x[i].t ? 0.f : x[i].t;
|
bar (x[i].t);
|
bar (x[i].t);
|
}
|
}
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.