Home | History | Annotate | Line # | Download | only in include
ptrace.h revision 1.16
      1  1.16     kamil /*	$NetBSD: ptrace.h,v 1.16 2016/12/15 12:04:18 kamil Exp $	*/
      2   1.7   thorpej 
      3   1.7   thorpej /*
      4   1.7   thorpej  * Copyright (c) 2001 Wasabi Systems, Inc.
      5   1.7   thorpej  * All rights reserved.
      6   1.7   thorpej  *
      7   1.7   thorpej  * Written by Jason R. Thorpe for Wasabi Systems, Inc.
      8   1.7   thorpej  *
      9   1.7   thorpej  * Redistribution and use in source and binary forms, with or without
     10   1.7   thorpej  * modification, are permitted provided that the following conditions
     11   1.7   thorpej  * are met:
     12   1.7   thorpej  * 1. Redistributions of source code must retain the above copyright
     13   1.7   thorpej  *    notice, this list of conditions and the following disclaimer.
     14   1.7   thorpej  * 2. Redistributions in binary form must reproduce the above copyright
     15   1.7   thorpej  *    notice, this list of conditions and the following disclaimer in the
     16   1.7   thorpej  *    documentation and/or other materials provided with the distribution.
     17   1.7   thorpej  * 3. All advertising materials mentioning features or use of this software
     18   1.7   thorpej  *    must display the following acknowledgement:
     19   1.7   thorpej  *	This product includes software developed for the NetBSD Project by
     20   1.7   thorpej  *	Wasabi Systems, Inc.
     21   1.7   thorpej  * 4. The name of Wasabi Systems, Inc. may not be used to endorse
     22   1.7   thorpej  *    or promote products derived from this software without specific prior
     23   1.7   thorpej  *    written permission.
     24   1.7   thorpej  *
     25   1.7   thorpej  * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
     26   1.7   thorpej  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     27   1.7   thorpej  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     28   1.7   thorpej  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL WASABI SYSTEMS, INC
     29   1.7   thorpej  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     30   1.7   thorpej  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     31   1.7   thorpej  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     32   1.7   thorpej  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     33   1.7   thorpej  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     34   1.7   thorpej  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     35   1.7   thorpej  * POSSIBILITY OF SUCH DAMAGE.
     36   1.7   thorpej  */
     37   1.5       cgd 
     38   1.1       cgd /*
     39   1.1       cgd  * Copyright (c) 1993 Christopher G. Demetriou
     40   1.1       cgd  * All rights reserved.
     41   1.1       cgd  *
     42   1.1       cgd  * Redistribution and use in source and binary forms, with or without
     43   1.1       cgd  * modification, are permitted provided that the following conditions
     44   1.1       cgd  * are met:
     45   1.1       cgd  * 1. Redistributions of source code must retain the above copyright
     46   1.1       cgd  *    notice, this list of conditions and the following disclaimer.
     47   1.1       cgd  * 2. Redistributions in binary form must reproduce the above copyright
     48   1.1       cgd  *    notice, this list of conditions and the following disclaimer in the
     49   1.1       cgd  *    documentation and/or other materials provided with the distribution.
     50   1.1       cgd  * 3. All advertising materials mentioning features or use of this software
     51   1.1       cgd  *    must display the following acknowledgement:
     52   1.1       cgd  *      This product includes software developed by Christopher G. Demetriou.
     53   1.1       cgd  * 4. The name of the author may not be used to endorse or promote products
     54   1.4       jtc  *    derived from this software without specific prior written permission
     55   1.1       cgd  *
     56   1.1       cgd  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     57   1.1       cgd  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     58   1.1       cgd  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     59   1.1       cgd  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     60   1.1       cgd  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     61   1.1       cgd  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     62   1.1       cgd  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     63   1.1       cgd  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     64   1.1       cgd  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     65   1.1       cgd  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     66   1.1       cgd  */
     67   1.1       cgd 
     68   1.7   thorpej #ifndef _I386_PTRACE_H_
     69   1.7   thorpej #define	_I386_PTRACE_H_
     70   1.7   thorpej 
     71   1.1       cgd /*
     72   1.1       cgd  * i386-dependent ptrace definitions
     73   1.1       cgd  */
     74   1.2       cgd #define	PT_STEP		(PT_FIRSTMACH + 0)
     75   1.2       cgd #define	PT_GETREGS	(PT_FIRSTMACH + 1)
     76   1.2       cgd #define	PT_SETREGS	(PT_FIRSTMACH + 2)
     77   1.2       cgd #define	PT_GETFPREGS	(PT_FIRSTMACH + 3)
     78   1.2       cgd #define	PT_SETFPREGS	(PT_FIRSTMACH + 4)
     79   1.7   thorpej 
     80   1.7   thorpej /* We have machine-dependent process tracing needs. */
     81   1.7   thorpej #define	__HAVE_PTRACE_MACHDEP
     82   1.7   thorpej 
     83   1.7   thorpej /* We have machine-dependent procfs nodes. */
     84   1.7   thorpej #define	__HAVE_PROCFS_MACHDEP
     85   1.7   thorpej 
     86   1.7   thorpej /* The machine-dependent ptrace(2) requests. */
     87  1.16     kamil #define	PT_GETXMMREGS		(PT_FIRSTMACH + 5)
     88  1.16     kamil #define	PT_SETXMMREGS		(PT_FIRSTMACH + 6)
     89  1.16     kamil #define PT_READ_WATCHPOINT	(PT_FIRSTMACH + 7)
     90  1.16     kamil #define PT_WRITE_WATCHPOINT	(PT_FIRSTMACH + 8)
     91  1.16     kamil #define PT_COUNT_WATCHPOINTS	(PT_FIRSTMACH + 9)
     92   1.7   thorpej 
     93  1.13  christos #define PT_MACHDEP_STRINGS \
     94  1.13  christos 	"PT_STEP", \
     95  1.13  christos 	"PT_GETREGS", \
     96  1.13  christos 	"PT_SETREGS", \
     97  1.13  christos 	"PT_GETFPREGS", \
     98  1.13  christos 	"PT_SETFPREGS", \
     99  1.13  christos 	"PT_GETXMMREGS", \
    100  1.16     kamil 	"PT_SETXMMREGS", \
    101  1.16     kamil 	"PT_READ_WATCHPOINT", \
    102  1.16     kamil 	"PT_WRITE_WATCHPOINT", \
    103  1.16     kamil 	"PT_COUNT_WATCHPOINTS"
    104  1.13  christos 
    105  1.14  christos #include <machine/reg.h>
    106  1.14  christos #define PTRACE_REG_PC(r)	(r)->r_eip
    107  1.14  christos #define PTRACE_REG_SET_PC(r, v)	(r)->r_eip = (v)
    108  1.14  christos #define PTRACE_REG_SP(r)	(r)->r_esp
    109  1.14  christos #define PTRACE_REG_INTRV(r)	(r)->r_eax
    110  1.14  christos 
    111  1.15  christos #define PTRACE_BREAKPOINT	((const uint8_t[]) { 0xcc })
    112  1.15  christos #define PTRACE_BREAKPOINT_SIZE	1
    113  1.15  christos #define PTRACE_BREAKPOINT_ADJ	sizeof(PTRACE_BREAKPOINT)
    114  1.15  christos 
    115  1.16     kamil #define __HAVE_PTRACE_WATCHPOINTS
    116  1.16     kamil 
    117  1.16     kamil /*
    118  1.16     kamil  * This MD structure translates into x86_hw_watchpoint
    119  1.16     kamil  *
    120  1.16     kamil  * pw_address - 0 represents disabled hardware watchpoint
    121  1.16     kamil  *
    122  1.16     kamil  * conditions:
    123  1.16     kamil  *     0b00 - execution
    124  1.16     kamil  *     0b01 - data write
    125  1.16     kamil  *     0b10 - io read/write (not implemented)
    126  1.16     kamil  *     0b11 - data read/write
    127  1.16     kamil  *
    128  1.16     kamil  * length:
    129  1.16     kamil  *     0b00 - 1 byte
    130  1.16     kamil  *     0b01 - 2 bytes
    131  1.16     kamil  *     0b10 - undefined
    132  1.16     kamil  *     0b11 - 4 bytes
    133  1.16     kamil  *
    134  1.16     kamil  * Helper symbols for conditions and length are available in <x86/dbregs.h>
    135  1.16     kamil  *
    136  1.16     kamil  */
    137  1.16     kamil struct mdpw {
    138  1.16     kamil 	void	*md_address;
    139  1.16     kamil 	int	 md_condition;
    140  1.16     kamil 	int	 md_length;
    141  1.16     kamil };
    142  1.16     kamil 
    143   1.7   thorpej #ifdef _KERNEL
    144   1.7   thorpej 
    145   1.7   thorpej /*
    146   1.7   thorpej  * These are used in sys_ptrace() to find good ptrace(2) requests.
    147   1.7   thorpej  */
    148   1.7   thorpej #define	PTRACE_MACHDEP_REQUEST_CASES					\
    149   1.7   thorpej 	case PT_GETXMMREGS:						\
    150   1.7   thorpej 	case PT_SETXMMREGS:
    151   1.7   thorpej 
    152   1.7   thorpej /*
    153   1.7   thorpej  * These are used to define machine-dependent procfs node types.
    154   1.7   thorpej  */
    155   1.7   thorpej #define	PROCFS_MACHDEP_NODE_TYPES					\
    156   1.7   thorpej 	Pmachdep_xmmregs,	/* extended FP register set */
    157   1.7   thorpej 
    158   1.7   thorpej /*
    159   1.7   thorpej  * These are used in switch statements to catch machine-dependent
    160   1.7   thorpej  * procfs node types.
    161   1.7   thorpej  */
    162   1.7   thorpej #define	PROCFS_MACHDEP_NODETYPE_CASES					\
    163   1.7   thorpej 	case Pmachdep_xmmregs:
    164   1.7   thorpej 
    165   1.7   thorpej /*
    166   1.7   thorpej  * These are used to protect a privileged process's state.
    167   1.7   thorpej  */
    168   1.7   thorpej #define	PROCFS_MACHDEP_PROTECT_CASES					\
    169   1.7   thorpej 	case Pmachdep_xmmregs:
    170   1.7   thorpej 
    171   1.7   thorpej /*
    172   1.7   thorpej  * These are used to define the machine-dependent procfs nodes.
    173   1.7   thorpej  */
    174   1.7   thorpej #define	PROCFS_MACHDEP_NODETYPE_DEFNS					\
    175   1.7   thorpej 	{ DT_REG, N("xmmregs"), Pmachdep_xmmregs,			\
    176   1.7   thorpej 	  procfs_machdep_validxmmregs },
    177   1.7   thorpej 
    178   1.7   thorpej struct xmmregs;
    179   1.7   thorpej 
    180   1.8   thorpej /* Functions used by both ptrace(2) and procfs. */
    181  1.12  christos int	process_machdep_doxmmregs(struct lwp *, struct lwp *, struct uio *);
    182   1.8   thorpej int	process_machdep_validxmmregs(struct proc *);
    183   1.8   thorpej 
    184   1.8   thorpej /* Functions used by procfs. */
    185   1.7   thorpej struct mount;
    186   1.7   thorpej struct pfsnode;
    187  1.12  christos int	procfs_machdep_doxmmregs(struct lwp *, struct lwp *,
    188   1.7   thorpej 	    struct pfsnode *, struct uio *);
    189  1.12  christos int	procfs_machdep_validxmmregs(struct lwp *, struct mount *);
    190   1.7   thorpej 
    191   1.7   thorpej #endif /* _KERNEL */
    192   1.7   thorpej 
    193   1.7   thorpej #endif /* _I386_PTRACE_H_ */
    194