ptrace.h revision 1.21 1 1.21 kamil /* $NetBSD: ptrace.h,v 1.21 2019/06/17 14:31:51 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.18 kamil #define PT_GETDBREGS (PT_FIRSTMACH + 7)
90 1.18 kamil #define PT_SETDBREGS (PT_FIRSTMACH + 8)
91 1.19 kamil #define PT_SETSTEP (PT_FIRSTMACH + 9)
92 1.19 kamil #define PT_CLEARSTEP (PT_FIRSTMACH + 10)
93 1.7 thorpej
94 1.13 christos #define PT_MACHDEP_STRINGS \
95 1.13 christos "PT_STEP", \
96 1.13 christos "PT_GETREGS", \
97 1.13 christos "PT_SETREGS", \
98 1.13 christos "PT_GETFPREGS", \
99 1.13 christos "PT_SETFPREGS", \
100 1.13 christos "PT_GETXMMREGS", \
101 1.16 kamil "PT_SETXMMREGS", \
102 1.18 kamil "PT_GETDBREGS", \
103 1.19 kamil "PT_SETDBREGS", \
104 1.19 kamil "PT_SETSTEP", \
105 1.19 kamil "PT_CLEARSTEP",
106 1.18 kamil
107 1.13 christos
108 1.14 christos #include <machine/reg.h>
109 1.14 christos #define PTRACE_REG_PC(r) (r)->r_eip
110 1.14 christos #define PTRACE_REG_SET_PC(r, v) (r)->r_eip = (v)
111 1.14 christos #define PTRACE_REG_SP(r) (r)->r_esp
112 1.14 christos #define PTRACE_REG_INTRV(r) (r)->r_eax
113 1.14 christos
114 1.21 kamil #define PTRACE_ILLEGAL_ASM __asm __volatile ("ud2" : : : "memory")
115 1.21 kamil
116 1.15 christos #define PTRACE_BREAKPOINT ((const uint8_t[]) { 0xcc })
117 1.20 kamil #define PTRACE_BREAKPOINT_ASM __asm __volatile ("int3" : : : "memory")
118 1.15 christos #define PTRACE_BREAKPOINT_SIZE 1
119 1.15 christos #define PTRACE_BREAKPOINT_ADJ sizeof(PTRACE_BREAKPOINT)
120 1.15 christos
121 1.7 thorpej #ifdef _KERNEL
122 1.7 thorpej
123 1.7 thorpej /*
124 1.7 thorpej * These are used in sys_ptrace() to find good ptrace(2) requests.
125 1.7 thorpej */
126 1.7 thorpej #define PTRACE_MACHDEP_REQUEST_CASES \
127 1.7 thorpej case PT_GETXMMREGS: \
128 1.7 thorpej case PT_SETXMMREGS:
129 1.7 thorpej
130 1.7 thorpej /*
131 1.7 thorpej * These are used to define machine-dependent procfs node types.
132 1.7 thorpej */
133 1.7 thorpej #define PROCFS_MACHDEP_NODE_TYPES \
134 1.7 thorpej Pmachdep_xmmregs, /* extended FP register set */
135 1.7 thorpej
136 1.7 thorpej /*
137 1.7 thorpej * These are used in switch statements to catch machine-dependent
138 1.7 thorpej * procfs node types.
139 1.7 thorpej */
140 1.7 thorpej #define PROCFS_MACHDEP_NODETYPE_CASES \
141 1.7 thorpej case Pmachdep_xmmregs:
142 1.7 thorpej
143 1.7 thorpej /*
144 1.7 thorpej * These are used to protect a privileged process's state.
145 1.7 thorpej */
146 1.7 thorpej #define PROCFS_MACHDEP_PROTECT_CASES \
147 1.7 thorpej case Pmachdep_xmmregs:
148 1.7 thorpej
149 1.7 thorpej /*
150 1.7 thorpej * These are used to define the machine-dependent procfs nodes.
151 1.7 thorpej */
152 1.7 thorpej #define PROCFS_MACHDEP_NODETYPE_DEFNS \
153 1.7 thorpej { DT_REG, N("xmmregs"), Pmachdep_xmmregs, \
154 1.7 thorpej procfs_machdep_validxmmregs },
155 1.7 thorpej
156 1.7 thorpej struct xmmregs;
157 1.7 thorpej
158 1.8 thorpej /* Functions used by both ptrace(2) and procfs. */
159 1.12 christos int process_machdep_doxmmregs(struct lwp *, struct lwp *, struct uio *);
160 1.8 thorpej int process_machdep_validxmmregs(struct proc *);
161 1.8 thorpej
162 1.8 thorpej /* Functions used by procfs. */
163 1.7 thorpej struct mount;
164 1.7 thorpej struct pfsnode;
165 1.12 christos int procfs_machdep_doxmmregs(struct lwp *, struct lwp *,
166 1.7 thorpej struct pfsnode *, struct uio *);
167 1.12 christos int procfs_machdep_validxmmregs(struct lwp *, struct mount *);
168 1.7 thorpej
169 1.7 thorpej #endif /* _KERNEL */
170 1.7 thorpej
171 1.7 thorpej #endif /* _I386_PTRACE_H_ */
172