76 lines
1.6 KiB
C
76 lines
1.6 KiB
C
/* { dg-do compile { target { powerpc*-*-* } } } */
|
|
/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
|
|
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power6" } } */
|
|
/* { dg-options "-O2 -mcpu=power6 -mavoid-indexed-addresses" } */
|
|
/* { dg-final { scan-assembler-times "lwbrx" 12 } } */
|
|
/* { dg-final { scan-assembler-times "stwbrx" 6 } } */
|
|
|
|
/* PR 51399: bswap gets an error if -mavoid-indexed-addresses was used in
|
|
creating the two lwbrx instructions. */
|
|
|
|
long long
|
|
load64_reverse_1 (long long *p)
|
|
{
|
|
return __builtin_bswap64 (*p);
|
|
}
|
|
|
|
long long
|
|
load64_reverse_2 (long long *p)
|
|
{
|
|
return __builtin_bswap64 (p[1]);
|
|
}
|
|
|
|
long long
|
|
load64_reverse_3 (long long *p, int i)
|
|
{
|
|
return __builtin_bswap64 (p[i]);
|
|
}
|
|
|
|
long long
|
|
load64_reverse_4 (long long dummy __attribute__ ((unused)), long long *p)
|
|
{
|
|
return __builtin_bswap64 (*p);
|
|
}
|
|
|
|
long long
|
|
load64_reverse_5 (long long dummy __attribute__ ((unused)), long long *p)
|
|
{
|
|
return __builtin_bswap64 (p[1]);
|
|
}
|
|
|
|
long long
|
|
load64_reverse_6 (long long dummy __attribute__ ((unused)), long long *p, int i)
|
|
{
|
|
return __builtin_bswap64 (p[i]);
|
|
}
|
|
|
|
void
|
|
store64_reverse_1 (long long *p, long long x)
|
|
{
|
|
*p = __builtin_bswap64 (x);
|
|
}
|
|
|
|
void
|
|
store64_reverse_2 (long long *p, long long x)
|
|
{
|
|
p[1] = __builtin_bswap64 (x);
|
|
}
|
|
|
|
void
|
|
store64_reverse_3 (long long *p, long long x, int i)
|
|
{
|
|
p[i] = __builtin_bswap64 (x);
|
|
}
|
|
|
|
long long
|
|
reg_reverse_1 (long long x)
|
|
{
|
|
return __builtin_bswap64 (x);
|
|
}
|
|
|
|
long long
|
|
reg_reverse_2 (long long dummy __attribute__ ((unused)), long long x)
|
|
{
|
|
return __builtin_bswap64 (x);
|
|
}
|