Blame SOURCES/binutils-CVE-2018-10372.patch

49857a
--- binutils.orig/binutils/dwarf.c	2018-05-01 11:42:02.656431736 +0100
49857a
+++ binutils-2.30/binutils/dwarf.c	2018-05-01 11:43:24.210383020 +0100
49857a
@@ -9244,7 +9244,18 @@ process_cu_tu_index (struct dwarf_sectio
49857a
 		}
49857a
 
49857a
 	      if (!do_display)
49857a
-		memcpy (&this_set[row - 1].signature, ph, sizeof (uint64_t));
49857a
+		{
49857a
+		  size_t num_copy = sizeof (uint64_t);
49857a
+
49857a
+		  /* PR 23064: Beware of buffer overflow.  */
49857a
+		  if (ph + num_copy < limit)
49857a
+		    memcpy (&this_set[row - 1].signature, ph, num_copy);
49857a
+		  else
49857a
+		    {
49857a
+		      warn (_("Signature (%p) extends beyond end of space in section\n"), ph);
49857a
+		      return 0;
49857a
+		    }
49857a
+		}
49857a
 
49857a
 	      prow = poffsets + (row - 1) * ncols * 4;
49857a
 	      /* PR 17531: file: b8ce60a8.  */