gdb/doc: make use of group/end group in 'info pretty-printers' example
[binutils-gdb.git] / gdb / dbxread.c
1 /* Read dbx symbol tables and convert to internal format, for GDB.
2 Copyright (C) 1986-2022 Free Software Foundation, Inc.
3
4 This file is part of GDB.
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program. If not, see <http://www.gnu.org/licenses/>. */
18
19 /* This module provides three functions: dbx_symfile_init,
20 which initializes to read a symbol file; dbx_new_init, which
21 discards existing cached information when all symbols are being
22 discarded; and dbx_symfile_read, which reads a symbol table
23 from a file.
24
25 dbx_symfile_read only does the minimum work necessary for letting the
26 user "name" things symbolically; it does not read the entire symtab.
27 Instead, it reads the external and static symbols and puts them in partial
28 symbol tables. When more extensive information is requested of a
29 file, the corresponding partial symbol table is mutated into a full
30 fledged symbol table by going back and reading the symbols
31 for real. dbx_psymtab_to_symtab() is the function that does this */
32
33 #include "defs.h"
34
35 #include "gdbsupport/gdb_obstack.h"
36 #include <sys/stat.h>
37 #include "symtab.h"
38 #include "breakpoint.h"
39 #include "target.h"
40 #include "gdbcore.h" /* for bfd stuff */
41 #include "libaout.h" /* FIXME Secret internal BFD stuff for a.out */
42 #include "filenames.h"
43 #include "objfiles.h"
44 #include "buildsym-legacy.h"
45 #include "stabsread.h"
46 #include "gdb-stabs.h"
47 #include "demangle.h"
48 #include "complaints.h"
49 #include "cp-abi.h"
50 #include "cp-support.h"
51 #include "psympriv.h"
52 #include "block.h"
53 #include "aout/aout64.h"
54 #include "aout/stab_gnu.h" /* We always use GNU stabs, not
55 native, now. */
56 \f
57
58 /* Key for dbx-associated data. */
59
60 objfile_key<dbx_symfile_info> dbx_objfile_data_key;
61
62 /* We put a pointer to this structure in the read_symtab_private field
63 of the psymtab. */
64
65 struct symloc
66 {
67 /* Offset within the file symbol table of first local symbol for this
68 file. */
69
70 int ldsymoff;
71
72 /* Length (in bytes) of the section of the symbol table devoted to
73 this file's symbols (actually, the section bracketed may contain
74 more than just this file's symbols). If ldsymlen is 0, the only
75 reason for this thing's existence is the dependency list. Nothing
76 else will happen when it is read in. */
77
78 int ldsymlen;
79
80 /* The size of each symbol in the symbol file (in external form). */
81
82 int symbol_size;
83
84 /* Further information needed to locate the symbols if they are in
85 an ELF file. */
86
87 int symbol_offset;
88 int string_offset;
89 int file_string_offset;
90 enum language pst_language;
91 };
92
93 #define LDSYMOFF(p) (((struct symloc *)((p)->read_symtab_private))->ldsymoff)
94 #define LDSYMLEN(p) (((struct symloc *)((p)->read_symtab_private))->ldsymlen)
95 #define SYMLOC(p) ((struct symloc *)((p)->read_symtab_private))
96 #define SYMBOL_SIZE(p) (SYMLOC(p)->symbol_size)
97 #define SYMBOL_OFFSET(p) (SYMLOC(p)->symbol_offset)
98 #define STRING_OFFSET(p) (SYMLOC(p)->string_offset)
99 #define FILE_STRING_OFFSET(p) (SYMLOC(p)->file_string_offset)
100 #define PST_LANGUAGE(p) (SYMLOC(p)->pst_language)
101 \f
102
103 /* The objfile we are currently reading. */
104
105 static struct objfile *dbxread_objfile;
106
107 /* Remember what we deduced to be the source language of this psymtab. */
108
109 static enum language psymtab_language = language_unknown;
110
111 /* The BFD for this file -- implicit parameter to next_symbol_text. */
112
113 static bfd *symfile_bfd;
114
115 /* The size of each symbol in the symbol file (in external form).
116 This is set by dbx_symfile_read when building psymtabs, and by
117 dbx_psymtab_to_symtab when building symtabs. */
118
119 static unsigned symbol_size;
120
121 /* This is the offset of the symbol table in the executable file. */
122
123 static unsigned symbol_table_offset;
124
125 /* This is the offset of the string table in the executable file. */
126
127 static unsigned string_table_offset;
128
129 /* For elf+stab executables, the n_strx field is not a simple index
130 into the string table. Instead, each .o file has a base offset in
131 the string table, and the associated symbols contain offsets from
132 this base. The following two variables contain the base offset for
133 the current and next .o files. */
134
135 static unsigned int file_string_table_offset;
136 static unsigned int next_file_string_table_offset;
137
138 /* .o and NLM files contain unrelocated addresses which are based at
139 0. When non-zero, this flag disables some of the special cases for
140 Solaris elf+stab text addresses at location 0. */
141
142 static int symfile_relocatable = 0;
143
144 /* When set, we are processing a .o file compiled by sun acc. This is
145 misnamed; it refers to all stabs-in-elf implementations which use
146 N_UNDF the way Sun does, including Solaris gcc. Hopefully all
147 stabs-in-elf implementations ever invented will choose to be
148 compatible. */
149
150 static unsigned char processing_acc_compilation;
151
152 \f
153 /* The lowest text address we have yet encountered. This is needed
154 because in an a.out file, there is no header field which tells us
155 what address the program is actually going to be loaded at, so we
156 need to make guesses based on the symbols (which *are* relocated to
157 reflect the address it will be loaded at). */
158
159 static CORE_ADDR lowest_text_address;
160
161 /* Non-zero if there is any line number info in the objfile. Prevents
162 dbx_end_psymtab from discarding an otherwise empty psymtab. */
163
164 static int has_line_numbers;
165
166 /* Complaints about the symbols we have encountered. */
167
168 static void
169 unknown_symtype_complaint (const char *arg1)
170 {
171 complaint (_("unknown symbol type %s"), arg1);
172 }
173
174 static void
175 lbrac_mismatch_complaint (int arg1)
176 {
177 complaint (_("N_LBRAC/N_RBRAC symbol mismatch at symtab pos %d"), arg1);
178 }
179
180 static void
181 repeated_header_complaint (const char *arg1, int arg2)
182 {
183 complaint (_("\"repeated\" header file %s not "
184 "previously seen, at symtab pos %d"),
185 arg1, arg2);
186 }
187
188 /* find_text_range --- find start and end of loadable code sections
189
190 The find_text_range function finds the shortest address range that
191 encloses all sections containing executable code, and stores it in
192 objfile's text_addr and text_size members.
193
194 dbx_symfile_read will use this to finish off the partial symbol
195 table, in some cases. */
196
197 static void
198 find_text_range (bfd * sym_bfd, struct objfile *objfile)
199 {
200 asection *sec;
201 int found_any = 0;
202 CORE_ADDR start = 0;
203 CORE_ADDR end = 0;
204
205 for (sec = sym_bfd->sections; sec; sec = sec->next)
206 if (bfd_section_flags (sec) & SEC_CODE)
207 {
208 CORE_ADDR sec_start = bfd_section_vma (sec);
209 CORE_ADDR sec_end = sec_start + bfd_section_size (sec);
210
211 if (found_any)
212 {
213 if (sec_start < start)
214 start = sec_start;
215 if (sec_end > end)
216 end = sec_end;
217 }
218 else
219 {
220 start = sec_start;
221 end = sec_end;
222 }
223
224 found_any = 1;
225 }
226
227 if (!found_any)
228 error (_("Can't find any code sections in symbol file"));
229
230 DBX_TEXT_ADDR (objfile) = start;
231 DBX_TEXT_SIZE (objfile) = end - start;
232 }
233 \f
234
235
236 /* During initial symbol readin, we need to have a structure to keep
237 track of which psymtabs have which bincls in them. This structure
238 is used during readin to setup the list of dependencies within each
239 partial symbol table. */
240
241 struct header_file_location
242 {
243 header_file_location (const char *name_, int instance_,
244 legacy_psymtab *pst_)
245 : name (name_),
246 instance (instance_),
247 pst (pst_)
248 {
249 }
250
251 const char *name; /* Name of header file */
252 int instance; /* See above */
253 legacy_psymtab *pst; /* Partial symtab that has the
254 BINCL/EINCL defs for this file. */
255 };
256
257 /* The list of bincls. */
258 static std::vector<struct header_file_location> *bincl_list;
259
260 /* Local function prototypes. */
261
262 static void read_ofile_symtab (struct objfile *, legacy_psymtab *);
263
264 static void dbx_read_symtab (legacy_psymtab *self,
265 struct objfile *objfile);
266
267 static void dbx_expand_psymtab (legacy_psymtab *, struct objfile *);
268
269 static void read_dbx_symtab (minimal_symbol_reader &, psymtab_storage *,
270 struct objfile *);
271
272 static legacy_psymtab *find_corresponding_bincl_psymtab (const char *,
273 int);
274
275 static const char *dbx_next_symbol_text (struct objfile *);
276
277 static void fill_symbuf (bfd *);
278
279 static void dbx_symfile_init (struct objfile *);
280
281 static void dbx_new_init (struct objfile *);
282
283 static void dbx_symfile_read (struct objfile *, symfile_add_flags);
284
285 static void dbx_symfile_finish (struct objfile *);
286
287 static void record_minimal_symbol (minimal_symbol_reader &,
288 const char *, CORE_ADDR, int,
289 struct objfile *);
290
291 static void add_new_header_file (const char *, int);
292
293 static void add_old_header_file (const char *, int);
294
295 static void add_this_object_header_file (int);
296
297 static legacy_psymtab *start_psymtab (psymtab_storage *, struct objfile *,
298 const char *, CORE_ADDR, int);
299
300 /* Free up old header file tables. */
301
302 void
303 free_header_files (void)
304 {
305 if (this_object_header_files)
306 {
307 xfree (this_object_header_files);
308 this_object_header_files = NULL;
309 }
310 n_allocated_this_object_header_files = 0;
311 }
312
313 /* Allocate new header file tables. */
314
315 void
316 init_header_files (void)
317 {
318 n_allocated_this_object_header_files = 10;
319 this_object_header_files = XNEWVEC (int, 10);
320 }
321
322 /* Add header file number I for this object file
323 at the next successive FILENUM. */
324
325 static void
326 add_this_object_header_file (int i)
327 {
328 if (n_this_object_header_files == n_allocated_this_object_header_files)
329 {
330 n_allocated_this_object_header_files *= 2;
331 this_object_header_files
332 = (int *) xrealloc ((char *) this_object_header_files,
333 n_allocated_this_object_header_files * sizeof (int));
334 }
335
336 this_object_header_files[n_this_object_header_files++] = i;
337 }
338
339 /* Add to this file an "old" header file, one already seen in
340 a previous object file. NAME is the header file's name.
341 INSTANCE is its instance code, to select among multiple
342 symbol tables for the same header file. */
343
344 static void
345 add_old_header_file (const char *name, int instance)
346 {
347 struct header_file *p = HEADER_FILES (dbxread_objfile);
348 int i;
349
350 for (i = 0; i < N_HEADER_FILES (dbxread_objfile); i++)
351 if (filename_cmp (p[i].name, name) == 0 && instance == p[i].instance)
352 {
353 add_this_object_header_file (i);
354 return;
355 }
356 repeated_header_complaint (name, symnum);
357 }
358
359 /* Add to this file a "new" header file: definitions for its types follow.
360 NAME is the header file's name.
361 Most often this happens only once for each distinct header file,
362 but not necessarily. If it happens more than once, INSTANCE has
363 a different value each time, and references to the header file
364 use INSTANCE values to select among them.
365
366 dbx output contains "begin" and "end" markers for each new header file,
367 but at this level we just need to know which files there have been;
368 so we record the file when its "begin" is seen and ignore the "end". */
369
370 static void
371 add_new_header_file (const char *name, int instance)
372 {
373 int i;
374 struct header_file *hfile;
375
376 /* Make sure there is room for one more header file. */
377
378 i = N_ALLOCATED_HEADER_FILES (dbxread_objfile);
379
380 if (N_HEADER_FILES (dbxread_objfile) == i)
381 {
382 if (i == 0)
383 {
384 N_ALLOCATED_HEADER_FILES (dbxread_objfile) = 10;
385 HEADER_FILES (dbxread_objfile) = (struct header_file *)
386 xmalloc (10 * sizeof (struct header_file));
387 }
388 else
389 {
390 i *= 2;
391 N_ALLOCATED_HEADER_FILES (dbxread_objfile) = i;
392 HEADER_FILES (dbxread_objfile) = (struct header_file *)
393 xrealloc ((char *) HEADER_FILES (dbxread_objfile),
394 (i * sizeof (struct header_file)));
395 }
396 }
397
398 /* Create an entry for this header file. */
399
400 i = N_HEADER_FILES (dbxread_objfile)++;
401 hfile = HEADER_FILES (dbxread_objfile) + i;
402 hfile->name = xstrdup (name);
403 hfile->instance = instance;
404 hfile->length = 10;
405 hfile->vector = XCNEWVEC (struct type *, 10);
406
407 add_this_object_header_file (i);
408 }
409
410 #if 0
411 static struct type **
412 explicit_lookup_type (int real_filenum, int index)
413 {
414 struct header_file *f = &HEADER_FILES (dbxread_objfile)[real_filenum];
415
416 if (index >= f->length)
417 {
418 f->length *= 2;
419 f->vector = (struct type **)
420 xrealloc (f->vector, f->length * sizeof (struct type *));
421 memset (&f->vector[f->length / 2],
422 '\0', f->length * sizeof (struct type *) / 2);
423 }
424 return &f->vector[index];
425 }
426 #endif
427 \f
428 static void
429 record_minimal_symbol (minimal_symbol_reader &reader,
430 const char *name, CORE_ADDR address, int type,
431 struct objfile *objfile)
432 {
433 enum minimal_symbol_type ms_type;
434 int section;
435
436 switch (type)
437 {
438 case N_TEXT | N_EXT:
439 ms_type = mst_text;
440 section = SECT_OFF_TEXT (objfile);
441 break;
442 case N_DATA | N_EXT:
443 ms_type = mst_data;
444 section = SECT_OFF_DATA (objfile);
445 break;
446 case N_BSS | N_EXT:
447 ms_type = mst_bss;
448 section = SECT_OFF_BSS (objfile);
449 break;
450 case N_ABS | N_EXT:
451 ms_type = mst_abs;
452 section = -1;
453 break;
454 #ifdef N_SETV
455 case N_SETV | N_EXT:
456 ms_type = mst_data;
457 section = SECT_OFF_DATA (objfile);
458 break;
459 case N_SETV:
460 /* I don't think this type actually exists; since a N_SETV is the result
461 of going over many .o files, it doesn't make sense to have one
462 file local. */
463 ms_type = mst_file_data;
464 section = SECT_OFF_DATA (objfile);
465 break;
466 #endif
467 case N_TEXT:
468 case N_NBTEXT:
469 case N_FN:
470 case N_FN_SEQ:
471 ms_type = mst_file_text;
472 section = SECT_OFF_TEXT (objfile);
473 break;
474 case N_DATA:
475 ms_type = mst_file_data;
476
477 /* Check for __DYNAMIC, which is used by Sun shared libraries.
478 Record it as global even if it's local, not global, so
479 lookup_minimal_symbol can find it. We don't check symbol_leading_char
480 because for SunOS4 it always is '_'. */
481 if (name[8] == 'C' && strcmp ("__DYNAMIC", name) == 0)
482 ms_type = mst_data;
483
484 /* Same with virtual function tables, both global and static. */
485 {
486 const char *tempstring = name;
487
488 if (tempstring[0] == bfd_get_symbol_leading_char (objfile->obfd))
489 ++tempstring;
490 if (is_vtable_name (tempstring))
491 ms_type = mst_data;
492 }
493 section = SECT_OFF_DATA (objfile);
494 break;
495 case N_BSS:
496 ms_type = mst_file_bss;
497 section = SECT_OFF_BSS (objfile);
498 break;
499 default:
500 ms_type = mst_unknown;
501 section = -1;
502 break;
503 }
504
505 if ((ms_type == mst_file_text || ms_type == mst_text)
506 && address < lowest_text_address)
507 lowest_text_address = address;
508
509 reader.record_with_info (name, address, ms_type, section);
510 }
511 \f
512 /* Scan and build partial symbols for a symbol file.
513 We have been initialized by a call to dbx_symfile_init, which
514 put all the relevant info into a "struct dbx_symfile_info",
515 hung off the objfile structure. */
516
517 static void
518 dbx_symfile_read (struct objfile *objfile, symfile_add_flags symfile_flags)
519 {
520 bfd *sym_bfd;
521 int val;
522
523 sym_bfd = objfile->obfd;
524
525 /* .o and .nlm files are relocatables with text, data and bss segs based at
526 0. This flag disables special (Solaris stabs-in-elf only) fixups for
527 symbols with a value of 0. */
528
529 symfile_relocatable = bfd_get_file_flags (sym_bfd) & HAS_RELOC;
530
531 val = bfd_seek (sym_bfd, DBX_SYMTAB_OFFSET (objfile), SEEK_SET);
532 if (val < 0)
533 perror_with_name (objfile_name (objfile));
534
535 symbol_size = DBX_SYMBOL_SIZE (objfile);
536 symbol_table_offset = DBX_SYMTAB_OFFSET (objfile);
537
538 scoped_free_pendings free_pending;
539
540 minimal_symbol_reader reader (objfile);
541
542 /* Read stabs data from executable file and define symbols. */
543
544 psymbol_functions *psf = new psymbol_functions ();
545 psymtab_storage *partial_symtabs = psf->get_partial_symtabs ().get ();
546 objfile->qf.emplace_front (psf);
547 read_dbx_symtab (reader, partial_symtabs, objfile);
548
549 /* Install any minimal symbols that have been collected as the current
550 minimal symbols for this objfile. */
551
552 reader.install ();
553 }
554
555 /* Initialize anything that needs initializing when a completely new
556 symbol file is specified (not just adding some symbols from another
557 file, e.g. a shared library). */
558
559 static void
560 dbx_new_init (struct objfile *ignore)
561 {
562 stabsread_new_init ();
563 init_header_files ();
564 }
565
566
567 /* dbx_symfile_init ()
568 is the dbx-specific initialization routine for reading symbols.
569 It is passed a struct objfile which contains, among other things,
570 the BFD for the file whose symbols are being read, and a slot for a pointer
571 to "private data" which we fill with goodies.
572
573 We read the string table into malloc'd space and stash a pointer to it.
574
575 Since BFD doesn't know how to read debug symbols in a format-independent
576 way (and may never do so...), we have to do it ourselves. We will never
577 be called unless this is an a.out (or very similar) file.
578 FIXME, there should be a cleaner peephole into the BFD environment here. */
579
580 #define DBX_STRINGTAB_SIZE_SIZE sizeof(long) /* FIXME */
581
582 static void
583 dbx_symfile_init (struct objfile *objfile)
584 {
585 int val;
586 bfd *sym_bfd = objfile->obfd;
587 const char *name = bfd_get_filename (sym_bfd);
588 asection *text_sect;
589 unsigned char size_temp[DBX_STRINGTAB_SIZE_SIZE];
590
591 /* Allocate struct to keep track of the symfile. */
592 dbx_objfile_data_key.emplace (objfile);
593
594 DBX_TEXT_SECTION (objfile) = bfd_get_section_by_name (sym_bfd, ".text");
595 DBX_DATA_SECTION (objfile) = bfd_get_section_by_name (sym_bfd, ".data");
596 DBX_BSS_SECTION (objfile) = bfd_get_section_by_name (sym_bfd, ".bss");
597
598 /* FIXME POKING INSIDE BFD DATA STRUCTURES. */
599 #define STRING_TABLE_OFFSET (sym_bfd->origin + obj_str_filepos (sym_bfd))
600 #define SYMBOL_TABLE_OFFSET (sym_bfd->origin + obj_sym_filepos (sym_bfd))
601
602 /* FIXME POKING INSIDE BFD DATA STRUCTURES. */
603
604 text_sect = bfd_get_section_by_name (sym_bfd, ".text");
605 if (!text_sect)
606 error (_("Can't find .text section in symbol file"));
607 DBX_TEXT_ADDR (objfile) = bfd_section_vma (text_sect);
608 DBX_TEXT_SIZE (objfile) = bfd_section_size (text_sect);
609
610 DBX_SYMBOL_SIZE (objfile) = obj_symbol_entry_size (sym_bfd);
611 DBX_SYMCOUNT (objfile) = bfd_get_symcount (sym_bfd);
612 DBX_SYMTAB_OFFSET (objfile) = SYMBOL_TABLE_OFFSET;
613
614 /* Read the string table and stash it away in the objfile_obstack.
615 When we blow away the objfile the string table goes away as well.
616 Note that gdb used to use the results of attempting to malloc the
617 string table, based on the size it read, as a form of sanity check
618 for botched byte swapping, on the theory that a byte swapped string
619 table size would be so totally bogus that the malloc would fail. Now
620 that we put in on the objfile_obstack, we can't do this since gdb gets
621 a fatal error (out of virtual memory) if the size is bogus. We can
622 however at least check to see if the size is less than the size of
623 the size field itself, or larger than the size of the entire file.
624 Note that all valid string tables have a size greater than zero, since
625 the bytes used to hold the size are included in the count. */
626
627 if (STRING_TABLE_OFFSET == 0)
628 {
629 /* It appears that with the existing bfd code, STRING_TABLE_OFFSET
630 will never be zero, even when there is no string table. This
631 would appear to be a bug in bfd. */
632 DBX_STRINGTAB_SIZE (objfile) = 0;
633 DBX_STRINGTAB (objfile) = NULL;
634 }
635 else
636 {
637 val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, SEEK_SET);
638 if (val < 0)
639 perror_with_name (name);
640
641 memset (size_temp, 0, sizeof (size_temp));
642 val = bfd_bread (size_temp, sizeof (size_temp), sym_bfd);
643 if (val < 0)
644 {
645 perror_with_name (name);
646 }
647 else if (val == 0)
648 {
649 /* With the existing bfd code, STRING_TABLE_OFFSET will be set to
650 EOF if there is no string table, and attempting to read the size
651 from EOF will read zero bytes. */
652 DBX_STRINGTAB_SIZE (objfile) = 0;
653 DBX_STRINGTAB (objfile) = NULL;
654 }
655 else
656 {
657 /* Read some data that would appear to be the string table size.
658 If there really is a string table, then it is probably the right
659 size. Byteswap if necessary and validate the size. Note that
660 the minimum is DBX_STRINGTAB_SIZE_SIZE. If we just read some
661 random data that happened to be at STRING_TABLE_OFFSET, because
662 bfd can't tell us there is no string table, the sanity checks may
663 or may not catch this. */
664 DBX_STRINGTAB_SIZE (objfile) = bfd_h_get_32 (sym_bfd, size_temp);
665
666 if (DBX_STRINGTAB_SIZE (objfile) < sizeof (size_temp)
667 || DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
668 error (_("ridiculous string table size (%d bytes)."),
669 DBX_STRINGTAB_SIZE (objfile));
670
671 DBX_STRINGTAB (objfile) =
672 (char *) obstack_alloc (&objfile->objfile_obstack,
673 DBX_STRINGTAB_SIZE (objfile));
674 OBJSTAT (objfile, sz_strtab += DBX_STRINGTAB_SIZE (objfile));
675
676 /* Now read in the string table in one big gulp. */
677
678 val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, SEEK_SET);
679 if (val < 0)
680 perror_with_name (name);
681 val = bfd_bread (DBX_STRINGTAB (objfile),
682 DBX_STRINGTAB_SIZE (objfile),
683 sym_bfd);
684 if (val != DBX_STRINGTAB_SIZE (objfile))
685 perror_with_name (name);
686 }
687 }
688 }
689
690 /* Perform any local cleanups required when we are done with a particular
691 objfile. I.E, we are in the process of discarding all symbol information
692 for an objfile, freeing up all memory held for it, and unlinking the
693 objfile struct from the global list of known objfiles. */
694
695 static void
696 dbx_symfile_finish (struct objfile *objfile)
697 {
698 free_header_files ();
699 }
700
701 dbx_symfile_info::~dbx_symfile_info ()
702 {
703 if (header_files != NULL)
704 {
705 int i = n_header_files;
706 struct header_file *hfiles = header_files;
707
708 while (--i >= 0)
709 {
710 xfree (hfiles[i].name);
711 xfree (hfiles[i].vector);
712 }
713 xfree (hfiles);
714 }
715 }
716
717 \f
718
719 /* Buffer for reading the symbol table entries. */
720 static struct external_nlist symbuf[4096];
721 static int symbuf_idx;
722 static int symbuf_end;
723
724 /* Name of last function encountered. Used in Solaris to approximate
725 object file boundaries. */
726 static const char *last_function_name;
727
728 /* The address in memory of the string table of the object file we are
729 reading (which might not be the "main" object file, but might be a
730 shared library or some other dynamically loaded thing). This is
731 set by read_dbx_symtab when building psymtabs, and by
732 read_ofile_symtab when building symtabs, and is used only by
733 next_symbol_text. FIXME: If that is true, we don't need it when
734 building psymtabs, right? */
735 static char *stringtab_global;
736
737 /* These variables are used to control fill_symbuf when the stabs
738 symbols are not contiguous (as may be the case when a COFF file is
739 linked using --split-by-reloc). */
740 static const std::vector<asection *> *symbuf_sections;
741 static size_t sect_idx;
742 static unsigned int symbuf_left;
743 static unsigned int symbuf_read;
744
745 /* This variable stores a global stabs buffer, if we read stabs into
746 memory in one chunk in order to process relocations. */
747 static bfd_byte *stabs_data;
748
749 /* Refill the symbol table input buffer
750 and set the variables that control fetching entries from it.
751 Reports an error if no data available.
752 This function can read past the end of the symbol table
753 (into the string table) but this does no harm. */
754
755 static void
756 fill_symbuf (bfd *sym_bfd)
757 {
758 unsigned int count;
759 int nbytes;
760
761 if (stabs_data)
762 {
763 nbytes = sizeof (symbuf);
764 if (nbytes > symbuf_left)
765 nbytes = symbuf_left;
766 memcpy (symbuf, stabs_data + symbuf_read, nbytes);
767 }
768 else if (symbuf_sections == NULL)
769 {
770 count = sizeof (symbuf);
771 nbytes = bfd_bread (symbuf, count, sym_bfd);
772 }
773 else
774 {
775 if (symbuf_left <= 0)
776 {
777 file_ptr filepos = (*symbuf_sections)[sect_idx]->filepos;
778
779 if (bfd_seek (sym_bfd, filepos, SEEK_SET) != 0)
780 perror_with_name (bfd_get_filename (sym_bfd));
781 symbuf_left = bfd_section_size ((*symbuf_sections)[sect_idx]);
782 symbol_table_offset = filepos - symbuf_read;
783 ++sect_idx;
784 }
785
786 count = symbuf_left;
787 if (count > sizeof (symbuf))
788 count = sizeof (symbuf);
789 nbytes = bfd_bread (symbuf, count, sym_bfd);
790 }
791
792 if (nbytes < 0)
793 perror_with_name (bfd_get_filename (sym_bfd));
794 else if (nbytes == 0)
795 error (_("Premature end of file reading symbol table"));
796 symbuf_end = nbytes / symbol_size;
797 symbuf_idx = 0;
798 symbuf_left -= nbytes;
799 symbuf_read += nbytes;
800 }
801
802 static void
803 stabs_seek (int sym_offset)
804 {
805 if (stabs_data)
806 {
807 symbuf_read += sym_offset;
808 symbuf_left -= sym_offset;
809 }
810 else
811 bfd_seek (symfile_bfd, sym_offset, SEEK_CUR);
812 }
813
814 #define INTERNALIZE_SYMBOL(intern, extern, abfd) \
815 { \
816 (intern).n_strx = bfd_h_get_32 (abfd, (extern)->e_strx); \
817 (intern).n_type = bfd_h_get_8 (abfd, (extern)->e_type); \
818 (intern).n_other = 0; \
819 (intern).n_desc = bfd_h_get_16 (abfd, (extern)->e_desc); \
820 if (bfd_get_sign_extend_vma (abfd)) \
821 (intern).n_value = bfd_h_get_signed_32 (abfd, (extern)->e_value); \
822 else \
823 (intern).n_value = bfd_h_get_32 (abfd, (extern)->e_value); \
824 }
825
826 /* Invariant: The symbol pointed to by symbuf_idx is the first one
827 that hasn't been swapped. Swap the symbol at the same time
828 that symbuf_idx is incremented. */
829
830 /* dbx allows the text of a symbol name to be continued into the
831 next symbol name! When such a continuation is encountered
832 (a \ at the end of the text of a name)
833 call this function to get the continuation. */
834
835 static const char *
836 dbx_next_symbol_text (struct objfile *objfile)
837 {
838 struct internal_nlist nlist;
839
840 if (symbuf_idx == symbuf_end)
841 fill_symbuf (symfile_bfd);
842
843 symnum++;
844 INTERNALIZE_SYMBOL (nlist, &symbuf[symbuf_idx], symfile_bfd);
845 OBJSTAT (objfile, n_stabs++);
846
847 symbuf_idx++;
848
849 return nlist.n_strx + stringtab_global + file_string_table_offset;
850 }
851 \f
852
853 /* Given a name, value pair, find the corresponding
854 bincl in the list. Return the partial symtab associated
855 with that header_file_location. */
856
857 static legacy_psymtab *
858 find_corresponding_bincl_psymtab (const char *name, int instance)
859 {
860 for (const header_file_location &bincl : *bincl_list)
861 if (bincl.instance == instance
862 && strcmp (name, bincl.name) == 0)
863 return bincl.pst;
864
865 repeated_header_complaint (name, symnum);
866 return (legacy_psymtab *) 0;
867 }
868
869 /* Set namestring based on nlist. If the string table index is invalid,
870 give a fake name, and print a single error message per symbol file read,
871 rather than abort the symbol reading or flood the user with messages. */
872
873 static const char *
874 set_namestring (struct objfile *objfile, const struct internal_nlist *nlist)
875 {
876 const char *namestring;
877
878 if (nlist->n_strx + file_string_table_offset
879 >= DBX_STRINGTAB_SIZE (objfile)
880 || nlist->n_strx + file_string_table_offset < nlist->n_strx)
881 {
882 complaint (_("bad string table offset in symbol %d"),
883 symnum);
884 namestring = "<bad string table offset>";
885 }
886 else
887 namestring = (nlist->n_strx + file_string_table_offset
888 + DBX_STRINGTAB (objfile));
889 return namestring;
890 }
891
892 static struct bound_minimal_symbol
893 find_stab_function (const char *namestring, const char *filename,
894 struct objfile *objfile)
895 {
896 struct bound_minimal_symbol msym;
897 int n;
898
899 const char *colon = strchr (namestring, ':');
900 if (colon == NULL)
901 n = 0;
902 else
903 n = colon - namestring;
904
905 char *p = (char *) alloca (n + 2);
906 strncpy (p, namestring, n);
907 p[n] = 0;
908
909 msym = lookup_minimal_symbol (p, filename, objfile);
910 if (msym.minsym == NULL)
911 {
912 /* Sun Fortran appends an underscore to the minimal symbol name,
913 try again with an appended underscore if the minimal symbol
914 was not found. */
915 p[n] = '_';
916 p[n + 1] = 0;
917 msym = lookup_minimal_symbol (p, filename, objfile);
918 }
919
920 if (msym.minsym == NULL && filename != NULL)
921 {
922 /* Try again without the filename. */
923 p[n] = 0;
924 msym = lookup_minimal_symbol (p, NULL, objfile);
925 }
926 if (msym.minsym == NULL && filename != NULL)
927 {
928 /* And try again for Sun Fortran, but without the filename. */
929 p[n] = '_';
930 p[n + 1] = 0;
931 msym = lookup_minimal_symbol (p, NULL, objfile);
932 }
933
934 return msym;
935 }
936
937 static void
938 function_outside_compilation_unit_complaint (const char *arg1)
939 {
940 complaint (_("function `%s' appears to be defined "
941 "outside of all compilation units"),
942 arg1);
943 }
944
945 /* Setup partial_symtab's describing each source file for which
946 debugging information is available. */
947
948 static void
949 read_dbx_symtab (minimal_symbol_reader &reader,
950 psymtab_storage *partial_symtabs,
951 struct objfile *objfile)
952 {
953 struct gdbarch *gdbarch = objfile->arch ();
954 struct external_nlist *bufp = 0; /* =0 avoids gcc -Wall glitch. */
955 struct internal_nlist nlist;
956 CORE_ADDR text_addr;
957 int text_size;
958 const char *sym_name;
959 int sym_len;
960
961 const char *namestring;
962 int nsl;
963 int past_first_source_file = 0;
964 CORE_ADDR last_function_start = 0;
965 bfd *abfd;
966 int textlow_not_set;
967 int data_sect_index;
968
969 /* Current partial symtab. */
970 legacy_psymtab *pst;
971
972 /* List of current psymtab's include files. */
973 const char **psymtab_include_list;
974 int includes_allocated;
975 int includes_used;
976
977 /* Index within current psymtab dependency list. */
978 legacy_psymtab **dependency_list;
979 int dependencies_used, dependencies_allocated;
980
981 text_addr = DBX_TEXT_ADDR (objfile);
982 text_size = DBX_TEXT_SIZE (objfile);
983
984 /* FIXME. We probably want to change stringtab_global rather than add this
985 while processing every symbol entry. FIXME. */
986 file_string_table_offset = 0;
987 next_file_string_table_offset = 0;
988
989 stringtab_global = DBX_STRINGTAB (objfile);
990
991 pst = (legacy_psymtab *) 0;
992
993 includes_allocated = 30;
994 includes_used = 0;
995 psymtab_include_list = (const char **) alloca (includes_allocated *
996 sizeof (const char *));
997
998 dependencies_allocated = 30;
999 dependencies_used = 0;
1000 dependency_list =
1001 (legacy_psymtab **) alloca (dependencies_allocated *
1002 sizeof (legacy_psymtab *));
1003
1004 /* Init bincl list */
1005 std::vector<struct header_file_location> bincl_storage;
1006 scoped_restore restore_bincl_global
1007 = make_scoped_restore (&bincl_list, &bincl_storage);
1008
1009 set_last_source_file (NULL);
1010
1011 lowest_text_address = (CORE_ADDR) -1;
1012
1013 symfile_bfd = objfile->obfd; /* For next_text_symbol. */
1014 abfd = objfile->obfd;
1015 symbuf_end = symbuf_idx = 0;
1016 next_symbol_text_func = dbx_next_symbol_text;
1017 textlow_not_set = 1;
1018 has_line_numbers = 0;
1019
1020 /* FIXME: jimb/2003-09-12: We don't apply the right section's offset
1021 to global and static variables. The stab for a global or static
1022 variable doesn't give us any indication of which section it's in,
1023 so we can't tell immediately which offset in
1024 objfile->section_offsets we should apply to the variable's
1025 address.
1026
1027 We could certainly find out which section contains the variable
1028 by looking up the variable's unrelocated address with
1029 find_pc_section, but that would be expensive; this is the
1030 function that constructs the partial symbol tables by examining
1031 every symbol in the entire executable, and it's
1032 performance-critical. So that expense would not be welcome. I'm
1033 not sure what to do about this at the moment.
1034
1035 What we have done for years is to simply assume that the .data
1036 section's offset is appropriate for all global and static
1037 variables. Recently, this was expanded to fall back to the .bss
1038 section's offset if there is no .data section, and then to the
1039 .rodata section's offset. */
1040 data_sect_index = objfile->sect_index_data;
1041 if (data_sect_index == -1)
1042 data_sect_index = SECT_OFF_BSS (objfile);
1043 if (data_sect_index == -1)
1044 data_sect_index = SECT_OFF_RODATA (objfile);
1045
1046 /* If data_sect_index is still -1, that's okay. It's perfectly fine
1047 for the file to have no .data, no .bss, and no .text at all, if
1048 it also has no global or static variables. */
1049
1050 for (symnum = 0; symnum < DBX_SYMCOUNT (objfile); symnum++)
1051 {
1052 /* Get the symbol for this run and pull out some info. */
1053 QUIT; /* Allow this to be interruptable. */
1054 if (symbuf_idx == symbuf_end)
1055 fill_symbuf (abfd);
1056 bufp = &symbuf[symbuf_idx++];
1057
1058 /*
1059 * Special case to speed up readin.
1060 */
1061 if (bfd_h_get_8 (abfd, bufp->e_type) == N_SLINE)
1062 {
1063 has_line_numbers = 1;
1064 continue;
1065 }
1066
1067 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
1068 OBJSTAT (objfile, n_stabs++);
1069
1070 /* Ok. There is a lot of code duplicated in the rest of this
1071 switch statement (for efficiency reasons). Since I don't
1072 like duplicating code, I will do my penance here, and
1073 describe the code which is duplicated:
1074
1075 *) The assignment to namestring.
1076 *) The call to strchr.
1077 *) The addition of a partial symbol the two partial
1078 symbol lists. This last is a large section of code, so
1079 I've imbedded it in the following macro. */
1080
1081 switch (nlist.n_type)
1082 {
1083 /*
1084 * Standard, external, non-debugger, symbols
1085 */
1086
1087 case N_TEXT | N_EXT:
1088 case N_NBTEXT | N_EXT:
1089 goto record_it;
1090
1091 case N_DATA | N_EXT:
1092 case N_NBDATA | N_EXT:
1093 goto record_it;
1094
1095 case N_BSS:
1096 case N_BSS | N_EXT:
1097 case N_NBBSS | N_EXT:
1098 case N_SETV | N_EXT: /* FIXME, is this in BSS? */
1099 goto record_it;
1100
1101 case N_ABS | N_EXT:
1102 record_it:
1103 namestring = set_namestring (objfile, &nlist);
1104
1105 record_minimal_symbol (reader, namestring, nlist.n_value,
1106 nlist.n_type, objfile); /* Always */
1107 continue;
1108
1109 /* Standard, local, non-debugger, symbols. */
1110
1111 case N_NBTEXT:
1112
1113 /* We need to be able to deal with both N_FN or N_TEXT,
1114 because we have no way of knowing whether the sys-supplied ld
1115 or GNU ld was used to make the executable. Sequents throw
1116 in another wrinkle -- they renumbered N_FN. */
1117
1118 case N_FN:
1119 case N_FN_SEQ:
1120 case N_TEXT:
1121 namestring = set_namestring (objfile, &nlist);
1122
1123 if ((namestring[0] == '-' && namestring[1] == 'l')
1124 || (namestring[(nsl = strlen (namestring)) - 1] == 'o'
1125 && namestring[nsl - 2] == '.'))
1126 {
1127 if (past_first_source_file && pst
1128 /* The gould NP1 uses low values for .o and -l symbols
1129 which are not the address. */
1130 && nlist.n_value >= pst->raw_text_low ())
1131 {
1132 dbx_end_psymtab (objfile, partial_symtabs,
1133 pst, psymtab_include_list,
1134 includes_used, symnum * symbol_size,
1135 nlist.n_value > pst->raw_text_high ()
1136 ? nlist.n_value : pst->raw_text_high (),
1137 dependency_list, dependencies_used,
1138 textlow_not_set);
1139 pst = (legacy_psymtab *) 0;
1140 includes_used = 0;
1141 dependencies_used = 0;
1142 has_line_numbers = 0;
1143 }
1144 else
1145 past_first_source_file = 1;
1146 }
1147 else
1148 goto record_it;
1149 continue;
1150
1151 case N_DATA:
1152 goto record_it;
1153
1154 case N_UNDF | N_EXT:
1155 /* The case (nlist.n_value != 0) is a "Fortran COMMON" symbol.
1156 We used to rely on the target to tell us whether it knows
1157 where the symbol has been relocated to, but none of the
1158 target implementations actually provided that operation.
1159 So we just ignore the symbol, the same way we would do if
1160 we had a target-side symbol lookup which returned no match.
1161
1162 All other symbols (with nlist.n_value == 0), are really
1163 undefined, and so we ignore them too. */
1164 continue;
1165
1166 case N_UNDF:
1167 if (processing_acc_compilation && nlist.n_strx == 1)
1168 {
1169 /* Deal with relative offsets in the string table
1170 used in ELF+STAB under Solaris. If we want to use the
1171 n_strx field, which contains the name of the file,
1172 we must adjust file_string_table_offset *before* calling
1173 set_namestring(). */
1174 past_first_source_file = 1;
1175 file_string_table_offset = next_file_string_table_offset;
1176 next_file_string_table_offset =
1177 file_string_table_offset + nlist.n_value;
1178 if (next_file_string_table_offset < file_string_table_offset)
1179 error (_("string table offset backs up at %d"), symnum);
1180 /* FIXME -- replace error() with complaint. */
1181 continue;
1182 }
1183 continue;
1184
1185 /* Lots of symbol types we can just ignore. */
1186
1187 case N_ABS:
1188 case N_NBDATA:
1189 case N_NBBSS:
1190 continue;
1191
1192 /* Keep going . . . */
1193
1194 /*
1195 * Special symbol types for GNU
1196 */
1197 case N_INDR:
1198 case N_INDR | N_EXT:
1199 case N_SETA:
1200 case N_SETA | N_EXT:
1201 case N_SETT:
1202 case N_SETT | N_EXT:
1203 case N_SETD:
1204 case N_SETD | N_EXT:
1205 case N_SETB:
1206 case N_SETB | N_EXT:
1207 case N_SETV:
1208 continue;
1209
1210 /*
1211 * Debugger symbols
1212 */
1213
1214 case N_SO:
1215 {
1216 CORE_ADDR valu;
1217 static int prev_so_symnum = -10;
1218 static int first_so_symnum;
1219 const char *p;
1220 static const char *dirname_nso;
1221 int prev_textlow_not_set;
1222
1223 valu = nlist.n_value;
1224
1225 prev_textlow_not_set = textlow_not_set;
1226
1227 /* A zero value is probably an indication for the SunPRO 3.0
1228 compiler. dbx_end_psymtab explicitly tests for zero, so
1229 don't relocate it. */
1230
1231 if (nlist.n_value == 0
1232 && gdbarch_sofun_address_maybe_missing (gdbarch))
1233 {
1234 textlow_not_set = 1;
1235 valu = 0;
1236 }
1237 else
1238 textlow_not_set = 0;
1239
1240 past_first_source_file = 1;
1241
1242 if (prev_so_symnum != symnum - 1)
1243 { /* Here if prev stab wasn't N_SO. */
1244 first_so_symnum = symnum;
1245
1246 if (pst)
1247 {
1248 dbx_end_psymtab (objfile, partial_symtabs,
1249 pst, psymtab_include_list,
1250 includes_used, symnum * symbol_size,
1251 (valu > pst->raw_text_high ()
1252 ? valu : pst->raw_text_high ()),
1253 dependency_list, dependencies_used,
1254 prev_textlow_not_set);
1255 pst = (legacy_psymtab *) 0;
1256 includes_used = 0;
1257 dependencies_used = 0;
1258 has_line_numbers = 0;
1259 }
1260 }
1261
1262 prev_so_symnum = symnum;
1263
1264 /* End the current partial symtab and start a new one. */
1265
1266 namestring = set_namestring (objfile, &nlist);
1267
1268 /* Null name means end of .o file. Don't start a new one. */
1269 if (*namestring == '\000')
1270 continue;
1271
1272 /* Some compilers (including gcc) emit a pair of initial N_SOs.
1273 The first one is a directory name; the second the file name.
1274 If pst exists, is empty, and has a filename ending in '/',
1275 we assume the previous N_SO was a directory name. */
1276
1277 p = lbasename (namestring);
1278 if (p != namestring && *p == '\000')
1279 {
1280 /* Save the directory name SOs locally, then save it into
1281 the psymtab when it's created below. */
1282 dirname_nso = namestring;
1283 continue;
1284 }
1285
1286 /* Some other compilers (C++ ones in particular) emit useless
1287 SOs for non-existant .c files. We ignore all subsequent SOs
1288 that immediately follow the first. */
1289
1290 if (!pst)
1291 {
1292 pst = start_psymtab (partial_symtabs, objfile,
1293 namestring, valu,
1294 first_so_symnum * symbol_size);
1295 pst->dirname = dirname_nso;
1296 dirname_nso = NULL;
1297 }
1298 continue;
1299 }
1300
1301 case N_BINCL:
1302 {
1303 enum language tmp_language;
1304
1305 /* Add this bincl to the bincl_list for future EXCLs. No
1306 need to save the string; it'll be around until
1307 read_dbx_symtab function returns. */
1308
1309 namestring = set_namestring (objfile, &nlist);
1310 tmp_language = deduce_language_from_filename (namestring);
1311
1312 /* Only change the psymtab's language if we've learned
1313 something useful (eg. tmp_language is not language_unknown).
1314 In addition, to match what start_subfile does, never change
1315 from C++ to C. */
1316 if (tmp_language != language_unknown
1317 && (tmp_language != language_c
1318 || psymtab_language != language_cplus))
1319 psymtab_language = tmp_language;
1320
1321 if (pst == NULL)
1322 {
1323 /* FIXME: we should not get here without a PST to work on.
1324 Attempt to recover. */
1325 complaint (_("N_BINCL %s not in entries for "
1326 "any file, at symtab pos %d"),
1327 namestring, symnum);
1328 continue;
1329 }
1330 bincl_list->emplace_back (namestring, nlist.n_value, pst);
1331
1332 /* Mark down an include file in the current psymtab. */
1333
1334 goto record_include_file;
1335 }
1336
1337 case N_SOL:
1338 {
1339 enum language tmp_language;
1340
1341 /* Mark down an include file in the current psymtab. */
1342 namestring = set_namestring (objfile, &nlist);
1343 tmp_language = deduce_language_from_filename (namestring);
1344
1345 /* Only change the psymtab's language if we've learned
1346 something useful (eg. tmp_language is not language_unknown).
1347 In addition, to match what start_subfile does, never change
1348 from C++ to C. */
1349 if (tmp_language != language_unknown
1350 && (tmp_language != language_c
1351 || psymtab_language != language_cplus))
1352 psymtab_language = tmp_language;
1353
1354 /* In C++, one may expect the same filename to come round many
1355 times, when code is coming alternately from the main file
1356 and from inline functions in other files. So I check to see
1357 if this is a file we've seen before -- either the main
1358 source file, or a previously included file.
1359
1360 This seems to be a lot of time to be spending on N_SOL, but
1361 things like "break c-exp.y:435" need to work (I
1362 suppose the psymtab_include_list could be hashed or put
1363 in a binary tree, if profiling shows this is a major hog). */
1364 if (pst && filename_cmp (namestring, pst->filename) == 0)
1365 continue;
1366 {
1367 int i;
1368
1369 for (i = 0; i < includes_used; i++)
1370 if (filename_cmp (namestring, psymtab_include_list[i]) == 0)
1371 {
1372 i = -1;
1373 break;
1374 }
1375 if (i == -1)
1376 continue;
1377 }
1378
1379 record_include_file:
1380
1381 psymtab_include_list[includes_used++] = namestring;
1382 if (includes_used >= includes_allocated)
1383 {
1384 const char **orig = psymtab_include_list;
1385
1386 psymtab_include_list = (const char **)
1387 alloca ((includes_allocated *= 2) * sizeof (const char *));
1388 memcpy (psymtab_include_list, orig,
1389 includes_used * sizeof (const char *));
1390 }
1391 continue;
1392 }
1393 case N_LSYM: /* Typedef or automatic variable. */
1394 case N_STSYM: /* Data seg var -- static. */
1395 case N_LCSYM: /* BSS " */
1396 case N_ROSYM: /* Read-only data seg var -- static. */
1397 case N_NBSTS: /* Gould nobase. */
1398 case N_NBLCS: /* symbols. */
1399 case N_FUN:
1400 case N_GSYM: /* Global (extern) variable; can be
1401 data or bss (sigh FIXME). */
1402
1403 /* Following may probably be ignored; I'll leave them here
1404 for now (until I do Pascal and Modula 2 extensions). */
1405
1406 case N_PC: /* I may or may not need this; I
1407 suspect not. */
1408 case N_M2C: /* I suspect that I can ignore this here. */
1409 case N_SCOPE: /* Same. */
1410 {
1411 const char *p;
1412
1413 namestring = set_namestring (objfile, &nlist);
1414
1415 /* See if this is an end of function stab. */
1416 if (pst && nlist.n_type == N_FUN && *namestring == '\000')
1417 {
1418 CORE_ADDR valu;
1419
1420 /* It's value is the size (in bytes) of the function for
1421 function relative stabs, or the address of the function's
1422 end for old style stabs. */
1423 valu = nlist.n_value + last_function_start;
1424 if (pst->raw_text_high () == 0 || valu > pst->raw_text_high ())
1425 pst->set_text_high (valu);
1426 break;
1427 }
1428
1429 p = (char *) strchr (namestring, ':');
1430 if (!p)
1431 continue; /* Not a debugging symbol. */
1432
1433 sym_len = 0;
1434 sym_name = NULL; /* pacify "gcc -Werror" */
1435 if (psymtab_language == language_cplus)
1436 {
1437 std::string name (namestring, p - namestring);
1438 gdb::unique_xmalloc_ptr<char> new_name
1439 = cp_canonicalize_string (name.c_str ());
1440 if (new_name != nullptr)
1441 {
1442 sym_len = strlen (new_name.get ());
1443 sym_name = obstack_strdup (&objfile->objfile_obstack,
1444 new_name.get ());
1445 }
1446 }
1447
1448 if (sym_len == 0)
1449 {
1450 sym_name = namestring;
1451 sym_len = p - namestring;
1452 }
1453
1454 /* Main processing section for debugging symbols which
1455 the initial read through the symbol tables needs to worry
1456 about. If we reach this point, the symbol which we are
1457 considering is definitely one we are interested in.
1458 p must also contain the (valid) index into the namestring
1459 which indicates the debugging type symbol. */
1460
1461 switch (p[1])
1462 {
1463 case 'S':
1464 if (pst != nullptr)
1465 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1466 VAR_DOMAIN, LOC_STATIC,
1467 data_sect_index,
1468 psymbol_placement::STATIC,
1469 nlist.n_value, psymtab_language,
1470 partial_symtabs, objfile);
1471 else
1472 complaint (_("static `%*s' appears to be defined "
1473 "outside of all compilation units"),
1474 sym_len, sym_name);
1475 continue;
1476
1477 case 'G':
1478 /* The addresses in these entries are reported to be
1479 wrong. See the code that reads 'G's for symtabs. */
1480 if (pst != nullptr)
1481 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1482 VAR_DOMAIN, LOC_STATIC,
1483 data_sect_index,
1484 psymbol_placement::GLOBAL,
1485 nlist.n_value, psymtab_language,
1486 partial_symtabs, objfile);
1487 else
1488 complaint (_("global `%*s' appears to be defined "
1489 "outside of all compilation units"),
1490 sym_len, sym_name);
1491 continue;
1492
1493 case 'T':
1494 /* When a 'T' entry is defining an anonymous enum, it
1495 may have a name which is the empty string, or a
1496 single space. Since they're not really defining a
1497 symbol, those shouldn't go in the partial symbol
1498 table. We do pick up the elements of such enums at
1499 'check_enum:', below. */
1500 if (p >= namestring + 2
1501 || (p == namestring + 1
1502 && namestring[0] != ' '))
1503 {
1504 if (pst != nullptr)
1505 pst->add_psymbol (gdb::string_view (sym_name, sym_len),
1506 true, STRUCT_DOMAIN, LOC_TYPEDEF, -1,
1507 psymbol_placement::STATIC,
1508 0, psymtab_language,
1509 partial_symtabs, objfile);
1510 else
1511 complaint (_("enum, struct, or union `%*s' appears "
1512 "to be defined outside of all "
1513 "compilation units"),
1514 sym_len, sym_name);
1515 if (p[2] == 't')
1516 {
1517 /* Also a typedef with the same name. */
1518 if (pst != nullptr)
1519 pst->add_psymbol (gdb::string_view (sym_name, sym_len),
1520 true, VAR_DOMAIN, LOC_TYPEDEF, -1,
1521 psymbol_placement::STATIC,
1522 0, psymtab_language,
1523 partial_symtabs, objfile);
1524 else
1525 complaint (_("typedef `%*s' appears to be defined "
1526 "outside of all compilation units"),
1527 sym_len, sym_name);
1528 p += 1;
1529 }
1530 }
1531 goto check_enum;
1532
1533 case 't':
1534 if (p != namestring) /* a name is there, not just :T... */
1535 {
1536 if (pst != nullptr)
1537 pst->add_psymbol (gdb::string_view (sym_name, sym_len),
1538 true, VAR_DOMAIN, LOC_TYPEDEF, -1,
1539 psymbol_placement::STATIC,
1540 0, psymtab_language,
1541 partial_symtabs, objfile);
1542 else
1543 complaint (_("typename `%*s' appears to be defined "
1544 "outside of all compilation units"),
1545 sym_len, sym_name);
1546 }
1547 check_enum:
1548 /* If this is an enumerated type, we need to
1549 add all the enum constants to the partial symbol
1550 table. This does not cover enums without names, e.g.
1551 "enum {a, b} c;" in C, but fortunately those are
1552 rare. There is no way for GDB to find those from the
1553 enum type without spending too much time on it. Thus
1554 to solve this problem, the compiler needs to put out the
1555 enum in a nameless type. GCC2 does this. */
1556
1557 /* We are looking for something of the form
1558 <name> ":" ("t" | "T") [<number> "="] "e"
1559 {<constant> ":" <value> ","} ";". */
1560
1561 /* Skip over the colon and the 't' or 'T'. */
1562 p += 2;
1563 /* This type may be given a number. Also, numbers can come
1564 in pairs like (0,26). Skip over it. */
1565 while ((*p >= '0' && *p <= '9')
1566 || *p == '(' || *p == ',' || *p == ')'
1567 || *p == '=')
1568 p++;
1569
1570 if (*p++ == 'e')
1571 {
1572 /* The aix4 compiler emits extra crud before the members. */
1573 if (*p == '-')
1574 {
1575 /* Skip over the type (?). */
1576 while (*p != ':')
1577 p++;
1578
1579 /* Skip over the colon. */
1580 p++;
1581 }
1582
1583 /* We have found an enumerated type. */
1584 /* According to comments in read_enum_type
1585 a comma could end it instead of a semicolon.
1586 I don't know where that happens.
1587 Accept either. */
1588 while (*p && *p != ';' && *p != ',')
1589 {
1590 const char *q;
1591
1592 /* Check for and handle cretinous dbx symbol name
1593 continuation! */
1594 if (*p == '\\' || (*p == '?' && p[1] == '\0'))
1595 p = next_symbol_text (objfile);
1596
1597 /* Point to the character after the name
1598 of the enum constant. */
1599 for (q = p; *q && *q != ':'; q++)
1600 ;
1601 /* Note that the value doesn't matter for
1602 enum constants in psymtabs, just in symtabs. */
1603 if (pst != nullptr)
1604 pst->add_psymbol (gdb::string_view (p, q - p), true,
1605 VAR_DOMAIN, LOC_CONST, -1,
1606 psymbol_placement::STATIC, 0,
1607 psymtab_language,
1608 partial_symtabs, objfile);
1609 else
1610 complaint (_("enum constant `%*s' appears to be defined "
1611 "outside of all compilation units"),
1612 ((int) (q - p)), p);
1613 /* Point past the name. */
1614 p = q;
1615 /* Skip over the value. */
1616 while (*p && *p != ',')
1617 p++;
1618 /* Advance past the comma. */
1619 if (*p)
1620 p++;
1621 }
1622 }
1623 continue;
1624
1625 case 'c':
1626 /* Constant, e.g. from "const" in Pascal. */
1627 if (pst != nullptr)
1628 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1629 VAR_DOMAIN, LOC_CONST, -1,
1630 psymbol_placement::STATIC, 0,
1631 psymtab_language,
1632 partial_symtabs, objfile);
1633 else
1634 complaint (_("constant `%*s' appears to be defined "
1635 "outside of all compilation units"),
1636 sym_len, sym_name);
1637
1638 continue;
1639
1640 case 'f':
1641 if (! pst)
1642 {
1643 std::string name (namestring, (p - namestring));
1644 function_outside_compilation_unit_complaint (name.c_str ());
1645 }
1646 /* Kludges for ELF/STABS with Sun ACC. */
1647 last_function_name = namestring;
1648 /* Do not fix textlow==0 for .o or NLM files, as 0 is a legit
1649 value for the bottom of the text seg in those cases. */
1650 if (nlist.n_value == 0
1651 && gdbarch_sofun_address_maybe_missing (gdbarch))
1652 {
1653 struct bound_minimal_symbol minsym
1654 = find_stab_function (namestring,
1655 pst ? pst->filename : NULL,
1656 objfile);
1657 if (minsym.minsym != NULL)
1658 nlist.n_value = minsym.minsym->value_raw_address ();
1659 }
1660 if (pst && textlow_not_set
1661 && gdbarch_sofun_address_maybe_missing (gdbarch))
1662 {
1663 pst->set_text_low (nlist.n_value);
1664 textlow_not_set = 0;
1665 }
1666 /* End kludge. */
1667
1668 /* Keep track of the start of the last function so we
1669 can handle end of function symbols. */
1670 last_function_start = nlist.n_value;
1671
1672 /* In reordered executables this function may lie outside
1673 the bounds created by N_SO symbols. If that's the case
1674 use the address of this function as the low bound for
1675 the partial symbol table. */
1676 if (pst
1677 && (textlow_not_set
1678 || (nlist.n_value < pst->raw_text_low ()
1679 && (nlist.n_value != 0))))
1680 {
1681 pst->set_text_low (nlist.n_value);
1682 textlow_not_set = 0;
1683 }
1684 if (pst != nullptr)
1685 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1686 VAR_DOMAIN, LOC_BLOCK,
1687 SECT_OFF_TEXT (objfile),
1688 psymbol_placement::STATIC,
1689 nlist.n_value, psymtab_language,
1690 partial_symtabs, objfile);
1691 continue;
1692
1693 /* Global functions were ignored here, but now they
1694 are put into the global psymtab like one would expect.
1695 They're also in the minimal symbol table. */
1696 case 'F':
1697 if (! pst)
1698 {
1699 std::string name (namestring, (p - namestring));
1700 function_outside_compilation_unit_complaint (name.c_str ());
1701 }
1702 /* Kludges for ELF/STABS with Sun ACC. */
1703 last_function_name = namestring;
1704 /* Do not fix textlow==0 for .o or NLM files, as 0 is a legit
1705 value for the bottom of the text seg in those cases. */
1706 if (nlist.n_value == 0
1707 && gdbarch_sofun_address_maybe_missing (gdbarch))
1708 {
1709 struct bound_minimal_symbol minsym
1710 = find_stab_function (namestring,
1711 pst ? pst->filename : NULL,
1712 objfile);
1713 if (minsym.minsym != NULL)
1714 nlist.n_value = minsym.minsym->value_raw_address ();
1715 }
1716 if (pst && textlow_not_set
1717 && gdbarch_sofun_address_maybe_missing (gdbarch))
1718 {
1719 pst->set_text_low (nlist.n_value);
1720 textlow_not_set = 0;
1721 }
1722 /* End kludge. */
1723
1724 /* Keep track of the start of the last function so we
1725 can handle end of function symbols. */
1726 last_function_start = nlist.n_value;
1727
1728 /* In reordered executables this function may lie outside
1729 the bounds created by N_SO symbols. If that's the case
1730 use the address of this function as the low bound for
1731 the partial symbol table. */
1732 if (pst
1733 && (textlow_not_set
1734 || (nlist.n_value < pst->raw_text_low ()
1735 && (nlist.n_value != 0))))
1736 {
1737 pst->set_text_low (nlist.n_value);
1738 textlow_not_set = 0;
1739 }
1740 if (pst != nullptr)
1741 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1742 VAR_DOMAIN, LOC_BLOCK,
1743 SECT_OFF_TEXT (objfile),
1744 psymbol_placement::GLOBAL,
1745 nlist.n_value, psymtab_language,
1746 partial_symtabs, objfile);
1747 continue;
1748
1749 /* Two things show up here (hopefully); static symbols of
1750 local scope (static used inside braces) or extensions
1751 of structure symbols. We can ignore both. */
1752 case 'V':
1753 case '(':
1754 case '0':
1755 case '1':
1756 case '2':
1757 case '3':
1758 case '4':
1759 case '5':
1760 case '6':
1761 case '7':
1762 case '8':
1763 case '9':
1764 case '-':
1765 case '#': /* For symbol identification (used in live ranges). */
1766 continue;
1767
1768 case ':':
1769 /* It is a C++ nested symbol. We don't need to record it
1770 (I don't think); if we try to look up foo::bar::baz,
1771 then symbols for the symtab containing foo should get
1772 read in, I think. */
1773 /* Someone says sun cc puts out symbols like
1774 /foo/baz/maclib::/usr/local/bin/maclib,
1775 which would get here with a symbol type of ':'. */
1776 continue;
1777
1778 default:
1779 /* Unexpected symbol descriptor. The second and subsequent stabs
1780 of a continued stab can show up here. The question is
1781 whether they ever can mimic a normal stab--it would be
1782 nice if not, since we certainly don't want to spend the
1783 time searching to the end of every string looking for
1784 a backslash. */
1785
1786 complaint (_("unknown symbol descriptor `%c'"),
1787 p[1]);
1788
1789 /* Ignore it; perhaps it is an extension that we don't
1790 know about. */
1791 continue;
1792 }
1793 }
1794
1795 case N_EXCL:
1796
1797 namestring = set_namestring (objfile, &nlist);
1798
1799 /* Find the corresponding bincl and mark that psymtab on the
1800 psymtab dependency list. */
1801 {
1802 legacy_psymtab *needed_pst =
1803 find_corresponding_bincl_psymtab (namestring, nlist.n_value);
1804
1805 /* If this include file was defined earlier in this file,
1806 leave it alone. */
1807 if (needed_pst == pst)
1808 continue;
1809
1810 if (needed_pst)
1811 {
1812 int i;
1813 int found = 0;
1814
1815 for (i = 0; i < dependencies_used; i++)
1816 if (dependency_list[i] == needed_pst)
1817 {
1818 found = 1;
1819 break;
1820 }
1821
1822 /* If it's already in the list, skip the rest. */
1823 if (found)
1824 continue;
1825
1826 dependency_list[dependencies_used++] = needed_pst;
1827 if (dependencies_used >= dependencies_allocated)
1828 {
1829 legacy_psymtab **orig = dependency_list;
1830
1831 dependency_list =
1832 (legacy_psymtab **)
1833 alloca ((dependencies_allocated *= 2)
1834 * sizeof (legacy_psymtab *));
1835 memcpy (dependency_list, orig,
1836 (dependencies_used
1837 * sizeof (legacy_psymtab *)));
1838 #ifdef DEBUG_INFO
1839 gdb_printf (gdb_stderr,
1840 "Had to reallocate "
1841 "dependency list.\n");
1842 gdb_printf (gdb_stderr,
1843 "New dependencies allocated: %d\n",
1844 dependencies_allocated);
1845 #endif
1846 }
1847 }
1848 }
1849 continue;
1850
1851 case N_ENDM:
1852 /* Solaris 2 end of module, finish current partial symbol
1853 table. dbx_end_psymtab will set the high text address of
1854 PST to the proper value, which is necessary if a module
1855 compiled without debugging info follows this module. */
1856 if (pst && gdbarch_sofun_address_maybe_missing (gdbarch))
1857 {
1858 dbx_end_psymtab (objfile, partial_symtabs, pst,
1859 psymtab_include_list, includes_used,
1860 symnum * symbol_size,
1861 (CORE_ADDR) 0, dependency_list,
1862 dependencies_used, textlow_not_set);
1863 pst = (legacy_psymtab *) 0;
1864 includes_used = 0;
1865 dependencies_used = 0;
1866 has_line_numbers = 0;
1867 }
1868 continue;
1869
1870 case N_RBRAC:
1871 #ifdef HANDLE_RBRAC
1872 HANDLE_RBRAC (nlist.n_value);
1873 continue;
1874 #endif
1875 case N_EINCL:
1876 case N_DSLINE:
1877 case N_BSLINE:
1878 case N_SSYM: /* Claim: Structure or union element.
1879 Hopefully, I can ignore this. */
1880 case N_ENTRY: /* Alternate entry point; can ignore. */
1881 case N_MAIN: /* Can definitely ignore this. */
1882 case N_CATCH: /* These are GNU C++ extensions */
1883 case N_EHDECL: /* that can safely be ignored here. */
1884 case N_LENG:
1885 case N_BCOMM:
1886 case N_ECOMM:
1887 case N_ECOML:
1888 case N_FNAME:
1889 case N_SLINE:
1890 case N_RSYM:
1891 case N_PSYM:
1892 case N_BNSYM:
1893 case N_ENSYM:
1894 case N_LBRAC:
1895 case N_NSYMS: /* Ultrix 4.0: symbol count */
1896 case N_DEFD: /* GNU Modula-2 */
1897 case N_ALIAS: /* SunPro F77: alias name, ignore for now. */
1898
1899 case N_OBJ: /* Useless types from Solaris. */
1900 case N_OPT:
1901 case N_PATCH:
1902 /* These symbols aren't interesting; don't worry about them. */
1903 continue;
1904
1905 default:
1906 /* If we haven't found it yet, ignore it. It's probably some
1907 new type we don't know about yet. */
1908 unknown_symtype_complaint (hex_string (nlist.n_type));
1909 continue;
1910 }
1911 }
1912
1913 /* If there's stuff to be cleaned up, clean it up. */
1914 if (pst)
1915 {
1916 /* Don't set high text address of PST lower than it already
1917 is. */
1918 CORE_ADDR text_end =
1919 (lowest_text_address == (CORE_ADDR) -1
1920 ? text_addr
1921 : lowest_text_address)
1922 + text_size;
1923
1924 dbx_end_psymtab (objfile, partial_symtabs,
1925 pst, psymtab_include_list, includes_used,
1926 symnum * symbol_size,
1927 (text_end > pst->raw_text_high ()
1928 ? text_end : pst->raw_text_high ()),
1929 dependency_list, dependencies_used, textlow_not_set);
1930 }
1931 }
1932
1933 /* Allocate and partially fill a partial symtab. It will be
1934 completely filled at the end of the symbol list.
1935
1936 SYMFILE_NAME is the name of the symbol-file we are reading from, and ADDR
1937 is the address relative to which its symbols are (incremental) or 0
1938 (normal). */
1939
1940 static legacy_psymtab *
1941 start_psymtab (psymtab_storage *partial_symtabs, struct objfile *objfile,
1942 const char *filename, CORE_ADDR textlow, int ldsymoff)
1943 {
1944 legacy_psymtab *result = new legacy_psymtab (filename, partial_symtabs,
1945 objfile->per_bfd, textlow);
1946
1947 result->read_symtab_private =
1948 XOBNEW (&objfile->objfile_obstack, struct symloc);
1949 LDSYMOFF (result) = ldsymoff;
1950 result->legacy_read_symtab = dbx_read_symtab;
1951 result->legacy_expand_psymtab = dbx_expand_psymtab;
1952 SYMBOL_SIZE (result) = symbol_size;
1953 SYMBOL_OFFSET (result) = symbol_table_offset;
1954 STRING_OFFSET (result) = string_table_offset;
1955 FILE_STRING_OFFSET (result) = file_string_table_offset;
1956
1957 /* Deduce the source language from the filename for this psymtab. */
1958 psymtab_language = deduce_language_from_filename (filename);
1959 PST_LANGUAGE (result) = psymtab_language;
1960
1961 return result;
1962 }
1963
1964 /* Close off the current usage of PST.
1965 Returns PST or NULL if the partial symtab was empty and thrown away.
1966
1967 FIXME: List variables and peculiarities of same. */
1968
1969 legacy_psymtab *
1970 dbx_end_psymtab (struct objfile *objfile, psymtab_storage *partial_symtabs,
1971 legacy_psymtab *pst,
1972 const char **include_list, int num_includes,
1973 int capping_symbol_offset, CORE_ADDR capping_text,
1974 legacy_psymtab **dependency_list,
1975 int number_dependencies,
1976 int textlow_not_set)
1977 {
1978 int i;
1979 struct gdbarch *gdbarch = objfile->arch ();
1980
1981 if (capping_symbol_offset != -1)
1982 LDSYMLEN (pst) = capping_symbol_offset - LDSYMOFF (pst);
1983 pst->set_text_high (capping_text);
1984
1985 /* Under Solaris, the N_SO symbols always have a value of 0,
1986 instead of the usual address of the .o file. Therefore,
1987 we have to do some tricks to fill in texthigh and textlow.
1988 The first trick is: if we see a static
1989 or global function, and the textlow for the current pst
1990 is not set (ie: textlow_not_set), then we use that function's
1991 address for the textlow of the pst. */
1992
1993 /* Now, to fill in texthigh, we remember the last function seen
1994 in the .o file. Also, there's a hack in
1995 bfd/elf.c and gdb/elfread.c to pass the ELF st_size field
1996 to here via the misc_info field. Therefore, we can fill in
1997 a reliable texthigh by taking the address plus size of the
1998 last function in the file. */
1999
2000 if (!pst->text_high_valid && last_function_name
2001 && gdbarch_sofun_address_maybe_missing (gdbarch))
2002 {
2003 int n;
2004 struct bound_minimal_symbol minsym;
2005
2006 const char *colon = strchr (last_function_name, ':');
2007 if (colon == NULL)
2008 n = 0;
2009 else
2010 n = colon - last_function_name;
2011 char *p = (char *) alloca (n + 2);
2012 strncpy (p, last_function_name, n);
2013 p[n] = 0;
2014
2015 minsym = lookup_minimal_symbol (p, pst->filename, objfile);
2016 if (minsym.minsym == NULL)
2017 {
2018 /* Sun Fortran appends an underscore to the minimal symbol name,
2019 try again with an appended underscore if the minimal symbol
2020 was not found. */
2021 p[n] = '_';
2022 p[n + 1] = 0;
2023 minsym = lookup_minimal_symbol (p, pst->filename, objfile);
2024 }
2025
2026 if (minsym.minsym)
2027 pst->set_text_high (minsym.minsym->value_raw_address ()
2028 + minsym.minsym->size ());
2029
2030 last_function_name = NULL;
2031 }
2032
2033 if (!gdbarch_sofun_address_maybe_missing (gdbarch))
2034 ;
2035 /* This test will be true if the last .o file is only data. */
2036 else if (textlow_not_set)
2037 pst->set_text_low (pst->raw_text_high ());
2038 else
2039 {
2040 /* If we know our own starting text address, then walk through all other
2041 psymtabs for this objfile, and if any didn't know their ending text
2042 address, set it to our starting address. Take care to not set our
2043 own ending address to our starting address. */
2044
2045 for (partial_symtab *p1 : partial_symtabs->range ())
2046 if (!p1->text_high_valid && p1->text_low_valid && p1 != pst)
2047 p1->set_text_high (pst->raw_text_low ());
2048 }
2049
2050 /* End of kludge for patching Solaris textlow and texthigh. */
2051
2052 pst->end ();
2053
2054 pst->number_of_dependencies = number_dependencies;
2055 if (number_dependencies)
2056 {
2057 pst->dependencies
2058 = partial_symtabs->allocate_dependencies (number_dependencies);
2059 memcpy (pst->dependencies, dependency_list,
2060 number_dependencies * sizeof (legacy_psymtab *));
2061 }
2062 else
2063 pst->dependencies = 0;
2064
2065 for (i = 0; i < num_includes; i++)
2066 {
2067 legacy_psymtab *subpst =
2068 new legacy_psymtab (include_list[i], partial_symtabs, objfile->per_bfd);
2069
2070 subpst->read_symtab_private =
2071 XOBNEW (&objfile->objfile_obstack, struct symloc);
2072 LDSYMOFF (subpst) =
2073 LDSYMLEN (subpst) = 0;
2074
2075 /* We could save slight bits of space by only making one of these,
2076 shared by the entire set of include files. FIXME-someday. */
2077 subpst->dependencies =
2078 partial_symtabs->allocate_dependencies (1);
2079 subpst->dependencies[0] = pst;
2080 subpst->number_of_dependencies = 1;
2081
2082 subpst->legacy_read_symtab = pst->legacy_read_symtab;
2083 subpst->legacy_expand_psymtab = pst->legacy_expand_psymtab;
2084 }
2085
2086 if (num_includes == 0
2087 && number_dependencies == 0
2088 && pst->empty ()
2089 && has_line_numbers == 0)
2090 {
2091 /* Throw away this psymtab, it's empty. */
2092 /* Empty psymtabs happen as a result of header files which don't have
2093 any symbols in them. There can be a lot of them. But this check
2094 is wrong, in that a psymtab with N_SLINE entries but nothing else
2095 is not empty, but we don't realize that. Fixing that without slowing
2096 things down might be tricky. */
2097
2098 partial_symtabs->discard_psymtab (pst);
2099
2100 /* Indicate that psymtab was thrown away. */
2101 pst = NULL;
2102 }
2103 return pst;
2104 }
2105 \f
2106 static void
2107 dbx_expand_psymtab (legacy_psymtab *pst, struct objfile *objfile)
2108 {
2109 gdb_assert (!pst->readin);
2110
2111 /* Read in all partial symtabs on which this one is dependent. */
2112 pst->expand_dependencies (objfile);
2113
2114 if (LDSYMLEN (pst)) /* Otherwise it's a dummy. */
2115 {
2116 /* Init stuff necessary for reading in symbols */
2117 stabsread_init ();
2118 scoped_free_pendings free_pending;
2119 file_string_table_offset = FILE_STRING_OFFSET (pst);
2120 symbol_size = SYMBOL_SIZE (pst);
2121
2122 /* Read in this file's symbols. */
2123 bfd_seek (objfile->obfd, SYMBOL_OFFSET (pst), SEEK_SET);
2124 read_ofile_symtab (objfile, pst);
2125 }
2126
2127 pst->readin = true;
2128 }
2129
2130 /* Read in all of the symbols for a given psymtab for real.
2131 Be verbose about it if the user wants that. SELF is not NULL. */
2132
2133 static void
2134 dbx_read_symtab (legacy_psymtab *self, struct objfile *objfile)
2135 {
2136 gdb_assert (!self->readin);
2137
2138 if (LDSYMLEN (self) || self->number_of_dependencies)
2139 {
2140 next_symbol_text_func = dbx_next_symbol_text;
2141
2142 {
2143 scoped_restore restore_stabs_data = make_scoped_restore (&stabs_data);
2144 gdb::unique_xmalloc_ptr<gdb_byte> data_holder;
2145 if (DBX_STAB_SECTION (objfile))
2146 {
2147 stabs_data
2148 = symfile_relocate_debug_section (objfile,
2149 DBX_STAB_SECTION (objfile),
2150 NULL);
2151 data_holder.reset (stabs_data);
2152 }
2153
2154 self->expand_psymtab (objfile);
2155 }
2156
2157 /* Match with global symbols. This only needs to be done once,
2158 after all of the symtabs and dependencies have been read in. */
2159 scan_file_globals (objfile);
2160 }
2161 }
2162
2163 /* Read in a defined section of a specific object file's symbols. */
2164
2165 static void
2166 read_ofile_symtab (struct objfile *objfile, legacy_psymtab *pst)
2167 {
2168 const char *namestring;
2169 struct external_nlist *bufp;
2170 struct internal_nlist nlist;
2171 unsigned char type;
2172 unsigned max_symnum;
2173 bfd *abfd;
2174 int sym_offset; /* Offset to start of symbols to read */
2175 int sym_size; /* Size of symbols to read */
2176 CORE_ADDR text_offset; /* Start of text segment for symbols */
2177 int text_size; /* Size of text segment for symbols */
2178
2179 sym_offset = LDSYMOFF (pst);
2180 sym_size = LDSYMLEN (pst);
2181 text_offset = pst->text_low (objfile);
2182 text_size = pst->text_high (objfile) - pst->text_low (objfile);
2183 const section_offsets &section_offsets = objfile->section_offsets;
2184
2185 dbxread_objfile = objfile;
2186
2187 stringtab_global = DBX_STRINGTAB (objfile);
2188 set_last_source_file (NULL);
2189
2190 abfd = objfile->obfd;
2191 symfile_bfd = objfile->obfd; /* Implicit param to next_text_symbol. */
2192 symbuf_end = symbuf_idx = 0;
2193 symbuf_read = 0;
2194 symbuf_left = sym_offset + sym_size;
2195
2196 /* It is necessary to actually read one symbol *before* the start
2197 of this symtab's symbols, because the GCC_COMPILED_FLAG_SYMBOL
2198 occurs before the N_SO symbol.
2199
2200 Detecting this in read_dbx_symtab
2201 would slow down initial readin, so we look for it here instead. */
2202 if (!processing_acc_compilation && sym_offset >= (int) symbol_size)
2203 {
2204 stabs_seek (sym_offset - symbol_size);
2205 fill_symbuf (abfd);
2206 bufp = &symbuf[symbuf_idx++];
2207 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
2208 OBJSTAT (objfile, n_stabs++);
2209
2210 namestring = set_namestring (objfile, &nlist);
2211
2212 processing_gcc_compilation = 0;
2213 if (nlist.n_type == N_TEXT)
2214 {
2215 const char *tempstring = namestring;
2216
2217 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
2218 processing_gcc_compilation = 1;
2219 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2220 processing_gcc_compilation = 2;
2221 if (tempstring[0] == bfd_get_symbol_leading_char (symfile_bfd))
2222 ++tempstring;
2223 if (startswith (tempstring, "__gnu_compiled"))
2224 processing_gcc_compilation = 2;
2225 }
2226 }
2227 else
2228 {
2229 /* The N_SO starting this symtab is the first symbol, so we
2230 better not check the symbol before it. I'm not this can
2231 happen, but it doesn't hurt to check for it. */
2232 stabs_seek (sym_offset);
2233 processing_gcc_compilation = 0;
2234 }
2235
2236 if (symbuf_idx == symbuf_end)
2237 fill_symbuf (abfd);
2238 bufp = &symbuf[symbuf_idx];
2239 if (bfd_h_get_8 (abfd, bufp->e_type) != N_SO)
2240 error (_("First symbol in segment of executable not a source symbol"));
2241
2242 max_symnum = sym_size / symbol_size;
2243
2244 for (symnum = 0;
2245 symnum < max_symnum;
2246 symnum++)
2247 {
2248 QUIT; /* Allow this to be interruptable. */
2249 if (symbuf_idx == symbuf_end)
2250 fill_symbuf (abfd);
2251 bufp = &symbuf[symbuf_idx++];
2252 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
2253 OBJSTAT (objfile, n_stabs++);
2254
2255 type = bfd_h_get_8 (abfd, bufp->e_type);
2256
2257 namestring = set_namestring (objfile, &nlist);
2258
2259 if (type & N_STAB)
2260 {
2261 if (sizeof (nlist.n_value) > 4
2262 /* We are a 64-bit debugger debugging a 32-bit program. */
2263 && (type == N_LSYM || type == N_PSYM))
2264 /* We have to be careful with the n_value in the case of N_LSYM
2265 and N_PSYM entries, because they are signed offsets from frame
2266 pointer, but we actually read them as unsigned 32-bit values.
2267 This is not a problem for 32-bit debuggers, for which negative
2268 values end up being interpreted correctly (as negative
2269 offsets) due to integer overflow.
2270 But we need to sign-extend the value for 64-bit debuggers,
2271 or we'll end up interpreting negative values as very large
2272 positive offsets. */
2273 nlist.n_value = (nlist.n_value ^ 0x80000000) - 0x80000000;
2274 process_one_symbol (type, nlist.n_desc, nlist.n_value,
2275 namestring, section_offsets, objfile,
2276 PST_LANGUAGE (pst));
2277 }
2278 /* We skip checking for a new .o or -l file; that should never
2279 happen in this routine. */
2280 else if (type == N_TEXT)
2281 {
2282 /* I don't think this code will ever be executed, because
2283 the GCC_COMPILED_FLAG_SYMBOL usually is right before
2284 the N_SO symbol which starts this source file.
2285 However, there is no reason not to accept
2286 the GCC_COMPILED_FLAG_SYMBOL anywhere. */
2287
2288 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
2289 processing_gcc_compilation = 1;
2290 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2291 processing_gcc_compilation = 2;
2292 }
2293 else if (type & N_EXT || type == (unsigned char) N_TEXT
2294 || type == (unsigned char) N_NBTEXT)
2295 {
2296 /* Global symbol: see if we came across a dbx definition for
2297 a corresponding symbol. If so, store the value. Remove
2298 syms from the chain when their values are stored, but
2299 search the whole chain, as there may be several syms from
2300 different files with the same name. */
2301 /* This is probably not true. Since the files will be read
2302 in one at a time, each reference to a global symbol will
2303 be satisfied in each file as it appears. So we skip this
2304 section. */
2305 ;
2306 }
2307 }
2308
2309 /* In a Solaris elf file, this variable, which comes from the value
2310 of the N_SO symbol, will still be 0. Luckily, text_offset, which
2311 comes from low text address of PST, is correct. */
2312 if (get_last_source_start_addr () == 0)
2313 set_last_source_start_addr (text_offset);
2314
2315 /* In reordered executables last_source_start_addr may not be the
2316 lower bound for this symtab, instead use text_offset which comes
2317 from the low text address of PST, which is correct. */
2318 if (get_last_source_start_addr () > text_offset)
2319 set_last_source_start_addr (text_offset);
2320
2321 pst->compunit_symtab = end_compunit_symtab (text_offset + text_size,
2322 SECT_OFF_TEXT (objfile));
2323
2324 end_stabs ();
2325
2326 dbxread_objfile = NULL;
2327 }
2328 \f
2329
2330 /* Record the namespace that the function defined by SYMBOL was
2331 defined in, if necessary. BLOCK is the associated block; use
2332 OBSTACK for allocation. */
2333
2334 static void
2335 cp_set_block_scope (const struct symbol *symbol,
2336 struct block *block,
2337 struct obstack *obstack)
2338 {
2339 if (symbol->demangled_name () != NULL)
2340 {
2341 /* Try to figure out the appropriate namespace from the
2342 demangled name. */
2343
2344 /* FIXME: carlton/2003-04-15: If the function in question is
2345 a method of a class, the name will actually include the
2346 name of the class as well. This should be harmless, but
2347 is a little unfortunate. */
2348
2349 const char *name = symbol->demangled_name ();
2350 unsigned int prefix_len = cp_entire_prefix_len (name);
2351
2352 block_set_scope (block, obstack_strndup (obstack, name, prefix_len),
2353 obstack);
2354 }
2355 }
2356
2357 /* This handles a single symbol from the symbol-file, building symbols
2358 into a GDB symtab. It takes these arguments and an implicit argument.
2359
2360 TYPE is the type field of the ".stab" symbol entry.
2361 DESC is the desc field of the ".stab" entry.
2362 VALU is the value field of the ".stab" entry.
2363 NAME is the symbol name, in our address space.
2364 SECTION_OFFSETS is a set of amounts by which the sections of this
2365 object file were relocated when it was loaded into memory. Note
2366 that these section_offsets are not the objfile->section_offsets but
2367 the pst->section_offsets. All symbols that refer to memory
2368 locations need to be offset by these amounts.
2369 OBJFILE is the object file from which we are reading symbols. It
2370 is used in end_compunit_symtab.
2371 LANGUAGE is the language of the symtab.
2372 */
2373
2374 void
2375 process_one_symbol (int type, int desc, CORE_ADDR valu, const char *name,
2376 const section_offsets &section_offsets,
2377 struct objfile *objfile, enum language language)
2378 {
2379 struct gdbarch *gdbarch = objfile->arch ();
2380 struct context_stack *newobj;
2381 struct context_stack cstk;
2382 /* This remembers the address of the start of a function. It is
2383 used because in Solaris 2, N_LBRAC, N_RBRAC, and N_SLINE entries
2384 are relative to the current function's start address. On systems
2385 other than Solaris 2, this just holds the SECT_OFF_TEXT value,
2386 and is used to relocate these symbol types rather than
2387 SECTION_OFFSETS. */
2388 static CORE_ADDR function_start_offset;
2389
2390 /* This holds the address of the start of a function, without the
2391 system peculiarities of function_start_offset. */
2392 static CORE_ADDR last_function_start;
2393
2394 /* If this is nonzero, we've seen an N_SLINE since the start of the
2395 current function. We use this to tell us to move the first sline
2396 to the beginning of the function regardless of what its given
2397 value is. */
2398 static int sline_found_in_function = 1;
2399
2400 /* If this is nonzero, we've seen a non-gcc N_OPT symbol for this
2401 source file. Used to detect the SunPRO solaris compiler. */
2402 static int n_opt_found;
2403
2404 /* Something is wrong if we see real data before seeing a source
2405 file name. */
2406
2407 if (get_last_source_file () == NULL && type != (unsigned char) N_SO)
2408 {
2409 /* Ignore any symbols which appear before an N_SO symbol.
2410 Currently no one puts symbols there, but we should deal
2411 gracefully with the case. A complain()t might be in order,
2412 but this should not be an error (). */
2413 return;
2414 }
2415
2416 switch (type)
2417 {
2418 case N_FUN:
2419 case N_FNAME:
2420
2421 if (*name == '\000')
2422 {
2423 /* This N_FUN marks the end of a function. This closes off
2424 the current block. */
2425 struct block *block;
2426
2427 if (outermost_context_p ())
2428 {
2429 lbrac_mismatch_complaint (symnum);
2430 break;
2431 }
2432
2433 /* The following check is added before recording line 0 at
2434 end of function so as to handle hand-generated stabs
2435 which may have an N_FUN stabs at the end of the function,
2436 but no N_SLINE stabs. */
2437 if (sline_found_in_function)
2438 {
2439 CORE_ADDR addr = last_function_start + valu;
2440
2441 record_line (get_current_subfile (), 0,
2442 gdbarch_addr_bits_remove (gdbarch, addr));
2443 }
2444
2445 within_function = 0;
2446 cstk = pop_context ();
2447
2448 /* Make a block for the local symbols within. */
2449 block = finish_block (cstk.name,
2450 cstk.old_blocks, NULL,
2451 cstk.start_addr, cstk.start_addr + valu);
2452
2453 /* For C++, set the block's scope. */
2454 if (cstk.name->language () == language_cplus)
2455 cp_set_block_scope (cstk.name, block, &objfile->objfile_obstack);
2456
2457 /* May be switching to an assembler file which may not be using
2458 block relative stabs, so reset the offset. */
2459 function_start_offset = 0;
2460
2461 break;
2462 }
2463
2464 sline_found_in_function = 0;
2465
2466 /* Relocate for dynamic loading. */
2467 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2468 valu = gdbarch_addr_bits_remove (gdbarch, valu);
2469 last_function_start = valu;
2470
2471 goto define_a_symbol;
2472
2473 case N_LBRAC:
2474 /* This "symbol" just indicates the start of an inner lexical
2475 context within a function. */
2476
2477 /* Ignore extra outermost context from SunPRO cc and acc. */
2478 if (n_opt_found && desc == 1)
2479 break;
2480
2481 valu += function_start_offset;
2482
2483 push_context (desc, valu);
2484 break;
2485
2486 case N_RBRAC:
2487 /* This "symbol" just indicates the end of an inner lexical
2488 context that was started with N_LBRAC. */
2489
2490 /* Ignore extra outermost context from SunPRO cc and acc. */
2491 if (n_opt_found && desc == 1)
2492 break;
2493
2494 valu += function_start_offset;
2495
2496 if (outermost_context_p ())
2497 {
2498 lbrac_mismatch_complaint (symnum);
2499 break;
2500 }
2501
2502 cstk = pop_context ();
2503 if (desc != cstk.depth)
2504 lbrac_mismatch_complaint (symnum);
2505
2506 if (*get_local_symbols () != NULL)
2507 {
2508 /* GCC development snapshots from March to December of
2509 2000 would output N_LSYM entries after N_LBRAC
2510 entries. As a consequence, these symbols are simply
2511 discarded. Complain if this is the case. */
2512 complaint (_("misplaced N_LBRAC entry; discarding local "
2513 "symbols which have no enclosing block"));
2514 }
2515 *get_local_symbols () = cstk.locals;
2516
2517 if (get_context_stack_depth () > 1)
2518 {
2519 /* This is not the outermost LBRAC...RBRAC pair in the
2520 function, its local symbols preceded it, and are the ones
2521 just recovered from the context stack. Define the block
2522 for them (but don't bother if the block contains no
2523 symbols. Should we complain on blocks without symbols?
2524 I can't think of any useful purpose for them). */
2525 if (*get_local_symbols () != NULL)
2526 {
2527 /* Muzzle a compiler bug that makes end < start.
2528
2529 ??? Which compilers? Is this ever harmful?. */
2530 if (cstk.start_addr > valu)
2531 {
2532 complaint (_("block start larger than block end"));
2533 cstk.start_addr = valu;
2534 }
2535 /* Make a block for the local symbols within. */
2536 finish_block (0, cstk.old_blocks, NULL,
2537 cstk.start_addr, valu);
2538 }
2539 }
2540 else
2541 {
2542 /* This is the outermost LBRAC...RBRAC pair. There is no
2543 need to do anything; leave the symbols that preceded it
2544 to be attached to the function's own block. We need to
2545 indicate that we just moved outside of the function. */
2546 within_function = 0;
2547 }
2548
2549 break;
2550
2551 case N_FN:
2552 case N_FN_SEQ:
2553 /* This kind of symbol indicates the start of an object file.
2554 Relocate for dynamic loading. */
2555 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2556 break;
2557
2558 case N_SO:
2559 /* This type of symbol indicates the start of data for one
2560 source file. Finish the symbol table of the previous source
2561 file (if any) and start accumulating a new symbol table.
2562 Relocate for dynamic loading. */
2563 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2564
2565 n_opt_found = 0;
2566
2567 if (get_last_source_file ())
2568 {
2569 /* Check if previous symbol was also an N_SO (with some
2570 sanity checks). If so, that one was actually the
2571 directory name, and the current one is the real file
2572 name. Patch things up. */
2573 if (previous_stab_code == (unsigned char) N_SO)
2574 {
2575 patch_subfile_names (get_current_subfile (), name);
2576 break; /* Ignore repeated SOs. */
2577 }
2578 end_compunit_symtab (valu, SECT_OFF_TEXT (objfile));
2579 end_stabs ();
2580 }
2581
2582 /* Null name means this just marks the end of text for this .o
2583 file. Don't start a new symtab in this case. */
2584 if (*name == '\000')
2585 break;
2586
2587 function_start_offset = 0;
2588
2589 start_stabs ();
2590 start_compunit_symtab (objfile, name, NULL, valu, language);
2591 record_debugformat ("stabs");
2592 break;
2593
2594 case N_SOL:
2595 /* This type of symbol indicates the start of data for a
2596 sub-source-file, one whose contents were copied or included
2597 in the compilation of the main source file (whose name was
2598 given in the N_SO symbol). Relocate for dynamic loading. */
2599 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2600 start_subfile (name);
2601 break;
2602
2603 case N_BINCL:
2604 push_subfile ();
2605 add_new_header_file (name, valu);
2606 start_subfile (name);
2607 break;
2608
2609 case N_EINCL:
2610 start_subfile (pop_subfile ());
2611 break;
2612
2613 case N_EXCL:
2614 add_old_header_file (name, valu);
2615 break;
2616
2617 case N_SLINE:
2618 /* This type of "symbol" really just records one line-number --
2619 core-address correspondence. Enter it in the line list for
2620 this symbol table. */
2621
2622 /* Relocate for dynamic loading and for ELF acc
2623 function-relative symbols. */
2624 valu += function_start_offset;
2625
2626 /* GCC 2.95.3 emits the first N_SLINE stab somewhere in the
2627 middle of the prologue instead of right at the start of the
2628 function. To deal with this we record the address for the
2629 first N_SLINE stab to be the start of the function instead of
2630 the listed location. We really shouldn't to this. When
2631 compiling with optimization, this first N_SLINE stab might be
2632 optimized away. Other (non-GCC) compilers don't emit this
2633 stab at all. There is no real harm in having an extra
2634 numbered line, although it can be a bit annoying for the
2635 user. However, it totally screws up our testsuite.
2636
2637 So for now, keep adjusting the address of the first N_SLINE
2638 stab, but only for code compiled with GCC. */
2639
2640 if (within_function && sline_found_in_function == 0)
2641 {
2642 CORE_ADDR addr = processing_gcc_compilation == 2 ?
2643 last_function_start : valu;
2644
2645 record_line (get_current_subfile (), desc,
2646 gdbarch_addr_bits_remove (gdbarch, addr));
2647 sline_found_in_function = 1;
2648 }
2649 else
2650 record_line (get_current_subfile (), desc,
2651 gdbarch_addr_bits_remove (gdbarch, valu));
2652 break;
2653
2654 case N_BCOMM:
2655 common_block_start (name, objfile);
2656 break;
2657
2658 case N_ECOMM:
2659 common_block_end (objfile);
2660 break;
2661
2662 /* The following symbol types need to have the appropriate
2663 offset added to their value; then we process symbol
2664 definitions in the name. */
2665
2666 case N_STSYM: /* Static symbol in data segment. */
2667 case N_LCSYM: /* Static symbol in BSS segment. */
2668 case N_ROSYM: /* Static symbol in read-only data segment. */
2669 /* HORRID HACK DEPT. However, it's Sun's furgin' fault.
2670 Solaris 2's stabs-in-elf makes *most* symbols relative but
2671 leaves a few absolute (at least for Solaris 2.1 and version
2672 2.0.1 of the SunPRO compiler). N_STSYM and friends sit on
2673 the fence. .stab "foo:S...",N_STSYM is absolute (ld
2674 relocates it) .stab "foo:V...",N_STSYM is relative (section
2675 base subtracted). This leaves us no choice but to search for
2676 the 'S' or 'V'... (or pass the whole section_offsets stuff
2677 down ONE MORE function call level, which we really don't want
2678 to do). */
2679 {
2680 const char *p;
2681
2682 /* Normal object file and NLMs have non-zero text seg offsets,
2683 but don't need their static syms offset in this fashion.
2684 XXX - This is really a crock that should be fixed in the
2685 solib handling code so that I don't have to work around it
2686 here. */
2687
2688 if (!symfile_relocatable)
2689 {
2690 p = strchr (name, ':');
2691 if (p != 0 && p[1] == 'S')
2692 {
2693 /* The linker relocated it. We don't want to add a
2694 Sun-stabs Tfoo.foo-like offset, but we *do*
2695 want to add whatever solib.c passed to
2696 symbol_file_add as addr (this is known to affect
2697 SunOS 4, and I suspect ELF too). Since there is no
2698 Ttext.text symbol, we can get addr from the text offset. */
2699 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2700 goto define_a_symbol;
2701 }
2702 }
2703 /* Since it's not the kludge case, re-dispatch to the right
2704 handler. */
2705 switch (type)
2706 {
2707 case N_STSYM:
2708 goto case_N_STSYM;
2709 case N_LCSYM:
2710 goto case_N_LCSYM;
2711 case N_ROSYM:
2712 goto case_N_ROSYM;
2713 default:
2714 internal_error (__FILE__, __LINE__,
2715 _("failed internal consistency check"));
2716 }
2717 }
2718
2719 case_N_STSYM: /* Static symbol in data segment. */
2720 case N_DSLINE: /* Source line number, data segment. */
2721 valu += section_offsets[SECT_OFF_DATA (objfile)];
2722 goto define_a_symbol;
2723
2724 case_N_LCSYM: /* Static symbol in BSS segment. */
2725 case N_BSLINE: /* Source line number, BSS segment. */
2726 /* N_BROWS: overlaps with N_BSLINE. */
2727 valu += section_offsets[SECT_OFF_BSS (objfile)];
2728 goto define_a_symbol;
2729
2730 case_N_ROSYM: /* Static symbol in read-only data segment. */
2731 valu += section_offsets[SECT_OFF_RODATA (objfile)];
2732 goto define_a_symbol;
2733
2734 case N_ENTRY: /* Alternate entry point. */
2735 /* Relocate for dynamic loading. */
2736 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2737 goto define_a_symbol;
2738
2739 /* The following symbol types we don't know how to process.
2740 Handle them in a "default" way, but complain to people who
2741 care. */
2742 default:
2743 case N_CATCH: /* Exception handler catcher. */
2744 case N_EHDECL: /* Exception handler name. */
2745 case N_PC: /* Global symbol in Pascal. */
2746 case N_M2C: /* Modula-2 compilation unit. */
2747 /* N_MOD2: overlaps with N_EHDECL. */
2748 case N_SCOPE: /* Modula-2 scope information. */
2749 case N_ECOML: /* End common (local name). */
2750 case N_NBTEXT: /* Gould Non-Base-Register symbols??? */
2751 case N_NBDATA:
2752 case N_NBBSS:
2753 case N_NBSTS:
2754 case N_NBLCS:
2755 unknown_symtype_complaint (hex_string (type));
2756 /* FALLTHROUGH */
2757
2758 define_a_symbol:
2759 /* These symbol types don't need the address field relocated,
2760 since it is either unused, or is absolute. */
2761 case N_GSYM: /* Global variable. */
2762 case N_NSYMS: /* Number of symbols (Ultrix). */
2763 case N_NOMAP: /* No map? (Ultrix). */
2764 case N_RSYM: /* Register variable. */
2765 case N_DEFD: /* Modula-2 GNU module dependency. */
2766 case N_SSYM: /* Struct or union element. */
2767 case N_LSYM: /* Local symbol in stack. */
2768 case N_PSYM: /* Parameter variable. */
2769 case N_LENG: /* Length of preceding symbol type. */
2770 if (name)
2771 {
2772 int deftype;
2773 const char *colon_pos = strchr (name, ':');
2774
2775 if (colon_pos == NULL)
2776 deftype = '\0';
2777 else
2778 deftype = colon_pos[1];
2779
2780 switch (deftype)
2781 {
2782 case 'f':
2783 case 'F':
2784 /* Deal with the SunPRO 3.0 compiler which omits the
2785 address from N_FUN symbols. */
2786 if (type == N_FUN
2787 && valu == section_offsets[SECT_OFF_TEXT (objfile)]
2788 && gdbarch_sofun_address_maybe_missing (gdbarch))
2789 {
2790 struct bound_minimal_symbol minsym
2791 = find_stab_function (name, get_last_source_file (),
2792 objfile);
2793 if (minsym.minsym != NULL)
2794 valu = minsym.value_address ();
2795 }
2796
2797 /* These addresses are absolute. */
2798 function_start_offset = valu;
2799
2800 within_function = 1;
2801
2802 if (get_context_stack_depth () > 1)
2803 {
2804 complaint (_("unmatched N_LBRAC before symtab pos %d"),
2805 symnum);
2806 break;
2807 }
2808
2809 if (!outermost_context_p ())
2810 {
2811 struct block *block;
2812
2813 cstk = pop_context ();
2814 /* Make a block for the local symbols within. */
2815 block = finish_block (cstk.name,
2816 cstk.old_blocks, NULL,
2817 cstk.start_addr, valu);
2818
2819 /* For C++, set the block's scope. */
2820 if (cstk.name->language () == language_cplus)
2821 cp_set_block_scope (cstk.name, block,
2822 &objfile->objfile_obstack);
2823 }
2824
2825 newobj = push_context (0, valu);
2826 newobj->name = define_symbol (valu, name, desc, type, objfile);
2827 break;
2828
2829 default:
2830 define_symbol (valu, name, desc, type, objfile);
2831 break;
2832 }
2833 }
2834 break;
2835
2836 /* We use N_OPT to carry the gcc2_compiled flag. Sun uses it
2837 for a bunch of other flags, too. Someday we may parse their
2838 flags; for now we ignore theirs and hope they'll ignore ours. */
2839 case N_OPT: /* Solaris 2: Compiler options. */
2840 if (name)
2841 {
2842 if (strcmp (name, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2843 {
2844 processing_gcc_compilation = 2;
2845 }
2846 else
2847 n_opt_found = 1;
2848 }
2849 break;
2850
2851 case N_MAIN: /* Name of main routine. */
2852 /* FIXME: If one has a symbol file with N_MAIN and then replaces
2853 it with a symbol file with "main" and without N_MAIN. I'm
2854 not sure exactly what rule to follow but probably something
2855 like: N_MAIN takes precedence over "main" no matter what
2856 objfile it is in; If there is more than one N_MAIN, choose
2857 the one in the symfile_objfile; If there is more than one
2858 N_MAIN within a given objfile, complain() and choose
2859 arbitrarily. (kingdon) */
2860 if (name != NULL)
2861 set_objfile_main_name (objfile, name, language_unknown);
2862 break;
2863
2864 /* The following symbol types can be ignored. */
2865 case N_OBJ: /* Solaris 2: Object file dir and name. */
2866 case N_PATCH: /* Solaris 2: Patch Run Time Checker. */
2867 /* N_UNDF: Solaris 2: File separator mark. */
2868 /* N_UNDF: -- we will never encounter it, since we only process
2869 one file's symbols at once. */
2870 case N_ENDM: /* Solaris 2: End of module. */
2871 case N_ALIAS: /* SunPro F77: alias name, ignore for now. */
2872 break;
2873 }
2874
2875 /* '#' is a GNU C extension to allow one symbol to refer to another
2876 related symbol.
2877
2878 Generally this is used so that an alias can refer to its main
2879 symbol. */
2880 gdb_assert (name);
2881 if (name[0] == '#')
2882 {
2883 /* Initialize symbol reference names and determine if this is a
2884 definition. If a symbol reference is being defined, go ahead
2885 and add it. Otherwise, just return. */
2886
2887 const char *s = name;
2888 int refnum;
2889
2890 /* If this stab defines a new reference ID that is not on the
2891 reference list, then put it on the reference list.
2892
2893 We go ahead and advance NAME past the reference, even though
2894 it is not strictly necessary at this time. */
2895 refnum = symbol_reference_defined (&s);
2896 if (refnum >= 0)
2897 if (!ref_search (refnum))
2898 ref_add (refnum, 0, name, valu);
2899 name = s;
2900 }
2901
2902 previous_stab_code = type;
2903 }
2904 \f
2905 /* FIXME: The only difference between this and elfstab_build_psymtabs
2906 is the call to install_minimal_symbols for elf, and the support for
2907 split sections. If the differences are really that small, the code
2908 should be shared. */
2909
2910 /* Scan and build partial symbols for an coff symbol file.
2911 The coff file has already been processed to get its minimal symbols.
2912
2913 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
2914 rolled into one.
2915
2916 OBJFILE is the object file we are reading symbols from.
2917 ADDR is the address relative to which the symbols are (e.g.
2918 the base address of the text segment).
2919 TEXTADDR is the address of the text section.
2920 TEXTSIZE is the size of the text section.
2921 STABSECTS is the list of .stab sections in OBJFILE.
2922 STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
2923 .stabstr section exists.
2924
2925 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
2926 adjusted for coff details. */
2927
2928 void
2929 coffstab_build_psymtabs (struct objfile *objfile,
2930 CORE_ADDR textaddr, unsigned int textsize,
2931 const std::vector<asection *> &stabsects,
2932 file_ptr stabstroffset, unsigned int stabstrsize)
2933 {
2934 int val;
2935 bfd *sym_bfd = objfile->obfd;
2936 const char *name = bfd_get_filename (sym_bfd);
2937 unsigned int stabsize;
2938
2939 /* Allocate struct to keep track of stab reading. */
2940 dbx_objfile_data_key.emplace (objfile);
2941
2942 DBX_TEXT_ADDR (objfile) = textaddr;
2943 DBX_TEXT_SIZE (objfile) = textsize;
2944
2945 #define COFF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
2946 DBX_SYMBOL_SIZE (objfile) = COFF_STABS_SYMBOL_SIZE;
2947 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
2948
2949 if (stabstrsize > bfd_get_size (sym_bfd))
2950 error (_("ridiculous string table size: %d bytes"), stabstrsize);
2951 DBX_STRINGTAB (objfile) = (char *)
2952 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
2953 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
2954
2955 /* Now read in the string table in one big gulp. */
2956
2957 val = bfd_seek (sym_bfd, stabstroffset, SEEK_SET);
2958 if (val < 0)
2959 perror_with_name (name);
2960 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
2961 if (val != stabstrsize)
2962 perror_with_name (name);
2963
2964 stabsread_new_init ();
2965 free_header_files ();
2966 init_header_files ();
2967
2968 processing_acc_compilation = 1;
2969
2970 /* In a coff file, we've already installed the minimal symbols that came
2971 from the coff (non-stab) symbol table, so always act like an
2972 incremental load here. */
2973 scoped_restore save_symbuf_sections
2974 = make_scoped_restore (&symbuf_sections);
2975 if (stabsects.size () == 1)
2976 {
2977 stabsize = bfd_section_size (stabsects[0]);
2978 DBX_SYMCOUNT (objfile) = stabsize / DBX_SYMBOL_SIZE (objfile);
2979 DBX_SYMTAB_OFFSET (objfile) = stabsects[0]->filepos;
2980 }
2981 else
2982 {
2983 DBX_SYMCOUNT (objfile) = 0;
2984 for (asection *section : stabsects)
2985 {
2986 stabsize = bfd_section_size (section);
2987 DBX_SYMCOUNT (objfile) += stabsize / DBX_SYMBOL_SIZE (objfile);
2988 }
2989
2990 DBX_SYMTAB_OFFSET (objfile) = stabsects[0]->filepos;
2991
2992 sect_idx = 1;
2993 symbuf_sections = &stabsects;
2994 symbuf_left = bfd_section_size (stabsects[0]);
2995 symbuf_read = 0;
2996 }
2997
2998 dbx_symfile_read (objfile, 0);
2999 }
3000 \f
3001 /* Scan and build partial symbols for an ELF symbol file.
3002 This ELF file has already been processed to get its minimal symbols.
3003
3004 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
3005 rolled into one.
3006
3007 OBJFILE is the object file we are reading symbols from.
3008 ADDR is the address relative to which the symbols are (e.g.
3009 the base address of the text segment).
3010 STABSECT is the BFD section information for the .stab section.
3011 STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
3012 .stabstr section exists.
3013
3014 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
3015 adjusted for elf details. */
3016
3017 void
3018 elfstab_build_psymtabs (struct objfile *objfile, asection *stabsect,
3019 file_ptr stabstroffset, unsigned int stabstrsize)
3020 {
3021 int val;
3022 bfd *sym_bfd = objfile->obfd;
3023 const char *name = bfd_get_filename (sym_bfd);
3024
3025 stabsread_new_init ();
3026
3027 /* Allocate struct to keep track of stab reading. */
3028 dbx_objfile_data_key.emplace (objfile);
3029
3030 /* Find the first and last text address. dbx_symfile_read seems to
3031 want this. */
3032 find_text_range (sym_bfd, objfile);
3033
3034 #define ELF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
3035 DBX_SYMBOL_SIZE (objfile) = ELF_STABS_SYMBOL_SIZE;
3036 DBX_SYMCOUNT (objfile)
3037 = bfd_section_size (stabsect) / DBX_SYMBOL_SIZE (objfile);
3038 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
3039 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos;
3040 DBX_STAB_SECTION (objfile) = stabsect;
3041
3042 if (stabstrsize > bfd_get_size (sym_bfd))
3043 error (_("ridiculous string table size: %d bytes"), stabstrsize);
3044 DBX_STRINGTAB (objfile) = (char *)
3045 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
3046 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
3047
3048 /* Now read in the string table in one big gulp. */
3049
3050 val = bfd_seek (sym_bfd, stabstroffset, SEEK_SET);
3051 if (val < 0)
3052 perror_with_name (name);
3053 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
3054 if (val != stabstrsize)
3055 perror_with_name (name);
3056
3057 stabsread_new_init ();
3058 free_header_files ();
3059 init_header_files ();
3060
3061 processing_acc_compilation = 1;
3062
3063 symbuf_read = 0;
3064 symbuf_left = bfd_section_size (stabsect);
3065
3066 scoped_restore restore_stabs_data = make_scoped_restore (&stabs_data);
3067 gdb::unique_xmalloc_ptr<gdb_byte> data_holder;
3068
3069 stabs_data = symfile_relocate_debug_section (objfile, stabsect, NULL);
3070 if (stabs_data)
3071 data_holder.reset (stabs_data);
3072
3073 /* In an elf file, we've already installed the minimal symbols that came
3074 from the elf (non-stab) symbol table, so always act like an
3075 incremental load here. dbx_symfile_read should not generate any new
3076 minimal symbols, since we will have already read the ELF dynamic symbol
3077 table and normal symbol entries won't be in the ".stab" section; but in
3078 case it does, it will install them itself. */
3079 dbx_symfile_read (objfile, 0);
3080 }
3081 \f
3082 /* Scan and build partial symbols for a file with special sections for stabs
3083 and stabstrings. The file has already been processed to get its minimal
3084 symbols, and any other symbols that might be necessary to resolve GSYMs.
3085
3086 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
3087 rolled into one.
3088
3089 OBJFILE is the object file we are reading symbols from.
3090 ADDR is the address relative to which the symbols are (e.g. the base address
3091 of the text segment).
3092 STAB_NAME is the name of the section that contains the stabs.
3093 STABSTR_NAME is the name of the section that contains the stab strings.
3094
3095 This routine is mostly copied from dbx_symfile_init and
3096 dbx_symfile_read. */
3097
3098 void
3099 stabsect_build_psymtabs (struct objfile *objfile, char *stab_name,
3100 char *stabstr_name, char *text_name)
3101 {
3102 int val;
3103 bfd *sym_bfd = objfile->obfd;
3104 const char *name = bfd_get_filename (sym_bfd);
3105 asection *stabsect;
3106 asection *stabstrsect;
3107 asection *text_sect;
3108
3109 stabsect = bfd_get_section_by_name (sym_bfd, stab_name);
3110 stabstrsect = bfd_get_section_by_name (sym_bfd, stabstr_name);
3111
3112 if (!stabsect)
3113 return;
3114
3115 if (!stabstrsect)
3116 error (_("stabsect_build_psymtabs: Found stabs (%s), "
3117 "but not string section (%s)"),
3118 stab_name, stabstr_name);
3119
3120 dbx_objfile_data_key.emplace (objfile);
3121
3122 text_sect = bfd_get_section_by_name (sym_bfd, text_name);
3123 if (!text_sect)
3124 error (_("Can't find %s section in symbol file"), text_name);
3125 DBX_TEXT_ADDR (objfile) = bfd_section_vma (text_sect);
3126 DBX_TEXT_SIZE (objfile) = bfd_section_size (text_sect);
3127
3128 DBX_SYMBOL_SIZE (objfile) = sizeof (struct external_nlist);
3129 DBX_SYMCOUNT (objfile) = bfd_section_size (stabsect)
3130 / DBX_SYMBOL_SIZE (objfile);
3131 DBX_STRINGTAB_SIZE (objfile) = bfd_section_size (stabstrsect);
3132 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos; /* XXX - FIXME: POKING
3133 INSIDE BFD DATA
3134 STRUCTURES */
3135
3136 if (DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
3137 error (_("ridiculous string table size: %d bytes"),
3138 DBX_STRINGTAB_SIZE (objfile));
3139 DBX_STRINGTAB (objfile) = (char *)
3140 obstack_alloc (&objfile->objfile_obstack,
3141 DBX_STRINGTAB_SIZE (objfile) + 1);
3142 OBJSTAT (objfile, sz_strtab += DBX_STRINGTAB_SIZE (objfile) + 1);
3143
3144 /* Now read in the string table in one big gulp. */
3145
3146 val = bfd_get_section_contents (sym_bfd, /* bfd */
3147 stabstrsect, /* bfd section */
3148 DBX_STRINGTAB (objfile), /* input buffer */
3149 0, /* offset into section */
3150 DBX_STRINGTAB_SIZE (objfile)); /* amount to
3151 read */
3152
3153 if (!val)
3154 perror_with_name (name);
3155
3156 stabsread_new_init ();
3157 free_header_files ();
3158 init_header_files ();
3159
3160 /* Now, do an incremental load. */
3161
3162 processing_acc_compilation = 1;
3163 dbx_symfile_read (objfile, 0);
3164 }
3165 \f
3166 static const struct sym_fns aout_sym_fns =
3167 {
3168 dbx_new_init, /* init anything gbl to entire symtab */
3169 dbx_symfile_init, /* read initial info, setup for sym_read() */
3170 dbx_symfile_read, /* read a symbol file into symtab */
3171 dbx_symfile_finish, /* finished with file, cleanup */
3172 default_symfile_offsets, /* parse user's offsets to internal form */
3173 default_symfile_segments, /* Get segment information from a file. */
3174 NULL,
3175 default_symfile_relocate, /* Relocate a debug section. */
3176 NULL, /* sym_probe_fns */
3177 };
3178
3179 void _initialize_dbxread ();
3180 void
3181 _initialize_dbxread ()
3182 {
3183 add_symtab_fns (bfd_target_aout_flavour, &aout_sym_fns);
3184 }