OSDN Git Service

2008-08-21 Richard Guenther <rguenther@suse.de>
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 21 Aug 2008 11:25:28 +0000 (11:25 +0000)
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 21 Aug 2008 11:25:28 +0000 (11:25 +0000)
PR tree-optimization/37181
* tree-vrp.c (extract_range_from_binary_expr): Check for NULL
folding result.
(extract_range_from_unary_expr): Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@139375 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/tree-vrp.c

index 2f3db96..98a28e6 100644 (file)
@@ -1,3 +1,10 @@
+2008-08-21  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/37181
+       * tree-vrp.c (extract_range_from_binary_expr): Check for NULL
+       folding result.
+       (extract_range_from_unary_expr): Likewise.
+
 2008-08-21  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
 
        * diagnostic.c (pedwarn_at): Rename as pedwarn.
index a71002f..a61f292 100644 (file)
@@ -2062,7 +2062,8 @@ extract_range_from_binary_expr (value_range_t *vr,
          && (op1 = op_with_constant_singleton_value_range (op1)) != NULL_TREE)
        {
          tree tem = fold_binary (code, expr_type, op0, op1);
-         if (is_gimple_min_invariant (tem)
+         if (tem
+             && is_gimple_min_invariant (tem)
              && !is_overflow_infinity (tem))
            {
              set_value_range (vr, VR_RANGE, tem, tem, NULL);
@@ -2477,7 +2478,8 @@ extract_range_from_unary_expr (value_range_t *vr, enum tree_code code,
       if ((op0 = op_with_constant_singleton_value_range (op0)) != NULL_TREE)
        {
          tree tem = fold_unary (code, type, op0);
-         if (is_gimple_min_invariant (tem)
+         if (tem
+             && is_gimple_min_invariant (tem)
              && !is_overflow_infinity (tem))
            {
              set_value_range (vr, VR_RANGE, tem, tem, NULL);