Index: gdb/minsyms.h |
diff --git a/gdb/minsyms.h b/gdb/minsyms.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..8f0472fb32c61fcb2cc2dbde19e75c29e83618f9 |
--- /dev/null |
+++ b/gdb/minsyms.h |
@@ -0,0 +1,251 @@ |
+/* Minimal symbol table definitions for GDB. |
+ |
+ Copyright (C) 2011-2012 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 MINSYMS_H |
+#define MINSYMS_H |
+ |
+/* This header declares most of the API for dealing with minimal |
+ symbols and minimal symbol tables. A few things are declared |
+ elsewhere; see below. |
+ |
+ A minimal symbol is a symbol for which there is no direct debug |
+ information. For example, for an ELF binary, minimal symbols are |
+ created from the ELF symbol table. |
+ |
+ For the definition of the minimal symbol structure, see struct |
+ minimal_symbol in symtab.h. |
+ |
+ Minimal symbols are stored in tables attached to an objfile; see |
+ objfiles.h for details. Code should generally treat these tables |
+ as opaque and use functions provided by minsyms.c to inspect them. |
+*/ |
+ |
+/* Prepare to start collecting minimal symbols. This should be called |
+ by a symbol reader to initialize the minimal symbol module. |
+ Currently, minimal symbol table creation is not reentrant; it |
+ relies on global (static) variables in minsyms.c. */ |
+ |
+void init_minimal_symbol_collection (void); |
+ |
+/* Return a cleanup which is used to clean up the global state left |
+ over by minimal symbol creation. After calling |
+ init_minimal_symbol_collection, a symbol reader should call this |
+ function. Then, after all minimal symbols have been read, |
+ regardless of whether they are installed or not, the cleanup |
+ returned by this function should be run. */ |
+ |
+struct cleanup *make_cleanup_discard_minimal_symbols (void); |
+ |
+/* Record a new minimal symbol. This is the "full" entry point; |
+ simpler convenience entry points are also provided below. |
+ |
+ This returns a new minimal symbol. It is ok to modify the returned |
+ minimal symbol (though generally not necessary). It is not ok, |
+ though, to stash the pointer anywhere; as minimal symbols may be |
+ moved after creation. The memory for the returned minimal symbol |
+ is still owned by the minsyms.c code, and should not be freed. |
+ |
+ Arguments are: |
+ |
+ NAME - the symbol's name |
+ NAME_LEN - the length of the name |
+ COPY_NAME - if true, the minsym code must make a copy of NAME. If |
+ false, then NAME must be NUL-terminated, and must have a lifetime |
+ that is at least as long as OBJFILE's lifetime. |
+ ADDRESS - the address of the symbol |
+ MS_TYPE - the type of the symbol |
+ SECTION - the symbol's section |
+ BFD_SECTION - the symbol's BFD section; used to find the |
+ appropriate obj_section for the minimal symbol. This can be NULL. |
+ OBJFILE - the objfile associated with the minimal symbol. */ |
+ |
+struct minimal_symbol *prim_record_minimal_symbol_full |
+ (const char *name, |
+ int name_len, |
+ int copy_name, |
+ CORE_ADDR address, |
+ enum minimal_symbol_type ms_type, |
+ int section, |
+ asection *bfd_section, |
+ struct objfile *objfile); |
+ |
+/* Like prim_record_minimal_symbol_full, but: |
+ - uses strlen to compute NAME_LEN, |
+ - passes COPY_NAME = 0, |
+ - passes SECTION = 0, |
+ - and passes BFD_SECTION = NULL. |
+ |
+ This variant does not return the new symbol. */ |
+ |
+void prim_record_minimal_symbol (const char *, CORE_ADDR, |
+ enum minimal_symbol_type, |
+ struct objfile *); |
+ |
+/* Like prim_record_minimal_symbol_full, but: |
+ - uses strlen to compute NAME_LEN, |
+ - passes COPY_NAME = 0. */ |
+ |
+struct minimal_symbol *prim_record_minimal_symbol_and_info |
+ (const char *, |
+ CORE_ADDR, |
+ enum minimal_symbol_type, |
+ int section, |
+ asection *bfd_section, |
+ struct objfile *); |
+ |
+/* Install the minimal symbols that have been collected into the given |
+ objfile. After this is called, the cleanup returned by |
+ make_cleanup_discard_minimal_symbols should be run in order to |
+ clean up global state. */ |
+ |
+void install_minimal_symbols (struct objfile *); |
+ |
+/* Create the terminating entry of OBJFILE's minimal symbol table. |
+ If OBJFILE->msymbols is zero, allocate a single entry from |
+ OBJFILE->objfile_obstack; otherwise, just initialize |
+ OBJFILE->msymbols[OBJFILE->minimal_symbol_count]. */ |
+ |
+void terminate_minimal_symbol_table (struct objfile *objfile); |
+ |
+/* Sort all the minimal symbols in OBJFILE. This should be only be |
+ called after relocating symbols; it ensures that the minimal |
+ symbols are properly sorted by address. */ |
+ |
+void msymbols_sort (struct objfile *objfile); |
+ |
+ |
+ |
+/* Compute a hash code for the string argument. */ |
+ |
+unsigned int msymbol_hash (const char *); |
+ |
+/* Like msymbol_hash, but compute a hash code that is compatible with |
+ strcmp_iw. */ |
+ |
+unsigned int msymbol_hash_iw (const char *); |
+ |
+/* Compute the next hash value from previous HASH and the character C. This |
+ is only a GDB in-memory computed value with no external files compatibility |
+ requirements. */ |
+ |
+#define SYMBOL_HASH_NEXT(hash, c) \ |
+ ((hash) * 67 + tolower ((unsigned char) (c)) - 113) |
+ |
+ |
+ |
+/* Return the objfile that holds the minimal symbol SYM. Every |
+ minimal symbols is held by some objfile; this will never return |
+ NULL. */ |
+ |
+struct objfile *msymbol_objfile (struct minimal_symbol *sym); |
+ |
+ |
+ |
+/* Look through all the current minimal symbol tables and find the |
+ first minimal symbol that matches NAME. If OBJF is non-NULL, limit |
+ the search to that objfile. If SFILE is non-NULL, the only file-scope |
+ symbols considered will be from that source file (global symbols are |
+ still preferred). Returns a pointer to the minimal symbol that |
+ matches, or NULL if no match is found. */ |
+ |
+struct minimal_symbol *lookup_minimal_symbol (const char *, |
+ const char *, |
+ struct objfile *); |
+ |
+/* Find the minimal symbol named NAME, and return both the minsym |
+ struct and its objfile. This only checks the linkage name. Sets |
+ *OBJFILE_P and returns the minimal symbol, if it is found. If it |
+ is not found, returns NULL. */ |
+ |
+struct minimal_symbol *lookup_minimal_symbol_and_objfile (const char *, |
+ struct objfile **); |
+ |
+/* Look through all the current minimal symbol tables and find the |
+ first minimal symbol that matches NAME and has text type. If OBJF |
+ is non-NULL, limit the search to that objfile. Returns a pointer |
+ to the minimal symbol that matches, or NULL if no match is found. |
+ |
+ This function only searches the mangled (linkage) names. */ |
+ |
+struct minimal_symbol *lookup_minimal_symbol_text (const char *, |
+ struct objfile *); |
+ |
+/* Look through all the current minimal symbol tables and find the |
+ first minimal symbol that matches NAME and is a solib trampoline. |
+ If OBJF is non-NULL, limit the search to that objfile. Returns a |
+ pointer to the minimal symbol that matches, or NULL if no match is |
+ found. |
+ |
+ This function only searches the mangled (linkage) names. */ |
+ |
+struct minimal_symbol *lookup_minimal_symbol_solib_trampoline |
+ (const char *, |
+ struct objfile *); |
+ |
+/* Look through all the current minimal symbol tables and find the |
+ first minimal symbol that matches NAME and PC. If OBJF is non-NULL, |
+ limit the search to that objfile. Returns a pointer to the minimal |
+ symbol that matches, or NULL if no match is found. */ |
+ |
+struct minimal_symbol *lookup_minimal_symbol_by_pc_name |
+ (CORE_ADDR, const char *, struct objfile *); |
+ |
+/* Search through the minimal symbol table for each objfile and find |
+ the symbol whose address is the largest address that is still less |
+ than or equal to PC, and which matches SECTION. |
+ |
+ If SECTION is NULL, this uses the result of find_pc_section |
+ instead. |
+ |
+ Returns a pointer to the minimal symbol if such a symbol is found, |
+ or NULL if PC is not in a suitable range. */ |
+ |
+struct minimal_symbol *lookup_minimal_symbol_by_pc_section |
+ (CORE_ADDR, |
+ struct obj_section *); |
+ |
+/* Backward compatibility: search through the minimal symbol table |
+ for a matching PC (no section given). |
+ |
+ This is a wrapper that calls lookup_minimal_symbol_by_pc_section |
+ with a NULL section argument. */ |
+ |
+struct minimal_symbol *lookup_minimal_symbol_by_pc (CORE_ADDR); |
+ |
+/* Check if PC is in a shared library trampoline code stub. |
+ Return minimal symbol for the trampoline entry or NULL if PC is not |
+ in a trampoline code stub. */ |
+ |
+struct minimal_symbol *lookup_solib_trampoline_symbol_by_pc (CORE_ADDR); |
+ |
+/* Iterate over all the minimal symbols in the objfile OBJF which |
+ match NAME. Both the ordinary and demangled names of each symbol |
+ are considered. The caller is responsible for canonicalizing NAME, |
+ should that need to be done. |
+ |
+ For each matching symbol, CALLBACK is called with the symbol and |
+ USER_DATA as arguments. */ |
+ |
+void iterate_over_minimal_symbols (struct objfile *objf, |
+ const char *name, |
+ void (*callback) (struct minimal_symbol *, |
+ void *), |
+ void *user_data); |
+ |
+#endif /* MINSYMS_H */ |