aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vrp.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2013-05-21 17:17:31 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2013-05-21 17:17:31 +0200
commita4ce12589d1442367da66cc16658fdeef2c0420f (patch)
treed47ff968d7466a7eaeb156f5bd570935376bfd20 /gcc/tree-vrp.c
parentf3e4f44cb2d0964726a3f07601dcc6bded23e37c (diff)
downloadgcc-a4ce12589d1442367da66cc16658fdeef2c0420f.zip
gcc-a4ce12589d1442367da66cc16658fdeef2c0420f.tar.gz
gcc-a4ce12589d1442367da66cc16658fdeef2c0420f.tar.bz2
re PR tree-optimization/57331 (ICE: tree check: expected integer_type or enumeral_type or boolean_type or real_type or fixed_point_type, have pointer_type in int_fits_type_p, at tree.c:8437)
PR tree-optimization/57331 * tree-vrp.c (simplify_cond_using_ranges): Don't optimize comparison of conversion from pointer type to integral type with integer. * gcc.c-torture/compile/pr57331.c: New test. From-SVN: r199148
Diffstat (limited to 'gcc/tree-vrp.c')
-rw-r--r--gcc/tree-vrp.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/tree-vrp.c b/gcc/tree-vrp.c
index b5de683..66c50ca 100644
--- a/gcc/tree-vrp.c
+++ b/gcc/tree-vrp.c
@@ -8661,7 +8661,8 @@ simplify_cond_using_ranges (gimple stmt)
innerop = gimple_assign_rhs1 (def_stmt);
- if (TREE_CODE (innerop) == SSA_NAME)
+ if (TREE_CODE (innerop) == SSA_NAME
+ && !POINTER_TYPE_P (TREE_TYPE (innerop)))
{
value_range_t *vr = get_value_range (innerop);