1 1.2 matt /* $NetBSD: rtld_start64.S,v 1.2 2014/03/06 19:19:40 matt Exp $ */ 2 1.1 matt 3 1.1 matt /*- 4 1.1 matt * Copyright (C) 1998 Tsubai Masanari 5 1.1 matt * Portions copyright 2002 Charles M. Hannum <root (at) ihack.net> 6 1.1 matt * All rights reserved. 7 1.1 matt * 8 1.1 matt * Redistribution and use in source and binary forms, with or without 9 1.1 matt * modification, are permitted provided that the following conditions 10 1.1 matt * are met: 11 1.1 matt * 1. Redistributions of source code must retain the above copyright 12 1.1 matt * notice, this list of conditions and the following disclaimer. 13 1.1 matt * 2. Redistributions in binary form must reproduce the above copyright 14 1.1 matt * notice, this list of conditions and the following disclaimer in the 15 1.1 matt * documentation and/or other materials provided with the distribution. 16 1.1 matt * 3. The name of the author may not be used to endorse or promote products 17 1.1 matt * derived from this software without specific prior written permission. 18 1.1 matt * 19 1.1 matt * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 20 1.1 matt * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 21 1.1 matt * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 22 1.1 matt * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 23 1.1 matt * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 24 1.1 matt * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 25 1.1 matt * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 26 1.1 matt * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 27 1.1 matt * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 28 1.1 matt * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 29 1.1 matt */ 30 1.1 matt 31 1.1 matt #include <machine/asm.h> 32 1.1 matt 33 1.1 matt .globl _rtld_relocate_nonplt_self 34 1.1 matt .globl _rtld 35 1.1 matt 36 1.1 matt .text 37 1.1 matt ENTRY_NOPROFILE(_rtld_start) 38 1.1 matt mr %r23,%r3 // argc 39 1.1 matt mr %r24,%r4 // argv 40 1.1 matt mr %r25,%r5 // envp 41 1.1 matt /* mr %r26,%r6 // obj (always 0) */ 42 1.1 matt /* mr %r27,%r7 // cleanup (always 0) */ 43 1.1 matt mr %r28,%r8 // ps_strings 44 1.1 matt li %r0,0 45 1.1 matt stdu %r0,-64(%r1) // terminate stack chain 46 1.1 matt std %r2,40(%r1) // save TOC 47 1.1 matt std %r0,16(%r1) // ditto 48 1.1 matt 49 1.1 matt bcl 20,31,1f 50 1.1 matt 1: mflr %r30 51 1.1 matt ld %r3,0(%r2) // TOC[0] = &TOC 52 1.1 matt sub %r29,%r2,%r3 // compute relocbase 53 1.1 matt 54 1.1 matt addis %r3,%r3,_DYNAMIC-1b@ha // get _DYNAMIC actual address 55 1.1 matt addi %r3,%r3,_DYNAMIC-1b@l 56 1.1 matt mr %r4,%r29 // r4 = relocbase 57 1.1 matt CALL(_rtld_relocate_nonplt_self) 58 1.1 matt 59 1.1 matt addi %r3,%r1,48 // sp = <local variable space> 60 1.1 matt mr %r4,%r29 // r4 = relocbase 61 1.1 matt CALL(_rtld) // _start = _rtld(sp, relocbase) 62 1.1 matt 63 1.1 matt ld %r0,0(%r3) // func address 64 1.1 matt ld %r2,8(%r3) // TOC address 65 1.1 matt ld %r11,16(%r3) // environment pointer 66 1.1 matt mtctr %r0 // so we can call it. 67 1.1 matt 68 1.1 matt mr %r3,%r23 // argc 69 1.1 matt mr %r4,%r24 // argv 70 1.1 matt mr %r5,%r25 // envp 71 1.1 matt ld %r6,56(%r1) // obj = <localvar>[1] 72 1.1 matt ld %r7,48(%r1) // cleanup = <localvar>[0] 73 1.1 matt mr %r8,%r28 // ps_strings 74 1.1 matt 75 1.1 matt bctrl // _start(argc, argv, envp, obj, cleanup, ps_strings) 76 1.1 matt nop 77 1.1 matt 78 1.1 matt li %r0,1 // _exit() 79 1.1 matt sc 80 1.1 matt END(_rtld_start) 81 1.1 matt 82 1.1 matt .globl _rtld_bind 83 1.1 matt 84 1.1 matt /* 85 1.1 matt * %r0 has the index of the rela, %r12 has a pointer to the plt entry. 86 1.1 matt */ 87 1.1 matt ENTRY_NOPROFILE(_rtld_bind_start) 88 1.1 matt std %r3,-72(%r1) // save argument register 89 1.1 matt std %r4,-64(%r1) // save argument register 90 1.1 matt std %r5,-56(%r1) // save argument register 91 1.1 matt std %r6,-48(%r1) // save argument register 92 1.1 matt std %r7,-40(%r1) // save argument register 93 1.1 matt std %r8,-32(%r1) // save argument register 94 1.1 matt std %r9,-24(%r1) // save argument register 95 1.1 matt std %r10,-16(%r1) // save argument register 96 1.1 matt std %r31,-8(%r1) // save register 97 1.1 matt stdu %r1,-(48+80)(%r1) // create back chain 98 1.1 matt mflr %r10 99 1.1 matt std %r10,16(%r1) // save LR 100 1.1 matt mfcr %r9 101 1.1 matt std %r9,8(%r1) // save CR to be safe 102 1.1 matt 103 1.1 matt mr %r31, %r12 // save this across bind call 104 1.1 matt mr %r3, %r11 // obj 105 1.1 matt mr %r4, %r0 // reloff 106 1.1 matt 107 1.1 matt CALL(_rtld_bind) // _rtld_bind(obj, reloff) 108 1.1 matt 109 1.1 matt mtctr %r3 110 1.2 matt mr %r12,%r31 // restore r12 111 1.1 matt 112 1.1 matt ld %r0,8(%r1) // get saved CR 113 1.1 matt mtcr %r0 // restore it 114 1.1 matt ld %r0,16(%r1) // get saved LR 115 1.1 matt mtlr %r0 // restore it 116 1.1 matt 117 1.1 matt addi %r1,%r1,(48+80) // adjust stack 118 1.1 matt ld %r3,-72(%r1) // restore argument register 119 1.1 matt ld %r4,-64(%r1) // restore argument register 120 1.1 matt ld %r5,-56(%r1) // restore argument register 121 1.1 matt ld %r6,-48(%r1) // restore argument register 122 1.1 matt ld %r7,-40(%r1) // restore argument register 123 1.1 matt ld %r8,-32(%r1) // restore argument register 124 1.1 matt ld %r9,-24(%r1) // restore argument register 125 1.1 matt ld %r10,-16(%r1) // restore argument register 126 1.1 matt ld %r31,-8(%r1) // restore register 127 1.1 matt bctr 128 1.1 matt END(_rtld_bind_start) 129