From ded291197c7da40793b072cd5487434b252376d7 Mon Sep 17 00:00:00 2001 From: Roland McGrath Date: Mon, 5 Jun 1995 03:04:45 +0000 Subject: Sun Jun 4 22:14:11 1995 Roland McGrath * hurd/Makefile (sig): Added thread-self. * hurd/hurd.h: Declare hurd_thread_self. * hurd/thread-self.c: New file. Thu Jun 1 12:17:52 1995 Roland McGrath * elf/rtld.c: Initialize RTLD_MAP.l_type. * elf/dl-reloc.c (_dl_relocate_object): Clear LAZY if relocating the dynamic linker itself. --- elf/dl-reloc.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'elf/dl-reloc.c') diff --git a/elf/dl-reloc.c b/elf/dl-reloc.c index ebc31d07fa..a3590ff749 100644 --- a/elf/dl-reloc.c +++ b/elf/dl-reloc.c @@ -76,6 +76,14 @@ _dl_relocate_object (struct link_map *l, int lazy) else scope = _dl_loaded; + if (l->l_type == lt_interpreter) + /* We cannot be lazy when relocating the dynamic linker itself. It + was previously relocated eagerly (allowing us to be running now), + and needs always to be fully relocated so it can run without the + aid of run-time fixups (because it's the one to do them), so we + must always re-relocate its PLT eagerly. */ + lazy = 0; + ELF_DYNAMIC_RELOCATE (l, lazy, resolve); /* Restore list frobnication done above for DT_SYMBOLIC. */ -- cgit 1.4.1