aboutsummaryrefslogtreecommitdiff
path: root/gcc/lra.c
diff options
context:
space:
mode:
authorTom de Vries <tom@codesourcery.com>2014-05-28 21:50:28 +0000
committerTom de Vries <vries@gcc.gnu.org>2014-05-28 21:50:28 +0000
commitea0b381f6e6b7a7261f028007453a8fe99587aa0 (patch)
treea85218b1d43ae3380e45d9f5caad31d59415b71d /gcc/lra.c
parent73f793e3bb4e0a2bd04536f8bbc861c34cfec945 (diff)
downloadgcc-ea0b381f6e6b7a7261f028007453a8fe99587aa0.zip
gcc-ea0b381f6e6b7a7261f028007453a8fe99587aa0.tar.gz
gcc-ea0b381f6e6b7a7261f028007453a8fe99587aa0.tar.bz2
revert: lra-int.h (struct lra_reg): Add field actual_call_used_reg_set.
2014-05-28 Tom de Vries <tom@codesourcery.com> Revert: 2014-05-28 Tom de Vries <tom@codesourcery.com> * lra-int.h (struct lra_reg): Add field actual_call_used_reg_set. * lra.c (initialize_lra_reg_info_element): Add init of actual_call_used_reg_set field. (lra): Call lra_create_live_ranges before lra_inheritance for -fuse-caller-save. * lra-assigns.c (lra_assign): Allow call_used_regs to cross calls for -fuse-caller-save. * lra-constraints.c (need_for_call_save_p): Use actual_call_used_reg_set instead of call_used_reg_set for -fuse-caller-save. * lra-lives.c (process_bb_lives): Calculate actual_call_used_reg_set. From-SVN: r211033
Diffstat (limited to 'gcc/lra.c')
-rw-r--r--gcc/lra.c14
1 files changed, 1 insertions, 13 deletions
diff --git a/gcc/lra.c b/gcc/lra.c
index d199a81..ecec890 100644
--- a/gcc/lra.c
+++ b/gcc/lra.c
@@ -1427,7 +1427,6 @@ initialize_lra_reg_info_element (int i)
lra_reg_info[i].no_stack_p = false;
#endif
CLEAR_HARD_REG_SET (lra_reg_info[i].conflict_hard_regs);
- CLEAR_HARD_REG_SET (lra_reg_info[i].actual_call_used_reg_set);
lra_reg_info[i].preferred_hard_regno1 = -1;
lra_reg_info[i].preferred_hard_regno2 = -1;
lra_reg_info[i].preferred_hard_regno_profit1 = 0;
@@ -2345,18 +2344,7 @@ lra (FILE *f)
lra_eliminate (false, false);
/* Do inheritance only for regular algorithms. */
if (! lra_simple_p)
- {
- if (flag_use_caller_save)
- {
- if (live_p)
- lra_clear_live_ranges ();
- /* As a side-effect of lra_create_live_ranges, we calculate
- actual_call_used_reg_set, which is needed during
- lra_inheritance. */
- lra_create_live_ranges (true);
- }
- lra_inheritance ();
- }
+ lra_inheritance ();
if (live_p)
lra_clear_live_ranges ();
/* We need live ranges for lra_assign -- so build them. */