ptrace.h revision 1.11.34.1       1  1.11.34.1     skrll /*	$NetBSD: ptrace.h,v 1.11.34.1 2015/09/22 12:05:49 skrll Exp $	*/
      2        1.5      matt 
      3        1.5      matt #ifndef _POWERPC_PTRACE_H
      4        1.5      matt #define	_POWERPC_PTRACE_H
      5        1.2     perry 
      6        1.3    tsubai #define	PT_STEP		(PT_FIRSTMACH + 0)
      7        1.3    tsubai #define	PT_GETREGS	(PT_FIRSTMACH + 1)
      8        1.3    tsubai #define	PT_SETREGS	(PT_FIRSTMACH + 2)
      9        1.4    tsubai #define	PT_GETFPREGS	(PT_FIRSTMACH + 3)
     10        1.4    tsubai #define	PT_SETFPREGS	(PT_FIRSTMACH + 4)
     11        1.5      matt #define	PT_GETVECREGS	(PT_FIRSTMACH + 5)
     12        1.5      matt #define	PT_SETVECREGS	(PT_FIRSTMACH + 6)
     13        1.5      matt 
     14        1.8      matt #define	PT_MACHDEP_STRINGS				\
     15        1.8      matt 	"PT_STEP",					\
     16        1.8      matt 	"PT_GETREGS",		"PT_SETREGS",		\
     17        1.8      matt 	"PT_GETFPREGS",		"PT_SETFPREGS",		\
     18        1.8      matt 	"PT_GETVECREGS",	"PT_SETVECREGS",
     19        1.8      matt 
     20  1.11.34.1     skrll #include <machine/reg.h>
     21  1.11.34.1     skrll #define PTRACE_REG_PC(r)	(r)->pc
     22  1.11.34.1     skrll #define PTRACE_REG_SET_PC(r, v)	(r)->pc = (v)
     23  1.11.34.1     skrll #define PTRACE_REG_SP(r)	(r)->fixreg[1]
     24  1.11.34.1     skrll #define PTRACE_REG_INTRV(r)	(r)->fixreg[3]
     25  1.11.34.1     skrll 
     26        1.5      matt #ifdef _KERNEL
     27        1.5      matt #ifdef _KERNEL_OPT
     28        1.5      matt #include "opt_altivec.h"
     29        1.5      matt #endif
     30        1.5      matt 
     31       1.11      matt #if defined(ALTIVEC) || defined(PPC_HAVE_SPE)
     32        1.5      matt 
     33        1.5      matt /* We have machine-dependent process tracing requests.  */
     34        1.5      matt #define __HAVE_PTRACE_MACHDEP
     35        1.5      matt 
     36        1.5      matt #define	PTRACE_MACHDEP_REQUEST_CASES \
     37        1.5      matt 	case PT_GETVECREGS: \
     38        1.5      matt 	case PT_SETVECREGS:
     39        1.5      matt 
     40       1.10  christos int ptrace_machdep_dorequest(struct lwp *, struct lwp *, int, void *, int);
     41        1.9  christos int process_machdep_dovecregs(struct lwp *, struct lwp *, struct uio *);
     42        1.5      matt int process_machdep_validvecregs(struct proc *);
     43        1.5      matt 
     44        1.5      matt /* We have machine-dependent procfs nodes.  */
     45        1.5      matt #define __HAVE_PROCFS_MACHDEP
     46        1.5      matt 
     47        1.5      matt #define	PROCFS_MACHDEP_NODE_TYPES \
     48        1.5      matt 	Pmachdep_vecregs,		/* AltiVec register set */
     49        1.5      matt 
     50        1.5      matt #define	PROCFS_MACHDEP_NODETYPE_CASES \
     51        1.5      matt 	case Pmachdep_vecregs:
     52        1.5      matt 
     53        1.5      matt #define	PROCFS_MACHDEP_PROTECT_CASES \
     54        1.5      matt 	case Pmachdep_vecregs:
     55        1.5      matt 
     56        1.5      matt #define	PROCFS_MACHDEP_NODETYPE_DEFNS \
     57        1.5      matt 	{ DT_REG, N("vecregs"), Pmachdep_vecregs, \
     58        1.5      matt 	  procfs_machdep_validvecregs },
     59        1.5      matt 
     60        1.5      matt /* Functions used by procfs.  */
     61        1.5      matt struct mount;
     62        1.5      matt struct pfsnode;
     63        1.9  christos int procfs_machdep_dovecregs(struct lwp *, struct lwp *,
     64        1.5      matt 	struct pfsnode *, struct uio *);
     65        1.9  christos int procfs_machdep_validvecregs(struct lwp *, struct mount *);
     66        1.5      matt 
     67       1.11      matt #endif /* ALTIVEC || PPC_HAVE_SPE */
     68        1.5      matt #endif /* _KERNEL */
     69        1.5      matt 
     70        1.5      matt #endif /* _POWERPC_PTRACE_H */
     71