1 /* Partial symbol tables.
3 Copyright (C) 2009-2018 Free Software Foundation, Inc.
5 This file is part of GDB.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
25 #include "filenames.h"
32 #include "readline/readline.h"
33 #include "gdb_regex.h"
34 #include "dictionary.h"
36 #include "cp-support.h"
43 struct bcache *bcache;
46 static struct partial_symbol *match_partial_symbol (struct objfile *,
47 struct partial_symtab *,
49 const char *, domain_enum,
50 symbol_name_match_type,
51 symbol_compare_ftype *);
53 static struct partial_symbol *lookup_partial_symbol (struct objfile *,
54 struct partial_symtab *,
58 static const char *psymtab_to_fullname (struct partial_symtab *ps);
60 static struct partial_symbol *find_pc_sect_psymbol (struct objfile *,
61 struct partial_symtab *,
63 struct obj_section *);
65 static void fixup_psymbol_section (struct partial_symbol *psym,
66 struct objfile *objfile);
68 static struct compunit_symtab *psymtab_to_symtab (struct objfile *objfile,
69 struct partial_symtab *pst);
71 /* Ensure that the partial symbols for OBJFILE have been loaded. This
72 function always returns its argument, as a convenience. */
75 require_partial_symbols (struct objfile *objfile, int verbose)
77 if ((objfile->flags & OBJF_PSYMTABS_READ) == 0)
79 objfile->flags |= OBJF_PSYMTABS_READ;
81 if (objfile->sf->sym_read_psymbols)
85 printf_unfiltered (_("Reading symbols from %s..."),
86 objfile_name (objfile));
87 gdb_flush (gdb_stdout);
89 (*objfile->sf->sym_read_psymbols) (objfile);
91 /* Partial symbols list are not expected to changed after this
93 objfile->global_psymbols.shrink_to_fit ();
94 objfile->static_psymbols.shrink_to_fit ();
98 if (!objfile_has_symbols (objfile))
101 printf_unfiltered (_("(no debugging symbols found)..."));
105 printf_unfiltered (_("done.\n"));
113 /* Traverse all psymtabs in one objfile, requiring that the psymtabs
116 #define ALL_OBJFILE_PSYMTABS_REQUIRED(objfile, p) \
117 for ((p) = require_partial_symbols (objfile, 1)->psymtabs; \
121 /* We want to make sure this file always requires psymtabs. */
123 #undef ALL_OBJFILE_PSYMTABS
125 /* Traverse all psymtabs in all objfiles. */
127 #define ALL_PSYMTABS(objfile, p) \
128 ALL_OBJFILES (objfile) \
129 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, p)
131 /* Helper function for psym_map_symtabs_matching_filename that
132 expands the symtabs and calls the iterator. */
135 partial_map_expand_apply (struct objfile *objfile,
137 const char *real_path,
138 struct partial_symtab *pst,
139 gdb::function_view<bool (symtab *)> callback)
141 struct compunit_symtab *last_made = objfile->compunit_symtabs;
143 /* Shared psymtabs should never be seen here. Instead they should
144 be handled properly by the caller. */
145 gdb_assert (pst->user == NULL);
147 /* Don't visit already-expanded psymtabs. */
151 /* This may expand more than one symtab, and we want to iterate over
153 psymtab_to_symtab (objfile, pst);
155 return iterate_over_some_symtabs (name, real_path, objfile->compunit_symtabs,
156 last_made, callback);
159 /* Psymtab version of map_symtabs_matching_filename. See its definition in
160 the definition of quick_symbol_functions in symfile.h. */
163 psym_map_symtabs_matching_filename
164 (struct objfile *objfile,
166 const char *real_path,
167 gdb::function_view<bool (symtab *)> callback)
169 struct partial_symtab *pst;
170 const char *name_basename = lbasename (name);
172 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
174 /* We can skip shared psymtabs here, because any file name will be
175 attached to the unshared psymtab. */
176 if (pst->user != NULL)
179 /* Anonymous psymtabs don't have a file name. */
183 if (compare_filenames_for_search (pst->filename, name))
185 if (partial_map_expand_apply (objfile, name, real_path,
191 /* Before we invoke realpath, which can get expensive when many
192 files are involved, do a quick comparison of the basenames. */
193 if (! basenames_may_differ
194 && FILENAME_CMP (name_basename, lbasename (pst->filename)) != 0)
197 if (compare_filenames_for_search (psymtab_to_fullname (pst), name))
199 if (partial_map_expand_apply (objfile, name, real_path,
205 /* If the user gave us an absolute path, try to find the file in
206 this symtab and use its absolute path. */
207 if (real_path != NULL)
209 gdb_assert (IS_ABSOLUTE_PATH (real_path));
210 gdb_assert (IS_ABSOLUTE_PATH (name));
211 if (filename_cmp (psymtab_to_fullname (pst), real_path) == 0)
213 if (partial_map_expand_apply (objfile, name, real_path,
224 /* Find which partial symtab contains PC and SECTION starting at psymtab PST.
225 We may find a different psymtab than PST. See FIND_PC_SECT_PSYMTAB. */
227 static struct partial_symtab *
228 find_pc_sect_psymtab_closer (struct objfile *objfile,
229 CORE_ADDR pc, struct obj_section *section,
230 struct partial_symtab *pst,
231 struct bound_minimal_symbol msymbol)
233 struct partial_symtab *tpst;
234 struct partial_symtab *best_pst = pst;
235 CORE_ADDR best_addr = pst->text_low ();
237 gdb_assert (!pst->psymtabs_addrmap_supported);
239 /* An objfile that has its functions reordered might have
240 many partial symbol tables containing the PC, but
241 we want the partial symbol table that contains the
242 function containing the PC. */
243 if (!(objfile->flags & OBJF_REORDERED)
244 && section == NULL) /* Can't validate section this way. */
247 if (msymbol.minsym == NULL)
250 /* The code range of partial symtabs sometimes overlap, so, in
251 the loop below, we need to check all partial symtabs and
252 find the one that fits better for the given PC address. We
253 select the partial symtab that contains a symbol whose
254 address is closest to the PC address. By closest we mean
255 that find_pc_sect_symbol returns the symbol with address
256 that is closest and still less than the given PC. */
257 for (tpst = pst; tpst != NULL; tpst = tpst->next)
259 if (pc >= tpst->text_low () && pc < tpst->text_high ())
261 struct partial_symbol *p;
264 /* NOTE: This assumes that every psymbol has a
265 corresponding msymbol, which is not necessarily
266 true; the debug info might be much richer than the
267 object's symbol table. */
268 p = find_pc_sect_psymbol (objfile, tpst, pc, section);
270 && (p->address (objfile) == BMSYMBOL_VALUE_ADDRESS (msymbol)))
273 /* Also accept the textlow value of a psymtab as a
274 "symbol", to provide some support for partial
275 symbol tables with line information but no debug
276 symbols (e.g. those produced by an assembler). */
278 this_addr = p->address (objfile);
280 this_addr = tpst->text_low ();
282 /* Check whether it is closer than our current
283 BEST_ADDR. Since this symbol address is
284 necessarily lower or equal to PC, the symbol closer
285 to PC is the symbol which address is the highest.
286 This way we return the psymtab which contains such
287 best match symbol. This can help in cases where the
288 symbol information/debuginfo is not complete, like
289 for instance on IRIX6 with gcc, where no debug info
290 is emitted for statics. (See also the nodebug.exp
292 if (this_addr > best_addr)
294 best_addr = this_addr;
302 /* Find which partial symtab contains PC and SECTION. Return NULL if
303 none. We return the psymtab that contains a symbol whose address
304 exactly matches PC, or, if we cannot find an exact match, the
305 psymtab that contains a symbol whose address is closest to PC. */
307 static struct partial_symtab *
308 find_pc_sect_psymtab (struct objfile *objfile, CORE_ADDR pc,
309 struct obj_section *section,
310 struct bound_minimal_symbol msymbol)
312 struct partial_symtab *pst;
314 /* Try just the PSYMTABS_ADDRMAP mapping first as it has better granularity
315 than the later used TEXTLOW/TEXTHIGH one. */
317 if (objfile->psymtabs_addrmap != NULL)
319 pst = ((struct partial_symtab *)
320 addrmap_find (objfile->psymtabs_addrmap, pc));
323 /* FIXME: addrmaps currently do not handle overlayed sections,
324 so fall back to the non-addrmap case if we're debugging
325 overlays and the addrmap returned the wrong section. */
326 if (overlay_debugging && msymbol.minsym != NULL && section != NULL)
328 struct partial_symbol *p;
330 /* NOTE: This assumes that every psymbol has a
331 corresponding msymbol, which is not necessarily
332 true; the debug info might be much richer than the
333 object's symbol table. */
334 p = find_pc_sect_psymbol (objfile, pst, pc, section);
336 || (p->address (objfile)
337 != BMSYMBOL_VALUE_ADDRESS (msymbol)))
341 /* We do not try to call FIND_PC_SECT_PSYMTAB_CLOSER as
342 PSYMTABS_ADDRMAP we used has already the best 1-byte
343 granularity and FIND_PC_SECT_PSYMTAB_CLOSER may mislead us into
344 a worse chosen section due to the TEXTLOW/TEXTHIGH ranges
353 /* Existing PSYMTABS_ADDRMAP mapping is present even for PARTIAL_SYMTABs
354 which still have no corresponding full SYMTABs read. But it is not
355 present for non-DWARF2 debug infos not supporting PSYMTABS_ADDRMAP in GDB
358 /* Check even OBJFILE with non-zero PSYMTABS_ADDRMAP as only several of
359 its CUs may be missing in PSYMTABS_ADDRMAP as they may be varying
360 debug info type in single OBJFILE. */
362 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
363 if (!pst->psymtabs_addrmap_supported
364 && pc >= pst->text_low () && pc < pst->text_high ())
366 struct partial_symtab *best_pst;
368 best_pst = find_pc_sect_psymtab_closer (objfile, pc, section, pst,
370 if (best_pst != NULL)
377 /* Psymtab version of find_pc_sect_compunit_symtab. See its definition in
378 the definition of quick_symbol_functions in symfile.h. */
380 static struct compunit_symtab *
381 psym_find_pc_sect_compunit_symtab (struct objfile *objfile,
382 struct bound_minimal_symbol msymbol,
384 struct obj_section *section,
387 struct partial_symtab *ps = find_pc_sect_psymtab (objfile, pc, section,
391 if (warn_if_readin && ps->readin)
392 /* Might want to error() here (in case symtab is corrupt and
393 will cause a core dump), but maybe we can successfully
394 continue, so let's not. */
396 (Internal error: pc %s in read in psymtab, but not in symtab.)\n"),
397 paddress (get_objfile_arch (objfile), pc));
398 psymtab_to_symtab (objfile, ps);
399 return ps->compunit_symtab;
404 /* Find which partial symbol within a psymtab matches PC and SECTION.
405 Return NULL if none. */
407 static struct partial_symbol *
408 find_pc_sect_psymbol (struct objfile *objfile,
409 struct partial_symtab *psymtab, CORE_ADDR pc,
410 struct obj_section *section)
412 struct partial_symbol *best = NULL;
415 gdb_assert (psymtab != NULL);
417 /* Cope with programs that start at address 0. */
418 best_pc = ((psymtab->text_low () != 0)
419 ? psymtab->text_low () - 1 : 0);
421 /* Search the global symbols as well as the static symbols, so that
422 find_pc_partial_function doesn't use a minimal symbol and thus
423 cache a bad endaddr. */
424 for (int i = 0; i < psymtab->n_global_syms; i++)
426 partial_symbol *p = objfile->global_psymbols[psymtab->globals_offset + i];
428 if (p->domain == VAR_DOMAIN
429 && p->aclass == LOC_BLOCK
430 && pc >= p->address (objfile)
431 && (p->address (objfile) > best_pc
432 || (psymtab->text_low () == 0
433 && best_pc == 0 && p->address (objfile) == 0)))
435 if (section != NULL) /* Match on a specific section. */
437 fixup_psymbol_section (p, objfile);
438 if (!matching_obj_sections (p->obj_section (objfile),
442 best_pc = p->address (objfile);
447 for (int i = 0; i < psymtab->n_static_syms; i++)
449 partial_symbol *p = objfile->static_psymbols[psymtab->statics_offset + i];
451 if (p->domain == VAR_DOMAIN
452 && p->aclass == LOC_BLOCK
453 && pc >= p->address (objfile)
454 && (p->address (objfile) > best_pc
455 || (psymtab->text_low () == 0
456 && best_pc == 0 && p->address (objfile) == 0)))
458 if (section != NULL) /* Match on a specific section. */
460 fixup_psymbol_section (p, objfile);
461 if (!matching_obj_sections (p->obj_section (objfile),
465 best_pc = p->address (objfile);
474 fixup_psymbol_section (struct partial_symbol *psym, struct objfile *objfile)
481 if (psym->section >= 0)
484 gdb_assert (objfile);
486 switch (psym->aclass)
491 addr = psym->address (objfile);
494 /* Nothing else will be listed in the minsyms -- no use looking
499 fixup_section (psym, addr, objfile);
502 /* Psymtab version of lookup_symbol. See its definition in
503 the definition of quick_symbol_functions in symfile.h. */
505 static struct compunit_symtab *
506 psym_lookup_symbol (struct objfile *objfile,
507 int block_index, const char *name,
508 const domain_enum domain)
510 struct partial_symtab *ps;
511 const int psymtab_index = (block_index == GLOBAL_BLOCK ? 1 : 0);
512 struct compunit_symtab *stab_best = NULL;
514 lookup_name_info lookup_name (name, symbol_name_match_type::FULL);
516 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
518 if (!ps->readin && lookup_partial_symbol (objfile, ps, name,
519 psymtab_index, domain))
521 struct symbol *sym, *with_opaque = NULL;
522 struct compunit_symtab *stab = psymtab_to_symtab (objfile, ps);
523 /* Note: While psymtab_to_symtab can return NULL if the partial symtab
524 is empty, we can assume it won't here because lookup_partial_symbol
526 const struct blockvector *bv = COMPUNIT_BLOCKVECTOR (stab);
527 struct block *block = BLOCKVECTOR_BLOCK (bv, block_index);
529 sym = block_find_symbol (block, name, domain,
530 block_find_non_opaque_type_preferred,
533 /* Some caution must be observed with overloaded functions
534 and methods, since the index will not contain any overload
535 information (but NAME might contain it). */
538 && SYMBOL_MATCHES_SEARCH_NAME (sym, lookup_name))
540 if (with_opaque != NULL
541 && SYMBOL_MATCHES_SEARCH_NAME (with_opaque, lookup_name))
544 /* Keep looking through other psymtabs. */
551 /* Returns true if PSYM matches LOOKUP_NAME. */
554 psymbol_name_matches (partial_symbol *psym,
555 const lookup_name_info &lookup_name)
557 const language_defn *lang = language_def (psym->language);
558 symbol_name_matcher_ftype *name_match
559 = get_symbol_name_matcher (lang, lookup_name);
560 return name_match (symbol_search_name (psym), lookup_name, NULL);
563 /* Look in PST for a symbol in DOMAIN whose name matches NAME. Search
564 the global block of PST if GLOBAL, and otherwise the static block.
565 MATCH is the comparison operation that returns true iff MATCH (s,
566 NAME), where s is a SYMBOL_SEARCH_NAME. If ORDERED_COMPARE is
567 non-null, the symbols in the block are assumed to be ordered
568 according to it (allowing binary search). It must be compatible
569 with MATCH. Returns the symbol, if found, and otherwise NULL. */
571 static struct partial_symbol *
572 match_partial_symbol (struct objfile *objfile,
573 struct partial_symtab *pst, int global,
574 const char *name, domain_enum domain,
575 symbol_name_match_type match_type,
576 symbol_compare_ftype *ordered_compare)
578 struct partial_symbol **start, **psym;
579 struct partial_symbol **top, **real_top, **bottom, **center;
580 int length = (global ? pst->n_global_syms : pst->n_static_syms);
581 int do_linear_search = 1;
586 lookup_name_info lookup_name (name, match_type);
589 &objfile->global_psymbols[pst->globals_offset] :
590 &objfile->static_psymbols[pst->statics_offset]);
592 if (global && ordered_compare) /* Can use a binary search. */
594 do_linear_search = 0;
596 /* Binary search. This search is guaranteed to end with center
597 pointing at the earliest partial symbol whose name might be
598 correct. At that point *all* partial symbols with an
599 appropriate name will be checked against the correct
603 top = start + length - 1;
607 center = bottom + (top - bottom) / 2;
608 gdb_assert (center < top);
610 enum language lang = (*center)->language;
612 = lookup_name.language_lookup_name (lang).c_str ();
614 if (ordered_compare (symbol_search_name (*center), lang_ln) >= 0)
619 gdb_assert (top == bottom);
621 while (top <= real_top
622 && psymbol_name_matches (*top, lookup_name))
624 if (symbol_matches_domain ((*top)->language,
625 (*top)->domain, domain))
631 /* Can't use a binary search or else we found during the binary search that
632 we should also do a linear search. */
634 if (do_linear_search)
636 for (psym = start; psym < start + length; psym++)
638 if (symbol_matches_domain ((*psym)->language,
639 (*psym)->domain, domain)
640 && psymbol_name_matches (*psym, lookup_name))
648 /* Returns the name used to search psymtabs. Unlike symtabs, psymtabs do
649 not contain any method/function instance information (since this would
650 force reading type information while reading psymtabs). Therefore,
651 if NAME contains overload information, it must be stripped before searching
654 static gdb::unique_xmalloc_ptr<char>
655 psymtab_search_name (const char *name)
657 switch (current_language->la_language)
661 if (strchr (name, '('))
663 gdb::unique_xmalloc_ptr<char> ret = cp_remove_params (name);
675 return gdb::unique_xmalloc_ptr<char> (xstrdup (name));
678 /* Look, in partial_symtab PST, for symbol whose natural name is NAME.
679 Check the global symbols if GLOBAL, the static symbols if not. */
681 static struct partial_symbol *
682 lookup_partial_symbol (struct objfile *objfile,
683 struct partial_symtab *pst, const char *name,
684 int global, domain_enum domain)
686 struct partial_symbol **start, **psym;
687 struct partial_symbol **top, **real_top, **bottom, **center;
688 int length = (global ? pst->n_global_syms : pst->n_static_syms);
689 int do_linear_search = 1;
694 gdb::unique_xmalloc_ptr<char> search_name = psymtab_search_name (name);
696 lookup_name_info lookup_name (search_name.get (), symbol_name_match_type::FULL);
699 &objfile->global_psymbols[pst->globals_offset] :
700 &objfile->static_psymbols[pst->statics_offset]);
702 if (global) /* This means we can use a binary search. */
704 do_linear_search = 0;
706 /* Binary search. This search is guaranteed to end with center
707 pointing at the earliest partial symbol whose name might be
708 correct. At that point *all* partial symbols with an
709 appropriate name will be checked against the correct
713 top = start + length - 1;
717 center = bottom + (top - bottom) / 2;
719 internal_error (__FILE__, __LINE__,
720 _("failed internal consistency check"));
721 if (strcmp_iw_ordered (symbol_search_name (*center),
722 search_name.get ()) >= 0)
731 if (!(top == bottom))
732 internal_error (__FILE__, __LINE__,
733 _("failed internal consistency check"));
735 /* For `case_sensitivity == case_sensitive_off' strcmp_iw_ordered will
736 search more exactly than what matches SYMBOL_MATCHES_SEARCH_NAME. */
737 while (top >= start && symbol_matches_search_name (*top, lookup_name))
740 /* Fixup to have a symbol which matches SYMBOL_MATCHES_SEARCH_NAME. */
743 while (top <= real_top && symbol_matches_search_name (*top, lookup_name))
745 if (symbol_matches_domain ((*top)->language,
746 (*top)->domain, domain))
752 /* Can't use a binary search or else we found during the binary search that
753 we should also do a linear search. */
755 if (do_linear_search)
757 for (psym = start; psym < start + length; psym++)
759 if (symbol_matches_domain ((*psym)->language,
760 (*psym)->domain, domain)
761 && symbol_matches_search_name (*psym, lookup_name))
769 /* Get the symbol table that corresponds to a partial_symtab.
770 This is fast after the first time you do it.
771 The result will be NULL if the primary symtab has no symbols,
772 which can happen. Otherwise the result is the primary symtab
773 that contains PST. */
775 static struct compunit_symtab *
776 psymtab_to_symtab (struct objfile *objfile, struct partial_symtab *pst)
778 /* If it is a shared psymtab, find an unshared psymtab that includes
779 it. Any such psymtab will do. */
780 while (pst->user != NULL)
783 /* If it's been looked up before, return it. */
784 if (pst->compunit_symtab)
785 return pst->compunit_symtab;
787 /* If it has not yet been read in, read it. */
790 scoped_restore decrementer = increment_reading_symtab ();
792 (*pst->read_symtab) (pst, objfile);
795 return pst->compunit_symtab;
798 /* Psymtab version of relocate. See its definition in
799 the definition of quick_symbol_functions in symfile.h. */
802 psym_relocate (struct objfile *objfile,
803 const struct section_offsets *new_offsets,
804 const struct section_offsets *delta)
806 struct partial_symtab *p;
808 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, p)
810 p->set_text_low (p->text_low ()
811 + ANOFFSET (delta, SECT_OFF_TEXT (objfile)));
812 p->set_text_high (p->text_high ()
813 + ANOFFSET (delta, SECT_OFF_TEXT (objfile)));
816 for (partial_symbol *psym : objfile->global_psymbols)
818 fixup_psymbol_section (psym, objfile);
819 if (psym->section >= 0)
820 psym->set_address (psym->unrelocated_address ()
821 + ANOFFSET (delta, psym->section));
823 for (partial_symbol *psym : objfile->static_psymbols)
825 fixup_psymbol_section (psym, objfile);
826 if (psym->section >= 0)
827 psym->set_address (psym->unrelocated_address ()
828 + ANOFFSET (delta, psym->section));
831 objfile->psymbol_map.clear ();
834 /* Psymtab version of find_last_source_symtab. See its definition in
835 the definition of quick_symbol_functions in symfile.h. */
837 static struct symtab *
838 psym_find_last_source_symtab (struct objfile *ofp)
840 struct partial_symtab *ps;
841 struct partial_symtab *cs_pst = NULL;
843 ALL_OBJFILE_PSYMTABS_REQUIRED (ofp, ps)
845 const char *name = ps->filename;
846 int len = strlen (name);
848 if (!(len > 2 && (strcmp (&name[len - 2], ".h") == 0
849 || strcmp (name, "<<C++-namespaces>>") == 0)))
857 internal_error (__FILE__, __LINE__,
858 _("select_source_symtab: "
859 "readin pst found and no symtabs."));
863 struct compunit_symtab *cust = psymtab_to_symtab (ofp, cs_pst);
867 return compunit_primary_filetab (cust);
873 /* Psymtab version of forget_cached_source_info. See its definition in
874 the definition of quick_symbol_functions in symfile.h. */
877 psym_forget_cached_source_info (struct objfile *objfile)
879 struct partial_symtab *pst;
881 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
883 if (pst->fullname != NULL)
885 xfree (pst->fullname);
886 pst->fullname = NULL;
892 print_partial_symbols (struct gdbarch *gdbarch, struct objfile *objfile,
893 struct partial_symbol **p, int count, const char *what,
894 struct ui_file *outfile)
896 fprintf_filtered (outfile, " %s partial symbols:\n", what);
900 fprintf_filtered (outfile, " `%s'", (*p)->name);
901 if (symbol_demangled_name (*p) != NULL)
903 fprintf_filtered (outfile, " `%s'", symbol_demangled_name (*p));
905 fputs_filtered (", ", outfile);
906 switch ((*p)->domain)
909 fputs_filtered ("undefined domain, ", outfile);
912 /* This is the usual thing -- don't print it. */
915 fputs_filtered ("struct domain, ", outfile);
918 fputs_filtered ("label domain, ", outfile);
921 fputs_filtered ("<invalid domain>, ", outfile);
924 switch ((*p)->aclass)
927 fputs_filtered ("undefined", outfile);
930 fputs_filtered ("constant int", outfile);
933 fputs_filtered ("static", outfile);
936 fputs_filtered ("register", outfile);
939 fputs_filtered ("pass by value", outfile);
942 fputs_filtered ("pass by reference", outfile);
944 case LOC_REGPARM_ADDR:
945 fputs_filtered ("register address parameter", outfile);
948 fputs_filtered ("stack parameter", outfile);
951 fputs_filtered ("type", outfile);
954 fputs_filtered ("label", outfile);
957 fputs_filtered ("function", outfile);
959 case LOC_CONST_BYTES:
960 fputs_filtered ("constant bytes", outfile);
963 fputs_filtered ("unresolved", outfile);
965 case LOC_OPTIMIZED_OUT:
966 fputs_filtered ("optimized out", outfile);
969 fputs_filtered ("computed at runtime", outfile);
972 fputs_filtered ("<invalid location>", outfile);
975 fputs_filtered (", ", outfile);
976 fputs_filtered (paddress (gdbarch, (*p)->unrelocated_address ()), outfile);
977 fprintf_filtered (outfile, "\n");
983 dump_psymtab (struct objfile *objfile, struct partial_symtab *psymtab,
984 struct ui_file *outfile)
986 struct gdbarch *gdbarch = get_objfile_arch (objfile);
989 if (psymtab->anonymous)
991 fprintf_filtered (outfile, "\nAnonymous partial symtab (%s) ",
996 fprintf_filtered (outfile, "\nPartial symtab for source file %s ",
999 fprintf_filtered (outfile, "(object ");
1000 gdb_print_host_address (psymtab, outfile);
1001 fprintf_filtered (outfile, ")\n\n");
1002 fprintf_unfiltered (outfile, " Read from object file %s (",
1003 objfile_name (objfile));
1004 gdb_print_host_address (objfile, outfile);
1005 fprintf_unfiltered (outfile, ")\n");
1007 if (psymtab->readin)
1009 fprintf_filtered (outfile,
1010 " Full symtab was read (at ");
1011 gdb_print_host_address (psymtab->compunit_symtab, outfile);
1012 fprintf_filtered (outfile, " by function at ");
1013 gdb_print_host_address (psymtab->read_symtab, outfile);
1014 fprintf_filtered (outfile, ")\n");
1017 fprintf_filtered (outfile, " Symbols cover text addresses ");
1018 fputs_filtered (paddress (gdbarch, psymtab->text_low ()), outfile);
1019 fprintf_filtered (outfile, "-");
1020 fputs_filtered (paddress (gdbarch, psymtab->text_high ()), outfile);
1021 fprintf_filtered (outfile, "\n");
1022 fprintf_filtered (outfile, " Address map supported - %s.\n",
1023 psymtab->psymtabs_addrmap_supported ? "yes" : "no");
1024 fprintf_filtered (outfile, " Depends on %d other partial symtabs.\n",
1025 psymtab->number_of_dependencies);
1026 for (i = 0; i < psymtab->number_of_dependencies; i++)
1028 fprintf_filtered (outfile, " %d ", i);
1029 gdb_print_host_address (psymtab->dependencies[i], outfile);
1030 fprintf_filtered (outfile, " %s\n",
1031 psymtab->dependencies[i]->filename);
1033 if (psymtab->user != NULL)
1035 fprintf_filtered (outfile, " Shared partial symtab with user ");
1036 gdb_print_host_address (psymtab->user, outfile);
1037 fprintf_filtered (outfile, "\n");
1039 if (psymtab->n_global_syms > 0)
1041 print_partial_symbols (gdbarch, objfile,
1042 &objfile->global_psymbols[psymtab->globals_offset],
1043 psymtab->n_global_syms, "Global", outfile);
1045 if (psymtab->n_static_syms > 0)
1047 print_partial_symbols (gdbarch, objfile,
1048 &objfile->static_psymbols[psymtab->statics_offset],
1049 psymtab->n_static_syms, "Static", outfile);
1051 fprintf_filtered (outfile, "\n");
1054 /* Psymtab version of print_stats. See its definition in
1055 the definition of quick_symbol_functions in symfile.h. */
1058 psym_print_stats (struct objfile *objfile)
1061 struct partial_symtab *ps;
1064 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1066 if (ps->readin == 0)
1069 printf_filtered (_(" Number of psym tables (not yet expanded): %d\n"), i);
1072 /* Psymtab version of dump. See its definition in
1073 the definition of quick_symbol_functions in symfile.h. */
1076 psym_dump (struct objfile *objfile)
1078 struct partial_symtab *psymtab;
1080 if (objfile->psymtabs)
1082 printf_filtered ("Psymtabs:\n");
1083 for (psymtab = objfile->psymtabs;
1085 psymtab = psymtab->next)
1087 printf_filtered ("%s at ",
1089 gdb_print_host_address (psymtab, gdb_stdout);
1090 printf_filtered (", ");
1093 printf_filtered ("\n\n");
1097 /* Psymtab version of expand_symtabs_for_function. See its definition in
1098 the definition of quick_symbol_functions in symfile.h. */
1101 psym_expand_symtabs_for_function (struct objfile *objfile,
1102 const char *func_name)
1104 struct partial_symtab *ps;
1106 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1111 if ((lookup_partial_symbol (objfile, ps, func_name, 1, VAR_DOMAIN)
1113 || (lookup_partial_symbol (objfile, ps, func_name, 0, VAR_DOMAIN)
1115 psymtab_to_symtab (objfile, ps);
1119 /* Psymtab version of expand_all_symtabs. See its definition in
1120 the definition of quick_symbol_functions in symfile.h. */
1123 psym_expand_all_symtabs (struct objfile *objfile)
1125 struct partial_symtab *psymtab;
1127 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, psymtab)
1129 psymtab_to_symtab (objfile, psymtab);
1133 /* Psymtab version of expand_symtabs_with_fullname. See its definition in
1134 the definition of quick_symbol_functions in symfile.h. */
1137 psym_expand_symtabs_with_fullname (struct objfile *objfile,
1138 const char *fullname)
1140 struct partial_symtab *p;
1142 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, p)
1144 /* Anonymous psymtabs don't have a name of a source file. */
1148 /* psymtab_to_fullname tries to open the file which is slow.
1149 Don't call it if we know the basenames don't match. */
1150 if ((basenames_may_differ
1151 || filename_cmp (lbasename (fullname), lbasename (p->filename)) == 0)
1152 && filename_cmp (fullname, psymtab_to_fullname (p)) == 0)
1153 psymtab_to_symtab (objfile, p);
1157 /* Psymtab version of map_symbol_filenames. See its definition in
1158 the definition of quick_symbol_functions in symfile.h. */
1161 psym_map_symbol_filenames (struct objfile *objfile,
1162 symbol_filename_ftype *fun, void *data,
1165 struct partial_symtab *ps;
1167 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1169 const char *fullname;
1174 /* We can skip shared psymtabs here, because any file name will be
1175 attached to the unshared psymtab. */
1176 if (ps->user != NULL)
1179 /* Anonymous psymtabs don't have a file name. */
1185 fullname = psymtab_to_fullname (ps);
1188 (*fun) (ps->filename, fullname, data);
1192 /* Finds the fullname that a partial_symtab represents.
1194 If this functions finds the fullname, it will save it in ps->fullname
1195 and it will also return the value.
1197 If this function fails to find the file that this partial_symtab represents,
1198 NULL will be returned and ps->fullname will be set to NULL. */
1201 psymtab_to_fullname (struct partial_symtab *ps)
1203 gdb_assert (!ps->anonymous);
1205 /* Use cached copy if we have it.
1206 We rely on forget_cached_source_info being called appropriately
1207 to handle cases like the file being moved. */
1208 if (ps->fullname == NULL)
1210 gdb::unique_xmalloc_ptr<char> fullname;
1211 int fd = find_and_open_source (ps->filename, ps->dirname, &fullname);
1212 ps->fullname = fullname.release ();
1218 /* rewrite_source_path would be applied by find_and_open_source, we
1219 should report the pathname where GDB tried to find the file. */
1221 if (ps->dirname == NULL || IS_ABSOLUTE_PATH (ps->filename))
1222 fullname.reset (xstrdup (ps->filename));
1224 fullname.reset (concat (ps->dirname, SLASH_STRING,
1225 ps->filename, (char *) NULL));
1227 ps->fullname = rewrite_source_path (fullname.get ()).release ();
1228 if (ps->fullname == NULL)
1229 ps->fullname = fullname.release ();
1233 return ps->fullname;
1236 /* For all symbols, s, in BLOCK that are in DOMAIN and match NAME
1237 according to the function MATCH, call CALLBACK(BLOCK, s, DATA).
1238 BLOCK is assumed to come from OBJFILE. Returns 1 iff CALLBACK
1239 ever returns non-zero, and otherwise returns 0. */
1242 map_block (const char *name, domain_enum domain, struct objfile *objfile,
1243 struct block *block,
1244 int (*callback) (struct block *, struct symbol *, void *),
1245 void *data, symbol_name_match_type match)
1247 struct block_iterator iter;
1250 lookup_name_info lookup_name (name, match);
1252 for (sym = block_iter_match_first (block, lookup_name, &iter);
1254 sym = block_iter_match_next (lookup_name, &iter))
1256 if (symbol_matches_domain (SYMBOL_LANGUAGE (sym),
1257 SYMBOL_DOMAIN (sym), domain))
1259 if (callback (block, sym, data))
1267 /* Psymtab version of map_matching_symbols. See its definition in
1268 the definition of quick_symbol_functions in symfile.h. */
1271 psym_map_matching_symbols (struct objfile *objfile,
1272 const char *name, domain_enum domain,
1274 int (*callback) (struct block *,
1275 struct symbol *, void *),
1277 symbol_name_match_type match,
1278 symbol_compare_ftype *ordered_compare)
1280 const int block_kind = global ? GLOBAL_BLOCK : STATIC_BLOCK;
1281 struct partial_symtab *ps;
1283 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1287 || match_partial_symbol (objfile, ps, global, name, domain, match,
1290 struct compunit_symtab *cust = psymtab_to_symtab (objfile, ps);
1291 struct block *block;
1295 block = BLOCKVECTOR_BLOCK (COMPUNIT_BLOCKVECTOR (cust), block_kind);
1296 if (map_block (name, domain, objfile, block,
1297 callback, data, match))
1299 if (callback (block, NULL, data))
1305 /* A helper for psym_expand_symtabs_matching that handles searching
1306 included psymtabs. This returns true if a symbol is found, and
1307 false otherwise. It also updates the 'searched_flag' on the
1308 various psymtabs that it searches. */
1311 recursively_search_psymtabs
1312 (struct partial_symtab *ps, struct objfile *objfile, enum search_domain domain,
1313 const lookup_name_info &lookup_name,
1314 gdb::function_view<expand_symtabs_symbol_matcher_ftype> sym_matcher)
1317 enum psymtab_search_status result = PST_SEARCHED_AND_NOT_FOUND;
1320 if (ps->searched_flag != PST_NOT_SEARCHED)
1321 return ps->searched_flag == PST_SEARCHED_AND_FOUND;
1323 /* Recurse into shared psymtabs first, because they may have already
1324 been searched, and this could save some time. */
1325 for (i = 0; i < ps->number_of_dependencies; ++i)
1329 /* Skip non-shared dependencies, these are handled elsewhere. */
1330 if (ps->dependencies[i]->user == NULL)
1333 r = recursively_search_psymtabs (ps->dependencies[i],
1334 objfile, domain, lookup_name,
1338 ps->searched_flag = PST_SEARCHED_AND_FOUND;
1343 partial_symbol **gbound
1344 = objfile->global_psymbols.data () + ps->globals_offset + ps->n_global_syms;
1345 partial_symbol **sbound
1346 = objfile->static_psymbols.data () + ps->statics_offset + ps->n_static_syms;
1347 partial_symbol **bound = gbound;
1349 /* Go through all of the symbols stored in a partial
1350 symtab in one loop. */
1351 partial_symbol **psym = objfile->global_psymbols.data () + ps->globals_offset;
1356 if (bound == gbound && ps->n_static_syms != 0)
1358 psym = objfile->static_psymbols.data () + ps->statics_offset;
1369 if ((domain == ALL_DOMAIN
1370 || (domain == VARIABLES_DOMAIN
1371 && (*psym)->aclass != LOC_TYPEDEF
1372 && (*psym)->aclass != LOC_BLOCK)
1373 || (domain == FUNCTIONS_DOMAIN
1374 && (*psym)->aclass == LOC_BLOCK)
1375 || (domain == TYPES_DOMAIN
1376 && (*psym)->aclass == LOC_TYPEDEF))
1377 && psymbol_name_matches (*psym, lookup_name)
1378 && (sym_matcher == NULL || sym_matcher (symbol_search_name (*psym))))
1380 /* Found a match, so notify our caller. */
1381 result = PST_SEARCHED_AND_FOUND;
1388 ps->searched_flag = result;
1389 return result == PST_SEARCHED_AND_FOUND;
1392 /* Psymtab version of expand_symtabs_matching. See its definition in
1393 the definition of quick_symbol_functions in symfile.h. */
1396 psym_expand_symtabs_matching
1397 (struct objfile *objfile,
1398 gdb::function_view<expand_symtabs_file_matcher_ftype> file_matcher,
1399 const lookup_name_info &lookup_name_in,
1400 gdb::function_view<expand_symtabs_symbol_matcher_ftype> symbol_matcher,
1401 gdb::function_view<expand_symtabs_exp_notify_ftype> expansion_notify,
1402 enum search_domain domain)
1404 struct partial_symtab *ps;
1406 lookup_name_info lookup_name = lookup_name_in.make_ignore_params ();
1408 /* Clear the search flags. */
1409 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1411 ps->searched_flag = PST_NOT_SEARCHED;
1414 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1421 /* We skip shared psymtabs because file-matching doesn't apply
1422 to them; but we search them later in the loop. */
1423 if (ps->user != NULL)
1433 match = file_matcher (ps->filename, false);
1436 /* Before we invoke realpath, which can get expensive when many
1437 files are involved, do a quick comparison of the basenames. */
1438 if (basenames_may_differ
1439 || file_matcher (lbasename (ps->filename), true))
1440 match = file_matcher (psymtab_to_fullname (ps), false);
1446 if (recursively_search_psymtabs (ps, objfile, domain,
1447 lookup_name, symbol_matcher))
1449 struct compunit_symtab *symtab =
1450 psymtab_to_symtab (objfile, ps);
1452 if (expansion_notify != NULL)
1453 expansion_notify (symtab);
1458 /* Psymtab version of has_symbols. See its definition in
1459 the definition of quick_symbol_functions in symfile.h. */
1462 psym_has_symbols (struct objfile *objfile)
1464 return objfile->psymtabs != NULL;
1467 /* Helper function for psym_find_compunit_symtab_by_address that fills
1468 in psymbol_map for a given range of psymbols. */
1471 psym_fill_psymbol_map (struct objfile *objfile,
1472 struct partial_symtab *psymtab,
1473 std::set<CORE_ADDR> *seen_addrs,
1474 const std::vector<partial_symbol *> &symbols,
1478 for (int i = 0; i < length; ++i)
1480 struct partial_symbol *psym = symbols[start + i];
1482 if (psym->aclass == LOC_STATIC)
1484 CORE_ADDR addr = psym->address (objfile);
1485 if (seen_addrs->find (addr) == seen_addrs->end ())
1487 seen_addrs->insert (addr);
1488 objfile->psymbol_map.emplace_back (addr, psymtab);
1494 /* See find_compunit_symtab_by_address in quick_symbol_functions, in
1497 static compunit_symtab *
1498 psym_find_compunit_symtab_by_address (struct objfile *objfile,
1501 if (objfile->psymbol_map.empty ())
1503 struct partial_symtab *pst;
1505 std::set<CORE_ADDR> seen_addrs;
1507 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
1509 psym_fill_psymbol_map (objfile, pst,
1511 objfile->global_psymbols,
1512 pst->globals_offset,
1513 pst->n_global_syms);
1514 psym_fill_psymbol_map (objfile, pst,
1516 objfile->static_psymbols,
1517 pst->statics_offset,
1518 pst->n_static_syms);
1521 objfile->psymbol_map.shrink_to_fit ();
1523 std::sort (objfile->psymbol_map.begin (), objfile->psymbol_map.end (),
1524 [] (const std::pair<CORE_ADDR, partial_symtab *> &a,
1525 const std::pair<CORE_ADDR, partial_symtab *> &b)
1527 return a.first < b.first;
1531 auto iter = std::lower_bound
1532 (objfile->psymbol_map.begin (), objfile->psymbol_map.end (), address,
1533 [] (const std::pair<CORE_ADDR, partial_symtab *> &a,
1539 if (iter == objfile->psymbol_map.end () || iter->first != address)
1542 return psymtab_to_symtab (objfile, iter->second);
1545 const struct quick_symbol_functions psym_functions =
1548 psym_find_last_source_symtab,
1549 psym_forget_cached_source_info,
1550 psym_map_symtabs_matching_filename,
1555 psym_expand_symtabs_for_function,
1556 psym_expand_all_symtabs,
1557 psym_expand_symtabs_with_fullname,
1558 psym_map_matching_symbols,
1559 psym_expand_symtabs_matching,
1560 psym_find_pc_sect_compunit_symtab,
1561 psym_find_compunit_symtab_by_address,
1562 psym_map_symbol_filenames
1568 sort_pst_symbols (struct objfile *objfile, struct partial_symtab *pst)
1570 /* Sort the global list; don't sort the static list. */
1571 auto begin = objfile->global_psymbols.begin ();
1572 std::advance (begin, pst->globals_offset);
1574 /* The psymbols for this partial_symtab are currently at the end of the
1576 auto end = objfile->global_psymbols.end ();
1578 std::sort (begin, end, [] (partial_symbol *s1, partial_symbol *s2)
1580 return strcmp_iw_ordered (symbol_search_name (s1),
1581 symbol_search_name (s2)) < 0;
1585 /* Allocate and partially fill a partial symtab. It will be
1586 completely filled at the end of the symbol list.
1588 FILENAME is the name of the symbol-file we are reading from. */
1590 struct partial_symtab *
1591 start_psymtab_common (struct objfile *objfile,
1592 const char *filename,
1594 std::vector<partial_symbol *> &global_psymbols,
1595 std::vector<partial_symbol *> &static_psymbols)
1597 struct partial_symtab *psymtab;
1599 psymtab = allocate_psymtab (filename, objfile);
1600 psymtab->set_text_low (textlow);
1601 psymtab->set_text_high (psymtab->text_low ()); /* default */
1602 psymtab->globals_offset = global_psymbols.size ();
1603 psymtab->statics_offset = static_psymbols.size ();
1607 /* Perform "finishing up" operations of a partial symtab. */
1610 end_psymtab_common (struct objfile *objfile, struct partial_symtab *pst)
1612 pst->n_global_syms = objfile->global_psymbols.size () - pst->globals_offset;
1613 pst->n_static_syms = objfile->static_psymbols.size () - pst->statics_offset;
1615 sort_pst_symbols (objfile, pst);
1618 /* Calculate a hash code for the given partial symbol. The hash is
1619 calculated using the symbol's value, language, domain, class
1620 and name. These are the values which are set by
1621 add_psymbol_to_bcache. */
1623 static unsigned long
1624 psymbol_hash (const void *addr, int length)
1626 unsigned long h = 0;
1627 struct partial_symbol *psymbol = (struct partial_symbol *) addr;
1628 unsigned int lang = psymbol->language;
1629 unsigned int domain = psymbol->domain;
1630 unsigned int theclass = psymbol->aclass;
1632 h = hash_continue (&psymbol->value, sizeof (psymbol->value), h);
1633 h = hash_continue (&lang, sizeof (unsigned int), h);
1634 h = hash_continue (&domain, sizeof (unsigned int), h);
1635 h = hash_continue (&theclass, sizeof (unsigned int), h);
1636 /* Note that psymbol names are interned via symbol_set_names, so
1637 there's no need to hash the contents of the name here. */
1638 h = hash_continue (&psymbol->name,
1639 sizeof (psymbol->name), h);
1644 /* Returns true if the symbol at addr1 equals the symbol at addr2.
1645 For the comparison this function uses a symbols value,
1646 language, domain, class and name. */
1649 psymbol_compare (const void *addr1, const void *addr2, int length)
1651 struct partial_symbol *sym1 = (struct partial_symbol *) addr1;
1652 struct partial_symbol *sym2 = (struct partial_symbol *) addr2;
1654 return (memcmp (&sym1->value, &sym2->value,
1655 sizeof (sym1->value)) == 0
1656 && sym1->language == sym2->language
1657 && sym1->domain == sym2->domain
1658 && sym1->aclass == sym2->aclass
1659 /* Note that psymbol names are interned via
1660 symbol_set_names, so there's no need to compare the
1661 contents of the name here. */
1662 && sym1->name == sym2->name);
1665 /* Initialize a partial symbol bcache. */
1667 struct psymbol_bcache *
1668 psymbol_bcache_init (void)
1670 struct psymbol_bcache *bcache = XCNEW (struct psymbol_bcache);
1672 bcache->bcache = bcache_xmalloc (psymbol_hash, psymbol_compare);
1676 /* Free a partial symbol bcache. */
1679 psymbol_bcache_free (struct psymbol_bcache *bcache)
1684 bcache_xfree (bcache->bcache);
1688 /* Return the internal bcache of the psymbol_bcache BCACHE. */
1691 psymbol_bcache_get_bcache (struct psymbol_bcache *bcache)
1693 return bcache->bcache;
1696 /* Find a copy of the SYM in BCACHE. If BCACHE has never seen this
1697 symbol before, add a copy to BCACHE. In either case, return a pointer
1698 to BCACHE's copy of the symbol. If optional ADDED is not NULL, return
1699 1 in case of new entry or 0 if returning an old entry. */
1701 static struct partial_symbol *
1702 psymbol_bcache_full (struct partial_symbol *sym,
1703 struct psymbol_bcache *bcache,
1706 return ((struct partial_symbol *)
1707 bcache_full (sym, sizeof (struct partial_symbol), bcache->bcache,
1711 /* Helper function, initialises partial symbol structure and stashes
1712 it into objfile's bcache. Note that our caching mechanism will
1713 use all fields of struct partial_symbol to determine hash value of the
1714 structure. In other words, having two symbols with the same name but
1715 different domain (or address) is possible and correct. */
1717 static struct partial_symbol *
1718 add_psymbol_to_bcache (const char *name, int namelength, int copy_name,
1720 enum address_class theclass,
1722 enum language language, struct objfile *objfile,
1725 struct partial_symbol psymbol;
1727 psymbol.set_address (coreaddr);
1728 psymbol.section = -1;
1729 psymbol.domain = domain;
1730 psymbol.aclass = theclass;
1732 memset (&psymbol.language_specific, 0, sizeof (psymbol.language_specific));
1733 psymbol.ada_mangled = 0;
1734 symbol_set_language (&psymbol, language, &objfile->objfile_obstack);
1735 symbol_set_names (&psymbol, name, namelength, copy_name, objfile);
1737 /* Stash the partial symbol away in the cache. */
1738 return psymbol_bcache_full (&psymbol, objfile->psymbol_cache, added);
1741 /* Helper function, adds partial symbol to the given partial symbol list. */
1744 append_psymbol_to_list (std::vector<partial_symbol *> *list,
1745 struct partial_symbol *psym,
1746 struct objfile *objfile)
1748 list->push_back (psym);
1749 OBJSTAT (objfile, n_psyms++);
1752 /* Add a symbol with a long value to a psymtab.
1753 Since one arg is a struct, we pass in a ptr and deref it (sigh).
1754 The only value we need to store for psyms is an address.
1755 For all other psyms pass zero for COREADDR.
1756 Return the partial symbol that has been added. */
1759 add_psymbol_to_list (const char *name, int namelength, int copy_name,
1761 enum address_class theclass,
1762 std::vector<partial_symbol *> *list,
1764 enum language language, struct objfile *objfile)
1766 struct partial_symbol *psym;
1770 /* Stash the partial symbol away in the cache. */
1771 psym = add_psymbol_to_bcache (name, namelength, copy_name, domain, theclass,
1772 coreaddr, language, objfile, &added);
1774 /* Do not duplicate global partial symbols. */
1775 if (list == &objfile->global_psymbols
1779 /* Save pointer to partial symbol in psymtab, growing symtab if needed. */
1780 append_psymbol_to_list (list, psym, objfile);
1783 /* Initialize storage for partial symbols. */
1786 init_psymbol_list (struct objfile *objfile, int total_symbols)
1788 /* Free any previously allocated psymbol lists. */
1789 objfile->global_psymbols.clear ();
1790 objfile->static_psymbols.clear ();
1792 /* Current best guess is that approximately a twentieth
1793 of the total symbols (in a debugging file) are global or static
1794 oriented symbols, then multiply that by slop factor of two. */
1795 objfile->global_psymbols.reserve (total_symbols / 10);
1796 objfile->static_psymbols.reserve (total_symbols / 10);
1799 struct partial_symtab *
1800 allocate_psymtab (const char *filename, struct objfile *objfile)
1802 struct partial_symtab *psymtab;
1804 if (objfile->free_psymtabs)
1806 psymtab = objfile->free_psymtabs;
1807 objfile->free_psymtabs = psymtab->next;
1810 psymtab = XOBNEW (&objfile->objfile_obstack, partial_symtab);
1812 memset (psymtab, 0, sizeof (struct partial_symtab));
1814 = (const char *) bcache (filename, strlen (filename) + 1,
1815 objfile->per_bfd->filename_cache);
1816 psymtab->compunit_symtab = NULL;
1818 /* Prepend it to the psymtab list for the objfile it belongs to.
1819 Psymtabs are searched in most recent inserted -> least recent
1822 psymtab->next = objfile->psymtabs;
1823 objfile->psymtabs = psymtab;
1825 if (symtab_create_debug)
1827 /* Be a bit clever with debugging messages, and don't print objfile
1828 every time, only when it changes. */
1829 static char *last_objfile_name = NULL;
1831 if (last_objfile_name == NULL
1832 || strcmp (last_objfile_name, objfile_name (objfile)) != 0)
1834 xfree (last_objfile_name);
1835 last_objfile_name = xstrdup (objfile_name (objfile));
1836 fprintf_unfiltered (gdb_stdlog,
1837 "Creating one or more psymtabs for objfile %s ...\n",
1840 fprintf_unfiltered (gdb_stdlog,
1841 "Created psymtab %s for module %s.\n",
1842 host_address_to_string (psymtab), filename);
1849 discard_psymtab (struct objfile *objfile, struct partial_symtab *pst)
1851 struct partial_symtab **prev_pst;
1854 Empty psymtabs happen as a result of header files which don't
1855 have any symbols in them. There can be a lot of them. But this
1856 check is wrong, in that a psymtab with N_SLINE entries but
1857 nothing else is not empty, but we don't realize that. Fixing
1858 that without slowing things down might be tricky. */
1860 /* First, snip it out of the psymtab chain. */
1862 prev_pst = &(objfile->psymtabs);
1863 while ((*prev_pst) != pst)
1864 prev_pst = &((*prev_pst)->next);
1865 (*prev_pst) = pst->next;
1867 /* Next, put it on a free list for recycling. */
1869 pst->next = objfile->free_psymtabs;
1870 objfile->free_psymtabs = pst;
1875 /* We need to pass a couple of items to the addrmap_foreach function,
1878 struct dump_psymtab_addrmap_data
1880 struct objfile *objfile;
1881 struct partial_symtab *psymtab;
1882 struct ui_file *outfile;
1884 /* Non-zero if the previously printed addrmap entry was for PSYMTAB.
1885 If so, we want to print the next one as well (since the next addrmap
1886 entry defines the end of the range). */
1887 int previous_matched;
1890 /* Helper function for dump_psymtab_addrmap to print an addrmap entry. */
1893 dump_psymtab_addrmap_1 (void *datap, CORE_ADDR start_addr, void *obj)
1895 struct dump_psymtab_addrmap_data *data
1896 = (struct dump_psymtab_addrmap_data *) datap;
1897 struct gdbarch *gdbarch = get_objfile_arch (data->objfile);
1898 struct partial_symtab *addrmap_psymtab = (struct partial_symtab *) obj;
1899 const char *psymtab_address_or_end = NULL;
1903 if (data->psymtab == NULL
1904 || data->psymtab == addrmap_psymtab)
1905 psymtab_address_or_end = host_address_to_string (addrmap_psymtab);
1906 else if (data->previous_matched)
1907 psymtab_address_or_end = "<ends here>";
1909 if (data->psymtab == NULL
1910 || data->psymtab == addrmap_psymtab
1911 || data->previous_matched)
1913 fprintf_filtered (data->outfile, " %s%s %s\n",
1914 data->psymtab != NULL ? " " : "",
1915 paddress (gdbarch, start_addr),
1916 psymtab_address_or_end);
1919 data->previous_matched = (data->psymtab == NULL
1920 || data->psymtab == addrmap_psymtab);
1925 /* Helper function for maintenance_print_psymbols to print the addrmap
1926 of PSYMTAB. If PSYMTAB is NULL print the entire addrmap. */
1929 dump_psymtab_addrmap (struct objfile *objfile, struct partial_symtab *psymtab,
1930 struct ui_file *outfile)
1932 struct dump_psymtab_addrmap_data addrmap_dump_data;
1934 if ((psymtab == NULL
1935 || psymtab->psymtabs_addrmap_supported)
1936 && objfile->psymtabs_addrmap != NULL)
1938 addrmap_dump_data.objfile = objfile;
1939 addrmap_dump_data.psymtab = psymtab;
1940 addrmap_dump_data.outfile = outfile;
1941 addrmap_dump_data.previous_matched = 0;
1942 fprintf_filtered (outfile, "%sddress map:\n",
1943 psymtab == NULL ? "Entire a" : " A");
1944 addrmap_foreach (objfile->psymtabs_addrmap, dump_psymtab_addrmap_1,
1945 &addrmap_dump_data);
1950 maintenance_print_psymbols (const char *args, int from_tty)
1952 struct ui_file *outfile = gdb_stdout;
1953 char *address_arg = NULL, *source_arg = NULL, *objfile_arg = NULL;
1954 struct objfile *objfile;
1955 struct partial_symtab *ps;
1956 int i, outfile_idx, found;
1958 struct obj_section *section = NULL;
1962 gdb_argv argv (args);
1964 for (i = 0; argv != NULL && argv[i] != NULL; ++i)
1966 if (strcmp (argv[i], "-pc") == 0)
1968 if (argv[i + 1] == NULL)
1969 error (_("Missing pc value"));
1970 address_arg = argv[++i];
1972 else if (strcmp (argv[i], "-source") == 0)
1974 if (argv[i + 1] == NULL)
1975 error (_("Missing source file"));
1976 source_arg = argv[++i];
1978 else if (strcmp (argv[i], "-objfile") == 0)
1980 if (argv[i + 1] == NULL)
1981 error (_("Missing objfile name"));
1982 objfile_arg = argv[++i];
1984 else if (strcmp (argv[i], "--") == 0)
1986 /* End of options. */
1990 else if (argv[i][0] == '-')
1992 /* Future proofing: Don't allow OUTFILE to begin with "-". */
1993 error (_("Unknown option: %s"), argv[i]);
2000 if (address_arg != NULL && source_arg != NULL)
2001 error (_("Must specify at most one of -pc and -source"));
2003 stdio_file arg_outfile;
2005 if (argv != NULL && argv[outfile_idx] != NULL)
2007 if (argv[outfile_idx + 1] != NULL)
2008 error (_("Junk at end of command"));
2009 gdb::unique_xmalloc_ptr<char> outfile_name
2010 (tilde_expand (argv[outfile_idx]));
2011 if (!arg_outfile.open (outfile_name.get (), FOPEN_WT))
2012 perror_with_name (outfile_name.get ());
2013 outfile = &arg_outfile;
2016 if (address_arg != NULL)
2018 pc = parse_and_eval_address (address_arg);
2019 /* If we fail to find a section, that's ok, try the lookup anyway. */
2020 section = find_pc_section (pc);
2024 ALL_OBJFILES (objfile)
2026 int printed_objfile_header = 0;
2027 int print_for_objfile = 1;
2030 if (objfile_arg != NULL)
2032 = compare_filenames_for_search (objfile_name (objfile),
2034 if (!print_for_objfile)
2037 if (address_arg != NULL)
2039 struct bound_minimal_symbol msymbol = { NULL, NULL };
2041 /* We don't assume each pc has a unique objfile (this is for
2043 ps = find_pc_sect_psymtab (objfile, pc, section, msymbol);
2046 if (!printed_objfile_header)
2048 outfile->printf ("\nPartial symtabs for objfile %s\n",
2049 objfile_name (objfile));
2050 printed_objfile_header = 1;
2052 dump_psymtab (objfile, ps, outfile);
2053 dump_psymtab_addrmap (objfile, ps, outfile);
2059 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
2061 int print_for_source = 0;
2064 if (source_arg != NULL)
2067 = compare_filenames_for_search (ps->filename, source_arg);
2070 if (source_arg == NULL
2071 || print_for_source)
2073 if (!printed_objfile_header)
2075 outfile->printf ("\nPartial symtabs for objfile %s\n",
2076 objfile_name (objfile));
2077 printed_objfile_header = 1;
2079 dump_psymtab (objfile, ps, outfile);
2080 dump_psymtab_addrmap (objfile, ps, outfile);
2085 /* If we're printing all the objfile's symbols dump the full addrmap. */
2087 if (address_arg == NULL
2088 && source_arg == NULL
2089 && objfile->psymtabs_addrmap != NULL)
2091 outfile->puts ("\n");
2092 dump_psymtab_addrmap (objfile, NULL, outfile);
2098 if (address_arg != NULL)
2099 error (_("No partial symtab for address: %s"), address_arg);
2100 if (source_arg != NULL)
2101 error (_("No partial symtab for source file: %s"), source_arg);
2105 /* List all the partial symbol tables whose names match REGEXP (optional). */
2108 maintenance_info_psymtabs (const char *regexp, int from_tty)
2110 struct program_space *pspace;
2111 struct objfile *objfile;
2116 ALL_PSPACES (pspace)
2117 ALL_PSPACE_OBJFILES (pspace, objfile)
2119 struct gdbarch *gdbarch = get_objfile_arch (objfile);
2120 struct partial_symtab *psymtab;
2122 /* We don't want to print anything for this objfile until we
2123 actually find a symtab whose name matches. */
2124 int printed_objfile_start = 0;
2126 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, psymtab)
2131 || re_exec (psymtab->filename))
2133 if (! printed_objfile_start)
2135 printf_filtered ("{ objfile %s ", objfile_name (objfile));
2137 printf_filtered ("((struct objfile *) %s)\n",
2138 host_address_to_string (objfile));
2139 printed_objfile_start = 1;
2142 printf_filtered (" { psymtab %s ", psymtab->filename);
2144 printf_filtered ("((struct partial_symtab *) %s)\n",
2145 host_address_to_string (psymtab));
2147 printf_filtered (" readin %s\n",
2148 psymtab->readin ? "yes" : "no");
2149 printf_filtered (" fullname %s\n",
2151 ? psymtab->fullname : "(null)");
2152 printf_filtered (" text addresses ");
2153 fputs_filtered (paddress (gdbarch, psymtab->text_low ()),
2155 printf_filtered (" -- ");
2156 fputs_filtered (paddress (gdbarch, psymtab->text_high ()),
2158 printf_filtered ("\n");
2159 printf_filtered (" psymtabs_addrmap_supported %s\n",
2160 (psymtab->psymtabs_addrmap_supported
2162 printf_filtered (" globals ");
2163 if (psymtab->n_global_syms)
2165 auto p = &objfile->global_psymbols[psymtab->globals_offset];
2167 printf_filtered ("(* (struct partial_symbol **) %s @ %d)\n",
2168 host_address_to_string (p),
2169 psymtab->n_global_syms);
2172 printf_filtered ("(none)\n");
2173 printf_filtered (" statics ");
2174 if (psymtab->n_static_syms)
2176 auto p = &objfile->static_psymbols[psymtab->statics_offset];
2178 printf_filtered ("(* (struct partial_symbol **) %s @ %d)\n",
2179 host_address_to_string (p),
2180 psymtab->n_static_syms);
2183 printf_filtered ("(none)\n");
2184 printf_filtered (" dependencies ");
2185 if (psymtab->number_of_dependencies)
2189 printf_filtered ("{\n");
2190 for (i = 0; i < psymtab->number_of_dependencies; i++)
2192 struct partial_symtab *dep = psymtab->dependencies[i];
2194 /* Note the string concatenation there --- no comma. */
2195 printf_filtered (" psymtab %s "
2196 "((struct partial_symtab *) %s)\n",
2198 host_address_to_string (dep));
2200 printf_filtered (" }\n");
2203 printf_filtered ("(none)\n");
2204 printf_filtered (" }\n");
2208 if (printed_objfile_start)
2209 printf_filtered ("}\n");
2213 /* Check consistency of currently expanded psymtabs vs symtabs. */
2216 maintenance_check_psymtabs (const char *ignore, int from_tty)
2219 struct compunit_symtab *cust = NULL;
2220 struct partial_symtab *ps;
2221 const struct blockvector *bv;
2222 struct objfile *objfile;
2226 ALL_PSYMTABS (objfile, ps)
2228 struct gdbarch *gdbarch = get_objfile_arch (objfile);
2230 /* We don't call psymtab_to_symtab here because that may cause symtab
2231 expansion. When debugging a problem it helps if checkers leave
2232 things unchanged. */
2233 cust = ps->compunit_symtab;
2235 /* First do some checks that don't require the associated symtab. */
2236 if (ps->text_high () < ps->text_low ())
2238 printf_filtered ("Psymtab ");
2239 puts_filtered (ps->filename);
2240 printf_filtered (" covers bad range ");
2241 fputs_filtered (paddress (gdbarch, ps->text_low ()), gdb_stdout);
2242 printf_filtered (" - ");
2243 fputs_filtered (paddress (gdbarch, ps->text_high ()), gdb_stdout);
2244 printf_filtered ("\n");
2248 /* Now do checks requiring the associated symtab. */
2251 bv = COMPUNIT_BLOCKVECTOR (cust);
2252 b = BLOCKVECTOR_BLOCK (bv, STATIC_BLOCK);
2253 partial_symbol **psym = &objfile->static_psymbols[ps->statics_offset];
2254 length = ps->n_static_syms;
2257 sym = block_lookup_symbol (b, symbol_search_name (*psym),
2258 symbol_name_match_type::SEARCH_NAME,
2262 printf_filtered ("Static symbol `");
2263 puts_filtered ((*psym)->name);
2264 printf_filtered ("' only found in ");
2265 puts_filtered (ps->filename);
2266 printf_filtered (" psymtab\n");
2270 b = BLOCKVECTOR_BLOCK (bv, GLOBAL_BLOCK);
2271 psym = &objfile->global_psymbols[ps->globals_offset];
2272 length = ps->n_global_syms;
2275 sym = block_lookup_symbol (b, symbol_search_name (*psym),
2276 symbol_name_match_type::SEARCH_NAME,
2280 printf_filtered ("Global symbol `");
2281 puts_filtered ((*psym)->name);
2282 printf_filtered ("' only found in ");
2283 puts_filtered (ps->filename);
2284 printf_filtered (" psymtab\n");
2288 if (ps->text_high () != 0
2289 && (ps->text_low () < BLOCK_START (b)
2290 || ps->text_high () > BLOCK_END (b)))
2292 printf_filtered ("Psymtab ");
2293 puts_filtered (ps->filename);
2294 printf_filtered (" covers ");
2295 fputs_filtered (paddress (gdbarch, ps->text_low ()), gdb_stdout);
2296 printf_filtered (" - ");
2297 fputs_filtered (paddress (gdbarch, ps->text_high ()), gdb_stdout);
2298 printf_filtered (" but symtab covers only ");
2299 fputs_filtered (paddress (gdbarch, BLOCK_START (b)), gdb_stdout);
2300 printf_filtered (" - ");
2301 fputs_filtered (paddress (gdbarch, BLOCK_END (b)), gdb_stdout);
2302 printf_filtered ("\n");
2308 _initialize_psymtab (void)
2310 add_cmd ("psymbols", class_maintenance, maintenance_print_psymbols, _("\
2311 Print dump of current partial symbol definitions.\n\
2312 Usage: mt print psymbols [-objfile objfile] [-pc address] [--] [outfile]\n\
2313 mt print psymbols [-objfile objfile] [-source source] [--] [outfile]\n\
2314 Entries in the partial symbol table are dumped to file OUTFILE,\n\
2315 or the terminal if OUTFILE is unspecified.\n\
2316 If ADDRESS is provided, dump only the file for that address.\n\
2317 If SOURCE is provided, dump only that file's symbols.\n\
2318 If OBJFILE is provided, dump only that file's minimal symbols."),
2319 &maintenanceprintlist);
2321 add_cmd ("psymtabs", class_maintenance, maintenance_info_psymtabs, _("\
2322 List the partial symbol tables for all object files.\n\
2323 This does not include information about individual partial symbols,\n\
2324 just the symbol table structures themselves."),
2325 &maintenanceinfolist);
2327 add_cmd ("check-psymtabs", class_maintenance, maintenance_check_psymtabs,
2329 Check consistency of currently expanded psymtabs versus symtabs."),