* c-valprint.c (print_function_pointer_address): Move...
[deliverable/binutils-gdb.git] / gdb / psymtab.c
1 /* Partial symbol tables.
2
3 Copyright (C) 2009-2012 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 "psympriv.h"
23 #include "objfiles.h"
24 #include "gdb_assert.h"
25 #include "block.h"
26 #include "filenames.h"
27 #include "source.h"
28 #include "addrmap.h"
29 #include "gdbtypes.h"
30 #include "bcache.h"
31 #include "ui-out.h"
32 #include "command.h"
33 #include "readline/readline.h"
34 #include "gdb_regex.h"
35 #include "dictionary.h"
36 #include "language.h"
37 #include "cp-support.h"
38
39 #ifndef DEV_TTY
40 #define DEV_TTY "/dev/tty"
41 #endif
42
43 struct psymbol_bcache
44 {
45 struct bcache *bcache;
46 };
47
48 /* A fast way to get from a psymtab to its symtab (after the first time). */
49 #define PSYMTAB_TO_SYMTAB(pst) \
50 ((pst) -> symtab != NULL ? (pst) -> symtab : psymtab_to_symtab (pst))
51
52 static struct partial_symbol *match_partial_symbol (struct partial_symtab *,
53 int,
54 const char *, domain_enum,
55 symbol_compare_ftype *,
56 symbol_compare_ftype *);
57
58 static struct partial_symbol *lookup_partial_symbol (struct partial_symtab *,
59 const char *, int,
60 domain_enum);
61
62 static char *psymtab_to_fullname (struct partial_symtab *ps);
63
64 static struct partial_symbol *find_pc_sect_psymbol (struct partial_symtab *,
65 CORE_ADDR,
66 struct obj_section *);
67
68 static struct partial_symbol *fixup_psymbol_section (struct partial_symbol
69 *psym,
70 struct objfile *objfile);
71
72 static struct symtab *psymtab_to_symtab (struct partial_symtab *pst);
73
74 /* Ensure that the partial symbols for OBJFILE have been loaded. This
75 function always returns its argument, as a convenience. */
76
77 struct objfile *
78 require_partial_symbols (struct objfile *objfile, int verbose)
79 {
80 if ((objfile->flags & OBJF_PSYMTABS_READ) == 0)
81 {
82 objfile->flags |= OBJF_PSYMTABS_READ;
83
84 if (objfile->sf->sym_read_psymbols)
85 {
86 if (verbose)
87 {
88 printf_unfiltered (_("Reading symbols from %s..."),
89 objfile->name);
90 gdb_flush (gdb_stdout);
91 }
92 (*objfile->sf->sym_read_psymbols) (objfile);
93 if (verbose)
94 {
95 if (!objfile_has_symbols (objfile))
96 {
97 wrap_here ("");
98 printf_unfiltered (_("(no debugging symbols found)..."));
99 wrap_here ("");
100 }
101
102 printf_unfiltered (_("done.\n"));
103 }
104 }
105 }
106
107 return objfile;
108 }
109
110 /* Traverse all psymtabs in one objfile, requiring that the psymtabs
111 be read in. */
112
113 #define ALL_OBJFILE_PSYMTABS_REQUIRED(objfile, p) \
114 for ((p) = require_partial_symbols (objfile, 1)->psymtabs; \
115 (p) != NULL; \
116 (p) = (p)->next)
117
118 /* We want to make sure this file always requires psymtabs. */
119
120 #undef ALL_OBJFILE_PSYMTABS
121
122 /* Traverse all psymtabs in all objfiles. */
123
124 #define ALL_PSYMTABS(objfile, p) \
125 ALL_OBJFILES (objfile) \
126 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, p)
127
128 /* Helper function for partial_map_symtabs_matching_filename that
129 expands the symtabs and calls the iterator. */
130
131 static int
132 partial_map_expand_apply (struct objfile *objfile,
133 const char *name,
134 const char *full_path,
135 const char *real_path,
136 struct partial_symtab *pst,
137 int (*callback) (struct symtab *, void *),
138 void *data)
139 {
140 struct symtab *last_made = objfile->symtabs;
141
142 /* Don't visit already-expanded psymtabs. */
143 if (pst->readin)
144 return 0;
145
146 /* This may expand more than one symtab, and we want to iterate over
147 all of them. */
148 psymtab_to_symtab (pst);
149
150 return iterate_over_some_symtabs (name, full_path, real_path, callback, data,
151 objfile->symtabs, last_made);
152 }
153
154 /* Implementation of the map_symtabs_matching_filename method. */
155
156 static int
157 partial_map_symtabs_matching_filename (struct objfile *objfile,
158 const char *name,
159 const char *full_path,
160 const char *real_path,
161 int (*callback) (struct symtab *,
162 void *),
163 void *data)
164 {
165 struct partial_symtab *pst;
166 const char *name_basename = lbasename (name);
167 int name_len = strlen (name);
168 int is_abs = IS_ABSOLUTE_PATH (name);
169
170 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
171 {
172 if (FILENAME_CMP (name, pst->filename) == 0
173 || (!is_abs && compare_filenames_for_search (pst->filename,
174 name, name_len)))
175 {
176 if (partial_map_expand_apply (objfile, name, full_path, real_path,
177 pst, callback, data))
178 return 1;
179 }
180
181 /* Before we invoke realpath, which can get expensive when many
182 files are involved, do a quick comparison of the basenames. */
183 if (! basenames_may_differ
184 && FILENAME_CMP (name_basename, lbasename (pst->filename)) != 0)
185 continue;
186
187 /* If the user gave us an absolute path, try to find the file in
188 this symtab and use its absolute path. */
189 if (full_path != NULL)
190 {
191 psymtab_to_fullname (pst);
192 if (pst->fullname != NULL
193 && (FILENAME_CMP (full_path, pst->fullname) == 0
194 || (!is_abs && compare_filenames_for_search (pst->fullname,
195 name, name_len))))
196 {
197 if (partial_map_expand_apply (objfile, name, full_path, real_path,
198 pst, callback, data))
199 return 1;
200 }
201 }
202
203 if (real_path != NULL)
204 {
205 char *rp = NULL;
206 psymtab_to_fullname (pst);
207 if (pst->fullname != NULL)
208 {
209 rp = gdb_realpath (pst->fullname);
210 make_cleanup (xfree, rp);
211 }
212 if (rp != NULL
213 && (FILENAME_CMP (real_path, rp) == 0
214 || (!is_abs && compare_filenames_for_search (real_path,
215 name, name_len))))
216 {
217 if (partial_map_expand_apply (objfile, name, full_path, real_path,
218 pst, callback, data))
219 return 1;
220 }
221 }
222 }
223
224 return 0;
225 }
226
227 /* Find which partial symtab contains PC and SECTION starting at psymtab PST.
228 We may find a different psymtab than PST. See FIND_PC_SECT_PSYMTAB. */
229
230 static struct partial_symtab *
231 find_pc_sect_psymtab_closer (CORE_ADDR pc, struct obj_section *section,
232 struct partial_symtab *pst,
233 struct minimal_symbol *msymbol)
234 {
235 struct objfile *objfile = pst->objfile;
236 struct partial_symtab *tpst;
237 struct partial_symtab *best_pst = pst;
238 CORE_ADDR best_addr = pst->textlow;
239
240 gdb_assert (!pst->psymtabs_addrmap_supported);
241
242 /* An objfile that has its functions reordered might have
243 many partial symbol tables containing the PC, but
244 we want the partial symbol table that contains the
245 function containing the PC. */
246 if (!(objfile->flags & OBJF_REORDERED) &&
247 section == 0) /* Can't validate section this way. */
248 return pst;
249
250 if (msymbol == NULL)
251 return (pst);
252
253 /* The code range of partial symtabs sometimes overlap, so, in
254 the loop below, we need to check all partial symtabs and
255 find the one that fits better for the given PC address. We
256 select the partial symtab that contains a symbol whose
257 address is closest to the PC address. By closest we mean
258 that find_pc_sect_symbol returns the symbol with address
259 that is closest and still less than the given PC. */
260 for (tpst = pst; tpst != NULL; tpst = tpst->next)
261 {
262 if (pc >= tpst->textlow && pc < tpst->texthigh)
263 {
264 struct partial_symbol *p;
265 CORE_ADDR this_addr;
266
267 /* NOTE: This assumes that every psymbol has a
268 corresponding msymbol, which is not necessarily
269 true; the debug info might be much richer than the
270 object's symbol table. */
271 p = find_pc_sect_psymbol (tpst, pc, section);
272 if (p != NULL
273 && SYMBOL_VALUE_ADDRESS (p)
274 == SYMBOL_VALUE_ADDRESS (msymbol))
275 return tpst;
276
277 /* Also accept the textlow value of a psymtab as a
278 "symbol", to provide some support for partial
279 symbol tables with line information but no debug
280 symbols (e.g. those produced by an assembler). */
281 if (p != NULL)
282 this_addr = SYMBOL_VALUE_ADDRESS (p);
283 else
284 this_addr = tpst->textlow;
285
286 /* Check whether it is closer than our current
287 BEST_ADDR. Since this symbol address is
288 necessarily lower or equal to PC, the symbol closer
289 to PC is the symbol which address is the highest.
290 This way we return the psymtab which contains such
291 best match symbol. This can help in cases where the
292 symbol information/debuginfo is not complete, like
293 for instance on IRIX6 with gcc, where no debug info
294 is emitted for statics. (See also the nodebug.exp
295 testcase.) */
296 if (this_addr > best_addr)
297 {
298 best_addr = this_addr;
299 best_pst = tpst;
300 }
301 }
302 }
303 return best_pst;
304 }
305
306 /* Find which partial symtab contains PC and SECTION. Return 0 if
307 none. We return the psymtab that contains a symbol whose address
308 exactly matches PC, or, if we cannot find an exact match, the
309 psymtab that contains a symbol whose address is closest to PC. */
310 static struct partial_symtab *
311 find_pc_sect_psymtab (struct objfile *objfile, CORE_ADDR pc,
312 struct obj_section *section,
313 struct minimal_symbol *msymbol)
314 {
315 struct partial_symtab *pst;
316
317 /* Try just the PSYMTABS_ADDRMAP mapping first as it has better granularity
318 than the later used TEXTLOW/TEXTHIGH one. */
319
320 if (objfile->psymtabs_addrmap != NULL)
321 {
322 pst = addrmap_find (objfile->psymtabs_addrmap, pc);
323 if (pst != NULL)
324 {
325 /* FIXME: addrmaps currently do not handle overlayed sections,
326 so fall back to the non-addrmap case if we're debugging
327 overlays and the addrmap returned the wrong section. */
328 if (overlay_debugging && msymbol && section)
329 {
330 struct partial_symbol *p;
331
332 /* NOTE: This assumes that every psymbol has a
333 corresponding msymbol, which is not necessarily
334 true; the debug info might be much richer than the
335 object's symbol table. */
336 p = find_pc_sect_psymbol (pst, pc, section);
337 if (!p
338 || SYMBOL_VALUE_ADDRESS (p)
339 != SYMBOL_VALUE_ADDRESS (msymbol))
340 goto next;
341 }
342
343 /* We do not try to call FIND_PC_SECT_PSYMTAB_CLOSER as
344 PSYMTABS_ADDRMAP we used has already the best 1-byte
345 granularity and FIND_PC_SECT_PSYMTAB_CLOSER may mislead us into
346 a worse chosen section due to the TEXTLOW/TEXTHIGH ranges
347 overlap. */
348
349 return pst;
350 }
351 }
352
353 next:
354
355 /* Existing PSYMTABS_ADDRMAP mapping is present even for PARTIAL_SYMTABs
356 which still have no corresponding full SYMTABs read. But it is not
357 present for non-DWARF2 debug infos not supporting PSYMTABS_ADDRMAP in GDB
358 so far. */
359
360 /* Check even OBJFILE with non-zero PSYMTABS_ADDRMAP as only several of
361 its CUs may be missing in PSYMTABS_ADDRMAP as they may be varying
362 debug info type in single OBJFILE. */
363
364 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
365 if (!pst->psymtabs_addrmap_supported
366 && pc >= pst->textlow && pc < pst->texthigh)
367 {
368 struct partial_symtab *best_pst;
369
370 best_pst = find_pc_sect_psymtab_closer (pc, section, pst, msymbol);
371 if (best_pst != NULL)
372 return best_pst;
373 }
374
375 return NULL;
376 }
377
378 static struct symtab *
379 find_pc_sect_symtab_from_partial (struct objfile *objfile,
380 struct minimal_symbol *msymbol,
381 CORE_ADDR pc, 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)
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 (ps->objfile), pc));
395 return PSYMTAB_TO_SYMTAB (ps);
396 }
397 return NULL;
398 }
399
400 /* Find which partial symbol within a psymtab matches PC and SECTION.
401 Return 0 if none. */
402
403 static struct partial_symbol *
404 find_pc_sect_psymbol (struct partial_symtab *psymtab, CORE_ADDR pc,
405 struct obj_section *section)
406 {
407 struct partial_symbol *best = NULL, *p, **pp;
408 CORE_ADDR best_pc;
409
410 gdb_assert (psymtab != NULL);
411
412 /* Cope with programs that start at address 0. */
413 best_pc = (psymtab->textlow != 0) ? psymtab->textlow - 1 : 0;
414
415 /* Search the global symbols as well as the static symbols, so that
416 find_pc_partial_function doesn't use a minimal symbol and thus
417 cache a bad endaddr. */
418 for (pp = psymtab->objfile->global_psymbols.list + psymtab->globals_offset;
419 (pp - (psymtab->objfile->global_psymbols.list + psymtab->globals_offset)
420 < psymtab->n_global_syms);
421 pp++)
422 {
423 p = *pp;
424 if (SYMBOL_DOMAIN (p) == VAR_DOMAIN
425 && SYMBOL_CLASS (p) == LOC_BLOCK
426 && pc >= SYMBOL_VALUE_ADDRESS (p)
427 && (SYMBOL_VALUE_ADDRESS (p) > best_pc
428 || (psymtab->textlow == 0
429 && best_pc == 0 && SYMBOL_VALUE_ADDRESS (p) == 0)))
430 {
431 if (section) /* Match on a specific section. */
432 {
433 fixup_psymbol_section (p, psymtab->objfile);
434 if (!matching_obj_sections (SYMBOL_OBJ_SECTION (p), section))
435 continue;
436 }
437 best_pc = SYMBOL_VALUE_ADDRESS (p);
438 best = p;
439 }
440 }
441
442 for (pp = psymtab->objfile->static_psymbols.list + psymtab->statics_offset;
443 (pp - (psymtab->objfile->static_psymbols.list + psymtab->statics_offset)
444 < psymtab->n_static_syms);
445 pp++)
446 {
447 p = *pp;
448 if (SYMBOL_DOMAIN (p) == VAR_DOMAIN
449 && SYMBOL_CLASS (p) == LOC_BLOCK
450 && pc >= SYMBOL_VALUE_ADDRESS (p)
451 && (SYMBOL_VALUE_ADDRESS (p) > best_pc
452 || (psymtab->textlow == 0
453 && best_pc == 0 && SYMBOL_VALUE_ADDRESS (p) == 0)))
454 {
455 if (section) /* Match on a specific section. */
456 {
457 fixup_psymbol_section (p, psymtab->objfile);
458 if (!matching_obj_sections (SYMBOL_OBJ_SECTION (p), section))
459 continue;
460 }
461 best_pc = SYMBOL_VALUE_ADDRESS (p);
462 best = p;
463 }
464 }
465
466 return best;
467 }
468
469 static struct partial_symbol *
470 fixup_psymbol_section (struct partial_symbol *psym, struct objfile *objfile)
471 {
472 CORE_ADDR addr;
473
474 if (!psym)
475 return NULL;
476
477 if (SYMBOL_OBJ_SECTION (psym))
478 return psym;
479
480 gdb_assert (objfile);
481
482 switch (SYMBOL_CLASS (psym))
483 {
484 case LOC_STATIC:
485 case LOC_LABEL:
486 case LOC_BLOCK:
487 addr = SYMBOL_VALUE_ADDRESS (psym);
488 break;
489 default:
490 /* Nothing else will be listed in the minsyms -- no use looking
491 it up. */
492 return psym;
493 }
494
495 fixup_section (&psym->ginfo, addr, objfile);
496
497 return psym;
498 }
499
500 static struct symtab *
501 lookup_symbol_aux_psymtabs (struct objfile *objfile,
502 int block_index, const char *name,
503 const domain_enum domain)
504 {
505 struct partial_symtab *ps;
506 const int psymtab_index = (block_index == GLOBAL_BLOCK ? 1 : 0);
507
508 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
509 {
510 if (!ps->readin && lookup_partial_symbol (ps, name, psymtab_index, domain))
511 {
512 struct symbol *sym = NULL;
513 struct symtab *stab = PSYMTAB_TO_SYMTAB (ps);
514
515 /* Some caution must be observed with overloaded functions
516 and methods, since the psymtab will not contain any overload
517 information (but NAME might contain it). */
518 if (stab->primary)
519 {
520 struct blockvector *bv = BLOCKVECTOR (stab);
521 struct block *block = BLOCKVECTOR_BLOCK (bv, block_index);
522
523 sym = lookup_block_symbol (block, name, domain);
524 }
525
526 if (sym && strcmp_iw (SYMBOL_SEARCH_NAME (sym), name) == 0)
527 return stab;
528
529 /* Keep looking through other psymtabs. */
530 }
531 }
532
533 return NULL;
534 }
535
536 /* Look in PST for a symbol in DOMAIN whose name matches NAME. Search
537 the global block of PST if GLOBAL, and otherwise the static block.
538 MATCH is the comparison operation that returns true iff MATCH (s,
539 NAME), where s is a SYMBOL_SEARCH_NAME. If ORDERED_COMPARE is
540 non-null, the symbols in the block are assumed to be ordered
541 according to it (allowing binary search). It must be compatible
542 with MATCH. Returns the symbol, if found, and otherwise NULL. */
543
544 static struct partial_symbol *
545 match_partial_symbol (struct partial_symtab *pst, int global,
546 const char *name, domain_enum domain,
547 symbol_compare_ftype *match,
548 symbol_compare_ftype *ordered_compare)
549 {
550 struct partial_symbol **start, **psym;
551 struct partial_symbol **top, **real_top, **bottom, **center;
552 int length = (global ? pst->n_global_syms : pst->n_static_syms);
553 int do_linear_search = 1;
554
555 if (length == 0)
556 return NULL;
557 start = (global ?
558 pst->objfile->global_psymbols.list + pst->globals_offset :
559 pst->objfile->static_psymbols.list + pst->statics_offset);
560
561 if (global && ordered_compare) /* Can use a binary search. */
562 {
563 do_linear_search = 0;
564
565 /* Binary search. This search is guaranteed to end with center
566 pointing at the earliest partial symbol whose name might be
567 correct. At that point *all* partial symbols with an
568 appropriate name will be checked against the correct
569 domain. */
570
571 bottom = start;
572 top = start + length - 1;
573 real_top = top;
574 while (top > bottom)
575 {
576 center = bottom + (top - bottom) / 2;
577 gdb_assert (center < top);
578 if (!do_linear_search
579 && (SYMBOL_LANGUAGE (*center) == language_java))
580 do_linear_search = 1;
581 if (ordered_compare (SYMBOL_SEARCH_NAME (*center), name) >= 0)
582 top = center;
583 else
584 bottom = center + 1;
585 }
586 gdb_assert (top == bottom);
587
588 while (top <= real_top
589 && match (SYMBOL_SEARCH_NAME (*top), name) == 0)
590 {
591 if (symbol_matches_domain (SYMBOL_LANGUAGE (*top),
592 SYMBOL_DOMAIN (*top), 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 (SYMBOL_LANGUAGE (*psym),
606 SYMBOL_DOMAIN (*psym), domain)
607 && match (SYMBOL_SEARCH_NAME (*psym), name) == 0)
608 return *psym;
609 }
610 }
611
612 return NULL;
613 }
614
615 static void
616 pre_expand_symtabs_matching_psymtabs (struct objfile *objfile,
617 enum block_enum block_kind,
618 const char *name,
619 domain_enum domain)
620 {
621 /* Nothing. */
622 }
623
624 /* Returns the name used to search psymtabs. Unlike symtabs, psymtabs do
625 not contain any method/function instance information (since this would
626 force reading type information while reading psymtabs). Therefore,
627 if NAME contains overload information, it must be stripped before searching
628 psymtabs.
629
630 The caller is responsible for freeing the return result. */
631
632 static char *
633 psymtab_search_name (const char *name)
634 {
635 switch (current_language->la_language)
636 {
637 case language_cplus:
638 case language_java:
639 {
640 if (strchr (name, '('))
641 {
642 char *ret = cp_remove_params (name);
643
644 if (ret)
645 return ret;
646 }
647 }
648 break;
649
650 default:
651 break;
652 }
653
654 return xstrdup (name);
655 }
656
657 /* Look, in partial_symtab PST, for symbol whose natural name is NAME.
658 Check the global symbols if GLOBAL, the static symbols if not. */
659
660 static struct partial_symbol *
661 lookup_partial_symbol (struct partial_symtab *pst, const char *name,
662 int global, domain_enum domain)
663 {
664 struct partial_symbol **start, **psym;
665 struct partial_symbol **top, **real_top, **bottom, **center;
666 int length = (global ? pst->n_global_syms : pst->n_static_syms);
667 int do_linear_search = 1;
668 char *search_name;
669 struct cleanup *cleanup;
670
671 if (length == 0)
672 {
673 return (NULL);
674 }
675
676 search_name = psymtab_search_name (name);
677 cleanup = make_cleanup (xfree, search_name);
678 start = (global ?
679 pst->objfile->global_psymbols.list + pst->globals_offset :
680 pst->objfile->static_psymbols.list + pst->statics_offset);
681
682 if (global) /* This means we can use a binary search. */
683 {
684 do_linear_search = 0;
685
686 /* Binary search. This search is guaranteed to end with center
687 pointing at the earliest partial symbol whose name might be
688 correct. At that point *all* partial symbols with an
689 appropriate name will be checked against the correct
690 domain. */
691
692 bottom = start;
693 top = start + length - 1;
694 real_top = top;
695 while (top > bottom)
696 {
697 center = bottom + (top - bottom) / 2;
698 if (!(center < top))
699 internal_error (__FILE__, __LINE__,
700 _("failed internal consistency check"));
701 if (!do_linear_search
702 && SYMBOL_LANGUAGE (*center) == language_java)
703 {
704 do_linear_search = 1;
705 }
706 if (strcmp_iw_ordered (SYMBOL_SEARCH_NAME (*center),
707 search_name) >= 0)
708 {
709 top = center;
710 }
711 else
712 {
713 bottom = center + 1;
714 }
715 }
716 if (!(top == bottom))
717 internal_error (__FILE__, __LINE__,
718 _("failed internal consistency check"));
719
720 /* For `case_sensitivity == case_sensitive_off' strcmp_iw_ordered will
721 search more exactly than what matches SYMBOL_MATCHES_SEARCH_NAME. */
722 while (top >= start && SYMBOL_MATCHES_SEARCH_NAME (*top, search_name))
723 top--;
724
725 /* Fixup to have a symbol which matches SYMBOL_MATCHES_SEARCH_NAME. */
726 top++;
727
728 while (top <= real_top && SYMBOL_MATCHES_SEARCH_NAME (*top, search_name))
729 {
730 if (symbol_matches_domain (SYMBOL_LANGUAGE (*top),
731 SYMBOL_DOMAIN (*top), domain))
732 {
733 do_cleanups (cleanup);
734 return (*top);
735 }
736 top++;
737 }
738 }
739
740 /* Can't use a binary search or else we found during the binary search that
741 we should also do a linear search. */
742
743 if (do_linear_search)
744 {
745 for (psym = start; psym < start + length; psym++)
746 {
747 if (symbol_matches_domain (SYMBOL_LANGUAGE (*psym),
748 SYMBOL_DOMAIN (*psym), domain)
749 && SYMBOL_MATCHES_SEARCH_NAME (*psym, search_name))
750 {
751 do_cleanups (cleanup);
752 return (*psym);
753 }
754 }
755 }
756
757 do_cleanups (cleanup);
758 return (NULL);
759 }
760
761 /* Get the symbol table that corresponds to a partial_symtab.
762 This is fast after the first time you do it. In fact, there
763 is an even faster macro PSYMTAB_TO_SYMTAB that does the fast
764 case inline. */
765
766 static struct symtab *
767 psymtab_to_symtab (struct partial_symtab *pst)
768 {
769 /* If it's been looked up before, return it. */
770 if (pst->symtab)
771 return pst->symtab;
772
773 /* If it has not yet been read in, read it. */
774 if (!pst->readin)
775 {
776 struct cleanup *back_to = increment_reading_symtab ();
777
778 (*pst->read_symtab) (pst);
779 do_cleanups (back_to);
780 }
781
782 return pst->symtab;
783 }
784
785 static void
786 relocate_psymtabs (struct objfile *objfile,
787 struct section_offsets *new_offsets,
788 struct section_offsets *delta)
789 {
790 struct partial_symbol **psym;
791 struct partial_symtab *p;
792
793 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, p)
794 {
795 p->textlow += ANOFFSET (delta, SECT_OFF_TEXT (objfile));
796 p->texthigh += ANOFFSET (delta, SECT_OFF_TEXT (objfile));
797 }
798
799 for (psym = objfile->global_psymbols.list;
800 psym < objfile->global_psymbols.next;
801 psym++)
802 {
803 fixup_psymbol_section (*psym, objfile);
804 if (SYMBOL_SECTION (*psym) >= 0)
805 SYMBOL_VALUE_ADDRESS (*psym) += ANOFFSET (delta,
806 SYMBOL_SECTION (*psym));
807 }
808 for (psym = objfile->static_psymbols.list;
809 psym < objfile->static_psymbols.next;
810 psym++)
811 {
812 fixup_psymbol_section (*psym, objfile);
813 if (SYMBOL_SECTION (*psym) >= 0)
814 SYMBOL_VALUE_ADDRESS (*psym) += ANOFFSET (delta,
815 SYMBOL_SECTION (*psym));
816 }
817 }
818
819 static struct symtab *
820 find_last_source_symtab_from_partial (struct objfile *ofp)
821 {
822 struct partial_symtab *ps;
823 struct partial_symtab *cs_pst = 0;
824
825 ALL_OBJFILE_PSYMTABS_REQUIRED (ofp, ps)
826 {
827 const char *name = ps->filename;
828 int len = strlen (name);
829
830 if (!(len > 2 && (strcmp (&name[len - 2], ".h") == 0
831 || strcmp (name, "<<C++-namespaces>>") == 0)))
832 cs_pst = ps;
833 }
834
835 if (cs_pst)
836 {
837 if (cs_pst->readin)
838 {
839 internal_error (__FILE__, __LINE__,
840 _("select_source_symtab: "
841 "readin pst found and no symtabs."));
842 }
843 else
844 return PSYMTAB_TO_SYMTAB (cs_pst);
845 }
846 return NULL;
847 }
848
849 static void
850 forget_cached_source_info_partial (struct objfile *objfile)
851 {
852 struct partial_symtab *pst;
853
854 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
855 {
856 if (pst->fullname != NULL)
857 {
858 xfree (pst->fullname);
859 pst->fullname = NULL;
860 }
861 }
862 }
863
864 static void
865 print_partial_symbols (struct gdbarch *gdbarch,
866 struct partial_symbol **p, int count, char *what,
867 struct ui_file *outfile)
868 {
869 fprintf_filtered (outfile, " %s partial symbols:\n", what);
870 while (count-- > 0)
871 {
872 fprintf_filtered (outfile, " `%s'", SYMBOL_LINKAGE_NAME (*p));
873 if (SYMBOL_DEMANGLED_NAME (*p) != NULL)
874 {
875 fprintf_filtered (outfile, " `%s'", SYMBOL_DEMANGLED_NAME (*p));
876 }
877 fputs_filtered (", ", outfile);
878 switch (SYMBOL_DOMAIN (*p))
879 {
880 case UNDEF_DOMAIN:
881 fputs_filtered ("undefined domain, ", outfile);
882 break;
883 case VAR_DOMAIN:
884 /* This is the usual thing -- don't print it. */
885 break;
886 case STRUCT_DOMAIN:
887 fputs_filtered ("struct domain, ", outfile);
888 break;
889 case LABEL_DOMAIN:
890 fputs_filtered ("label domain, ", outfile);
891 break;
892 default:
893 fputs_filtered ("<invalid domain>, ", outfile);
894 break;
895 }
896 switch (SYMBOL_CLASS (*p))
897 {
898 case LOC_UNDEF:
899 fputs_filtered ("undefined", outfile);
900 break;
901 case LOC_CONST:
902 fputs_filtered ("constant int", outfile);
903 break;
904 case LOC_STATIC:
905 fputs_filtered ("static", outfile);
906 break;
907 case LOC_REGISTER:
908 fputs_filtered ("register", outfile);
909 break;
910 case LOC_ARG:
911 fputs_filtered ("pass by value", outfile);
912 break;
913 case LOC_REF_ARG:
914 fputs_filtered ("pass by reference", outfile);
915 break;
916 case LOC_REGPARM_ADDR:
917 fputs_filtered ("register address parameter", outfile);
918 break;
919 case LOC_LOCAL:
920 fputs_filtered ("stack parameter", outfile);
921 break;
922 case LOC_TYPEDEF:
923 fputs_filtered ("type", outfile);
924 break;
925 case LOC_LABEL:
926 fputs_filtered ("label", outfile);
927 break;
928 case LOC_BLOCK:
929 fputs_filtered ("function", outfile);
930 break;
931 case LOC_CONST_BYTES:
932 fputs_filtered ("constant bytes", outfile);
933 break;
934 case LOC_UNRESOLVED:
935 fputs_filtered ("unresolved", outfile);
936 break;
937 case LOC_OPTIMIZED_OUT:
938 fputs_filtered ("optimized out", outfile);
939 break;
940 case LOC_COMPUTED:
941 fputs_filtered ("computed at runtime", outfile);
942 break;
943 default:
944 fputs_filtered ("<invalid location>", outfile);
945 break;
946 }
947 fputs_filtered (", ", outfile);
948 fputs_filtered (paddress (gdbarch, SYMBOL_VALUE_ADDRESS (*p)), outfile);
949 fprintf_filtered (outfile, "\n");
950 p++;
951 }
952 }
953
954 static void
955 dump_psymtab (struct objfile *objfile, struct partial_symtab *psymtab,
956 struct ui_file *outfile)
957 {
958 struct gdbarch *gdbarch = get_objfile_arch (objfile);
959 int i;
960
961 fprintf_filtered (outfile, "\nPartial symtab for source file %s ",
962 psymtab->filename);
963 fprintf_filtered (outfile, "(object ");
964 gdb_print_host_address (psymtab, outfile);
965 fprintf_filtered (outfile, ")\n\n");
966 fprintf_unfiltered (outfile, " Read from object file %s (",
967 objfile->name);
968 gdb_print_host_address (objfile, outfile);
969 fprintf_unfiltered (outfile, ")\n");
970
971 if (psymtab->readin)
972 {
973 fprintf_filtered (outfile,
974 " Full symtab was read (at ");
975 gdb_print_host_address (psymtab->symtab, outfile);
976 fprintf_filtered (outfile, " by function at ");
977 gdb_print_host_address (psymtab->read_symtab, outfile);
978 fprintf_filtered (outfile, ")\n");
979 }
980
981 fprintf_filtered (outfile, " Relocate symbols by ");
982 for (i = 0; i < psymtab->objfile->num_sections; ++i)
983 {
984 if (i != 0)
985 fprintf_filtered (outfile, ", ");
986 wrap_here (" ");
987 fputs_filtered (paddress (gdbarch,
988 ANOFFSET (psymtab->section_offsets, i)),
989 outfile);
990 }
991 fprintf_filtered (outfile, "\n");
992
993 fprintf_filtered (outfile, " Symbols cover text addresses ");
994 fputs_filtered (paddress (gdbarch, psymtab->textlow), outfile);
995 fprintf_filtered (outfile, "-");
996 fputs_filtered (paddress (gdbarch, psymtab->texthigh), outfile);
997 fprintf_filtered (outfile, "\n");
998 fprintf_filtered (outfile, " Address map supported - %s.\n",
999 psymtab->psymtabs_addrmap_supported ? "yes" : "no");
1000 fprintf_filtered (outfile, " Depends on %d other partial symtabs.\n",
1001 psymtab->number_of_dependencies);
1002 for (i = 0; i < psymtab->number_of_dependencies; i++)
1003 {
1004 fprintf_filtered (outfile, " %d ", i);
1005 gdb_print_host_address (psymtab->dependencies[i], outfile);
1006 fprintf_filtered (outfile, " %s\n",
1007 psymtab->dependencies[i]->filename);
1008 }
1009 if (psymtab->n_global_syms > 0)
1010 {
1011 print_partial_symbols (gdbarch,
1012 objfile->global_psymbols.list
1013 + psymtab->globals_offset,
1014 psymtab->n_global_syms, "Global", outfile);
1015 }
1016 if (psymtab->n_static_syms > 0)
1017 {
1018 print_partial_symbols (gdbarch,
1019 objfile->static_psymbols.list
1020 + psymtab->statics_offset,
1021 psymtab->n_static_syms, "Static", outfile);
1022 }
1023 fprintf_filtered (outfile, "\n");
1024 }
1025
1026 static void
1027 print_psymtab_stats_for_objfile (struct objfile *objfile)
1028 {
1029 int i;
1030 struct partial_symtab *ps;
1031
1032 i = 0;
1033 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1034 {
1035 if (ps->readin == 0)
1036 i++;
1037 }
1038 printf_filtered (_(" Number of psym tables (not yet expanded): %d\n"), i);
1039 }
1040
1041 static void
1042 dump_psymtabs_for_objfile (struct objfile *objfile)
1043 {
1044 struct partial_symtab *psymtab;
1045
1046 if (objfile->psymtabs)
1047 {
1048 printf_filtered ("Psymtabs:\n");
1049 for (psymtab = objfile->psymtabs;
1050 psymtab != NULL;
1051 psymtab = psymtab->next)
1052 {
1053 printf_filtered ("%s at ",
1054 psymtab->filename);
1055 gdb_print_host_address (psymtab, gdb_stdout);
1056 printf_filtered (", ");
1057 if (psymtab->objfile != objfile)
1058 {
1059 printf_filtered ("NOT ON CHAIN! ");
1060 }
1061 wrap_here (" ");
1062 }
1063 printf_filtered ("\n\n");
1064 }
1065 }
1066
1067 /* Look through the partial symtabs for all symbols which begin
1068 by matching FUNC_NAME. Make sure we read that symbol table in. */
1069
1070 static void
1071 read_symtabs_for_function (struct objfile *objfile, const char *func_name)
1072 {
1073 struct partial_symtab *ps;
1074
1075 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1076 {
1077 if (ps->readin)
1078 continue;
1079
1080 if ((lookup_partial_symbol (ps, func_name, 1, VAR_DOMAIN)
1081 != NULL)
1082 || (lookup_partial_symbol (ps, func_name, 0, VAR_DOMAIN)
1083 != NULL))
1084 psymtab_to_symtab (ps);
1085 }
1086 }
1087
1088 static void
1089 expand_partial_symbol_tables (struct objfile *objfile)
1090 {
1091 struct partial_symtab *psymtab;
1092
1093 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, psymtab)
1094 {
1095 psymtab_to_symtab (psymtab);
1096 }
1097 }
1098
1099 static void
1100 read_psymtabs_with_filename (struct objfile *objfile, const char *filename)
1101 {
1102 struct partial_symtab *p;
1103
1104 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, p)
1105 {
1106 if (filename_cmp (filename, p->filename) == 0)
1107 PSYMTAB_TO_SYMTAB (p);
1108 }
1109 }
1110
1111 static void
1112 map_symbol_filenames_psymtab (struct objfile *objfile,
1113 symbol_filename_ftype *fun, void *data,
1114 int need_fullname)
1115 {
1116 struct partial_symtab *ps;
1117
1118 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1119 {
1120 const char *fullname;
1121
1122 if (ps->readin)
1123 continue;
1124
1125 QUIT;
1126 if (need_fullname)
1127 fullname = psymtab_to_fullname (ps);
1128 else
1129 fullname = NULL;
1130 (*fun) (ps->filename, fullname, data);
1131 }
1132 }
1133
1134 int find_and_open_source (const char *filename,
1135 const char *dirname,
1136 char **fullname);
1137
1138 /* Finds the fullname that a partial_symtab represents.
1139
1140 If this functions finds the fullname, it will save it in ps->fullname
1141 and it will also return the value.
1142
1143 If this function fails to find the file that this partial_symtab represents,
1144 NULL will be returned and ps->fullname will be set to NULL. */
1145
1146 static char *
1147 psymtab_to_fullname (struct partial_symtab *ps)
1148 {
1149 int r;
1150
1151 if (!ps)
1152 return NULL;
1153
1154 /* Use cached copy if we have it.
1155 We rely on forget_cached_source_info being called appropriately
1156 to handle cases like the file being moved. */
1157 if (ps->fullname)
1158 return ps->fullname;
1159
1160 r = find_and_open_source (ps->filename, ps->dirname, &ps->fullname);
1161
1162 if (r >= 0)
1163 {
1164 close (r);
1165 return ps->fullname;
1166 }
1167
1168 return NULL;
1169 }
1170
1171 static const char *
1172 find_symbol_file_from_partial (struct objfile *objfile, const char *name)
1173 {
1174 struct partial_symtab *pst;
1175
1176 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, pst)
1177 {
1178 if (lookup_partial_symbol (pst, name, 1, VAR_DOMAIN))
1179 return pst->filename;
1180 }
1181 return NULL;
1182 }
1183
1184 /* For all symbols, s, in BLOCK that are in NAMESPACE and match NAME
1185 according to the function MATCH, call CALLBACK(BLOCK, s, DATA).
1186 BLOCK is assumed to come from OBJFILE. Returns 1 iff CALLBACK
1187 ever returns non-zero, and otherwise returns 0. */
1188
1189 static int
1190 map_block (const char *name, domain_enum namespace, struct objfile *objfile,
1191 struct block *block,
1192 int (*callback) (struct block *, struct symbol *, void *),
1193 void *data, symbol_compare_ftype *match)
1194 {
1195 struct dict_iterator iter;
1196 struct symbol *sym;
1197
1198 for (sym = dict_iter_match_first (BLOCK_DICT (block), name, match, &iter);
1199 sym != NULL; sym = dict_iter_match_next (name, match, &iter))
1200 {
1201 if (symbol_matches_domain (SYMBOL_LANGUAGE (sym),
1202 SYMBOL_DOMAIN (sym), namespace))
1203 {
1204 if (callback (block, sym, data))
1205 return 1;
1206 }
1207 }
1208
1209 return 0;
1210 }
1211
1212 /* Psymtab version of map_matching_symbols. See its definition in
1213 the definition of quick_symbol_functions in symfile.h. */
1214
1215 static void
1216 map_matching_symbols_psymtab (const char *name, domain_enum namespace,
1217 struct objfile *objfile, int global,
1218 int (*callback) (struct block *,
1219 struct symbol *, void *),
1220 void *data,
1221 symbol_compare_ftype *match,
1222 symbol_compare_ftype *ordered_compare)
1223 {
1224 const int block_kind = global ? GLOBAL_BLOCK : STATIC_BLOCK;
1225 struct partial_symtab *ps;
1226
1227 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1228 {
1229 QUIT;
1230 if (ps->readin
1231 || match_partial_symbol (ps, global, name, namespace, match,
1232 ordered_compare))
1233 {
1234 struct symtab *s = PSYMTAB_TO_SYMTAB (ps);
1235 struct block *block;
1236
1237 if (s == NULL || !s->primary)
1238 continue;
1239 block = BLOCKVECTOR_BLOCK (BLOCKVECTOR (s), block_kind);
1240 if (map_block (name, namespace, objfile, block,
1241 callback, data, match))
1242 return;
1243 if (callback (block, NULL, data))
1244 return;
1245 }
1246 }
1247 }
1248
1249 static void
1250 expand_symtabs_matching_via_partial
1251 (struct objfile *objfile,
1252 int (*file_matcher) (const char *, void *),
1253 int (*name_matcher) (const char *, void *),
1254 enum search_domain kind,
1255 void *data)
1256 {
1257 struct partial_symtab *ps;
1258
1259 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, ps)
1260 {
1261 struct partial_symbol **psym;
1262 struct partial_symbol **bound, **gbound, **sbound;
1263 int keep_going = 1;
1264
1265 if (ps->readin)
1266 continue;
1267
1268 if (file_matcher && ! (*file_matcher) (ps->filename, data))
1269 continue;
1270
1271 gbound = objfile->global_psymbols.list
1272 + ps->globals_offset + ps->n_global_syms;
1273 sbound = objfile->static_psymbols.list
1274 + ps->statics_offset + ps->n_static_syms;
1275 bound = gbound;
1276
1277 /* Go through all of the symbols stored in a partial
1278 symtab in one loop. */
1279 psym = objfile->global_psymbols.list + ps->globals_offset;
1280 while (keep_going)
1281 {
1282 if (psym >= bound)
1283 {
1284 if (bound == gbound && ps->n_static_syms != 0)
1285 {
1286 psym = objfile->static_psymbols.list + ps->statics_offset;
1287 bound = sbound;
1288 }
1289 else
1290 keep_going = 0;
1291 continue;
1292 }
1293 else
1294 {
1295 QUIT;
1296
1297 if ((kind == ALL_DOMAIN
1298 || (kind == VARIABLES_DOMAIN
1299 && SYMBOL_CLASS (*psym) != LOC_TYPEDEF
1300 && SYMBOL_CLASS (*psym) != LOC_BLOCK)
1301 || (kind == FUNCTIONS_DOMAIN
1302 && SYMBOL_CLASS (*psym) == LOC_BLOCK)
1303 || (kind == TYPES_DOMAIN
1304 && SYMBOL_CLASS (*psym) == LOC_TYPEDEF))
1305 && (*name_matcher) (SYMBOL_SEARCH_NAME (*psym), data))
1306 {
1307 PSYMTAB_TO_SYMTAB (ps);
1308 keep_going = 0;
1309 }
1310 }
1311 psym++;
1312 }
1313 }
1314 }
1315
1316 static int
1317 objfile_has_psyms (struct objfile *objfile)
1318 {
1319 return objfile->psymtabs != NULL;
1320 }
1321
1322 const struct quick_symbol_functions psym_functions =
1323 {
1324 objfile_has_psyms,
1325 find_last_source_symtab_from_partial,
1326 forget_cached_source_info_partial,
1327 partial_map_symtabs_matching_filename,
1328 lookup_symbol_aux_psymtabs,
1329 pre_expand_symtabs_matching_psymtabs,
1330 print_psymtab_stats_for_objfile,
1331 dump_psymtabs_for_objfile,
1332 relocate_psymtabs,
1333 read_symtabs_for_function,
1334 expand_partial_symbol_tables,
1335 read_psymtabs_with_filename,
1336 find_symbol_file_from_partial,
1337 map_matching_symbols_psymtab,
1338 expand_symtabs_matching_via_partial,
1339 find_pc_sect_symtab_from_partial,
1340 map_symbol_filenames_psymtab
1341 };
1342
1343 \f
1344
1345 /* This compares two partial symbols by names, using strcmp_iw_ordered
1346 for the comparison. */
1347
1348 static int
1349 compare_psymbols (const void *s1p, const void *s2p)
1350 {
1351 struct partial_symbol *const *s1 = s1p;
1352 struct partial_symbol *const *s2 = s2p;
1353
1354 return strcmp_iw_ordered (SYMBOL_SEARCH_NAME (*s1),
1355 SYMBOL_SEARCH_NAME (*s2));
1356 }
1357
1358 void
1359 sort_pst_symbols (struct partial_symtab *pst)
1360 {
1361 /* Sort the global list; don't sort the static list. */
1362
1363 qsort (pst->objfile->global_psymbols.list + pst->globals_offset,
1364 pst->n_global_syms, sizeof (struct partial_symbol *),
1365 compare_psymbols);
1366 }
1367
1368 /* Allocate and partially fill a partial symtab. It will be
1369 completely filled at the end of the symbol list.
1370
1371 FILENAME is the name of the symbol-file we are reading from. */
1372
1373 struct partial_symtab *
1374 start_psymtab_common (struct objfile *objfile,
1375 struct section_offsets *section_offsets,
1376 const char *filename,
1377 CORE_ADDR textlow, struct partial_symbol **global_syms,
1378 struct partial_symbol **static_syms)
1379 {
1380 struct partial_symtab *psymtab;
1381
1382 psymtab = allocate_psymtab (filename, objfile);
1383 psymtab->section_offsets = section_offsets;
1384 psymtab->textlow = textlow;
1385 psymtab->texthigh = psymtab->textlow; /* default */
1386 psymtab->globals_offset = global_syms - objfile->global_psymbols.list;
1387 psymtab->statics_offset = static_syms - objfile->static_psymbols.list;
1388 return (psymtab);
1389 }
1390
1391 /* Calculate a hash code for the given partial symbol. The hash is
1392 calculated using the symbol's value, language, domain, class
1393 and name. These are the values which are set by
1394 add_psymbol_to_bcache. */
1395
1396 static unsigned long
1397 psymbol_hash (const void *addr, int length)
1398 {
1399 unsigned long h = 0;
1400 struct partial_symbol *psymbol = (struct partial_symbol *) addr;
1401 unsigned int lang = psymbol->ginfo.language;
1402 unsigned int domain = PSYMBOL_DOMAIN (psymbol);
1403 unsigned int class = PSYMBOL_CLASS (psymbol);
1404
1405 h = hash_continue (&psymbol->ginfo.value, sizeof (psymbol->ginfo.value), h);
1406 h = hash_continue (&lang, sizeof (unsigned int), h);
1407 h = hash_continue (&domain, sizeof (unsigned int), h);
1408 h = hash_continue (&class, sizeof (unsigned int), h);
1409 h = hash_continue (psymbol->ginfo.name, strlen (psymbol->ginfo.name), h);
1410
1411 return h;
1412 }
1413
1414 /* Returns true if the symbol at addr1 equals the symbol at addr2.
1415 For the comparison this function uses a symbols value,
1416 language, domain, class and name. */
1417
1418 static int
1419 psymbol_compare (const void *addr1, const void *addr2, int length)
1420 {
1421 struct partial_symbol *sym1 = (struct partial_symbol *) addr1;
1422 struct partial_symbol *sym2 = (struct partial_symbol *) addr2;
1423
1424 return (memcmp (&sym1->ginfo.value, &sym1->ginfo.value,
1425 sizeof (sym1->ginfo.value)) == 0
1426 && sym1->ginfo.language == sym2->ginfo.language
1427 && PSYMBOL_DOMAIN (sym1) == PSYMBOL_DOMAIN (sym2)
1428 && PSYMBOL_CLASS (sym1) == PSYMBOL_CLASS (sym2)
1429 && sym1->ginfo.name == sym2->ginfo.name);
1430 }
1431
1432 /* Initialize a partial symbol bcache. */
1433
1434 struct psymbol_bcache *
1435 psymbol_bcache_init (void)
1436 {
1437 struct psymbol_bcache *bcache = XCALLOC (1, struct psymbol_bcache);
1438 bcache->bcache = bcache_xmalloc (psymbol_hash, psymbol_compare);
1439 return bcache;
1440 }
1441
1442 /* Free a partial symbol bcache. */
1443 void
1444 psymbol_bcache_free (struct psymbol_bcache *bcache)
1445 {
1446 if (bcache == NULL)
1447 return;
1448
1449 bcache_xfree (bcache->bcache);
1450 xfree (bcache);
1451 }
1452
1453 /* Return the internal bcache of the psymbol_bcache BCACHE. */
1454
1455 struct bcache *
1456 psymbol_bcache_get_bcache (struct psymbol_bcache *bcache)
1457 {
1458 return bcache->bcache;
1459 }
1460
1461 /* Find a copy of the SYM in BCACHE. If BCACHE has never seen this
1462 symbol before, add a copy to BCACHE. In either case, return a pointer
1463 to BCACHE's copy of the symbol. If optional ADDED is not NULL, return
1464 1 in case of new entry or 0 if returning an old entry. */
1465
1466 static const struct partial_symbol *
1467 psymbol_bcache_full (struct partial_symbol *sym,
1468 struct psymbol_bcache *bcache,
1469 int *added)
1470 {
1471 return bcache_full (sym,
1472 sizeof (struct partial_symbol),
1473 bcache->bcache,
1474 added);
1475 }
1476
1477 /* Helper function, initialises partial symbol structure and stashes
1478 it into objfile's bcache. Note that our caching mechanism will
1479 use all fields of struct partial_symbol to determine hash value of the
1480 structure. In other words, having two symbols with the same name but
1481 different domain (or address) is possible and correct. */
1482
1483 static const struct partial_symbol *
1484 add_psymbol_to_bcache (const char *name, int namelength, int copy_name,
1485 domain_enum domain,
1486 enum address_class class,
1487 long val, /* Value as a long */
1488 CORE_ADDR coreaddr, /* Value as a CORE_ADDR */
1489 enum language language, struct objfile *objfile,
1490 int *added)
1491 {
1492 struct partial_symbol psymbol;
1493
1494 /* We must ensure that the entire 'value' field has been zeroed
1495 before assigning to it, because an assignment may not write the
1496 entire field. */
1497 memset (&psymbol.ginfo.value, 0, sizeof (psymbol.ginfo.value));
1498
1499 /* val and coreaddr are mutually exclusive, one of them *will* be zero. */
1500 if (val != 0)
1501 {
1502 SYMBOL_VALUE (&psymbol) = val;
1503 }
1504 else
1505 {
1506 SYMBOL_VALUE_ADDRESS (&psymbol) = coreaddr;
1507 }
1508 SYMBOL_SECTION (&psymbol) = 0;
1509 SYMBOL_OBJ_SECTION (&psymbol) = NULL;
1510 SYMBOL_SET_LANGUAGE (&psymbol, language);
1511 PSYMBOL_DOMAIN (&psymbol) = domain;
1512 PSYMBOL_CLASS (&psymbol) = class;
1513
1514 SYMBOL_SET_NAMES (&psymbol, name, namelength, copy_name, objfile);
1515
1516 /* Stash the partial symbol away in the cache. */
1517 return psymbol_bcache_full (&psymbol,
1518 objfile->psymbol_cache,
1519 added);
1520 }
1521
1522 /* Increase the space allocated for LISTP, which is probably
1523 global_psymbols or static_psymbols. This space will eventually
1524 be freed in free_objfile(). */
1525
1526 static void
1527 extend_psymbol_list (struct psymbol_allocation_list *listp,
1528 struct objfile *objfile)
1529 {
1530 int new_size;
1531
1532 if (listp->size == 0)
1533 {
1534 new_size = 255;
1535 listp->list = (struct partial_symbol **)
1536 xmalloc (new_size * sizeof (struct partial_symbol *));
1537 }
1538 else
1539 {
1540 new_size = listp->size * 2;
1541 listp->list = (struct partial_symbol **)
1542 xrealloc ((char *) listp->list,
1543 new_size * sizeof (struct partial_symbol *));
1544 }
1545 /* Next assumes we only went one over. Should be good if
1546 program works correctly. */
1547 listp->next = listp->list + listp->size;
1548 listp->size = new_size;
1549 }
1550
1551 /* Helper function, adds partial symbol to the given partial symbol
1552 list. */
1553
1554 static void
1555 append_psymbol_to_list (struct psymbol_allocation_list *list,
1556 const struct partial_symbol *psym,
1557 struct objfile *objfile)
1558 {
1559 if (list->next >= list->list + list->size)
1560 extend_psymbol_list (list, objfile);
1561 *list->next++ = (struct partial_symbol *) psym;
1562 OBJSTAT (objfile, n_psyms++);
1563 }
1564
1565 /* Add a symbol with a long value to a psymtab.
1566 Since one arg is a struct, we pass in a ptr and deref it (sigh).
1567 Return the partial symbol that has been added. */
1568
1569 void
1570 add_psymbol_to_list (const char *name, int namelength, int copy_name,
1571 domain_enum domain,
1572 enum address_class class,
1573 struct psymbol_allocation_list *list,
1574 long val, /* Value as a long */
1575 CORE_ADDR coreaddr, /* Value as a CORE_ADDR */
1576 enum language language, struct objfile *objfile)
1577 {
1578 const struct partial_symbol *psym;
1579
1580 int added;
1581
1582 /* Stash the partial symbol away in the cache. */
1583 psym = add_psymbol_to_bcache (name, namelength, copy_name, domain, class,
1584 val, coreaddr, language, objfile, &added);
1585
1586 /* Do not duplicate global partial symbols. */
1587 if (list == &objfile->global_psymbols
1588 && !added)
1589 return;
1590
1591 /* Save pointer to partial symbol in psymtab, growing symtab if needed. */
1592 append_psymbol_to_list (list, psym, objfile);
1593 }
1594
1595 /* Initialize storage for partial symbols. */
1596
1597 void
1598 init_psymbol_list (struct objfile *objfile, int total_symbols)
1599 {
1600 /* Free any previously allocated psymbol lists. */
1601
1602 if (objfile->global_psymbols.list)
1603 {
1604 xfree (objfile->global_psymbols.list);
1605 }
1606 if (objfile->static_psymbols.list)
1607 {
1608 xfree (objfile->static_psymbols.list);
1609 }
1610
1611 /* Current best guess is that approximately a twentieth
1612 of the total symbols (in a debugging file) are global or static
1613 oriented symbols. */
1614
1615 objfile->global_psymbols.size = total_symbols / 10;
1616 objfile->static_psymbols.size = total_symbols / 10;
1617
1618 if (objfile->global_psymbols.size > 0)
1619 {
1620 objfile->global_psymbols.next =
1621 objfile->global_psymbols.list = (struct partial_symbol **)
1622 xmalloc ((objfile->global_psymbols.size
1623 * sizeof (struct partial_symbol *)));
1624 }
1625 if (objfile->static_psymbols.size > 0)
1626 {
1627 objfile->static_psymbols.next =
1628 objfile->static_psymbols.list = (struct partial_symbol **)
1629 xmalloc ((objfile->static_psymbols.size
1630 * sizeof (struct partial_symbol *)));
1631 }
1632 }
1633
1634 struct partial_symtab *
1635 allocate_psymtab (const char *filename, struct objfile *objfile)
1636 {
1637 struct partial_symtab *psymtab;
1638
1639 if (objfile->free_psymtabs)
1640 {
1641 psymtab = objfile->free_psymtabs;
1642 objfile->free_psymtabs = psymtab->next;
1643 }
1644 else
1645 psymtab = (struct partial_symtab *)
1646 obstack_alloc (&objfile->objfile_obstack,
1647 sizeof (struct partial_symtab));
1648
1649 memset (psymtab, 0, sizeof (struct partial_symtab));
1650 psymtab->filename = obsavestring (filename, strlen (filename),
1651 &objfile->objfile_obstack);
1652 psymtab->symtab = NULL;
1653
1654 /* Prepend it to the psymtab list for the objfile it belongs to.
1655 Psymtabs are searched in most recent inserted -> least recent
1656 inserted order. */
1657
1658 psymtab->objfile = objfile;
1659 psymtab->next = objfile->psymtabs;
1660 objfile->psymtabs = psymtab;
1661
1662 return (psymtab);
1663 }
1664
1665 void
1666 discard_psymtab (struct partial_symtab *pst)
1667 {
1668 struct partial_symtab **prev_pst;
1669
1670 /* From dbxread.c:
1671 Empty psymtabs happen as a result of header files which don't
1672 have any symbols in them. There can be a lot of them. But this
1673 check is wrong, in that a psymtab with N_SLINE entries but
1674 nothing else is not empty, but we don't realize that. Fixing
1675 that without slowing things down might be tricky. */
1676
1677 /* First, snip it out of the psymtab chain. */
1678
1679 prev_pst = &(pst->objfile->psymtabs);
1680 while ((*prev_pst) != pst)
1681 prev_pst = &((*prev_pst)->next);
1682 (*prev_pst) = pst->next;
1683
1684 /* Next, put it on a free list for recycling. */
1685
1686 pst->next = pst->objfile->free_psymtabs;
1687 pst->objfile->free_psymtabs = pst;
1688 }
1689
1690 \f
1691
1692 void
1693 maintenance_print_psymbols (char *args, int from_tty)
1694 {
1695 char **argv;
1696 struct ui_file *outfile;
1697 struct cleanup *cleanups;
1698 char *symname = NULL;
1699 char *filename = DEV_TTY;
1700 struct objfile *objfile;
1701 struct partial_symtab *ps;
1702
1703 dont_repeat ();
1704
1705 if (args == NULL)
1706 {
1707 error (_("\
1708 print-psymbols takes an output file name and optional symbol file name"));
1709 }
1710 argv = gdb_buildargv (args);
1711 cleanups = make_cleanup_freeargv (argv);
1712
1713 if (argv[0] != NULL)
1714 {
1715 filename = argv[0];
1716 /* If a second arg is supplied, it is a source file name to match on. */
1717 if (argv[1] != NULL)
1718 {
1719 symname = argv[1];
1720 }
1721 }
1722
1723 filename = tilde_expand (filename);
1724 make_cleanup (xfree, filename);
1725
1726 outfile = gdb_fopen (filename, FOPEN_WT);
1727 if (outfile == 0)
1728 perror_with_name (filename);
1729 make_cleanup_ui_file_delete (outfile);
1730
1731 immediate_quit++;
1732 ALL_PSYMTABS (objfile, ps)
1733 if (symname == NULL || filename_cmp (symname, ps->filename) == 0)
1734 dump_psymtab (objfile, ps, outfile);
1735 immediate_quit--;
1736 do_cleanups (cleanups);
1737 }
1738
1739 /* List all the partial symbol tables whose names match REGEXP (optional). */
1740 void
1741 maintenance_info_psymtabs (char *regexp, int from_tty)
1742 {
1743 struct program_space *pspace;
1744 struct objfile *objfile;
1745
1746 if (regexp)
1747 re_comp (regexp);
1748
1749 ALL_PSPACES (pspace)
1750 ALL_PSPACE_OBJFILES (pspace, objfile)
1751 {
1752 struct gdbarch *gdbarch = get_objfile_arch (objfile);
1753 struct partial_symtab *psymtab;
1754
1755 /* We don't want to print anything for this objfile until we
1756 actually find a symtab whose name matches. */
1757 int printed_objfile_start = 0;
1758
1759 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, psymtab)
1760 {
1761 QUIT;
1762
1763 if (! regexp
1764 || re_exec (psymtab->filename))
1765 {
1766 if (! printed_objfile_start)
1767 {
1768 printf_filtered ("{ objfile %s ", objfile->name);
1769 wrap_here (" ");
1770 printf_filtered ("((struct objfile *) %s)\n",
1771 host_address_to_string (objfile));
1772 printed_objfile_start = 1;
1773 }
1774
1775 printf_filtered (" { psymtab %s ", psymtab->filename);
1776 wrap_here (" ");
1777 printf_filtered ("((struct partial_symtab *) %s)\n",
1778 host_address_to_string (psymtab));
1779
1780 printf_filtered (" readin %s\n",
1781 psymtab->readin ? "yes" : "no");
1782 printf_filtered (" fullname %s\n",
1783 psymtab->fullname
1784 ? psymtab->fullname : "(null)");
1785 printf_filtered (" text addresses ");
1786 fputs_filtered (paddress (gdbarch, psymtab->textlow),
1787 gdb_stdout);
1788 printf_filtered (" -- ");
1789 fputs_filtered (paddress (gdbarch, psymtab->texthigh),
1790 gdb_stdout);
1791 printf_filtered ("\n");
1792 printf_filtered (" psymtabs_addrmap_supported %s\n",
1793 (psymtab->psymtabs_addrmap_supported
1794 ? "yes" : "no"));
1795 printf_filtered (" globals ");
1796 if (psymtab->n_global_syms)
1797 {
1798 printf_filtered ("(* (struct partial_symbol **) %s @ %d)\n",
1799 host_address_to_string (psymtab->objfile->global_psymbols.list
1800 + psymtab->globals_offset),
1801 psymtab->n_global_syms);
1802 }
1803 else
1804 printf_filtered ("(none)\n");
1805 printf_filtered (" statics ");
1806 if (psymtab->n_static_syms)
1807 {
1808 printf_filtered ("(* (struct partial_symbol **) %s @ %d)\n",
1809 host_address_to_string (psymtab->objfile->static_psymbols.list
1810 + psymtab->statics_offset),
1811 psymtab->n_static_syms);
1812 }
1813 else
1814 printf_filtered ("(none)\n");
1815 printf_filtered (" dependencies ");
1816 if (psymtab->number_of_dependencies)
1817 {
1818 int i;
1819
1820 printf_filtered ("{\n");
1821 for (i = 0; i < psymtab->number_of_dependencies; i++)
1822 {
1823 struct partial_symtab *dep = psymtab->dependencies[i];
1824
1825 /* Note the string concatenation there --- no comma. */
1826 printf_filtered (" psymtab %s "
1827 "((struct partial_symtab *) %s)\n",
1828 dep->filename,
1829 host_address_to_string (dep));
1830 }
1831 printf_filtered (" }\n");
1832 }
1833 else
1834 printf_filtered ("(none)\n");
1835 printf_filtered (" }\n");
1836 }
1837 }
1838
1839 if (printed_objfile_start)
1840 printf_filtered ("}\n");
1841 }
1842 }
1843
1844 /* Check consistency of psymtabs and symtabs. */
1845
1846 void
1847 maintenance_check_symtabs (char *ignore, int from_tty)
1848 {
1849 struct symbol *sym;
1850 struct partial_symbol **psym;
1851 struct symtab *s = NULL;
1852 struct partial_symtab *ps;
1853 struct blockvector *bv;
1854 struct objfile *objfile;
1855 struct block *b;
1856 int length;
1857
1858 ALL_PSYMTABS (objfile, ps)
1859 {
1860 struct gdbarch *gdbarch = get_objfile_arch (objfile);
1861
1862 s = PSYMTAB_TO_SYMTAB (ps);
1863 if (s == NULL)
1864 continue;
1865 bv = BLOCKVECTOR (s);
1866 b = BLOCKVECTOR_BLOCK (bv, STATIC_BLOCK);
1867 psym = ps->objfile->static_psymbols.list + ps->statics_offset;
1868 length = ps->n_static_syms;
1869 while (length--)
1870 {
1871 sym = lookup_block_symbol (b, SYMBOL_LINKAGE_NAME (*psym),
1872 SYMBOL_DOMAIN (*psym));
1873 if (!sym)
1874 {
1875 printf_filtered ("Static symbol `");
1876 puts_filtered (SYMBOL_LINKAGE_NAME (*psym));
1877 printf_filtered ("' only found in ");
1878 puts_filtered (ps->filename);
1879 printf_filtered (" psymtab\n");
1880 }
1881 psym++;
1882 }
1883 b = BLOCKVECTOR_BLOCK (bv, GLOBAL_BLOCK);
1884 psym = ps->objfile->global_psymbols.list + ps->globals_offset;
1885 length = ps->n_global_syms;
1886 while (length--)
1887 {
1888 sym = lookup_block_symbol (b, SYMBOL_LINKAGE_NAME (*psym),
1889 SYMBOL_DOMAIN (*psym));
1890 if (!sym)
1891 {
1892 printf_filtered ("Global symbol `");
1893 puts_filtered (SYMBOL_LINKAGE_NAME (*psym));
1894 printf_filtered ("' only found in ");
1895 puts_filtered (ps->filename);
1896 printf_filtered (" psymtab\n");
1897 }
1898 psym++;
1899 }
1900 if (ps->texthigh < ps->textlow)
1901 {
1902 printf_filtered ("Psymtab ");
1903 puts_filtered (ps->filename);
1904 printf_filtered (" covers bad range ");
1905 fputs_filtered (paddress (gdbarch, ps->textlow), gdb_stdout);
1906 printf_filtered (" - ");
1907 fputs_filtered (paddress (gdbarch, ps->texthigh), gdb_stdout);
1908 printf_filtered ("\n");
1909 continue;
1910 }
1911 if (ps->texthigh == 0)
1912 continue;
1913 if (ps->textlow < BLOCK_START (b) || ps->texthigh > BLOCK_END (b))
1914 {
1915 printf_filtered ("Psymtab ");
1916 puts_filtered (ps->filename);
1917 printf_filtered (" covers ");
1918 fputs_filtered (paddress (gdbarch, ps->textlow), gdb_stdout);
1919 printf_filtered (" - ");
1920 fputs_filtered (paddress (gdbarch, ps->texthigh), gdb_stdout);
1921 printf_filtered (" but symtab covers only ");
1922 fputs_filtered (paddress (gdbarch, BLOCK_START (b)), gdb_stdout);
1923 printf_filtered (" - ");
1924 fputs_filtered (paddress (gdbarch, BLOCK_END (b)), gdb_stdout);
1925 printf_filtered ("\n");
1926 }
1927 }
1928 }
1929
1930 \f
1931
1932 void
1933 expand_partial_symbol_names (int (*fun) (const char *, void *),
1934 void *data)
1935 {
1936 struct objfile *objfile;
1937
1938 ALL_OBJFILES (objfile)
1939 {
1940 if (objfile->sf)
1941 objfile->sf->qf->expand_symtabs_matching (objfile, NULL, fun,
1942 ALL_DOMAIN, data);
1943 }
1944 }
1945
1946 void
1947 map_partial_symbol_filenames (symbol_filename_ftype *fun, void *data,
1948 int need_fullname)
1949 {
1950 struct objfile *objfile;
1951
1952 ALL_OBJFILES (objfile)
1953 {
1954 if (objfile->sf)
1955 objfile->sf->qf->map_symbol_filenames (objfile, fun, data,
1956 need_fullname);
1957 }
1958 }
This page took 0.069101 seconds and 4 git commands to generate.