diff options
author | Mircea Gherzan <mgherzan@sourceware.org> | 2012-12-12 21:20:13 +0000 |
---|---|---|
committer | Mircea Gherzan <mgherzan@sourceware.org> | 2012-12-12 21:20:13 +0000 |
commit | 91985142973d550628c61d201e0a7cd3e36cd5b3 (patch) | |
tree | 2ad6df5064c30b67befdfbd0951935a7a96c95ff /gdb/mi | |
parent | afedb563c68c0856f41d8b8de5822943e136702a (diff) | |
download | fsf-binutils-gdb-91985142973d550628c61d201e0a7cd3e36cd5b3.zip fsf-binutils-gdb-91985142973d550628c61d201e0a7cd3e36cd5b3.tar.gz fsf-binutils-gdb-91985142973d550628c61d201e0a7cd3e36cd5b3.tar.bz2 |
MI: add the -catch-load and -catch-unload commands
They are equivalent to "catch load" and "catch unload" from CLI.
Rationale: GUIs might be interested in catching solib load or
unload events.
2012-11-16 Mircea Gherzan <mircea.gherzan@intel.com>
* Makefile.in (SUBDIR_MI_OBS): Add mi-cmd-catch.o.
(SUBDIR_MI_SRCS): Add mi/mi-cmd-catch.c.
* breakpoint.c (add_solib_catchpoint): New function that
can be used by both CLI and MI, factored out from
catch_load_or_unload.
(catch_load_or_unload): Strip it down and make it use the
new add_solib_catchpoint.
* breakpoint.h (add_solib_catchpoint): Declare it.
* mi/mi-cmd-break.h: New file.
* mi/mi-cmd-break.c: Include mi-cmd-break.h.
(setup_breakpoint_reporting): New function used for both
catchpoints and breakpoints.
(mi_cmd_break_insert): Use setup_breakpoint_reporting.
* mi/mi-cmd-catch.c: New file.
* mi/mi-cmds.c (mi_cmds): Add the handlers for -catch-load
and -catch-unload.
* mi/mi-cmds.h: Declare the handlers for -catch-load and
-catch-unload.
Diffstat (limited to 'gdb/mi')
-rw-r--r-- | gdb/mi/mi-cmd-break.c | 34 | ||||
-rw-r--r-- | gdb/mi/mi-cmd-break.h | 30 | ||||
-rw-r--r-- | gdb/mi/mi-cmd-catch.c | 102 | ||||
-rw-r--r-- | gdb/mi/mi-cmds.c | 4 | ||||
-rw-r--r-- | gdb/mi/mi-cmds.h | 2 |
5 files changed, 164 insertions, 8 deletions
diff --git a/gdb/mi/mi-cmd-break.c b/gdb/mi/mi-cmd-break.c index 487d42d..a36e1ef 100644 --- a/gdb/mi/mi-cmd-break.c +++ b/gdb/mi/mi-cmd-break.c @@ -29,6 +29,7 @@ #include "exceptions.h" #include "observer.h" #include "mi-main.h" +#include "mi-cmd-break.h" enum { @@ -59,6 +60,30 @@ enum bp_type REGEXP_BP }; +/* Arrange for all new breakpoints and catchpoints to be reported to + CURRENT_UIOUT until the cleanup returned by this function is run. + + Note that MI output will be probably invalid if more than one + breakpoint is created inside one MI command. */ + +struct cleanup * +setup_breakpoint_reporting (void) +{ + struct cleanup *rev_flag; + + if (! mi_breakpoint_observers_installed) + { + observer_attach_breakpoint_created (breakpoint_notify); + mi_breakpoint_observers_installed = 1; + } + + rev_flag = make_cleanup_restore_integer (&mi_can_breakpoint_notify); + mi_can_breakpoint_notify = 1; + + return rev_flag; +} + + /* Implements the -break-insert command. See the MI manual for the list of possible options. */ @@ -144,14 +169,7 @@ mi_cmd_break_insert (char *command, char **argv, int argc) address = argv[oind]; /* Now we have what we need, let's insert the breakpoint! */ - if (! mi_breakpoint_observers_installed) - { - observer_attach_breakpoint_created (breakpoint_notify); - mi_breakpoint_observers_installed = 1; - } - - back_to = make_cleanup_restore_integer (&mi_can_breakpoint_notify); - mi_can_breakpoint_notify = 1; + back_to = setup_breakpoint_reporting (); /* Note that to request a fast tracepoint, the client uses the "hardware" flag, although there's nothing of hardware related to diff --git a/gdb/mi/mi-cmd-break.h b/gdb/mi/mi-cmd-break.h new file mode 100644 index 0000000..8a46754 --- /dev/null +++ b/gdb/mi/mi-cmd-break.h @@ -0,0 +1,30 @@ +/* MI Command Set - breakpoint and watchpoint commands. + Copyright (C) 2012 Free Software Foundation, Inc. + + Contributed by Intel Corporation. + + 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 3 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, see <http://www.gnu.org/licenses/>. */ + +#ifndef MI_CMD_BREAK_H +#define MI_CMD_BREAK_H + + +/* Setup the reporting of the insertion of a new breakpoint or + catchpoint. */ +struct cleanup *setup_breakpoint_reporting (void); + +#endif + diff --git a/gdb/mi/mi-cmd-catch.c b/gdb/mi/mi-cmd-catch.c new file mode 100644 index 0000000..a3efa6f --- /dev/null +++ b/gdb/mi/mi-cmd-catch.c @@ -0,0 +1,102 @@ +/* MI Command Set - catch commands. + Copyright (C) 2012 Free Software Foundation, Inc. + + Contributed by Intel Corporation. + + 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 3 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, see <http://www.gnu.org/licenses/>. */ + +#include "defs.h" +#include "arch-utils.h" +#include "breakpoint.h" +#include "gdb.h" +#include "libiberty.h" +#include "mi-cmds.h" +#include "mi-getopt.h" +#include "mi-cmd-break.h" + + +/* Common path for the -catch-load and -catch-unload. */ + +static void +mi_catch_load_unload (int load, char *argv[], int argc) +{ + struct solib_catchpoint *c; + struct cleanup *back_to; + const char *actual_cmd = load ? "-catch-load" : "-catch-unload"; + int temp = 0; + int enabled = 1; + int oind = 0; + char *oarg; + enum opt + { + OPT_TEMP, + OPT_DISABLED, + }; + static const struct mi_opt opts[] = + { + { "t", OPT_TEMP, 0 }, + { "d", OPT_DISABLED, 0 }, + { 0, 0, 0 } + }; + + for (;;) + { + int opt = mi_getopt (actual_cmd, argc, argv, opts, + &oind, &oarg); + + if (opt < 0) + break; + + switch ((enum opt) opt) + { + case OPT_TEMP: + temp = 1; + break; + case OPT_DISABLED: + enabled = 0; + break; + } + } + + if (oind >= argc) + error (_("-catch-load/unload: Missing <library name>")); + if (oind < argc -1) + error (_("-catch-load/unload: Garbage following the <library name>")); + + back_to = setup_breakpoint_reporting (); + + add_solib_catchpoint (argv[oind], load, temp, enabled); + + do_cleanups (back_to); +} + +/* Handler for the -catch-load. */ + +void +mi_cmd_catch_load (char *cmd, char *argv[], int argc) +{ + mi_catch_load_unload (1, argv, argc); +} + + +/* Handler for the -catch-unload. */ + +void +mi_cmd_catch_unload (char *cmd, char *argv[], int argc) +{ + mi_catch_load_unload (0, argv, argc); +} + diff --git a/gdb/mi/mi-cmds.c b/gdb/mi/mi-cmds.c index 572625f..0e3cd6c 100644 --- a/gdb/mi/mi-cmds.c +++ b/gdb/mi/mi-cmds.c @@ -67,6 +67,10 @@ static struct mi_cmd mi_cmds[] = &mi_suppress_notification.breakpoint), DEF_MI_CMD_MI_1 ("break-watch", mi_cmd_break_watch, &mi_suppress_notification.breakpoint), + DEF_MI_CMD_MI_1 ("catch-load", mi_cmd_catch_load, + &mi_suppress_notification.breakpoint), + DEF_MI_CMD_MI_1 ("catch-unload", mi_cmd_catch_unload, + &mi_suppress_notification.breakpoint), DEF_MI_CMD_MI ("data-disassemble", mi_cmd_disassemble), DEF_MI_CMD_MI ("data-evaluate-expression", mi_cmd_data_evaluate_expression), DEF_MI_CMD_MI ("data-list-changed-registers", diff --git a/gdb/mi/mi-cmds.h b/gdb/mi/mi-cmds.h index cf1a5eb..da8df48 100644 --- a/gdb/mi/mi-cmds.h +++ b/gdb/mi/mi-cmds.h @@ -43,6 +43,8 @@ extern mi_cmd_argv_ftype mi_cmd_break_insert; extern mi_cmd_argv_ftype mi_cmd_break_commands; extern mi_cmd_argv_ftype mi_cmd_break_passcount; extern mi_cmd_argv_ftype mi_cmd_break_watch; +extern mi_cmd_argv_ftype mi_cmd_catch_load; +extern mi_cmd_argv_ftype mi_cmd_catch_unload; extern mi_cmd_argv_ftype mi_cmd_disassemble; extern mi_cmd_argv_ftype mi_cmd_data_evaluate_expression; extern mi_cmd_argv_ftype mi_cmd_data_list_register_names; |