From 1394066b3d1ae4aa7cfac87c4ccbd5cb9d46097b Mon Sep 17 00:00:00 2001 From: marxin Date: Mon, 1 Jun 2015 12:38:23 +0000 Subject: [PATCH] Change use to type-based pool allocator in cfg.c. * cfg.c (initialize_original_copy_tables):Use new type-based pool allocator. (free_original_copy_tables) Likewise. (copy_original_table_clear) Likewise. (copy_original_table_set) Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@223950 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 7 +++++++ gcc/cfg.c | 17 +++++++---------- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e1bdc4e..ef7e40a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,12 @@ 2015-06-01 Martin Liska + * cfg.c (initialize_original_copy_tables):Use new type-based pool allocator. + (free_original_copy_tables) Likewise. + (copy_original_table_clear) Likewise. + (copy_original_table_set) Likewise. + +2015-06-01 Martin Liska + * asan.c (asan_mem_ref_get_alloc_pool):Use new type-based pool allocator. (asan_mem_ref_new) Likewise. (free_mem_ref_resources) Likewise. diff --git a/gcc/cfg.c b/gcc/cfg.c index cdcc01c..ddfecdc 100644 --- a/gcc/cfg.c +++ b/gcc/cfg.c @@ -1066,18 +1066,16 @@ static hash_table *bb_copy; /* And between loops and copies. */ static hash_table *loop_copy; -static alloc_pool original_copy_bb_pool; - +static pool_allocator *original_copy_bb_pool; /* Initialize the data structures to maintain mapping between blocks and its copies. */ void initialize_original_copy_tables (void) { - gcc_assert (!original_copy_bb_pool); - original_copy_bb_pool - = create_alloc_pool ("original_copy", - sizeof (struct htab_bb_copy_original_entry), 10); + + original_copy_bb_pool = new pool_allocator + ("original_copy", 10); bb_original = new hash_table (10); bb_copy = new hash_table (10); loop_copy = new hash_table (10); @@ -1095,7 +1093,7 @@ free_original_copy_tables (void) bb_copy = NULL; delete loop_copy; loop_copy = NULL; - free_alloc_pool (original_copy_bb_pool); + delete original_copy_bb_pool; original_copy_bb_pool = NULL; } @@ -1117,7 +1115,7 @@ copy_original_table_clear (hash_table *tab, unsigned obj) elt = *slot; tab->clear_slot (slot); - pool_free (original_copy_bb_pool, elt); + original_copy_bb_pool->remove (elt); } /* Sets the value associated with OBJ in table TAB to VAL. @@ -1137,8 +1135,7 @@ copy_original_table_set (hash_table *tab, slot = tab->find_slot (&key, INSERT); if (!*slot) { - *slot = (struct htab_bb_copy_original_entry *) - pool_alloc (original_copy_bb_pool); + *slot = original_copy_bb_pool->allocate (); (*slot)->index1 = obj; } (*slot)->index2 = val; -- 2.7.4