URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Go to most recent revision |
Only display areas with differences |
Details |
Blame |
View Log
Rev 154 |
Rev 816 |
/* { dg-do run { target i?86-*-* x86_64-*-* } } */
|
/* { dg-do run { target i?86-*-* x86_64-*-* } } */
|
/* { dg-require-effective-target ilp32 } */
|
/* { dg-require-effective-target ilp32 } */
|
/* { dg-options "-march=i386 -O3 -fomit-frame-pointer" } */
|
/* { dg-options "-march=i386 -O3 -fomit-frame-pointer" } */
|
|
|
/* For this test case, we used to do an invalid load motion after
|
/* For this test case, we used to do an invalid load motion after
|
reload, because we missed autoincrements of the stack pointer. */
|
reload, because we missed autoincrements of the stack pointer. */
|
|
|
extern void abort (void);
|
extern void abort (void);
|
|
|
static int j;
|
static int j;
|
|
|
static void __attribute__((noinline))
|
static void __attribute__((noinline))
|
f1 (int a, int b, int c, int d, int e)
|
f1 (int a, int b, int c, int d, int e)
|
{
|
{
|
j = a;
|
j = a;
|
}
|
}
|
|
|
int __attribute__((noinline))
|
int __attribute__((noinline))
|
f2 (int a, int b, int c, int d, int e)
|
f2 (int a, int b, int c, int d, int e)
|
{
|
{
|
if ((b & 0x1111) != 1)
|
if ((b & 0x1111) != 1)
|
f1 (a, b, c, d, e);
|
f1 (a, b, c, d, e);
|
return 0;
|
return 0;
|
}
|
}
|
|
|
int
|
int
|
main (void)
|
main (void)
|
{
|
{
|
f2 (123, 0, 0, 0, 0);
|
f2 (123, 0, 0, 0, 0);
|
if (j != 123)
|
if (j != 123)
|
abort ();
|
abort ();
|
return 0;
|
return 0;
|
}
|
}
|
|
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.