]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
regex: fix buffer read overrun in search [BZ#28470]
authorPaul Eggert <eggert@cs.ucla.edu>
Wed, 24 Nov 2021 22:16:09 +0000 (14:16 -0800)
committerFlorian Weimer <fweimer@redhat.com>
Fri, 11 Nov 2022 15:54:09 +0000 (16:54 +0100)
Problem reported by Benno Schulenberg in:
https://lists.gnu.org/r/bug-gnulib/2021-10/msg00035.html
* posix/regexec.c (re_search_internal): Use better bounds check.

(cherry picked from commit c52ef24829f95a819965214eeae28e3289a91a61)

NEWS
posix/regexec.c

diff --git a/NEWS b/NEWS
index 8329b2454c541e15e387882795d7e0520829a0f6..ca93010a9454a2b0bb882013576328e00203cab3 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -77,6 +77,7 @@ The following bugs are resolved with this release:
   [28357] deadlock between pthread_create and ELF constructors
   [28361] nptl: Avoid setxid deadlock with blocked signals in thread exit
   [28407] pthread_kill assumes that kill and tgkill are equivalent
+  [28470] Buffer read overrun in regular expression searching
   [28524] Conversion from ISO-2022-JP-3 with iconv may emit spurious NULs
   [28532] powerpc64[le]: CFI for assembly templated syscalls is incorrect
   [28607] Masked signals are delivered on thread exit
index 83e9aaf8cad956a28b545f9c5c98c0ebb607a7b2..6aeba3c0b4da23ccbc4fc7b7037377ba6428278a 100644 (file)
@@ -758,10 +758,9 @@ re_search_internal (const regex_t *preg, const char *string, Idx length,
 
                  offset = match_first - mctx.input.raw_mbs_idx;
                }
-             /* If MATCH_FIRST is out of the buffer, leave it as '\0'.
-                Note that MATCH_FIRST must not be smaller than 0.  */
-             ch = (match_first >= length
-                   ? 0 : re_string_byte_at (&mctx.input, offset));
+             /* Use buffer byte if OFFSET is in buffer, otherwise '\0'.  */
+             ch = (offset < mctx.input.valid_len
+                   ? re_string_byte_at (&mctx.input, offset) : 0);
              if (fastmap[ch])
                break;
              match_first += incr;