re PR middle-end/48270 (New test failures)
authorRichard Guenther <rguenther@suse.de>
Thu, 24 Mar 2011 14:39:36 +0000 (14:39 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Thu, 24 Mar 2011 14:39:36 +0000 (14:39 +0000)
2011-03-24  Richard Guenther  <rguenther@suse.de>

PR tree-optimization/48270
* tree-ssa-phiopt.c (cond_if_else_store_replacement): Do
not free datarefs before ddrs.

From-SVN: r171394

gcc/ChangeLog
gcc/tree-ssa-phiopt.c

index c2e1bf4f12f9f3a1a13085a9b80b75a83084537c..edf923cbea6b05ec7f9892d0f629920524f8fc30 100644 (file)
@@ -1,3 +1,9 @@
+2011-03-24  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/48270
+       * tree-ssa-phiopt.c (cond_if_else_store_replacement): Do
+       not free datarefs before ddrs.
+
 2011-03-24  Eric Botcazou  <ebotcazou@adacore.com>
 
        * tree-sra.c (build_ref_for_offset): Strip useless type conversions
index 77ce5b02f7baf75c195594959e51ce7e8035edb6..caea9ac723f399da2bf9488623ac91260be46dca 100644 (file)
@@ -1494,8 +1494,6 @@ cond_if_else_store_replacement (basic_block then_bb, basic_block else_bb,
   else_ddrs = VEC_alloc (ddr_p, heap, 1);
   compute_all_dependences (then_datarefs, &then_ddrs, NULL, false);
   compute_all_dependences (else_datarefs, &else_ddrs, NULL, false);
-  free_data_refs (then_datarefs);
-  free_data_refs (else_datarefs);
   blocks[0] = then_bb;
   blocks[1] = else_bb;
   blocks[2] = join_bb;
@@ -1517,6 +1515,8 @@ cond_if_else_store_replacement (basic_block then_bb, basic_block else_bb,
         {
           free_dependence_relations (then_ddrs);
           free_dependence_relations (else_ddrs);
+         free_data_refs (then_datarefs);
+         free_data_refs (else_datarefs);
           VEC_free (gimple, heap, then_stores);
           VEC_free (gimple, heap, else_stores);
           return false;
@@ -1539,6 +1539,8 @@ cond_if_else_store_replacement (basic_block then_bb, basic_block else_bb,
         {
           free_dependence_relations (then_ddrs);
           free_dependence_relations (else_ddrs);
+         free_data_refs (then_datarefs);
+         free_data_refs (else_datarefs);
           VEC_free (gimple, heap, then_stores);
           VEC_free (gimple, heap, else_stores);
           return false;
@@ -1556,6 +1558,8 @@ cond_if_else_store_replacement (basic_block then_bb, basic_block else_bb,
 
   free_dependence_relations (then_ddrs);
   free_dependence_relations (else_ddrs);
+  free_data_refs (then_datarefs);
+  free_data_refs (else_datarefs);
   VEC_free (gimple, heap, then_stores);
   VEC_free (gimple, heap, else_stores);