2003-06-01 Andrew Cagney <cagney@redhat.com>
[deliverable/binutils-gdb.git] / gdb / vax-tdep.c
1 /* Print VAX instructions for GDB, the GNU debugger.
2 Copyright 1986, 1989, 1991, 1992, 1995, 1996, 1998, 1999, 2000, 2002, 2003
3 Free Software Foundation, Inc.
4
5 This file is part of GDB.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA. */
21
22 #include "defs.h"
23 #include "symtab.h"
24 #include "opcode/vax.h"
25 #include "gdbcore.h"
26 #include "inferior.h"
27 #include "regcache.h"
28 #include "frame.h"
29 #include "value.h"
30 #include "arch-utils.h"
31 #include "gdb_string.h"
32 #include "osabi.h"
33
34 #include "vax-tdep.h"
35
36 static gdbarch_register_name_ftype vax_register_name;
37 static gdbarch_register_byte_ftype vax_register_byte;
38 static gdbarch_register_raw_size_ftype vax_register_raw_size;
39 static gdbarch_register_virtual_size_ftype vax_register_virtual_size;
40 static gdbarch_register_virtual_type_ftype vax_register_virtual_type;
41
42 static gdbarch_skip_prologue_ftype vax_skip_prologue;
43 static gdbarch_frame_num_args_ftype vax_frame_num_args;
44 static gdbarch_deprecated_frame_chain_ftype vax_frame_chain;
45 static gdbarch_frame_args_address_ftype vax_frame_args_address;
46 static gdbarch_frame_locals_address_ftype vax_frame_locals_address;
47
48 static gdbarch_deprecated_extract_return_value_ftype vax_extract_return_value;
49 static gdbarch_deprecated_extract_struct_value_address_ftype
50 vax_extract_struct_value_address;
51
52 static gdbarch_deprecated_push_dummy_frame_ftype vax_push_dummy_frame;
53 \f
54 static const char *
55 vax_register_name (int regno)
56 {
57 static char *register_names[] =
58 {
59 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
60 "r8", "r9", "r10", "r11", "ap", "fp", "sp", "pc",
61 "ps",
62 };
63
64 if (regno < 0)
65 return (NULL);
66 if (regno >= (sizeof(register_names) / sizeof(*register_names)))
67 return (NULL);
68 return (register_names[regno]);
69 }
70
71 static int
72 vax_register_byte (int regno)
73 {
74 return (regno * 4);
75 }
76
77 static int
78 vax_register_raw_size (int regno)
79 {
80 return (4);
81 }
82
83 static int
84 vax_register_virtual_size (int regno)
85 {
86 return (4);
87 }
88
89 static struct type *
90 vax_register_virtual_type (int regno)
91 {
92 return (builtin_type_int);
93 }
94 \f
95 static void
96 vax_frame_init_saved_regs (struct frame_info *frame)
97 {
98 int regnum, regmask;
99 CORE_ADDR next_addr;
100
101 if (get_frame_saved_regs (frame))
102 return;
103
104 frame_saved_regs_zalloc (frame);
105
106 regmask = read_memory_integer (get_frame_base (frame) + 4, 4) >> 16;
107
108 next_addr = get_frame_base (frame) + 16;
109
110 /* regmask's low bit is for register 0, which is the first one
111 what would be pushed. */
112 for (regnum = 0; regnum < VAX_AP_REGNUM; regnum++)
113 {
114 if (regmask & (1 << regnum))
115 get_frame_saved_regs (frame)[regnum] = next_addr += 4;
116 }
117
118 get_frame_saved_regs (frame)[SP_REGNUM] = next_addr + 4;
119 if (regmask & (1 << DEPRECATED_FP_REGNUM))
120 get_frame_saved_regs (frame)[SP_REGNUM] +=
121 4 + (4 * read_memory_integer (next_addr + 4, 4));
122
123 get_frame_saved_regs (frame)[PC_REGNUM] = get_frame_base (frame) + 16;
124 get_frame_saved_regs (frame)[DEPRECATED_FP_REGNUM] = get_frame_base (frame) + 12;
125 get_frame_saved_regs (frame)[VAX_AP_REGNUM] = get_frame_base (frame) + 8;
126 get_frame_saved_regs (frame)[PS_REGNUM] = get_frame_base (frame) + 4;
127 }
128
129 /* Get saved user PC for sigtramp from sigcontext for BSD style sigtramp. */
130
131 static CORE_ADDR
132 vax_sigtramp_saved_pc (struct frame_info *frame)
133 {
134 CORE_ADDR sigcontext_addr;
135 char *buf;
136 int ptrbytes = TYPE_LENGTH (builtin_type_void_func_ptr);
137 int sigcontext_offs = (2 * TARGET_INT_BIT) / TARGET_CHAR_BIT;
138
139 buf = alloca (ptrbytes);
140 /* Get sigcontext address, it is the third parameter on the stack. */
141 if (get_next_frame (frame))
142 sigcontext_addr = read_memory_typed_address
143 (FRAME_ARGS_ADDRESS (get_next_frame (frame))
144 + FRAME_ARGS_SKIP + sigcontext_offs,
145 builtin_type_void_data_ptr);
146 else
147 sigcontext_addr = read_memory_typed_address
148 (read_register (SP_REGNUM) + sigcontext_offs, builtin_type_void_data_ptr);
149
150 /* Don't cause a memory_error when accessing sigcontext in case the stack
151 layout has changed or the stack is corrupt. */
152 target_read_memory (sigcontext_addr + SIGCONTEXT_PC_OFFSET, buf, ptrbytes);
153 return extract_typed_address (buf, builtin_type_void_func_ptr);
154 }
155
156 static CORE_ADDR
157 vax_frame_saved_pc (struct frame_info *frame)
158 {
159 if ((get_frame_type (frame) == SIGTRAMP_FRAME))
160 return (vax_sigtramp_saved_pc (frame)); /* XXXJRT */
161
162 return (read_memory_integer (get_frame_base (frame) + 16, 4));
163 }
164
165 CORE_ADDR
166 vax_frame_args_address_correct (struct frame_info *frame)
167 {
168 /* Cannot find the AP register value directly from the FP value. Must
169 find it saved in the frame called by this one, or in the AP register
170 for the innermost frame. However, there is no way to tell the
171 difference between the innermost frame and a frame for which we
172 just don't know the frame that it called (e.g. "info frame 0x7ffec789").
173 For the sake of argument, suppose that the stack is somewhat trashed
174 (which is one reason that "info frame" exists). So, return 0 (indicating
175 we don't know the address of the arglist) if we don't know what frame
176 this frame calls. */
177 if (get_next_frame (frame))
178 return (read_memory_integer (get_frame_base (get_next_frame (frame)) + 8, 4));
179
180 return (0);
181 }
182
183 static CORE_ADDR
184 vax_frame_args_address (struct frame_info *frame)
185 {
186 /* In most of GDB, getting the args address is too important to
187 just say "I don't know". This is sometimes wrong for functions
188 that aren't on top of the stack, but c'est la vie. */
189 if (get_next_frame (frame))
190 return (read_memory_integer (get_frame_base (get_next_frame (frame)) + 8, 4));
191
192 return (read_register (VAX_AP_REGNUM));
193 }
194
195 static CORE_ADDR
196 vax_frame_locals_address (struct frame_info *frame)
197 {
198 return (get_frame_base (frame));
199 }
200
201 static int
202 vax_frame_num_args (struct frame_info *fi)
203 {
204 return (0xff & read_memory_integer (FRAME_ARGS_ADDRESS (fi), 1));
205 }
206
207 static CORE_ADDR
208 vax_frame_chain (struct frame_info *frame)
209 {
210 /* In the case of the VAX, the frame's nominal address is the FP value,
211 and 12 bytes later comes the saved previous FP value as a 4-byte word. */
212 if (inside_entry_file (get_frame_pc (frame)))
213 return (0);
214
215 return (read_memory_integer (get_frame_base (frame) + 12, 4));
216 }
217 \f
218 static void
219 vax_push_dummy_frame (void)
220 {
221 CORE_ADDR sp = read_register (SP_REGNUM);
222 int regnum;
223
224 sp = push_word (sp, 0); /* arglist */
225 for (regnum = 11; regnum >= 0; regnum--)
226 sp = push_word (sp, read_register (regnum));
227 sp = push_word (sp, read_register (PC_REGNUM));
228 sp = push_word (sp, read_register (DEPRECATED_FP_REGNUM));
229 sp = push_word (sp, read_register (VAX_AP_REGNUM));
230 sp = push_word (sp, (read_register (PS_REGNUM) & 0xffef) + 0x2fff0000);
231 sp = push_word (sp, 0);
232 write_register (SP_REGNUM, sp);
233 write_register (DEPRECATED_FP_REGNUM, sp);
234 write_register (VAX_AP_REGNUM, sp + (17 * 4));
235 }
236
237 static void
238 vax_pop_frame (void)
239 {
240 CORE_ADDR fp = read_register (DEPRECATED_FP_REGNUM);
241 int regnum;
242 int regmask = read_memory_integer (fp + 4, 4);
243
244 write_register (PS_REGNUM,
245 (regmask & 0xffff)
246 | (read_register (PS_REGNUM) & 0xffff0000));
247 write_register (PC_REGNUM, read_memory_integer (fp + 16, 4));
248 write_register (DEPRECATED_FP_REGNUM, read_memory_integer (fp + 12, 4));
249 write_register (VAX_AP_REGNUM, read_memory_integer (fp + 8, 4));
250 fp += 16;
251 for (regnum = 0; regnum < 12; regnum++)
252 if (regmask & (0x10000 << regnum))
253 write_register (regnum, read_memory_integer (fp += 4, 4));
254 fp = fp + 4 + ((regmask >> 30) & 3);
255 if (regmask & 0x20000000)
256 {
257 regnum = read_memory_integer (fp, 4);
258 fp += (regnum + 1) * 4;
259 }
260 write_register (SP_REGNUM, fp);
261 flush_cached_frames ();
262 }
263
264 /* The VAX call dummy sequence:
265
266 calls #69, @#32323232
267 bpt
268
269 It is 8 bytes long. The address and argc are patched by
270 vax_fix_call_dummy(). */
271 static LONGEST vax_call_dummy_words[] = { 0x329f69fb, 0x03323232 };
272 static int sizeof_vax_call_dummy_words = sizeof(vax_call_dummy_words);
273
274 static void
275 vax_fix_call_dummy (char *dummy, CORE_ADDR pc, CORE_ADDR fun, int nargs,
276 struct value **args, struct type *type, int gcc_p)
277 {
278 dummy[1] = nargs;
279 store_unsigned_integer (dummy + 3, 4, fun);
280 }
281 \f
282 static void
283 vax_store_struct_return (CORE_ADDR addr, CORE_ADDR sp)
284 {
285 write_register (1, addr);
286 }
287
288 static void
289 vax_extract_return_value (struct type *valtype, char *regbuf, char *valbuf)
290 {
291 memcpy (valbuf, regbuf + REGISTER_BYTE (0), TYPE_LENGTH (valtype));
292 }
293
294 static void
295 vax_store_return_value (struct type *valtype, char *valbuf)
296 {
297 deprecated_write_register_bytes (0, valbuf, TYPE_LENGTH (valtype));
298 }
299
300 static CORE_ADDR
301 vax_extract_struct_value_address (char *regbuf)
302 {
303 return (extract_unsigned_integer (regbuf + REGISTER_BYTE (0),
304 REGISTER_RAW_SIZE (0)));
305 }
306 \f
307 static const unsigned char *
308 vax_breakpoint_from_pc (CORE_ADDR *pcptr, int *lenptr)
309 {
310 static const unsigned char vax_breakpoint[] = { 3 };
311
312 *lenptr = sizeof(vax_breakpoint);
313 return (vax_breakpoint);
314 }
315 \f
316 /* Advance PC across any function entry prologue instructions
317 to reach some "real" code. */
318
319 static CORE_ADDR
320 vax_skip_prologue (CORE_ADDR pc)
321 {
322 register int op = (unsigned char) read_memory_integer (pc, 1);
323 if (op == 0x11)
324 pc += 2; /* skip brb */
325 if (op == 0x31)
326 pc += 3; /* skip brw */
327 if (op == 0xC2
328 && ((unsigned char) read_memory_integer (pc + 2, 1)) == 0x5E)
329 pc += 3; /* skip subl2 */
330 if (op == 0x9E
331 && ((unsigned char) read_memory_integer (pc + 1, 1)) == 0xAE
332 && ((unsigned char) read_memory_integer (pc + 3, 1)) == 0x5E)
333 pc += 4; /* skip movab */
334 if (op == 0x9E
335 && ((unsigned char) read_memory_integer (pc + 1, 1)) == 0xCE
336 && ((unsigned char) read_memory_integer (pc + 4, 1)) == 0x5E)
337 pc += 5; /* skip movab */
338 if (op == 0x9E
339 && ((unsigned char) read_memory_integer (pc + 1, 1)) == 0xEE
340 && ((unsigned char) read_memory_integer (pc + 6, 1)) == 0x5E)
341 pc += 7; /* skip movab */
342 return pc;
343 }
344
345 static CORE_ADDR
346 vax_saved_pc_after_call (struct frame_info *frame)
347 {
348 return (DEPRECATED_FRAME_SAVED_PC(frame));
349 }
350 \f
351 /* Initialize the current architecture based on INFO. If possible, re-use an
352 architecture from ARCHES, which is a list of architectures already created
353 during this debugging session.
354
355 Called e.g. at program startup, when reading a core file, and when reading
356 a binary file. */
357
358 static struct gdbarch *
359 vax_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
360 {
361 struct gdbarch *gdbarch;
362
363 /* If there is already a candidate, use it. */
364 arches = gdbarch_list_lookup_by_info (arches, &info);
365 if (arches != NULL)
366 return arches->gdbarch;
367
368 gdbarch = gdbarch_alloc (&info, NULL);
369
370 /* NOTE: cagney/2002-12-06: This can be deleted when this arch is
371 ready to unwind the PC first (see frame.c:get_prev_frame()). */
372 set_gdbarch_deprecated_init_frame_pc (gdbarch, init_frame_pc_default);
373
374 /* Register info */
375 set_gdbarch_num_regs (gdbarch, VAX_NUM_REGS);
376 set_gdbarch_sp_regnum (gdbarch, VAX_SP_REGNUM);
377 set_gdbarch_deprecated_fp_regnum (gdbarch, VAX_FP_REGNUM);
378 set_gdbarch_pc_regnum (gdbarch, VAX_PC_REGNUM);
379 set_gdbarch_ps_regnum (gdbarch, VAX_PS_REGNUM);
380
381 set_gdbarch_register_name (gdbarch, vax_register_name);
382 set_gdbarch_deprecated_register_size (gdbarch, VAX_REGISTER_SIZE);
383 set_gdbarch_deprecated_register_bytes (gdbarch, VAX_REGISTER_BYTES);
384 set_gdbarch_register_byte (gdbarch, vax_register_byte);
385 set_gdbarch_register_raw_size (gdbarch, vax_register_raw_size);
386 set_gdbarch_deprecated_max_register_raw_size (gdbarch, VAX_MAX_REGISTER_RAW_SIZE);
387 set_gdbarch_register_virtual_size (gdbarch, vax_register_virtual_size);
388 set_gdbarch_deprecated_max_register_virtual_size (gdbarch,
389 VAX_MAX_REGISTER_VIRTUAL_SIZE);
390 set_gdbarch_register_virtual_type (gdbarch, vax_register_virtual_type);
391
392 /* Frame and stack info */
393 set_gdbarch_skip_prologue (gdbarch, vax_skip_prologue);
394 set_gdbarch_deprecated_saved_pc_after_call (gdbarch, vax_saved_pc_after_call);
395
396 set_gdbarch_frame_num_args (gdbarch, vax_frame_num_args);
397 set_gdbarch_frameless_function_invocation (gdbarch,
398 generic_frameless_function_invocation_not);
399
400 set_gdbarch_deprecated_frame_chain (gdbarch, vax_frame_chain);
401 set_gdbarch_deprecated_frame_saved_pc (gdbarch, vax_frame_saved_pc);
402
403 set_gdbarch_frame_args_address (gdbarch, vax_frame_args_address);
404 set_gdbarch_frame_locals_address (gdbarch, vax_frame_locals_address);
405
406 set_gdbarch_deprecated_frame_init_saved_regs (gdbarch, vax_frame_init_saved_regs);
407
408 set_gdbarch_frame_args_skip (gdbarch, 4);
409
410 set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
411
412 /* Return value info */
413 set_gdbarch_deprecated_store_struct_return (gdbarch, vax_store_struct_return);
414 set_gdbarch_deprecated_extract_return_value (gdbarch, vax_extract_return_value);
415 set_gdbarch_deprecated_store_return_value (gdbarch, vax_store_return_value);
416 set_gdbarch_deprecated_extract_struct_value_address (gdbarch, vax_extract_struct_value_address);
417
418 /* Call dummy info */
419 set_gdbarch_deprecated_push_dummy_frame (gdbarch, vax_push_dummy_frame);
420 set_gdbarch_deprecated_pop_frame (gdbarch, vax_pop_frame);
421 set_gdbarch_call_dummy_location (gdbarch, ON_STACK);
422 set_gdbarch_deprecated_call_dummy_words (gdbarch, vax_call_dummy_words);
423 set_gdbarch_deprecated_sizeof_call_dummy_words (gdbarch, sizeof_vax_call_dummy_words);
424 set_gdbarch_deprecated_fix_call_dummy (gdbarch, vax_fix_call_dummy);
425 set_gdbarch_deprecated_call_dummy_breakpoint_offset (gdbarch, 7);
426 set_gdbarch_deprecated_use_generic_dummy_frames (gdbarch, 0);
427 set_gdbarch_deprecated_pc_in_call_dummy (gdbarch, deprecated_pc_in_call_dummy_on_stack);
428
429 /* Breakpoint info */
430 set_gdbarch_breakpoint_from_pc (gdbarch, vax_breakpoint_from_pc);
431 set_gdbarch_decr_pc_after_break (gdbarch, 0);
432
433 /* Misc info */
434 set_gdbarch_function_start_offset (gdbarch, 2);
435 set_gdbarch_believe_pcc_promotion (gdbarch, 1);
436
437 /* Should be using push_dummy_call. */
438 set_gdbarch_deprecated_dummy_write_sp (gdbarch, generic_target_write_sp);
439
440 /* Hook in ABI-specific overrides, if they have been registered. */
441 gdbarch_init_osabi (info, gdbarch);
442
443 set_gdbarch_print_insn (gdbarch, print_insn_vax);
444
445 return (gdbarch);
446 }
447
448 void
449 _initialize_vax_tdep (void)
450 {
451 gdbarch_register (bfd_arch_vax, vax_gdbarch_init, NULL);
452 }
This page took 0.039907 seconds and 4 git commands to generate.