diff options
author | Joel Brobecker <brobecker@gnat.com> | 2011-12-11 17:35:34 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2011-12-11 17:35:34 +0000 |
commit | f17011e0cdc423256adc389981b4a51b8a13c1ec (patch) | |
tree | 083b19798f4a05e6c170d162bd5c1fac32dc1e6b /gdb | |
parent | 143bb59922e6bbeba29288fd5ac216f594c565dd (diff) | |
download | gdb-f17011e0cdc423256adc389981b4a51b8a13c1ec.zip gdb-f17011e0cdc423256adc389981b4a51b8a13c1ec.tar.gz gdb-f17011e0cdc423256adc389981b4a51b8a13c1ec.tar.bz2 |
Ada exception catchpoint support cleanup.
This patch cleans up a bit the way we detect which type of runtime
the program uses with respect to Ada exceptions. It also removes
an unnecessary check in ada_exception_sal which is already performed
by ada_exception_support_info_sniffer.
Some of the changes are preparation work for detecting the situation
where the Ada runtime is found, but lacking debugging info.
gdb/ChangeLog:
* ada-lang.c (ada_has_this_exception_support): New function,
extracted out of ada_exception_sal and ada_exception_sal.
(ada_exception_support_info_sniffer): Simplify by using
ada_has_this_exception_support.
(ada_exception_sal): Replace unnecessary checks by assertions.
Minor simplifications.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 9 | ||||
-rw-r--r-- | gdb/ada-lang.c | 74 |
2 files changed, 48 insertions, 35 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index a4698d8..cbd770b 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,12 @@ +2011-12-11 Joel Brobecker <brobecker@adacore.com> + + * ada-lang.c (ada_has_this_exception_support): New function, + extracted out of ada_exception_sal and ada_exception_sal. + (ada_exception_support_info_sniffer): Simplify by using + ada_has_this_exception_support. + (ada_exception_sal): Replace unnecessary checks by assertions. + Minor simplifications. + 2011-12-10 Andrey Smirnov <andrew.smirnov@gmail.com> * breakpoint.c (update_global_location_list): Remove nested diff --git a/gdb/ada-lang.c b/gdb/ada-lang.c index d32d316..66d7420 100644 --- a/gdb/ada-lang.c +++ b/gdb/ada-lang.c @@ -10641,6 +10641,35 @@ static const struct exception_support_info exception_support_info_fallback = ada_unhandled_exception_name_addr_from_raise }; +/* Return nonzero if we can detect the exception support routines + described in EINFO. + + This function errors out if an abnormal situation is detected + (for instance, if we find the exception support routines, but + that support is found to be incomplete). */ + +static int +ada_has_this_exception_support (const struct exception_support_info *einfo) +{ + struct symbol *sym; + + /* The symbol we're looking up is provided by a unit in the GNAT runtime + that should be compiled with debugging information. As a result, we + expect to find that symbol in the symtabs. */ + + sym = standard_lookup (einfo->catch_exception_sym, NULL, VAR_DOMAIN); + if (sym == NULL) + return 0; + + /* Make sure that the symbol we found corresponds to a function. */ + + if (SYMBOL_CLASS (sym) != LOC_BLOCK) + error (_("Symbol \"%s\" is not a function (class = %d)"), + SYMBOL_LINKAGE_NAME (sym), SYMBOL_CLASS (sym)); + + return 1; +} + /* For each executable, we sniff which exception info structure to use and cache it in the following global variable. */ @@ -10661,18 +10690,14 @@ ada_exception_support_info_sniffer (void) return; /* Check the latest (default) exception support info. */ - sym = standard_lookup (default_exception_support_info.catch_exception_sym, - NULL, VAR_DOMAIN); - if (sym != NULL) + if (ada_has_this_exception_support (&default_exception_support_info)) { exception_info = &default_exception_support_info; return; } /* Try our fallback exception suport info. */ - sym = standard_lookup (exception_support_info_fallback.catch_exception_sym, - NULL, VAR_DOMAIN); - if (sym != NULL) + if (ada_has_this_exception_support (&exception_support_info_fallback)) { exception_info = &exception_support_info_fallback; return; @@ -11663,52 +11688,31 @@ ada_exception_sal (enum exception_catchpoint_kind ex, char *excep_string, { const char *sym_name; struct symbol *sym; - struct symtab_and_line sal; /* First, find out which exception support info to use. */ ada_exception_support_info_sniffer (); /* Then lookup the function on which we will break in order to catch the Ada exceptions requested by the user. */ - sym_name = ada_exception_sym_name (ex); sym = standard_lookup (sym_name, NULL, VAR_DOMAIN); - /* The symbol we're looking up is provided by a unit in the GNAT runtime - that should be compiled with debugging information. As a result, we - expect to find that symbol in the symtabs. If we don't find it, then - the target most likely does not support Ada exceptions, or we cannot - insert exception breakpoints yet, because the GNAT runtime hasn't been - loaded yet. */ - - /* brobecker/2006-12-26: It is conceivable that the runtime was compiled - in such a way that no debugging information is produced for the symbol - we are looking for. In this case, we could search the minimal symbols - as a fall-back mechanism. This would still be operating in degraded - mode, however, as we would still be missing the debugging information - that is needed in order to extract the name of the exception being - raised (this name is printed in the catchpoint message, and is also - used when trying to catch a specific exception). We do not handle - this case for now. */ - - if (sym == NULL) - error (_("Unable to break on '%s' in this configuration."), sym_name); - - /* Make sure that the symbol we found corresponds to a function. */ - if (SYMBOL_CLASS (sym) != LOC_BLOCK) - error (_("Symbol \"%s\" is not a function (class = %d)"), - sym_name, SYMBOL_CLASS (sym)); + /* We can assume that SYM is not NULL at this stage. If the symbol + did not exist, ada_exception_support_info_sniffer would have + raised an exception. - sal = find_function_start_sal (sym, 1); + Also, ada_exception_support_info_sniffer should have already + verified that SYM is a function symbol. */ + gdb_assert (sym != NULL); + gdb_assert (SYMBOL_CLASS (sym) == LOC_BLOCK); /* Set ADDR_STRING. */ - *addr_string = xstrdup (sym_name); /* Set OPS. */ *ops = ada_exception_breakpoint_ops (ex); - return sal; + return find_function_start_sal (sym, 1); } /* Parse the arguments (ARGS) of the "catch exception" command. |