diff options
author | Richard Henderson <rth@redhat.com> | 2002-03-10 15:46:14 -0800 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2002-03-10 15:46:14 -0800 |
commit | 26b738be01562bb7cf45e9bcd93838af69a0d9bd (patch) | |
tree | 2fbb3d0587a9cec6f404c15cbbf3d81173a818c1 /gcc/loop.c | |
parent | 8d8a083e9c81948217d3a5cb3010d4f6ed910222 (diff) | |
download | gcc-26b738be01562bb7cf45e9bcd93838af69a0d9bd.zip gcc-26b738be01562bb7cf45e9bcd93838af69a0d9bd.tar.gz gcc-26b738be01562bb7cf45e9bcd93838af69a0d9bd.tar.bz2 |
loop.c (strength_reduce): Compute number of iterations as unsigned HOST_WIDE_INT.
* loop.c (strength_reduce): Compute number of iterations as
unsigned HOST_WIDE_INT.
From-SVN: r50550
Diffstat (limited to 'gcc/loop.c')
-rw-r--r-- | gcc/loop.c | 12 |
1 files changed, 6 insertions, 6 deletions
@@ -5225,13 +5225,13 @@ strength_reduce (loop, flags) /* In case number of iterations is known, drop branch prediction note in the branch. Do that only in second loop pass, as loop unrolling may change the number of iterations performed. */ - if ((flags & LOOP_BCT) - && loop_info->n_iterations / loop_info->unroll_number > 1) + if (flags & LOOP_BCT) { - int n = loop_info->n_iterations / loop_info->unroll_number; - predict_insn (PREV_INSN (loop->end), - PRED_LOOP_ITERATIONS, - REG_BR_PROB_BASE - REG_BR_PROB_BASE / n); + unsigned HOST_WIDE_INT n + = loop_info->n_iterations / loop_info->unroll_number; + if (n > 1) + predict_insn (PREV_INSN (loop->end), PRED_LOOP_ITERATIONS, + REG_BR_PROB_BASE - REG_BR_PROB_BASE / n); } if (loop_dump_stream) |