summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Sandiford <rsandifo@redhat.com>2005-05-07 19:05:33 +0000
committerRichard Sandiford <rsandifo@gcc.gnu.org>2005-05-07 19:05:33 +0000
commitf72392241a3b1735042c4d6fb7568e12d7499d56 (patch)
tree4df2128d211b7cc40648dfe699517223c78bf880 /gcc
parentc1630cc5dc135d34a91cf62fc7ee57fb68295556 (diff)
downloadgcc-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/ChangeLog11
-rw-r--r--gcc/integrate.c57
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