URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 149 |
Rev 154 |
/* { dg-do compile { target "sh*-*-*" } } */
|
/* { dg-do compile { target "sh*-*-*" } } */
|
/* { dg-options "-ml -O2 -fomit-frame-pointer" } */
|
/* { dg-options "-ml -O2 -fomit-frame-pointer" } */
|
/* { dg-final { scan-assembler "mov @\\(4,r.\\),r.; mov @r.,r." } } */
|
/* { dg-final { scan-assembler "mov @\\(4,r.\\),r.; mov @r.,r." } } */
|
double d;
|
double d;
|
|
|
double
|
double
|
f (void)
|
f (void)
|
{
|
{
|
double r;
|
double r;
|
|
|
/* If -mb from the target options is passed after -ml from dg-options, we
|
/* If -mb from the target options is passed after -ml from dg-options, we
|
end up with th reverse endianness. */
|
end up with th reverse endianness. */
|
#if TARGET_SHMEDIA || defined (__BIG_ENDIAN__)
|
#if TARGET_SHMEDIA || defined (__BIG_ENDIAN__)
|
asm ("mov @(4,r1),r4; mov @r1,r3");
|
asm ("mov @(4,r1),r4; mov @r1,r3");
|
#else
|
#else
|
asm ("mov %S1,%S0; mov %R1,%R0" : "=&r" (r) : "m" (d));
|
asm ("mov %S1,%S0; mov %R1,%R0" : "=&r" (r) : "m" (d));
|
#endif
|
#endif
|
return r;
|
return r;
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.