diff options
author | Aldy Hernandez <aldyh@redhat.com> | 2022-11-02 12:39:45 +0100 |
---|---|---|
committer | Aldy Hernandez <aldyh@redhat.com> | 2022-11-02 14:37:01 +0100 |
commit | 58511b3fc035f7fe77c3403f7b99de3a795a7964 (patch) | |
tree | 2ccbfb726d883f49747293115a2a26dc9458f7c0 /gcc/value-range.cc | |
parent | 6d9dbdf51f9afe86a57fb28bc55065fa4500a72b (diff) | |
download | gcc-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.cc | 10 |
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); |