From f145fac4afd9586470a3337fe49279ad4a289b33 Mon Sep 17 00:00:00 2001 From: jakub Date: Mon, 10 May 2010 18:28:03 +0000 Subject: PR debug/44028 * haifa-sched.c (schedule_insn): When clearing INSN_VAR_LOCATION_LOC, clear also INSN_REG_USE_LIST. * gcc.dg/pr44028.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@159240 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/haifa-sched.c | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'gcc/haifa-sched.c') diff --git a/gcc/haifa-sched.c b/gcc/haifa-sched.c index b7f0cfce359..0dd220d7302 100644 --- a/gcc/haifa-sched.c +++ b/gcc/haifa-sched.c @@ -1695,6 +1695,7 @@ schedule_insn (rtx insn) sd_iterator_cond (&sd_it, &dep);) { rtx dbg = DEP_PRO (dep); + struct reg_use_data *use, *next; gcc_assert (DEBUG_INSN_P (dbg)); @@ -1716,6 +1717,14 @@ schedule_insn (rtx insn) INSN_VAR_LOCATION_LOC (dbg) = gen_rtx_UNKNOWN_VAR_LOC (); df_insn_rescan (dbg); + /* Unknown location doesn't use any registers. */ + for (use = INSN_REG_USE_LIST (dbg); use != NULL; use = next) + { + next = use->next_insn_use; + free (use); + } + INSN_REG_USE_LIST (dbg) = NULL; + /* We delete rather than resolve these deps, otherwise we crash in sched_free_deps(), because forward deps are expected to be released before backward deps. */ -- cgit v1.2.1