aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Liska <mliska@suse.cz>2021-01-11 18:12:54 +0100
committerMartin Liska <mliska@suse.cz>2021-04-21 20:09:19 +0200
commita63035ae262078cd70927b06a2bd3ee94cc6e56e (patch)
treef551312555ac203d328d5e0f3a1a3a29695bed39
parent95dfc3ac7baca19157bb976ee4c8c69753e1e178 (diff)
downloadgcc-a63035ae262078cd70927b06a2bd3ee94cc6e56e.zip
gcc-a63035ae262078cd70927b06a2bd3ee94cc6e56e.tar.gz
gcc-a63035ae262078cd70927b06a2bd3ee94cc6e56e.tar.bz2
Call toplev::finalize in CHECKING_P mode.
gcc/ChangeLog: PR jit/98615 * main.c (main): Call toplev::finalize in CHECKING_P mode. * ipa-modref.c (ipa_modref_c_finalize): summaries are NULL when incremental LTO linking happens.
-rw-r--r--gcc/ipa-modref.c3
-rw-r--r--gcc/main.c7
2 files changed, 8 insertions, 2 deletions
diff --git a/gcc/ipa-modref.c b/gcc/ipa-modref.c
index ef5e62b..e7f79ca 100644
--- a/gcc/ipa-modref.c
+++ b/gcc/ipa-modref.c
@@ -3867,7 +3867,8 @@ ipa_modref_c_finalize ()
if (optimization_summaries)
ggc_delete (optimization_summaries);
optimization_summaries = NULL;
- gcc_checking_assert (!summaries);
+ gcc_checking_assert (!summaries
+ || flag_incremental_link == INCREMENTAL_LINK_LTO);
if (summaries_lto)
ggc_delete (summaries_lto);
summaries_lto = NULL;
diff --git a/gcc/main.c b/gcc/main.c
index ab0244b..093e639 100644
--- a/gcc/main.c
+++ b/gcc/main.c
@@ -36,5 +36,10 @@ main (int argc, char **argv)
toplev toplev (NULL, /* external_timer */
true /* init_signals */);
- return toplev.main (argc, argv);
+ int r = toplev.main (argc, argv);
+#if CHECKING_P
+ toplev.finalize ();
+#endif
+
+ return r;
}