aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorBernd Schmidt <bernd.schmidt@analog.com>2007-07-06 13:42:26 +0000
committerBernd Schmidt <bernds@gcc.gnu.org>2007-07-06 13:42:26 +0000
commit374d961c0df2af3d7fc3367d63daec408b09d148 (patch)
treef665accc8a8a1bf7939e3fd2f91e6a91b081ca6b /gcc
parentde8b1dca2f7b3779dcaa217a103862ac69ed4c95 (diff)
downloadgcc-374d961c0df2af3d7fc3367d63daec408b09d148.zip
gcc-374d961c0df2af3d7fc3367d63daec408b09d148.tar.gz
gcc-374d961c0df2af3d7fc3367d63daec408b09d148.tar.bz2
reload1.c (choose_reload_regs): Set reload_spill_index for regs chosen during find_reloads.
* reload1.c (choose_reload_regs): Set reload_spill_index for regs chosen during find_reloads. From-SVN: r126415
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/reload1.c9
2 files changed, 13 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f405b26..2c5edb5 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2007-07-06 Bernd Schmidt <bernd.schmidt@analog.com>
+
+ * reload1.c (choose_reload_regs): Set reload_spill_index for regs
+ chosen during find_reloads.
+
2007-07-06 Richard Guenther <rguenther@suse.de>
* gimplify.c (gimplify_call_expr): Prefer DECL_ARGUMENTS over
diff --git a/gcc/reload1.c b/gcc/reload1.c
index 6bba280..fda1adc 100644
--- a/gcc/reload1.c
+++ b/gcc/reload1.c
@@ -5633,7 +5633,14 @@ choose_reload_regs (struct insn_chain *chain)
for (j = 0; j < n_reloads; j++)
{
reload_order[j] = j;
- reload_spill_index[j] = -1;
+ if (rld[j].reg_rtx != NULL_RTX)
+ {
+ gcc_assert (REG_P (rld[j].reg_rtx)
+ && HARD_REGISTER_P (rld[j].reg_rtx));
+ reload_spill_index[j] = REGNO (rld[j].reg_rtx);
+ }
+ else
+ reload_spill_index[j] = -1;
if (rld[j].nregs > 1)
{