Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/libexec/ld.elf_so When loading a non-PIE main binary, the vi...



details:   https://anonhg.NetBSD.org/src/rev/02897ae007d8
branches:  trunk
changeset: 995814:02897ae007d8
user:      joerg <joerg%NetBSD.org@localhost>
date:      Sun Jan 06 19:44:54 2019 +0000

description:
When loading a non-PIE main binary, the virtual address must match.
Use MAP_TRYFIXED and verify that the result matches the expectation.

diffstat:

 libexec/ld.elf_so/map_object.c |  20 ++++++++++++++------
 1 files changed, 14 insertions(+), 6 deletions(-)

diffs (56 lines):

diff -r d9398f4e340a -r 02897ae007d8 libexec/ld.elf_so/map_object.c
--- a/libexec/ld.elf_so/map_object.c    Sun Jan 06 18:56:52 2019 +0000
+++ b/libexec/ld.elf_so/map_object.c    Sun Jan 06 19:44:54 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: map_object.c,v 1.59 2019/01/04 19:54:56 joerg Exp $     */
+/*     $NetBSD: map_object.c,v 1.60 2019/01/06 19:44:54 joerg Exp $     */
 
 /*
  * Copyright 1996 John D. Polstra.
@@ -34,7 +34,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: map_object.c,v 1.59 2019/01/04 19:54:56 joerg Exp $");
+__RCSID("$NetBSD: map_object.c,v 1.60 2019/01/06 19:44:54 joerg Exp $");
 #endif /* not lint */
 
 #include <errno.h>
@@ -82,7 +82,7 @@
        Elf_Addr         base_vlimit;
        Elf_Addr         text_vlimit;
        int              text_flags;
-       caddr_t          base_addr;
+       void            *base_addr;
        Elf_Off          data_offset;
        Elf_Addr         data_vaddr;
        Elf_Addr         data_vlimit;
@@ -339,10 +339,12 @@
                mapflags = MAP_ALIGNED(log2);
        }
 
+       base_addr = NULL;
 #ifdef RTLD_LOADER
-       base_addr = obj->isdynamic ? NULL : (caddr_t)base_vaddr;
-#else
-       base_addr = NULL;
+       if (!obj->isdynamic) {
+               mapflags |= MAP_TRYFIXED;
+               base_addr = (void *)(uintptr_t)base_vaddr;
+       }
 #endif
        mapsize = base_vlimit - base_vaddr;
        mapbase = mmap(base_addr, mapsize, text_flags,
@@ -352,6 +354,12 @@
                    xstrerror(errno));
                goto bad;
        }
+#ifdef RTLD_LOADER
+       if (!obj->isdynamic && mapbase != base_addr) {
+               _rtld_error("mmap of executable at correct address failed");
+               goto bad;
+       }
+#endif
 
        /* Overlay the data segment onto the proper region. */
        data_addr = mapbase + (data_vaddr - base_vaddr);



Home | Main Index | Thread Index | Old Index