/* Definitions for symbol-reading containing "stabs", for GDB. Copyright (C) 1992-2024 Free Software Foundation, Inc. Contributed by Cygnus Support. Written by John Gilmore. 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 . */ #ifndef GDB_STABS_H #define GDB_STABS_H /* During initial symbol readin, we need to have a structure to keep track of which psymtabs have which bincls in them. This structure is used during readin to setup the list of dependencies within each partial symbol table. */ struct legacy_psymtab; struct header_file_location { header_file_location (const char *name_, int instance_, legacy_psymtab *pst_) : name (name_), instance (instance_), pst (pst_) { } const char *name; /* Name of header file */ int instance; /* See above */ legacy_psymtab *pst; /* Partial symtab that has the BINCL/EINCL defs for this file. */ }; /* This file exists to hold the common definitions required of most of the symbol-readers that end up using stabs. The common use of these `symbol-type-specific' customizations of the generic data structures makes the stabs-oriented symbol readers able to call each others' functions as required. */ struct stabsread_context { /* Remember what we deduced to be the source language of this psymtab. */ enum language psymtab_language = language_unknown; /* The size of each symbol in the symbol file (in external form). This is set by dbx_symfile_read when building psymtabs, and by dbx_psymtab_to_symtab when building symtabs. */ unsigned symbol_size = 0; /* This is the offset of the symbol table in the executable file. */ unsigned symbol_table_offset = 0; /* This is the offset of the string table in the executable file. */ unsigned string_table_offset = 0; /* For elf+stab executables, the n_strx field is not a simple index into the string table. Instead, each .o file has a base offset in the string table, and the associated symbols contain offsets from this base. The following two variables contain the base offset for the current and next .o files. */ unsigned int file_string_table_offset = 0; /* .o and NLM files contain unrelocated addresses which are based at 0. When non-zero, this flag disables some of the special cases for Solaris elf+stab text addresses at location 0. */ int symfile_relocatable = 0; /* When set, we are processing a .o file compiled by sun acc. This is misnamed; it refers to all stabs-in-elf implementations which use N_UNDF the way Sun does, including Solaris gcc. Hopefully all stabs-in-elf implementations ever invented will choose to be compatible. */ unsigned char processing_acc_compilation = 0; /* The lowest text address we have yet encountered. This is needed because in an a.out file, there is no header field which tells us what address the program is actually going to be loaded at, so we need to make guesses based on the symbols (which *are* relocated to reflect the address it will be loaded at). */ unrelocated_addr lowest_text_address; /* Non-zero if there is any line number info in the objfile. Prevents dbx_end_psymtab from discarding an otherwise empty psymtab. */ int has_line_numbers = 0; /* The list of bincls. */ std::vector bincl_list; /* Name of last function encountered. Used in Solaris to approximate object file boundaries. */ const char *last_function_name = nullptr; /* The address in memory of the string table of the object file we are reading (which might not be the "main" object file, but might be a shared library or some other dynamically loaded thing). This is set by read_dbx_symtab when building psymtabs, and by read_ofile_symtab when building symtabs, and is used only by next_symbol_text. FIXME: If that is true, we don't need it when building psymtabs, right? */ char *stringtab_global = nullptr; /* These variables are used to control fill_symbuf when the stabs symbols are not contiguous (as may be the case when a COFF file is linked using --split-by-reloc). */ const std::vector *symbuf_sections; size_t sect_idx = 0; unsigned int symbuf_left = 0; unsigned int symbuf_read = 0; /* This variable stores a global stabs buffer, if we read stabs into memory in one chunk in order to process relocations. */ bfd_byte *stabs_data = nullptr; }; /* Information is passed among various dbxread routines for accessing symbol files. A pointer to this structure is kept in the objfile, using the dbx_objfile_data_key. */ struct dbx_symfile_info { ~dbx_symfile_info (); CORE_ADDR text_addr = 0; /* Start of text section */ int text_size = 0; /* Size of text section */ int symcount = 0; /* How many symbols are there in the file */ char *stringtab = nullptr; /* The actual string table */ int stringtab_size = 0; /* Its size */ file_ptr symtab_offset = 0; /* Offset in file to symbol table */ int symbol_size = 0; /* Bytes in a single symbol */ stabsread_context ctx; /* Context for the symfile being read. */ /* See stabsread.h for the use of the following. */ struct header_file *header_files = nullptr; int n_header_files = 0; int n_allocated_header_files = 0; /* Pointers to BFD sections. These are used to speed up the building of minimal symbols. */ asection *text_section = nullptr; asection *data_section = nullptr; asection *bss_section = nullptr; /* Pointer to the separate ".stab" section, if there is one. */ asection *stab_section = nullptr; }; /* The tag used to find the DBX info attached to an objfile. This is global because it is referenced by several modules. */ extern const registry::key dbx_objfile_data_key; #define DBX_SYMFILE_INFO(o) (dbx_objfile_data_key.get (o)) #define DBX_TEXT_ADDR(o) (DBX_SYMFILE_INFO(o)->text_addr) #define DBX_TEXT_SIZE(o) (DBX_SYMFILE_INFO(o)->text_size) #define DBX_SYMCOUNT(o) (DBX_SYMFILE_INFO(o)->symcount) #define DBX_STRINGTAB(o) (DBX_SYMFILE_INFO(o)->stringtab) #define DBX_STRINGTAB_SIZE(o) (DBX_SYMFILE_INFO(o)->stringtab_size) #define DBX_SYMTAB_OFFSET(o) (DBX_SYMFILE_INFO(o)->symtab_offset) #define DBX_SYMBOL_SIZE(o) (DBX_SYMFILE_INFO(o)->symbol_size) #define DBX_TEXT_SECTION(o) (DBX_SYMFILE_INFO(o)->text_section) #define DBX_DATA_SECTION(o) (DBX_SYMFILE_INFO(o)->data_section) #define DBX_BSS_SECTION(o) (DBX_SYMFILE_INFO(o)->bss_section) #define DBX_STAB_SECTION(o) (DBX_SYMFILE_INFO(o)->stab_section) #endif /* GDB_STABS_H */