aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/regclass.c12
2 files changed, 8 insertions, 8 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f186e3e..6050f79 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+Tue Jan 4 11:44:13 2000 Jeffrey A Law (law@cygnus.com)
+
+ * regclass.c: Revert my Jan 4 change to loop cost computation.
+
Tue Jan 4 19:22:39 MET 2000 Jan Hubicka <hubicka@freesoft.cz>
* regclass.c (regclass): Do not obey REG_N_REFS in non-optimizing
diff --git a/gcc/regclass.c b/gcc/regclass.c
index d1bcf30..1a45b24 100644
--- a/gcc/regclass.c
+++ b/gcc/regclass.c
@@ -1100,17 +1100,13 @@ regclass (f, nregs, dump)
basic_block bb = BASIC_BLOCK (index);
/* Show that an insn inside a loop is likely to be executed three
- times more than insns outside a loop. This is much more
- aggressive than the assumptions made elsewhere and is being
- tried as an experiment.
-
- Note that a block's loop depth starts at zero, not one! We
- must not subract one from the loop depth as that could give
- a negative shift count below. */
+ times more than insns outside a loop. This is much more aggressive
+ than the assumptions made elsewhere and is being tried as an
+ experiment. */
if (optimize_size)
loop_cost = 1;
else
- loop_cost = 1 << (2 * MIN (bb->loop_depth, 5));
+ loop_cost = 1 << (2 * MIN (bb->loop_depth - 1, 5));
for (insn = bb->head; ; insn = NEXT_INSN (insn))
{
insn = scan_one_insn (insn, pass);