aboutsummaryrefslogtreecommitdiff
path: root/gcc
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
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')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.c-torture/compile/pr57331.c11
-rw-r--r--gcc/tree-vrp.c3
4 files changed, 25 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index ffd389e..0199bd5 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2013-05-21 Jakub Jelinek <jakub@redhat.com>
+
+ 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.
+
2013-05-21 Martin Jambor <mjambor@suse.cz>
PR lto/57289
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 1ba9007..77b02f5 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2013-05-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/57331
+ * gcc.c-torture/compile/pr57331.c: New test.
+
2013-05-21 Richard Biener <rguenther@suse.de>
PR tree-optimization/57330
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr57331.c b/gcc/testsuite/gcc.c-torture/compile/pr57331.c
new file mode 100644
index 0000000..b30e1ad
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/pr57331.c
@@ -0,0 +1,11 @@
+/* PR tree-optimization/57331 */
+
+int
+foo (int x)
+{
+ void *p = x ? (void *) 1 : (void *) 0;
+ __INTPTR_TYPE__ b = (__INTPTR_TYPE__) p;
+ if (b)
+ return 0;
+ return 1;
+}
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);