]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
libstdc++: Tell GCC what basic_string::_M_is_local() means [PR109299]
authorJonathan Wakely <jwakely@redhat.com>
Tue, 28 Mar 2023 09:50:40 +0000 (10:50 +0100)
committerJonathan Wakely <jwakely@redhat.com>
Tue, 28 Mar 2023 21:59:51 +0000 (22:59 +0100)
This avoids a bogus warning about overflowing a buffer, because GCC
can't tell that we don't copy into the buffer unless it fits. By adding
a __builtin_unreachable() hint we inform the compiler about the
invariant that the buffer is only used when it's big enough.

This can also improve codegen, by eliminating dead code that GCC
couldn't tell was unreachable.

libstdc++-v3/ChangeLog:

PR libstdc++/109299
* include/bits/basic_string.h (basic_string::_M_is_local()): Add
hint for compiler that local strings fit in the local buffer.

(cherry picked from commit bf78b43873b0b7e8f9a430df38749b8b61f9c9b8)

libstdc++-v3/include/bits/basic_string.h

index f1a0e6984a1f1b9e1726e1c52b6d6b0b7b6726ee..1dbe7c2415c4d471235ef7db2f8f3dda85648207 100644 (file)
@@ -271,7 +271,15 @@ _GLIBCXX_BEGIN_NAMESPACE_CXX11
       _GLIBCXX20_CONSTEXPR
       bool
       _M_is_local() const
-      { return _M_data() == _M_local_data(); }
+      {
+       if (_M_data() == _M_local_data())
+         {
+           if (_M_string_length > _S_local_capacity)
+             __builtin_unreachable();
+           return true;
+         }
+       return false;
+      }
 
       // Create & Destroy
       _GLIBCXX20_CONSTEXPR