+2020-01-31 David Malcolm <dmalcolm@redhat.com>
+
+ PR analyzer/93450
+ * constraint-manager.cc
+ (constraint_manager::get_or_add_equiv_class): Only compare constants
+ if their types are compatible.
+ * region-model.cc (constant_svalue::eval_condition): Replace check
+ for identical types with call to types_compatible_p.
+
2020-01-30 David Malcolm <dmalcolm@redhat.com>
* program-state.cc (extrinsic_state::dump_to_pp): New.
other_id.m_idx++)
{
const equiv_class &other_ec = other_id.get_obj (*this);
- if (other_ec.m_constant)
+ if (other_ec.m_constant
+ && types_compatible_p (TREE_TYPE (new_ec->m_constant),
+ TREE_TYPE (other_ec.m_constant)))
{
/* If we have two ECs, both with constants, the constants must be
non-equal (or they would be in the same EC).
gcc_assert (CONSTANT_CLASS_P (rhs_const));
/* Check for comparable types. */
- if (TREE_TYPE (lhs_const) == TREE_TYPE (rhs_const))
+ if (types_compatible_p (TREE_TYPE (lhs_const), TREE_TYPE (rhs_const)))
{
tree comparison
= fold_build2 (op, boolean_type_node, lhs_const, rhs_const);