diff options
author | bonzini <bonzini@138bc75d-0d04-0410-961f-82ee72b054a4> | 2009-02-06 07:33:05 +0000 |
---|---|---|
committer | bonzini <bonzini@138bc75d-0d04-0410-961f-82ee72b054a4> | 2009-02-06 07:33:05 +0000 |
commit | 3d2d7de7064f0629b185af2a221b499b108d4f7a (patch) | |
tree | 0a8d158aa9cc33fc558acdf02d5f054a85411376 /gcc/tree-ssa-pre.c | |
parent | 7e1e15cd09ff0d699019ffc06d51a7857e62940f (diff) | |
download | gcc-3d2d7de7064f0629b185af2a221b499b108d4f7a.tar.gz |
2009-02-06 Paolo Bonzini <bonzini@gnu.org>
PR tree-optimization/35659
* tree-ssa-sccvn.c (vn_constant_eq, vn_reference_eq, vn_nary_op_eq
vn_phi_eq): Shortcut if hashcode does not match.
(vn_reference_op_compute_hash): Do not call iterative_hash_expr for
NULL operands.
* tree-ssa-pre.c (pre_expr_hash): Look at hashcode if available,
and avoid iterative_hash_expr.
(FOR_EACH_VALUE_ID_IN_SET): New.
(value_id_compare): Remove.
(sorted_array_from_bitmap_set): Use FOR_EACH_VALUE_ID_IN_SET to
sort expressions by value id.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@143980 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-ssa-pre.c')
-rw-r--r-- | gcc/tree-ssa-pre.c | 48 |
1 files changed, 26 insertions, 22 deletions
diff --git a/gcc/tree-ssa-pre.c b/gcc/tree-ssa-pre.c index a3f91f07d58..32c557cc0fb 100644 --- a/gcc/tree-ssa-pre.c +++ b/gcc/tree-ssa-pre.c @@ -216,11 +216,11 @@ pre_expr_hash (const void *p1) case CONSTANT: return vn_hash_constant_with_type (PRE_EXPR_CONSTANT (e)); case NAME: - return iterative_hash_expr (PRE_EXPR_NAME (e), 0); + return iterative_hash_hashval_t (SSA_NAME_VERSION (PRE_EXPR_NAME (e)), 0); case NARY: - return vn_nary_op_compute_hash (PRE_EXPR_NARY (e)); + return PRE_EXPR_NARY (e)->hashcode; case REFERENCE: - return vn_reference_compute_hash (PRE_EXPR_REFERENCE (e)); + return PRE_EXPR_REFERENCE (e)->hashcode; default: abort (); } @@ -337,6 +337,9 @@ typedef struct bitmap_set #define FOR_EACH_EXPR_ID_IN_SET(set, id, bi) \ EXECUTE_IF_SET_IN_BITMAP((set)->expressions, 0, (id), (bi)) +#define FOR_EACH_VALUE_ID_IN_SET(set, id, bi) \ + EXECUTE_IF_SET_IN_BITMAP((set)->values, 0, (id), (bi)) + /* Mapping from value id to expressions with that value_id. */ DEF_VEC_P (bitmap_set_t); DEF_VEC_ALLOC_P (bitmap_set_t, heap); @@ -672,33 +675,34 @@ bitmap_set_free (bitmap_set_t set) } -/* A comparison function for use in qsort to top sort a bitmap set. Simply - subtracts value ids, since they are created with leaves before - their parent users (IE topological order). */ - -static int -value_id_compare (const void *pa, const void *pb) -{ - const unsigned int vha = get_expr_value_id (*((const pre_expr *)pa)); - const unsigned int vhb = get_expr_value_id (*((const pre_expr *)pb)); - - return vha - vhb; -} - /* Generate an topological-ordered array of bitmap set SET. */ static VEC(pre_expr, heap) * sorted_array_from_bitmap_set (bitmap_set_t set) { - unsigned int i; - bitmap_iterator bi; + unsigned int i, j; + bitmap_iterator bi, bj; VEC(pre_expr, heap) *result = NULL; - FOR_EACH_EXPR_ID_IN_SET (set, i, bi) - VEC_safe_push (pre_expr, heap, result, expression_for_id (i)); + FOR_EACH_VALUE_ID_IN_SET (set, i, bi) + { + /* The number of expressions having a given value is usually + relatively small. Thus, rather than making a vector of all + the expressions and sorting it by value-id, we walk the values + and check in the reverse mapping that tells us what expressions + have a given value, to filter those in our set. As a result, + the expressions are inserted in value-id order, which means + topological order. - qsort (VEC_address (pre_expr, result), VEC_length (pre_expr, result), - sizeof (pre_expr), value_id_compare); + If this is somehow a significant lose for some cases, we can + choose which set to walk based on the set size. */ + bitmap_set_t exprset = VEC_index (bitmap_set_t, value_expressions, i); + FOR_EACH_EXPR_ID_IN_SET (exprset, j, bj) + { + if (bitmap_bit_p (set->expressions, j)) + VEC_safe_push (pre_expr, heap, result, expression_for_id (j)); + } + } return result; } |