diff options
author | crowl <crowl@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-10-30 00:02:55 +0000 |
---|---|---|
committer | crowl <crowl@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-10-30 00:02:55 +0000 |
commit | 53c5d9d4909405a1f98efd0f06266b77a6057b5e (patch) | |
tree | 1ab800d2373b19aaee52a26a91b2c67b2657101e /gcc/bt-load.c | |
parent | 8b447d3f4f8509f90a13d4aa2fd435b84ff517f4 (diff) | |
download | gcc-53c5d9d4909405a1f98efd0f06266b77a6057b5e.tar.gz |
This patch implements the unification of the *bitmap interfaces as discussed.
Essentially, we rename ebitmap and sbitmap functions to use the same names
as the bitmap functions. This rename works because we can now overload
on the bitmap type. Some macros now become inline functions to enable
that overloading.
The sbitmap non-bool returning bitwise operations have been merged with
the bool versions. Sometimes this merge involved modifying the non-bool
version to compute the bool value, and sometimes modifying bool version to
add additional work from the non-bool version. The redundant routines have
been removed.
The allocation functions have not been renamed, because we often do not
have an argument on which to overload. The cardinality functions have not
been renamed, because they have different parameters, and are thus not
interchangable. The iteration functions have not been renamed, because
they are functionally different.
Tested on x86_64, contrib/config-list.mk testing passed.
Index: gcc/ChangeLog
2012-10-29 Lawrence Crowl <crowl@google.com>
* sbitmap.h (sbitmap_copy): Rename bitmap_copy.
(sbitmap_copy_n): Rename bitmap_copy_n.
(sbitmap_equal): Rename bitmap_equal_p.
(sbitmap_empty_p): Rename bitmap_empty_p.
(sbitmap_range_empty_p): Rename bitmap_range_empty_p.
(sbitmap_zero): Rename bitmap_clear.
(sbitmap_ones): Rename bitmap_ones.
(sbitmap_vector_zero): Rename bitmap_vector_clear.
(sbitmap_vector_ones): Rename bitmap_vector_ones.
(sbitmap_not): Rename bitmap_not.
(sbitmap_a_and_b_cg): Commented out.
(sbitmap_a_and_b): Rename bitmap_and. Add bool return.
(sbitmap_difference): Rename bitmap_and_compl.
(sbitmap_a_or_b_cg): Commented out.
(sbitmap_a_or_b): Rename bitmap_xor. Add bool return.
(sbitmap_a_xor_b_cg): Commented out.
(sbitmap_a_xor_b): Rename bitmap_xor. Add bool return.
(sbitmap_a_and_b_or_c_cg): Rename bitmap_and_or.
(sbitmap_a_and_b_or_c): Commented out.
(sbitmap_a_or_b_and_c_cg): Rename bitmap_or_and.
(sbitmap_a_or_b_and_c): Commented out.
(sbitmap_union_of_diff_cg): Rename bitmap_ior_and_compl.
(sbitmap_union_of_diff): Commented out.
(dump_sbitmap): Rename dump_bitmap.
(dump_sbitmap_file): Rename dump_bitmap_file.
(debug_sbitmap): Rename debug_bitmap.
(dump_sbitmap_vector): Rename dump_bitmap_vector.
(sbitmap_first_set_bit): Rename bitmap_first_set_bit.
(sbitmap_last_set_bit): Rename bitmap_last_set_bit.
(sbitmap_a_subset_b_p): Rename bitmap_subset_p.
(sbitmap_any_common_bits): Rename bitmap_intersect_p.
(#define sbitmap_free): Reimplement as inline function.
(#define sbitmap_vector_free): Reimplement as inline function.
* bitmap.h (#define bitmap_zero): Remove as redundant.
(#define bitmap_empty_p): Reimplement as inline function.
(#define dump_bitmap): Reimplement as inline function.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@192969 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/bt-load.c')
-rw-r--r-- | gcc/bt-load.c | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/gcc/bt-load.c b/gcc/bt-load.c index 385bc6c45ac..2aeb1c0f023 100644 --- a/gcc/bt-load.c +++ b/gcc/bt-load.c @@ -436,7 +436,7 @@ note_btr_set (rtx dest, const_rtx set ATTRIBUTE_UNUSED, void *data) note_other_use_this_block (regno, info->users_this_bb); SET_HARD_REG_BIT (info->btrs_written_in_block, regno); SET_HARD_REG_BIT (info->btrs_live_in_block, regno); - sbitmap_difference (info->bb_gen, info->bb_gen, + bitmap_and_compl (info->bb_gen, info->bb_gen, info->btr_defset[regno - first_btr]); } } @@ -457,7 +457,7 @@ compute_defs_uses_and_gen (fibheap_t all_btr_defs, btr_def *def_array, btr_def_group all_btr_def_groups = NULL; defs_uses_info info; - sbitmap_vector_zero (bb_gen, last_basic_block); + bitmap_vector_clear (bb_gen, last_basic_block); for (i = NUM_FIXED_BLOCKS; i < last_basic_block; i++) { basic_block bb = BASIC_BLOCK (i); @@ -497,7 +497,7 @@ compute_defs_uses_and_gen (fibheap_t all_btr_defs, btr_def *def_array, def_array[insn_uid] = def; SET_HARD_REG_BIT (info.btrs_written_in_block, regno); SET_HARD_REG_BIT (info.btrs_live_in_block, regno); - sbitmap_difference (bb_gen[i], bb_gen[i], + bitmap_and_compl (bb_gen[i], bb_gen[i], btr_defset[regno - first_btr]); SET_BIT (bb_gen[i], insn_uid); def->next_this_bb = defs_this_bb; @@ -519,7 +519,7 @@ compute_defs_uses_and_gen (fibheap_t all_btr_defs, btr_def *def_array, user->other_use_this_block = 1; IOR_HARD_REG_SET (info.btrs_written_in_block, all_btrs); IOR_HARD_REG_SET (info.btrs_live_in_block, all_btrs); - sbitmap_zero (info.bb_gen); + bitmap_clear (info.bb_gen); } else { @@ -618,13 +618,13 @@ compute_kill (sbitmap *bb_kill, sbitmap *btr_defset, /* For each basic block, form the set BB_KILL - the set of definitions that the block kills. */ - sbitmap_vector_zero (bb_kill, last_basic_block); + bitmap_vector_clear (bb_kill, last_basic_block); for (i = NUM_FIXED_BLOCKS; i < last_basic_block; i++) { for (regno = first_btr; regno <= last_btr; regno++) if (TEST_HARD_REG_BIT (all_btrs, regno) && TEST_HARD_REG_BIT (btrs_written[i], regno)) - sbitmap_a_or_b (bb_kill[i], bb_kill[i], + bitmap_ior (bb_kill[i], bb_kill[i], btr_defset[regno - first_btr]); } } @@ -643,7 +643,7 @@ compute_out (sbitmap *bb_out, sbitmap *bb_gen, sbitmap *bb_kill, int max_uid) sbitmap bb_in = sbitmap_alloc (max_uid); for (i = NUM_FIXED_BLOCKS; i < last_basic_block; i++) - sbitmap_copy (bb_out[i], bb_gen[i]); + bitmap_copy (bb_out[i], bb_gen[i]); changed = 1; while (changed) @@ -652,7 +652,7 @@ compute_out (sbitmap *bb_out, sbitmap *bb_gen, sbitmap *bb_kill, int max_uid) for (i = NUM_FIXED_BLOCKS; i < last_basic_block; i++) { sbitmap_union_of_preds (bb_in, bb_out, BASIC_BLOCK (i)); - changed |= sbitmap_union_of_diff_cg (bb_out[i], bb_gen[i], + changed |= bitmap_ior_and_compl (bb_out[i], bb_gen[i], bb_in, bb_kill[i]); } } @@ -689,7 +689,7 @@ link_btr_uses (btr_def *def_array, btr_user *use_array, sbitmap *bb_out, { /* Remove all reaching defs of regno except for this one. */ - sbitmap_difference (reaching_defs, reaching_defs, + bitmap_and_compl (reaching_defs, reaching_defs, btr_defset[def->btr - first_btr]); SET_BIT(reaching_defs, insn_uid); } @@ -702,7 +702,7 @@ link_btr_uses (btr_def *def_array, btr_user *use_array, sbitmap *bb_out, sbitmap_iterator sbi; if (user->use) - sbitmap_a_and_b ( + bitmap_and ( reaching_defs_of_reg, reaching_defs, btr_defset[REGNO (user->use) - first_btr]); @@ -710,12 +710,12 @@ link_btr_uses (btr_def *def_array, btr_user *use_array, sbitmap *bb_out, { int reg; - sbitmap_zero (reaching_defs_of_reg); + bitmap_clear (reaching_defs_of_reg); for (reg = first_btr; reg <= last_btr; reg++) if (TEST_HARD_REG_BIT (all_btrs, reg) && refers_to_regno_p (reg, reg + 1, user->insn, NULL)) - sbitmap_a_or_b_and_c (reaching_defs_of_reg, + bitmap_or_and (reaching_defs_of_reg, reaching_defs_of_reg, reaching_defs, btr_defset[reg - first_btr]); @@ -763,7 +763,7 @@ link_btr_uses (btr_def *def_array, btr_user *use_array, sbitmap *bb_out, for (regno = first_btr; regno <= last_btr; regno++) if (TEST_HARD_REG_BIT (all_btrs, regno) && TEST_HARD_REG_BIT (call_used_reg_set, regno)) - sbitmap_difference (reaching_defs, reaching_defs, + bitmap_and_compl (reaching_defs, reaching_defs, btr_defset[regno - first_btr]); } } @@ -785,7 +785,7 @@ build_btr_def_use_webs (fibheap_t all_btr_defs) sbitmap *bb_kill; sbitmap *bb_out; - sbitmap_vector_zero (btr_defset, (last_btr - first_btr) + 1); + bitmap_vector_clear (btr_defset, (last_btr - first_btr) + 1); compute_defs_uses_and_gen (all_btr_defs, def_array, use_array, btr_defset, bb_gen, btrs_written); |