1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
|
/* OBSOLETE /* Native-dependent code for GDB, for NYU Ultra3 running Sym1 OS. */
/* OBSOLETE Copyright 1988, 1989, 1991, 1992, 1995, 1996, 1999, 2000, 2001 */
/* OBSOLETE Free Software Foundation, Inc. */
/* OBSOLETE Contributed by David Wood (wood@nyu.edu) at New York University. */
/* OBSOLETE */
/* OBSOLETE This file is part of GDB. */
/* OBSOLETE */
/* OBSOLETE This program is free software; you can redistribute it and/or modify */
/* OBSOLETE it under the terms of the GNU General Public License as published by */
/* OBSOLETE the Free Software Foundation; either version 2 of the License, or */
/* OBSOLETE (at your option) any later version. */
/* OBSOLETE */
/* OBSOLETE This program is distributed in the hope that it will be useful, */
/* OBSOLETE but WITHOUT ANY WARRANTY; without even the implied warranty of */
/* OBSOLETE MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
/* OBSOLETE GNU General Public License for more details. */
/* OBSOLETE */
/* OBSOLETE You should have received a copy of the GNU General Public License */
/* OBSOLETE along with this program; if not, write to the Free Software */
/* OBSOLETE Foundation, Inc., 59 Temple Place - Suite 330, */
/* OBSOLETE Boston, MA 02111-1307, USA. */ */
/* OBSOLETE */
/* OBSOLETE #define DEBUG */
/* OBSOLETE #include "defs.h" */
/* OBSOLETE #include "frame.h" */
/* OBSOLETE #include "inferior.h" */
/* OBSOLETE #include "symtab.h" */
/* OBSOLETE #include "value.h" */
/* OBSOLETE #include "regcache.h" */
/* OBSOLETE */
/* OBSOLETE #include <sys/types.h> */
/* OBSOLETE #include <sys/param.h> */
/* OBSOLETE #include <signal.h> */
/* OBSOLETE #include <sys/ioctl.h> */
/* OBSOLETE #include <fcntl.h> */
/* OBSOLETE */
/* OBSOLETE #include "gdbcore.h" */
/* OBSOLETE */
/* OBSOLETE #include <sys/file.h> */
/* OBSOLETE #include "gdb_stat.h" */
/* OBSOLETE */
/* OBSOLETE static void fetch_core_registers (char *, unsigned, int, CORE_ADDR); */
/* OBSOLETE */
/* OBSOLETE /* Assumes support for AMD's Binary Compatibility Standard */
/* OBSOLETE for ptrace(). If you define ULTRA3, the ultra3 extensions to */
/* OBSOLETE ptrace() are used allowing the reading of more than one register */
/* OBSOLETE at a time. */
/* OBSOLETE */
/* OBSOLETE This file assumes KERNEL_DEBUGGING is turned off. This means */
/* OBSOLETE that if the user/gdb tries to read gr64-gr95 or any of the */
/* OBSOLETE protected special registers we silently return -1 (see the */
/* OBSOLETE CANNOT_STORE/FETCH_REGISTER macros). */ */
/* OBSOLETE #define ULTRA3 */
/* OBSOLETE */
/* OBSOLETE #if !defined (offsetof) */
/* OBSOLETE #define offsetof(TYPE, MEMBER) ((unsigned long) &((TYPE *)0)->MEMBER) */
/* OBSOLETE #endif */
/* OBSOLETE */
/* OBSOLETE extern int errno; */
/* OBSOLETE struct ptrace_user pt_struct; */
/* OBSOLETE */
/* OBSOLETE /* Get all available registers from the inferior. Registers that are */
/* OBSOLETE * defined in REGISTER_NAMES, but not available to the user/gdb are */
/* OBSOLETE * supplied as -1. This may include gr64-gr95 and the protected special */
/* OBSOLETE * purpose registers. */
/* OBSOLETE */ */
/* OBSOLETE */
/* OBSOLETE void */
/* OBSOLETE fetch_inferior_registers (int regno) */
/* OBSOLETE { */
/* OBSOLETE register int i, j, ret_val = 0; */
/* OBSOLETE char buf[128]; */
/* OBSOLETE */
/* OBSOLETE if (regno != -1) */
/* OBSOLETE { */
/* OBSOLETE fetch_register (regno); */
/* OBSOLETE return; */
/* OBSOLETE } */
/* OBSOLETE */
/* OBSOLETE /* Global Registers */ */
/* OBSOLETE #ifdef ULTRA3 */
/* OBSOLETE errno = 0; */
/* OBSOLETE ptrace (PT_READ_STRUCT, inferior_pid, */
/* OBSOLETE (PTRACE_ARG3_TYPE) register_addr (GR96_REGNUM, 0), */
/* OBSOLETE (int) &pt_struct.pt_gr[0], 32 * 4); */
/* OBSOLETE if (errno != 0) */
/* OBSOLETE { */
/* OBSOLETE perror_with_name ("reading global registers"); */
/* OBSOLETE ret_val = -1; */
/* OBSOLETE } */
/* OBSOLETE else */
/* OBSOLETE for (regno = GR96_REGNUM, j = 0; j < 32; regno++, j++) */
/* OBSOLETE { */
/* OBSOLETE supply_register (regno, &pt_struct.pt_gr[j]); */
/* OBSOLETE } */
/* OBSOLETE #else */
/* OBSOLETE for (regno = GR96_REGNUM; !ret_val && regno < GR96_REGNUM + 32; regno++) */
/* OBSOLETE fetch_register (regno); */
/* OBSOLETE #endif */
/* OBSOLETE */
/* OBSOLETE /* Local Registers */ */
/* OBSOLETE #ifdef ULTRA3 */
/* OBSOLETE errno = 0; */
/* OBSOLETE ptrace (PT_READ_STRUCT, inferior_pid, */
/* OBSOLETE (PTRACE_ARG3_TYPE) register_addr (LR0_REGNUM, 0), */
/* OBSOLETE (int) &pt_struct.pt_lr[0], 128 * 4); */
/* OBSOLETE if (errno != 0) */
/* OBSOLETE { */
/* OBSOLETE perror_with_name ("reading local registers"); */
/* OBSOLETE ret_val = -1; */
/* OBSOLETE } */
/* OBSOLETE else */
/* OBSOLETE for (regno = LR0_REGNUM, j = 0; j < 128; regno++, j++) */
/* OBSOLETE { */
/* OBSOLETE supply_register (regno, &pt_struct.pt_lr[j]); */
/* OBSOLETE } */
/* OBSOLETE #else */
/* OBSOLETE for (regno = LR0_REGNUM; !ret_val && regno < LR0_REGNUM + 128; regno++) */
/* OBSOLETE fetch_register (regno); */
/* OBSOLETE #endif */
/* OBSOLETE */
/* OBSOLETE /* Special Registers */ */
/* OBSOLETE fetch_register (GR1_REGNUM); */
/* OBSOLETE fetch_register (CPS_REGNUM); */
/* OBSOLETE fetch_register (PC_REGNUM); */
/* OBSOLETE fetch_register (NPC_REGNUM); */
/* OBSOLETE fetch_register (PC2_REGNUM); */
/* OBSOLETE fetch_register (IPC_REGNUM); */
/* OBSOLETE fetch_register (IPA_REGNUM); */
/* OBSOLETE fetch_register (IPB_REGNUM); */
/* OBSOLETE fetch_register (Q_REGNUM); */
/* OBSOLETE fetch_register (BP_REGNUM); */
/* OBSOLETE fetch_register (FC_REGNUM); */
/* OBSOLETE */
/* OBSOLETE /* Fake any registers that are in REGISTER_NAMES, but not available to gdb */ */
/* OBSOLETE registers_fetched (); */
/* OBSOLETE } */
/* OBSOLETE */
/* OBSOLETE /* Store our register values back into the inferior. */
/* OBSOLETE * If REGNO is -1, do this for all registers. */
/* OBSOLETE * Otherwise, REGNO specifies which register (so we can save time). */
/* OBSOLETE * NOTE: Assumes AMD's binary compatibility standard. */
/* OBSOLETE */ */
/* OBSOLETE */
/* OBSOLETE void */
/* OBSOLETE store_inferior_registers (int regno) */
/* OBSOLETE { */
/* OBSOLETE register unsigned int regaddr; */
/* OBSOLETE char buf[80]; */
/* OBSOLETE */
/* OBSOLETE if (regno >= 0) */
/* OBSOLETE { */
/* OBSOLETE if (CANNOT_STORE_REGISTER (regno)) */
/* OBSOLETE return; */
/* OBSOLETE regaddr = register_addr (regno, 0); */
/* OBSOLETE errno = 0; */
/* OBSOLETE ptrace (PT_WRITE_U, inferior_pid, */
/* OBSOLETE (PTRACE_ARG3_TYPE) regaddr, read_register (regno)); */
/* OBSOLETE if (errno != 0) */
/* OBSOLETE { */
/* OBSOLETE sprintf (buf, "writing register %s (#%d)", REGISTER_NAME (regno), regno); */
/* OBSOLETE perror_with_name (buf); */
/* OBSOLETE } */
/* OBSOLETE } */
/* OBSOLETE else */
/* OBSOLETE { */
/* OBSOLETE #ifdef ULTRA3 */
/* OBSOLETE pt_struct.pt_gr1 = read_register (GR1_REGNUM); */
/* OBSOLETE for (regno = GR96_REGNUM; regno < GR96_REGNUM + 32; regno++) */
/* OBSOLETE pt_struct.pt_gr[regno] = read_register (regno); */
/* OBSOLETE for (regno = LR0_REGNUM; regno < LR0_REGNUM + 128; regno++) */
/* OBSOLETE pt_struct.pt_gr[regno] = read_register (regno); */
/* OBSOLETE errno = 0; */
/* OBSOLETE ptrace (PT_WRITE_STRUCT, inferior_pid, */
/* OBSOLETE (PTRACE_ARG3_TYPE) register_addr (GR1_REGNUM, 0), */
/* OBSOLETE (int) &pt_struct.pt_gr1, (1 * 32 * 128) * 4); */
/* OBSOLETE if (errno != 0) */
/* OBSOLETE { */
/* OBSOLETE sprintf (buf, "writing all local/global registers"); */
/* OBSOLETE perror_with_name (buf); */
/* OBSOLETE } */
/* OBSOLETE pt_struct.pt_psr = read_register (CPS_REGNUM); */
/* OBSOLETE pt_struct.pt_pc0 = read_register (NPC_REGNUM); */
/* OBSOLETE pt_struct.pt_pc1 = read_register (PC_REGNUM); */
/* OBSOLETE pt_struct.pt_pc2 = read_register (PC2_REGNUM); */
/* OBSOLETE pt_struct.pt_ipc = read_register (IPC_REGNUM); */
/* OBSOLETE pt_struct.pt_ipa = read_register (IPA_REGNUM); */
/* OBSOLETE pt_struct.pt_ipb = read_register (IPB_REGNUM); */
/* OBSOLETE pt_struct.pt_q = read_register (Q_REGNUM); */
/* OBSOLETE pt_struct.pt_bp = read_register (BP_REGNUM); */
/* OBSOLETE pt_struct.pt_fc = read_register (FC_REGNUM); */
/* OBSOLETE errno = 0; */
/* OBSOLETE ptrace (PT_WRITE_STRUCT, inferior_pid, */
/* OBSOLETE (PTRACE_ARG3_TYPE) register_addr (CPS_REGNUM, 0), */
/* OBSOLETE (int) &pt_struct.pt_psr, (10) * 4); */
/* OBSOLETE if (errno != 0) */
/* OBSOLETE { */
/* OBSOLETE sprintf (buf, "writing all special registers"); */
/* OBSOLETE perror_with_name (buf); */
/* OBSOLETE return; */
/* OBSOLETE } */
/* OBSOLETE #else */
/* OBSOLETE store_inferior_registers (GR1_REGNUM); */
/* OBSOLETE for (regno = GR96_REGNUM; regno < GR96_REGNUM + 32; regno++) */
/* OBSOLETE store_inferior_registers (regno); */
/* OBSOLETE for (regno = LR0_REGNUM; regno < LR0_REGNUM + 128; regno++) */
/* OBSOLETE store_inferior_registers (regno); */
/* OBSOLETE store_inferior_registers (CPS_REGNUM); */
/* OBSOLETE store_inferior_registers (PC_REGNUM); */
/* OBSOLETE store_inferior_registers (NPC_REGNUM); */
/* OBSOLETE store_inferior_registers (PC2_REGNUM); */
/* OBSOLETE store_inferior_registers (IPC_REGNUM); */
/* OBSOLETE store_inferior_registers (IPA_REGNUM); */
/* OBSOLETE store_inferior_registers (IPB_REGNUM); */
/* OBSOLETE store_inferior_registers (Q_REGNUM); */
/* OBSOLETE store_inferior_registers (BP_REGNUM); */
/* OBSOLETE store_inferior_registers (FC_REGNUM); */
/* OBSOLETE #endif /* ULTRA3 */ */
/* OBSOLETE } */
/* OBSOLETE } */
/* OBSOLETE */
/* OBSOLETE /* */
/* OBSOLETE * Fetch an individual register (and supply it). */
/* OBSOLETE * return 0 on success, -1 on failure. */
/* OBSOLETE * NOTE: Assumes AMD's Binary Compatibility Standard for ptrace(). */
/* OBSOLETE */ */
/* OBSOLETE static void */
/* OBSOLETE fetch_register (int regno) */
/* OBSOLETE { */
/* OBSOLETE char buf[128]; */
/* OBSOLETE int val; */
/* OBSOLETE */
/* OBSOLETE if (CANNOT_FETCH_REGISTER (regno)) */
/* OBSOLETE { */
/* OBSOLETE val = -1; */
/* OBSOLETE supply_register (regno, &val); */
/* OBSOLETE } */
/* OBSOLETE else */
/* OBSOLETE { */
/* OBSOLETE errno = 0; */
/* OBSOLETE val = ptrace (PT_READ_U, inferior_pid, */
/* OBSOLETE (PTRACE_ARG3_TYPE) register_addr (regno, 0), 0); */
/* OBSOLETE if (errno != 0) */
/* OBSOLETE { */
/* OBSOLETE sprintf (buf, "reading register %s (#%d)", REGISTER_NAME (regno), regno); */
/* OBSOLETE perror_with_name (buf); */
/* OBSOLETE } */
/* OBSOLETE else */
/* OBSOLETE { */
/* OBSOLETE supply_register (regno, &val); */
/* OBSOLETE } */
/* OBSOLETE } */
/* OBSOLETE } */
/* OBSOLETE */
/* OBSOLETE */
/* OBSOLETE /* */
/* OBSOLETE * Read AMD's Binary Compatibilty Standard conforming core file. */
/* OBSOLETE * struct ptrace_user is the first thing in the core file */
/* OBSOLETE * */
/* OBSOLETE * CORE_REG_SECT, CORE_REG_SIZE, WHICH, and REG_ADDR are all ignored. */
/* OBSOLETE */ */
/* OBSOLETE */
/* OBSOLETE static void */
/* OBSOLETE fetch_core_registers (char *core_reg_sect, unsigned core_reg_size, */
/* OBSOLETE int which, CORE_ADDR reg_addr) */
/* OBSOLETE { */
/* OBSOLETE register int regno; */
/* OBSOLETE int val; */
/* OBSOLETE char buf[4]; */
/* OBSOLETE */
/* OBSOLETE for (regno = 0; regno < NUM_REGS; regno++) */
/* OBSOLETE { */
/* OBSOLETE if (!CANNOT_FETCH_REGISTER (regno)) */
/* OBSOLETE { */
/* OBSOLETE val = bfd_seek (core_bfd, (file_ptr) register_addr (regno, 0), SEEK_SET); */
/* OBSOLETE if (val < 0 || (val = bfd_read (buf, sizeof buf, 1, core_bfd)) < 0) */
/* OBSOLETE { */
/* OBSOLETE char *buffer = (char *) alloca (strlen (REGISTER_NAME (regno)) + 35); */
/* OBSOLETE strcpy (buffer, "Reading core register "); */
/* OBSOLETE strcat (buffer, REGISTER_NAME (regno)); */
/* OBSOLETE perror_with_name (buffer); */
/* OBSOLETE } */
/* OBSOLETE supply_register (regno, buf); */
/* OBSOLETE } */
/* OBSOLETE } */
/* OBSOLETE */
/* OBSOLETE /* Fake any registers that are in REGISTER_NAMES, but not available to gdb */ */
/* OBSOLETE registers_fetched (); */
/* OBSOLETE } */
/* OBSOLETE */
/* OBSOLETE */
/* OBSOLETE /* */
/* OBSOLETE * Takes a register number as defined in tm.h via REGISTER_NAMES, and maps */
/* OBSOLETE * it to an offset in a struct ptrace_user defined by AMD's BCS. */
/* OBSOLETE * That is, it defines the mapping between gdb register numbers and items in */
/* OBSOLETE * a struct ptrace_user. */
/* OBSOLETE * A register protection scheme is set up here. If a register not */
/* OBSOLETE * available to the user is specified in 'regno', then an address that */
/* OBSOLETE * will cause ptrace() to fail is returned. */
/* OBSOLETE */ */
/* OBSOLETE CORE_ADDR */
/* OBSOLETE register_addr (int regno, CORE_ADDR blockend) */
/* OBSOLETE { */
/* OBSOLETE if ((regno >= LR0_REGNUM) && (regno < LR0_REGNUM + 128)) */
/* OBSOLETE { */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_lr[regno - LR0_REGNUM])); */
/* OBSOLETE } */
/* OBSOLETE else if ((regno >= GR96_REGNUM) && (regno < GR96_REGNUM + 32)) */
/* OBSOLETE { */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_gr[regno - GR96_REGNUM])); */
/* OBSOLETE } */
/* OBSOLETE else */
/* OBSOLETE { */
/* OBSOLETE switch (regno) */
/* OBSOLETE { */
/* OBSOLETE case GR1_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_gr1)); */
/* OBSOLETE case CPS_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_psr)); */
/* OBSOLETE case NPC_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_pc0)); */
/* OBSOLETE case PC_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_pc1)); */
/* OBSOLETE case PC2_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_pc2)); */
/* OBSOLETE case IPC_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_ipc)); */
/* OBSOLETE case IPA_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_ipa)); */
/* OBSOLETE case IPB_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_ipb)); */
/* OBSOLETE case Q_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_q)); */
/* OBSOLETE case BP_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_bp)); */
/* OBSOLETE case FC_REGNUM: */
/* OBSOLETE return (offsetof (struct ptrace_user, pt_fc)); */
/* OBSOLETE default: */
/* OBSOLETE fprintf_filtered (gdb_stderr, "register_addr():Bad register %s (%d)\n", */
/* OBSOLETE REGISTER_NAME (regno), regno); */
/* OBSOLETE return (0xffffffff); /* Should make ptrace() fail */ */
/* OBSOLETE } */
/* OBSOLETE } */
/* OBSOLETE } */
/* OBSOLETE */
/* OBSOLETE */
/* OBSOLETE /* Register that we are able to handle ultra3 core file formats. */
/* OBSOLETE FIXME: is this really bfd_target_unknown_flavour? */ */
/* OBSOLETE */
/* OBSOLETE static struct core_fns ultra3_core_fns = */
/* OBSOLETE { */
/* OBSOLETE bfd_target_unknown_flavour, /* core_flavour */ */
/* OBSOLETE default_check_format, /* check_format */ */
/* OBSOLETE default_core_sniffer, /* core_sniffer */ */
/* OBSOLETE fetch_core_registers, /* core_read_registers */ */
/* OBSOLETE NULL /* next */ */
/* OBSOLETE }; */
/* OBSOLETE */
/* OBSOLETE void */
/* OBSOLETE _initialize_core_ultra3 (void) */
/* OBSOLETE { */
/* OBSOLETE add_core_fns (&ultra3_core_fns); */
/* OBSOLETE } */
|