blob: a5a53077ac282272dee87b1bdb971f8a723b0080 [file] [log] [blame]
/* { dg-do compile { target { powerpc*-*-* } } } */
/* { dg-skip-if "" { powerpc*-*-darwin* } } */
/* { dg-options "-O2 -mdejagnu-cpu=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);
}