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