> Hi,
> 
> IPA-CP transformation summary streaming code currently won't stream
> out transformations necessary for clones which are only necessary for
> materialization of other clones (such as an IPA-CP clone which is then
> cloned again by IPA-SRA).  However, a follow-up patch for bettor
> reconciling IPA-SRA and IPA-CP modifications requires to have that
> information at its disposal and so this one reworks the streaming to
> write out all non-empty transformation summaries.
> 
> This should actually mean less streaming in typical case because
> previously we streamed three zeros for all nodes in a partition with
> no useful information associated with them.  Currently we don't stream
> anything for those.
> 
> When reworking the streaming, I also simplified it a little a
> converted it writing to nicer C++ vector iterations.
> 
> Bootstrapped and tested on x86_64-linux.  OK for master?
> 
> Thanks,
> 
> Martin
> 
> 
> gcc/ChangeLog:
> 
> 2022-11-11  Martin Jambor  <mjam...@suse.cz>
> 
>       * ipa-prop.cc (useful_ipcp_transformation_info_p): New function.
>       (write_ipcp_transformation_info): Added a parameter, simplified
>       given that is known not to be NULL.
>       (ipcp_write_transformation_summaries): Write out all useful
>       transformation summaries.
>       (read_ipcp_transformation_info): Simplify given that some info
>       will be read.
>       (read_replacements_section): Remove assert.
> ---
>  gcc/ipa-prop.cc | 151 +++++++++++++++++++++++-------------------------
>  1 file changed, 71 insertions(+), 80 deletions(-)
> 
> diff --git a/gcc/ipa-prop.cc b/gcc/ipa-prop.cc
> index e6cf25591b3..cfd12a97b36 100644
> --- a/gcc/ipa-prop.cc
> +++ b/gcc/ipa-prop.cc
> @@ -5279,80 +5279,72 @@ ipa_prop_read_jump_functions (void)
>      }
>  }
>  
> -void
> -write_ipcp_transformation_info (output_block *ob, cgraph_node *node)
> +/* Return true if the IPA-CP transformation summary TS is non-NULL and 
> contains
> +   useful info.  */
> +static bool
> +useful_ipcp_transformation_info_p (ipcp_transformation *ts)
>  {
> -  int node_ref;
> -  unsigned int count = 0;
> -  lto_symtab_encoder_t encoder;
> +  if (!ts)
> +    return false;
> +  if (!vec_safe_is_empty (ts->m_agg_values)
> +      || !vec_safe_is_empty (ts->bits)
> +      || !vec_safe_is_empty (ts->m_vr))
> +    return true;
> +  return false;
> +}

This way we stream transformation info for everything in the boundary.
Even for functions that belongs to other partitions and they are called
from current partition.  Perhaps we want to check that the function has
body streamed?

Also would be possible to make a testcase? I think it should be possible
to use -flto-partition=max and builtin_constant_p checks verifying that
intended transformation happens.

Honza

Reply via email to