diff mbox series

[scarthgap] coreutils: fix CVE-2025-5278

Message ID 20250618030710.4051350-1-Qi.Chen@windriver.com
State Changes Requested
Delegated to: Steve Sakoman
Headers show
Series [scarthgap] coreutils: fix CVE-2025-5278 | expand

Commit Message

ChenQi June 18, 2025, 3:07 a.m. UTC
From: Chen Qi <Qi.Chen@windriver.com>

Backport patch to fix CVE-2025-5278.

Signed-off-by: Chen Qi <Qi.Chen@windriver.com>
---
 ...1-sort-fix-buffer-under-read-CWE-127.patch | 112 ++++++++++++++++++
 meta/recipes-core/coreutils/coreutils_9.4.bb  |   1 +
 2 files changed, 113 insertions(+)
 create mode 100644 meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch

Comments

Steve Sakoman June 18, 2025, 3:59 p.m. UTC | #1
On Tue, Jun 17, 2025 at 8:07 PM Chen Qi via lists.openembedded.org
<Qi.Chen=windriver.com@lists.openembedded.org> wrote:
>
> From: Chen Qi <Qi.Chen@windriver.com>
>
> Backport patch to fix CVE-2025-5278.
>
> Signed-off-by: Chen Qi <Qi.Chen@windriver.com>
> ---
>  ...1-sort-fix-buffer-under-read-CWE-127.patch | 112 ++++++++++++++++++

Could you please send a V2 using the standard convention of naming the
patch file with the CVE number?  (CVE-2025-5278.patch)

Thanks!

Steve

>  meta/recipes-core/coreutils/coreutils_9.4.bb  |   1 +
>  2 files changed, 113 insertions(+)
>  create mode 100644 meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch
>
> diff --git a/meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch b/meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch
> new file mode 100644
> index 0000000000..41be1635b5
> --- /dev/null
> +++ b/meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch
> @@ -0,0 +1,112 @@
> +From 8763c305c29d0abb7e2be4695212b42917d054b2 Mon Sep 17 00:00:00 2001
> +From: =?UTF-8?q?P=C3=A1draig=20Brady?= <P@draigBrady.com>
> +Date: Tue, 20 May 2025 16:03:44 +0100
> +Subject: [PATCH] sort: fix buffer under-read (CWE-127)
> +
> +* src/sort.c (begfield): Check pointer adjustment
> +to avoid Out-of-range pointer offset (CWE-823).
> +(limfield): Likewise.
> +* tests/sort/sort-field-limit.sh: Add a new test,
> +which triggers with ASAN or Valgrind.
> +* tests/local.mk: Reference the new test.
> +* NEWS: Mention bug fix introduced in v7.2 (2009).
> +Fixes https://bugs.gnu.org/78507
> +
> +CVE: CVE-2025-5278
> +
> +Upstream-Status: Backport [https://cgit.git.savannah.gnu.org/cgit/coreutils.git/commit/?id=8c9602e3a145e9596dc1a63c6ed67865814b6633]
> +
> +Signed-off-by: Chen Qi <Qi.Chen@windriver.com>
> +---
> + src/sort.c                     | 12 ++++++++++--
> + tests/local.mk                 |  1 +
> + tests/sort/sort-field-limit.sh | 35 ++++++++++++++++++++++++++++++++++
> + 3 files changed, 46 insertions(+), 2 deletions(-)
> + create mode 100755 tests/sort/sort-field-limit.sh
> +
> +diff --git a/src/sort.c b/src/sort.c
> +index b10183b6f..7af1a2512 100644
> +--- a/src/sort.c
> ++++ b/src/sort.c
> +@@ -1644,7 +1644,11 @@ begfield (struct line const *line, struct keyfield const *key)
> +       ++ptr;
> +
> +   /* Advance PTR by SCHAR (if possible), but no further than LIM.  */
> +-  ptr = MIN (lim, ptr + schar);
> ++  size_t remaining_bytes = lim - ptr;
> ++  if (schar < remaining_bytes)
> ++    ptr += schar;
> ++  else
> ++    ptr = lim;
> +
> +   return ptr;
> + }
> +@@ -1746,7 +1750,11 @@ limfield (struct line const *line, struct keyfield const *key)
> +           ++ptr;
> +
> +       /* Advance PTR by ECHAR (if possible), but no further than LIM.  */
> +-      ptr = MIN (lim, ptr + echar);
> ++      size_t remaining_bytes = lim - ptr;
> ++      if (echar < remaining_bytes)
> ++        ptr += echar;
> ++      else
> ++        ptr = lim;
> +     }
> +
> +   return ptr;
> +diff --git a/tests/local.mk b/tests/local.mk
> +index 4da6756ac..642d225fa 100644
> +--- a/tests/local.mk
> ++++ b/tests/local.mk
> +@@ -388,6 +388,7 @@ all_tests =                                        \
> +   tests/sort/sort-debug-keys.sh                       \
> +   tests/sort/sort-debug-warn.sh                       \
> +   tests/sort/sort-discrim.sh                  \
> ++  tests/sort/sort-field-limit.sh              \
> +   tests/sort/sort-files0-from.pl              \
> +   tests/sort/sort-float.sh                    \
> +   tests/sort/sort-h-thousands-sep.sh          \
> +diff --git a/tests/sort/sort-field-limit.sh b/tests/sort/sort-field-limit.sh
> +new file mode 100755
> +index 000000000..52d8e1d17
> +--- /dev/null
> ++++ b/tests/sort/sort-field-limit.sh
> +@@ -0,0 +1,35 @@
> ++#!/bin/sh
> ++# From 7.2-9.7, this would trigger an out of bounds mem read
> ++
> ++# Copyright (C) 2025 Free Software Foundation, Inc.
> ++
> ++# This program is free software: you can redistribute it and/or modify
> ++# it under the terms of the GNU General Public License as published by
> ++# the Free Software Foundation, either version 3 of the License, or
> ++# (at your option) any later version.
> ++
> ++# This program is distributed in the hope that it will be useful,
> ++# but WITHOUT ANY WARRANTY; without even the implied warranty of
> ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> ++# GNU General Public License for more details.
> ++
> ++# You should have received a copy of the GNU General Public License
> ++# along with this program.  If not, see <https://www.gnu.org/licenses/>.
> ++
> ++. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
> ++print_ver_ sort
> ++getlimits_
> ++
> ++# This issue triggers with valgrind or ASAN
> ++valgrind --error-exitcode=1 sort --version 2>/dev/null &&
> ++  VALGRIND='valgrind --error-exitcode=1'
> ++
> ++{ printf '%s\n' aa bb; } > in || framework_failure_
> ++
> ++_POSIX2_VERSION=200809 $VALGRIND sort +0.${SIZE_MAX}R in > out || fail=1
> ++compare in out || fail=1
> ++
> ++_POSIX2_VERSION=200809 $VALGRIND sort +1 -1.${SIZE_MAX}R in > out || fail=1
> ++compare in out || fail=1
> ++
> ++Exit $fail
> +--
> +2.34.1
> +
> diff --git a/meta/recipes-core/coreutils/coreutils_9.4.bb b/meta/recipes-core/coreutils/coreutils_9.4.bb
> index 62ecdea6ec..ce35240d44 100644
> --- a/meta/recipes-core/coreutils/coreutils_9.4.bb
> +++ b/meta/recipes-core/coreutils/coreutils_9.4.bb
> @@ -18,6 +18,7 @@ SRC_URI = "${GNU_MIRROR}/coreutils/${BP}.tar.xz \
>             file://0001-local.mk-fix-cross-compiling-problem.patch \
>             file://0001-posixtm-pacify-clang-18.patch \
>             file://CVE-2024-0684.patch \
> +           file://0001-sort-fix-buffer-under-read-CWE-127.patch \
>             file://run-ptest \
>             "
>  SRC_URI[sha256sum] = "ea613a4cf44612326e917201bbbcdfbd301de21ffc3b59b6e5c07e040b275e52"
> --
> 2.34.1
>
>
> -=-=-=-=-=-=-=-=-=-=-=-
> Links: You receive all messages sent to this group.
> View/Reply Online (#218968): https://lists.openembedded.org/g/openembedded-core/message/218968
> Mute This Topic: https://lists.openembedded.org/mt/113702781/3620601
> Group Owner: openembedded-core+owner@lists.openembedded.org
> Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [steve@sakoman.com]
> -=-=-=-=-=-=-=-=-=-=-=-
>
diff mbox series

Patch

diff --git a/meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch b/meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch
new file mode 100644
index 0000000000..41be1635b5
--- /dev/null
+++ b/meta/recipes-core/coreutils/coreutils/0001-sort-fix-buffer-under-read-CWE-127.patch
@@ -0,0 +1,112 @@ 
+From 8763c305c29d0abb7e2be4695212b42917d054b2 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?P=C3=A1draig=20Brady?= <P@draigBrady.com>
+Date: Tue, 20 May 2025 16:03:44 +0100
+Subject: [PATCH] sort: fix buffer under-read (CWE-127)
+
+* src/sort.c (begfield): Check pointer adjustment
+to avoid Out-of-range pointer offset (CWE-823).
+(limfield): Likewise.
+* tests/sort/sort-field-limit.sh: Add a new test,
+which triggers with ASAN or Valgrind.
+* tests/local.mk: Reference the new test.
+* NEWS: Mention bug fix introduced in v7.2 (2009).
+Fixes https://bugs.gnu.org/78507
+
+CVE: CVE-2025-5278
+
+Upstream-Status: Backport [https://cgit.git.savannah.gnu.org/cgit/coreutils.git/commit/?id=8c9602e3a145e9596dc1a63c6ed67865814b6633]
+
+Signed-off-by: Chen Qi <Qi.Chen@windriver.com>
+---
+ src/sort.c                     | 12 ++++++++++--
+ tests/local.mk                 |  1 +
+ tests/sort/sort-field-limit.sh | 35 ++++++++++++++++++++++++++++++++++
+ 3 files changed, 46 insertions(+), 2 deletions(-)
+ create mode 100755 tests/sort/sort-field-limit.sh
+
+diff --git a/src/sort.c b/src/sort.c
+index b10183b6f..7af1a2512 100644
+--- a/src/sort.c
++++ b/src/sort.c
+@@ -1644,7 +1644,11 @@ begfield (struct line const *line, struct keyfield const *key)
+       ++ptr;
+ 
+   /* Advance PTR by SCHAR (if possible), but no further than LIM.  */
+-  ptr = MIN (lim, ptr + schar);
++  size_t remaining_bytes = lim - ptr;
++  if (schar < remaining_bytes)
++    ptr += schar;
++  else
++    ptr = lim;
+ 
+   return ptr;
+ }
+@@ -1746,7 +1750,11 @@ limfield (struct line const *line, struct keyfield const *key)
+           ++ptr;
+ 
+       /* Advance PTR by ECHAR (if possible), but no further than LIM.  */
+-      ptr = MIN (lim, ptr + echar);
++      size_t remaining_bytes = lim - ptr;
++      if (echar < remaining_bytes)
++        ptr += echar;
++      else
++        ptr = lim;
+     }
+ 
+   return ptr;
+diff --git a/tests/local.mk b/tests/local.mk
+index 4da6756ac..642d225fa 100644
+--- a/tests/local.mk
++++ b/tests/local.mk
+@@ -388,6 +388,7 @@ all_tests =					\
+   tests/sort/sort-debug-keys.sh			\
+   tests/sort/sort-debug-warn.sh			\
+   tests/sort/sort-discrim.sh			\
++  tests/sort/sort-field-limit.sh		\
+   tests/sort/sort-files0-from.pl		\
+   tests/sort/sort-float.sh			\
+   tests/sort/sort-h-thousands-sep.sh		\
+diff --git a/tests/sort/sort-field-limit.sh b/tests/sort/sort-field-limit.sh
+new file mode 100755
+index 000000000..52d8e1d17
+--- /dev/null
++++ b/tests/sort/sort-field-limit.sh
+@@ -0,0 +1,35 @@
++#!/bin/sh
++# From 7.2-9.7, this would trigger an out of bounds mem read
++
++# Copyright (C) 2025 Free Software Foundation, Inc.
++
++# This program is free software: you can redistribute it and/or modify
++# it under the terms of the GNU General Public License as published by
++# the Free Software Foundation, either version 3 of the License, or
++# (at your option) any later version.
++
++# This program is distributed in the hope that it will be useful,
++# but WITHOUT ANY WARRANTY; without even the implied warranty of
++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++# GNU General Public License for more details.
++
++# You should have received a copy of the GNU General Public License
++# along with this program.  If not, see <https://www.gnu.org/licenses/>.
++
++. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
++print_ver_ sort
++getlimits_
++
++# This issue triggers with valgrind or ASAN
++valgrind --error-exitcode=1 sort --version 2>/dev/null &&
++  VALGRIND='valgrind --error-exitcode=1'
++
++{ printf '%s\n' aa bb; } > in || framework_failure_
++
++_POSIX2_VERSION=200809 $VALGRIND sort +0.${SIZE_MAX}R in > out || fail=1
++compare in out || fail=1
++
++_POSIX2_VERSION=200809 $VALGRIND sort +1 -1.${SIZE_MAX}R in > out || fail=1
++compare in out || fail=1
++
++Exit $fail
+-- 
+2.34.1
+
diff --git a/meta/recipes-core/coreutils/coreutils_9.4.bb b/meta/recipes-core/coreutils/coreutils_9.4.bb
index 62ecdea6ec..ce35240d44 100644
--- a/meta/recipes-core/coreutils/coreutils_9.4.bb
+++ b/meta/recipes-core/coreutils/coreutils_9.4.bb
@@ -18,6 +18,7 @@  SRC_URI = "${GNU_MIRROR}/coreutils/${BP}.tar.xz \
            file://0001-local.mk-fix-cross-compiling-problem.patch \
            file://0001-posixtm-pacify-clang-18.patch \
            file://CVE-2024-0684.patch \
+           file://0001-sort-fix-buffer-under-read-CWE-127.patch \
            file://run-ptest \
            "
 SRC_URI[sha256sum] = "ea613a4cf44612326e917201bbbcdfbd301de21ffc3b59b6e5c07e040b275e52"