diff options
author | Alexandre Oliva <aoliva@gcc.gnu.org> | 2001-01-02 00:59:52 +0000 |
---|---|---|
committer | Alexandre Oliva <aoliva@gcc.gnu.org> | 2001-01-02 00:59:52 +0000 |
commit | e56b459443c4a8d7f46f33fae6b686d0ed645f2d (patch) | |
tree | e521405558bc22c6ba3380b06b0ff680d3435a47 /gcc/reload1.c | |
parent | 5b1ef594574c48fc88045d143efe913f704e3f09 (diff) | |
download | gcc-e56b459443c4a8d7f46f33fae6b686d0ed645f2d.zip gcc-e56b459443c4a8d7f46f33fae6b686d0ed645f2d.tar.gz gcc-e56b459443c4a8d7f46f33fae6b686d0ed645f2d.tar.bz2 |
tm.texi (REGISTER_MOVE_COST): Add a mode argument.
* tm.texi (REGISTER_MOVE_COST): Add a mode argument.
* reload.c (REGISTER_MOVE_COST): Likewise. Adjust all callers.
* reload1.c (REGISTER_MOVE_COST): Likewise.
* regclass.c (REGISTER_MOVE_COST): Likewise.
(move_cost, may_move_in_cost, may_move_out_cost): Add mode
dimension. Adjust all users.
(init_reg_sets_1): Iterate on all modes.
* config/1750a/1750a.h (REGISTER_MOVE_COST): Adjust.
* config/a29k/a29k.h (REGISTER_MOVE_COST): Adjust.
* config/alpha/alpha.h (REGISTER_MOVE_COST): Adjust.
* config/arc/arc.h (REGISTER_MOVE_COST): Adjust.
* config/arm/arm.h (REGISTER_MOVE_COST): Adjust.
* config/avr/avr.h (REGISTER_MOVE_COST): Adjust.
* config/c4x/c4x.h (REGISTER_MOVE_COST): Adjust.
* config/d30v/d30v.h (REGISTER_MOVE_COST): Adjust.
* config/dsp16xx/dsp16xx.h (REGISTER_MOVE_COST): Adjust.
* config/h8300/h8300.h (REGISTER_MOVE_COST): Adjust.
* config/i386/i386.h (REGISTER_MOVE_COST): Adjust.
* config/ia64/ia64.h (REGISTER_MOVE_COST): Adjust.
* config/m32r/m32r.h (REGISTER_MOVE_COST): Adjust.
* config/m68hc11/m68hc11.h (REGISTER_MOVE_COST): Adjust.
* config/m68k/m68k.h (REGISTER_MOVE_COST): Adjust.
* config/mcore/mcore.h (REGISTER_MOVE_COST): Adjust.
* config/mips/mips.h (REGISTER_MOVE_COST): Adjust.
* config/mn10200/mn10200.h (REGISTER_MOVE_COST): Adjust.
* config/mn10300/mn10300.h (REGISTER_MOVE_COST): Adjust.
* config/ns32k/ns32k.h (REGISTER_MOVE_COST): Adjust.
* config/pa/pa.h (REGISTER_MOVE_COST): Adjust.
* config/pdp11/pdp11.h (REGISTER_MOVE_COST): Adjust.
* config/pj/pj.h (REGISTER_MOVE_COST): Adjust.
* config/romp/romp.h (REGISTER_MOVE_COST): Adjust.
* config/rs6000/rs6000.h (REGISTER_MOVE_COST): Adjust.
* config/sh/sh.h (REGISTER_MOVE_COST): Adjust.
* config/sparc/sparc.h (REGISTER_MOVE_COST): Adjust.
From-SVN: r38604
Diffstat (limited to 'gcc/reload1.c')
-rw-r--r-- | gcc/reload1.c | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/gcc/reload1.c b/gcc/reload1.c index ee252a6..3a3dab0 100644 --- a/gcc/reload1.c +++ b/gcc/reload1.c @@ -1,6 +1,6 @@ /* Reload pseudo regs into hard regs for insns that require hard regs. Copyright (C) 1987, 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, - 1999, 2000 Free Software Foundation, Inc. + 1999, 2000, 2001 Free Software Foundation, Inc. This file is part of GNU CC. @@ -81,7 +81,7 @@ Boston, MA 02111-1307, USA. */ into the reload registers. */ #ifndef REGISTER_MOVE_COST -#define REGISTER_MOVE_COST(x, y) 2 +#define REGISTER_MOVE_COST(m, x, y) 2 #endif #ifndef LOCAL_REGNO @@ -5396,7 +5396,7 @@ choose_reload_regs (chain) register, we might use it for reload_override_in, if copying it to the desired class is cheap enough. */ - || ((REGISTER_MOVE_COST (last_class, class) + || ((REGISTER_MOVE_COST (mode, last_class, class) < MEMORY_MOVE_COST (mode, class, 1)) #ifdef SECONDARY_INPUT_RELOAD_CLASS && (SECONDARY_INPUT_RELOAD_CLASS (class, mode, @@ -6113,7 +6113,7 @@ emit_input_reload_insns (chain, rl, old, j) if (oldequiv != 0 && ((REGNO_REG_CLASS (regno) != rl->class - && (REGISTER_MOVE_COST (REGNO_REG_CLASS (regno), + && (REGISTER_MOVE_COST (mode, REGNO_REG_CLASS (regno), rl->class) >= MEMORY_MOVE_COST (mode, rl->class, 1))) #ifdef SECONDARY_INPUT_RELOAD_CLASS @@ -8106,7 +8106,8 @@ reload_cse_simplify_set (set, insn) else if (CONSTANT_P (src)) old_cost = rtx_cost (src, SET); else if (GET_CODE (src) == REG) - old_cost = REGISTER_MOVE_COST (REGNO_REG_CLASS (REGNO (src)), dclass); + old_cost = REGISTER_MOVE_COST (GET_MODE (src), + REGNO_REG_CLASS (REGNO (src)), dclass); else /* ??? */ old_cost = rtx_cost (src, SET); @@ -8120,7 +8121,8 @@ reload_cse_simplify_set (set, insn) if (CONSTANT_P (l->loc) && ! references_value_p (l->loc, 0)) this_cost = rtx_cost (l->loc, SET); else if (GET_CODE (l->loc) == REG) - this_cost = REGISTER_MOVE_COST (REGNO_REG_CLASS (REGNO (l->loc)), + this_cost = REGISTER_MOVE_COST (GET_MODE (l->loc), + REGNO_REG_CLASS (REGNO (l->loc)), dclass); else continue; |