* psymtab.c (add_psymbol_to_list): Result is now "void".
[external/binutils.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 }