aboutsummaryrefslogtreecommitdiff
path: root/gcc/doloop.c
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2001-11-28 10:09:26 -0800
committerRichard Henderson <rth@gcc.gnu.org>2001-11-28 10:09:26 -0800
commite6dc3aa0ee1e616a385d12371a6965ab83b2238b (patch)
treeac2618577cfde9967a56e67bf26ecd32a0196efc /gcc/doloop.c
parent969ff1a01916ab79390cf9302bb8db63483bf0e7 (diff)
downloadgcc-e6dc3aa0ee1e616a385d12371a6965ab83b2238b.zip
gcc-e6dc3aa0ee1e616a385d12371a6965ab83b2238b.tar.gz
gcc-e6dc3aa0ee1e616a385d12371a6965ab83b2238b.tar.bz2
doloop.c (doloop_modify_runtime): Properly select induction variable...
* doloop.c (doloop_modify_runtime): Properly select induction variable; skip late entry test if biv initializer created by loop. From-SVN: r47423
Diffstat (limited to 'gcc/doloop.c')
-rw-r--r--gcc/doloop.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/gcc/doloop.c b/gcc/doloop.c
index be232d6..cf50d68 100644
--- a/gcc/doloop.c
+++ b/gcc/doloop.c
@@ -621,11 +621,23 @@ doloop_modify_runtime (loop, iterations_max,
if (loop->scan_start)
{
+ rtx iteration_var = loop_info->iteration_var;
struct loop_ivs *ivs = LOOP_IVS (loop);
- struct iv_class *bl
- = REG_IV_CLASS (ivs, REGNO (loop_info->iteration_var));
+ struct iv_class *bl;
- if (INSN_LUID (bl->biv->insn) < INSN_LUID (loop->scan_start))
+ if (REG_IV_TYPE (ivs, REGNO (iteration_var)) == BASIC_INDUCT)
+ bl = REG_IV_CLASS (ivs, REGNO (iteration_var));
+ else if (REG_IV_TYPE (ivs, REGNO (iteration_var)) == GENERAL_INDUCT)
+ {
+ struct induction *v = REG_IV_INFO (ivs, REGNO (iteration_var));
+ bl = REG_IV_CLASS (ivs, REGNO (v->src_reg));
+ }
+ else
+ /* Iteration var must be an induction variable to get here. */
+ abort();
+
+ if (INSN_UID (bl->biv->insn) < max_uid_for_loop
+ && INSN_LUID (bl->biv->insn) < INSN_LUID (loop->scan_start))
{
if (loop_dump_stream)
fprintf (loop_dump_stream,