aboutsummaryrefslogtreecommitdiff
path: root/gcc/rtlanal.c
diff options
context:
space:
mode:
authorRichard Sandiford <rdsandiford@googlemail.com>2014-08-28 06:24:32 +0000
committerRichard Sandiford <rsandifo@gcc.gnu.org>2014-08-28 06:24:32 +0000
commitf7d0b0fc77b26e5fa6872678099576e875d87ed5 (patch)
tree555e45a78d43f197773ed4453483ae4c68e82730 /gcc/rtlanal.c
parenta2b7026c2e31369f7b1d63f4ba3b71cefed64268 (diff)
downloadgcc-f7d0b0fc77b26e5fa6872678099576e875d87ed5.zip
gcc-f7d0b0fc77b26e5fa6872678099576e875d87ed5.tar.gz
gcc-f7d0b0fc77b26e5fa6872678099576e875d87ed5.tar.bz2
rtl.h (find_all_hard_regs): Declare.
gcc/ * rtl.h (find_all_hard_regs): Declare. * rtlanal.c (find_all_hard_regs): New function. (record_hard_reg_uses_1): Delete. (record_hard_reg_uses): Use find_all_hard_regs. From-SVN: r214656
Diffstat (limited to 'gcc/rtlanal.c')
-rw-r--r--gcc/rtlanal.c31
1 files changed, 14 insertions, 17 deletions
diff --git a/gcc/rtlanal.c b/gcc/rtlanal.c
index f1cb224..8649166 100644
--- a/gcc/rtlanal.c
+++ b/gcc/rtlanal.c
@@ -1122,6 +1122,19 @@ set_of (const_rtx pat, const_rtx insn)
return data.found;
}
+/* Add all hard register in X to *PSET. */
+void
+find_all_hard_regs (const_rtx x, HARD_REG_SET *pset)
+{
+ subrtx_iterator::array_type array;
+ FOR_EACH_SUBRTX (iter, array, x, NONCONST)
+ {
+ const_rtx x = *iter;
+ if (REG_P (x) && REGNO (x) < FIRST_PSEUDO_REGISTER)
+ add_to_hard_reg_set (pset, GET_MODE (x), REGNO (x));
+ }
+}
+
/* This function, called through note_stores, collects sets and
clobbers of hard registers in a HARD_REG_SET, which is pointed to
by DATA. */
@@ -1155,27 +1168,11 @@ find_all_hard_reg_sets (const_rtx insn, HARD_REG_SET *pset, bool implicit)
record_hard_reg_sets (XEXP (link, 0), NULL, pset);
}
-/* A for_each_rtx subroutine of record_hard_reg_uses. */
-static int
-record_hard_reg_uses_1 (rtx *px, void *data)
-{
- rtx x = *px;
- HARD_REG_SET *pused = (HARD_REG_SET *)data;
-
- if (REG_P (x) && REGNO (x) < FIRST_PSEUDO_REGISTER)
- {
- int nregs = hard_regno_nregs[REGNO (x)][GET_MODE (x)];
- while (nregs-- > 0)
- SET_HARD_REG_BIT (*pused, REGNO (x) + nregs);
- }
- return 0;
-}
-
/* Like record_hard_reg_sets, but called through note_uses. */
void
record_hard_reg_uses (rtx *px, void *data)
{
- for_each_rtx (px, record_hard_reg_uses_1, data);
+ find_all_hard_regs (*px, (HARD_REG_SET *) data);
}
/* Given an INSN, return a SET expression if this insn has only a single SET.