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
|
/* ??? It'd be nice to run this for sparc32 as well, if we could know
for sure that we're on an ultrasparc, rather than an older cpu. */
/* { dg-do run { target sparcv9-*-* sparc64-*-* } } */
/* { dg-options "-O2 -m32 -mcpu=ultrasparc -mvis" } */
int foo(double a, int b, int c, double *d, int h)
{
int f, g;
double e;
l:
f = (int) a;
a -= (double) f;
if (b == 1)
{
g = c;
f += g;
c -= g;
}
if (b == 2)
{
f++;
h = c;
goto l;
}
asm volatile ("" : : :
"f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
"f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
"f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
"f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31");
return f & 7;
}
int main()
{
if (foo(0.1, 1, 3, 0, 1) != 3)
abort ();
exit (0);
}
|