[lra] patch to speed more compilation of PR54146

Vladimir Makarov vmakarov@redhat.com
Mon Oct 8 20:21:00 GMT 2012


On 10/08/2012 06:31 AM, Steven Bosscher wrote:
> On Sun, Oct 7, 2012 at 5:59 PM, Vladimir Makarov wrote:
>>          * lra-lives.c (lra_start_point_ranges, lra_finish_point_ranges):
>>          Remove.
>>          (process_bb_lives): Change start regno in
>>          EXECUTE_IF_SET_IN_BITMAP.  Iterate on DF_LR_IN (bb) instead of
>>          pseudos_live_through_calls.
> This can be done a bit better still by checking whether the
> pseudos_live_through_calls set is empty:
>
>          * lra-lives.c (process_bb_lives): At the top of a basic block, break
>          from the loop over pseudos_live_through_calls if the set is empty.
>
> --- lra-lives.c.orig   2012-10-08 12:24:10.000000000 +0200
> +++ lra-lives.c        2012-10-08 12:26:07.000000000 +0200
> @@ -751,8 +751,12 @@ process_bb_lives (basic_block bb)
>       mark_pseudo_dead (i);
>
>     EXECUTE_IF_SET_IN_BITMAP (DF_LR_IN (bb), FIRST_PSEUDO_REGISTER, j, bi)
> -    if (sparseset_bit_p (pseudos_live_through_calls, j))
> -      check_pseudos_live_through_calls (j);
> +    {
> +      if (sparseset_cardinality (pseudos_live_through_calls) == 0)
> +       break;
> +      if (sparseset_bit_p (pseudos_live_through_calls, j))
> +       check_pseudos_live_through_calls (j);
> +    }
>
>     incr_curr_point (freq);
>   }
>
>
> This test is extremely cheap (the load for the cardinality test
> re-used by sparseset_bit_p) and it cuts down the time spent in live
> range chains even further (especially e.g. for blocks that don't
> contain calls).
>
> OK for the branch if it passes bootstrap+testing on x86_64-unknown-linux-gnu?
>
>
Yes.  Thanks.



More information about the Gcc-patches mailing list