diff options
author | rakdver <rakdver@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-07-10 04:57:58 +0000 |
---|---|---|
committer | rakdver <rakdver@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-07-10 04:57:58 +0000 |
commit | 7d23383d23bf777ea4201c1ebf168bc595ec13a6 (patch) | |
tree | 7fd5b8c64fe84e6fadd94b6c98bdd7f62f3789a2 /gcc/tree-eh.c | |
parent | 1e61e8f00147221ae46ecfb14cb3a79cfc1defa2 (diff) | |
download | gcc-7d23383d23bf777ea4201c1ebf168bc595ec13a6.tar.gz |
* tree-ssa-loop-im.c: New file.
* Makefile.in (tree-ssa-loop-im.o): Add.
* cfgloop.c (superloop_at_depth): New function.
* cfgloop.h (superloop_at_depth): Declare.
* common.opt (ftree-lim): New flag.
* expr.c (array_ref_up_bound): New function.
* params.def (PARAM_LIM_EXPENSIVE): New parameter.
* timevar.def (TV_LIM): New timevar.
* tree-dfa.c (compute_immediate_uses): Respect TDFA_USE flags when
computing immediate uses of a phi node.
* tree-flow.h (struct tree_ann_common_d): Add aux field.
(loop_commit_inserts, for_each_index, tree_ssa_lim): Declare.
* tree-optimize.c (init_tree_optimization_passes): Add pass_lim.
* tree-pass.h (pass_lim): Declare.
* tree-ssa-loop.c (tree_ssa_loop_im, gate_tree_ssa_loop_im): New
functions.
(pass_lim): New pass structure.
* tree-eh.c (tree_could_trap_p): Handle ARRAY_REFs correctly.
* tree.c (in_array_bounds_p): New function.
* tree.h (TREE_THIS_NOTRAP): Define also for ARRAY_REFs.
(in_array_bounds_p, array_ref_up_bound): Declare.
* doc/invoke.texi (-ftree-lim, --param lim-expensive): Document.
* doc/passes.texi (tree-ssa-loop-im.c): Document.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@84441 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-eh.c')
-rw-r--r-- | gcc/tree-eh.c | 28 |
1 files changed, 23 insertions, 5 deletions
diff --git a/gcc/tree-eh.c b/gcc/tree-eh.c index 9666e998f04..8ff1bfa55b7 100644 --- a/gcc/tree-eh.c +++ b/gcc/tree-eh.c @@ -1705,7 +1705,7 @@ tree_could_trap_p (tree expr) bool honor_nans = false; bool honor_snans = false; bool fp_operation = false; - tree t; + tree t, base, idx; if (TREE_CODE_CLASS (code) == '<' || TREE_CODE_CLASS (code) == '1' @@ -1722,14 +1722,32 @@ tree_could_trap_p (tree expr) switch (code) { - case ARRAY_REF: - case ARRAY_RANGE_REF: case COMPONENT_REF: case REALPART_EXPR: case IMAGPART_EXPR: case BIT_FIELD_REF: - t = get_base_address (expr); - return !t || tree_could_trap_p (t); + t = TREE_OPERAND (expr, 0); + return tree_could_trap_p (t); + + case ARRAY_RANGE_REF: + /* Let us be conservative here for now. We might be checking bounds of + the access similarly to the case below. */ + if (!TREE_THIS_NOTRAP (expr)) + return true; + + base = TREE_OPERAND (expr, 0); + return tree_could_trap_p (base); + + case ARRAY_REF: + base = TREE_OPERAND (expr, 0); + idx = TREE_OPERAND (expr, 1); + if (tree_could_trap_p (base)) + return true; + + if (TREE_THIS_NOTRAP (expr)) + return false; + + return !in_array_bounds_p (expr); case INDIRECT_REF: return !TREE_THIS_NOTRAP (expr); |