From e6dc3aa0ee1e616a385d12371a6965ab83b2238b Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Wed, 28 Nov 2001 10:09:26 -0800 Subject: [PATCH] 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 --- gcc/ChangeLog | 5 +++++ gcc/doloop.c | 18 +++++++++++++++--- 2 files changed, 20 insertions(+), 3 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 849630ba368..04077893697 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2001-11-28 Richard Henderson + + * doloop.c (doloop_modify_runtime): Properly select induction + variable; skip late entry test if biv initializer created by loop. + Wed Nov 28 08:21:47 2001 Richard Kenner * tree.h (EXPR_WFL_LINECOL): Used by Java in node other than diff --git a/gcc/doloop.c b/gcc/doloop.c index be232d63e6c..cf50d685096 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, -- 2.30.2