aboutsummaryrefslogtreecommitdiff
path: root/gcc/value-range.cc
diff options
context:
space:
mode:
authorAldy Hernandez <aldyh@redhat.com>2022-11-02 12:39:45 +0100
committerAldy Hernandez <aldyh@redhat.com>2022-11-02 14:37:01 +0100
commit58511b3fc035f7fe77c3403f7b99de3a795a7964 (patch)
tree2ccbfb726d883f49747293115a2a26dc9458f7c0 /gcc/value-range.cc
parent6d9dbdf51f9afe86a57fb28bc55065fa4500a72b (diff)
downloadgcc-58511b3fc035f7fe77c3403f7b99de3a795a7964.zip
gcc-58511b3fc035f7fe77c3403f7b99de3a795a7964.tar.gz
gcc-58511b3fc035f7fe77c3403f7b99de3a795a7964.tar.bz2
Fix bug in frange::contains_p() for signed zeros.
The contains_p() code wasn't returning true for non-singleton ranges containing signed zeros. With this patch we now handle: -0.0 exists in [-3, +5.0] +0.0 exists in [-3, +5.0] gcc/ChangeLog: * value-range.cc (frange::contains_p): Fix signed zero handling. (range_tests_signed_zeros): New test.
Diffstat (limited to 'gcc/value-range.cc')
-rw-r--r--gcc/value-range.cc10
1 files changed, 9 insertions, 1 deletions
diff --git a/gcc/value-range.cc b/gcc/value-range.cc
index 3743ec7..a855aaf 100644
--- a/gcc/value-range.cc
+++ b/gcc/value-range.cc
@@ -661,7 +661,7 @@ frange::contains_p (tree cst) const
{
// Make sure the signs are equal for signed zeros.
if (HONOR_SIGNED_ZEROS (m_type) && real_iszero (rv))
- return m_min.sign == m_max.sign && m_min.sign == rv->sign;
+ return rv->sign == m_min.sign || rv->sign == m_max.sign;
return true;
}
return false;
@@ -3859,6 +3859,14 @@ range_tests_signed_zeros ()
ASSERT_TRUE (r0.contains_p (neg_zero));
ASSERT_FALSE (r0.contains_p (zero));
+ r0 = frange (neg_zero, zero);
+ ASSERT_TRUE (r0.contains_p (neg_zero));
+ ASSERT_TRUE (r0.contains_p (zero));
+
+ r0 = frange_float ("-3", "5");
+ ASSERT_TRUE (r0.contains_p (neg_zero));
+ ASSERT_TRUE (r0.contains_p (zero));
+
// The intersection of zeros that differ in sign is a NAN (or
// undefined if not honoring NANs).
r0 = frange (neg_zero, neg_zero);