@@ -46,4 +46,5 @@ SRC_URI = "\
file://0018-CVE-2025-11494.patch \
file://0019-CVE-2025-11839.patch \
file://0020-CVE-2025-11840.patch \
+ file://CVE-2025-69644.patch \
"
new file mode 100644
@@ -0,0 +1,83 @@
+From ba49416855d61189ef1d8c422ad2815b8702871e Mon Sep 17 00:00:00 2001
+From: Alan Modra <amodra@gmail.com>
+Date: Sat, 22 Nov 2025 09:52:18 +1030
+Subject: [PATCH] PR 33639 .debug_loclists output
+
+The fuzzed testcase in this PR prints an almost endless table of
+offsets, due to a bogus offset count. Limit that count, and the total
+length too.
+
+ PR 33639
+ * dwarf.c (display_loclists_unit_header): Return error on
+ length too small to read header. Limit length to section
+ size. Limit offset count similarly.
+CVE: CVE-2025-69644
+Upstream-Status: Backport [https://sourceware.org/git/?p=binutils-gdb.git;a=commitdiff;h=455446bbdc8675f34808187de2bbad4682016ff7]
+
+(cherry picked from commit 455446bbdc8675f34808187de2bbad4682016ff7)
+Signed-off-by: Deepak Rathore <deeratho@cisco.com>
+---
+ binutils/dwarf.c | 20 ++++++++++++++------
+ 1 file changed, 14 insertions(+), 6 deletions(-)
+
+diff --git a/binutils/dwarf.c b/binutils/dwarf.c
+index f4bcb677761..3c53821149c 100644
+--- a/binutils/dwarf.c
++++ b/binutils/dwarf.c
+@@ -7257,8 +7257,6 @@ display_loclists_unit_header (struct dwarf_section * section,
+ bool is_64bit;
+ uint32_t i;
+
+- printf (_("Table at Offset %#" PRIx64 "\n"), header_offset);
+-
+ SAFE_BYTE_GET_AND_INC (length, start, 4, end);
+ if (length == 0xffffffff)
+ {
+@@ -7267,6 +7265,11 @@ display_loclists_unit_header (struct dwarf_section * section,
+ }
+ else
+ is_64bit = false;
++ if (length < 8)
++ return (uint64_t) -1;
++
++ printf (_("Table at Offset %#" PRIx64 "\n"), header_offset);
++ header_offset = start - section->start;
+
+ SAFE_BYTE_GET_AND_INC (version, start, 2, end);
+ SAFE_BYTE_GET_AND_INC (address_size, start, 1, end);
+@@ -7279,15 +7282,21 @@ display_loclists_unit_header (struct dwarf_section * section,
+ printf (_(" Segment size: %u\n"), segment_selector_size);
+ printf (_(" Offset entries: %u\n"), *offset_count);
+
++ if (length > section->size - header_offset)
++ length = section->size - header_offset;
++
+ if (segment_selector_size != 0)
+ {
+ warn (_("The %s section contains an "
+ "unsupported segment selector size: %d.\n"),
+ section->name, segment_selector_size);
+- return (uint64_t)-1;
++ return (uint64_t) -1;
+ }
+
+- if ( *offset_count)
++ uint64_t max_off_count = length >> (is_64bit ? 3 : 2);
++ if (*offset_count > max_off_count)
++ *offset_count = max_off_count;
++ if (*offset_count)
+ {
+ printf (_("\n Offset Entries starting at %#tx:\n"),
+ start - section->start);
+@@ -7304,8 +7313,7 @@ display_loclists_unit_header (struct dwarf_section * section,
+ putchar ('\n');
+ *loclists_start = start;
+
+- /* The length field doesn't include the length field itself. */
+- return header_offset + length + (is_64bit ? 12 : 4);
++ return header_offset + length;
+ }
+
+ static int
+--
+2.44.1