From 47633640aac786547853c20f7d767c0f6c66f5fb Mon Sep 17 00:00:00 2001 From: John Polstra Date: Sun, 7 Feb 1999 23:49:56 +0000 Subject: [PATCH] Change the load address of the ELF dynamic linker from "2L*MAXDSIZ" to an architecture-specific value defined in . This solves problems on large-memory systems that have a high value for MAXDSIZ. The load address is controlled by a new macro ELF_RTLD_ADDR(vmspace). On the i386 it is hard-wired to 0x08000000, which is the standard SVR4 location for the dynamic linker. On the Alpha, the dynamic linker is loaded MAXDSIZ bytes beyond the start of the program's data segment. This is the same place a userland mmap(0, ...) call would put it, so it ends up just below all the shared libraries. The rationale behind the calculation is that it allows room for the data segment to grow to its maximum possible size. These changes have been tested on the i386 for several months without problems. They have been tested on the Alpha as well, though not for nearly as long. I would like to merge the changes into 3.1 within a week if no problems have surfaced as a result of them. --- sys/alpha/include/elf.h | 14 +++++++++++++- sys/amd64/include/elf.h | 12 +++++++++++- sys/i386/include/elf.h | 12 +++++++++++- sys/kern/imgact_elf.c | 4 ++-- 4 files changed, 37 insertions(+), 5 deletions(-) diff --git a/sys/alpha/include/elf.h b/sys/alpha/include/elf.h index 3972adb4825a..26e912edd7b5 100644 --- a/sys/alpha/include/elf.h +++ b/sys/alpha/include/elf.h @@ -23,7 +23,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: elf.h,v 1.4 1998/08/17 08:05:55 dfr Exp $ + * $Id: elf.h,v 1.5 1998/09/14 20:30:08 jdp Exp $ */ #ifndef _MACHINE_ELF_H_ @@ -135,4 +135,16 @@ __ElfType(Auxinfo); #define ELF_TARG_MACH EM_ALPHA #define ELF_TARG_VER 1 +#ifdef KERNEL + +/* + * On the Alpha we load the dynamic linker where a userland call + * to mmap(0, ...) would put it. The rationale behind this + * calculation is that it leaves room for the heap can grow to + * its maximum allowed size. + */ +#define ELF_RTLD_ADDR(vmspace) \ + (round_page((vm_offset_t)(vmspace)->vm_daddr + MAXDSIZ)) + +#endif /* KERNEL */ #endif /* !_MACHINE_ELF_H_ */ diff --git a/sys/amd64/include/elf.h b/sys/amd64/include/elf.h index 93f486bf2d02..c6bedaf8e306 100644 --- a/sys/amd64/include/elf.h +++ b/sys/amd64/include/elf.h @@ -23,7 +23,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: elf.h,v 1.4 1998/09/14 20:30:12 jdp Exp $ + * $Id: elf.h,v 1.5 1998/10/18 15:31:23 peter Exp $ */ #ifndef _MACHINE_ELF_H_ @@ -118,4 +118,14 @@ __ElfType(Auxinfo); #define ELF_TARG_MACH EM_386 #define ELF_TARG_VER 1 +#ifdef KERNEL + +/* + * On the i386 we load the dynamic linker at a fixed address, + * below where the executable itself is loaded. This is the + * standard SVR4 location for it. + */ +#define ELF_RTLD_ADDR(vmspace) 0x08000000 + +#endif /* KERNEL */ #endif /* !_MACHINE_ELF_H_ */ diff --git a/sys/i386/include/elf.h b/sys/i386/include/elf.h index 93f486bf2d02..c6bedaf8e306 100644 --- a/sys/i386/include/elf.h +++ b/sys/i386/include/elf.h @@ -23,7 +23,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: elf.h,v 1.4 1998/09/14 20:30:12 jdp Exp $ + * $Id: elf.h,v 1.5 1998/10/18 15:31:23 peter Exp $ */ #ifndef _MACHINE_ELF_H_ @@ -118,4 +118,14 @@ __ElfType(Auxinfo); #define ELF_TARG_MACH EM_386 #define ELF_TARG_VER 1 +#ifdef KERNEL + +/* + * On the i386 we load the dynamic linker at a fixed address, + * below where the executable itself is loaded. This is the + * standard SVR4 location for it. + */ +#define ELF_RTLD_ADDR(vmspace) 0x08000000 + +#endif /* KERNEL */ #endif /* !_MACHINE_ELF_H_ */ diff --git a/sys/kern/imgact_elf.c b/sys/kern/imgact_elf.c index 38f70d9b72ba..6d9586e9a1a4 100644 --- a/sys/kern/imgact_elf.c +++ b/sys/kern/imgact_elf.c @@ -26,7 +26,7 @@ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * - * $Id: imgact_elf.c,v 1.51 1999/02/05 22:24:26 jdp Exp $ + * $Id: imgact_elf.c,v 1.52 1999/02/07 21:48:21 dillon Exp $ */ #include "opt_rlimit.h" @@ -522,7 +522,7 @@ exec_elf_imgact(struct image_params *imgp) vmspace->vm_dsize = data_size >> PAGE_SHIFT; vmspace->vm_daddr = (caddr_t)(uintptr_t)data_addr; - addr = 2L*MAXDSIZ; /* May depend on OS type XXX */ + addr = ELF_RTLD_ADDR(vmspace); imgp->entry_addr = entry;