+ as well. */
+
+extern void clear_solib (void);
+
+/* 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 (struct so_list *, 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 char *solib_name_from_address (struct program_space *, CORE_ADDR);
+
+/* Return true if ADDR lies within SOLIB. */
+
+extern bool solib_contains_address_p (const struct so_list *, 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);
+
+/* Set the solib operations for GDBARCH to NEW_OPS. */
+
+extern void set_solib_ops (struct gdbarch *gdbarch,
+ const struct target_so_ops *new_ops);
+
+/* 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);