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

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