2012-01-24 Pedro Alves <pedro@codesourcery.com>
[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 struct language_defn *, 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) (current_language,
1306 SYMBOL_SEARCH_NAME (*psym), data))
1307 {
1308 PSYMTAB_TO_SYMTAB (ps);
1309 keep_going = 0;
1310 }
1311 }
1312 psym++;
1313 }
1314 }
1315 }
1316
1317 static int
1318 objfile_has_psyms (struct objfile *objfile)
1319 {
1320 return objfile->psymtabs != NULL;
1321 }
1322
1323 const struct quick_symbol_functions psym_functions =
1324 {
1325 objfile_has_psyms,
1326 find_last_source_symtab_from_partial,
1327 forget_cached_source_info_partial,
1328 partial_map_symtabs_matching_filename,
1329 lookup_symbol_aux_psymtabs,
1330 pre_expand_symtabs_matching_psymtabs,
1331 print_psymtab_stats_for_objfile,
1332 dump_psymtabs_for_objfile,
1333 relocate_psymtabs,
1334 read_symtabs_for_function,
1335 expand_partial_symbol_tables,
1336 read_psymtabs_with_filename,
1337 find_symbol_file_from_partial,
1338 map_matching_symbols_psymtab,
1339 expand_symtabs_matching_via_partial,
1340 find_pc_sect_symtab_from_partial,
1341 map_symbol_filenames_psymtab
1342 };
1343
1344 \f
1345
1346 /* This compares two partial symbols by names, using strcmp_iw_ordered
1347 for the comparison. */
1348
1349 static int
1350 compare_psymbols (const void *s1p, const void *s2p)
1351 {
1352 struct partial_symbol *const *s1 = s1p;
1353 struct partial_symbol *const *s2 = s2p;
1354
1355 return strcmp_iw_ordered (SYMBOL_SEARCH_NAME (*s1),
1356 SYMBOL_SEARCH_NAME (*s2));
1357 }
1358
1359 void
1360 sort_pst_symbols (struct partial_symtab *pst)
1361 {
1362 /* Sort the global list; don't sort the static list. */
1363
1364 qsort (pst->objfile->global_psymbols.list + pst->globals_offset,
1365 pst->n_global_syms, sizeof (struct partial_symbol *),
1366 compare_psymbols);
1367 }
1368
1369 /* Allocate and partially fill a partial symtab. It will be
1370 completely filled at the end of the symbol list.
1371
1372 FILENAME is the name of the symbol-file we are reading from. */
1373
1374 struct partial_symtab *
1375 start_psymtab_common (struct objfile *objfile,
1376 struct section_offsets *section_offsets,
1377 const char *filename,
1378 CORE_ADDR textlow, struct partial_symbol **global_syms,
1379 struct partial_symbol **static_syms)
1380 {
1381 struct partial_symtab *psymtab;
1382
1383 psymtab = allocate_psymtab (filename, objfile);
1384 psymtab->section_offsets = section_offsets;
1385 psymtab->textlow = textlow;
1386 psymtab->texthigh = psymtab->textlow; /* default */
1387 psymtab->globals_offset = global_syms - objfile->global_psymbols.list;
1388 psymtab->statics_offset = static_syms - objfile->static_psymbols.list;
1389 return (psymtab);
1390 }
1391
1392 /* Calculate a hash code for the given partial symbol. The hash is
1393 calculated using the symbol's value, language, domain, class
1394 and name. These are the values which are set by
1395 add_psymbol_to_bcache. */
1396
1397 static unsigned long
1398 psymbol_hash (const void *addr, int length)
1399 {
1400 unsigned long h = 0;
1401 struct partial_symbol *psymbol = (struct partial_symbol *) addr;
1402 unsigned int lang = psymbol->ginfo.language;
1403 unsigned int domain = PSYMBOL_DOMAIN (psymbol);
1404 unsigned int class = PSYMBOL_CLASS (psymbol);
1405
1406 h = hash_continue (&psymbol->ginfo.value, sizeof (psymbol->ginfo.value), h);
1407 h = hash_continue (&lang, sizeof (unsigned int), h);
1408 h = hash_continue (&domain, sizeof (unsigned int), h);
1409 h = hash_continue (&class, sizeof (unsigned int), h);
1410 h = hash_continue (psymbol->ginfo.name, strlen (psymbol->ginfo.name), h);
1411
1412 return h;
1413 }
1414
1415 /* Returns true if the symbol at addr1 equals the symbol at addr2.
1416 For the comparison this function uses a symbols value,
1417 language, domain, class and name. */
1418
1419 static int
1420 psymbol_compare (const void *addr1, const void *addr2, int length)
1421 {
1422 struct partial_symbol *sym1 = (struct partial_symbol *) addr1;
1423 struct partial_symbol *sym2 = (struct partial_symbol *) addr2;
1424
1425 return (memcmp (&sym1->ginfo.value, &sym1->ginfo.value,
1426 sizeof (sym1->ginfo.value)) == 0
1427 && sym1->ginfo.language == sym2->ginfo.language
1428 && PSYMBOL_DOMAIN (sym1) == PSYMBOL_DOMAIN (sym2)
1429 && PSYMBOL_CLASS (sym1) == PSYMBOL_CLASS (sym2)
1430 && sym1->ginfo.name == sym2->ginfo.name);
1431 }
1432
1433 /* Initialize a partial symbol bcache. */
1434
1435 struct psymbol_bcache *
1436 psymbol_bcache_init (void)
1437 {
1438 struct psymbol_bcache *bcache = XCALLOC (1, struct psymbol_bcache);
1439 bcache->bcache = bcache_xmalloc (psymbol_hash, psymbol_compare);
1440 return bcache;
1441 }
1442
1443 /* Free a partial symbol bcache. */
1444 void
1445 psymbol_bcache_free (struct psymbol_bcache *bcache)
1446 {
1447 if (bcache == NULL)
1448 return;
1449
1450 bcache_xfree (bcache->bcache);
1451 xfree (bcache);
1452 }
1453
1454 /* Return the internal bcache of the psymbol_bcache BCACHE. */
1455
1456 struct bcache *
1457 psymbol_bcache_get_bcache (struct psymbol_bcache *bcache)
1458 {
1459 return bcache->bcache;
1460 }
1461
1462 /* Find a copy of the SYM in BCACHE. If BCACHE has never seen this
1463 symbol before, add a copy to BCACHE. In either case, return a pointer
1464 to BCACHE's copy of the symbol. If optional ADDED is not NULL, return
1465 1 in case of new entry or 0 if returning an old entry. */
1466
1467 static const struct partial_symbol *
1468 psymbol_bcache_full (struct partial_symbol *sym,
1469 struct psymbol_bcache *bcache,
1470 int *added)
1471 {
1472 return bcache_full (sym,
1473 sizeof (struct partial_symbol),
1474 bcache->bcache,
1475 added);
1476 }
1477
1478 /* Helper function, initialises partial symbol structure and stashes
1479 it into objfile's bcache. Note that our caching mechanism will
1480 use all fields of struct partial_symbol to determine hash value of the
1481 structure. In other words, having two symbols with the same name but
1482 different domain (or address) is possible and correct. */
1483
1484 static const struct partial_symbol *
1485 add_psymbol_to_bcache (const char *name, int namelength, int copy_name,
1486 domain_enum domain,
1487 enum address_class class,
1488 long val, /* Value as a long */
1489 CORE_ADDR coreaddr, /* Value as a CORE_ADDR */
1490 enum language language, struct objfile *objfile,
1491 int *added)
1492 {
1493 struct partial_symbol psymbol;
1494
1495 /* We must ensure that the entire 'value' field has been zeroed
1496 before assigning to it, because an assignment may not write the
1497 entire field. */
1498 memset (&psymbol.ginfo.value, 0, sizeof (psymbol.ginfo.value));
1499
1500 /* val and coreaddr are mutually exclusive, one of them *will* be zero. */
1501 if (val != 0)
1502 {
1503 SYMBOL_VALUE (&psymbol) = val;
1504 }
1505 else
1506 {
1507 SYMBOL_VALUE_ADDRESS (&psymbol) = coreaddr;
1508 }
1509 SYMBOL_SECTION (&psymbol) = 0;
1510 SYMBOL_OBJ_SECTION (&psymbol) = NULL;
1511 SYMBOL_SET_LANGUAGE (&psymbol, language);
1512 PSYMBOL_DOMAIN (&psymbol) = domain;
1513 PSYMBOL_CLASS (&psymbol) = class;
1514
1515 SYMBOL_SET_NAMES (&psymbol, name, namelength, copy_name, objfile);
1516
1517 /* Stash the partial symbol away in the cache. */
1518 return psymbol_bcache_full (&psymbol,
1519 objfile->psymbol_cache,
1520 added);
1521 }
1522
1523 /* Increase the space allocated for LISTP, which is probably
1524 global_psymbols or static_psymbols. This space will eventually
1525 be freed in free_objfile(). */
1526
1527 static void
1528 extend_psymbol_list (struct psymbol_allocation_list *listp,
1529 struct objfile *objfile)
1530 {
1531 int new_size;
1532
1533 if (listp->size == 0)
1534 {
1535 new_size = 255;
1536 listp->list = (struct partial_symbol **)
1537 xmalloc (new_size * sizeof (struct partial_symbol *));
1538 }
1539 else
1540 {
1541 new_size = listp->size * 2;
1542 listp->list = (struct partial_symbol **)
1543 xrealloc ((char *) listp->list,
1544 new_size * sizeof (struct partial_symbol *));
1545 }
1546 /* Next assumes we only went one over. Should be good if
1547 program works correctly. */
1548 listp->next = listp->list + listp->size;
1549 listp->size = new_size;
1550 }
1551
1552 /* Helper function, adds partial symbol to the given partial symbol
1553 list. */
1554
1555 static void
1556 append_psymbol_to_list (struct psymbol_allocation_list *list,
1557 const struct partial_symbol *psym,
1558 struct objfile *objfile)
1559 {
1560 if (list->next >= list->list + list->size)
1561 extend_psymbol_list (list, objfile);
1562 *list->next++ = (struct partial_symbol *) psym;
1563 OBJSTAT (objfile, n_psyms++);
1564 }
1565
1566 /* Add a symbol with a long value to a psymtab.
1567 Since one arg is a struct, we pass in a ptr and deref it (sigh).
1568 Return the partial symbol that has been added. */
1569
1570 /* NOTE: carlton/2003-09-11: The reason why we return the partial
1571 symbol is so that callers can get access to the symbol's demangled
1572 name, which they don't have any cheap way to determine otherwise.
1573 (Currenly, dwarf2read.c is the only file who uses that information,
1574 though it's possible that other readers might in the future.)
1575 Elena wasn't thrilled about that, and I don't blame her, but we
1576 couldn't come up with a better way to get that information. If
1577 it's needed in other situations, we could consider breaking up
1578 SYMBOL_SET_NAMES to provide access to the demangled name lookup
1579 cache. */
1580
1581 const struct partial_symbol *
1582 add_psymbol_to_list (const char *name, int namelength, int copy_name,
1583 domain_enum domain,
1584 enum address_class class,
1585 struct psymbol_allocation_list *list,
1586 long val, /* Value as a long */
1587 CORE_ADDR coreaddr, /* Value as a CORE_ADDR */
1588 enum language language, struct objfile *objfile)
1589 {
1590 const struct partial_symbol *psym;
1591
1592 int added;
1593
1594 /* Stash the partial symbol away in the cache. */
1595 psym = add_psymbol_to_bcache (name, namelength, copy_name, domain, class,
1596 val, coreaddr, language, objfile, &added);
1597
1598 /* Do not duplicate global partial symbols. */
1599 if (list == &objfile->global_psymbols
1600 && !added)
1601 return psym;
1602
1603 /* Save pointer to partial symbol in psymtab, growing symtab if needed. */
1604 append_psymbol_to_list (list, psym, objfile);
1605 return psym;
1606 }
1607
1608 /* Initialize storage for partial symbols. */
1609
1610 void
1611 init_psymbol_list (struct objfile *objfile, int total_symbols)
1612 {
1613 /* Free any previously allocated psymbol lists. */
1614
1615 if (objfile->global_psymbols.list)
1616 {
1617 xfree (objfile->global_psymbols.list);
1618 }
1619 if (objfile->static_psymbols.list)
1620 {
1621 xfree (objfile->static_psymbols.list);
1622 }
1623
1624 /* Current best guess is that approximately a twentieth
1625 of the total symbols (in a debugging file) are global or static
1626 oriented symbols. */
1627
1628 objfile->global_psymbols.size = total_symbols / 10;
1629 objfile->static_psymbols.size = total_symbols / 10;
1630
1631 if (objfile->global_psymbols.size > 0)
1632 {
1633 objfile->global_psymbols.next =
1634 objfile->global_psymbols.list = (struct partial_symbol **)
1635 xmalloc ((objfile->global_psymbols.size
1636 * sizeof (struct partial_symbol *)));
1637 }
1638 if (objfile->static_psymbols.size > 0)
1639 {
1640 objfile->static_psymbols.next =
1641 objfile->static_psymbols.list = (struct partial_symbol **)
1642 xmalloc ((objfile->static_psymbols.size
1643 * sizeof (struct partial_symbol *)));
1644 }
1645 }
1646
1647 struct partial_symtab *
1648 allocate_psymtab (const char *filename, struct objfile *objfile)
1649 {
1650 struct partial_symtab *psymtab;
1651
1652 if (objfile->free_psymtabs)
1653 {
1654 psymtab = objfile->free_psymtabs;
1655 objfile->free_psymtabs = psymtab->next;
1656 }
1657 else
1658 psymtab = (struct partial_symtab *)
1659 obstack_alloc (&objfile->objfile_obstack,
1660 sizeof (struct partial_symtab));
1661
1662 memset (psymtab, 0, sizeof (struct partial_symtab));
1663 psymtab->filename = obsavestring (filename, strlen (filename),
1664 &objfile->objfile_obstack);
1665 psymtab->symtab = NULL;
1666
1667 /* Prepend it to the psymtab list for the objfile it belongs to.
1668 Psymtabs are searched in most recent inserted -> least recent
1669 inserted order. */
1670
1671 psymtab->objfile = objfile;
1672 psymtab->next = objfile->psymtabs;
1673 objfile->psymtabs = psymtab;
1674
1675 return (psymtab);
1676 }
1677
1678 void
1679 discard_psymtab (struct partial_symtab *pst)
1680 {
1681 struct partial_symtab **prev_pst;
1682
1683 /* From dbxread.c:
1684 Empty psymtabs happen as a result of header files which don't
1685 have any symbols in them. There can be a lot of them. But this
1686 check is wrong, in that a psymtab with N_SLINE entries but
1687 nothing else is not empty, but we don't realize that. Fixing
1688 that without slowing things down might be tricky. */
1689
1690 /* First, snip it out of the psymtab chain. */
1691
1692 prev_pst = &(pst->objfile->psymtabs);
1693 while ((*prev_pst) != pst)
1694 prev_pst = &((*prev_pst)->next);
1695 (*prev_pst) = pst->next;
1696
1697 /* Next, put it on a free list for recycling. */
1698
1699 pst->next = pst->objfile->free_psymtabs;
1700 pst->objfile->free_psymtabs = pst;
1701 }
1702
1703 \f
1704
1705 void
1706 maintenance_print_psymbols (char *args, int from_tty)
1707 {
1708 char **argv;
1709 struct ui_file *outfile;
1710 struct cleanup *cleanups;
1711 char *symname = NULL;
1712 char *filename = DEV_TTY;
1713 struct objfile *objfile;
1714 struct partial_symtab *ps;
1715
1716 dont_repeat ();
1717
1718 if (args == NULL)
1719 {
1720 error (_("\
1721 print-psymbols takes an output file name and optional symbol file name"));
1722 }
1723 argv = gdb_buildargv (args);
1724 cleanups = make_cleanup_freeargv (argv);
1725
1726 if (argv[0] != NULL)
1727 {
1728 filename = argv[0];
1729 /* If a second arg is supplied, it is a source file name to match on. */
1730 if (argv[1] != NULL)
1731 {
1732 symname = argv[1];
1733 }
1734 }
1735
1736 filename = tilde_expand (filename);
1737 make_cleanup (xfree, filename);
1738
1739 outfile = gdb_fopen (filename, FOPEN_WT);
1740 if (outfile == 0)
1741 perror_with_name (filename);
1742 make_cleanup_ui_file_delete (outfile);
1743
1744 immediate_quit++;
1745 ALL_PSYMTABS (objfile, ps)
1746 if (symname == NULL || filename_cmp (symname, ps->filename) == 0)
1747 dump_psymtab (objfile, ps, outfile);
1748 immediate_quit--;
1749 do_cleanups (cleanups);
1750 }
1751
1752 /* List all the partial symbol tables whose names match REGEXP (optional). */
1753 void
1754 maintenance_info_psymtabs (char *regexp, int from_tty)
1755 {
1756 struct program_space *pspace;
1757 struct objfile *objfile;
1758
1759 if (regexp)
1760 re_comp (regexp);
1761
1762 ALL_PSPACES (pspace)
1763 ALL_PSPACE_OBJFILES (pspace, objfile)
1764 {
1765 struct gdbarch *gdbarch = get_objfile_arch (objfile);
1766 struct partial_symtab *psymtab;
1767
1768 /* We don't want to print anything for this objfile until we
1769 actually find a symtab whose name matches. */
1770 int printed_objfile_start = 0;
1771
1772 ALL_OBJFILE_PSYMTABS_REQUIRED (objfile, psymtab)
1773 {
1774 QUIT;
1775
1776 if (! regexp
1777 || re_exec (psymtab->filename))
1778 {
1779 if (! printed_objfile_start)
1780 {
1781 printf_filtered ("{ objfile %s ", objfile->name);
1782 wrap_here (" ");
1783 printf_filtered ("((struct objfile *) %s)\n",
1784 host_address_to_string (objfile));
1785 printed_objfile_start = 1;
1786 }
1787
1788 printf_filtered (" { psymtab %s ", psymtab->filename);
1789 wrap_here (" ");
1790 printf_filtered ("((struct partial_symtab *) %s)\n",
1791 host_address_to_string (psymtab));
1792
1793 printf_filtered (" readin %s\n",
1794 psymtab->readin ? "yes" : "no");
1795 printf_filtered (" fullname %s\n",
1796 psymtab->fullname
1797 ? psymtab->fullname : "(null)");
1798 printf_filtered (" text addresses ");
1799 fputs_filtered (paddress (gdbarch, psymtab->textlow),
1800 gdb_stdout);
1801 printf_filtered (" -- ");
1802 fputs_filtered (paddress (gdbarch, psymtab->texthigh),
1803 gdb_stdout);
1804 printf_filtered ("\n");
1805 printf_filtered (" psymtabs_addrmap_supported %s\n",
1806 (psymtab->psymtabs_addrmap_supported
1807 ? "yes" : "no"));
1808 printf_filtered (" globals ");
1809 if (psymtab->n_global_syms)
1810 {
1811 printf_filtered ("(* (struct partial_symbol **) %s @ %d)\n",
1812 host_address_to_string (psymtab->objfile->global_psymbols.list
1813 + psymtab->globals_offset),
1814 psymtab->n_global_syms);
1815 }
1816 else
1817 printf_filtered ("(none)\n");
1818 printf_filtered (" statics ");
1819 if (psymtab->n_static_syms)
1820 {
1821 printf_filtered ("(* (struct partial_symbol **) %s @ %d)\n",
1822 host_address_to_string (psymtab->objfile->static_psymbols.list
1823 + psymtab->statics_offset),
1824 psymtab->n_static_syms);
1825 }
1826 else
1827 printf_filtered ("(none)\n");
1828 printf_filtered (" dependencies ");
1829 if (psymtab->number_of_dependencies)
1830 {
1831 int i;
1832
1833 printf_filtered ("{\n");
1834 for (i = 0; i < psymtab->number_of_dependencies; i++)
1835 {
1836 struct partial_symtab *dep = psymtab->dependencies[i];
1837
1838 /* Note the string concatenation there --- no comma. */
1839 printf_filtered (" psymtab %s "
1840 "((struct partial_symtab *) %s)\n",
1841 dep->filename,
1842 host_address_to_string (dep));
1843 }
1844 printf_filtered (" }\n");
1845 }
1846 else
1847 printf_filtered ("(none)\n");
1848 printf_filtered (" }\n");
1849 }
1850 }
1851
1852 if (printed_objfile_start)
1853 printf_filtered ("}\n");
1854 }
1855 }
1856
1857 /* Check consistency of psymtabs and symtabs. */
1858
1859 void
1860 maintenance_check_symtabs (char *ignore, int from_tty)
1861 {
1862 struct symbol *sym;
1863 struct partial_symbol **psym;
1864 struct symtab *s = NULL;
1865 struct partial_symtab *ps;
1866 struct blockvector *bv;
1867 struct objfile *objfile;
1868 struct block *b;
1869 int length;
1870
1871 ALL_PSYMTABS (objfile, ps)
1872 {
1873 struct gdbarch *gdbarch = get_objfile_arch (objfile);
1874
1875 s = PSYMTAB_TO_SYMTAB (ps);
1876 if (s == NULL)
1877 continue;
1878 bv = BLOCKVECTOR (s);
1879 b = BLOCKVECTOR_BLOCK (bv, STATIC_BLOCK);
1880 psym = ps->objfile->static_psymbols.list + ps->statics_offset;
1881 length = ps->n_static_syms;
1882 while (length--)
1883 {
1884 sym = lookup_block_symbol (b, SYMBOL_LINKAGE_NAME (*psym),
1885 SYMBOL_DOMAIN (*psym));
1886 if (!sym)
1887 {
1888 printf_filtered ("Static symbol `");
1889 puts_filtered (SYMBOL_LINKAGE_NAME (*psym));
1890 printf_filtered ("' only found in ");
1891 puts_filtered (ps->filename);
1892 printf_filtered (" psymtab\n");
1893 }
1894 psym++;
1895 }
1896 b = BLOCKVECTOR_BLOCK (bv, GLOBAL_BLOCK);
1897 psym = ps->objfile->global_psymbols.list + ps->globals_offset;
1898 length = ps->n_global_syms;
1899 while (length--)
1900 {
1901 sym = lookup_block_symbol (b, SYMBOL_LINKAGE_NAME (*psym),
1902 SYMBOL_DOMAIN (*psym));
1903 if (!sym)
1904 {
1905 printf_filtered ("Global symbol `");
1906 puts_filtered (SYMBOL_LINKAGE_NAME (*psym));
1907 printf_filtered ("' only found in ");
1908 puts_filtered (ps->filename);
1909 printf_filtered (" psymtab\n");
1910 }
1911 psym++;
1912 }
1913 if (ps->texthigh < ps->textlow)
1914 {
1915 printf_filtered ("Psymtab ");
1916 puts_filtered (ps->filename);
1917 printf_filtered (" covers bad range ");
1918 fputs_filtered (paddress (gdbarch, ps->textlow), gdb_stdout);
1919 printf_filtered (" - ");
1920 fputs_filtered (paddress (gdbarch, ps->texthigh), gdb_stdout);
1921 printf_filtered ("\n");
1922 continue;
1923 }
1924 if (ps->texthigh == 0)
1925 continue;
1926 if (ps->textlow < BLOCK_START (b) || ps->texthigh > BLOCK_END (b))
1927 {
1928 printf_filtered ("Psymtab ");
1929 puts_filtered (ps->filename);
1930 printf_filtered (" covers ");
1931 fputs_filtered (paddress (gdbarch, ps->textlow), gdb_stdout);
1932 printf_filtered (" - ");
1933 fputs_filtered (paddress (gdbarch, ps->texthigh), gdb_stdout);
1934 printf_filtered (" but symtab covers only ");
1935 fputs_filtered (paddress (gdbarch, BLOCK_START (b)), gdb_stdout);
1936 printf_filtered (" - ");
1937 fputs_filtered (paddress (gdbarch, BLOCK_END (b)), gdb_stdout);
1938 printf_filtered ("\n");
1939 }
1940 }
1941 }
1942
1943 \f
1944
1945 void
1946 expand_partial_symbol_names (int (*fun) (const struct language_defn *,
1947 const char *, void *),
1948 void *data)
1949 {
1950 struct objfile *objfile;
1951
1952 ALL_OBJFILES (objfile)
1953 {
1954 if (objfile->sf)
1955 objfile->sf->qf->expand_symtabs_matching (objfile, NULL, fun,
1956 ALL_DOMAIN, data);
1957 }
1958 }
1959
1960 void
1961 map_partial_symbol_filenames (symbol_filename_ftype *fun, void *data,
1962 int need_fullname)
1963 {
1964 struct objfile *objfile;
1965
1966 ALL_OBJFILES (objfile)
1967 {
1968 if (objfile->sf)
1969 objfile->sf->qf->map_symbol_filenames (objfile, fun, data,
1970 need_fullname);
1971 }
1972 }
This page took 0.068796 seconds and 4 git commands to generate.