Switch m88k to pass &_DYNAMIC to _dl_boot_bind()
authorguenther <guenther@openbsd.org>
Fri, 15 Jul 2016 09:25:47 +0000 (09:25 +0000)
committerguenther <guenther@openbsd.org>
Fri, 15 Jul 2016 09:25:47 +0000 (09:25 +0000)
probably works: this ASM pattern is already used for _dl_dtors

libexec/ld.so/boot.c
libexec/ld.so/m88k/ldasm.S

index 30e646c..8271e38 100644 (file)
@@ -1,4 +1,4 @@
-/*     $OpenBSD: boot.c,v 1.6 2015/12/06 23:36:12 guenther Exp $ */
+/*     $OpenBSD: boot.c,v 1.7 2016/07/15 09:25:47 guenther Exp $ */
 
 /*
  * Copyright (c) 1998 Per Fogelstrom, Opsycon AB
@@ -130,7 +130,7 @@ _dl_boot_bind(const long sp, long *dl_data, Elf_Dyn *dynamicp)
 #if defined(__alpha__)
        dynp = (Elf_Dyn *)((long)_DYNAMIC);
 #elif defined(__sparc__) || defined(__sparc64__) || defined(__powerpc__) || \
-    defined(__hppa__) || defined(__sh__)
+    defined(__hppa__) || defined(__sh__) || defined(__m88k__)
        dynp = dynamicp;
 #else
        dynp = (Elf_Dyn *)((long)_DYNAMIC + loff);
index ca2c33a..f4719a8 100644 (file)
@@ -1,4 +1,4 @@
-/*     $OpenBSD: ldasm.S,v 1.19 2016/05/07 19:05:23 guenther Exp $     */
+/*     $OpenBSD: ldasm.S,v 1.20 2016/07/15 09:25:47 guenther Exp $     */
 
 /*
  * Copyright (c) 2013 Miodrag Vallat.
@@ -74,12 +74,10 @@ ENTRY(_dl_start)
         */
        or      %r2,  %r30, 0           | kernel args
        or      %r3,  %r31, 0           | array base
-#if 0 /* _dl_boot_bind() can compute this itself */
        bsr     1f                      | the following instruction is skipped
        bcnd    eq0, %r0, _DYNAMIC      | but gives us the pc-relative offset
 1:     ld.hu   %r5, %r1, 2             | fetch branch offset (low 16 bits)
        lda     %r4, %r1[%r5]           |
-#endif
        bsr     _dl_boot_bind
 
        ld      %r2,  %r30, 0           | argc