diff options
author | Jakub Jelinek <jakub@gcc.gnu.org> | 2008-09-15 23:55:05 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2008-09-15 23:55:05 +0200 |
commit | a0044be570e23969f742d62d734ff3dc570af48b (patch) | |
tree | 3a80fb5ba141a335e30a28fc364cb58ee7216972 /gcc | |
parent | 8f57ac5a83dd534f7a2be8489b7dd04f6c68e8cf (diff) | |
download | gcc-a0044be570e23969f742d62d734ff3dc570af48b.zip gcc-a0044be570e23969f742d62d734ff3dc570af48b.tar.gz gcc-a0044be570e23969f742d62d734ff3dc570af48b.tar.bz2 |
tree-predcom.c (filter_suitable_components): Free all refs in act->refs vector before calling release_component.
* tree-predcom.c (filter_suitable_components): Free all refs in
act->refs vector before calling release_component.
(add_ref_to_chain): Free ref if not adding it to chain->refs.
* tree-data-ref.c (free_subscripts): Free all subscript objects.
* tree-loop-linear.c (linear_transform_loops): Initialize
lambda_obstack only after calling perfect_loop_nest_depth.
Goto free_and_continue instead of just continue for later failures.
From-SVN: r140376
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/tree-data-ref.c | 1 | ||||
-rw-r--r-- | gcc/tree-loop-linear.c | 6 | ||||
-rw-r--r-- | gcc/tree-predcom.c | 10 |
3 files changed, 13 insertions, 4 deletions
diff --git a/gcc/tree-data-ref.c b/gcc/tree-data-ref.c index 2be0ad1..5a52d26 100644 --- a/gcc/tree-data-ref.c +++ b/gcc/tree-data-ref.c @@ -1398,6 +1398,7 @@ free_subscripts (VEC (subscript_p, heap) *subscripts) { free_conflict_function (s->conflicting_iterations_in_a); free_conflict_function (s->conflicting_iterations_in_b); + free (s); } VEC_free (subscript_p, heap, subscripts); } diff --git a/gcc/tree-loop-linear.c b/gcc/tree-loop-linear.c index 7e5f298..a97433b 100644 --- a/gcc/tree-loop-linear.c +++ b/gcc/tree-loop-linear.c @@ -333,12 +333,12 @@ linear_transform_loops (void) lambda_loopnest before, after; lambda_trans_matrix trans; struct obstack lambda_obstack; - gcc_obstack_init (&lambda_obstack); depth = perfect_loop_nest_depth (loop_nest); if (depth == 0) continue; + gcc_obstack_init (&lambda_obstack); VEC_truncate (tree, oldivs, 0); VEC_truncate (tree, invariants, 0); VEC_truncate (tree, lambda_parameters, 0); @@ -347,12 +347,12 @@ linear_transform_loops (void) dependence_relations = VEC_alloc (ddr_p, heap, 10 * 10); if (!compute_data_dependences_for_loop (loop_nest, true, &datarefs, &dependence_relations)) - continue; + goto free_and_continue; lambda_collect_parameters (datarefs, &lambda_parameters); if (!lambda_compute_access_matrices (datarefs, lambda_parameters, loop_nest->num)) - continue; + goto free_and_continue; if (dump_file && (dump_flags & TDF_DETAILS)) dump_ddrs (dump_file, dependence_relations); diff --git a/gcc/tree-predcom.c b/gcc/tree-predcom.c index 85cfbd6..b6ccfd7 100644 --- a/gcc/tree-predcom.c +++ b/gcc/tree-predcom.c @@ -877,7 +877,12 @@ filter_suitable_components (struct loop *loop, struct component *comps) comp = &act->next; else { + dref ref; + unsigned i; + *comp = act->next; + for (i = 0; VEC_iterate (dref, act->refs, i, ref); i++) + free (ref); release_component (act); } } @@ -920,7 +925,10 @@ add_ref_to_chain (chain_p chain, dref ref) gcc_assert (double_int_scmp (root->offset, ref->offset) <= 0); dist = double_int_add (ref->offset, double_int_neg (root->offset)); if (double_int_ucmp (uhwi_to_double_int (MAX_DISTANCE), dist) <= 0) - return; + { + free (ref); + return; + } gcc_assert (double_int_fits_in_uhwi_p (dist)); VEC_safe_push (dref, heap, chain->refs, ref); |