> Looks like the existing check using has_gimple_body_p isn't enough
> at LTRANS time but I need to check in_other_partition as well.
> 
> Bootstrapped on x86_64-unknown-linux-gnu, testing in progress.
> 
> OK?
> 
> Thanks,
> Richard.
> 
> 2021-08-23  Richard Biener  <rguent...@suse.de>
> 
>       PR ipa/97565
>       * tree-ssa-structalias.c (ipa_pta_execute): Check in_other_partition
>       in addition to has_gimple_body.
> 
>       * g++.dg/lto/pr97565_0.C: New testcase.
>       * g++.dg/lto/pr97565_1.C: Likewise.
OK,
thanks!

Honza
> ---
>  gcc/testsuite/g++.dg/lto/pr97565_0.C |  7 +++++++
>  gcc/testsuite/g++.dg/lto/pr97565_1.C |  6 ++++++
>  gcc/tree-ssa-structalias.c           | 22 ++++++++++++++--------
>  3 files changed, 27 insertions(+), 8 deletions(-)
>  create mode 100644 gcc/testsuite/g++.dg/lto/pr97565_0.C
>  create mode 100644 gcc/testsuite/g++.dg/lto/pr97565_1.C
> 
> diff --git a/gcc/testsuite/g++.dg/lto/pr97565_0.C 
> b/gcc/testsuite/g++.dg/lto/pr97565_0.C
> new file mode 100644
> index 00000000000..f4572e17bf5
> --- /dev/null
> +++ b/gcc/testsuite/g++.dg/lto/pr97565_0.C
> @@ -0,0 +1,7 @@
> +// { dg-lto-do link }
> +// { dg-lto-options { "-O -flto -fipa-pta" } }
> +
> +extern "C" void abort(void)
> +{
> +  abort();
> +}
> diff --git a/gcc/testsuite/g++.dg/lto/pr97565_1.C 
> b/gcc/testsuite/g++.dg/lto/pr97565_1.C
> new file mode 100644
> index 00000000000..ff7b638e9c5
> --- /dev/null
> +++ b/gcc/testsuite/g++.dg/lto/pr97565_1.C
> @@ -0,0 +1,6 @@
> +extern "C" void abort(void);
> +
> +int main(int argc, char * argv[])
> +{
> +  abort();
> +}
> diff --git a/gcc/tree-ssa-structalias.c b/gcc/tree-ssa-structalias.c
> index fb0e4299703..c4308551d1b 100644
> --- a/gcc/tree-ssa-structalias.c
> +++ b/gcc/tree-ssa-structalias.c
> @@ -8220,10 +8220,12 @@ ipa_pta_execute (void)
>    FOR_EACH_DEFINED_FUNCTION (node)
>      {
>        varinfo_t vi;
> -      /* Nodes without a body are not interesting.  Especially do not
> -         visit clones at this point for now - we get duplicate decls
> -      there for inline clones at least.  */
> -      if (!node->has_gimple_body_p () || node->inlined_to)
> +      /* Nodes without a body in this partition are not interesting.
> +      Especially do not visit clones at this point for now - we
> +      get duplicate decls there for inline clones at least.  */
> +      if (!node->has_gimple_body_p ()
> +       || node->in_other_partition
> +       || node->inlined_to)
>       continue;
>        node->get_body ();
>  
> @@ -8301,8 +8303,10 @@ ipa_pta_execute (void)
>        struct function *func;
>        basic_block bb;
>  
> -      /* Nodes without a body are not interesting.  */
> -      if (!node->has_gimple_body_p () || node->clone_of)
> +      /* Nodes without a body in this partition are not interesting.  */
> +      if (!node->has_gimple_body_p ()
> +       || node->in_other_partition
> +       || node->clone_of)
>       continue;
>  
>        if (dump_file)
> @@ -8431,8 +8435,10 @@ ipa_pta_execute (void)
>        unsigned i;
>        basic_block bb;
>  
> -      /* Nodes without a body are not interesting.  */
> -      if (!node->has_gimple_body_p () || node->clone_of)
> +      /* Nodes without a body in this partition are not interesting.  */
> +      if (!node->has_gimple_body_p ()
> +       || node->in_other_partition
> +       || node->clone_of)
>       continue;
>  
>        fn = DECL_STRUCT_FUNCTION (node->decl);
> -- 
> 2.31.1

Reply via email to