aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorVladimir Makarov <vmakarov@redhat.com>2014-11-16 05:00:30 +0000
committerVladimir Makarov <vmakarov@gcc.gnu.org>2014-11-16 05:00:30 +0000
commitf607c5c4b7720bdc62998ebb2b64d4d093690d5c (patch)
treee7ab8e4ebe6b2ee4340da36b42c99a9bc2b3cdd0 /gcc
parentcb9365ac6afa908abd6c3ddf74572d81831700c9 (diff)
downloadgcc-f607c5c4b7720bdc62998ebb2b64d4d093690d5c.zip
gcc-f607c5c4b7720bdc62998ebb2b64d4d093690d5c.tar.gz
gcc-f607c5c4b7720bdc62998ebb2b64d4d093690d5c.tar.bz2
lra-remat.c (cand_transf_func): Process regno for rematerialization too.
2014-11-15 Vladimir Makarov <vmakarov@redhat.com> * lra-remat.c (cand_transf_func): Process regno for rematerialization too. * lra.c (lra): Switch on rematerialization pass. From-SVN: r217624
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/lra-remat.c4
-rw-r--r--gcc/lra.c2
3 files changed, 11 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index b50fd18..758c3ad 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,11 @@
2014-11-15 Vladimir Makarov <vmakarov@redhat.com>
+ * lra-remat.c (cand_transf_func): Process regno for
+ rematerialization too.
+ * lra.c (lra): Switch on rematerialization pass.
+
+2014-11-15 Vladimir Makarov <vmakarov@redhat.com>
+
* lra.c (lra): Switch off rematerialization pass.
2014-11-15 Marc Glisse <marc.glisse@inria.fr>
diff --git a/gcc/lra-remat.c b/gcc/lra-remat.c
index f638a1d..fcb1b6f 100644
--- a/gcc/lra-remat.c
+++ b/gcc/lra-remat.c
@@ -860,6 +860,10 @@ cand_trans_fun (int bb_index, bitmap bb_in, bitmap bb_out)
bitmap_set_bit (&temp_bitmap, cid);
break;
}
+ /* Check regno for rematerialization. */
+ if (bitmap_bit_p (bb_changed_regs, cand->regno)
+ || bitmap_bit_p (bb_dead_regs, cand->regno))
+ bitmap_set_bit (&temp_bitmap, cid);
}
return bitmap_ior_and_compl (bb_out,
&bb_info->gen_cands, bb_in, &temp_bitmap);
diff --git a/gcc/lra.c b/gcc/lra.c
index 661a384..9309d5e 100644
--- a/gcc/lra.c
+++ b/gcc/lra.c
@@ -2354,7 +2354,7 @@ lra (FILE *f)
break;
/* Now we know what pseudos should be spilled. Try to
rematerialize them first. */
- if (0&&lra_remat ())
+ if (lra_remat ())
{
/* We need full live info -- see the comment above. */
lra_create_live_ranges (lra_reg_spill_p, true);