URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 325 |
Rev 338 |
/* { dg-do compile { target "sh*-*-*" } } */
|
/* { dg-do compile { target "sh*-*-*" } } */
|
/* { dg-options "-mb -O2 -fomit-frame-pointer" } */
|
/* { dg-options "-mb -O2 -fomit-frame-pointer" } */
|
/* { dg-final { scan-assembler "mov @r.,r.; mov @\\(4,r.\\),r." } } */
|
/* { dg-final { scan-assembler "mov @r.,r.; mov @\\(4,r.\\),r." } } */
|
double d;
|
double d;
|
|
|
double
|
double
|
f (void)
|
f (void)
|
{
|
{
|
double r;
|
double r;
|
|
|
/* If -ml from the target options is passed after -mb from dg-options, we
|
/* If -ml from the target options is passed after -mb from dg-options, we
|
end up with th reverse endianness. */
|
end up with th reverse endianness. */
|
#if TARGET_SHMEDIA || defined (__LITTLE_ENDIAN__)
|
#if TARGET_SHMEDIA || defined (__LITTLE_ENDIAN__)
|
asm ("mov @r1,r3; mov @(4,r1),r4");
|
asm ("mov @r1,r3; mov @(4,r1),r4");
|
#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.