diff options
author | Richard Earnshaw <richard.earnshaw@arm.com> | 2002-02-18 13:35:31 +0000 |
---|---|---|
committer | Richard Earnshaw <richard.earnshaw@arm.com> | 2002-02-18 13:35:31 +0000 |
commit | 9df628e0aa21fe96d386e6a634d0af30d9b2efb7 (patch) | |
tree | 503736636ec7c2ab30389dada3d698497f8e14d0 /gdb/breakpoint.c | |
parent | 82bd7b59c94c3fbb5ee9186e7c08b350ea073375 (diff) | |
download | gdb-9df628e0aa21fe96d386e6a634d0af30d9b2efb7.zip gdb-9df628e0aa21fe96d386e6a634d0af30d9b2efb7.tar.gz gdb-9df628e0aa21fe96d386e6a634d0af30d9b2efb7.tar.bz2 |
* gdbarch.sh (GET_LONGJMP_TARGET): Add rule.
* gdbarch.c gdbarch.h: Regenerate.
* breakpoint.c (create_longjmp_breakpoint): Always compile this
function.
(breakpoint_reset): Test GET_LONGJMP_TARGET_P().
* infrun.c (GET_LONGJMP_TARGET): Delete default definition.
(handle_inferior_event): Test GET_LONGJMP_TARGET_P().
* arm-tdep.h (struct gdbarch_tdep): Add jb_pc and jb_elt_size fields.
* arm-tdep.c (arm_get_longjmp_target): New function.
(arm_gdbarch_init): Initialize jb_pc to -1. If ABI handler changes
this to a positive value register arm_get_longjmp_target as the
longjmp handler.
* arm-linux-tdep.c (arm_get_longjmp_target): Delete.
(arm_linux_init_abi): Set up longjmp description in tdep.
* armnbsd-nat.c (get_longjmp_target): Delete.
* armnbsd-tdep.c (arm_netbsd_init_abi_common): Set up longjmp
description in tdep.
* config/arm/tm-nbsd.h (JB_ELEMENT_SIZE, JB_PC): Delete.
(get_longjmp_target): Delete declaration.
(GET_LONGJMP_TARGET): Delete.
* config/arm/tm-linux.h (arm_get_longjmp_target): Delete declaration.
(GET_LONGJMP_TARGET): Delete.
Diffstat (limited to 'gdb/breakpoint.c')
-rw-r--r-- | gdb/breakpoint.c | 20 |
1 files changed, 8 insertions, 12 deletions
diff --git a/gdb/breakpoint.c b/gdb/breakpoint.c index b22a206..640505e 100644 --- a/gdb/breakpoint.c +++ b/gdb/breakpoint.c @@ -143,9 +143,7 @@ static int cover_target_enable_exception_callback (PTR); static void maintenance_info_breakpoints (char *, int); -#ifdef GET_LONGJMP_TARGET static void create_longjmp_breakpoint (char *); -#endif static void create_overlay_event_breakpoint (char *); @@ -3758,7 +3756,6 @@ create_internal_breakpoint (CORE_ADDR address, enum bptype type) return b; } -#ifdef GET_LONGJMP_TARGET static void create_longjmp_breakpoint (char *func_name) @@ -3782,8 +3779,6 @@ create_longjmp_breakpoint (char *func_name) b->addr_string = xstrdup (func_name); } -#endif /* #ifdef GET_LONGJMP_TARGET */ - /* Call this routine when stepping and nexting to enable a breakpoint if we do a longjmp(). When we hit that breakpoint, call set_longjmp_resume_breakpoint() to figure out where we are going. */ @@ -6967,13 +6962,14 @@ breakpoint_re_set (void) set_language (save_language); input_radix = save_input_radix; -#ifdef GET_LONGJMP_TARGET - create_longjmp_breakpoint ("longjmp"); - create_longjmp_breakpoint ("_longjmp"); - create_longjmp_breakpoint ("siglongjmp"); - create_longjmp_breakpoint ("_siglongjmp"); - create_longjmp_breakpoint (NULL); -#endif + if (GET_LONGJMP_TARGET_P ()) + { + create_longjmp_breakpoint ("longjmp"); + create_longjmp_breakpoint ("_longjmp"); + create_longjmp_breakpoint ("siglongjmp"); + create_longjmp_breakpoint ("_siglongjmp"); + create_longjmp_breakpoint (NULL); + } create_overlay_event_breakpoint ("_ovly_debug_event"); } |