mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-19 14:34:07 +08:00
Move code duplicated in almost every single m68k based machine to the
common target file tm-68k.h. Duplications still need to be removed (FIXME).
This commit is contained in:
parent
150f543625
commit
dcd15e5e7a
@ -1,5 +1,10 @@
|
|||||||
Thu Oct 24 01:32:51 1991 Fred Fish (fnf at cygnus.com)
|
Thu Oct 24 01:32:51 1991 Fred Fish (fnf at cygnus.com)
|
||||||
|
|
||||||
|
* tm-68k.h: Move code that is duplicated in almost every single
|
||||||
|
m68k based machine's configuration files to this common file.
|
||||||
|
Duplications in the configuration files still need to be removed
|
||||||
|
(FIXME).
|
||||||
|
|
||||||
* infrun.c (child_create_inferior): System V versions must call
|
* infrun.c (child_create_inferior): System V versions must call
|
||||||
setpgrp() with no arguments, to comply with prototyping typically
|
setpgrp() with no arguments, to comply with prototyping typically
|
||||||
in <unistd.h>.
|
in <unistd.h>.
|
||||||
|
53
gdb/tm-68k.h
53
gdb/tm-68k.h
@ -73,7 +73,7 @@ read_memory_integer (read_register (SP_REGNUM), 4)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* If your kernel resets the pc after the trap happens you may need to
|
/* If your kernel resets the pc after the trap happens you may need to
|
||||||
define this in m-68k.h. */
|
define this before including this file. */
|
||||||
|
|
||||||
#if !defined (DECR_PC_AFTER_BREAK)
|
#if !defined (DECR_PC_AFTER_BREAK)
|
||||||
#define DECR_PC_AFTER_BREAK 2
|
#define DECR_PC_AFTER_BREAK 2
|
||||||
@ -468,6 +468,57 @@ extern struct ext_format ext_format_68881;
|
|||||||
#endif /* no 68881. */
|
#endif /* no 68881. */
|
||||||
#endif /* no FIND_FRAME_SAVED_REGS. */
|
#endif /* no FIND_FRAME_SAVED_REGS. */
|
||||||
|
|
||||||
|
|
||||||
|
/* Things needed for making the inferior call functions.
|
||||||
|
It seems like every m68k based machine has almost identical definitions
|
||||||
|
in the individual machine's configuration files. Most other cpu types
|
||||||
|
(mips, i386, etc) have routines in their *-tdep.c files to handle this
|
||||||
|
for most configurations. The m68k family should be able to do this as
|
||||||
|
well. These macros can still be overridden when necessary. */
|
||||||
|
|
||||||
|
/* The CALL_DUMMY macro is the sequence of instructions
|
||||||
|
fmovem 0xff,-(sp)
|
||||||
|
moveml 0xfffc,-(sp)
|
||||||
|
clrw -(sp)
|
||||||
|
movew ccr,-(sp)
|
||||||
|
/..* The arguments are pushed at this point by GDB;
|
||||||
|
no code is needed in the dummy for this.
|
||||||
|
The CALL_DUMMY_START_OFFSET gives the position of
|
||||||
|
the following jsr instruction. *../
|
||||||
|
jsr @#32323232
|
||||||
|
addl #69696969,sp
|
||||||
|
bpt
|
||||||
|
nop
|
||||||
|
Note this is 28 bytes.
|
||||||
|
We actually start executing at the jsr, since the pushing of the
|
||||||
|
registers is done by PUSH_DUMMY_FRAME. If this were real code,
|
||||||
|
the arguments for the function called by the jsr would be pushed
|
||||||
|
between the moveml and the jsr, and we could allow it to execute through.
|
||||||
|
But the arguments have to be pushed by GDB after the PUSH_DUMMY_FRAME is done,
|
||||||
|
and we cannot allow the moveml to push the registers again lest they be
|
||||||
|
taken for the arguments. */
|
||||||
|
|
||||||
|
#define CALL_DUMMY {0xf227e0ff, 0x48e7fffc, 0x426742e7, 0x4eb93232, 0x3232dffc, 0x69696969, 0x4e414e71}
|
||||||
|
|
||||||
|
#define CALL_DUMMY_LENGTH 28
|
||||||
|
|
||||||
|
#define CALL_DUMMY_START_OFFSET 12
|
||||||
|
|
||||||
|
/* Insert the specified number of args and function address
|
||||||
|
into a call sequence of the above form stored at DUMMYNAME. */
|
||||||
|
|
||||||
|
#define FIX_CALL_DUMMY(dummyname, pc, fun, nargs, args, type, gcc_p) \
|
||||||
|
{ *(int *)((char *) dummyname + 20) = nargs * 4; \
|
||||||
|
*(int *)((char *) dummyname + 14) = fun; }
|
||||||
|
|
||||||
|
/* Push an empty stack frame, to record the current PC, etc. */
|
||||||
|
|
||||||
|
#define PUSH_DUMMY_FRAME { m68k_push_dummy_frame (); }
|
||||||
|
|
||||||
|
/* Discard from the stack the innermost frame, restoring all registers. */
|
||||||
|
|
||||||
|
#define POP_FRAME { m68k_pop_frame (); }
|
||||||
|
|
||||||
/* Note that stuff for calling inferior functions is not in this file
|
/* Note that stuff for calling inferior functions is not in this file
|
||||||
because the call dummy is different for different breakpoint
|
because the call dummy is different for different breakpoint
|
||||||
instructions, which are different on different systems. Perhaps
|
instructions, which are different on different systems. Perhaps
|
||||||
|
Loading…
Reference in New Issue
Block a user