aboutsummaryrefslogtreecommitdiff
path: root/gcc/var-tracking.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2010-03-30 22:16:52 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2010-03-30 22:16:52 +0200
commit03a5f060b9bdcf4520645cb4e6c15297e3eea060 (patch)
tree62931f856516f4b4de948b98b3788cef3bad0e7d /gcc/var-tracking.c
parent8533c9d8ac498572eec1978b30860b487e47ade3 (diff)
downloadgcc-03a5f060b9bdcf4520645cb4e6c15297e3eea060.zip
gcc-03a5f060b9bdcf4520645cb4e6c15297e3eea060.tar.gz
gcc-03a5f060b9bdcf4520645cb4e6c15297e3eea060.tar.bz2
re PR debug/43593 (Var-tracking unnecessarily flushes all call used registers on calls instead of regs invalidated by call)
PR debug/43593 * var-tracking.c (dataflow_set_clear_at_call): Invalidate just regs_invalidated_by_call instead all call_used_reg_set registers. * gcc.dg/guality/pr43593.c: New test. From-SVN: r157834
Diffstat (limited to 'gcc/var-tracking.c')
-rw-r--r--gcc/var-tracking.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/var-tracking.c b/gcc/var-tracking.c
index bff7d11..e0f7229 100644
--- a/gcc/var-tracking.c
+++ b/gcc/var-tracking.c
@@ -4170,7 +4170,7 @@ dataflow_set_clear_at_call (dataflow_set *set)
int r;
for (r = 0; r < FIRST_PSEUDO_REGISTER; r++)
- if (TEST_HARD_REG_BIT (call_used_reg_set, r))
+ if (TEST_HARD_REG_BIT (regs_invalidated_by_call, r))
var_regno_delete (set, r);
if (MAY_HAVE_DEBUG_INSNS)