about summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2005-01-06 11:14:03 +0000
committerUlrich Drepper <drepper@redhat.com>2005-01-06 11:14:03 +0000
commitef07fd10d992d6af9657dbbd58b2465828bec516 (patch)
treef3254e11c98a3d12307d86e17506281a3e1ce00c
parent1b99d99f0e7e7bfc690f260d16193f162dfda8cf (diff)
downloadglibc-ef07fd10d992d6af9657dbbd58b2465828bec516.tar.gz
glibc-ef07fd10d992d6af9657dbbd58b2465828bec516.tar.xz
glibc-ef07fd10d992d6af9657dbbd58b2465828bec516.zip
Update.
2005-01-05  Steven Munroe  <sjmunroe@us.ibm.com>

	* elf/rtld.c (dl_main) [NEED_DL_SYSINFO_DSO]: Insure l_map_end and
	l_text_end are set for a VDSO with a single PT_LOAD entry.
-rw-r--r--ChangeLog5
-rw-r--r--elf/rtld.c6
2 files changed, 8 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 66a6f02297..58c6bbb510 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2005-01-05  Steven Munroe  <sjmunroe@us.ibm.com>
+
+	* elf/rtld.c (dl_main) [NEED_DL_SYSINFO_DSO]: Insure l_map_end and
+	l_text_end are set for a VDSO with a single PT_LOAD entry.
+
 2005-01-05  Ulrich Drepper  <drepper@redhat.com>
 
 	* libio/fmemopen.c (fmemopen_seek): SEEK_END should count from
diff --git a/elf/rtld.c b/elf/rtld.c
index cd40f80088..de46956a6a 100644
--- a/elf/rtld.c
+++ b/elf/rtld.c
@@ -1,5 +1,5 @@
 /* Run time dynamic linker.
-   Copyright (C) 1995-2002, 2003, 2004 Free Software Foundation, Inc.
+   Copyright (C) 1995-2002, 2003, 2004, 2005 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -1304,9 +1304,9 @@ ERROR: ld.so: object '%s' from %s cannot be preloaded: ignored.\n",
 		{
 		  if (! l->l_addr)
 		    l->l_addr = ph->p_vaddr;
-		  else if (ph->p_vaddr + ph->p_memsz >= l->l_map_end)
+		  if (ph->p_vaddr + ph->p_memsz >= l->l_map_end)
 		    l->l_map_end = ph->p_vaddr + ph->p_memsz;
-		  else if ((ph->p_flags & PF_X)
+		  if ((ph->p_flags & PF_X)
 			   && ph->p_vaddr + ph->p_memsz >= l->l_text_end)
 		    l->l_text_end = ph->p_vaddr + ph->p_memsz;
 		}