aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-ssa-reassoc.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2016-10-09 13:18:53 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2016-10-09 13:18:53 +0200
commit4dfb8a2a60a582b0a1cab65f34d706cf961c9d20 (patch)
tree575c2ff14712a649731088bf4d9e47de753bc32b /gcc/tree-ssa-reassoc.c
parent67b974787c1e77ebebb4f36cdf09ac11a5690f43 (diff)
downloadgcc-4dfb8a2a60a582b0a1cab65f34d706cf961c9d20.zip
gcc-4dfb8a2a60a582b0a1cab65f34d706cf961c9d20.tar.gz
gcc-4dfb8a2a60a582b0a1cab65f34d706cf961c9d20.tar.bz2
re PR tree-optimization/77901 (ICE in tree-sse-reassoc,c:2881)
PR tree-optimization/77901 * tree-ssa-reassoc.c (optimize_range_tests_var_bound): Only optimize if ranges[i].exp is SSA_NAME when looking for >= and only when ranges[i].exp is NULL or SSA_NAME when looking for the other comparison. * gcc.c-torture/compile/pr77901.c: New test. From-SVN: r240899
Diffstat (limited to 'gcc/tree-ssa-reassoc.c')
-rw-r--r--gcc/tree-ssa-reassoc.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/tree-ssa-reassoc.c b/gcc/tree-ssa-reassoc.c
index c5b36ef..7666365 100644
--- a/gcc/tree-ssa-reassoc.c
+++ b/gcc/tree-ssa-reassoc.c
@@ -2846,7 +2846,9 @@ optimize_range_tests_var_bound (enum tree_code opcode, int first, int length,
for (i = first; i < length; i++)
{
- if (ranges[i].exp == NULL_TREE || !ranges[i].in_p)
+ if (ranges[i].exp == NULL_TREE
+ || TREE_CODE (ranges[i].exp) != SSA_NAME
+ || !ranges[i].in_p)
continue;
tree type = TREE_TYPE (ranges[i].exp);
@@ -2878,6 +2880,8 @@ optimize_range_tests_var_bound (enum tree_code opcode, int first, int length,
tree rhs1, rhs2;
if (ranges[i].exp)
{
+ if (TREE_CODE (ranges[i].exp) != SSA_NAME)
+ continue;
stmt = SSA_NAME_DEF_STMT (ranges[i].exp);
if (!is_gimple_assign (stmt))
continue;