diff options
author | Herman A.J. ten Brugge <Haj.Ten.Brugge@net.HCC.nl> | 2002-01-12 02:43:51 +0100 |
---|---|---|
committer | Michael Hayes <m.hayes@gcc.gnu.org> | 2002-01-12 01:43:51 +0000 |
commit | cf11ac5596a2a5f7ebb0f8269e45aac2f85954df (patch) | |
tree | 17b74d6c0d2b8115708bd51066642a01bb9cafd5 | |
parent | 41fcea287cbf2b275470524cbf8fdd82bb071c48 (diff) | |
download | gcc-cf11ac5596a2a5f7ebb0f8269e45aac2f85954df.zip gcc-cf11ac5596a2a5f7ebb0f8269e45aac2f85954df.tar.gz gcc-cf11ac5596a2a5f7ebb0f8269e45aac2f85954df.tar.bz2 |
global.c (find_reg): Check for HARD_REGNO_CALL_PART_CLOBBERED every where we allocate a register.
* global.c (find_reg): Check for HARD_REGNO_CALL_PART_CLOBBERED
every where we allocate a register.
From-SVN: r48791
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/global.c | 9 |
2 files changed, 14 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b3612e7..0046e6e 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2002-01-12 Herman A.J. ten Brugge <Haj.Ten.Brugge@net.HCC.nl> + + * global.c (find_reg): Check for HARD_REGNO_CALL_PART_CLOBBERED + every where we allocate a register. + 2002-01-12 Michael Hayes <m.hayes@elec.canterbury.ac.nz> * gcse.c (compute_pre_data, pre_gcse): Use sbitmap_free. diff --git a/gcc/global.c b/gcc/global.c index 99f54ca..0d9618c 100644 --- a/gcc/global.c +++ b/gcc/global.c @@ -1086,6 +1086,9 @@ find_reg (num, losers, alt_regs_p, accept_call_clobbered, retrying) for (i = 0; i < FIRST_PSEUDO_REGISTER; i++) if (TEST_HARD_REG_BIT (allocno[num].hard_reg_copy_preferences, i) && HARD_REGNO_MODE_OK (i, mode) + && (allocno[num].calls_crossed == 0 + || accept_call_clobbered + || ! HARD_REGNO_CALL_PART_CLOBBERED (i, mode)) && (REGNO_REG_CLASS (i) == REGNO_REG_CLASS (best_reg) || reg_class_subset_p (REGNO_REG_CLASS (i), REGNO_REG_CLASS (best_reg)) @@ -1122,6 +1125,9 @@ find_reg (num, losers, alt_regs_p, accept_call_clobbered, retrying) for (i = 0; i < FIRST_PSEUDO_REGISTER; i++) if (TEST_HARD_REG_BIT (allocno[num].hard_reg_preferences, i) && HARD_REGNO_MODE_OK (i, mode) + && (allocno[num].calls_crossed == 0 + || accept_call_clobbered + || ! HARD_REGNO_CALL_PART_CLOBBERED (i, mode)) && (REGNO_REG_CLASS (i) == REGNO_REG_CLASS (best_reg) || reg_class_subset_p (REGNO_REG_CLASS (i), REGNO_REG_CLASS (best_reg)) @@ -1202,6 +1208,9 @@ find_reg (num, losers, alt_regs_p, accept_call_clobbered, retrying) /* Don't use a reg no good for this pseudo. */ && ! TEST_HARD_REG_BIT (used2, regno) && HARD_REGNO_MODE_OK (regno, mode) + && (allocno[num].calls_crossed == 0 + || accept_call_clobbered + || ! HARD_REGNO_CALL_PART_CLOBBERED (regno, mode)) #ifdef CLASS_CANNOT_CHANGE_MODE && ! (REG_CHANGES_MODE (allocno[num].reg) && (TEST_HARD_REG_BIT |