diff options
Diffstat (limited to 'gdb/dwarf2/ada-imported.c')
-rw-r--r-- | gdb/dwarf2/ada-imported.c | 122 |
1 files changed, 122 insertions, 0 deletions
diff --git a/gdb/dwarf2/ada-imported.c b/gdb/dwarf2/ada-imported.c new file mode 100644 index 00000000000..d1d99be6923 --- /dev/null +++ b/gdb/dwarf2/ada-imported.c @@ -0,0 +1,122 @@ +/* Ada Pragma Import support. + + Copyright (C) 2023 Free Software Foundation, Inc. + + 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 "symtab.h" +#include "value.h" +#include "dwarf2/loc.h" + +/* Helper to get the imported symbol's real name. */ +static const char * +get_imported_name (const struct symbol *sym) +{ + return (const char *) SYMBOL_LOCATION_BATON (sym); +} + +/* Implement the read_variable method from symbol_computed_ops. */ + +static struct value * +ada_imported_read_variable (struct symbol *symbol, frame_info_ptr frame) +{ + const char *name = get_imported_name (symbol); + bound_minimal_symbol minsym = lookup_minimal_symbol_linkage (name, false); + if (minsym.minsym == nullptr) + error (_("could not find imported name %s"), name); + return value_at (symbol->type (), minsym.value_address ()); +} + +/* Implement the read_variable method from symbol_computed_ops. */ + +static enum symbol_needs_kind +ada_imported_get_symbol_read_needs (struct symbol *symbol) +{ + return SYMBOL_NEEDS_NONE; +} + +/* Implement the describe_location method from + symbol_computed_ops. */ + +static void +ada_imported_describe_location (struct symbol *symbol, CORE_ADDR addr, + struct ui_file *stream) +{ + gdb_printf (stream, "an imported name for '%s'", + get_imported_name (symbol)); +} + +/* Implement the tracepoint_var_ref method from + symbol_computed_ops. */ + +static void +ada_imported_tracepoint_var_ref (struct symbol *symbol, struct agent_expr *ax, + struct axs_value *value) +{ + /* Probably could be done, but not needed right now. */ + error (_("not implemented: trace of imported Ada symbol")); +} + +/* Implement the generate_c_location method from + symbol_computed_ops. */ + +static void +ada_imported_generate_c_location (struct symbol *symbol, string_file *stream, + struct gdbarch *gdbarch, + std::vector<bool> ®isters_used, + CORE_ADDR pc, const char *result_name) +{ + /* Probably could be done, but not needed right now, and perhaps not + ever. */ + error (_("not implemented: compile translation of imported Ada symbol")); +} + +const struct symbol_computed_ops ada_imported_funcs = +{ + ada_imported_read_variable, + nullptr, + ada_imported_get_symbol_read_needs, + ada_imported_describe_location, + 0, + ada_imported_tracepoint_var_ref, + ada_imported_generate_c_location +}; + +/* Implement the get_block_value method from symbol_block_ops. */ + +static const block * +ada_alias_get_block_value (const struct symbol *sym) +{ + const char *name = get_imported_name (sym); + block_symbol real_symbol = lookup_global_symbol (name, nullptr, + VAR_DOMAIN); + if (real_symbol.symbol == nullptr) + error (_("could not find alias '%s' for function '%s'"), + name, sym->print_name ()); + if (real_symbol.symbol->aclass () != LOC_BLOCK) + error (_("alias '%s' for function '%s' is not a function"), + name, sym->print_name ()); + + return real_symbol.symbol->value_block (); +} + +const struct symbol_block_ops ada_function_alias_funcs = +{ + nullptr, + nullptr, + ada_alias_get_block_value +}; |