ptrace.h revision 1.23.4.1 1 1.23.4.1 ad /* $NetBSD: ptrace.h,v 1.23.4.1 2020/01/17 21:47:25 ad 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.23 mgorny #define PT_GETXSTATE (PT_FIRSTMACH + 11)
94 1.23 mgorny #define PT_SETXSTATE (PT_FIRSTMACH + 12)
95 1.7 thorpej
96 1.13 christos #define PT_MACHDEP_STRINGS \
97 1.13 christos "PT_STEP", \
98 1.13 christos "PT_GETREGS", \
99 1.13 christos "PT_SETREGS", \
100 1.13 christos "PT_GETFPREGS", \
101 1.13 christos "PT_SETFPREGS", \
102 1.13 christos "PT_GETXMMREGS", \
103 1.16 kamil "PT_SETXMMREGS", \
104 1.18 kamil "PT_GETDBREGS", \
105 1.19 kamil "PT_SETDBREGS", \
106 1.19 kamil "PT_SETSTEP", \
107 1.23 mgorny "PT_CLEARSTEP", \
108 1.23 mgorny "PT_GETXSTATE", \
109 1.23 mgorny "PT_SETXSTATE"
110 1.13 christos
111 1.14 christos #include <machine/reg.h>
112 1.14 christos #define PTRACE_REG_PC(r) (r)->r_eip
113 1.22 kamil #define PTRACE_REG_FP(r) (r)->r_ebp
114 1.14 christos #define PTRACE_REG_SET_PC(r, v) (r)->r_eip = (v)
115 1.14 christos #define PTRACE_REG_SP(r) (r)->r_esp
116 1.14 christos #define PTRACE_REG_INTRV(r) (r)->r_eax
117 1.14 christos
118 1.21 kamil #define PTRACE_ILLEGAL_ASM __asm __volatile ("ud2" : : : "memory")
119 1.21 kamil
120 1.15 christos #define PTRACE_BREAKPOINT ((const uint8_t[]) { 0xcc })
121 1.20 kamil #define PTRACE_BREAKPOINT_ASM __asm __volatile ("int3" : : : "memory")
122 1.15 christos #define PTRACE_BREAKPOINT_SIZE 1
123 1.15 christos #define PTRACE_BREAKPOINT_ADJ sizeof(PTRACE_BREAKPOINT)
124 1.15 christos
125 1.7 thorpej #ifdef _KERNEL
126 1.7 thorpej
127 1.7 thorpej /*
128 1.7 thorpej * These are used in sys_ptrace() to find good ptrace(2) requests.
129 1.7 thorpej */
130 1.7 thorpej #define PTRACE_MACHDEP_REQUEST_CASES \
131 1.7 thorpej case PT_GETXMMREGS: \
132 1.23 mgorny case PT_SETXMMREGS: \
133 1.23 mgorny case PT_GETXSTATE: \
134 1.23 mgorny case PT_SETXSTATE:
135 1.7 thorpej
136 1.7 thorpej /*
137 1.7 thorpej * These are used to define machine-dependent procfs node types.
138 1.7 thorpej */
139 1.7 thorpej #define PROCFS_MACHDEP_NODE_TYPES \
140 1.7 thorpej Pmachdep_xmmregs, /* extended FP register set */
141 1.7 thorpej
142 1.7 thorpej /*
143 1.7 thorpej * These are used in switch statements to catch machine-dependent
144 1.7 thorpej * procfs node types.
145 1.7 thorpej */
146 1.7 thorpej #define PROCFS_MACHDEP_NODETYPE_CASES \
147 1.7 thorpej case Pmachdep_xmmregs:
148 1.7 thorpej
149 1.7 thorpej /*
150 1.7 thorpej * These are used to protect a privileged process's state.
151 1.7 thorpej */
152 1.7 thorpej #define PROCFS_MACHDEP_PROTECT_CASES \
153 1.7 thorpej case Pmachdep_xmmregs:
154 1.7 thorpej
155 1.7 thorpej /*
156 1.7 thorpej * These are used to define the machine-dependent procfs nodes.
157 1.7 thorpej */
158 1.7 thorpej #define PROCFS_MACHDEP_NODETYPE_DEFNS \
159 1.7 thorpej { DT_REG, N("xmmregs"), Pmachdep_xmmregs, \
160 1.7 thorpej procfs_machdep_validxmmregs },
161 1.7 thorpej
162 1.23.4.1 ad #define PT32_GETXSTATE PT_GETXSTATE
163 1.23.4.1 ad #define COREDUMP_MACHDEP_LWP_NOTES(l, ns, name) \
164 1.23.4.1 ad { \
165 1.23.4.1 ad struct xstate xstate; \
166 1.23.4.1 ad memset(&xstate, 0, sizeof(xstate)); \
167 1.23.4.1 ad if (!process_read_xstate(l, &xstate)) \
168 1.23.4.1 ad { \
169 1.23.4.1 ad ELFNAMEEND(coredump_savenote)(ns, \
170 1.23.4.1 ad CONCAT(CONCAT(PT, ELFSIZE), _GETXSTATE), name, \
171 1.23.4.1 ad &xstate, sizeof(xstate)); \
172 1.23.4.1 ad } \
173 1.23.4.1 ad }
174 1.23.4.1 ad
175 1.7 thorpej struct xmmregs;
176 1.7 thorpej
177 1.8 thorpej /* Functions used by both ptrace(2) and procfs. */
178 1.12 christos int process_machdep_doxmmregs(struct lwp *, struct lwp *, struct uio *);
179 1.8 thorpej int process_machdep_validxmmregs(struct proc *);
180 1.23 mgorny int process_machdep_doxstate(struct lwp *, struct lwp *, struct uio *);
181 1.23 mgorny int process_machdep_validxstate(struct proc *);
182 1.8 thorpej
183 1.8 thorpej /* Functions used by procfs. */
184 1.7 thorpej struct mount;
185 1.7 thorpej struct pfsnode;
186 1.12 christos int procfs_machdep_doxmmregs(struct lwp *, struct lwp *,
187 1.7 thorpej struct pfsnode *, struct uio *);
188 1.12 christos int procfs_machdep_validxmmregs(struct lwp *, struct mount *);
189 1.7 thorpej
190 1.7 thorpej #endif /* _KERNEL */
191 1.7 thorpej
192 1.7 thorpej #endif /* _I386_PTRACE_H_ */
193