diff options
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/global.c | 20 |
2 files changed, 16 insertions, 9 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 6e4f3a7..bdf2b89 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Thu Aug 12 23:51:04 1999 J"orn Rennecke <amylaar@cygnus.co.uk> + + * global.c (prune_preferences): Move some invariants out of the + inner loop. + Thu Aug 12 15:30:29 1999 Jesse Perry (jap@unx.dec.com) * configure.in (alpha*-dec-osf*): Add osf5. diff --git a/gcc/global.c b/gcc/global.c index 0c5b050..1ac0f24 100644 --- a/gcc/global.c +++ b/gcc/global.c @@ -864,7 +864,7 @@ prune_preferences () for (i = max_allocno - 1; i >= 0; i--) { - HARD_REG_SET temp; + HARD_REG_SET temp, temp2; allocno = allocno_order[i]; COPY_HARD_REG_SET (temp, hard_reg_conflicts[allocno]); @@ -882,25 +882,27 @@ prune_preferences () AND_COMPL_HARD_REG_SET (hard_reg_copy_preferences[allocno], temp); AND_COMPL_HARD_REG_SET (hard_reg_full_preferences[allocno], temp); - CLEAR_HARD_REG_SET (regs_someone_prefers[allocno]); - /* Merge in the preferences of lower-priority registers (they have already been pruned). If we also prefer some of those registers, don't exclude them unless we are of a smaller size (in which case we want to give the lower-priority allocno the first chance for these registers). */ + CLEAR_HARD_REG_SET (temp); + CLEAR_HARD_REG_SET (temp2); for (j = i + 1; j < max_allocno; j++) if (CONFLICTP (allocno, allocno_order[j]) || CONFLICTP (allocno_order[j], allocno)) { - COPY_HARD_REG_SET (temp, - hard_reg_full_preferences[allocno_order[j]]); if (allocno_size[allocno_order[j]] <= allocno_size[allocno]) - AND_COMPL_HARD_REG_SET (temp, - hard_reg_full_preferences[allocno]); - - IOR_HARD_REG_SET (regs_someone_prefers[allocno], temp); + IOR_HARD_REG_SET (temp, + hard_reg_full_preferences[allocno_order[j]]); + else + IOR_HARD_REG_SET (temp2, + hard_reg_full_preferences[allocno_order[j]]); } + AND_COMPL_HARD_REG_SET (temp, hard_reg_full_preferences[allocno]); + IOR_HARD_REG_SET (temp, temp2); + COPY_HARD_REG_SET (regs_someone_prefers[allocno], temp); } } |