Commit 22414f3f by Alexandre Oliva Committed by Alexandre Oliva

re PR debug/59992 (Compilation of insn-recog.c too slow due to var-tracking)

PR debug/59992
* cselib.c (remove_useless_values): Skip to avoid quadratic
behavior if the condition moved from...
(cselib_process_insn): ... here holds.

From-SVN: r208220
parent 2e084917
2014-02-28 Alexandre Oliva <aoliva@redhat.com>
PR debug/59992
* cselib.c (remove_useless_values): Skip to avoid quadratic
behavior if the condition moved from...
(cselib_process_insn): ... here holds.
2014-02-28 Alexandre Oliva <aoliva@redhat.com>
PR debug/57232
* var-tracking.c (vt_initialize): Apply the same condition to
preserve the CFA base value.
......
......@@ -662,6 +662,14 @@ remove_useless_values (void)
{
cselib_val **p, *v;
if (n_useless_values <= MAX_USELESS_VALUES
/* remove_useless_values is linear in the hash table size. Avoid
quadratic behavior for very large hashtables with very few
useless elements. */
|| ((unsigned int)n_useless_values
<= (cselib_hash_table.elements () - n_debug_values) / 4))
return;
/* First pass: eliminate locations that reference the value. That in
turn can make more values useless. */
do
......@@ -2693,13 +2701,7 @@ cselib_process_insn (rtx insn)
cselib_current_insn = NULL_RTX;
if (n_useless_values > MAX_USELESS_VALUES
/* remove_useless_values is linear in the hash table size. Avoid
quadratic behavior for very large hashtables with very few
useless elements. */
&& ((unsigned int)n_useless_values
> (cselib_hash_table.elements () - n_debug_values) / 4))
remove_useless_values ();
remove_useless_values ();
}
/* Initialize cselib for one pass. The caller must also call
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment