aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/range-op-float.cc7
-rw-r--r--gcc/range-op-mixed.h12
-rw-r--r--gcc/range-op.cc16
3 files changed, 22 insertions, 13 deletions
diff --git a/gcc/range-op-float.cc b/gcc/range-op-float.cc
index bc8ecc6..11d76f2 100644
--- a/gcc/range-op-float.cc
+++ b/gcc/range-op-float.cc
@@ -557,6 +557,13 @@ operator_identity::op1_range (frange &r, tree, const frange &lhs,
return true;
}
+bool
+operator_cst::fold_range (frange &r, tree, const frange &op1,
+ const frange &, relation_trio) const
+{
+ r = op1;
+ return true;
+}
bool
operator_equal::op2_range (frange &r, tree type,
diff --git a/gcc/range-op-mixed.h b/gcc/range-op-mixed.h
index f30f7d0..5b7fbe8 100644
--- a/gcc/range-op-mixed.h
+++ b/gcc/range-op-mixed.h
@@ -292,4 +292,16 @@ public:
relation_kind rel) const final override;
};
+class operator_cst : public range_operator
+{
+public:
+ using range_operator::fold_range;
+ bool fold_range (irange &r, tree type,
+ const irange &op1, const irange &op2,
+ relation_trio rel = TRIO_VARYING) const final override;
+ bool fold_range (frange &r, tree type,
+ const frange &op1, const frange &op2,
+ relation_trio = TRIO_VARYING) const final override;
+};
+
#endif // GCC_RANGE_OP_MIXED_H
diff --git a/gcc/range-op.cc b/gcc/range-op.cc
index 70684b4..31d4e1a 100644
--- a/gcc/range-op.cc
+++ b/gcc/range-op.cc
@@ -69,6 +69,7 @@ operator_le op_le;
operator_gt op_gt;
operator_ge op_ge;
operator_identity op_ident;
+operator_cst op_cst;
// Invoke the initialization routines for each class of range.
@@ -87,7 +88,8 @@ unified_table::unified_table ()
set (SSA_NAME, op_ident);
set (PAREN_EXPR, op_ident);
set (OBJ_TYPE_REF, op_ident);
- set (REAL_CST, op_ident);
+ set (REAL_CST, op_cst);
+ set (INTEGER_CST, op_cst);
}
// The tables are hidden and accessed via a simple extern function.
@@ -4224,16 +4226,6 @@ operator_bitwise_not::op1_range (irange &r, tree type,
}
-class operator_cst : public range_operator
-{
- using range_operator::fold_range;
-public:
- virtual bool fold_range (irange &r, tree type,
- const irange &op1,
- const irange &op2,
- relation_trio rel = TRIO_VARYING) const;
-} op_integer_cst;
-
bool
operator_cst::fold_range (irange &r, tree type ATTRIBUTE_UNUSED,
const irange &lh,
@@ -4758,7 +4750,6 @@ integral_table::integral_table ()
set (BIT_IOR_EXPR, op_bitwise_or);
set (BIT_XOR_EXPR, op_bitwise_xor);
set (BIT_NOT_EXPR, op_bitwise_not);
- set (INTEGER_CST, op_integer_cst);
set (ABS_EXPR, op_abs);
set (NEGATE_EXPR, op_negate);
set (ADDR_EXPR, op_addr);
@@ -4792,7 +4783,6 @@ pointer_table::pointer_table ()
set (MIN_EXPR, op_ptr_min_max);
set (MAX_EXPR, op_ptr_min_max);
- set (INTEGER_CST, op_integer_cst);
set (ADDR_EXPR, op_addr);
set (NOP_EXPR, op_cast);
set (CONVERT_EXPR, op_cast);