reg.h revision 1.16 1 1.16 thorpej /* $NetBSD: reg.h,v 1.16 2004/08/28 21:31:07 thorpej Exp $ */
2 1.8 cgd
3 1.1 cgd /*
4 1.1 cgd * Copyright (c) 1982, 1986, 1990 The Regents of the University of California.
5 1.1 cgd * All rights reserved.
6 1.15 agc *
7 1.15 agc * This code is derived from software contributed to Berkeley by
8 1.15 agc * the Systems Programming Group of the University of Utah Computer
9 1.15 agc * Science Department.
10 1.15 agc *
11 1.15 agc * Redistribution and use in source and binary forms, with or without
12 1.15 agc * modification, are permitted provided that the following conditions
13 1.15 agc * are met:
14 1.15 agc * 1. Redistributions of source code must retain the above copyright
15 1.15 agc * notice, this list of conditions and the following disclaimer.
16 1.15 agc * 2. Redistributions in binary form must reproduce the above copyright
17 1.15 agc * notice, this list of conditions and the following disclaimer in the
18 1.15 agc * documentation and/or other materials provided with the distribution.
19 1.15 agc * 3. Neither the name of the University nor the names of its contributors
20 1.15 agc * may be used to endorse or promote products derived from this software
21 1.15 agc * without specific prior written permission.
22 1.15 agc *
23 1.15 agc * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.15 agc * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.15 agc * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.15 agc * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.15 agc * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.15 agc * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.15 agc * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.15 agc * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.15 agc * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.15 agc * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.15 agc * SUCH DAMAGE.
34 1.15 agc *
35 1.15 agc * from: Utah Hdr: reg.h 1.1 90/07/09
36 1.15 agc *
37 1.15 agc * @(#)reg.h 7.2 (Berkeley) 11/3/90
38 1.15 agc */
39 1.15 agc /*
40 1.15 agc * Copyright (c) 1988 University of Utah.
41 1.1 cgd *
42 1.1 cgd * This code is derived from software contributed to Berkeley by
43 1.1 cgd * the Systems Programming Group of the University of Utah Computer
44 1.1 cgd * Science Department.
45 1.1 cgd *
46 1.1 cgd * Redistribution and use in source and binary forms, with or without
47 1.1 cgd * modification, are permitted provided that the following conditions
48 1.1 cgd * are met:
49 1.1 cgd * 1. Redistributions of source code must retain the above copyright
50 1.1 cgd * notice, this list of conditions and the following disclaimer.
51 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
52 1.1 cgd * notice, this list of conditions and the following disclaimer in the
53 1.1 cgd * documentation and/or other materials provided with the distribution.
54 1.1 cgd * 3. All advertising materials mentioning features or use of this software
55 1.1 cgd * must display the following acknowledgement:
56 1.1 cgd * This product includes software developed by the University of
57 1.1 cgd * California, Berkeley and its contributors.
58 1.1 cgd * 4. Neither the name of the University nor the names of its contributors
59 1.1 cgd * may be used to endorse or promote products derived from this software
60 1.1 cgd * without specific prior written permission.
61 1.1 cgd *
62 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
63 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
64 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
65 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
66 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
67 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
68 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
69 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
70 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
71 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
72 1.1 cgd * SUCH DAMAGE.
73 1.1 cgd *
74 1.8 cgd * from: Utah Hdr: reg.h 1.1 90/07/09
75 1.8 cgd *
76 1.8 cgd * @(#)reg.h 7.2 (Berkeley) 11/3/90
77 1.1 cgd */
78 1.1 cgd
79 1.7 cgd #ifndef _M68K_REG_H_
80 1.7 cgd #define _M68K_REG_H_
81 1.5 mycroft
82 1.1 cgd /*
83 1.5 mycroft * Register set accessible via /proc/$pid/reg and ptrace()
84 1.1 cgd */
85 1.5 mycroft struct reg {
86 1.5 mycroft int r_regs[16]; /* D0-D7/A0-A7 */
87 1.9 mycroft int r_sr;
88 1.5 mycroft int r_pc;
89 1.10 mycroft };
90 1.10 mycroft
91 1.10 mycroft struct fpreg {
92 1.10 mycroft int r_regs[8*3]; /* FP0-FP7 */
93 1.10 mycroft int r_fpcr;
94 1.10 mycroft int r_fpsr;
95 1.10 mycroft int r_fpiar;
96 1.5 mycroft };
97 1.6 mycroft
98 1.7 cgd /* XXXX this is historical (but it can't be deprecated quite yet) */
99 1.6 mycroft
100 1.6 mycroft /*
101 1.6 mycroft * Location of the users' stored
102 1.6 mycroft * registers relative to D0.
103 1.6 mycroft * Usage is u.u_ar0[XX].
104 1.6 mycroft */
105 1.6 mycroft #define D0 (0)
106 1.6 mycroft #define D1 (1)
107 1.6 mycroft #define D2 (2)
108 1.6 mycroft #define D3 (3)
109 1.6 mycroft #define D4 (4)
110 1.6 mycroft #define D5 (5)
111 1.6 mycroft #define D6 (6)
112 1.6 mycroft #define D7 (7)
113 1.6 mycroft #define A0 (8)
114 1.6 mycroft #define A1 (9)
115 1.6 mycroft #define A2 (10)
116 1.6 mycroft #define A3 (11)
117 1.6 mycroft #define A4 (12)
118 1.6 mycroft #define A5 (13)
119 1.6 mycroft #define A6 (14)
120 1.6 mycroft #define A7 (15)
121 1.6 mycroft
122 1.13 kleink #define FP A6
123 1.6 mycroft #define SP A7
124 1.9 mycroft #define PS (16)
125 1.6 mycroft #define PC (17)
126 1.6 mycroft
127 1.11 briggs #ifdef _KERNEL
128 1.6 mycroft /*
129 1.6 mycroft * Due to a mental lapse somewhere down the line, wait returns its values
130 1.6 mycroft * in strange registers. Kludge it up here so we don't have to in the
131 1.6 mycroft * machine-independent code.
132 1.6 mycroft */
133 1.6 mycroft #define R0 D1
134 1.6 mycroft #define R1 A0
135 1.12 gwr
136 1.14 thorpej struct lwp;
137 1.16 thorpej int process_read_regs(struct lwp *, struct reg *);
138 1.16 thorpej int process_read_fpregs(struct lwp *, struct fpreg *);
139 1.12 gwr
140 1.6 mycroft #endif
141 1.4 mycroft
142 1.7 cgd #endif /* !_M68K_REG_H_ */
143