blob: d238d112cfa1cb804fd1c5d2188aaf766cd8d2f7 (
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
|
/* PR rtl-optimization/33673 */
/* { dg-do compile } */
/* { dg-options "-Os -fno-forward-propagate -fno-guess-branch-probability -fno-move-loop-invariants -fno-tree-dominator-opts -fno-tree-loop-optimize" } */
extern int f1 (int);
extern int f2 (int);
extern int *a;
static void
find_reg (int n)
{
int i, pass;
unsigned int used[2], used1[2];
int c = n ? f1 (a[1]) : f2 (a[1]);
for (i = 64, pass = 0; pass <= 1 && i >= 64; pass++)
{
if (pass == 1)
{
unsigned int *scan_tp_ = used;
unsigned int *scan_fp_ = used1;
int j;
for (j = 0; j < 2; j++)
*scan_tp_++ = *scan_fp_++;
}
for (i = 0; i < 64; i++)
{
int regno = i;
if (n == 0)
if (i == regno)
break;
}
}
}
void
global_alloc ()
{
find_reg (0);
find_reg (1);
}
|