ce426f
diff -rup glibc-2.17-c758a686/elf/dl-load.c glibc-2.17-c758a686/elf/dl-load.c
ce426f
--- glibc-2.17-c758a686/elf/dl-load.c	2012-02-03 10:59:58.917870716 -0700
ce426f
+++ glibc-2.17-c758a686/elf/dl-load.c	2012-02-03 11:01:01.796580644 -0700
ce426f
@@ -1130,6 +1130,16 @@ _dl_map_object_from_fd (const char *name
ce426f
 		= N_("ELF load command address/offset not properly aligned");
ce426f
 	      goto call_lose;
ce426f
 	    }
ce426f
+	  if (__builtin_expect ((ph->p_offset + ph->p_filesz > st.st_size), 0))
ce426f
+	    {
ce426f
+	      /* If the segment requires zeroing of part of its last
ce426f
+		 page, we'll crash when accessing the unmapped page.
ce426f
+		 There's still a possibility of a race, if the shared
ce426f
+		 object is truncated between the fxstat above and the
ce426f
+		 memset below.  */
ce426f
+	      errstring = N_("ELF load command past end of file");
ce426f
+	      goto call_lose;
ce426f
+	    }
ce426f
 
ce426f
 	  c = &loadcmds[nloadcmds++];
ce426f
 	  c->mapstart = ph->p_vaddr & ~(GLRO(dl_pagesize) - 1);
ce426f
Only inglibc-2.17-c758a686/elf: dl-load.c.orig