summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/mips/int-moves-2.c
blob: 930c36f9f83e3332c741092c03c992e288f421a1 (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
/* { dg-options "(-mips16) -mgp64 -EB" } */

typedef unsigned uint128_t __attribute__((mode(TI)));

extern uint128_t g[16];
extern unsigned char gstuff[0x10000];

NOMIPS16 uint128_t
foo (uint128_t i1, uint128_t i2, uint128_t i3, uint128_t i4,
     uint128_t *x, unsigned char *lstuff)
{
  g[0] = i1;
  g[1] = i2;
  g[2] = i3;
  g[3] = i4;
  x[0] = x[4];
  x[1] = 0;
  x[2] = ((uint128_t) 0x123456789abcdefULL << 64) | 0xaabbccddeeff1122ULL;
  x[3] = g[4];
  x[4] = *(uint128_t *) (lstuff + 0x7fff);
  return *(uint128_t *) (gstuff + 0x7fff);
}

MIPS16 uint128_t
bar (uint128_t i1, uint128_t i2, uint128_t i3, uint128_t i4,
     uint128_t *x, unsigned char *lstuff)
{
  g[0] = i1;
  g[1] = i2;
  g[2] = i3;
  g[3] = i4;
  x[0] = x[4];
  x[1] = 0;
  x[2] = ((uint128_t) 0x123456789abcdefULL << 64) | 0xaabbccddeeff1122ULL;
  x[3] = g[4];
  x[4] = *(uint128_t *) (lstuff + 0x7fff);
  return *(uint128_t *) (gstuff + 0x7fff);
}