/* 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); }