rtl.h (local_alloc): Returns an integer now.

* rtl.h (local_alloc): Returns an integer now.
        * local-alloc.c (recorded_label_ref): New file scoped variable.
        (local_alloc): Initialize recorded_label_ref to zero.  Return its
        value when local allocation has completed.
        (update_equiv_regs); If we create an equivalence for a LABEL_REF,
        set recorded_label_ref.
        * toplev.c (rest_of_compilation): Run the loop optimizer after
        register allocation and reloading if needed.

From-SVN: r26324
This commit is contained in:
Jeffrey A Law 1999-04-10 02:55:36 +00:00 committed by Jeff Law
parent d1c13bdab5
commit 3f1b9b1b90
4 changed files with 52 additions and 4 deletions

View File

@ -1,3 +1,14 @@
Sat Apr 10 03:50:12 1999 Jeffrey A Law (law@cygnus.com)
* rtl.h (local_alloc): Returns an integer now.
* local-alloc.c (recorded_label_ref): New file scoped variable.
(local_alloc): Initialize recorded_label_ref to zero. Return its
value when local allocation has completed.
(update_equiv_regs); If we create an equivalence for a LABEL_REF,
set recorded_label_ref.
* toplev.c (rest_of_compilation): Run the loop optimizer after
register allocation and reloading if needed.
Fri Apr 9 21:02:57 1999 Krister Walfridsson (cato@df.lth.se) Fri Apr 9 21:02:57 1999 Krister Walfridsson (cato@df.lth.se)
* i386/gas.h (ASM_OUTPUT_MAX_SKIP_ALIGN): Fix typo. * i386/gas.h (ASM_OUTPUT_MAX_SKIP_ALIGN): Fix typo.

View File

@ -237,6 +237,9 @@ static rtx *reg_equiv_replacement;
/* Used for communication between update_equiv_regs and no_equiv. */ /* Used for communication between update_equiv_regs and no_equiv. */
static rtx *reg_equiv_init_insns; static rtx *reg_equiv_init_insns;
/* Nonzero if we recorded an equivalence for a LABEL_REF. */
static int recorded_label_ref;
static void alloc_qty PROTO((int, enum machine_mode, int, int)); static void alloc_qty PROTO((int, enum machine_mode, int, int));
static void validate_equiv_mem_from_store PROTO((rtx, rtx)); static void validate_equiv_mem_from_store PROTO((rtx, rtx));
static int validate_equiv_mem PROTO((rtx, rtx, rtx)); static int validate_equiv_mem PROTO((rtx, rtx, rtx));
@ -292,12 +295,16 @@ alloc_qty (regno, mode, size, birth)
/* Main entry point of this file. */ /* Main entry point of this file. */
void int
local_alloc () local_alloc ()
{ {
register int b, i; register int b, i;
int max_qty; int max_qty;
/* We need to keep track of whether or not we recorded a LABEL_REF so
that we know if the jump optimizer needs to be rerun. */
recorded_label_ref = 0;
/* Leaf functions and non-leaf functions have different needs. /* Leaf functions and non-leaf functions have different needs.
If defined, let the machine say what kind of ordering we If defined, let the machine say what kind of ordering we
should use. */ should use. */
@ -410,6 +417,7 @@ local_alloc ()
free (reg_qty); free (reg_qty);
free (reg_offset); free (reg_offset);
free (reg_next_in_qty); free (reg_next_in_qty);
return recorded_label_ref;
} }
/* Depth of loops we are in while in update_equiv_regs. */ /* Depth of loops we are in while in update_equiv_regs. */
@ -842,6 +850,19 @@ update_equiv_regs ()
{ {
int regno = REGNO (dest); int regno = REGNO (dest);
/* Record whether or not we created a REG_EQUIV note for a LABEL_REF.
We might end up substituting the LABEL_REF for uses of the
pseudo here or later. That kind of transformation may turn an
indirect jump into a direct jump, in which case we must rerun the
jump optimizer to ensure that the JUMP_LABEL fields are valid. */
if (GET_CODE (XEXP (note, 0)) == LABEL_REF
|| (GET_CODE (XEXP (note, 0)) == CONST
&& GET_CODE (XEXP (XEXP (note, 0), 0)) == PLUS
&& (GET_CODE (XEXP (XEXP (XEXP (note, 0), 0), 0))
== LABEL_REF)))
recorded_label_ref = 1;
reg_equiv_replacement[regno] = XEXP (note, 0); reg_equiv_replacement[regno] = XEXP (note, 0);
/* Don't mess with things live during setjmp. */ /* Don't mess with things live during setjmp. */

View File

@ -1539,7 +1539,7 @@ extern void init_optabs PROTO ((void));
#ifdef BUFSIZ #ifdef BUFSIZ
extern void dump_local_alloc PROTO ((FILE *)); extern void dump_local_alloc PROTO ((FILE *));
#endif #endif
extern void local_alloc PROTO ((void)); extern int local_alloc PROTO ((void));
extern int function_invariant_p PROTO ((rtx)); extern int function_invariant_p PROTO ((rtx));
/* In reload1.c */ /* In reload1.c */

View File

@ -3526,6 +3526,7 @@ rest_of_compilation (decl)
/* Likewise, for DECL_ARGUMENTS. */ /* Likewise, for DECL_ARGUMENTS. */
tree saved_arguments = 0; tree saved_arguments = 0;
int failure = 0; int failure = 0;
int run_jump_after_reload;
/* If we are reconsidering an inline function /* If we are reconsidering an inline function
at the end of compilation, skip the stuff for making it inline. */ at the end of compilation, skip the stuff for making it inline. */
@ -4063,15 +4064,20 @@ rest_of_compilation (decl)
} }
/* Unless we did stupid register allocation, /* Unless we did stupid register allocation,
allocate pseudo-regs that are used only within 1 basic block. */ allocate pseudo-regs that are used only within 1 basic block.
RUN_JUMP_AFTER_RELOAD records whether or not we need to rerun the
jump optimizer after register allocation and reloading are finished. */
if (!obey_regdecls) if (!obey_regdecls)
TIMEVAR (local_alloc_time, TIMEVAR (local_alloc_time,
{ {
recompute_reg_usage (insns, ! optimize_size); recompute_reg_usage (insns, ! optimize_size);
regclass (insns, max_reg_num ()); regclass (insns, max_reg_num ());
local_alloc (); run_jump_after_reload = local_alloc ();
}); });
else
run_jump_after_reload = 0;
/* Dump rtl code after allocating regs within basic blocks. */ /* Dump rtl code after allocating regs within basic blocks. */
@ -4106,6 +4112,16 @@ rest_of_compilation (decl)
if (failure) if (failure)
goto exit_rest_of_compilation; goto exit_rest_of_compilation;
/* Register allocation and reloading may have turned an indirect jump into
a direct jump. If so, we must rerun the jump optimizer to ensure that
the JUMP_LABEL of any jump changed by that transformation is valid.
We do this before reload_cse_regs since it may allow reload_cse to do
a better job. */
if (run_jump_after_reload)
TIMEVAR (jump_time, jump_optimize (insns, !JUMP_CROSS_JUMP,
!JUMP_NOOP_MOVES, !JUMP_AFTER_REGSCAN));
/* Do a very simple CSE pass over just the hard registers. */ /* Do a very simple CSE pass over just the hard registers. */
if (optimize > 0) if (optimize > 0)
reload_cse_regs (insns); reload_cse_regs (insns);