From: Jason Ekstrand Date: Thu, 9 May 2019 18:51:03 +0000 (-0500) Subject: util/ra: Only update best_optimistic_node if !progress X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=9d6d1f47e784df5941412f1e7f8946c65cb55c8d;p=mesa.git util/ra: Only update best_optimistic_node if !progress This shaves about half a second off the 30 second compile time of one of the compute shaders in Aztec ruins. Reviewed-by: Eric Anholt --- diff --git a/src/util/register_allocate.c b/src/util/register_allocate.c index 727c0c205fe..9493f578dba 100644 --- a/src/util/register_allocate.c +++ b/src/util/register_allocate.c @@ -524,7 +524,11 @@ ra_simplify(struct ra_graph *g) g->stack_count++; BITSET_SET(g->in_stack, i); progress = true; - } else { + } else if (!progress) { + /* We only need to do this if we haven't made progress. If we + * have made progress, we'll throw the data away and loop again + * anyway. + */ unsigned int new_q_total = g->nodes[i].q_total; if (new_q_total < lowest_q_total) { best_optimistic_node = i;