aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Kenner <kenner@gcc.gnu.org>1994-06-16 18:54:00 -0400
committerRichard Kenner <kenner@gcc.gnu.org>1994-06-16 18:54:00 -0400
commit224f1d7123164a8c7ed9f313320b464c468b8b18 (patch)
treea92d924535e2b5a0b6f0ffdcee76bd5595afd98d
parent787e63c8f337d23db7c6d162ed4413403274544e (diff)
downloadgcc-224f1d7123164a8c7ed9f313320b464c468b8b18.zip
gcc-224f1d7123164a8c7ed9f313320b464c468b8b18.tar.gz
gcc-224f1d7123164a8c7ed9f313320b464c468b8b18.tar.bz2
(reload_reg_free_p, case RELOAD_OTHER): Allowed to conflict with
RELOAD_FOR_OTHER_ADDRESS. From-SVN: r7505
-rw-r--r--gcc/reload1.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/gcc/reload1.c b/gcc/reload1.c
index 6de6b1d..11e0a1b 100644
--- a/gcc/reload1.c
+++ b/gcc/reload1.c
@@ -4156,10 +4156,22 @@ reload_reg_free_p (regno, opnum, type)
switch (type)
{
case RELOAD_OTHER:
- /* In use for anything means not available for a RELOAD_OTHER. */
- return ! TEST_HARD_REG_BIT (reload_reg_used_at_all, regno);
+ /* In use for anything except RELOAD_FOR_OTHER_ADDRESS means
+ we can't use it for RELOAD_OTHER. */
+ if (TEST_HARD_REG_BIT (reload_reg_used, regno)
+ || TEST_HARD_REG_BIT (reload_reg_used_in_op_addr, regno)
+ || TEST_HARD_REG_BIT (reload_reg_used_in_insn, regno))
+ return 0;
+
+ for (i = 0; i < reload_n_operands; i++)
+ if (TEST_HARD_REG_BIT (reload_reg_used_in_input_addr[i], regno)
+ || TEST_HARD_REG_BIT (reload_reg_used_in_output_addr[i], regno)
+ || TEST_HARD_REG_BIT (reload_reg_used_in_input[i], regno)
+ || TEST_HARD_REG_BIT (reload_reg_used_in_output[i], regno))
+ return 0;
+
+ return 1;
- /* The other kinds of use can sometimes share a register. */
case RELOAD_FOR_INPUT:
if (TEST_HARD_REG_BIT (reload_reg_used_in_insn, regno)
|| TEST_HARD_REG_BIT (reload_reg_used_in_op_addr, regno))