From 22b089e625f66921a8199a117007c8c712519037 Mon Sep 17 00:00:00 2001 From: Eli Zaretskii Date: Sun, 29 Jul 2001 08:14:45 +0000 Subject: Support for stepping through longjmp in DJGPP programs: * config/i386/tm-go32.h (JB_ELEMENT_SIZE, JB_PC): New macros. (GET_LONGJMP_TARGET): Define to call get_longjmp_target. (get_longjmp_target): Add prototype. --- gdb/ChangeLog | 8 ++++++++ gdb/NEWS | 2 ++ gdb/config/i386/tm-go32.h | 16 ++++++++++++++++ 3 files changed, 26 insertions(+) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index ac8e0a1c1b6..741377a1387 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,11 @@ +2001-07-29 Eli Zaretskii + + Support for stepping through longjmp in DJGPP programs: + + * config/i386/tm-go32.h (JB_ELEMENT_SIZE, JB_PC): New macros. + (GET_LONGJMP_TARGET): Define to call get_longjmp_target. + (get_longjmp_target): Add prototype. + 2001-07-28 Andrew Cagney * version.in: Bump version number to 5.0.90-cvs. diff --git a/gdb/NEWS b/gdb/NEWS index db1e486de70..edaf5e81b42 100644 --- a/gdb/NEWS +++ b/gdb/NEWS @@ -165,6 +165,8 @@ which is part of the DJGPP development kit). DWARF2 debug info is now supported. +It is now possible to `step' and `next' through calls to `longjmp'. + * Changes in documentation. All GDB documentation was converted to GFDL, the GNU Free diff --git a/gdb/config/i386/tm-go32.h b/gdb/config/i386/tm-go32.h index f416396a3f5..024f4fbe355 100644 --- a/gdb/config/i386/tm-go32.h +++ b/gdb/config/i386/tm-go32.h @@ -48,4 +48,20 @@ #undef FRAME_SAVED_PC #define FRAME_SAVED_PC(FRAME) (read_memory_integer ((FRAME)->frame + 4, 4)) +/* Support for longjmp. */ + +/* Details about jmp_buf. It's supposed to be an array of integers. */ + +#define JB_ELEMENT_SIZE 4 /* Size of elements in jmp_buf. */ +#define JB_PC 8 /* Array index of saved PC inside jmp_buf. */ + +/* 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) get_longjmp_target (addr) +extern int get_longjmp_target (CORE_ADDR *addr); + #endif /* TM_GO32_H */ -- cgit v1.2.1