aboutsummaryrefslogtreecommitdiff
path: root/gdb/buildsym-legacy.c
diff options
context:
space:
mode:
authorTom Tromey <tom@tromey.com>2018-05-22 14:39:24 -0600
committerTom Tromey <tom@tromey.com>2018-07-20 09:42:53 -0600
commit0baae8dbd38534c0f3dcedc7b9204bbc8f18de1b (patch)
tree177d401b531eb4a32c230f11c58e39de2dff3fd5 /gdb/buildsym-legacy.c
parentab209f6fa9dbaf0d3d0c42e2a8f14bf3ff7dfce8 (diff)
downloadgdb-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.c377
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 ();
+}