From: Yufeng Zhang Date: Thu, 5 Dec 2013 17:28:08 +0000 (+0000) Subject: gimple-ssa-strength-reduction.c (find_basis_for_candidate): Guard the get_alternative... X-Git-Tag: upstream/12.2.0~66074 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=8fde427f4fa132c7d86197c6273c1ef4729f3ae5;p=platform%2Fupstream%2Fgcc.git gimple-ssa-strength-reduction.c (find_basis_for_candidate): Guard the get_alternative_base call with flag_expensive_optimizations. gcc/ * gimple-ssa-strength-reduction.c (find_basis_for_candidate): Guard the get_alternative_base call with flag_expensive_optimizations. (alloc_cand_and_find_basis): Likewise. From-SVN: r205713 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 49c0844..58f9782 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2013-12-05 Yufeng Zhang + + * gimple-ssa-strength-reduction.c (find_basis_for_candidate): Guard + the get_alternative_base call with flag_expensive_optimizations. + (alloc_cand_and_find_basis): Likewise. + 2013-12-05 Tejas Belagod * rtlanal.c (set_noop_p): Return nonzero in case of redundant vec_select diff --git a/gcc/gimple-ssa-strength-reduction.c b/gcc/gimple-ssa-strength-reduction.c index 8471812..f5148ea 100644 --- a/gcc/gimple-ssa-strength-reduction.c +++ b/gcc/gimple-ssa-strength-reduction.c @@ -437,7 +437,10 @@ static struct pointer_map_t *alt_base_map; /* Given BASE, use the tree affine combiniation facilities to find the underlying tree expression for BASE, with any - immediate offset excluded. */ + immediate offset excluded. + + N.B. we should eliminate this backtracking with better forward + analysis in a future release. */ static tree get_alternative_base (tree base) @@ -565,7 +568,7 @@ find_basis_for_candidate (slsr_cand_t c) } } - if (!basis && c->kind == CAND_REF) + if (flag_expensive_optimizations && !basis && c->kind == CAND_REF) { tree alt_base_expr = get_alternative_base (c->base_expr); if (alt_base_expr) @@ -650,7 +653,7 @@ alloc_cand_and_find_basis (enum cand_kind kind, gimple gs, tree base, c->basis = find_basis_for_candidate (c); record_potential_basis (c, base); - if (kind == CAND_REF) + if (flag_expensive_optimizations && kind == CAND_REF) { tree alt_base = get_alternative_base (base); if (alt_base)