diff options
author | Richard Henderson <rth@cygnus.com> | 2000-04-08 15:38:38 -0700 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2000-04-08 15:38:38 -0700 |
commit | 729a7089845f57ffa7067612f8d5b059149eeae6 (patch) | |
tree | 1dc05b7313adaea608af4537317eb2bb4ccbba58 | |
parent | 83ffeecd1d9356db6935136e4e9a20ab714afb11 (diff) | |
download | gcc-729a7089845f57ffa7067612f8d5b059149eeae6.zip gcc-729a7089845f57ffa7067612f8d5b059149eeae6.tar.gz gcc-729a7089845f57ffa7067612f8d5b059149eeae6.tar.bz2 |
flow.c (mark_used_reg): Use reg_set_p to determine if a register was modified in the current insn.
* flow.c (mark_used_reg): Use reg_set_p to determine if a register
was modified in the current insn.
From-SVN: r33030
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/flow.c | 8 |
2 files changed, 12 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8719454..97c0cfa 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-04-08 Richard Henderson <rth@cygnus.com> + + * flow.c (mark_used_reg): Use reg_set_p to determine if a register + was modified in the current insn. + 2000-04-08 Richard Earnshaw (rearnsha@arm.com) * arm/thumb.md: Delete. @@ -4520,11 +4520,17 @@ mark_used_reg (pbi, new_live, reg, cond, insn) /* Record and count the insns in which a reg dies. If it is used in this insn and was dead below the insn then it dies in this insn. + If it was set in this insn, we do not make a REG_DEAD note; - likewise if we already made such a note. */ + likewise if we already made such a note. Recall that dead_or_set_p + checks for complete overlap, and thus is not suitable for the first + case. But it does handle the existing note case. Also recall that + reg_set_p, when presented with the complete insn, will try to infer + things about a call_insn that we do not wish. */ if ((pbi->flags & PROP_DEATH_NOTES) && some_was_dead + && ! reg_set_p (reg, PATTERN (insn)) && ! dead_or_set_p (insn, reg)) { int n; |