summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/powerpc/pr53199.c
blob: 89a0cad06feab299cb5e9fba21ec663c602c48c1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/* { dg-do compile { target { powerpc*-*-* } } } */
/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
/* { dg-options "-O2 -mcpu=power6 -mavoid-indexed-addresses" } */
/* { dg-final { scan-assembler-times "lwbrx" 6 } } */
/* { 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]);
}

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 (long long x)
{
  return __builtin_bswap64 (x);
}