summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2000-06-08 01:50:04 +0000
committerUlrich Drepper <drepper@redhat.com>2000-06-08 01:50:04 +0000
commit1c14af448eef3274c386069b78b2ce93f2a5e3c6 (patch)
treeb1ccb62a3185d2a0d4a285f0bfa55b38a92a23dd
parent7b228b6857ffc46e13b57ba2d1f6955320e46871 (diff)
Update.
* elf/dl-addr.c (_dl_addr): Do exact testing of address range using l_map_start and l_map_end.
-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. */