diff options
author | Richard Sandiford <rsandifo@redhat.com> | 2005-05-07 19:05:33 +0000 |
---|---|---|
committer | Richard Sandiford <rsandifo@gcc.gnu.org> | 2005-05-07 19:05:33 +0000 |
commit | f72392241a3b1735042c4d6fb7568e12d7499d56 (patch) | |
tree | 4df2128d211b7cc40648dfe699517223c78bf880 /gcc | |
parent | c1630cc5dc135d34a91cf62fc7ee57fb68295556 (diff) | |
download | gcc-f72392241a3b1735042c4d6fb7568e12d7499d56.tar.gz |
integrate.c (get_func_hard_reg_initial_val): Delete.
* integrate.c (get_func_hard_reg_initial_val): Delete.
(has_func_hard_reg_initial_val): Delete.
(get_hard_reg_initial_val): Inline the old implementation of
get_func_hard_reg_initial_val. Use has_hard_reg_initial_val
instead of has_func_hard_reg_initial_val to test for an existing
pseudo. Only create an rtx if a new initial value entry is needed.
(has_hard_reg_initial_val): Scan the initial value list directly.
Don't create an rtx.
From-SVN: r99358
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 11 | ||||
-rw-r--r-- | gcc/integrate.c | 57 |
2 files changed, 38 insertions, 30 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5537d7f3c9f..98daa946567 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,14 @@ +2005-05-07 Richard Sandiford <rsandifo@redhat.com> + + * integrate.c (get_func_hard_reg_initial_val): Delete. + (has_func_hard_reg_initial_val): Delete. + (get_hard_reg_initial_val): Inline the old implementation of + get_func_hard_reg_initial_val. Use has_hard_reg_initial_val + instead of has_func_hard_reg_initial_val to test for an existing + pseudo. Only create an rtx if a new initial value entry is needed. + (has_hard_reg_initial_val): Scan the initial value list directly. + Don't create an rtx. + 2005-05-07 David Edelsohn <edelsohn@gnu.org> * config.gcc ({powerpc,rs6000}-ibm-aix*): Remove rs6000/aix.opt diff --git a/gcc/integrate.c b/gcc/integrate.c index 910f977bf38..6987fcccec2 100644 --- a/gcc/integrate.c +++ b/gcc/integrate.c @@ -50,7 +50,7 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA #define CEIL_ROUND(VALUE,ALIGN) (((VALUE) + (ALIGN) - 1) & ~((ALIGN)- 1)) -/* Private type used by {get/has}_func_hard_reg_initial_val. */ +/* Private type used by {get/has}_hard_reg_initial_val. */ typedef struct initial_value_pair GTY(()) { rtx hard_reg; rtx pseudo; @@ -293,38 +293,27 @@ get_hard_reg_initial_reg (struct function *fun, rtx reg) return NULL_RTX; } -static rtx -has_func_hard_reg_initial_val (struct function *fun, rtx reg) -{ - struct initial_value_struct *ivs = fun->hard_reg_initial_vals; - int i; - - if (ivs == 0) - return NULL_RTX; - - for (i = 0; i < ivs->num_entries; i++) - if (rtx_equal_p (ivs->entries[i].hard_reg, reg)) - return ivs->entries[i].pseudo; - - return NULL_RTX; -} +/* Make sure that there's a pseudo register of mode MODE that stores the + initial value of hard register REGNO. Return an rtx for such a pseudo. */ -static rtx -get_func_hard_reg_initial_val (struct function *fun, rtx reg) +rtx +get_hard_reg_initial_val (enum machine_mode mode, int regno) { - struct initial_value_struct *ivs = fun->hard_reg_initial_vals; - rtx rv = has_func_hard_reg_initial_val (fun, reg); + struct initial_value_struct *ivs; + rtx rv; + rv = has_hard_reg_initial_val (mode, regno); if (rv) return rv; + ivs = cfun->hard_reg_initial_vals; if (ivs == 0) { - fun->hard_reg_initial_vals = ggc_alloc (sizeof (initial_value_struct)); - ivs = fun->hard_reg_initial_vals; + ivs = ggc_alloc (sizeof (initial_value_struct)); ivs->num_entries = 0; ivs->max_entries = 5; ivs->entries = ggc_alloc (5 * sizeof (initial_value_pair)); + cfun->hard_reg_initial_vals = ivs; } if (ivs->num_entries >= ivs->max_entries) @@ -335,22 +324,30 @@ get_func_hard_reg_initial_val (struct function *fun, rtx reg) * sizeof (initial_value_pair)); } - ivs->entries[ivs->num_entries].hard_reg = reg; - ivs->entries[ivs->num_entries].pseudo = gen_reg_rtx (GET_MODE (reg)); + ivs->entries[ivs->num_entries].hard_reg = gen_rtx_REG (mode, regno); + ivs->entries[ivs->num_entries].pseudo = gen_reg_rtx (mode); return ivs->entries[ivs->num_entries++].pseudo; } -rtx -get_hard_reg_initial_val (enum machine_mode mode, int regno) -{ - return get_func_hard_reg_initial_val (cfun, gen_rtx_REG (mode, regno)); -} +/* See if get_hard_reg_initial_val has been used to create a pseudo + for the initial value of hard register REGNO in mode MODE. Return + the associated pseudo if so, otherwise return NULL. */ rtx has_hard_reg_initial_val (enum machine_mode mode, int regno) { - return has_func_hard_reg_initial_val (cfun, gen_rtx_REG (mode, regno)); + struct initial_value_struct *ivs; + int i; + + ivs = cfun->hard_reg_initial_vals; + if (ivs != 0) + for (i = 0; i < ivs->num_entries; i++) + if (GET_MODE (ivs->entries[i].hard_reg) == mode + && REGNO (ivs->entries[i].hard_reg) == (unsigned int) regno) + return ivs->entries[i].pseudo; + + return NULL_RTX; } void |