aboutsummaryrefslogtreecommitdiff
path: root/gcc/ipa-modref.c
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2021-12-19 22:28:40 +0100
committerJan Hubicka <jh@suse.cz>2021-12-19 22:29:37 +0100
commitfcbf94a5be9e0c1ecad92da773a6632b86b7f70a (patch)
tree1775368cdffcfc72564f6eebef9312b8cd0c86ea /gcc/ipa-modref.c
parent6bcb6ed5a44b6f271891246ef7ae568bfdc14e9c (diff)
downloadgcc-fcbf94a5be9e0c1ecad92da773a6632b86b7f70a.zip
gcc-fcbf94a5be9e0c1ecad92da773a6632b86b7f70a.tar.gz
gcc-fcbf94a5be9e0c1ecad92da773a6632b86b7f70a.tar.bz2
Fix early exit in modref_merge_call_site_flags
When adding support for static chain and return slot flags I forgot to update early exit condition in modref_merge_call_site_flags. This yields to wrong code as demonstrated by the Fortran testcase attached to PR (which I hope someone will help me to turn into testuite one). gcc/ChangeLog: 2021-12-19 Jan Hubicka <hubicka@ucw.cz> PR ipa/103766 * ipa-modref.c (modref_merge_call_site_flags): Fix early exit condition
Diffstat (limited to 'gcc/ipa-modref.c')
-rw-r--r--gcc/ipa-modref.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/gcc/ipa-modref.c b/gcc/ipa-modref.c
index d3590f0..9c411a6 100644
--- a/gcc/ipa-modref.c
+++ b/gcc/ipa-modref.c
@@ -5019,9 +5019,15 @@ modref_merge_call_site_flags (escape_summary *sum,
bool changed = false;
bool ignore_stores = ignore_stores_p (caller, callee_ecf_flags);
- /* If we have no useful info to propagate. */
- if ((!cur_summary || !cur_summary->arg_flags.length ())
- && (!cur_summary_lto || !cur_summary_lto->arg_flags.length ()))
+ /* Return early if we have no useful info to propagate. */
+ if ((!cur_summary
+ || (!cur_summary->arg_flags.length ()
+ && !cur_summary->static_chain_flags
+ && !cur_summary->retslot_flags))
+ && (!cur_summary_lto
+ || (!cur_summary_lto->arg_flags.length ()
+ && !cur_summary_lto->static_chain_flags
+ && !cur_summary_lto->retslot_flags)))
return false;
FOR_EACH_VEC_ELT (sum->esc, i, ee)