diff options
author | Richard Henderson <rth@redhat.com> | 2001-10-26 00:49:34 -0700 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2001-10-26 00:49:34 -0700 |
commit | 108c1afce2b7b55375940b42e3779b76c6c24a1f (patch) | |
tree | 217b3b458beea6cff0af2f1de2339e47d5bc476d /gcc/cfg.c | |
parent | 4992fc7ff58e9c9938717fa503b9c2ec5de097a6 (diff) | |
download | gcc-108c1afce2b7b55375940b42e3779b76c6c24a1f.zip gcc-108c1afce2b7b55375940b42e3779b76c6c24a1f.tar.gz gcc-108c1afce2b7b55375940b42e3779b76c6c24a1f.tar.bz2 |
cfg.c (clear_aux_for_blocks): Split out of ...
* cfg.c (clear_aux_for_blocks): Split out of ...
(free_aux_for_blocks): here.
(clear_aux_for_edges): Split from ...
(free_aux_for_edges): here.
* basic-block.h: Declare them.
* lcm.c (compute_antinout_edge): Use them.
(compute_laterin, compute_available, compute_nearerout): Likewise.
(optimize_mode_switching): Likewise.
From-SVN: r46534
Diffstat (limited to 'gcc/cfg.c')
-rw-r--r-- | gcc/cfg.c | 42 |
1 files changed, 30 insertions, 12 deletions
@@ -618,22 +618,31 @@ alloc_aux_for_blocks (size) } } -/* Free data allocated in block_aux_obstack and clear AUX pointers - of all blocks. */ +/* Clear AUX pointers of all blocks. */ void -free_aux_for_blocks () +clear_aux_for_blocks () { int i; - if (!first_block_aux_obj) - abort (); - obstack_free (&block_aux_obstack, first_block_aux_obj); for (i = 0; i < n_basic_blocks; i++) BASIC_BLOCK (i)->aux = NULL; ENTRY_BLOCK_PTR->aux = NULL; EXIT_BLOCK_PTR->aux = NULL; +} + +/* Free data allocated in block_aux_obstack and clear AUX pointers + of all blocks. */ + +void +free_aux_for_blocks () +{ + if (!first_block_aux_obj) + abort (); + obstack_free (&block_aux_obstack, first_block_aux_obj); first_block_aux_obj = NULL; + + clear_aux_for_blocks (); } /* Allocate an memory edge of SIZE as BB->aux. The obstack must @@ -687,17 +696,13 @@ alloc_aux_for_edges (size) } } -/* Free data allocated in edge_aux_obstack and clear AUX pointers - of all edges. */ +/* Clear AUX pointers of all edges. */ void -free_aux_for_edges () +clear_aux_for_edges () { int i; - if (!first_edge_aux_obj) - abort (); - obstack_free (&edge_aux_obstack, first_edge_aux_obj); for (i = -1; i < n_basic_blocks; i++) { basic_block bb; @@ -710,5 +715,18 @@ free_aux_for_edges () for (e = bb->succ; e; e = e->succ_next) e->aux = NULL; } +} + +/* Free data allocated in edge_aux_obstack and clear AUX pointers + of all edges. */ + +void +free_aux_for_edges () +{ + if (!first_edge_aux_obj) + abort (); + obstack_free (&edge_aux_obstack, first_edge_aux_obj); first_edge_aux_obj = NULL; + + clear_aux_for_edges (); } |