Turn start_psymtab_common into a constructor
[deliverable/binutils-gdb.git] / gdb / psymtab.c
1 /* Partial symbol tables.
2
3 Copyright (C) 2009-2020 Free Software Foundation, Inc.
4
5 This file is part of GDB.
6
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.
11
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.
16
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/>. */
19
20 #include "defs.h"
21 #include "symtab.h"
22 #include "objfiles.h"
23 #include "psympriv.h"
24 #include "block.h"
25 #include "filenames.h"
26 #include "source.h"
27 #include "addrmap.h"
28 #include "gdbtypes.h"
29 #include "ui-out.h"
30 #include "command.h"
31 #include "readline/tilde.h"
32 #include "gdb_regex.h"
33 #include "dictionary.h"
34 #include "language.h"
35 #include "cp-support.h"
36 #include "gdbcmd.h"
37 #include <algorithm>
38 #include <set>
39
40 static struct partial_symbol *lookup_partial_symbol (struct objfile *,
41 struct partial_symtab *,
42 const char *, int,
43 domain_enum);
44
45 static const char *psymtab_to_fullname (struct partial_symtab *ps);
46
47 static struct partial_symbol *find_pc_sect_psymbol (struct objfile *,
48 struct partial_symtab *,
49 CORE_ADDR,
50 struct obj_section *);
51
52 static struct compunit_symtab *psymtab_to_symtab (struct objfile *objfile,
53 struct partial_symtab *pst);
54
55 \f
56
57 static unsigned long psymbol_hash (const void *addr, int length);
58 static int psymbol_compare (const void *addr1, const void *addr2, int length);
59
60 psymtab_storage::psymtab_storage ()
61 : psymbol_cache (psymbol_hash, psymbol_compare)
62 {
63 }
64
65 psymtab_storage::~psymtab_storage ()
66 {
67 partial_symtab *iter = psymtabs;
68 while (iter != nullptr)
69 {
70 partial_symtab *next = iter->next;
71 delete iter;
72 iter = next;
73 }
74 }
75
76 /* See psymtab.h. */
77
78 void
79 psymtab_storage::install_psymtab (partial_symtab *pst)
80 {
81 pst->next = psymtabs;
82 psymtabs = pst;
83 }
84
85 \f
86
87 /* See psymtab.h. */
88
89 psymtab_storage::partial_symtab_range
90 require_partial_symbols (struct objfile *objfile, bool verbose)
91 {
92 if ((objfile->flags & OBJF_PSYMTABS_READ) == 0)
93 {
94 objfile->flags |= OBJF_PSYMTABS_READ;
95
96 if (objfile->sf->sym_read_psymbols)
97 {
98 if (verbose)
99 printf_filtered (_("Reading symbols from %s...\n"),
100 objfile_name (objfile));
101 (*objfile->sf->sym_read_psymbols) (objfile);
102
103 /* Partial symbols list are not expected to changed after this
104 point. */
105 objfile->partial_symtabs->global_psymbols.shrink_to_fit ();
106 objfile->partial_symtabs->static_psymbols.shrink_to_fit ();
107
108 if (verbose && !objfile_has_symbols (objfile))
109 printf_filtered (_("(No debugging symbols found in %s)\n"),
110 objfile_name (objfile));
111 }
112 }
113
114 return objfile->psymtabs ();
115 }
116
117 /* Helper function for psym_map_symtabs_matching_filename that
118 expands the symtabs and calls the iterator. */
119
120 static bool
121 partial_map_expand_apply (struct objfile *objfile,
122 const char *name,
123 const char *real_path,
124 struct partial_symtab *pst,
125 gdb::function_view<bool (symtab *)> callback)
126 {
127 struct compunit_symtab *last_made = objfile->compunit_symtabs;
128
129 /* Shared psymtabs should never be seen here. Instead they should
130 be handled properly by the caller. */
131 gdb_assert (pst->user == NULL);
132
133 /* Don't visit already-expanded psymtabs. */
134 if (pst->readin)
135 return 0;
136
137 /* This may expand more than one symtab, and we want to iterate over
138 all of them. */
139 psymtab_to_symtab (objfile, pst);
140
141 return iterate_over_some_symtabs (name, real_path, objfile->compunit_symtabs,
142 last_made, callback);
143 }
144
145 /* Psymtab version of map_symtabs_matching_filename. See its definition in
146 the definition of quick_symbol_functions in symfile.h. */
147
148 static bool
149 psym_map_symtabs_matching_filename
150 (struct objfile *objfile,
151 const char *name,
152 const char *real_path,
153 gdb::function_view<bool (symtab *)> callback)
154 {
155 const char *name_basename = lbasename (name);
156
157 for (partial_symtab *pst : require_partial_symbols (objfile, true))
158 {
159 /* We can skip shared psymtabs here, because any file name will be
160 attached to the unshared psymtab. */
161 if (pst->user != NULL)
162 continue;
163
164 /* Anonymous psymtabs don't have a file name. */
165 if (pst->anonymous)
166 continue;
167
168 if (compare_filenames_for_search (pst->filename, name))
169 {
170 if (partial_map_expand_apply (objfile, name, real_path,
171 pst, callback))
172 return true;
173 continue;
174 }
175
176 /* Before we invoke realpath, which can get expensive when many
177 files are involved, do a quick comparison of the basenames. */
178 if (! basenames_may_differ
179 && FILENAME_CMP (name_basename, lbasename (pst->filename)) != 0)
180 continue;
181
182 if (compare_filenames_for_search (psymtab_to_fullname (pst), name))
183 {
184 if (partial_map_expand_apply (objfile, name, real_path,
185 pst, callback))
186 return true;
187 continue;
188 }
189
190 /* If the user gave us an absolute path, try to find the file in
191 this symtab and use its absolute path. */
192 if (real_path != NULL)
193 {
194 gdb_assert (IS_ABSOLUTE_PATH (real_path));
195 gdb_assert (IS_ABSOLUTE_PATH (name));
196 if (filename_cmp (psymtab_to_fullname (pst), real_path) == 0)
197 {
198 if (partial_map_expand_apply (objfile, name, real_path,
199 pst, callback))
200 return true;
201 continue;
202 }
203 }
204 }
205
206 return false;
207 }
208
209 /* Find which partial symtab contains PC and SECTION starting at psymtab PST.
210 We may find a different psymtab than PST. See FIND_PC_SECT_PSYMTAB. */
211
212 static struct partial_symtab *
213 find_pc_sect_psymtab_closer (struct objfile *objfile,
214 CORE_ADDR pc, struct obj_section *section,
215 struct partial_symtab *pst,
216 struct bound_minimal_symbol msymbol)
217 {
218 struct partial_symtab *tpst;
219 struct partial_symtab *best_pst = pst;
220 CORE_ADDR best_addr = pst->text_low (objfile);
221
222 gdb_assert (!pst->psymtabs_addrmap_supported);
223
224 /* An objfile that has its functions reordered might have
225 many partial symbol tables containing the PC, but
226 we want the partial symbol table that contains the
227 function containing the PC. */
228 if (!(objfile->flags & OBJF_REORDERED)
229 && section == NULL) /* Can't validate section this way. */
230 return pst;
231
232 if (msymbol.minsym == NULL)
233 return pst;
234
235 /* The code range of partial symtabs sometimes overlap, so, in
236 the loop below, we need to check all partial symtabs and
237 find the one that fits better for the given PC address. We
238 select the partial symtab that contains a symbol whose
239 address is closest to the PC address. By closest we mean
240 that find_pc_sect_symbol returns the symbol with address
241 that is closest and still less than the given PC. */
242 for (tpst = pst; tpst != NULL; tpst = tpst->next)
243 {
244 if (pc >= tpst->text_low (objfile) && pc < tpst->text_high (objfile))
245 {
246 struct partial_symbol *p;
247 CORE_ADDR this_addr;
248
249 /* NOTE: This assumes that every psymbol has a
250 corresponding msymbol, which is not necessarily
251 true; the debug info might be much richer than the
252 object's symbol table. */
253 p = find_pc_sect_psymbol (objfile, tpst, pc, section);
254 if (p != NULL
255 && (p->address (objfile) == BMSYMBOL_VALUE_ADDRESS (msymbol)))
256 return tpst;
257
258 /* Also accept the textlow value of a psymtab as a
259 "symbol", to provide some support for partial
260 symbol tables with line information but no debug
261 symbols (e.g. those produced by an assembler). */
262 if (p != NULL)
263 this_addr = p->address (objfile);
264 else
265 this_addr = tpst->text_low (objfile);
266
267 /* Check whether it is closer than our current
268 BEST_ADDR. Since this symbol address is
269 necessarily lower or equal to PC, the symbol closer
270 to PC is the symbol which address is the highest.
271 This way we return the psymtab which contains such
272 best match symbol. This can help in cases where the
273 symbol information/debuginfo is not complete, like
274 for instance on IRIX6 with gcc, where no debug info
275 is emitted for statics. (See also the nodebug.exp
276 testcase.) */
277 if (this_addr > best_addr)
278 {
279 best_addr = this_addr;
280 best_pst = tpst;
281 }
282 }
283 }
284 return best_pst;
285 }
286
287 /* Find which partial symtab contains PC and SECTION. Return NULL if
288 none. We return the psymtab that contains a symbol whose address
289 exactly matches PC, or, if we cannot find an exact match, the
290 psymtab that contains a symbol whose address is closest to PC. */
291
292 static struct partial_symtab *
293 find_pc_sect_psymtab (struct objfile *objfile, CORE_ADDR pc,
294 struct obj_section *section,
295 struct bound_minimal_symbol msymbol)
296 {
297 /* Try just the PSYMTABS_ADDRMAP mapping first as it has better
298 granularity than the later used TEXTLOW/TEXTHIGH one. However, we need
299 to take care as the PSYMTABS_ADDRMAP can hold things other than partial
300 symtabs in some cases.
301
302 This function should only be called for objfiles that are using partial
303 symtabs, not for objfiles that are using indexes (.gdb_index or
304 .debug_names), however 'maintenance print psymbols' calls this function
305 directly for all objfiles. If we assume that PSYMTABS_ADDRMAP contains
306 partial symtabs then we will end up returning a pointer to an object
307 that is not a partial_symtab, which doesn't end well. */
308
309 if (objfile->partial_symtabs->psymtabs != NULL
310 && objfile->partial_symtabs->psymtabs_addrmap != NULL)
311 {
312 CORE_ADDR baseaddr = objfile->text_section_offset ();
313
314 struct partial_symtab *pst
315 = ((struct partial_symtab *)
316 addrmap_find (objfile->partial_symtabs->psymtabs_addrmap,
317 pc - baseaddr));
318 if (pst != NULL)
319 {
320 /* FIXME: addrmaps currently do not handle overlayed sections,
321 so fall back to the non-addrmap case if we're debugging
322 overlays and the addrmap returned the wrong section. */
323 if (overlay_debugging && msymbol.minsym != NULL && section != NULL)
324 {
325 struct partial_symbol *p;
326
327 /* NOTE: This assumes that every psymbol has a
328 corresponding msymbol, which is not necessarily
329 true; the debug info might be much richer than the
330 object's symbol table. */
331 p = find_pc_sect_psymbol (objfile, pst, pc, section);
332 if (p == NULL
333 || (p->address (objfile)
334 != BMSYMBOL_VALUE_ADDRESS (msymbol)))
335 goto next;
336 }
337
338 /* We do not try to call FIND_PC_SECT_PSYMTAB_CLOSER as
339 PSYMTABS_ADDRMAP we used has already the best 1-byte
340 granularity and FIND_PC_SECT_PSYMTAB_CLOSER may mislead us into
341 a worse chosen section due to the TEXTLOW/TEXTHIGH ranges
342 overlap. */
343
344 return pst;
345 }
346 }
347
348 next:
349
350 /* Existing PSYMTABS_ADDRMAP mapping is present even for PARTIAL_SYMTABs
351 which still have no corresponding full SYMTABs read. But it is not
352 present for non-DWARF2 debug infos not supporting PSYMTABS_ADDRMAP in GDB
353 so far. */
354
355 /* Check even OBJFILE with non-zero PSYMTABS_ADDRMAP as only several of
356 its CUs may be missing in PSYMTABS_ADDRMAP as they may be varying
357 debug info type in single OBJFILE. */
358
359 for (partial_symtab *pst : require_partial_symbols (objfile, true))
360 if (!pst->psymtabs_addrmap_supported
361 && pc >= pst->text_low (objfile) && pc < pst->text_high (objfile))
362 {
363 struct partial_symtab *best_pst;
364
365 best_pst = find_pc_sect_psymtab_closer (objfile, pc, section, pst,
366 msymbol);
367 if (best_pst != NULL)
368 return best_pst;
369 }
370
371 return NULL;
372 }
373
374 /* Psymtab version of find_pc_sect_compunit_symtab. See its definition in
375 the definition of quick_symbol_functions in symfile.h. */
376
377 static struct compunit_symtab *
378 psym_find_pc_sect_compunit_symtab (struct objfile *objfile,
379 struct bound_minimal_symbol msymbol,
380 CORE_ADDR pc,
381 struct obj_section *section,
382 int warn_if_readin)
383 {
384 struct partial_symtab *ps = find_pc_sect_psymtab (objfile, pc, section,
385 msymbol);
386 if (ps != NULL)
387 {
388 if (warn_if_readin && ps->readin)
389 /* Might want to error() here (in case symtab is corrupt and
390 will cause a core dump), but maybe we can successfully
391 continue, so let's not. */
392 warning (_("\
393 (Internal error: pc %s in read in psymtab, but not in symtab.)\n"),
394 paddress (get_objfile_arch (objfile), pc));
395 psymtab_to_symtab (objfile, ps);
396 return ps->compunit_symtab;
397 }
398 return NULL;
399 }
400
401 /* Find which partial symbol within a psymtab matches PC and SECTION.
402 Return NULL if none. */
403
404 static struct partial_symbol *
405 find_pc_sect_psymbol (struct objfile *objfile,
406 struct partial_symtab *psymtab, CORE_ADDR pc,
407 struct obj_section *section)
408 {
409 struct partial_symbol *best = NULL;
410 CORE_ADDR best_pc;
411 const CORE_ADDR textlow = psymtab->text_low (objfile);
412
413 gdb_assert (psymtab != NULL);
414
415 /* Cope with programs that start at address 0. */
416 best_pc = (textlow != 0) ? textlow - 1 : 0;
417
418 /* Search the global symbols as well as the static symbols, so that
419 find_pc_partial_function doesn't use a minimal symbol and thus
420 cache a bad endaddr. */
421 for (int i = 0; i < psymtab->n_global_syms; i++)
422 {
423 partial_symbol *p
424 = objfile->partial_symtabs->global_psymbols[psymtab->globals_offset
425 + i];
426
427 if (p->domain == VAR_DOMAIN
428 && p->aclass == LOC_BLOCK
429 && pc >= p->address (objfile)
430 && (p->address (objfile) > best_pc
431 || (psymtab->text_low (objfile) == 0
432 && best_pc == 0 && p->address (objfile) == 0)))
433 {
434 if (section != NULL) /* Match on a specific section. */
435 {
436 if (!matching_obj_sections (p->obj_section (objfile),
437 section))
438 continue;
439 }
440 best_pc = p->address (objfile);
441 best = p;
442 }
443 }
444
445 for (int i = 0; i < psymtab->n_static_syms; i++)
446 {
447 partial_symbol *p
448 = objfile->partial_symtabs->static_psymbols[psymtab->statics_offset
449 + i];
450
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 (objfile) == 0
456 && best_pc == 0 && p->address (objfile) == 0)))
457 {
458 if (section != NULL) /* Match on a specific section. */
459 {
460 if (!matching_obj_sections (p->obj_section (objfile),
461 section))
462 continue;
463 }
464 best_pc = p->address (objfile);
465 best = p;
466 }
467 }
468
469 return best;
470 }
471
472 /* Psymtab version of lookup_symbol. See its definition in
473 the definition of quick_symbol_functions in symfile.h. */
474
475 static struct compunit_symtab *
476 psym_lookup_symbol (struct objfile *objfile,
477 block_enum block_index, const char *name,
478 const domain_enum domain)
479 {
480 const int psymtab_index = (block_index == GLOBAL_BLOCK ? 1 : 0);
481 struct compunit_symtab *stab_best = NULL;
482
483 lookup_name_info lookup_name (name, symbol_name_match_type::FULL);
484
485 for (partial_symtab *ps : require_partial_symbols (objfile, true))
486 {
487 if (!ps->readin && lookup_partial_symbol (objfile, ps, name,
488 psymtab_index, domain))
489 {
490 struct symbol *sym, *with_opaque = NULL;
491 struct compunit_symtab *stab = psymtab_to_symtab (objfile, ps);
492 /* Note: While psymtab_to_symtab can return NULL if the
493 partial symtab is empty, we can assume it won't here
494 because lookup_partial_symbol succeeded. */
495 const struct blockvector *bv = COMPUNIT_BLOCKVECTOR (stab);
496 const struct block *block = BLOCKVECTOR_BLOCK (bv, block_index);
497
498 sym = block_find_symbol (block, name, domain,
499 block_find_non_opaque_type_preferred,
500 &with_opaque);
501
502 /* Some caution must be observed with overloaded functions
503 and methods, since the index will not contain any overload
504 information (but NAME might contain it). */
505
506 if (sym != NULL
507 && SYMBOL_MATCHES_SEARCH_NAME (sym, lookup_name))
508 return stab;
509 if (with_opaque != NULL
510 && SYMBOL_MATCHES_SEARCH_NAME (with_opaque, lookup_name))
511 stab_best = stab;
512
513 /* Keep looking through other psymtabs. */
514 }
515 }
516
517 return stab_best;
518 }
519
520 /* Returns true if PSYM matches LOOKUP_NAME. */
521
522 static bool
523 psymbol_name_matches (partial_symbol *psym,
524 const lookup_name_info &lookup_name)
525 {
526 const language_defn *lang = language_def (psym->ginfo.language ());
527 symbol_name_matcher_ftype *name_match
528 = get_symbol_name_matcher (lang, lookup_name);
529 return name_match (psym->ginfo.search_name (), lookup_name, NULL);
530 }
531
532 /* Look in PST for a symbol in DOMAIN whose name matches NAME. Search
533 the global block of PST if GLOBAL, and otherwise the static block.
534 MATCH is the comparison operation that returns true iff MATCH (s,
535 NAME), where s is a SYMBOL_SEARCH_NAME. If ORDERED_COMPARE is
536 non-null, the symbols in the block are assumed to be ordered
537 according to it (allowing binary search). It must be compatible
538 with MATCH. Returns the symbol, if found, and otherwise NULL. */
539
540 static struct partial_symbol *
541 match_partial_symbol (struct objfile *objfile,
542 struct partial_symtab *pst, int global,
543 const lookup_name_info &name, domain_enum domain,
544 symbol_compare_ftype *ordered_compare)
545 {
546 struct partial_symbol **start, **psym;
547 struct partial_symbol **top, **real_top, **bottom, **center;
548 int length = (global ? pst->n_global_syms : pst->n_static_syms);
549 int do_linear_search = 1;
550
551 if (length == 0)
552 return NULL;
553
554 start = (global ?
555 &objfile->partial_symtabs->global_psymbols[pst->globals_offset] :
556 &objfile->partial_symtabs->static_psymbols[pst->statics_offset]);
557
558 if (global && ordered_compare) /* Can use a binary search. */
559 {
560 do_linear_search = 0;
561
562 /* Binary search. This search is guaranteed to end with center
563 pointing at the earliest partial symbol whose name might be
564 correct. At that point *all* partial symbols with an
565 appropriate name will be checked against the correct
566 domain. */
567
568 bottom = start;
569 top = start + length - 1;
570 real_top = top;
571 while (top > bottom)
572 {
573 center = bottom + (top - bottom) / 2;
574 gdb_assert (center < top);
575
576 enum language lang = (*center)->ginfo.language ();
577 const char *lang_ln
578 = name.language_lookup_name (lang).c_str ();
579
580 if (ordered_compare ((*center)->ginfo.search_name (),
581 lang_ln) >= 0)
582 top = center;
583 else
584 bottom = center + 1;
585 }
586 gdb_assert (top == bottom);
587
588 while (top <= real_top
589 && psymbol_name_matches (*top, name))
590 {
591 if (symbol_matches_domain ((*top)->ginfo.language (),
592 (*top)->domain, domain))
593 return *top;
594 top++;
595 }
596 }
597
598 /* Can't use a binary search or else we found during the binary search that
599 we should also do a linear search. */
600
601 if (do_linear_search)
602 {
603 for (psym = start; psym < start + length; psym++)
604 {
605 if (symbol_matches_domain ((*psym)->ginfo.language (),
606 (*psym)->domain, domain)
607 && psymbol_name_matches (*psym, name))
608 return *psym;
609 }
610 }
611
612 return NULL;
613 }
614
615 /* Returns the name used to search psymtabs. Unlike symtabs, psymtabs do
616 not contain any method/function instance information (since this would
617 force reading type information while reading psymtabs). Therefore,
618 if NAME contains overload information, it must be stripped before searching
619 psymtabs. */
620
621 static gdb::unique_xmalloc_ptr<char>
622 psymtab_search_name (const char *name)
623 {
624 switch (current_language->la_language)
625 {
626 case language_cplus:
627 {
628 if (strchr (name, '('))
629 {
630 gdb::unique_xmalloc_ptr<char> ret = cp_remove_params (name);
631
632 if (ret)
633 return ret;
634 }
635 }
636 break;
637
638 default:
639 break;
640 }
641
642 return make_unique_xstrdup (name);
643 }
644
645 /* Look, in partial_symtab PST, for symbol whose natural name is NAME.
646 Check the global symbols if GLOBAL, the static symbols if not. */
647
648 static struct partial_symbol *
649 lookup_partial_symbol (struct objfile *objfile,
650 struct partial_symtab *pst, const char *name,
651 int global, domain_enum domain)
652 {
653 struct partial_symbol **start, **psym;
654 struct partial_symbol **top, **real_top, **bottom, **center;
655 int length = (global ? pst->n_global_syms : pst->n_static_syms);
656 int do_linear_search = 1;
657
658 if (length == 0)
659 return NULL;
660
661 gdb::unique_xmalloc_ptr<char> search_name = psymtab_search_name (name);
662
663 lookup_name_info lookup_name (search_name.get (), symbol_name_match_type::FULL);
664
665 start = (global ?
666 &objfile->partial_symtabs->global_psymbols[pst->globals_offset] :
667 &objfile->partial_symtabs->static_psymbols[pst->statics_offset]);
668
669 if (global) /* This means we can use a binary search. */
670 {
671 do_linear_search = 0;
672
673 /* Binary search. This search is guaranteed to end with center
674 pointing at the earliest partial symbol whose name might be
675 correct. At that point *all* partial symbols with an
676 appropriate name will be checked against the correct
677 domain. */
678
679 bottom = start;
680 top = start + length - 1;
681 real_top = top;
682 while (top > bottom)
683 {
684 center = bottom + (top - bottom) / 2;
685 if (!(center < top))
686 internal_error (__FILE__, __LINE__,
687 _("failed internal consistency check"));
688 if (strcmp_iw_ordered ((*center)->ginfo.search_name (),
689 search_name.get ()) >= 0)
690 {
691 top = center;
692 }
693 else
694 {
695 bottom = center + 1;
696 }
697 }
698 if (!(top == bottom))
699 internal_error (__FILE__, __LINE__,
700 _("failed internal consistency check"));
701
702 /* For `case_sensitivity == case_sensitive_off' strcmp_iw_ordered will
703 search more exactly than what matches SYMBOL_MATCHES_SEARCH_NAME. */
704 while (top >= start && symbol_matches_search_name (&(*top)->ginfo,
705 lookup_name))
706 top--;
707
708 /* Fixup to have a symbol which matches SYMBOL_MATCHES_SEARCH_NAME. */
709 top++;
710
711 while (top <= real_top && symbol_matches_search_name (&(*top)->ginfo,
712 lookup_name))
713 {
714 if (symbol_matches_domain ((*top)->ginfo.language (),
715 (*top)->domain, domain))
716 return *top;
717 top++;
718 }
719 }
720
721 /* Can't use a binary search or else we found during the binary search that
722 we should also do a linear search. */
723
724 if (do_linear_search)
725 {
726 for (psym = start; psym < start + length; psym++)
727 {
728 if (symbol_matches_domain ((*psym)->ginfo.language (),
729 (*psym)->domain, domain)
730 && symbol_matches_search_name (&(*psym)->ginfo, lookup_name))
731 return *psym;
732 }
733 }
734
735 return NULL;
736 }
737
738 /* Get the symbol table that corresponds to a partial_symtab.
739 This is fast after the first time you do it.
740 The result will be NULL if the primary symtab has no symbols,
741 which can happen. Otherwise the result is the primary symtab
742 that contains PST. */
743
744 static struct compunit_symtab *
745 psymtab_to_symtab (struct objfile *objfile, struct partial_symtab *pst)
746 {
747 /* If it is a shared psymtab, find an unshared psymtab that includes
748 it. Any such psymtab will do. */
749 while (pst->user != NULL)
750 pst = pst->user;
751
752 /* If it's been looked up before, return it. */
753 if (pst->compunit_symtab)
754 return pst->compunit_symtab;
755
756 /* If it has not yet been read in, read it. */
757 if (!pst->readin)
758 {
759 scoped_restore decrementer = increment_reading_symtab ();
760
761 (*pst->read_symtab) (pst, objfile);
762 }
763
764 return pst->compunit_symtab;
765 }
766
767 /* Psymtab version of find_last_source_symtab. See its definition in
768 the definition of quick_symbol_functions in symfile.h. */
769
770 static struct symtab *
771 psym_find_last_source_symtab (struct objfile *ofp)
772 {
773 struct partial_symtab *cs_pst = NULL;
774
775 for (partial_symtab *ps : require_partial_symbols (ofp, true))
776 {
777 const char *name = ps->filename;
778 int len = strlen (name);
779
780 if (!(len > 2 && (strcmp (&name[len - 2], ".h") == 0
781 || strcmp (name, "<<C++-namespaces>>") == 0)))
782 cs_pst = ps;
783 }
784
785 if (cs_pst)
786 {
787 if (cs_pst->readin)
788 {
789 internal_error (__FILE__, __LINE__,
790 _("select_source_symtab: "
791 "readin pst found and no symtabs."));
792 }
793 else
794 {
795 struct compunit_symtab *cust = psymtab_to_symtab (ofp, cs_pst);
796
797 if (cust == NULL)
798 return NULL;
799 return compunit_primary_filetab (cust);
800 }
801 }
802 return NULL;
803 }
804
805 /* Psymtab version of forget_cached_source_info. See its definition in
806 the definition of quick_symbol_functions in symfile.h. */
807
808 static void
809 psym_forget_cached_source_info (struct objfile *objfile)
810 {
811 for (partial_symtab *pst : require_partial_symbols (objfile, true))
812 {
813 if (pst->fullname != NULL)
814 {
815 xfree (pst->fullname);
816 pst->fullname = NULL;
817 }
818 }
819 }
820
821 static void
822 print_partial_symbols (struct gdbarch *gdbarch, struct objfile *objfile,
823 struct partial_symbol **p, int count, const char *what,
824 struct ui_file *outfile)
825 {
826 fprintf_filtered (outfile, " %s partial symbols:\n", what);
827 while (count-- > 0)
828 {
829 QUIT;
830 fprintf_filtered (outfile, " `%s'", (*p)->ginfo.linkage_name ());
831 if ((*p)->ginfo.demangled_name () != NULL)
832 {
833 fprintf_filtered (outfile, " `%s'",
834 (*p)->ginfo.demangled_name ());
835 }
836 fputs_filtered (", ", outfile);
837 switch ((*p)->domain)
838 {
839 case UNDEF_DOMAIN:
840 fputs_filtered ("undefined domain, ", outfile);
841 break;
842 case VAR_DOMAIN:
843 /* This is the usual thing -- don't print it. */
844 break;
845 case STRUCT_DOMAIN:
846 fputs_filtered ("struct domain, ", outfile);
847 break;
848 case MODULE_DOMAIN:
849 fputs_filtered ("module domain, ", outfile);
850 break;
851 case LABEL_DOMAIN:
852 fputs_filtered ("label domain, ", outfile);
853 break;
854 case COMMON_BLOCK_DOMAIN:
855 fputs_filtered ("common block domain, ", outfile);
856 break;
857 default:
858 fputs_filtered ("<invalid domain>, ", outfile);
859 break;
860 }
861 switch ((*p)->aclass)
862 {
863 case LOC_UNDEF:
864 fputs_filtered ("undefined", outfile);
865 break;
866 case LOC_CONST:
867 fputs_filtered ("constant int", outfile);
868 break;
869 case LOC_STATIC:
870 fputs_filtered ("static", outfile);
871 break;
872 case LOC_REGISTER:
873 fputs_filtered ("register", outfile);
874 break;
875 case LOC_ARG:
876 fputs_filtered ("pass by value", outfile);
877 break;
878 case LOC_REF_ARG:
879 fputs_filtered ("pass by reference", outfile);
880 break;
881 case LOC_REGPARM_ADDR:
882 fputs_filtered ("register address parameter", outfile);
883 break;
884 case LOC_LOCAL:
885 fputs_filtered ("stack parameter", outfile);
886 break;
887 case LOC_TYPEDEF:
888 fputs_filtered ("type", outfile);
889 break;
890 case LOC_LABEL:
891 fputs_filtered ("label", outfile);
892 break;
893 case LOC_BLOCK:
894 fputs_filtered ("function", outfile);
895 break;
896 case LOC_CONST_BYTES:
897 fputs_filtered ("constant bytes", outfile);
898 break;
899 case LOC_UNRESOLVED:
900 fputs_filtered ("unresolved", outfile);
901 break;
902 case LOC_OPTIMIZED_OUT:
903 fputs_filtered ("optimized out", outfile);
904 break;
905 case LOC_COMPUTED:
906 fputs_filtered ("computed at runtime", outfile);
907 break;
908 default:
909 fputs_filtered ("<invalid location>", outfile);
910 break;
911 }
912 fputs_filtered (", ", outfile);
913 fputs_filtered (paddress (gdbarch, (*p)->unrelocated_address ()), outfile);
914 fprintf_filtered (outfile, "\n");
915 p++;
916 }
917 }
918
919 static void
920 dump_psymtab (struct objfile *objfile, struct partial_symtab *psymtab,
921 struct ui_file *outfile)
922 {
923 struct gdbarch *gdbarch = get_objfile_arch (objfile);
924 int i;
925
926 if (psymtab->anonymous)
927 {
928 fprintf_filtered (outfile, "\nAnonymous partial symtab (%s) ",
929 psymtab->filename);
930 }
931 else
932 {
933 fprintf_filtered (outfile, "\nPartial symtab for source file %s ",
934 psymtab->filename);
935 }
936 fprintf_filtered (outfile, "(object ");
937 gdb_print_host_address (psymtab, outfile);
938 fprintf_filtered (outfile, ")\n\n");
939 fprintf_filtered (outfile, " Read from object file %s (",
940 objfile_name (objfile));
941 gdb_print_host_address (objfile, outfile);
942 fprintf_filtered (outfile, ")\n");
943
944 if (psymtab->readin)
945 {
946 fprintf_filtered (outfile,
947 " Full symtab was read (at ");
948 gdb_print_host_address (psymtab->compunit_symtab, outfile);
949 fprintf_filtered (outfile, " by function at ");
950 gdb_print_host_address (psymtab->read_symtab, outfile);
951 fprintf_filtered (outfile, ")\n");
952 }
953
954 fprintf_filtered (outfile, " Symbols cover text addresses ");
955 fputs_filtered (paddress (gdbarch, psymtab->text_low (objfile)), outfile);
956 fprintf_filtered (outfile, "-");
957 fputs_filtered (paddress (gdbarch, psymtab->text_high (objfile)), outfile);
958 fprintf_filtered (outfile, "\n");
959 fprintf_filtered (outfile, " Address map supported - %s.\n",
960 psymtab->psymtabs_addrmap_supported ? "yes" : "no");
961 fprintf_filtered (outfile, " Depends on %d other partial symtabs.\n",
962 psymtab->number_of_dependencies);
963 for (i = 0; i < psymtab->number_of_dependencies; i++)
964 {
965 fprintf_filtered (outfile, " %d ", i);
966 gdb_print_host_address (psymtab->dependencies[i], outfile);
967 fprintf_filtered (outfile, " %s\n",
968 psymtab->dependencies[i]->filename);
969 }
970 if (psymtab->user != NULL)
971 {
972 fprintf_filtered (outfile, " Shared partial symtab with user ");
973 gdb_print_host_address (psymtab->user, outfile);
974 fprintf_filtered (outfile, "\n");
975 }
976 if (psymtab->n_global_syms > 0)
977 {
978 print_partial_symbols
979 (gdbarch, objfile,
980 &objfile->partial_symtabs->global_psymbols[psymtab->globals_offset],
981 psymtab->n_global_syms, "Global", outfile);
982 }
983 if (psymtab->n_static_syms > 0)
984 {
985 print_partial_symbols
986 (gdbarch, objfile,
987 &objfile->partial_symtabs->static_psymbols[psymtab->statics_offset],
988 psymtab->n_static_syms, "Static", outfile);
989 }
990 fprintf_filtered (outfile, "\n");
991 }
992
993 /* Psymtab version of print_stats. See its definition in
994 the definition of quick_symbol_functions in symfile.h. */
995
996 static void
997 psym_print_stats (struct objfile *objfile)
998 {
999 int i;
1000
1001 i = 0;
1002 for (partial_symtab *ps : require_partial_symbols (objfile, true))
1003 {
1004 if (!ps->readin)
1005 i++;
1006 }
1007 printf_filtered (_(" Number of psym tables (not yet expanded): %d\n"), i);
1008 }
1009
1010 /* Psymtab version of dump. See its definition in
1011 the definition of quick_symbol_functions in symfile.h. */
1012
1013 static void
1014 psym_dump (struct objfile *objfile)
1015 {
1016 struct partial_symtab *psymtab;
1017
1018 if (objfile->partial_symtabs->psymtabs)
1019 {
1020 printf_filtered ("Psymtabs:\n");
1021 for (psymtab = objfile->partial_symtabs->psymtabs;
1022 psymtab != NULL;
1023 psymtab = psymtab->next)
1024 {
1025 printf_filtered ("%s at ",
1026 psymtab->filename);
1027 gdb_print_host_address (psymtab, gdb_stdout);
1028 printf_filtered (", ");
1029 wrap_here (" ");
1030 }
1031 printf_filtered ("\n\n");
1032 }
1033 }
1034
1035 /* Psymtab version of expand_symtabs_for_function. See its definition in
1036 the definition of quick_symbol_functions in symfile.h. */
1037
1038 static void
1039 psym_expand_symtabs_for_function (struct objfile *objfile,
1040 const char *func_name)
1041 {
1042 for (partial_symtab *ps : require_partial_symbols (objfile, true))
1043 {
1044 if (ps->readin)
1045 continue;
1046
1047 if ((lookup_partial_symbol (objfile, ps, func_name, 1, VAR_DOMAIN)
1048 != NULL)
1049 || (lookup_partial_symbol (objfile, ps, func_name, 0, VAR_DOMAIN)
1050 != NULL))
1051 psymtab_to_symtab (objfile, ps);
1052 }
1053 }
1054
1055 /* Psymtab version of expand_all_symtabs. See its definition in
1056 the definition of quick_symbol_functions in symfile.h. */
1057
1058 static void
1059 psym_expand_all_symtabs (struct objfile *objfile)
1060 {
1061 for (partial_symtab *psymtab : require_partial_symbols (objfile, true))
1062 psymtab_to_symtab (objfile, psymtab);
1063 }
1064
1065 /* Psymtab version of expand_symtabs_with_fullname. See its definition in
1066 the definition of quick_symbol_functions in symfile.h. */
1067
1068 static void
1069 psym_expand_symtabs_with_fullname (struct objfile *objfile,
1070 const char *fullname)
1071 {
1072 for (partial_symtab *p : require_partial_symbols (objfile, true))
1073 {
1074 /* Anonymous psymtabs don't have a name of a source file. */
1075 if (p->anonymous)
1076 continue;
1077
1078 /* psymtab_to_fullname tries to open the file which is slow.
1079 Don't call it if we know the basenames don't match. */
1080 if ((basenames_may_differ
1081 || filename_cmp (lbasename (fullname), lbasename (p->filename)) == 0)
1082 && filename_cmp (fullname, psymtab_to_fullname (p)) == 0)
1083 psymtab_to_symtab (objfile, p);
1084 }
1085 }
1086
1087 /* Psymtab version of map_symbol_filenames. See its definition in
1088 the definition of quick_symbol_functions in symfile.h. */
1089
1090 static void
1091 psym_map_symbol_filenames (struct objfile *objfile,
1092 symbol_filename_ftype *fun, void *data,
1093 int need_fullname)
1094 {
1095 for (partial_symtab *ps : require_partial_symbols (objfile, true))
1096 {
1097 const char *fullname;
1098
1099 if (ps->readin)
1100 continue;
1101
1102 /* We can skip shared psymtabs here, because any file name will be
1103 attached to the unshared psymtab. */
1104 if (ps->user != NULL)
1105 continue;
1106
1107 /* Anonymous psymtabs don't have a file name. */
1108 if (ps->anonymous)
1109 continue;
1110
1111 QUIT;
1112 if (need_fullname)
1113 fullname = psymtab_to_fullname (ps);
1114 else
1115 fullname = NULL;
1116 (*fun) (ps->filename, fullname, data);
1117 }
1118 }
1119
1120 /* Finds the fullname that a partial_symtab represents.
1121
1122 If this functions finds the fullname, it will save it in ps->fullname
1123 and it will also return the value.
1124
1125 If this function fails to find the file that this partial_symtab represents,
1126 NULL will be returned and ps->fullname will be set to NULL. */
1127
1128 static const char *
1129 psymtab_to_fullname (struct partial_symtab *ps)
1130 {
1131 gdb_assert (!ps->anonymous);
1132
1133 /* Use cached copy if we have it.
1134 We rely on forget_cached_source_info being called appropriately
1135 to handle cases like the file being moved. */
1136 if (ps->fullname == NULL)
1137 {
1138 gdb::unique_xmalloc_ptr<char> fullname;
1139 scoped_fd fd = find_and_open_source (ps->filename, ps->dirname,
1140 &fullname);
1141 ps->fullname = fullname.release ();
1142
1143 if (fd.get () < 0)
1144 {
1145 /* rewrite_source_path would be applied by find_and_open_source, we
1146 should report the pathname where GDB tried to find the file. */
1147
1148 if (ps->dirname == NULL || IS_ABSOLUTE_PATH (ps->filename))
1149 fullname.reset (xstrdup (ps->filename));
1150 else
1151 fullname.reset (concat (ps->dirname, SLASH_STRING,
1152 ps->filename, (char *) NULL));
1153
1154 ps->fullname = rewrite_source_path (fullname.get ()).release ();
1155 if (ps->fullname == NULL)
1156 ps->fullname = fullname.release ();
1157 }
1158 }
1159
1160 return ps->fullname;
1161 }
1162
1163 /* Psymtab version of map_matching_symbols. See its definition in
1164 the definition of quick_symbol_functions in symfile.h. */
1165
1166 static void
1167 psym_map_matching_symbols
1168 (struct objfile *objfile,
1169 const lookup_name_info &name, domain_enum domain,
1170 int global,
1171 gdb::function_view<symbol_found_callback_ftype> callback,
1172 symbol_compare_ftype *ordered_compare)
1173 {
1174 const int block_kind = global ? GLOBAL_BLOCK : STATIC_BLOCK;
1175
1176 for (partial_symtab *ps : require_partial_symbols (objfile, true))
1177 {
1178 QUIT;
1179 if (ps->readin
1180 || match_partial_symbol (objfile, ps, global, name, domain,
1181 ordered_compare))
1182 {
1183 struct compunit_symtab *cust = psymtab_to_symtab (objfile, ps);
1184 const struct block *block;
1185
1186 if (cust == NULL)
1187 continue;
1188 block = BLOCKVECTOR_BLOCK (COMPUNIT_BLOCKVECTOR (cust), block_kind);
1189 if (!iterate_over_symbols_terminated (block, name,
1190 domain, callback))
1191 return;
1192 }
1193 }
1194 }
1195
1196 /* A helper for psym_expand_symtabs_matching that handles searching
1197 included psymtabs. This returns true if a symbol is found, and
1198 false otherwise. It also updates the 'searched_flag' on the
1199 various psymtabs that it searches. */
1200
1201 static bool
1202 recursively_search_psymtabs
1203 (struct partial_symtab *ps,
1204 struct objfile *objfile,
1205 enum search_domain domain,
1206 const lookup_name_info &lookup_name,
1207 gdb::function_view<expand_symtabs_symbol_matcher_ftype> sym_matcher)
1208 {
1209 int keep_going = 1;
1210 enum psymtab_search_status result = PST_SEARCHED_AND_NOT_FOUND;
1211 int i;
1212
1213 if (ps->searched_flag != PST_NOT_SEARCHED)
1214 return ps->searched_flag == PST_SEARCHED_AND_FOUND;
1215
1216 /* Recurse into shared psymtabs first, because they may have already
1217 been searched, and this could save some time. */
1218 for (i = 0; i < ps->number_of_dependencies; ++i)
1219 {
1220 int r;
1221
1222 /* Skip non-shared dependencies, these are handled elsewhere. */
1223 if (ps->dependencies[i]->user == NULL)
1224 continue;
1225
1226 r = recursively_search_psymtabs (ps->dependencies[i],
1227 objfile, domain, lookup_name,
1228 sym_matcher);
1229 if (r != 0)
1230 {
1231 ps->searched_flag = PST_SEARCHED_AND_FOUND;
1232 return true;
1233 }
1234 }
1235
1236 partial_symbol **gbound
1237 = (objfile->partial_symtabs->global_psymbols.data ()
1238 + ps->globals_offset + ps->n_global_syms);
1239 partial_symbol **sbound
1240 = (objfile->partial_symtabs->static_psymbols.data ()
1241 + ps->statics_offset + ps->n_static_syms);
1242 partial_symbol **bound = gbound;
1243
1244 /* Go through all of the symbols stored in a partial
1245 symtab in one loop. */
1246 partial_symbol **psym = (objfile->partial_symtabs->global_psymbols.data ()
1247 + ps->globals_offset);
1248 while (keep_going)
1249 {
1250 if (psym >= bound)
1251 {
1252 if (bound == gbound && ps->n_static_syms != 0)
1253 {
1254 psym = (objfile->partial_symtabs->static_psymbols.data ()
1255 + ps->statics_offset);
1256 bound = sbound;
1257 }
1258 else
1259 keep_going = 0;
1260 continue;
1261 }
1262 else
1263 {
1264 QUIT;
1265
1266 if ((domain == ALL_DOMAIN
1267 || (domain == MODULES_DOMAIN
1268 && (*psym)->domain == MODULE_DOMAIN)
1269 || (domain == VARIABLES_DOMAIN
1270 && (*psym)->aclass != LOC_TYPEDEF
1271 && (*psym)->aclass != LOC_BLOCK)
1272 || (domain == FUNCTIONS_DOMAIN
1273 && (*psym)->aclass == LOC_BLOCK)
1274 || (domain == TYPES_DOMAIN
1275 && (*psym)->aclass == LOC_TYPEDEF))
1276 && psymbol_name_matches (*psym, lookup_name)
1277 && (sym_matcher == NULL
1278 || sym_matcher ((*psym)->ginfo.search_name ())))
1279 {
1280 /* Found a match, so notify our caller. */
1281 result = PST_SEARCHED_AND_FOUND;
1282 keep_going = 0;
1283 }
1284 }
1285 psym++;
1286 }
1287
1288 ps->searched_flag = result;
1289 return result == PST_SEARCHED_AND_FOUND;
1290 }
1291
1292 /* Psymtab version of expand_symtabs_matching. See its definition in
1293 the definition of quick_symbol_functions in symfile.h. */
1294
1295 static void
1296 psym_expand_symtabs_matching
1297 (struct objfile *objfile,
1298 gdb::function_view<expand_symtabs_file_matcher_ftype> file_matcher,
1299 const lookup_name_info &lookup_name_in,
1300 gdb::function_view<expand_symtabs_symbol_matcher_ftype> symbol_matcher,
1301 gdb::function_view<expand_symtabs_exp_notify_ftype> expansion_notify,
1302 enum search_domain domain)
1303 {
1304 lookup_name_info lookup_name = lookup_name_in.make_ignore_params ();
1305
1306 /* Clear the search flags. */
1307 for (partial_symtab *ps : require_partial_symbols (objfile, true))
1308 ps->searched_flag = PST_NOT_SEARCHED;
1309
1310 for (partial_symtab *ps : objfile->psymtabs ())
1311 {
1312 QUIT;
1313
1314 if (ps->readin)
1315 continue;
1316
1317 /* We skip shared psymtabs because file-matching doesn't apply
1318 to them; but we search them later in the loop. */
1319 if (ps->user != NULL)
1320 continue;
1321
1322 if (file_matcher)
1323 {
1324 bool match;
1325
1326 if (ps->anonymous)
1327 continue;
1328
1329 match = file_matcher (ps->filename, false);
1330 if (!match)
1331 {
1332 /* Before we invoke realpath, which can get expensive when many
1333 files are involved, do a quick comparison of the basenames. */
1334 if (basenames_may_differ
1335 || file_matcher (lbasename (ps->filename), true))
1336 match = file_matcher (psymtab_to_fullname (ps), false);
1337 }
1338 if (!match)
1339 continue;
1340 }
1341
1342 if (recursively_search_psymtabs (ps, objfile, domain,
1343 lookup_name, symbol_matcher))
1344 {
1345 struct compunit_symtab *symtab =
1346 psymtab_to_symtab (objfile, ps);
1347
1348 if (expansion_notify != NULL)
1349 expansion_notify (symtab);
1350 }
1351 }
1352 }
1353
1354 /* Psymtab version of has_symbols. See its definition in
1355 the definition of quick_symbol_functions in symfile.h. */
1356
1357 static int
1358 psym_has_symbols (struct objfile *objfile)
1359 {
1360 return objfile->partial_symtabs->psymtabs != NULL;
1361 }
1362
1363 /* Helper function for psym_find_compunit_symtab_by_address that fills
1364 in psymbol_map for a given range of psymbols. */
1365
1366 static void
1367 psym_fill_psymbol_map (struct objfile *objfile,
1368 struct partial_symtab *psymtab,
1369 std::set<CORE_ADDR> *seen_addrs,
1370 const std::vector<partial_symbol *> &symbols,
1371 int start,
1372 int length)
1373 {
1374 for (int i = 0; i < length; ++i)
1375 {
1376 struct partial_symbol *psym = symbols[start + i];
1377
1378 if (psym->aclass == LOC_STATIC)
1379 {
1380 CORE_ADDR addr = psym->address (objfile);
1381 if (seen_addrs->find (addr) == seen_addrs->end ())
1382 {
1383 seen_addrs->insert (addr);
1384 objfile->psymbol_map.emplace_back (addr, psymtab);
1385 }
1386 }
1387 }
1388 }
1389
1390 /* See find_compunit_symtab_by_address in quick_symbol_functions, in
1391 symfile.h. */
1392
1393 static compunit_symtab *
1394 psym_find_compunit_symtab_by_address (struct objfile *objfile,
1395 CORE_ADDR address)
1396 {
1397 if (objfile->psymbol_map.empty ())
1398 {
1399 std::set<CORE_ADDR> seen_addrs;
1400
1401 for (partial_symtab *pst : require_partial_symbols (objfile, true))
1402 {
1403 psym_fill_psymbol_map (objfile, pst,
1404 &seen_addrs,
1405 objfile->partial_symtabs->global_psymbols,
1406 pst->globals_offset,
1407 pst->n_global_syms);
1408 psym_fill_psymbol_map (objfile, pst,
1409 &seen_addrs,
1410 objfile->partial_symtabs->static_psymbols,
1411 pst->statics_offset,
1412 pst->n_static_syms);
1413 }
1414
1415 objfile->psymbol_map.shrink_to_fit ();
1416
1417 std::sort (objfile->psymbol_map.begin (), objfile->psymbol_map.end (),
1418 [] (const std::pair<CORE_ADDR, partial_symtab *> &a,
1419 const std::pair<CORE_ADDR, partial_symtab *> &b)
1420 {
1421 return a.first < b.first;
1422 });
1423 }
1424
1425 auto iter = std::lower_bound
1426 (objfile->psymbol_map.begin (), objfile->psymbol_map.end (), address,
1427 [] (const std::pair<CORE_ADDR, partial_symtab *> &a,
1428 CORE_ADDR b)
1429 {
1430 return a.first < b;
1431 });
1432
1433 if (iter == objfile->psymbol_map.end () || iter->first != address)
1434 return NULL;
1435
1436 return psymtab_to_symtab (objfile, iter->second);
1437 }
1438
1439 const struct quick_symbol_functions psym_functions =
1440 {
1441 psym_has_symbols,
1442 psym_find_last_source_symtab,
1443 psym_forget_cached_source_info,
1444 psym_map_symtabs_matching_filename,
1445 psym_lookup_symbol,
1446 psym_print_stats,
1447 psym_dump,
1448 psym_expand_symtabs_for_function,
1449 psym_expand_all_symtabs,
1450 psym_expand_symtabs_with_fullname,
1451 psym_map_matching_symbols,
1452 psym_expand_symtabs_matching,
1453 psym_find_pc_sect_compunit_symtab,
1454 psym_find_compunit_symtab_by_address,
1455 psym_map_symbol_filenames
1456 };
1457
1458 \f
1459
1460 static void
1461 sort_pst_symbols (struct objfile *objfile, struct partial_symtab *pst)
1462 {
1463 /* Sort the global list; don't sort the static list. */
1464 auto begin = objfile->partial_symtabs->global_psymbols.begin ();
1465 std::advance (begin, pst->globals_offset);
1466
1467 /* The psymbols for this partial_symtab are currently at the end of the
1468 vector. */
1469 auto end = objfile->partial_symtabs->global_psymbols.end ();
1470
1471 std::sort (begin, end, [] (partial_symbol *s1, partial_symbol *s2)
1472 {
1473 return strcmp_iw_ordered (s1->ginfo.search_name (),
1474 s2->ginfo.search_name ()) < 0;
1475 });
1476 }
1477
1478 /* Partially fill a partial symtab. It will be completely filled at
1479 the end of the symbol list. */
1480
1481 partial_symtab::partial_symtab (const char *filename,
1482 struct objfile *objfile,
1483 CORE_ADDR textlow)
1484 : partial_symtab (filename, objfile)
1485 {
1486 set_text_low (textlow);
1487 set_text_high (raw_text_low ()); /* default */
1488 globals_offset = objfile->partial_symtabs->global_psymbols.size ();
1489 statics_offset = objfile->partial_symtabs->static_psymbols.size ();
1490 }
1491
1492 /* Perform "finishing up" operations of a partial symtab. */
1493
1494 void
1495 end_psymtab_common (struct objfile *objfile, struct partial_symtab *pst)
1496 {
1497 pst->n_global_syms = (objfile->partial_symtabs->global_psymbols.size ()
1498 - pst->globals_offset);
1499 pst->n_static_syms = (objfile->partial_symtabs->static_psymbols.size ()
1500 - pst->statics_offset);
1501
1502 sort_pst_symbols (objfile, pst);
1503 }
1504
1505 /* Calculate a hash code for the given partial symbol. The hash is
1506 calculated using the symbol's value, language, domain, class
1507 and name. These are the values which are set by
1508 add_psymbol_to_bcache. */
1509
1510 static unsigned long
1511 psymbol_hash (const void *addr, int length)
1512 {
1513 unsigned long h = 0;
1514 struct partial_symbol *psymbol = (struct partial_symbol *) addr;
1515 unsigned int lang = psymbol->ginfo.language ();
1516 unsigned int domain = psymbol->domain;
1517 unsigned int theclass = psymbol->aclass;
1518
1519 h = fast_hash (&psymbol->ginfo.value, sizeof (psymbol->ginfo.value), h);
1520 h = fast_hash (&lang, sizeof (unsigned int), h);
1521 h = fast_hash (&domain, sizeof (unsigned int), h);
1522 h = fast_hash (&theclass, sizeof (unsigned int), h);
1523 /* Note that psymbol names are interned via compute_and_set_names, so
1524 there's no need to hash the contents of the name here. */
1525 h = fast_hash (&psymbol->ginfo.m_name, sizeof (psymbol->ginfo.m_name), h);
1526
1527 return h;
1528 }
1529
1530 /* Returns true if the symbol at addr1 equals the symbol at addr2.
1531 For the comparison this function uses a symbols value,
1532 language, domain, class and name. */
1533
1534 static int
1535 psymbol_compare (const void *addr1, const void *addr2, int length)
1536 {
1537 struct partial_symbol *sym1 = (struct partial_symbol *) addr1;
1538 struct partial_symbol *sym2 = (struct partial_symbol *) addr2;
1539
1540 return (memcmp (&sym1->ginfo.value, &sym2->ginfo.value,
1541 sizeof (sym1->ginfo.value)) == 0
1542 && sym1->ginfo.language () == sym2->ginfo.language ()
1543 && sym1->domain == sym2->domain
1544 && sym1->aclass == sym2->aclass
1545 /* Note that psymbol names are interned via
1546 compute_and_set_names, so there's no need to compare the
1547 contents of the name here. */
1548 && sym1->ginfo.linkage_name () == sym2->ginfo.linkage_name ());
1549 }
1550
1551 /* Helper function, initialises partial symbol structure and stashes
1552 it into objfile's bcache. Note that our caching mechanism will
1553 use all fields of struct partial_symbol to determine hash value of the
1554 structure. In other words, having two symbols with the same name but
1555 different domain (or address) is possible and correct. */
1556
1557 static struct partial_symbol *
1558 add_psymbol_to_bcache (gdb::string_view name, bool copy_name,
1559 domain_enum domain,
1560 enum address_class theclass,
1561 short section,
1562 CORE_ADDR coreaddr,
1563 enum language language, struct objfile *objfile,
1564 int *added)
1565 {
1566 struct partial_symbol psymbol;
1567 memset (&psymbol, 0, sizeof (psymbol));
1568
1569 psymbol.set_unrelocated_address (coreaddr);
1570 psymbol.ginfo.section = section;
1571 psymbol.domain = domain;
1572 psymbol.aclass = theclass;
1573 psymbol.ginfo.set_language (language, objfile->partial_symtabs->obstack ());
1574 psymbol.ginfo.compute_and_set_names (name, copy_name, objfile->per_bfd);
1575
1576 /* Stash the partial symbol away in the cache. */
1577 return ((struct partial_symbol *)
1578 objfile->partial_symtabs->psymbol_cache.insert
1579 (&psymbol, sizeof (struct partial_symbol), added));
1580 }
1581
1582 /* Helper function, adds partial symbol to the given partial symbol list. */
1583
1584 static void
1585 append_psymbol_to_list (std::vector<partial_symbol *> *list,
1586 struct partial_symbol *psym,
1587 struct objfile *objfile)
1588 {
1589 list->push_back (psym);
1590 OBJSTAT (objfile, n_psyms++);
1591 }
1592
1593 /* See psympriv.h. */
1594
1595 void
1596 add_psymbol_to_list (gdb::string_view name, bool copy_name,
1597 domain_enum domain,
1598 enum address_class theclass,
1599 short section,
1600 psymbol_placement where,
1601 CORE_ADDR coreaddr,
1602 enum language language, struct objfile *objfile)
1603 {
1604 struct partial_symbol *psym;
1605
1606 int added;
1607
1608 /* Stash the partial symbol away in the cache. */
1609 psym = add_psymbol_to_bcache (name, copy_name, domain, theclass,
1610 section, coreaddr, language, objfile, &added);
1611
1612 /* Do not duplicate global partial symbols. */
1613 if (where == psymbol_placement::GLOBAL && !added)
1614 return;
1615
1616 /* Save pointer to partial symbol in psymtab, growing symtab if needed. */
1617 std::vector<partial_symbol *> *list
1618 = (where == psymbol_placement::STATIC
1619 ? &objfile->partial_symtabs->static_psymbols
1620 : &objfile->partial_symtabs->global_psymbols);
1621 append_psymbol_to_list (list, psym, objfile);
1622 }
1623
1624 /* See psympriv.h. */
1625
1626 void
1627 init_psymbol_list (struct objfile *objfile, int total_symbols)
1628 {
1629 if (objfile->partial_symtabs->global_psymbols.capacity () == 0
1630 && objfile->partial_symtabs->static_psymbols.capacity () == 0)
1631 {
1632 /* Current best guess is that approximately a twentieth of the
1633 total symbols (in a debugging file) are global or static
1634 oriented symbols, then multiply that by slop factor of
1635 two. */
1636 objfile->partial_symtabs->global_psymbols.reserve (total_symbols / 10);
1637 objfile->partial_symtabs->static_psymbols.reserve (total_symbols / 10);
1638 }
1639 }
1640
1641 /* See psympriv.h. */
1642
1643 partial_symtab::partial_symtab (const char *filename_, struct objfile *objfile)
1644 : searched_flag (PST_NOT_SEARCHED),
1645 text_low_valid (0),
1646 text_high_valid (0)
1647 {
1648 objfile->partial_symtabs->install_psymtab (this);
1649
1650 filename
1651 = ((const char *) objfile->per_bfd->filename_cache.insert
1652 (filename_, strlen (filename_) + 1));
1653 compunit_symtab = NULL;
1654
1655 if (symtab_create_debug)
1656 {
1657 /* Be a bit clever with debugging messages, and don't print objfile
1658 every time, only when it changes. */
1659 static char *last_objfile_name = NULL;
1660
1661 if (last_objfile_name == NULL
1662 || strcmp (last_objfile_name, objfile_name (objfile)) != 0)
1663 {
1664 xfree (last_objfile_name);
1665 last_objfile_name = xstrdup (objfile_name (objfile));
1666 fprintf_filtered (gdb_stdlog,
1667 "Creating one or more psymtabs for objfile %s ...\n",
1668 last_objfile_name);
1669 }
1670 fprintf_filtered (gdb_stdlog,
1671 "Created psymtab %s for module %s.\n",
1672 host_address_to_string (this), filename);
1673 }
1674 }
1675
1676 void
1677 psymtab_storage::discard_psymtab (struct partial_symtab *pst)
1678 {
1679 struct partial_symtab **prev_pst;
1680
1681 /* From dbxread.c:
1682 Empty psymtabs happen as a result of header files which don't
1683 have any symbols in them. There can be a lot of them. But this
1684 check is wrong, in that a psymtab with N_SLINE entries but
1685 nothing else is not empty, but we don't realize that. Fixing
1686 that without slowing things down might be tricky. */
1687
1688 /* First, snip it out of the psymtab chain. */
1689
1690 prev_pst = &psymtabs;
1691 while ((*prev_pst) != pst)
1692 prev_pst = &((*prev_pst)->next);
1693 (*prev_pst) = pst->next;
1694 delete pst;
1695 }
1696
1697 \f
1698
1699 /* We need to pass a couple of items to the addrmap_foreach function,
1700 so use a struct. */
1701
1702 struct dump_psymtab_addrmap_data
1703 {
1704 struct objfile *objfile;
1705 struct partial_symtab *psymtab;
1706 struct ui_file *outfile;
1707
1708 /* Non-zero if the previously printed addrmap entry was for PSYMTAB.
1709 If so, we want to print the next one as well (since the next addrmap
1710 entry defines the end of the range). */
1711 int previous_matched;
1712 };
1713
1714 /* Helper function for dump_psymtab_addrmap to print an addrmap entry. */
1715
1716 static int
1717 dump_psymtab_addrmap_1 (void *datap, CORE_ADDR start_addr, void *obj)
1718 {
1719 struct dump_psymtab_addrmap_data *data
1720 = (struct dump_psymtab_addrmap_data *) datap;
1721 struct gdbarch *gdbarch = get_objfile_arch (data->objfile);
1722 struct partial_symtab *addrmap_psymtab = (struct partial_symtab *) obj;
1723 const char *psymtab_address_or_end = NULL;
1724
1725 QUIT;
1726
1727 if (data->psymtab == NULL
1728 || data->psymtab == addrmap_psymtab)
1729 psymtab_address_or_end = host_address_to_string (addrmap_psymtab);
1730 else if (data->previous_matched)
1731 psymtab_address_or_end = "<ends here>";
1732
1733 if (data->psymtab == NULL
1734 || data->psymtab == addrmap_psymtab
1735 || data->previous_matched)
1736 {
1737 fprintf_filtered (data->outfile, " %s%s %s\n",
1738 data->psymtab != NULL ? " " : "",
1739 paddress (gdbarch, start_addr),
1740 psymtab_address_or_end);
1741 }
1742
1743 data->previous_matched = (data->psymtab == NULL
1744 || data->psymtab == addrmap_psymtab);
1745
1746 return 0;
1747 }
1748
1749 /* Helper function for maintenance_print_psymbols to print the addrmap
1750 of PSYMTAB. If PSYMTAB is NULL print the entire addrmap. */
1751
1752 static void
1753 dump_psymtab_addrmap (struct objfile *objfile, struct partial_symtab *psymtab,
1754 struct ui_file *outfile)
1755 {
1756 struct dump_psymtab_addrmap_data addrmap_dump_data;
1757
1758 if ((psymtab == NULL
1759 || psymtab->psymtabs_addrmap_supported)
1760 && objfile->partial_symtabs->psymtabs_addrmap != NULL)
1761 {
1762 addrmap_dump_data.objfile = objfile;
1763 addrmap_dump_data.psymtab = psymtab;
1764 addrmap_dump_data.outfile = outfile;
1765 addrmap_dump_data.previous_matched = 0;
1766 fprintf_filtered (outfile, "%sddress map:\n",
1767 psymtab == NULL ? "Entire a" : " A");
1768 addrmap_foreach (objfile->partial_symtabs->psymtabs_addrmap,
1769 dump_psymtab_addrmap_1, &addrmap_dump_data);
1770 }
1771 }
1772
1773 static void
1774 maintenance_print_psymbols (const char *args, int from_tty)
1775 {
1776 struct ui_file *outfile = gdb_stdout;
1777 char *address_arg = NULL, *source_arg = NULL, *objfile_arg = NULL;
1778 int i, outfile_idx, found;
1779 CORE_ADDR pc = 0;
1780 struct obj_section *section = NULL;
1781
1782 dont_repeat ();
1783
1784 gdb_argv argv (args);
1785
1786 for (i = 0; argv != NULL && argv[i] != NULL; ++i)
1787 {
1788 if (strcmp (argv[i], "-pc") == 0)
1789 {
1790 if (argv[i + 1] == NULL)
1791 error (_("Missing pc value"));
1792 address_arg = argv[++i];
1793 }
1794 else if (strcmp (argv[i], "-source") == 0)
1795 {
1796 if (argv[i + 1] == NULL)
1797 error (_("Missing source file"));
1798 source_arg = argv[++i];
1799 }
1800 else if (strcmp (argv[i], "-objfile") == 0)
1801 {
1802 if (argv[i + 1] == NULL)
1803 error (_("Missing objfile name"));
1804 objfile_arg = argv[++i];
1805 }
1806 else if (strcmp (argv[i], "--") == 0)
1807 {
1808 /* End of options. */
1809 ++i;
1810 break;
1811 }
1812 else if (argv[i][0] == '-')
1813 {
1814 /* Future proofing: Don't allow OUTFILE to begin with "-". */
1815 error (_("Unknown option: %s"), argv[i]);
1816 }
1817 else
1818 break;
1819 }
1820 outfile_idx = i;
1821
1822 if (address_arg != NULL && source_arg != NULL)
1823 error (_("Must specify at most one of -pc and -source"));
1824
1825 stdio_file arg_outfile;
1826
1827 if (argv != NULL && argv[outfile_idx] != NULL)
1828 {
1829 if (argv[outfile_idx + 1] != NULL)
1830 error (_("Junk at end of command"));
1831 gdb::unique_xmalloc_ptr<char> outfile_name
1832 (tilde_expand (argv[outfile_idx]));
1833 if (!arg_outfile.open (outfile_name.get (), FOPEN_WT))
1834 perror_with_name (outfile_name.get ());
1835 outfile = &arg_outfile;
1836 }
1837
1838 if (address_arg != NULL)
1839 {
1840 pc = parse_and_eval_address (address_arg);
1841 /* If we fail to find a section, that's ok, try the lookup anyway. */
1842 section = find_pc_section (pc);
1843 }
1844
1845 found = 0;
1846 for (objfile *objfile : current_program_space->objfiles ())
1847 {
1848 int printed_objfile_header = 0;
1849 int print_for_objfile = 1;
1850
1851 QUIT;
1852 if (objfile_arg != NULL)
1853 print_for_objfile
1854 = compare_filenames_for_search (objfile_name (objfile),
1855 objfile_arg);
1856 if (!print_for_objfile)
1857 continue;
1858
1859 if (address_arg != NULL)
1860 {
1861 struct bound_minimal_symbol msymbol = { NULL, NULL };
1862
1863 /* We don't assume each pc has a unique objfile (this is for
1864 debugging). */
1865 struct partial_symtab *ps = find_pc_sect_psymtab (objfile, pc,
1866 section, msymbol);
1867 if (ps != NULL)
1868 {
1869 if (!printed_objfile_header)
1870 {
1871 outfile->printf ("\nPartial symtabs for objfile %s\n",
1872 objfile_name (objfile));
1873 printed_objfile_header = 1;
1874 }
1875 dump_psymtab (objfile, ps, outfile);
1876 dump_psymtab_addrmap (objfile, ps, outfile);
1877 found = 1;
1878 }
1879 }
1880 else
1881 {
1882 for (partial_symtab *ps : require_partial_symbols (objfile, true))
1883 {
1884 int print_for_source = 0;
1885
1886 QUIT;
1887 if (source_arg != NULL)
1888 {
1889 print_for_source
1890 = compare_filenames_for_search (ps->filename, source_arg);
1891 found = 1;
1892 }
1893 if (source_arg == NULL
1894 || print_for_source)
1895 {
1896 if (!printed_objfile_header)
1897 {
1898 outfile->printf ("\nPartial symtabs for objfile %s\n",
1899 objfile_name (objfile));
1900 printed_objfile_header = 1;
1901 }
1902 dump_psymtab (objfile, ps, outfile);
1903 dump_psymtab_addrmap (objfile, ps, outfile);
1904 }
1905 }
1906 }
1907
1908 /* If we're printing all the objfile's symbols dump the full addrmap. */
1909
1910 if (address_arg == NULL
1911 && source_arg == NULL
1912 && objfile->partial_symtabs->psymtabs_addrmap != NULL)
1913 {
1914 outfile->puts ("\n");
1915 dump_psymtab_addrmap (objfile, NULL, outfile);
1916 }
1917 }
1918
1919 if (!found)
1920 {
1921 if (address_arg != NULL)
1922 error (_("No partial symtab for address: %s"), address_arg);
1923 if (source_arg != NULL)
1924 error (_("No partial symtab for source file: %s"), source_arg);
1925 }
1926 }
1927
1928 /* List all the partial symbol tables whose names match REGEXP (optional). */
1929
1930 static void
1931 maintenance_info_psymtabs (const char *regexp, int from_tty)
1932 {
1933 struct program_space *pspace;
1934
1935 if (regexp)
1936 re_comp (regexp);
1937
1938 ALL_PSPACES (pspace)
1939 for (objfile *objfile : pspace->objfiles ())
1940 {
1941 struct gdbarch *gdbarch = get_objfile_arch (objfile);
1942
1943 /* We don't want to print anything for this objfile until we
1944 actually find a symtab whose name matches. */
1945 int printed_objfile_start = 0;
1946
1947 for (partial_symtab *psymtab : require_partial_symbols (objfile, true))
1948 {
1949 QUIT;
1950
1951 if (! regexp
1952 || re_exec (psymtab->filename))
1953 {
1954 if (! printed_objfile_start)
1955 {
1956 printf_filtered ("{ objfile %s ", objfile_name (objfile));
1957 wrap_here (" ");
1958 printf_filtered ("((struct objfile *) %s)\n",
1959 host_address_to_string (objfile));
1960 printed_objfile_start = 1;
1961 }
1962
1963 printf_filtered (" { psymtab %s ", psymtab->filename);
1964 wrap_here (" ");
1965 printf_filtered ("((struct partial_symtab *) %s)\n",
1966 host_address_to_string (psymtab));
1967
1968 printf_filtered (" readin %s\n",
1969 psymtab->readin ? "yes" : "no");
1970 printf_filtered (" fullname %s\n",
1971 psymtab->fullname
1972 ? psymtab->fullname : "(null)");
1973 printf_filtered (" text addresses ");
1974 fputs_filtered (paddress (gdbarch,
1975 psymtab->text_low (objfile)),
1976 gdb_stdout);
1977 printf_filtered (" -- ");
1978 fputs_filtered (paddress (gdbarch,
1979 psymtab->text_high (objfile)),
1980 gdb_stdout);
1981 printf_filtered ("\n");
1982 printf_filtered (" psymtabs_addrmap_supported %s\n",
1983 (psymtab->psymtabs_addrmap_supported
1984 ? "yes" : "no"));
1985 printf_filtered (" globals ");
1986 if (psymtab->n_global_syms)
1987 {
1988 auto p = &(objfile->partial_symtabs
1989 ->global_psymbols[psymtab->globals_offset]);
1990
1991 printf_filtered
1992 ("(* (struct partial_symbol **) %s @ %d)\n",
1993 host_address_to_string (p),
1994 psymtab->n_global_syms);
1995 }
1996 else
1997 printf_filtered ("(none)\n");
1998 printf_filtered (" statics ");
1999 if (psymtab->n_static_syms)
2000 {
2001 auto p = &(objfile->partial_symtabs
2002 ->static_psymbols[psymtab->statics_offset]);
2003
2004 printf_filtered
2005 ("(* (struct partial_symbol **) %s @ %d)\n",
2006 host_address_to_string (p),
2007 psymtab->n_static_syms);
2008 }
2009 else
2010 printf_filtered ("(none)\n");
2011 printf_filtered (" dependencies ");
2012 if (psymtab->number_of_dependencies)
2013 {
2014 int i;
2015
2016 printf_filtered ("{\n");
2017 for (i = 0; i < psymtab->number_of_dependencies; i++)
2018 {
2019 struct partial_symtab *dep = psymtab->dependencies[i];
2020
2021 /* Note the string concatenation there --- no
2022 comma. */
2023 printf_filtered (" psymtab %s "
2024 "((struct partial_symtab *) %s)\n",
2025 dep->filename,
2026 host_address_to_string (dep));
2027 }
2028 printf_filtered (" }\n");
2029 }
2030 else
2031 printf_filtered ("(none)\n");
2032 printf_filtered (" }\n");
2033 }
2034 }
2035
2036 if (printed_objfile_start)
2037 printf_filtered ("}\n");
2038 }
2039 }
2040
2041 /* Check consistency of currently expanded psymtabs vs symtabs. */
2042
2043 static void
2044 maintenance_check_psymtabs (const char *ignore, int from_tty)
2045 {
2046 struct symbol *sym;
2047 struct compunit_symtab *cust = NULL;
2048 const struct blockvector *bv;
2049 const struct block *b;
2050 int length;
2051
2052 for (objfile *objfile : current_program_space->objfiles ())
2053 for (partial_symtab *ps : require_partial_symbols (objfile, true))
2054 {
2055 struct gdbarch *gdbarch = get_objfile_arch (objfile);
2056
2057 /* We don't call psymtab_to_symtab here because that may cause symtab
2058 expansion. When debugging a problem it helps if checkers leave
2059 things unchanged. */
2060 cust = ps->compunit_symtab;
2061
2062 /* First do some checks that don't require the associated symtab. */
2063 if (ps->text_high (objfile) < ps->text_low (objfile))
2064 {
2065 printf_filtered ("Psymtab ");
2066 puts_filtered (ps->filename);
2067 printf_filtered (" covers bad range ");
2068 fputs_filtered (paddress (gdbarch, ps->text_low (objfile)),
2069 gdb_stdout);
2070 printf_filtered (" - ");
2071 fputs_filtered (paddress (gdbarch, ps->text_high (objfile)),
2072 gdb_stdout);
2073 printf_filtered ("\n");
2074 continue;
2075 }
2076
2077 /* Now do checks requiring the associated symtab. */
2078 if (cust == NULL)
2079 continue;
2080 bv = COMPUNIT_BLOCKVECTOR (cust);
2081 b = BLOCKVECTOR_BLOCK (bv, STATIC_BLOCK);
2082 partial_symbol **psym
2083 = &objfile->partial_symtabs->static_psymbols[ps->statics_offset];
2084 length = ps->n_static_syms;
2085 while (length--)
2086 {
2087 sym = block_lookup_symbol (b, (*psym)->ginfo.search_name (),
2088 symbol_name_match_type::SEARCH_NAME,
2089 (*psym)->domain);
2090 if (!sym)
2091 {
2092 printf_filtered ("Static symbol `");
2093 puts_filtered ((*psym)->ginfo.linkage_name ());
2094 printf_filtered ("' only found in ");
2095 puts_filtered (ps->filename);
2096 printf_filtered (" psymtab\n");
2097 }
2098 psym++;
2099 }
2100 b = BLOCKVECTOR_BLOCK (bv, GLOBAL_BLOCK);
2101 psym = &objfile->partial_symtabs->global_psymbols[ps->globals_offset];
2102 length = ps->n_global_syms;
2103 while (length--)
2104 {
2105 sym = block_lookup_symbol (b, (*psym)->ginfo.search_name (),
2106 symbol_name_match_type::SEARCH_NAME,
2107 (*psym)->domain);
2108 if (!sym)
2109 {
2110 printf_filtered ("Global symbol `");
2111 puts_filtered ((*psym)->ginfo.linkage_name ());
2112 printf_filtered ("' only found in ");
2113 puts_filtered (ps->filename);
2114 printf_filtered (" psymtab\n");
2115 }
2116 psym++;
2117 }
2118 if (ps->raw_text_high () != 0
2119 && (ps->text_low (objfile) < BLOCK_START (b)
2120 || ps->text_high (objfile) > BLOCK_END (b)))
2121 {
2122 printf_filtered ("Psymtab ");
2123 puts_filtered (ps->filename);
2124 printf_filtered (" covers ");
2125 fputs_filtered (paddress (gdbarch, ps->text_low (objfile)),
2126 gdb_stdout);
2127 printf_filtered (" - ");
2128 fputs_filtered (paddress (gdbarch, ps->text_high (objfile)),
2129 gdb_stdout);
2130 printf_filtered (" but symtab covers only ");
2131 fputs_filtered (paddress (gdbarch, BLOCK_START (b)), gdb_stdout);
2132 printf_filtered (" - ");
2133 fputs_filtered (paddress (gdbarch, BLOCK_END (b)), gdb_stdout);
2134 printf_filtered ("\n");
2135 }
2136 }
2137 }
2138
2139 void _initialize_psymtab ();
2140 void
2141 _initialize_psymtab ()
2142 {
2143 add_cmd ("psymbols", class_maintenance, maintenance_print_psymbols, _("\
2144 Print dump of current partial symbol definitions.\n\
2145 Usage: mt print psymbols [-objfile OBJFILE] [-pc ADDRESS] [--] [OUTFILE]\n\
2146 mt print psymbols [-objfile OBJFILE] [-source SOURCE] [--] [OUTFILE]\n\
2147 Entries in the partial symbol table are dumped to file OUTFILE,\n\
2148 or the terminal if OUTFILE is unspecified.\n\
2149 If ADDRESS is provided, dump only the file for that address.\n\
2150 If SOURCE is provided, dump only that file's symbols.\n\
2151 If OBJFILE is provided, dump only that file's minimal symbols."),
2152 &maintenanceprintlist);
2153
2154 add_cmd ("psymtabs", class_maintenance, maintenance_info_psymtabs, _("\
2155 List the partial symbol tables for all object files.\n\
2156 This does not include information about individual partial symbols,\n\
2157 just the symbol table structures themselves."),
2158 &maintenanceinfolist);
2159
2160 add_cmd ("check-psymtabs", class_maintenance, maintenance_check_psymtabs,
2161 _("\
2162 Check consistency of currently expanded psymtabs versus symtabs."),
2163 &maintenancelist);
2164 }
This page took 0.205368 seconds and 4 git commands to generate.