From 88187dcc62fc3ca4229bb3e95018fb0f5c1543c2 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Sun, 9 Aug 1998 00:44:23 +0000 Subject: Update. 1998-08-09 Ulrich Drepper * elf/dl-reloc.c (_dl_relocate_object): Implement DT_BIND_NOW. --- ChangeLog | 4 ++++ elf/dl-reloc.c | 8 +++++++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 6a73cb6c4e..d56e798f29 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +1998-08-09 Ulrich Drepper + + * elf/dl-reloc.c (_dl_relocate_object): Implement DT_BIND_NOW. + 1998-07-31 17:59 Ulrich Drepper * sysdeps/generic/bits/byteswap.h: Fix problems with side effects. diff --git a/elf/dl-reloc.c b/elf/dl-reloc.c index 1c0cbb67c4..55e62b6705 100644 --- a/elf/dl-reloc.c +++ b/elf/dl-reloc.c @@ -33,9 +33,15 @@ _dl_relocate_object (struct link_map *l, struct link_map *scope[], int lazy, if (l->l_relocated) return; + /* If DT_BIND_NOW is set relocate all references in this object. We + do not do this if we are profiling, of course. */ + if (!consider_profiling && l->l_info[DT_BIND_NOW]) + lazy = 0; + if (_dl_debug_reloc) _dl_debug_message (1, "\nrelocation processing: ", - l->l_name[0] ? l->l_name : _dl_argv[0], "\n", NULL); + l->l_name[0] ? l->l_name : _dl_argv[0], + lazy ? " (lazy)\n" : "\n", NULL); if (l->l_info[DT_TEXTREL]) { -- cgit v1.2.3