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/arch/powerpc Startup file for powerpc64. ...
details: https://anonhg.NetBSD.org/src/rev/ceacd8b29917
branches: trunk
changeset: 327364:ceacd8b29917
user: matt <matt%NetBSD.org@localhost>
date: Thu Mar 06 07:47:19 2014 +0000
description:
Startup file for powerpc64. (too many difference with ppc32 to do
#ifdef dance)
diffstat:
libexec/ld.elf_so/arch/powerpc/rtld_start64.S | 129 ++++++++++++++++++++++++++
1 files changed, 129 insertions(+), 0 deletions(-)
diffs (133 lines):
diff -r 1e5eaf754fde -r ceacd8b29917 libexec/ld.elf_so/arch/powerpc/rtld_start64.S
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/libexec/ld.elf_so/arch/powerpc/rtld_start64.S Thu Mar 06 07:47:19 2014 +0000
@@ -0,0 +1,129 @@
+/* $NetBSD: rtld_start64.S,v 1.1 2014/03/06 07:47:19 matt Exp $ */
+
+/*-
+ * Copyright (C) 1998 Tsubai Masanari
+ * Portions copyright 2002 Charles M. Hannum <root%ihack.net@localhost>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. The name of the author may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <machine/asm.h>
+
+ .globl _rtld_relocate_nonplt_self
+ .globl _rtld
+
+ .text
+ENTRY_NOPROFILE(_rtld_start)
+ mr %r23,%r3 // argc
+ mr %r24,%r4 // argv
+ mr %r25,%r5 // envp
+/* mr %r26,%r6 // obj (always 0) */
+/* mr %r27,%r7 // cleanup (always 0) */
+ mr %r28,%r8 // ps_strings
+ li %r0,0
+ stdu %r0,-64(%r1) // terminate stack chain
+ std %r2,40(%r1) // save TOC
+ std %r0,16(%r1) // ditto
+
+ bcl 20,31,1f
+1: mflr %r30
+ ld %r3,0(%r2) // TOC[0] = &TOC
+ sub %r29,%r2,%r3 // compute relocbase
+
+ addis %r3,%r3,_DYNAMIC-1b@ha // get _DYNAMIC actual address
+ addi %r3,%r3,_DYNAMIC-1b@l
+ mr %r4,%r29 // r4 = relocbase
+ CALL(_rtld_relocate_nonplt_self)
+
+ addi %r3,%r1,48 // sp = <local variable space>
+ mr %r4,%r29 // r4 = relocbase
+ CALL(_rtld) // _start = _rtld(sp, relocbase)
+
+ ld %r0,0(%r3) // func address
+ ld %r2,8(%r3) // TOC address
+ ld %r11,16(%r3) // environment pointer
+ mtctr %r0 // so we can call it.
+
+ mr %r3,%r23 // argc
+ mr %r4,%r24 // argv
+ mr %r5,%r25 // envp
+ ld %r6,56(%r1) // obj = <localvar>[1]
+ ld %r7,48(%r1) // cleanup = <localvar>[0]
+ mr %r8,%r28 // ps_strings
+
+ bctrl // _start(argc, argv, envp, obj, cleanup, ps_strings)
+ nop
+
+ li %r0,1 // _exit()
+ sc
+END(_rtld_start)
+
+ .globl _rtld_bind
+
+/*
+ * %r0 has the index of the rela, %r12 has a pointer to the plt entry.
+ */
+ENTRY_NOPROFILE(_rtld_bind_start)
+ std %r3,-72(%r1) // save argument register
+ std %r4,-64(%r1) // save argument register
+ std %r5,-56(%r1) // save argument register
+ std %r6,-48(%r1) // save argument register
+ std %r7,-40(%r1) // save argument register
+ std %r8,-32(%r1) // save argument register
+ std %r9,-24(%r1) // save argument register
+ std %r10,-16(%r1) // save argument register
+ std %r31,-8(%r1) // save register
+ stdu %r1,-(48+80)(%r1) // create back chain
+ mflr %r10
+ std %r10,16(%r1) // save LR
+ mfcr %r9
+ std %r9,8(%r1) // save CR to be safe
+
+ mr %r31, %r12 // save this across bind call
+ mr %r3, %r11 // obj
+ mr %r4, %r0 // reloff
+
+ CALL(_rtld_bind) // _rtld_bind(obj, reloff)
+
+ mtctr %r3
+ ld %r2,8(%r31) // load TOC for function
+ ld %r11,16(%r31) // load env ptr for function.
+
+ ld %r0,8(%r1) // get saved CR
+ mtcr %r0 // restore it
+ ld %r0,16(%r1) // get saved LR
+ mtlr %r0 // restore it
+
+ addi %r1,%r1,(48+80) // adjust stack
+ ld %r3,-72(%r1) // restore argument register
+ ld %r4,-64(%r1) // restore argument register
+ ld %r5,-56(%r1) // restore argument register
+ ld %r6,-48(%r1) // restore argument register
+ ld %r7,-40(%r1) // restore argument register
+ ld %r8,-32(%r1) // restore argument register
+ ld %r9,-24(%r1) // restore argument register
+ ld %r10,-16(%r1) // restore argument register
+ ld %r31,-8(%r1) // restore register
+ bctr
+END(_rtld_bind_start)
Home |
Main Index |
Thread Index |
Old Index