about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog3
-rw-r--r--elf/dl-addr.c11
2 files changed, 9 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index 409528aff2..1079ab085a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2000-06-07  Ulrich Drepper  <drepper@redhat.com>
 
+	* elf/dl-addr.c (_dl_addr): Do exact testing of address range
+	using l_map_start and l_map_end.
+
 	* elf/dl-version.c: Add __builtin_expect in many places.
 
 	* sysdeps/unix/sysv/linux/i386/dl-procinfo.h (x86_cap_flags):
diff --git a/elf/dl-addr.c b/elf/dl-addr.c
index b0b864fa57..3932a6573a 100644
--- a/elf/dl-addr.c
+++ b/elf/dl-addr.c
@@ -34,12 +34,13 @@ _dl_addr (const void *address, Dl_info *info)
   /* Find the highest-addressed object that ADDRESS is not below.  */
   match = NULL;
   for (l = _dl_loaded; l; l = l->l_next)
-    if (l->l_addr != 0	/* Make sure we do not currently set this map up
-			   in this moment.  */
-	&& addr >= l->l_addr && (!match || match->l_addr < l->l_addr))
-      match = l;
+    if (addr >= l->l_map_start && addr < l->l_map_end)
+      {
+	match = l;
+	break;
+      }
 
-  if (match)
+  if (__builtin_expect (match != NULL, 1))
     {
       /* We know ADDRESS lies within MATCH if in any shared object.
 	 Make sure it isn't past the end of MATCH's segments.  */