mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
b1e29e332a
* gdbarch.sh (DEPRECATED_REGISTER_SIZE): Rename REGISTER_SIZE. (DEPRECATED_SIZEOF_CALL_DUMMY_WORDS): Rename SIZEOF_CALL_DUMMY_WORDS. (DEPRECATED_CALL_DUMMY_WORDS): Rename CALL_DUMMY_WORDS. (DEPRECATED_FIX_CALL_DUMMY): Rename FIX_CALL_DUMMY. (DEPRECATED_CALL_DUMMY_BREAKPOINT_OFFSET): Rename CALL_DUMMY_BREAKPOINT_OFFSET. (DEPRECATED_CALL_DUMMY_START_OFFSET): Rename CALL_DUMMY_START_OFFSET. (DEPRECATED_CALL_DUMMY_LENGTH): Rename CALL_DUMMY_LENGTH. * gdbarch.h, gdbarch.c: Re-generate. * alpha-tdep.c, alphafbsd-tdep.c, arm-linux-tdep.c: Update. * arm-tdep.c, avr-tdep.c, breakpoint.c, cris-tdep.c: Update. * dummy-frame.c, dummy-frame.h, frv-tdep.c, gdbarch.c: Update. * gdbarch.h, gdbarch.sh, h8300-tdep.c, hppa-tdep.c: Update. * i386-tdep.c, ia64-tdep.c, infcall.c, inferior.h: Update. * m68hc11-tdep.c, m68k-tdep.c, mcore-tdep.c: Update. * mips-tdep.c, mn10300-tdep.c, ns32k-tdep.c: Update. * rs6000-tdep.c, s390-tdep.c, sh-tdep.c, sol-thread.c: Update. * sparc-tdep.c, target.c, v850-tdep.c, valops.c: Update. * vax-tdep.c, x86-64-tdep.c, xstormy16-tdep.c: Update. * config/ia64/tm-ia64.h, config/m68k/tm-vx68.h: Update. * config/mips/tm-mips.h, config/pa/nm-hppah.h: Update. * config/pa/tm-hppa.h, config/pa/tm-hppa64.h: Update. * config/s390/tm-s390.h, config/sparc/tm-sp64.h: Update. * config/sparc/tm-sparc.h: Update. Index: doc/ChangeLog 2003-05-03 Andrew Cagney <cagney@redhat.com> * gdbint.texinfo (Target Architecture Definition): Make CALL_DUMMY_WORDS, SIZEOF_CALL_DUMMY_WORDS, CALL_DUMMY_LENGTH, FIX_CALL_DUMMY, CALL_DUMMY_BREAKPOINT_OFFSET and CALL_DUMMY_BREAKPOINT_OFFSET deprecated. Index: mi/ChangeLog 2003-05-03 Andrew Cagney <cagney@redhat.com> * mi-main.c (mi_cmd_data_write_register_values): Replace REGISTER_SIZE with DEPRECATED_REGISTER_SIZE. Index: testsuite/ChangeLog 2003-05-03 Andrew Cagney <cagney@redhat.com> * gdb.base/watchpoint.exp: Rename CALL_DUMMY_BREAKPOINT_OFFSET to DEPRECATED_CALL_DUMMY_BREAKPOINT_OFFSET in comments.
83 lines
2.7 KiB
C
83 lines
2.7 KiB
C
/* Target machine description for VxWorks m68k's, for GDB, the GNU debugger.
|
|
Copyright 1986, 1987, 1989, 1991, 1992, 1993, 1996, 1998, 1999, 2000,
|
|
2002, 2003
|
|
Free Software Foundation, Inc.
|
|
Contributed by Cygnus Support.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place - Suite 330,
|
|
Boston, MA 02111-1307, USA. */
|
|
|
|
/* GCC is probably the only compiler used on this configuration. So
|
|
get this right even if the code which detects gcc2_compiled. is
|
|
still broken. */
|
|
|
|
#define BELIEVE_PCC_PROMOTION 1
|
|
|
|
/* We have more complex, useful breakpoints on the target. */
|
|
#define DECR_PC_AFTER_BREAK 0
|
|
|
|
#include "m68k/tm-m68k.h"
|
|
#include "config/tm-vxworks.h"
|
|
|
|
/* Takes the current frame-struct pointer and returns the chain-pointer
|
|
to get to the calling frame.
|
|
|
|
If our current frame pointer is zero, we're at the top; else read out
|
|
the saved FP from memory pointed to by the current FP. */
|
|
|
|
#undef DEPRECATED_FRAME_CHAIN
|
|
#define DEPRECATED_FRAME_CHAIN(thisframe) ((thisframe)->frame? read_memory_integer ((thisframe)->frame, 4): 0)
|
|
|
|
/* FIXME, Longjmp information stolen from Sun-3 config. Dunno if right. */
|
|
/* Offsets (in target ints) into jmp_buf. Not defined by Sun, but at least
|
|
documented in a comment in <machine/setjmp.h>! */
|
|
|
|
#define JB_ELEMENT_SIZE 4
|
|
|
|
#define JB_ONSSTACK 0
|
|
#define JB_SIGMASK 1
|
|
#define JB_SP 2
|
|
#define JB_PC 3
|
|
#define JB_PSL 4
|
|
#define JB_D2 5
|
|
#define JB_D3 6
|
|
#define JB_D4 7
|
|
#define JB_D5 8
|
|
#define JB_D6 9
|
|
#define JB_D7 10
|
|
#define JB_A2 11
|
|
#define JB_A3 12
|
|
#define JB_A4 13
|
|
#define JB_A5 14
|
|
#define JB_A6 15
|
|
|
|
/* Figure out where the longjmp will land. Slurp the args out of the stack.
|
|
We expect the first arg to be a pointer to the jmp_buf structure from which
|
|
we extract the pc (JB_PC) that we will land at. The pc is copied into ADDR.
|
|
This routine returns true on success */
|
|
|
|
#define GET_LONGJMP_TARGET(ADDR) m68k_get_longjmp_target(ADDR)
|
|
|
|
/* Number of registers in a ptrace_getregs call. */
|
|
|
|
#define VX_NUM_REGS (18)
|
|
|
|
/* Number of registers in a ptrace_getfpregs call. */
|
|
|
|
#define VX_SIZE_FPREGS (8 * REGISTER_RAW_SIZE (FP0_REGNUM) \
|
|
+ (3 * DEPRECATED_REGISTER_SIZE))
|