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 Implement a self-relocate function for the...



details:   https://anonhg.NetBSD.org/src/rev/91a9349a4aab
branches:  trunk
changeset: 537106:91a9349a4aab
user:      mycroft <mycroft%NetBSD.org@localhost>
date:      Thu Sep 26 22:26:26 2002 +0000

description:
Implement a self-relocate function for the VAX.

diffstat:

 libexec/ld.elf_so/arch/vax/mdreloc.c    |  29 ++++++++++++++++++++++++++++-
 libexec/ld.elf_so/arch/vax/rtld_start.S |  18 ++++++++++++------
 libexec/ld.elf_so/rtld.c                |   6 +-----
 3 files changed, 41 insertions(+), 12 deletions(-)

diffs (105 lines):

diff -r 2a5db99bf085 -r 91a9349a4aab libexec/ld.elf_so/arch/vax/mdreloc.c
--- a/libexec/ld.elf_so/arch/vax/mdreloc.c      Thu Sep 26 21:35:27 2002 +0000
+++ b/libexec/ld.elf_so/arch/vax/mdreloc.c      Thu Sep 26 22:26:26 2002 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mdreloc.c,v 1.14 2002/09/26 20:42:12 mycroft Exp $     */
+/*     $NetBSD: mdreloc.c,v 1.15 2002/09/26 22:26:27 mycroft Exp $     */
 
 #include <sys/types.h>
 #include <sys/stat.h>
@@ -7,6 +7,7 @@
 #include "rtld.h"
 
 void _rtld_bind_start(void);
+void _rtld_relocate_nonplt_self(Elf_Dyn *, Elf_Addr);
 caddr_t _rtld_bind __P((const Obj_Entry *, Elf_Word));
 
 void
@@ -16,6 +17,32 @@
        obj->pltgot[2] = (Elf_Addr) &_rtld_bind_start;
 }
 
+void
+_rtld_relocate_nonplt_self(dynp, relocbase)
+       Elf_Dyn *dynp;
+       Elf_Addr relocbase;
+{
+       const Elf_Rela *rela = 0, *relalim;
+       Elf_Addr relasz = 0;
+       Elf_Addr *where;
+
+       for (; dynp->d_tag != DT_NULL; dynp++) {
+               switch (dynp->d_tag) {
+               case DT_RELA:
+                       rela = (const Elf_Rela *)(relocbase + dynp->d_un.d_ptr);
+                       break;
+               case DT_RELASZ:
+                       relasz = dynp->d_un.d_val;
+                       break;
+               }
+       }
+       relalim = (const Elf_Rela *)((caddr_t)rela + relasz);
+       for (; rela < relalim; rela++) {
+               where = (Elf_Addr *)(relocbase + rela->r_offset);
+               *where = (Elf_Addr)(relocbase + rela->r_addend);
+       }
+}
+
 int
 _rtld_relocate_nonplt_objects(obj)
        const Obj_Entry *obj;
diff -r 2a5db99bf085 -r 91a9349a4aab libexec/ld.elf_so/arch/vax/rtld_start.S
--- a/libexec/ld.elf_so/arch/vax/rtld_start.S   Thu Sep 26 21:35:27 2002 +0000
+++ b/libexec/ld.elf_so/arch/vax/rtld_start.S   Thu Sep 26 22:26:26 2002 +0000
@@ -1,7 +1,8 @@
-/*     $NetBSD: rtld_start.S,v 1.8 2002/09/12 17:43:30 mycroft Exp $   */
+/*     $NetBSD: rtld_start.S,v 1.9 2002/09/26 22:26:27 mycroft Exp $   */
 
 /*
  * Copyright 1996 Matt Thomas <matt%3am-software.com@localhost>
+ * Portions copyright 2002 Charles M. Hannum.
  * All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without
@@ -44,11 +45,16 @@
        clrl    %fp
        subl2   $8,%sp
 
-       movab   _GLOBAL_OFFSET_TABLE_,%r0
-       subl2   .L1,%r0
-       movl    %sp,%r1
-       pushl   %r0             /* relocbase */
-       pushl   %r1             /* sp */
+       movab   _DYNAMIC,%r0
+       movab   _GLOBAL_OFFSET_TABLE_,%r1
+       subl2   .L1,%r1
+       pushl   %r1             /* relocbase */
+       pushl   %r0             /* &_DYNAMIC */
+       calls   $2,_rtld_relocate_nonplt_self
+
+       movl    %sp,%r0
+       pushl   %r1             /* relocbase */
+       pushl   %r0             /* sp */
        calls   $2,_rtld        /* entry = _rtld(sp, relocbase) */
 
        movq    (%sp)+,%r7      /* grab cleanup and obj_main into %r7/%r8 */
diff -r 2a5db99bf085 -r 91a9349a4aab libexec/ld.elf_so/rtld.c
--- a/libexec/ld.elf_so/rtld.c  Thu Sep 26 21:35:27 2002 +0000
+++ b/libexec/ld.elf_so/rtld.c  Thu Sep 26 22:26:26 2002 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rtld.c,v 1.81 2002/09/26 20:42:10 mycroft Exp $         */
+/*     $NetBSD: rtld.c,v 1.82 2002/09/26 22:26:26 mycroft Exp $         */
 
 /*
  * Copyright 1996 John D. Polstra.
@@ -163,10 +163,6 @@
        assert(!_rtld_objself.pltgot && !_rtld_objself.textrel);
 #endif
 
-#ifdef __vax__
-       _rtld_relocate_nonplt_objects(&_rtld_objself);
-#endif
-
        _rtld_add_paths(&_rtld_default_paths, RTLD_DEFAULT_LIBRARY_PATH);
 
        /*



Home | Main Index | Thread Index | Old Index