middle-end/98638 - avoid SSA reference to stmts after SSA deconstruction
authorRichard Biener <rguenther@suse.de>
Tue, 19 Jan 2021 12:40:39 +0000 (13:40 +0100)
committerRichard Biener <rguenther@suse.de>
Tue, 19 Jan 2021 13:32:14 +0000 (14:32 +0100)
Since SSA names do leak into global tree data structures like
TYPE_SIZE or in this case GFC_DECL_SAVED_DESCRIPTOR because of
frontend bugs we have to be careful to wipe references to the
CFG when we deconstruct SSA form because we now do ggc_free that.

2021-01-19  Richard Biener  <rguenther@suse.de>

PR middle-end/98638
* tree-ssanames.c (fini_ssanames): Zero SSA_NAME_DEF_STMT.

gcc/tree-ssanames.c

index c293cc44189956aecf82116e810d5db407118de6..51a26d2fce1c25b1557b3adfc585383eb515a023 100644 (file)
@@ -102,6 +102,14 @@ init_ssanames (struct function *fn, int size)
 void
 fini_ssanames (struct function *fn)
 {
+  unsigned i;
+  tree name;
+  /* Some SSA names leak into global tree data structures so we can't simply
+     ggc_free them.  But make sure to clear references to stmts since we now
+     ggc_free the CFG itself.  */
+  FOR_EACH_VEC_SAFE_ELT (SSANAMES (fn), i, name)
+    if (name)
+      SSA_NAME_DEF_STMT (name) = NULL;
   vec_free (SSANAMES (fn));
   vec_free (FREE_SSANAMES (fn));
   vec_free (FREE_SSANAMES_QUEUE (fn));