diff options
author | Tom Tromey <tromey@redhat.com> | 2013-12-18 10:46:02 -0700 |
---|---|---|
committer | Tom Tromey <tromey@redhat.com> | 2014-02-19 07:47:25 -0700 |
commit | cda0f38c9e2092b84e9b44a9da7f7c6ef79a2332 (patch) | |
tree | 69ed3baf8affbb24b73ee0dc2d59e024b06766fd | |
parent | 62f64d7a6a8e8e46afa52133dc8a098684e118e9 (diff) | |
download | binutils-cda0f38c9e2092b84e9b44a9da7f7c6ef79a2332.zip binutils-cda0f38c9e2092b84e9b44a9da7f7c6ef79a2332.tar.gz binutils-cda0f38c9e2092b84e9b44a9da7f7c6ef79a2332.tar.bz2 |
convert to_remove_exec_catchpoint
2014-02-19 Tom Tromey <tromey@redhat.com>
* target-delegates.c: Rebuild.
* target.c (update_current_target): Don't inherit or default
to_insert_exec_catchpoint.
* target.h (struct target_ops) <to_insert_exec_catchpoint>: Use
TARGET_DEFAULT_RETURN.
-rw-r--r-- | gdb/ChangeLog | 8 | ||||
-rw-r--r-- | gdb/target-delegates.c | 16 | ||||
-rw-r--r-- | gdb/target.c | 5 | ||||
-rw-r--r-- | gdb/target.h | 3 |
4 files changed, 27 insertions, 5 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 0107969..c7e6176 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -6,6 +6,14 @@ * target.h (struct target_ops) <to_insert_exec_catchpoint>: Use TARGET_DEFAULT_RETURN. +2014-01-08 Tom Tromey <tromey@redhat.com> + + * target-delegates.c: Rebuild. + * target.c (update_current_target): Don't inherit or default + to_insert_exec_catchpoint. + * target.h (struct target_ops) <to_insert_exec_catchpoint>: Use + TARGET_DEFAULT_RETURN. + 2014-02-19 Tom Tromey <tromey@redhat.com> * target-delegates.c: Rebuild. diff --git a/gdb/target-delegates.c b/gdb/target-delegates.c index 20f5c5c..f786569 100644 --- a/gdb/target-delegates.c +++ b/gdb/target-delegates.c @@ -387,6 +387,19 @@ tdefault_insert_exec_catchpoint (struct target_ops *self, int arg1) return 1; } +static int +delegate_remove_exec_catchpoint (struct target_ops *self, int arg1) +{ + self = self->beneath; + return self->to_remove_exec_catchpoint (self, arg1); +} + +static int +tdefault_remove_exec_catchpoint (struct target_ops *self, int arg1) +{ + return 1; +} + static void delegate_rcmd (struct target_ops *self, char *arg1, struct ui_file *arg2) { @@ -516,6 +529,8 @@ install_delegators (struct target_ops *ops) ops->to_remove_vfork_catchpoint = delegate_remove_vfork_catchpoint; if (ops->to_insert_exec_catchpoint == NULL) ops->to_insert_exec_catchpoint = delegate_insert_exec_catchpoint; + if (ops->to_remove_exec_catchpoint == NULL) + ops->to_remove_exec_catchpoint = delegate_remove_exec_catchpoint; if (ops->to_rcmd == NULL) ops->to_rcmd = delegate_rcmd; if (ops->to_can_async_p == NULL) @@ -566,6 +581,7 @@ install_dummy_methods (struct target_ops *ops) ops->to_insert_vfork_catchpoint = tdefault_insert_vfork_catchpoint; ops->to_remove_vfork_catchpoint = tdefault_remove_vfork_catchpoint; ops->to_insert_exec_catchpoint = tdefault_insert_exec_catchpoint; + ops->to_remove_exec_catchpoint = tdefault_remove_exec_catchpoint; ops->to_rcmd = default_rcmd; ops->to_can_async_p = find_default_can_async_p; ops->to_is_async_p = find_default_is_async_p; diff --git a/gdb/target.c b/gdb/target.c index 783ed75..4185871 100644 --- a/gdb/target.c +++ b/gdb/target.c @@ -636,7 +636,7 @@ update_current_target (void) /* Do not inherit to_remove_vfork_catchpoint. */ /* Do not inherit to_follow_fork. */ /* Do not inherit to_insert_exec_catchpoint. */ - INHERIT (to_remove_exec_catchpoint, t); + /* Do not inherit to_remove_exec_catchpoint. */ INHERIT (to_set_syscall_catchpoint, t); INHERIT (to_has_exited, t); /* Do not inherit to_mourn_inferior. */ @@ -734,9 +734,6 @@ update_current_target (void) (int (*) (CORE_ADDR, gdb_byte *, int, int, struct mem_attrib *, struct target_ops *)) nomemory); - de_fault (to_remove_exec_catchpoint, - (int (*) (struct target_ops *, int)) - return_one); de_fault (to_set_syscall_catchpoint, (int (*) (struct target_ops *, int, int, int, int, int *)) return_one); diff --git a/gdb/target.h b/gdb/target.h index cfec2a1..436827e 100644 --- a/gdb/target.h +++ b/gdb/target.h @@ -530,7 +530,8 @@ struct target_ops int (*to_follow_fork) (struct target_ops *, int, int); int (*to_insert_exec_catchpoint) (struct target_ops *, int) TARGET_DEFAULT_RETURN (1); - int (*to_remove_exec_catchpoint) (struct target_ops *, int); + int (*to_remove_exec_catchpoint) (struct target_ops *, int) + TARGET_DEFAULT_RETURN (1); int (*to_set_syscall_catchpoint) (struct target_ops *, int, int, int, int, int *); int (*to_has_exited) (struct target_ops *, int, int, int *); |