1 1.9 joerg /* $NetBSD: ptrace.S,v 1.9 2013/09/12 15:36:16 joerg Exp $ */ 2 1.1 msaitoh 3 1.1 msaitoh /*- 4 1.1 msaitoh * Copyright (c) 1990 The Regents of the University of California. 5 1.1 msaitoh * All rights reserved. 6 1.1 msaitoh * 7 1.1 msaitoh * This code is derived from software contributed to Berkeley by 8 1.1 msaitoh * William Jolitz. 9 1.1 msaitoh * 10 1.1 msaitoh * Redistribution and use in source and binary forms, with or without 11 1.1 msaitoh * modification, are permitted provided that the following conditions 12 1.1 msaitoh * are met: 13 1.1 msaitoh * 1. Redistributions of source code must retain the above copyright 14 1.1 msaitoh * notice, this list of conditions and the following disclaimer. 15 1.1 msaitoh * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 msaitoh * notice, this list of conditions and the following disclaimer in the 17 1.1 msaitoh * documentation and/or other materials provided with the distribution. 18 1.5 agc * 3. Neither the name of the University nor the names of its contributors 19 1.1 msaitoh * may be used to endorse or promote products derived from this software 20 1.1 msaitoh * without specific prior written permission. 21 1.1 msaitoh * 22 1.1 msaitoh * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 23 1.1 msaitoh * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 24 1.1 msaitoh * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 25 1.1 msaitoh * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 26 1.1 msaitoh * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 27 1.1 msaitoh * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 28 1.1 msaitoh * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 29 1.1 msaitoh * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 30 1.1 msaitoh * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 31 1.1 msaitoh * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32 1.1 msaitoh * SUCH DAMAGE. 33 1.1 msaitoh * 34 1.1 msaitoh * from: @(#)ptrace.s 5.1 (Berkeley) 4/23/90 35 1.1 msaitoh */ 36 1.1 msaitoh 37 1.1 msaitoh #include <machine/asm.h> 38 1.1 msaitoh #if defined(SYSLIBC_SCCS) && !defined(lint) 39 1.9 joerg RCSID("$NetBSD: ptrace.S,v 1.9 2013/09/12 15:36:16 joerg Exp $") 40 1.1 msaitoh #endif /* SYSLIBC_SCCS and not lint */ 41 1.1 msaitoh 42 1.1 msaitoh #include "SYS.h" 43 1.1 msaitoh 44 1.8 uwe /* 45 1.8 uwe * int 46 1.8 uwe * ptrace(int request, pid_t pid, caddr_t addr, int data); 47 1.8 uwe */ 48 1.1 msaitoh ENTRY(ptrace) 49 1.8 uwe #ifdef _REENTRANT 50 1.8 uwe 51 1.8 uwe mov.l .L___errno, r1 52 1.8 uwe PIC_PROLOGUE(.L_GOT) 53 1.8 uwe sts.l pr, @-sp 54 1.8 uwe mov.l r7, @-sp 55 1.8 uwe mov.l r6, @-sp 56 1.8 uwe mov.l r5, @-sp 57 1.8 uwe 1: CALL r1 58 1.8 uwe mov.l r4, @-sp 59 1.8 uwe mov.l @sp+, r4 60 1.8 uwe mov.l @sp+, r5 61 1.8 uwe mov.l @sp+, r6 62 1.8 uwe mov.l @sp+, r7 63 1.8 uwe lds.l @sp+, pr 64 1.8 uwe PIC_EPILOGUE 65 1.8 uwe 66 1.8 uwe #else /* ! _REENTRANT */ 67 1.8 uwe 68 1.9 joerg #ifdef __PIC__ 69 1.8 uwe mova .L_GOT, r0 70 1.8 uwe mov.l .L_GOT, r1 71 1.4 marcus add r0, r1 72 1.8 uwe mov.l .L_errno, r0 73 1.4 marcus mov.l @(r0, r1), r0 74 1.4 marcus #else 75 1.8 uwe mov.l .L_errno, r0 76 1.4 marcus #endif 77 1.8 uwe 78 1.8 uwe #endif /* ! _REENTRANT */ 79 1.8 uwe 80 1.8 uwe mov #0, r1 81 1.8 uwe mov.l r1, @r0 /* errno = 0; */ 82 1.8 uwe 83 1.8 uwe mov #SYS_ptrace, r0 84 1.1 msaitoh trapa #0x80 85 1.1 msaitoh bf err 86 1.1 msaitoh rts 87 1.8 uwe nop 88 1.1 msaitoh err: 89 1.7 uwe JUMP_CERROR 90 1.1 msaitoh 91 1.3 msaitoh .align 2 92 1.8 uwe .L_GOT: 93 1.8 uwe PIC_GOT_DATUM 94 1.8 uwe 95 1.8 uwe #ifdef _REENTRANT 96 1.8 uwe .global _C_LABEL(__errno) 97 1.8 uwe .L___errno: 98 1.8 uwe CALL_DATUM(_C_LABEL(__errno), 1b) 99 1.8 uwe 100 1.8 uwe #else /* ! _REENTRANT */ 101 1.8 uwe .global _C_LABEL(errno) 102 1.8 uwe .L_errno: 103 1.9 joerg #ifdef __PIC__ 104 1.8 uwe .long PIC_GOT(_C_LABEL(errno)) 105 1.4 marcus #else 106 1.8 uwe .long _C_LABEL(errno) 107 1.4 marcus #endif 108 1.8 uwe 109 1.8 uwe #endif /* ! _REENTRANT */ 110 1.8 uwe 111 1.7 uwe SET_ENTRY_SIZE(ptrace) 112