blob: beb9248de757377add5795dc91a5eb38f5e5c036 (
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
51
|
/* { dg-options "(-mips16) -mcode-readable=yes -mabi=eabi -mgp64" } */
/* { dg-skip-if ".half requires -O" { *-*-* } { "-O0" } { "" } } */
volatile int x1;
volatile int x2;
volatile int x3;
volatile int x4;
volatile int x5;
volatile int x6;
volatile int x7;
volatile int x8;
volatile int x9;
volatile int x10;
volatile int x11;
MIPS16 int
foo (int i, volatile int *x)
{
switch (i)
{
case 1: return x1 + x[0];
case 2: return x2 + x[1];
case 3: return x3 + x[2];
case 4: return x4 + x[3];
case 5: return x5 + x[4];
case 6: return x6 + x[5];
case 7: return x7 + x[6];
case 8: return x8 + x[7];
case 9: return x9 + x[8];
case 10: return x10 + x[9];
case 11: return x11 + x[10];
default: return 0;
}
}
extern int k[];
MIPS16 int *
bar (void)
{
return k;
}
/* { dg-final { scan-assembler "\tla\t" } } */
/* { dg-final { scan-assembler "\t\\.half\t" } } */
/* { dg-final { scan-assembler-not "%hi\\(\[^)\]*L" } } */
/* { dg-final { scan-assembler-not "%lo\\(\[^)\]*L" } } */
/* { dg-final { scan-assembler "\t\\.dword\tk\n" } } */
/* { dg-final { scan-assembler-not "%hi\\(k\\)" } } */
/* { dg-final { scan-assembler-not "%lo\\(k\\)" } } */
|