|  | /* Shared library declarations for GDB, the GNU Debugger. | 
|  |  | 
|  | Copyright (C) 1992-2024 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/>.  */ | 
|  |  | 
|  | #ifndef SOLIB_H | 
|  | #define SOLIB_H | 
|  |  | 
|  | /* Forward decl's for prototypes */ | 
|  | struct solib; | 
|  | struct target_ops; | 
|  | struct solib_ops; | 
|  | struct program_space; | 
|  |  | 
|  | #include "gdb_bfd.h" | 
|  | #include "symfile-add-flags.h" | 
|  | #include "gdbsupport/function-view.h" | 
|  |  | 
|  | /* Value of the 'set debug solib' configuration variable.  */ | 
|  |  | 
|  | extern bool debug_solib; | 
|  |  | 
|  | /* Print an "solib" debug statement.  */ | 
|  |  | 
|  | #define solib_debug_printf(fmt, ...) \ | 
|  | debug_prefixed_printf_cond (debug_solib, "solib", fmt, ##__VA_ARGS__) | 
|  |  | 
|  | #define SOLIB_SCOPED_DEBUG_START_END(fmt, ...) \ | 
|  | scoped_debug_start_end (debug_solib, "solib", fmt, ##__VA_ARGS__) | 
|  |  | 
|  | /* Called when we free all symtabs of PSPACE, to free the shared library | 
|  | information as well.  */ | 
|  |  | 
|  | extern void clear_solib (program_space *pspace); | 
|  |  | 
|  | /* Called to add symbols from a shared library to gdb's symbol table.  */ | 
|  |  | 
|  | extern void solib_add (const char *, int, int); | 
|  | extern bool solib_read_symbols (solib &, symfile_add_flags); | 
|  |  | 
|  | /* Function to be called when the inferior starts up, to discover the | 
|  | names of shared libraries that are dynamically linked, the base | 
|  | addresses to which they are linked, and sufficient information to | 
|  | read in their symbols at a later time.  */ | 
|  |  | 
|  | extern void solib_create_inferior_hook (int from_tty); | 
|  |  | 
|  | /* If ADDR lies in a shared library, return its name.  */ | 
|  |  | 
|  | extern const char *solib_name_from_address (struct program_space *, CORE_ADDR); | 
|  |  | 
|  | /* Return true if ADDR lies within SOLIB.  */ | 
|  |  | 
|  | extern bool solib_contains_address_p (const solib &, CORE_ADDR); | 
|  |  | 
|  | /* Return whether the data starting at VADDR, size SIZE, must be kept | 
|  | in a core file for shared libraries loaded before "gcore" is used | 
|  | to be handled correctly when the core file is loaded.  This only | 
|  | applies when the section would otherwise not be kept in the core | 
|  | file (in particular, for readonly sections).  */ | 
|  |  | 
|  | extern bool solib_keep_data_in_core (CORE_ADDR vaddr, unsigned long size); | 
|  |  | 
|  | /* Return true if PC lies in the dynamic symbol resolution code of the | 
|  | run time loader.  */ | 
|  |  | 
|  | extern bool in_solib_dynsym_resolve_code (CORE_ADDR); | 
|  |  | 
|  | /* Discard symbols that were auto-loaded from shared libraries.  */ | 
|  |  | 
|  | extern void no_shared_libraries (const char *ignored, int from_tty); | 
|  |  | 
|  | /* Synchronize GDB's shared object list with inferior's. | 
|  |  | 
|  | Extract the list of currently loaded shared objects from the | 
|  | inferior, and compare it with the list of shared objects in the | 
|  | current program space's list of shared libraries.  Edit | 
|  | so_list_head to bring it in sync with the inferior's new list. | 
|  |  | 
|  | If we notice that the inferior has unloaded some shared objects, | 
|  | free any symbolic info GDB had read about those shared objects. | 
|  |  | 
|  | Don't load symbolic info for any new shared objects; just add them | 
|  | to the list, and leave their symbols_loaded flag clear. | 
|  |  | 
|  | If FROM_TTY is non-null, feel free to print messages about what | 
|  | we're doing.  */ | 
|  |  | 
|  | extern void update_solib_list (int from_tty); | 
|  |  | 
|  | /* Return true if NAME is the libpthread shared library.  */ | 
|  |  | 
|  | extern bool libpthread_name_p (const char *name); | 
|  |  | 
|  | /* Look up symbol from both symbol table and dynamic string table.  */ | 
|  |  | 
|  | extern CORE_ADDR gdb_bfd_lookup_symbol | 
|  | (bfd *abfd, gdb::function_view<bool (const asymbol *)> match_sym); | 
|  |  | 
|  | /* Look up symbol from symbol table.  */ | 
|  |  | 
|  | extern CORE_ADDR gdb_bfd_lookup_symbol_from_symtab | 
|  | (bfd *abfd, gdb::function_view<bool (const asymbol *)> match_sym); | 
|  |  | 
|  | /* Scan for DESIRED_DYNTAG in .dynamic section of ABFD.  If DESIRED_DYNTAG is | 
|  | found, 1 is returned and the corresponding PTR and PTR_ADDR are set.  */ | 
|  |  | 
|  | extern int gdb_bfd_scan_elf_dyntag (const int desired_dyntag, bfd *abfd, | 
|  | CORE_ADDR *ptr, CORE_ADDR *ptr_addr); | 
|  |  | 
|  | /* If FILENAME refers to an ELF shared object then attempt to return the | 
|  | string referred to by its DT_SONAME tag.   */ | 
|  |  | 
|  | extern gdb::unique_xmalloc_ptr<char> gdb_bfd_read_elf_soname | 
|  | (const char *filename); | 
|  |  | 
|  | /* Enable or disable optional solib event breakpoints as appropriate.  */ | 
|  |  | 
|  | extern void update_solib_breakpoints (void); | 
|  |  | 
|  | /* Handle an solib event by calling solib_add.  */ | 
|  |  | 
|  | extern void handle_solib_event (void); | 
|  |  | 
|  | /* Associate SONAME with BUILD_ID in ABFD's registry so that it can be | 
|  | retrieved with get_cbfd_soname_build_id.  */ | 
|  |  | 
|  | extern void set_cbfd_soname_build_id (gdb_bfd_ref_ptr abfd, | 
|  | const char *soname, | 
|  | const bfd_build_id *build_id); | 
|  |  | 
|  | #endif /* SOLIB_H */ |