* sparc64-tdep.h (sparc64_regnum): Fix comment.
[deliverable/binutils-gdb.git] / gdb / vax-tdep.c
CommitLineData
c906108c 1/* Print VAX instructions for GDB, the GNU debugger.
4be87837 2 Copyright 1986, 1989, 1991, 1992, 1995, 1996, 1998, 1999, 2000, 2002, 2003
b6ba6518 3 Free Software Foundation, Inc.
c906108c 4
c5aa993b 5 This file is part of GDB.
c906108c 6
c5aa993b
JM
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.
c906108c 11
c5aa993b
JM
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.
c906108c 16
c5aa993b
JM
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. */
c906108c
SS
21
22#include "defs.h"
23#include "symtab.h"
24#include "opcode/vax.h"
c11c3a98 25#include "gdbcore.h"
f267bd6a 26#include "inferior.h"
a33f7558 27#include "regcache.h"
c11c3a98
AC
28#include "frame.h"
29#include "value.h"
f267bd6a 30#include "arch-utils.h"
9bbe19fb 31#include "gdb_string.h"
4be87837 32#include "osabi.h"
f267bd6a
JT
33
34#include "vax-tdep.h"
35
36static gdbarch_register_name_ftype vax_register_name;
f267bd6a
JT
37
38static gdbarch_skip_prologue_ftype vax_skip_prologue;
f267bd6a 39static gdbarch_frame_num_args_ftype vax_frame_num_args;
618ce49f 40static gdbarch_deprecated_frame_chain_ftype vax_frame_chain;
f267bd6a 41
26e9b323 42static gdbarch_deprecated_extract_return_value_ftype vax_extract_return_value;
26e9b323 43static gdbarch_deprecated_extract_struct_value_address_ftype
f267bd6a
JT
44 vax_extract_struct_value_address;
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
b2fb4676 95 if (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))
b2fb4676 109 get_frame_saved_regs (frame)[regnum] = next_addr += 4;
ab62c900
JT
110 }
111
b2fb4676 112 get_frame_saved_regs (frame)[SP_REGNUM] = next_addr + 4;
0ba6dca9 113 if (regmask & (1 << DEPRECATED_FP_REGNUM))
b2fb4676 114 get_frame_saved_regs (frame)[SP_REGNUM] +=
ab62c900
JT
115 4 + (4 * read_memory_integer (next_addr + 4, 4));
116
1e2330ba 117 get_frame_saved_regs (frame)[PC_REGNUM] = get_frame_base (frame) + 16;
0ba6dca9 118 get_frame_saved_regs (frame)[DEPRECATED_FP_REGNUM] = get_frame_base (frame) + 12;
1e2330ba
AC
119 get_frame_saved_regs (frame)[VAX_AP_REGNUM] = get_frame_base (frame) + 8;
120 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
144 /* Don't cause a memory_error when accessing sigcontext in case the stack
145 layout has changed or the stack is corrupt. */
146 target_read_memory (sigcontext_addr + SIGCONTEXT_PC_OFFSET, buf, ptrbytes);
147 return extract_typed_address (buf, builtin_type_void_func_ptr);
148}
149
f267bd6a 150static CORE_ADDR
5516aa92
JT
151vax_frame_saved_pc (struct frame_info *frame)
152{
5a203e44 153 if ((get_frame_type (frame) == SIGTRAMP_FRAME))
f407986f 154 return (vax_sigtramp_saved_pc (frame)); /* XXXJRT */
5516aa92 155
1e2330ba 156 return (read_memory_integer (get_frame_base (frame) + 16, 4));
5516aa92
JT
157}
158
f267bd6a 159static CORE_ADDR
5516aa92
JT
160vax_frame_args_address (struct frame_info *frame)
161{
25e3a86b
AC
162 /* In most of GDB, getting the args address is too important to just
163 say "I don't know". This is sometimes wrong for functions that
164 aren't on top of the stack, but c'est la vie. */
11c02a10
AC
165 if (get_next_frame (frame))
166 return (read_memory_integer (get_frame_base (get_next_frame (frame)) + 8, 4));
25e3a86b
AC
167 /* Cannot find the AP register value directly from the FP value.
168 Must find it saved in the frame called by this one, or in the AP
169 register for the innermost frame. However, there is no way to
170 tell the difference between the innermost frame and a frame for
171 which we just don't know the frame that it called (e.g. "info
172 frame 0x7ffec789"). For the sake of argument, suppose that the
173 stack is somewhat trashed (which is one reason that "info frame"
174 exists). So, return 0 (indicating we don't know the address of
175 the arglist) if we don't know what frame this frame calls. */
176 return 0;
5516aa92
JT
177}
178
f267bd6a 179static int
5516aa92
JT
180vax_frame_num_args (struct frame_info *fi)
181{
42efa47a 182 return (0xff & read_memory_integer (DEPRECATED_FRAME_ARGS_ADDRESS (fi), 1));
5516aa92 183}
52efde73 184
f267bd6a 185static CORE_ADDR
52efde73
JT
186vax_frame_chain (struct frame_info *frame)
187{
188 /* In the case of the VAX, the frame's nominal address is the FP value,
189 and 12 bytes later comes the saved previous FP value as a 4-byte word. */
50abf9e5 190 if (inside_entry_file (get_frame_pc (frame)))
52efde73
JT
191 return (0);
192
1e2330ba 193 return (read_memory_integer (get_frame_base (frame) + 12, 4));
52efde73
JT
194}
195\f
f267bd6a 196static void
52efde73
JT
197vax_push_dummy_frame (void)
198{
199 CORE_ADDR sp = read_register (SP_REGNUM);
200 int regnum;
201
202 sp = push_word (sp, 0); /* arglist */
203 for (regnum = 11; regnum >= 0; regnum--)
204 sp = push_word (sp, read_register (regnum));
205 sp = push_word (sp, read_register (PC_REGNUM));
0ba6dca9 206 sp = push_word (sp, read_register (DEPRECATED_FP_REGNUM));
1d049c5e 207 sp = push_word (sp, read_register (VAX_AP_REGNUM));
52efde73
JT
208 sp = push_word (sp, (read_register (PS_REGNUM) & 0xffef) + 0x2fff0000);
209 sp = push_word (sp, 0);
210 write_register (SP_REGNUM, sp);
0ba6dca9 211 write_register (DEPRECATED_FP_REGNUM, sp);
1d049c5e 212 write_register (VAX_AP_REGNUM, sp + (17 * 4));
52efde73
JT
213}
214
f267bd6a 215static void
52efde73
JT
216vax_pop_frame (void)
217{
0ba6dca9 218 CORE_ADDR fp = read_register (DEPRECATED_FP_REGNUM);
52efde73
JT
219 int regnum;
220 int regmask = read_memory_integer (fp + 4, 4);
221
222 write_register (PS_REGNUM,
223 (regmask & 0xffff)
224 | (read_register (PS_REGNUM) & 0xffff0000));
225 write_register (PC_REGNUM, read_memory_integer (fp + 16, 4));
0ba6dca9 226 write_register (DEPRECATED_FP_REGNUM, read_memory_integer (fp + 12, 4));
1d049c5e 227 write_register (VAX_AP_REGNUM, read_memory_integer (fp + 8, 4));
52efde73
JT
228 fp += 16;
229 for (regnum = 0; regnum < 12; regnum++)
230 if (regmask & (0x10000 << regnum))
231 write_register (regnum, read_memory_integer (fp += 4, 4));
232 fp = fp + 4 + ((regmask >> 30) & 3);
233 if (regmask & 0x20000000)
234 {
235 regnum = read_memory_integer (fp, 4);
236 fp += (regnum + 1) * 4;
237 }
238 write_register (SP_REGNUM, fp);
239 flush_cached_frames ();
240}
a33f7558
JT
241
242/* The VAX call dummy sequence:
243
244 calls #69, @#32323232
245 bpt
246
247 It is 8 bytes long. The address and argc are patched by
248 vax_fix_call_dummy(). */
f267bd6a
JT
249static LONGEST vax_call_dummy_words[] = { 0x329f69fb, 0x03323232 };
250static int sizeof_vax_call_dummy_words = sizeof(vax_call_dummy_words);
a33f7558 251
f267bd6a 252static void
a33f7558
JT
253vax_fix_call_dummy (char *dummy, CORE_ADDR pc, CORE_ADDR fun, int nargs,
254 struct value **args, struct type *type, int gcc_p)
255{
256 dummy[1] = nargs;
257 store_unsigned_integer (dummy + 3, 4, fun);
258}
ab62c900 259\f
f267bd6a 260static void
ea74468c
JT
261vax_store_struct_return (CORE_ADDR addr, CORE_ADDR sp)
262{
263 write_register (1, addr);
264}
265
f267bd6a 266static void
ea74468c
JT
267vax_extract_return_value (struct type *valtype, char *regbuf, char *valbuf)
268{
269 memcpy (valbuf, regbuf + REGISTER_BYTE (0), TYPE_LENGTH (valtype));
270}
271
f267bd6a 272static void
ea74468c
JT
273vax_store_return_value (struct type *valtype, char *valbuf)
274{
73937e03 275 deprecated_write_register_bytes (0, valbuf, TYPE_LENGTH (valtype));
ea74468c
JT
276}
277
f267bd6a 278static CORE_ADDR
ea74468c
JT
279vax_extract_struct_value_address (char *regbuf)
280{
7c0b4a20
AC
281 return (extract_unsigned_integer (regbuf + REGISTER_BYTE (0),
282 REGISTER_RAW_SIZE (0)));
ea74468c
JT
283}
284\f
1d049c5e
JT
285static const unsigned char *
286vax_breakpoint_from_pc (CORE_ADDR *pcptr, int *lenptr)
287{
288 static const unsigned char vax_breakpoint[] = { 3 };
289
290 *lenptr = sizeof(vax_breakpoint);
291 return (vax_breakpoint);
292}
293\f
b83266a0
SS
294/* Advance PC across any function entry prologue instructions
295 to reach some "real" code. */
296
f267bd6a 297static CORE_ADDR
fba45db2 298vax_skip_prologue (CORE_ADDR pc)
b83266a0
SS
299{
300 register int op = (unsigned char) read_memory_integer (pc, 1);
301 if (op == 0x11)
c5aa993b 302 pc += 2; /* skip brb */
b83266a0 303 if (op == 0x31)
c5aa993b 304 pc += 3; /* skip brw */
b83266a0 305 if (op == 0xC2
c5aa993b
JM
306 && ((unsigned char) read_memory_integer (pc + 2, 1)) == 0x5E)
307 pc += 3; /* skip subl2 */
b83266a0 308 if (op == 0x9E
c5aa993b
JM
309 && ((unsigned char) read_memory_integer (pc + 1, 1)) == 0xAE
310 && ((unsigned char) read_memory_integer (pc + 3, 1)) == 0x5E)
311 pc += 4; /* skip movab */
b83266a0 312 if (op == 0x9E
c5aa993b
JM
313 && ((unsigned char) read_memory_integer (pc + 1, 1)) == 0xCE
314 && ((unsigned char) read_memory_integer (pc + 4, 1)) == 0x5E)
315 pc += 5; /* skip movab */
b83266a0 316 if (op == 0x9E
c5aa993b
JM
317 && ((unsigned char) read_memory_integer (pc + 1, 1)) == 0xEE
318 && ((unsigned char) read_memory_integer (pc + 6, 1)) == 0x5E)
319 pc += 7; /* skip movab */
b83266a0
SS
320 return pc;
321}
322
f267bd6a 323static CORE_ADDR
a33f7558
JT
324vax_saved_pc_after_call (struct frame_info *frame)
325{
8bedc050 326 return (DEPRECATED_FRAME_SAVED_PC(frame));
a33f7558
JT
327}
328\f
f267bd6a
JT
329/* Initialize the current architecture based on INFO. If possible, re-use an
330 architecture from ARCHES, which is a list of architectures already created
331 during this debugging session.
332
333 Called e.g. at program startup, when reading a core file, and when reading
334 a binary file. */
335
336static struct gdbarch *
337vax_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
338{
339 struct gdbarch *gdbarch;
340
4be87837
DJ
341 /* If there is already a candidate, use it. */
342 arches = gdbarch_list_lookup_by_info (arches, &info);
343 if (arches != NULL)
344 return arches->gdbarch;
f267bd6a 345
4be87837 346 gdbarch = gdbarch_alloc (&info, NULL);
4791e091 347
a5afb99f
AC
348 /* NOTE: cagney/2002-12-06: This can be deleted when this arch is
349 ready to unwind the PC first (see frame.c:get_prev_frame()). */
350 set_gdbarch_deprecated_init_frame_pc (gdbarch, init_frame_pc_default);
351
f267bd6a
JT
352 /* Register info */
353 set_gdbarch_num_regs (gdbarch, VAX_NUM_REGS);
354 set_gdbarch_sp_regnum (gdbarch, VAX_SP_REGNUM);
0ba6dca9 355 set_gdbarch_deprecated_fp_regnum (gdbarch, VAX_FP_REGNUM);
f267bd6a
JT
356 set_gdbarch_pc_regnum (gdbarch, VAX_PC_REGNUM);
357 set_gdbarch_ps_regnum (gdbarch, VAX_PS_REGNUM);
358
359 set_gdbarch_register_name (gdbarch, vax_register_name);
b1e29e33 360 set_gdbarch_deprecated_register_size (gdbarch, VAX_REGISTER_SIZE);
b8b527c5 361 set_gdbarch_deprecated_register_bytes (gdbarch, VAX_REGISTER_BYTES);
9c04cab7
AC
362 set_gdbarch_deprecated_register_byte (gdbarch, vax_register_byte);
363 set_gdbarch_deprecated_register_raw_size (gdbarch, vax_register_raw_size);
a0ed5532 364 set_gdbarch_deprecated_max_register_raw_size (gdbarch, VAX_MAX_REGISTER_RAW_SIZE);
9c04cab7 365 set_gdbarch_deprecated_register_virtual_size (gdbarch, vax_register_virtual_size);
a0ed5532 366 set_gdbarch_deprecated_max_register_virtual_size (gdbarch,
f267bd6a 367 VAX_MAX_REGISTER_VIRTUAL_SIZE);
9c04cab7 368 set_gdbarch_deprecated_register_virtual_type (gdbarch, vax_register_virtual_type);
f267bd6a
JT
369
370 /* Frame and stack info */
371 set_gdbarch_skip_prologue (gdbarch, vax_skip_prologue);
6913c89a 372 set_gdbarch_deprecated_saved_pc_after_call (gdbarch, vax_saved_pc_after_call);
f267bd6a
JT
373
374 set_gdbarch_frame_num_args (gdbarch, vax_frame_num_args);
375 set_gdbarch_frameless_function_invocation (gdbarch,
376 generic_frameless_function_invocation_not);
377
618ce49f 378 set_gdbarch_deprecated_frame_chain (gdbarch, vax_frame_chain);
8bedc050 379 set_gdbarch_deprecated_frame_saved_pc (gdbarch, vax_frame_saved_pc);
f267bd6a 380
42efa47a 381 set_gdbarch_deprecated_frame_args_address (gdbarch, vax_frame_args_address);
f267bd6a 382
f30ee0bc 383 set_gdbarch_deprecated_frame_init_saved_regs (gdbarch, vax_frame_init_saved_regs);
f267bd6a
JT
384
385 set_gdbarch_frame_args_skip (gdbarch, 4);
386
f267bd6a
JT
387 set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
388
389 /* Return value info */
4183d812 390 set_gdbarch_deprecated_store_struct_return (gdbarch, vax_store_struct_return);
26e9b323 391 set_gdbarch_deprecated_extract_return_value (gdbarch, vax_extract_return_value);
ebba8386 392 set_gdbarch_deprecated_store_return_value (gdbarch, vax_store_return_value);
26e9b323 393 set_gdbarch_deprecated_extract_struct_value_address (gdbarch, vax_extract_struct_value_address);
f267bd6a
JT
394
395 /* Call dummy info */
f3824013 396 set_gdbarch_deprecated_push_dummy_frame (gdbarch, vax_push_dummy_frame);
749b82f6 397 set_gdbarch_deprecated_pop_frame (gdbarch, vax_pop_frame);
f267bd6a 398 set_gdbarch_call_dummy_location (gdbarch, ON_STACK);
b1e29e33
AC
399 set_gdbarch_deprecated_call_dummy_words (gdbarch, vax_call_dummy_words);
400 set_gdbarch_deprecated_sizeof_call_dummy_words (gdbarch, sizeof_vax_call_dummy_words);
401 set_gdbarch_deprecated_fix_call_dummy (gdbarch, vax_fix_call_dummy);
402 set_gdbarch_deprecated_call_dummy_breakpoint_offset (gdbarch, 7);
07555a72 403 set_gdbarch_deprecated_use_generic_dummy_frames (gdbarch, 0);
ae45cd16 404 set_gdbarch_deprecated_pc_in_call_dummy (gdbarch, deprecated_pc_in_call_dummy_on_stack);
f267bd6a
JT
405
406 /* Breakpoint info */
1d049c5e 407 set_gdbarch_breakpoint_from_pc (gdbarch, vax_breakpoint_from_pc);
f267bd6a
JT
408 set_gdbarch_decr_pc_after_break (gdbarch, 0);
409
410 /* Misc info */
411 set_gdbarch_function_start_offset (gdbarch, 2);
1d049c5e 412 set_gdbarch_believe_pcc_promotion (gdbarch, 1);
f267bd6a 413
6c0e89ed 414 /* Should be using push_dummy_call. */
b46e02f6 415 set_gdbarch_deprecated_dummy_write_sp (gdbarch, deprecated_write_sp);
6c0e89ed 416
4791e091 417 /* Hook in ABI-specific overrides, if they have been registered. */
4be87837 418 gdbarch_init_osabi (info, gdbarch);
4791e091 419
ee2842e2
ILT
420 set_gdbarch_print_insn (gdbarch, print_insn_vax);
421
f267bd6a
JT
422 return (gdbarch);
423}
c906108c 424
a78f21af
AC
425extern initialize_file_ftype _initialize_vax_tdep; /* -Wmissing-prototypes */
426
c906108c 427void
fba45db2 428_initialize_vax_tdep (void)
c906108c 429{
4be87837 430 gdbarch_register (bfd_arch_vax, vax_gdbarch_init, NULL);
c906108c 431}
This page took 0.411125 seconds and 4 git commands to generate.