/* $NetBSD: ptrace.S,v 1.1 2014/09/03 19:34:26 matt Exp $ */ #include "SYS.h" #include "assym.h" #if defined(LIBC_SCCS) && !defined(lint) __RCSID("$NetBSD: ptrace.S,v 1.1 2014/09/03 19:34:26 matt Exp $") #endif /* LIBC_SCCS && !lint */ #define XCALLFRAME_LR (-1*4) #define XCALLFRAME_DATA (-2*4) #define XCALLFRAME_ADDR (-3*4) #define XCALLFRAME_PID (-4*4) #define XCALLFRAME_REQUEST (-5*4) #define XCALLFRAME_GP (-6*4) #define XCALLFRAME_SP (-7*4) #define XCALLFRAMELEN (-XCALLFRAME_SP) ENTRY(ptrace) #ifdef _REENTRANT l.sw XCALLFRAME_LR(r1),lr l.sw XCALLFRAME_REQUEST(r1),r3 l.sw XCALLFRAME_PID(r1),r4 l.sw XCALLFRAME_ADDR(r1),r5 l.sw XCALLFRAME_DATA(r1),r6 #ifdef __PIC__ l.sw XCALLFRAME_GP(r1),r16 PIC_GOTSETUP(r16) #endif l.addi r1,r1,-XCALLFRAMELEN l.jal PLT(_C_LABEL(__errno)) l.nop l.sw 0(r11),r0 l.addi r1,r1,XCALLFRAMELEN #ifdef __PIC__ l.lwz r16,XCALLFRAME_GP(r1) #endif l.lwz r6,XCALLFRAME_DATA(r1) l.lwz r4,XCALLFRAME_PID(r1) l.lwz r5,XCALLFRAME_ADDR(r1) l.lwz r3,XCALLFRAME_REQUEST(r1) l.lwz lr,XCALLFRAME_LR(r1) #else #ifdef __PIC__ l.or r8,r9,r0 PIC_GOTSETUP(r7) lwz r7,_C_LABEL(errno)@got(r7) l.or r9,r8,r0 #else l.movhi r7,hi(_C_LABEL(errno)) l.ori r7,r7,lo(_C_LABEL(errno)) #endif /* __PIC__ */ #endif /* _REENTRANT */ l.sw 0(r7),r0 _DOSYSCALL(ptrace) l.bf _C_LABEL(__cerror) l.nop l.jr lr l.nop END(ptrace)