diff options
author | Tom Tromey <tom@tromey.com> | 2018-05-22 14:39:24 -0600 |
---|---|---|
committer | Tom Tromey <tom@tromey.com> | 2018-07-20 09:42:53 -0600 |
commit | 0baae8dbd38534c0f3dcedc7b9204bbc8f18de1b (patch) | |
tree | 177d401b531eb4a32c230f11c58e39de2dff3fd5 /gdb/buildsym-legacy.c | |
parent | ab209f6fa9dbaf0d3d0c42e2a8f14bf3ff7dfce8 (diff) | |
download | gdb-0baae8dbd38534c0f3dcedc7b9204bbc8f18de1b.zip gdb-0baae8dbd38534c0f3dcedc7b9204bbc8f18de1b.tar.gz gdb-0baae8dbd38534c0f3dcedc7b9204bbc8f18de1b.tar.bz2 |
Introduce buildsym-legacy.h
This introduces a new header, buildsym-legacy.h, and changes all the
symbol readers to use it. The idea is to put the function-based
interface, that relies on the buildsym_compunit global, into a
separate header. Then when a symbol reader is updated to use the new
interface, it can simply not include buildsym-legacy.h, so it's easy
to be sure that the new API is used everywhere.
gdb/ChangeLog
2018-07-20 Tom Tromey <tom@tromey.com>
* xcoffread.c: Include buildsym-legacy.h.
* windows-nat.c: Include buildsym-legacy.h.
* stabsread.c: Include buildsym-legacy.h.
* mdebugread.c: Include buildsym-legacy.h.
* buildsym-legacy.h: New file.
* buildsym-legacy.c: New file, from buildsym.c.
* go32-nat.c: Include buildsym-legacy.h.
* dwarf2read.c: Include buildsym-legacy.h.
* dbxread.c: Include buildsym-legacy.h.
* cp-namespace.c: Include buildsym-legacy.h.
* coffread.c: Include buildsym-legacy.h.
* buildsym.h: Move some contents to buildsym-legacy.h.
* buildsym.c: Include buildsym-legacy.h. Move many functions to
buildsym-legacy.c.
* Makefile.in (HFILES_NO_SRCDIR): Add buildsym-legacy.h.
Diffstat (limited to 'gdb/buildsym-legacy.c')
-rw-r--r-- | gdb/buildsym-legacy.c | 377 |
1 files changed, 377 insertions, 0 deletions
diff --git a/gdb/buildsym-legacy.c b/gdb/buildsym-legacy.c new file mode 100644 index 0000000..e7eaf03 --- /dev/null +++ b/gdb/buildsym-legacy.c @@ -0,0 +1,377 @@ +/* Legacy support routines for building symbol tables in GDB's internal format. + Copyright (C) 1986-2018 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 "buildsym-legacy.h" + +/* The work-in-progress of the compunit we are building. + This is created first, before any subfiles by start_symtab. */ + +static struct buildsym_compunit *buildsym_compunit; + +void +record_debugformat (const char *format) +{ + buildsym_compunit->record_debugformat (format); +} + +void +record_producer (const char *producer) +{ + buildsym_compunit->record_producer (producer); +} + + + +/* See buildsym.h. */ + +void +set_last_source_file (const char *name) +{ + gdb_assert (buildsym_compunit != nullptr || name == nullptr); + if (buildsym_compunit != nullptr) + buildsym_compunit->set_last_source_file (name); +} + +/* See buildsym.h. */ + +const char * +get_last_source_file () +{ + if (buildsym_compunit == nullptr) + return nullptr; + return buildsym_compunit->get_last_source_file (); +} + +/* See buildsym.h. */ + +void +set_last_source_start_addr (CORE_ADDR addr) +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->set_last_source_start_addr (addr); +} + +/* See buildsym.h. */ + +CORE_ADDR +get_last_source_start_addr () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_last_source_start_addr (); +} + +/* See buildsym.h. */ + +struct using_direct ** +get_local_using_directives () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_local_using_directives (); +} + +/* See buildsym.h. */ + +void +set_local_using_directives (struct using_direct *new_local) +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->set_local_using_directives (new_local); +} + +/* See buildsym.h. */ + +struct using_direct ** +get_global_using_directives () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_global_using_directives (); +} + +/* See buildsym.h. */ + +bool +outermost_context_p () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->outermost_context_p (); +} + +/* See buildsym.h. */ + +struct context_stack * +get_current_context_stack () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_current_context_stack (); +} + +/* See buildsym.h. */ + +int +get_context_stack_depth () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_context_stack_depth (); +} + +/* See buildsym.h. */ + +struct subfile * +get_current_subfile () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_current_subfile (); +} + +/* See buildsym.h. */ + +struct pending ** +get_local_symbols () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_local_symbols (); +} + +/* See buildsym.h. */ + +struct pending ** +get_file_symbols () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_file_symbols (); +} + +/* See buildsym.h. */ + +struct pending ** +get_global_symbols () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->get_global_symbols (); +} + +void +start_subfile (const char *name) +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->start_subfile (name); +} + +void +patch_subfile_names (struct subfile *subfile, const char *name) +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->patch_subfile_names (subfile, name); +} + +void +push_subfile () +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->push_subfile (); +} + +const char * +pop_subfile () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->pop_subfile (); +} + +struct block * +end_symtab_get_static_block (CORE_ADDR end_addr, int expandable, int required) +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->end_symtab_get_static_block (end_addr, expandable, + required); +} + +/* Delete the buildsym compunit. */ + +static void +free_buildsym_compunit (void) +{ + if (buildsym_compunit == NULL) + return; + delete buildsym_compunit; + buildsym_compunit = NULL; +} + +struct compunit_symtab * +end_symtab_from_static_block (struct block *static_block, + int section, int expandable) +{ + gdb_assert (buildsym_compunit != nullptr); + struct compunit_symtab *result + = buildsym_compunit->end_symtab_from_static_block (static_block, + section, expandable); + free_buildsym_compunit (); + return result; +} + +struct compunit_symtab * +end_symtab (CORE_ADDR end_addr, int section) +{ + gdb_assert (buildsym_compunit != nullptr); + struct compunit_symtab *result + = buildsym_compunit->end_symtab (end_addr, section); + free_buildsym_compunit (); + return result; +} + +struct compunit_symtab * +end_expandable_symtab (CORE_ADDR end_addr, int section) +{ + gdb_assert (buildsym_compunit != nullptr); + struct compunit_symtab *result + = buildsym_compunit->end_expandable_symtab (end_addr, section); + free_buildsym_compunit (); + return result; +} + +void +augment_type_symtab () +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->augment_type_symtab (); + free_buildsym_compunit (); +} + +struct context_stack * +push_context (int desc, CORE_ADDR valu) +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->push_context (desc, valu); +} + +struct context_stack +pop_context () +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->pop_context (); +} + +struct block * +finish_block (struct symbol *symbol, struct pending_block *old_blocks, + const struct dynamic_prop *static_link, + CORE_ADDR start, CORE_ADDR end) +{ + gdb_assert (buildsym_compunit != nullptr); + return buildsym_compunit->finish_block (symbol, old_blocks, static_link, + start, end); +} + +void +record_block_range (struct block *block, CORE_ADDR start, + CORE_ADDR end_inclusive) +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->record_block_range (block, start, end_inclusive); +} + +void +record_line (struct subfile *subfile, int line, CORE_ADDR pc) +{ + gdb_assert (buildsym_compunit != nullptr); + buildsym_compunit->record_line (subfile, line, pc); +} + +/* Start a new symtab for a new source file in OBJFILE. Called, for example, + when a stabs symbol of type N_SO is seen, or when a DWARF + TAG_compile_unit DIE is seen. It indicates the start of data for + one original source file. + + NAME is the name of the file (cannot be NULL). COMP_DIR is the + directory in which the file was compiled (or NULL if not known). + START_ADDR is the lowest address of objects in the file (or 0 if + not known). LANGUAGE is the language of the source file, or + language_unknown if not known, in which case it'll be deduced from + the filename. */ + +struct compunit_symtab * +start_symtab (struct objfile *objfile, const char *name, const char *comp_dir, + CORE_ADDR start_addr, enum language language) +{ + /* These should have been reset either by successful completion of building + a symtab, or by the scoped_free_pendings destructor. */ + gdb_assert (buildsym_compunit == nullptr); + + buildsym_compunit = new struct buildsym_compunit (objfile, name, comp_dir, + language, start_addr); + + return buildsym_compunit->get_compunit_symtab (); +} + +/* Restart compilation for a symtab. + CUST is the result of end_expandable_symtab. + NAME, START_ADDR are the source file we are resuming with. + + This is used when a symtab is built from multiple sources. + The symtab is first built with start_symtab/end_expandable_symtab + and then for each additional piece call restart_symtab/augment_*_symtab. + Note: At the moment there is only augment_type_symtab. */ + +void +restart_symtab (struct compunit_symtab *cust, + const char *name, CORE_ADDR start_addr) +{ + /* These should have been reset either by successful completion of building + a symtab, or by the scoped_free_pendings destructor. */ + gdb_assert (buildsym_compunit == nullptr); + + buildsym_compunit + = new struct buildsym_compunit (COMPUNIT_OBJFILE (cust), + name, + COMPUNIT_DIRNAME (cust), + compunit_language (cust), + start_addr, + cust); +} + +/* See buildsym.h. */ + +struct compunit_symtab * +buildsym_compunit_symtab (void) +{ + gdb_assert (buildsym_compunit != NULL); + + return buildsym_compunit->get_compunit_symtab (); +} + +/* See buildsym.h. */ + +struct macro_table * +get_macro_table (void) +{ + struct objfile *objfile; + + gdb_assert (buildsym_compunit != NULL); + return buildsym_compunit->get_macro_table (); +} + +/* At end of reading syms, or in case of quit, ensure everything + associated with building symtabs is freed. + + N.B. This is *not* intended to be used when building psymtabs. Some debug + info readers call this anyway, which is harmless if confusing. */ + +scoped_free_pendings::~scoped_free_pendings () +{ + free_buildsym_compunit (); +} |