2225eb851e
* m68k/{tm-3b1.h, tm-altos.h, tm-amix.h, tm-es1800.h, tm-hp300bsd.h, tm-hp300hpux.h, tm-isi.h, tm-news.h, tm-os68k.h, tm-st2000.h, tm-sun2.h, tm-sun3.h, tm-vx68.h}: Include tm-m68k.h instead of tm-68k.h. * Makefile.in (HFILES): tm-68k.h renamed to tm-m68k.h. * README, a29k-pinsn.c, m68k-pinsn.c, m68k-stub.c, remote-vx.c, m68k/{altos.mh, altos.mt, apollo68b.mh, nm-apollo68b.h, nm-hp300bsd.h, config/m68k/xm-apollo68b.h}: Map '68k' to 'm68k'. * a29k/tm-a29k.h, doc/gdbint.texinfo: Account for renaming of tm-68k.h to tm-m68k.h. * m68k/m68k-fp.mt (TM_FILE): tm-68k-fp.h renamed to tm-m68k-fp.h. * m68k/m68k-nofp.mt (TM_FILE): tm-68k-nofp.h renamed to tm-m68k-nofp.h.
97 lines
3.7 KiB
C
97 lines
3.7 KiB
C
/* Parameters for Hewlett-Packard 9000/300 native support under bsd.
|
|
Copyright 1986, 1987, 1989, 1991, 1992, 1993 Free Software Foundation, Inc.
|
|
|
|
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., 675 Mass Ave, Cambridge, MA 02139, USA. */
|
|
|
|
/* This is a hack. This is only a hack. Were this a common source file,
|
|
rather than a config file specific to BSD on HP m68k's, you would have
|
|
been instructed to clean this up. As it is, clean it up if FSF's
|
|
HP's-running-ancient-BSD ever go away. */
|
|
|
|
#include <errno.h>
|
|
#ifdef EPROCUNAVAIL
|
|
/* BSD 4.4 alpha or better */
|
|
|
|
/* We can attach to processes using ptrace. */
|
|
|
|
#define ATTACH_DETACH
|
|
#define PTRACE_ATTACH 10
|
|
#define PTRACE_DETACH 11
|
|
|
|
/* The third argument of ptrace is declared as this type. */
|
|
|
|
#define PTRACE_ARG3_TYPE caddr_t
|
|
|
|
/* U_REGS_OFFSET is the offset of the registers within the u area for
|
|
ptrace purposes. */
|
|
#define U_REGS_OFFSET \
|
|
ptrace (PT_READ_U, inferior_pid, \
|
|
(PTRACE_ARG3_TYPE) \
|
|
(offsetof (struct user, u_kproc.kp_proc.p_md.md_regs)), 0) \
|
|
- USRSTACK
|
|
|
|
/* This is a piece of magic that is given a register number REGNO
|
|
and as BLOCKEND the address in the system of the end of the user structure
|
|
and stores in ADDR the address in the kernel or core dump
|
|
of that register. */
|
|
|
|
#define REGISTER_U_ADDR(addr, blockend, regno) \
|
|
{ \
|
|
if (regno < PS_REGNUM) \
|
|
addr = (int) &((struct frame *)(blockend))->f_regs[regno]; \
|
|
else if (regno == PS_REGNUM) \
|
|
addr = (int) &((struct frame *)(blockend))->f_stackadj; \
|
|
else if (regno == PC_REGNUM) \
|
|
addr = (int) &((struct frame *)(blockend))->f_pc; \
|
|
else if (regno < FPC_REGNUM) \
|
|
addr = (int) \
|
|
&((struct user *)0)->u_pcb.pcb_fpregs.fpf_regs[((regno)-FP0_REGNUM)*3];\
|
|
else if (regno == FPC_REGNUM) \
|
|
addr = (int) &((struct user *)0)->u_pcb.pcb_fpregs.fpf_fpcr; \
|
|
else if (regno == FPS_REGNUM) \
|
|
addr = (int) &((struct user *)0)->u_pcb.pcb_fpregs.fpf_fpsr; \
|
|
else \
|
|
addr = (int) &((struct user *)0)->u_pcb.pcb_fpregs.fpf_fpiar; \
|
|
}
|
|
#else
|
|
|
|
/* THIS IS BSD 4.3 or something like it. */
|
|
|
|
/* This is a piece of magic that is given a register number REGNO
|
|
and as BLOCKEND the address in the system of the end of the user structure
|
|
and stores in ADDR the address in the kernel or core dump
|
|
of that register. */
|
|
|
|
#define REGISTER_U_ADDR(addr, blockend, regno) \
|
|
{ \
|
|
if (regno < PS_REGNUM) \
|
|
addr = (int) &((struct frame *)(blockend))->f_regs[regno]; \
|
|
else if (regno == PS_REGNUM) \
|
|
addr = (int) &((struct frame *)(blockend))->f_stackadj; \
|
|
else if (regno == PC_REGNUM) \
|
|
addr = (int) &((struct frame *)(blockend))->f_pc; \
|
|
else if (regno < FPC_REGNUM) \
|
|
addr = (int) \
|
|
&((struct user *)0)->u_pcb.pcb_fpregs.fpf_regs[((regno)-FP0_REGNUM)*3];\
|
|
else if (regno == FPC_REGNUM) \
|
|
addr = (int) &((struct user *)0)->u_pcb.pcb_fpregs.fpf_fpcr; \
|
|
else if (regno == FPS_REGNUM) \
|
|
addr = (int) &((struct user *)0)->u_pcb.pcb_fpregs.fpf_fpsr; \
|
|
else \
|
|
addr = (int) &((struct user *)0)->u_pcb.pcb_fpregs.fpf_fpiar; \
|
|
}
|
|
#endif
|