]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - gdb/dbxread.c
Automatic Copyright Year update after running gdb/copyright.py
[thirdparty/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 "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 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1465 VAR_DOMAIN, LOC_STATIC,
1466 data_sect_index,
1467 psymbol_placement::STATIC,
1468 nlist.n_value, psymtab_language,
1469 partial_symtabs, objfile);
1470 continue;
1471
1472 case 'G':
1473 /* The addresses in these entries are reported to be
1474 wrong. See the code that reads 'G's for symtabs. */
1475 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1476 VAR_DOMAIN, LOC_STATIC,
1477 data_sect_index,
1478 psymbol_placement::GLOBAL,
1479 nlist.n_value, psymtab_language,
1480 partial_symtabs, objfile);
1481 continue;
1482
1483 case 'T':
1484 /* When a 'T' entry is defining an anonymous enum, it
1485 may have a name which is the empty string, or a
1486 single space. Since they're not really defining a
1487 symbol, those shouldn't go in the partial symbol
1488 table. We do pick up the elements of such enums at
1489 'check_enum:', below. */
1490 if (p >= namestring + 2
1491 || (p == namestring + 1
1492 && namestring[0] != ' '))
1493 {
1494 pst->add_psymbol (gdb::string_view (sym_name, sym_len),
1495 true, STRUCT_DOMAIN, LOC_TYPEDEF, -1,
1496 psymbol_placement::STATIC,
1497 0, psymtab_language,
1498 partial_symtabs, objfile);
1499 if (p[2] == 't')
1500 {
1501 /* Also a typedef with the same name. */
1502 pst->add_psymbol (gdb::string_view (sym_name, sym_len),
1503 true, VAR_DOMAIN, LOC_TYPEDEF, -1,
1504 psymbol_placement::STATIC,
1505 0, psymtab_language,
1506 partial_symtabs, objfile);
1507 p += 1;
1508 }
1509 }
1510 goto check_enum;
1511
1512 case 't':
1513 if (p != namestring) /* a name is there, not just :T... */
1514 {
1515 pst->add_psymbol (gdb::string_view (sym_name, sym_len),
1516 true, VAR_DOMAIN, LOC_TYPEDEF, -1,
1517 psymbol_placement::STATIC,
1518 0, psymtab_language,
1519 partial_symtabs, objfile);
1520 }
1521 check_enum:
1522 /* If this is an enumerated type, we need to
1523 add all the enum constants to the partial symbol
1524 table. This does not cover enums without names, e.g.
1525 "enum {a, b} c;" in C, but fortunately those are
1526 rare. There is no way for GDB to find those from the
1527 enum type without spending too much time on it. Thus
1528 to solve this problem, the compiler needs to put out the
1529 enum in a nameless type. GCC2 does this. */
1530
1531 /* We are looking for something of the form
1532 <name> ":" ("t" | "T") [<number> "="] "e"
1533 {<constant> ":" <value> ","} ";". */
1534
1535 /* Skip over the colon and the 't' or 'T'. */
1536 p += 2;
1537 /* This type may be given a number. Also, numbers can come
1538 in pairs like (0,26). Skip over it. */
1539 while ((*p >= '0' && *p <= '9')
1540 || *p == '(' || *p == ',' || *p == ')'
1541 || *p == '=')
1542 p++;
1543
1544 if (*p++ == 'e')
1545 {
1546 /* The aix4 compiler emits extra crud before the members. */
1547 if (*p == '-')
1548 {
1549 /* Skip over the type (?). */
1550 while (*p != ':')
1551 p++;
1552
1553 /* Skip over the colon. */
1554 p++;
1555 }
1556
1557 /* We have found an enumerated type. */
1558 /* According to comments in read_enum_type
1559 a comma could end it instead of a semicolon.
1560 I don't know where that happens.
1561 Accept either. */
1562 while (*p && *p != ';' && *p != ',')
1563 {
1564 const char *q;
1565
1566 /* Check for and handle cretinous dbx symbol name
1567 continuation! */
1568 if (*p == '\\' || (*p == '?' && p[1] == '\0'))
1569 p = next_symbol_text (objfile);
1570
1571 /* Point to the character after the name
1572 of the enum constant. */
1573 for (q = p; *q && *q != ':'; q++)
1574 ;
1575 /* Note that the value doesn't matter for
1576 enum constants in psymtabs, just in symtabs. */
1577 pst->add_psymbol (gdb::string_view (p, q - p), true,
1578 VAR_DOMAIN, LOC_CONST, -1,
1579 psymbol_placement::STATIC, 0,
1580 psymtab_language,
1581 partial_symtabs, objfile);
1582 /* Point past the name. */
1583 p = q;
1584 /* Skip over the value. */
1585 while (*p && *p != ',')
1586 p++;
1587 /* Advance past the comma. */
1588 if (*p)
1589 p++;
1590 }
1591 }
1592 continue;
1593
1594 case 'c':
1595 /* Constant, e.g. from "const" in Pascal. */
1596 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1597 VAR_DOMAIN, LOC_CONST, -1,
1598 psymbol_placement::STATIC, 0,
1599 psymtab_language,
1600 partial_symtabs, objfile);
1601 continue;
1602
1603 case 'f':
1604 if (! pst)
1605 {
1606 int name_len = p - namestring;
1607 char *name = (char *) xmalloc (name_len + 1);
1608
1609 memcpy (name, namestring, name_len);
1610 name[name_len] = '\0';
1611 function_outside_compilation_unit_complaint (name);
1612 xfree (name);
1613 }
1614 /* Kludges for ELF/STABS with Sun ACC. */
1615 last_function_name = namestring;
1616 /* Do not fix textlow==0 for .o or NLM files, as 0 is a legit
1617 value for the bottom of the text seg in those cases. */
1618 if (nlist.n_value == 0
1619 && gdbarch_sofun_address_maybe_missing (gdbarch))
1620 {
1621 struct bound_minimal_symbol minsym
1622 = find_stab_function (namestring,
1623 pst ? pst->filename : NULL,
1624 objfile);
1625 if (minsym.minsym != NULL)
1626 nlist.n_value = MSYMBOL_VALUE_RAW_ADDRESS (minsym.minsym);
1627 }
1628 if (pst && textlow_not_set
1629 && gdbarch_sofun_address_maybe_missing (gdbarch))
1630 {
1631 pst->set_text_low (nlist.n_value);
1632 textlow_not_set = 0;
1633 }
1634 /* End kludge. */
1635
1636 /* Keep track of the start of the last function so we
1637 can handle end of function symbols. */
1638 last_function_start = nlist.n_value;
1639
1640 /* In reordered executables this function may lie outside
1641 the bounds created by N_SO symbols. If that's the case
1642 use the address of this function as the low bound for
1643 the partial symbol table. */
1644 if (pst
1645 && (textlow_not_set
1646 || (nlist.n_value < pst->raw_text_low ()
1647 && (nlist.n_value != 0))))
1648 {
1649 pst->set_text_low (nlist.n_value);
1650 textlow_not_set = 0;
1651 }
1652 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1653 VAR_DOMAIN, LOC_BLOCK,
1654 SECT_OFF_TEXT (objfile),
1655 psymbol_placement::STATIC,
1656 nlist.n_value, psymtab_language,
1657 partial_symtabs, objfile);
1658 continue;
1659
1660 /* Global functions were ignored here, but now they
1661 are put into the global psymtab like one would expect.
1662 They're also in the minimal symbol table. */
1663 case 'F':
1664 if (! pst)
1665 {
1666 int name_len = p - namestring;
1667 char *name = (char *) xmalloc (name_len + 1);
1668
1669 memcpy (name, namestring, name_len);
1670 name[name_len] = '\0';
1671 function_outside_compilation_unit_complaint (name);
1672 xfree (name);
1673 }
1674 /* Kludges for ELF/STABS with Sun ACC. */
1675 last_function_name = namestring;
1676 /* Do not fix textlow==0 for .o or NLM files, as 0 is a legit
1677 value for the bottom of the text seg in those cases. */
1678 if (nlist.n_value == 0
1679 && gdbarch_sofun_address_maybe_missing (gdbarch))
1680 {
1681 struct bound_minimal_symbol minsym
1682 = find_stab_function (namestring,
1683 pst ? pst->filename : NULL,
1684 objfile);
1685 if (minsym.minsym != NULL)
1686 nlist.n_value = MSYMBOL_VALUE_RAW_ADDRESS (minsym.minsym);
1687 }
1688 if (pst && textlow_not_set
1689 && gdbarch_sofun_address_maybe_missing (gdbarch))
1690 {
1691 pst->set_text_low (nlist.n_value);
1692 textlow_not_set = 0;
1693 }
1694 /* End kludge. */
1695
1696 /* Keep track of the start of the last function so we
1697 can handle end of function symbols. */
1698 last_function_start = nlist.n_value;
1699
1700 /* In reordered executables this function may lie outside
1701 the bounds created by N_SO symbols. If that's the case
1702 use the address of this function as the low bound for
1703 the partial symbol table. */
1704 if (pst
1705 && (textlow_not_set
1706 || (nlist.n_value < pst->raw_text_low ()
1707 && (nlist.n_value != 0))))
1708 {
1709 pst->set_text_low (nlist.n_value);
1710 textlow_not_set = 0;
1711 }
1712 pst->add_psymbol (gdb::string_view (sym_name, sym_len), true,
1713 VAR_DOMAIN, LOC_BLOCK,
1714 SECT_OFF_TEXT (objfile),
1715 psymbol_placement::GLOBAL,
1716 nlist.n_value, psymtab_language,
1717 partial_symtabs, objfile);
1718 continue;
1719
1720 /* Two things show up here (hopefully); static symbols of
1721 local scope (static used inside braces) or extensions
1722 of structure symbols. We can ignore both. */
1723 case 'V':
1724 case '(':
1725 case '0':
1726 case '1':
1727 case '2':
1728 case '3':
1729 case '4':
1730 case '5':
1731 case '6':
1732 case '7':
1733 case '8':
1734 case '9':
1735 case '-':
1736 case '#': /* For symbol identification (used in live ranges). */
1737 continue;
1738
1739 case ':':
1740 /* It is a C++ nested symbol. We don't need to record it
1741 (I don't think); if we try to look up foo::bar::baz,
1742 then symbols for the symtab containing foo should get
1743 read in, I think. */
1744 /* Someone says sun cc puts out symbols like
1745 /foo/baz/maclib::/usr/local/bin/maclib,
1746 which would get here with a symbol type of ':'. */
1747 continue;
1748
1749 default:
1750 /* Unexpected symbol descriptor. The second and subsequent stabs
1751 of a continued stab can show up here. The question is
1752 whether they ever can mimic a normal stab--it would be
1753 nice if not, since we certainly don't want to spend the
1754 time searching to the end of every string looking for
1755 a backslash. */
1756
1757 complaint (_("unknown symbol descriptor `%c'"),
1758 p[1]);
1759
1760 /* Ignore it; perhaps it is an extension that we don't
1761 know about. */
1762 continue;
1763 }
1764 }
1765
1766 case N_EXCL:
1767
1768 namestring = set_namestring (objfile, &nlist);
1769
1770 /* Find the corresponding bincl and mark that psymtab on the
1771 psymtab dependency list. */
1772 {
1773 legacy_psymtab *needed_pst =
1774 find_corresponding_bincl_psymtab (namestring, nlist.n_value);
1775
1776 /* If this include file was defined earlier in this file,
1777 leave it alone. */
1778 if (needed_pst == pst)
1779 continue;
1780
1781 if (needed_pst)
1782 {
1783 int i;
1784 int found = 0;
1785
1786 for (i = 0; i < dependencies_used; i++)
1787 if (dependency_list[i] == needed_pst)
1788 {
1789 found = 1;
1790 break;
1791 }
1792
1793 /* If it's already in the list, skip the rest. */
1794 if (found)
1795 continue;
1796
1797 dependency_list[dependencies_used++] = needed_pst;
1798 if (dependencies_used >= dependencies_allocated)
1799 {
1800 legacy_psymtab **orig = dependency_list;
1801
1802 dependency_list =
1803 (legacy_psymtab **)
1804 alloca ((dependencies_allocated *= 2)
1805 * sizeof (legacy_psymtab *));
1806 memcpy (dependency_list, orig,
1807 (dependencies_used
1808 * sizeof (legacy_psymtab *)));
1809 #ifdef DEBUG_INFO
1810 fprintf_unfiltered (gdb_stderr,
1811 "Had to reallocate "
1812 "dependency list.\n");
1813 fprintf_unfiltered (gdb_stderr,
1814 "New dependencies allocated: %d\n",
1815 dependencies_allocated);
1816 #endif
1817 }
1818 }
1819 }
1820 continue;
1821
1822 case N_ENDM:
1823 /* Solaris 2 end of module, finish current partial symbol
1824 table. dbx_end_psymtab will set the high text address of
1825 PST to the proper value, which is necessary if a module
1826 compiled without debugging info follows this module. */
1827 if (pst && gdbarch_sofun_address_maybe_missing (gdbarch))
1828 {
1829 dbx_end_psymtab (objfile, partial_symtabs, pst,
1830 psymtab_include_list, includes_used,
1831 symnum * symbol_size,
1832 (CORE_ADDR) 0, dependency_list,
1833 dependencies_used, textlow_not_set);
1834 pst = (legacy_psymtab *) 0;
1835 includes_used = 0;
1836 dependencies_used = 0;
1837 has_line_numbers = 0;
1838 }
1839 continue;
1840
1841 case N_RBRAC:
1842 #ifdef HANDLE_RBRAC
1843 HANDLE_RBRAC (nlist.n_value);
1844 continue;
1845 #endif
1846 case N_EINCL:
1847 case N_DSLINE:
1848 case N_BSLINE:
1849 case N_SSYM: /* Claim: Structure or union element.
1850 Hopefully, I can ignore this. */
1851 case N_ENTRY: /* Alternate entry point; can ignore. */
1852 case N_MAIN: /* Can definitely ignore this. */
1853 case N_CATCH: /* These are GNU C++ extensions */
1854 case N_EHDECL: /* that can safely be ignored here. */
1855 case N_LENG:
1856 case N_BCOMM:
1857 case N_ECOMM:
1858 case N_ECOML:
1859 case N_FNAME:
1860 case N_SLINE:
1861 case N_RSYM:
1862 case N_PSYM:
1863 case N_BNSYM:
1864 case N_ENSYM:
1865 case N_LBRAC:
1866 case N_NSYMS: /* Ultrix 4.0: symbol count */
1867 case N_DEFD: /* GNU Modula-2 */
1868 case N_ALIAS: /* SunPro F77: alias name, ignore for now. */
1869
1870 case N_OBJ: /* Useless types from Solaris. */
1871 case N_OPT:
1872 case N_PATCH:
1873 /* These symbols aren't interesting; don't worry about them. */
1874 continue;
1875
1876 default:
1877 /* If we haven't found it yet, ignore it. It's probably some
1878 new type we don't know about yet. */
1879 unknown_symtype_complaint (hex_string (nlist.n_type));
1880 continue;
1881 }
1882 }
1883
1884 /* If there's stuff to be cleaned up, clean it up. */
1885 if (pst)
1886 {
1887 /* Don't set high text address of PST lower than it already
1888 is. */
1889 CORE_ADDR text_end =
1890 (lowest_text_address == (CORE_ADDR) -1
1891 ? text_addr
1892 : lowest_text_address)
1893 + text_size;
1894
1895 dbx_end_psymtab (objfile, partial_symtabs,
1896 pst, psymtab_include_list, includes_used,
1897 symnum * symbol_size,
1898 (text_end > pst->raw_text_high ()
1899 ? text_end : pst->raw_text_high ()),
1900 dependency_list, dependencies_used, textlow_not_set);
1901 }
1902 }
1903
1904 /* Allocate and partially fill a partial symtab. It will be
1905 completely filled at the end of the symbol list.
1906
1907 SYMFILE_NAME is the name of the symbol-file we are reading from, and ADDR
1908 is the address relative to which its symbols are (incremental) or 0
1909 (normal). */
1910
1911 static legacy_psymtab *
1912 start_psymtab (psymtab_storage *partial_symtabs, struct objfile *objfile,
1913 const char *filename, CORE_ADDR textlow, int ldsymoff)
1914 {
1915 legacy_psymtab *result = new legacy_psymtab (filename, partial_symtabs,
1916 objfile->per_bfd, textlow);
1917
1918 result->read_symtab_private =
1919 XOBNEW (&objfile->objfile_obstack, struct symloc);
1920 LDSYMOFF (result) = ldsymoff;
1921 result->legacy_read_symtab = dbx_read_symtab;
1922 result->legacy_expand_psymtab = dbx_expand_psymtab;
1923 SYMBOL_SIZE (result) = symbol_size;
1924 SYMBOL_OFFSET (result) = symbol_table_offset;
1925 STRING_OFFSET (result) = string_table_offset;
1926 FILE_STRING_OFFSET (result) = file_string_table_offset;
1927
1928 /* Deduce the source language from the filename for this psymtab. */
1929 psymtab_language = deduce_language_from_filename (filename);
1930 PST_LANGUAGE (result) = psymtab_language;
1931
1932 return result;
1933 }
1934
1935 /* Close off the current usage of PST.
1936 Returns PST or NULL if the partial symtab was empty and thrown away.
1937
1938 FIXME: List variables and peculiarities of same. */
1939
1940 legacy_psymtab *
1941 dbx_end_psymtab (struct objfile *objfile, psymtab_storage *partial_symtabs,
1942 legacy_psymtab *pst,
1943 const char **include_list, int num_includes,
1944 int capping_symbol_offset, CORE_ADDR capping_text,
1945 legacy_psymtab **dependency_list,
1946 int number_dependencies,
1947 int textlow_not_set)
1948 {
1949 int i;
1950 struct gdbarch *gdbarch = objfile->arch ();
1951
1952 if (capping_symbol_offset != -1)
1953 LDSYMLEN (pst) = capping_symbol_offset - LDSYMOFF (pst);
1954 pst->set_text_high (capping_text);
1955
1956 /* Under Solaris, the N_SO symbols always have a value of 0,
1957 instead of the usual address of the .o file. Therefore,
1958 we have to do some tricks to fill in texthigh and textlow.
1959 The first trick is: if we see a static
1960 or global function, and the textlow for the current pst
1961 is not set (ie: textlow_not_set), then we use that function's
1962 address for the textlow of the pst. */
1963
1964 /* Now, to fill in texthigh, we remember the last function seen
1965 in the .o file. Also, there's a hack in
1966 bfd/elf.c and gdb/elfread.c to pass the ELF st_size field
1967 to here via the misc_info field. Therefore, we can fill in
1968 a reliable texthigh by taking the address plus size of the
1969 last function in the file. */
1970
1971 if (!pst->text_high_valid && last_function_name
1972 && gdbarch_sofun_address_maybe_missing (gdbarch))
1973 {
1974 int n;
1975 struct bound_minimal_symbol minsym;
1976
1977 const char *colon = strchr (last_function_name, ':');
1978 if (colon == NULL)
1979 n = 0;
1980 else
1981 n = colon - last_function_name;
1982 char *p = (char *) alloca (n + 2);
1983 strncpy (p, last_function_name, n);
1984 p[n] = 0;
1985
1986 minsym = lookup_minimal_symbol (p, pst->filename, objfile);
1987 if (minsym.minsym == NULL)
1988 {
1989 /* Sun Fortran appends an underscore to the minimal symbol name,
1990 try again with an appended underscore if the minimal symbol
1991 was not found. */
1992 p[n] = '_';
1993 p[n + 1] = 0;
1994 minsym = lookup_minimal_symbol (p, pst->filename, objfile);
1995 }
1996
1997 if (minsym.minsym)
1998 pst->set_text_high (MSYMBOL_VALUE_RAW_ADDRESS (minsym.minsym)
1999 + MSYMBOL_SIZE (minsym.minsym));
2000
2001 last_function_name = NULL;
2002 }
2003
2004 if (!gdbarch_sofun_address_maybe_missing (gdbarch))
2005 ;
2006 /* This test will be true if the last .o file is only data. */
2007 else if (textlow_not_set)
2008 pst->set_text_low (pst->raw_text_high ());
2009 else
2010 {
2011 /* If we know our own starting text address, then walk through all other
2012 psymtabs for this objfile, and if any didn't know their ending text
2013 address, set it to our starting address. Take care to not set our
2014 own ending address to our starting address. */
2015
2016 for (partial_symtab *p1 : partial_symtabs->range ())
2017 if (!p1->text_high_valid && p1->text_low_valid && p1 != pst)
2018 p1->set_text_high (pst->raw_text_low ());
2019 }
2020
2021 /* End of kludge for patching Solaris textlow and texthigh. */
2022
2023 pst->end ();
2024
2025 pst->number_of_dependencies = number_dependencies;
2026 if (number_dependencies)
2027 {
2028 pst->dependencies
2029 = partial_symtabs->allocate_dependencies (number_dependencies);
2030 memcpy (pst->dependencies, dependency_list,
2031 number_dependencies * sizeof (legacy_psymtab *));
2032 }
2033 else
2034 pst->dependencies = 0;
2035
2036 for (i = 0; i < num_includes; i++)
2037 {
2038 legacy_psymtab *subpst =
2039 new legacy_psymtab (include_list[i], partial_symtabs, objfile->per_bfd);
2040
2041 subpst->read_symtab_private =
2042 XOBNEW (&objfile->objfile_obstack, struct symloc);
2043 LDSYMOFF (subpst) =
2044 LDSYMLEN (subpst) = 0;
2045
2046 /* We could save slight bits of space by only making one of these,
2047 shared by the entire set of include files. FIXME-someday. */
2048 subpst->dependencies =
2049 partial_symtabs->allocate_dependencies (1);
2050 subpst->dependencies[0] = pst;
2051 subpst->number_of_dependencies = 1;
2052
2053 subpst->legacy_read_symtab = pst->legacy_read_symtab;
2054 subpst->legacy_expand_psymtab = pst->legacy_expand_psymtab;
2055 }
2056
2057 if (num_includes == 0
2058 && number_dependencies == 0
2059 && pst->empty ()
2060 && has_line_numbers == 0)
2061 {
2062 /* Throw away this psymtab, it's empty. */
2063 /* Empty psymtabs happen as a result of header files which don't have
2064 any symbols in them. There can be a lot of them. But this check
2065 is wrong, in that a psymtab with N_SLINE entries but nothing else
2066 is not empty, but we don't realize that. Fixing that without slowing
2067 things down might be tricky. */
2068
2069 partial_symtabs->discard_psymtab (pst);
2070
2071 /* Indicate that psymtab was thrown away. */
2072 pst = NULL;
2073 }
2074 return pst;
2075 }
2076 \f
2077 static void
2078 dbx_expand_psymtab (legacy_psymtab *pst, struct objfile *objfile)
2079 {
2080 gdb_assert (!pst->readin);
2081
2082 /* Read in all partial symtabs on which this one is dependent. */
2083 pst->expand_dependencies (objfile);
2084
2085 if (LDSYMLEN (pst)) /* Otherwise it's a dummy. */
2086 {
2087 /* Init stuff necessary for reading in symbols */
2088 stabsread_init ();
2089 scoped_free_pendings free_pending;
2090 file_string_table_offset = FILE_STRING_OFFSET (pst);
2091 symbol_size = SYMBOL_SIZE (pst);
2092
2093 /* Read in this file's symbols. */
2094 bfd_seek (objfile->obfd, SYMBOL_OFFSET (pst), SEEK_SET);
2095 read_ofile_symtab (objfile, pst);
2096 }
2097
2098 pst->readin = true;
2099 }
2100
2101 /* Read in all of the symbols for a given psymtab for real.
2102 Be verbose about it if the user wants that. SELF is not NULL. */
2103
2104 static void
2105 dbx_read_symtab (legacy_psymtab *self, struct objfile *objfile)
2106 {
2107 gdb_assert (!self->readin);
2108
2109 if (LDSYMLEN (self) || self->number_of_dependencies)
2110 {
2111 next_symbol_text_func = dbx_next_symbol_text;
2112
2113 {
2114 scoped_restore restore_stabs_data = make_scoped_restore (&stabs_data);
2115 gdb::unique_xmalloc_ptr<gdb_byte> data_holder;
2116 if (DBX_STAB_SECTION (objfile))
2117 {
2118 stabs_data
2119 = symfile_relocate_debug_section (objfile,
2120 DBX_STAB_SECTION (objfile),
2121 NULL);
2122 data_holder.reset (stabs_data);
2123 }
2124
2125 self->expand_psymtab (objfile);
2126 }
2127
2128 /* Match with global symbols. This only needs to be done once,
2129 after all of the symtabs and dependencies have been read in. */
2130 scan_file_globals (objfile);
2131 }
2132 }
2133
2134 /* Read in a defined section of a specific object file's symbols. */
2135
2136 static void
2137 read_ofile_symtab (struct objfile *objfile, legacy_psymtab *pst)
2138 {
2139 const char *namestring;
2140 struct external_nlist *bufp;
2141 struct internal_nlist nlist;
2142 unsigned char type;
2143 unsigned max_symnum;
2144 bfd *abfd;
2145 int sym_offset; /* Offset to start of symbols to read */
2146 int sym_size; /* Size of symbols to read */
2147 CORE_ADDR text_offset; /* Start of text segment for symbols */
2148 int text_size; /* Size of text segment for symbols */
2149
2150 sym_offset = LDSYMOFF (pst);
2151 sym_size = LDSYMLEN (pst);
2152 text_offset = pst->text_low (objfile);
2153 text_size = pst->text_high (objfile) - pst->text_low (objfile);
2154 const section_offsets &section_offsets = objfile->section_offsets;
2155
2156 dbxread_objfile = objfile;
2157
2158 stringtab_global = DBX_STRINGTAB (objfile);
2159 set_last_source_file (NULL);
2160
2161 abfd = objfile->obfd;
2162 symfile_bfd = objfile->obfd; /* Implicit param to next_text_symbol. */
2163 symbuf_end = symbuf_idx = 0;
2164 symbuf_read = 0;
2165 symbuf_left = sym_offset + sym_size;
2166
2167 /* It is necessary to actually read one symbol *before* the start
2168 of this symtab's symbols, because the GCC_COMPILED_FLAG_SYMBOL
2169 occurs before the N_SO symbol.
2170
2171 Detecting this in read_dbx_symtab
2172 would slow down initial readin, so we look for it here instead. */
2173 if (!processing_acc_compilation && sym_offset >= (int) symbol_size)
2174 {
2175 stabs_seek (sym_offset - symbol_size);
2176 fill_symbuf (abfd);
2177 bufp = &symbuf[symbuf_idx++];
2178 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
2179 OBJSTAT (objfile, n_stabs++);
2180
2181 namestring = set_namestring (objfile, &nlist);
2182
2183 processing_gcc_compilation = 0;
2184 if (nlist.n_type == N_TEXT)
2185 {
2186 const char *tempstring = namestring;
2187
2188 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
2189 processing_gcc_compilation = 1;
2190 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2191 processing_gcc_compilation = 2;
2192 if (tempstring[0] == bfd_get_symbol_leading_char (symfile_bfd))
2193 ++tempstring;
2194 if (startswith (tempstring, "__gnu_compiled"))
2195 processing_gcc_compilation = 2;
2196 }
2197 }
2198 else
2199 {
2200 /* The N_SO starting this symtab is the first symbol, so we
2201 better not check the symbol before it. I'm not this can
2202 happen, but it doesn't hurt to check for it. */
2203 stabs_seek (sym_offset);
2204 processing_gcc_compilation = 0;
2205 }
2206
2207 if (symbuf_idx == symbuf_end)
2208 fill_symbuf (abfd);
2209 bufp = &symbuf[symbuf_idx];
2210 if (bfd_h_get_8 (abfd, bufp->e_type) != N_SO)
2211 error (_("First symbol in segment of executable not a source symbol"));
2212
2213 max_symnum = sym_size / symbol_size;
2214
2215 for (symnum = 0;
2216 symnum < max_symnum;
2217 symnum++)
2218 {
2219 QUIT; /* Allow this to be interruptable. */
2220 if (symbuf_idx == symbuf_end)
2221 fill_symbuf (abfd);
2222 bufp = &symbuf[symbuf_idx++];
2223 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
2224 OBJSTAT (objfile, n_stabs++);
2225
2226 type = bfd_h_get_8 (abfd, bufp->e_type);
2227
2228 namestring = set_namestring (objfile, &nlist);
2229
2230 if (type & N_STAB)
2231 {
2232 if (sizeof (nlist.n_value) > 4
2233 /* We are a 64-bit debugger debugging a 32-bit program. */
2234 && (type == N_LSYM || type == N_PSYM))
2235 /* We have to be careful with the n_value in the case of N_LSYM
2236 and N_PSYM entries, because they are signed offsets from frame
2237 pointer, but we actually read them as unsigned 32-bit values.
2238 This is not a problem for 32-bit debuggers, for which negative
2239 values end up being interpreted correctly (as negative
2240 offsets) due to integer overflow.
2241 But we need to sign-extend the value for 64-bit debuggers,
2242 or we'll end up interpreting negative values as very large
2243 positive offsets. */
2244 nlist.n_value = (nlist.n_value ^ 0x80000000) - 0x80000000;
2245 process_one_symbol (type, nlist.n_desc, nlist.n_value,
2246 namestring, section_offsets, objfile,
2247 PST_LANGUAGE (pst));
2248 }
2249 /* We skip checking for a new .o or -l file; that should never
2250 happen in this routine. */
2251 else if (type == N_TEXT)
2252 {
2253 /* I don't think this code will ever be executed, because
2254 the GCC_COMPILED_FLAG_SYMBOL usually is right before
2255 the N_SO symbol which starts this source file.
2256 However, there is no reason not to accept
2257 the GCC_COMPILED_FLAG_SYMBOL anywhere. */
2258
2259 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
2260 processing_gcc_compilation = 1;
2261 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2262 processing_gcc_compilation = 2;
2263 }
2264 else if (type & N_EXT || type == (unsigned char) N_TEXT
2265 || type == (unsigned char) N_NBTEXT)
2266 {
2267 /* Global symbol: see if we came across a dbx definition for
2268 a corresponding symbol. If so, store the value. Remove
2269 syms from the chain when their values are stored, but
2270 search the whole chain, as there may be several syms from
2271 different files with the same name. */
2272 /* This is probably not true. Since the files will be read
2273 in one at a time, each reference to a global symbol will
2274 be satisfied in each file as it appears. So we skip this
2275 section. */
2276 ;
2277 }
2278 }
2279
2280 /* In a Solaris elf file, this variable, which comes from the value
2281 of the N_SO symbol, will still be 0. Luckily, text_offset, which
2282 comes from low text address of PST, is correct. */
2283 if (get_last_source_start_addr () == 0)
2284 set_last_source_start_addr (text_offset);
2285
2286 /* In reordered executables last_source_start_addr may not be the
2287 lower bound for this symtab, instead use text_offset which comes
2288 from the low text address of PST, which is correct. */
2289 if (get_last_source_start_addr () > text_offset)
2290 set_last_source_start_addr (text_offset);
2291
2292 pst->compunit_symtab = end_symtab (text_offset + text_size,
2293 SECT_OFF_TEXT (objfile));
2294
2295 end_stabs ();
2296
2297 dbxread_objfile = NULL;
2298 }
2299 \f
2300
2301 /* Record the namespace that the function defined by SYMBOL was
2302 defined in, if necessary. BLOCK is the associated block; use
2303 OBSTACK for allocation. */
2304
2305 static void
2306 cp_set_block_scope (const struct symbol *symbol,
2307 struct block *block,
2308 struct obstack *obstack)
2309 {
2310 if (symbol->demangled_name () != NULL)
2311 {
2312 /* Try to figure out the appropriate namespace from the
2313 demangled name. */
2314
2315 /* FIXME: carlton/2003-04-15: If the function in question is
2316 a method of a class, the name will actually include the
2317 name of the class as well. This should be harmless, but
2318 is a little unfortunate. */
2319
2320 const char *name = symbol->demangled_name ();
2321 unsigned int prefix_len = cp_entire_prefix_len (name);
2322
2323 block_set_scope (block, obstack_strndup (obstack, name, prefix_len),
2324 obstack);
2325 }
2326 }
2327
2328 /* This handles a single symbol from the symbol-file, building symbols
2329 into a GDB symtab. It takes these arguments and an implicit argument.
2330
2331 TYPE is the type field of the ".stab" symbol entry.
2332 DESC is the desc field of the ".stab" entry.
2333 VALU is the value field of the ".stab" entry.
2334 NAME is the symbol name, in our address space.
2335 SECTION_OFFSETS is a set of amounts by which the sections of this
2336 object file were relocated when it was loaded into memory. Note
2337 that these section_offsets are not the objfile->section_offsets but
2338 the pst->section_offsets. All symbols that refer to memory
2339 locations need to be offset by these amounts.
2340 OBJFILE is the object file from which we are reading symbols. It
2341 is used in end_symtab.
2342 LANGUAGE is the language of the symtab.
2343 */
2344
2345 void
2346 process_one_symbol (int type, int desc, CORE_ADDR valu, const char *name,
2347 const section_offsets &section_offsets,
2348 struct objfile *objfile, enum language language)
2349 {
2350 struct gdbarch *gdbarch = objfile->arch ();
2351 struct context_stack *newobj;
2352 struct context_stack cstk;
2353 /* This remembers the address of the start of a function. It is
2354 used because in Solaris 2, N_LBRAC, N_RBRAC, and N_SLINE entries
2355 are relative to the current function's start address. On systems
2356 other than Solaris 2, this just holds the SECT_OFF_TEXT value,
2357 and is used to relocate these symbol types rather than
2358 SECTION_OFFSETS. */
2359 static CORE_ADDR function_start_offset;
2360
2361 /* This holds the address of the start of a function, without the
2362 system peculiarities of function_start_offset. */
2363 static CORE_ADDR last_function_start;
2364
2365 /* If this is nonzero, we've seen an N_SLINE since the start of the
2366 current function. We use this to tell us to move the first sline
2367 to the beginning of the function regardless of what its given
2368 value is. */
2369 static int sline_found_in_function = 1;
2370
2371 /* If this is nonzero, we've seen a non-gcc N_OPT symbol for this
2372 source file. Used to detect the SunPRO solaris compiler. */
2373 static int n_opt_found;
2374
2375 /* Something is wrong if we see real data before seeing a source
2376 file name. */
2377
2378 if (get_last_source_file () == NULL && type != (unsigned char) N_SO)
2379 {
2380 /* Ignore any symbols which appear before an N_SO symbol.
2381 Currently no one puts symbols there, but we should deal
2382 gracefully with the case. A complain()t might be in order,
2383 but this should not be an error (). */
2384 return;
2385 }
2386
2387 switch (type)
2388 {
2389 case N_FUN:
2390 case N_FNAME:
2391
2392 if (*name == '\000')
2393 {
2394 /* This N_FUN marks the end of a function. This closes off
2395 the current block. */
2396 struct block *block;
2397
2398 if (outermost_context_p ())
2399 {
2400 lbrac_mismatch_complaint (symnum);
2401 break;
2402 }
2403
2404 /* The following check is added before recording line 0 at
2405 end of function so as to handle hand-generated stabs
2406 which may have an N_FUN stabs at the end of the function,
2407 but no N_SLINE stabs. */
2408 if (sline_found_in_function)
2409 {
2410 CORE_ADDR addr = last_function_start + valu;
2411
2412 record_line (get_current_subfile (), 0,
2413 gdbarch_addr_bits_remove (gdbarch, addr));
2414 }
2415
2416 within_function = 0;
2417 cstk = pop_context ();
2418
2419 /* Make a block for the local symbols within. */
2420 block = finish_block (cstk.name,
2421 cstk.old_blocks, NULL,
2422 cstk.start_addr, cstk.start_addr + valu);
2423
2424 /* For C++, set the block's scope. */
2425 if (cstk.name->language () == language_cplus)
2426 cp_set_block_scope (cstk.name, block, &objfile->objfile_obstack);
2427
2428 /* May be switching to an assembler file which may not be using
2429 block relative stabs, so reset the offset. */
2430 function_start_offset = 0;
2431
2432 break;
2433 }
2434
2435 sline_found_in_function = 0;
2436
2437 /* Relocate for dynamic loading. */
2438 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2439 valu = gdbarch_addr_bits_remove (gdbarch, valu);
2440 last_function_start = valu;
2441
2442 goto define_a_symbol;
2443
2444 case N_LBRAC:
2445 /* This "symbol" just indicates the start of an inner lexical
2446 context within a function. */
2447
2448 /* Ignore extra outermost context from SunPRO cc and acc. */
2449 if (n_opt_found && desc == 1)
2450 break;
2451
2452 valu += function_start_offset;
2453
2454 push_context (desc, valu);
2455 break;
2456
2457 case N_RBRAC:
2458 /* This "symbol" just indicates the end of an inner lexical
2459 context that was started with N_LBRAC. */
2460
2461 /* Ignore extra outermost context from SunPRO cc and acc. */
2462 if (n_opt_found && desc == 1)
2463 break;
2464
2465 valu += function_start_offset;
2466
2467 if (outermost_context_p ())
2468 {
2469 lbrac_mismatch_complaint (symnum);
2470 break;
2471 }
2472
2473 cstk = pop_context ();
2474 if (desc != cstk.depth)
2475 lbrac_mismatch_complaint (symnum);
2476
2477 if (*get_local_symbols () != NULL)
2478 {
2479 /* GCC development snapshots from March to December of
2480 2000 would output N_LSYM entries after N_LBRAC
2481 entries. As a consequence, these symbols are simply
2482 discarded. Complain if this is the case. */
2483 complaint (_("misplaced N_LBRAC entry; discarding local "
2484 "symbols which have no enclosing block"));
2485 }
2486 *get_local_symbols () = cstk.locals;
2487
2488 if (get_context_stack_depth () > 1)
2489 {
2490 /* This is not the outermost LBRAC...RBRAC pair in the
2491 function, its local symbols preceded it, and are the ones
2492 just recovered from the context stack. Define the block
2493 for them (but don't bother if the block contains no
2494 symbols. Should we complain on blocks without symbols?
2495 I can't think of any useful purpose for them). */
2496 if (*get_local_symbols () != NULL)
2497 {
2498 /* Muzzle a compiler bug that makes end < start.
2499
2500 ??? Which compilers? Is this ever harmful?. */
2501 if (cstk.start_addr > valu)
2502 {
2503 complaint (_("block start larger than block end"));
2504 cstk.start_addr = valu;
2505 }
2506 /* Make a block for the local symbols within. */
2507 finish_block (0, cstk.old_blocks, NULL,
2508 cstk.start_addr, valu);
2509 }
2510 }
2511 else
2512 {
2513 /* This is the outermost LBRAC...RBRAC pair. There is no
2514 need to do anything; leave the symbols that preceded it
2515 to be attached to the function's own block. We need to
2516 indicate that we just moved outside of the function. */
2517 within_function = 0;
2518 }
2519
2520 break;
2521
2522 case N_FN:
2523 case N_FN_SEQ:
2524 /* This kind of symbol indicates the start of an object file.
2525 Relocate for dynamic loading. */
2526 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2527 break;
2528
2529 case N_SO:
2530 /* This type of symbol indicates the start of data for one
2531 source file. Finish the symbol table of the previous source
2532 file (if any) and start accumulating a new symbol table.
2533 Relocate for dynamic loading. */
2534 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2535
2536 n_opt_found = 0;
2537
2538 if (get_last_source_file ())
2539 {
2540 /* Check if previous symbol was also an N_SO (with some
2541 sanity checks). If so, that one was actually the
2542 directory name, and the current one is the real file
2543 name. Patch things up. */
2544 if (previous_stab_code == (unsigned char) N_SO)
2545 {
2546 patch_subfile_names (get_current_subfile (), name);
2547 break; /* Ignore repeated SOs. */
2548 }
2549 end_symtab (valu, SECT_OFF_TEXT (objfile));
2550 end_stabs ();
2551 }
2552
2553 /* Null name means this just marks the end of text for this .o
2554 file. Don't start a new symtab in this case. */
2555 if (*name == '\000')
2556 break;
2557
2558 function_start_offset = 0;
2559
2560 start_stabs ();
2561 start_symtab (objfile, name, NULL, valu, language);
2562 record_debugformat ("stabs");
2563 break;
2564
2565 case N_SOL:
2566 /* This type of symbol indicates the start of data for a
2567 sub-source-file, one whose contents were copied or included
2568 in the compilation of the main source file (whose name was
2569 given in the N_SO symbol). Relocate for dynamic loading. */
2570 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2571 start_subfile (name);
2572 break;
2573
2574 case N_BINCL:
2575 push_subfile ();
2576 add_new_header_file (name, valu);
2577 start_subfile (name);
2578 break;
2579
2580 case N_EINCL:
2581 start_subfile (pop_subfile ());
2582 break;
2583
2584 case N_EXCL:
2585 add_old_header_file (name, valu);
2586 break;
2587
2588 case N_SLINE:
2589 /* This type of "symbol" really just records one line-number --
2590 core-address correspondence. Enter it in the line list for
2591 this symbol table. */
2592
2593 /* Relocate for dynamic loading and for ELF acc
2594 function-relative symbols. */
2595 valu += function_start_offset;
2596
2597 /* GCC 2.95.3 emits the first N_SLINE stab somewhere in the
2598 middle of the prologue instead of right at the start of the
2599 function. To deal with this we record the address for the
2600 first N_SLINE stab to be the start of the function instead of
2601 the listed location. We really shouldn't to this. When
2602 compiling with optimization, this first N_SLINE stab might be
2603 optimized away. Other (non-GCC) compilers don't emit this
2604 stab at all. There is no real harm in having an extra
2605 numbered line, although it can be a bit annoying for the
2606 user. However, it totally screws up our testsuite.
2607
2608 So for now, keep adjusting the address of the first N_SLINE
2609 stab, but only for code compiled with GCC. */
2610
2611 if (within_function && sline_found_in_function == 0)
2612 {
2613 CORE_ADDR addr = processing_gcc_compilation == 2 ?
2614 last_function_start : valu;
2615
2616 record_line (get_current_subfile (), desc,
2617 gdbarch_addr_bits_remove (gdbarch, addr));
2618 sline_found_in_function = 1;
2619 }
2620 else
2621 record_line (get_current_subfile (), desc,
2622 gdbarch_addr_bits_remove (gdbarch, valu));
2623 break;
2624
2625 case N_BCOMM:
2626 common_block_start (name, objfile);
2627 break;
2628
2629 case N_ECOMM:
2630 common_block_end (objfile);
2631 break;
2632
2633 /* The following symbol types need to have the appropriate
2634 offset added to their value; then we process symbol
2635 definitions in the name. */
2636
2637 case N_STSYM: /* Static symbol in data segment. */
2638 case N_LCSYM: /* Static symbol in BSS segment. */
2639 case N_ROSYM: /* Static symbol in read-only data segment. */
2640 /* HORRID HACK DEPT. However, it's Sun's furgin' fault.
2641 Solaris 2's stabs-in-elf makes *most* symbols relative but
2642 leaves a few absolute (at least for Solaris 2.1 and version
2643 2.0.1 of the SunPRO compiler). N_STSYM and friends sit on
2644 the fence. .stab "foo:S...",N_STSYM is absolute (ld
2645 relocates it) .stab "foo:V...",N_STSYM is relative (section
2646 base subtracted). This leaves us no choice but to search for
2647 the 'S' or 'V'... (or pass the whole section_offsets stuff
2648 down ONE MORE function call level, which we really don't want
2649 to do). */
2650 {
2651 const char *p;
2652
2653 /* Normal object file and NLMs have non-zero text seg offsets,
2654 but don't need their static syms offset in this fashion.
2655 XXX - This is really a crock that should be fixed in the
2656 solib handling code so that I don't have to work around it
2657 here. */
2658
2659 if (!symfile_relocatable)
2660 {
2661 p = strchr (name, ':');
2662 if (p != 0 && p[1] == 'S')
2663 {
2664 /* The linker relocated it. We don't want to add a
2665 Sun-stabs Tfoo.foo-like offset, but we *do*
2666 want to add whatever solib.c passed to
2667 symbol_file_add as addr (this is known to affect
2668 SunOS 4, and I suspect ELF too). Since there is no
2669 Ttext.text symbol, we can get addr from the text offset. */
2670 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2671 goto define_a_symbol;
2672 }
2673 }
2674 /* Since it's not the kludge case, re-dispatch to the right
2675 handler. */
2676 switch (type)
2677 {
2678 case N_STSYM:
2679 goto case_N_STSYM;
2680 case N_LCSYM:
2681 goto case_N_LCSYM;
2682 case N_ROSYM:
2683 goto case_N_ROSYM;
2684 default:
2685 internal_error (__FILE__, __LINE__,
2686 _("failed internal consistency check"));
2687 }
2688 }
2689
2690 case_N_STSYM: /* Static symbol in data segment. */
2691 case N_DSLINE: /* Source line number, data segment. */
2692 valu += section_offsets[SECT_OFF_DATA (objfile)];
2693 goto define_a_symbol;
2694
2695 case_N_LCSYM: /* Static symbol in BSS segment. */
2696 case N_BSLINE: /* Source line number, BSS segment. */
2697 /* N_BROWS: overlaps with N_BSLINE. */
2698 valu += section_offsets[SECT_OFF_BSS (objfile)];
2699 goto define_a_symbol;
2700
2701 case_N_ROSYM: /* Static symbol in read-only data segment. */
2702 valu += section_offsets[SECT_OFF_RODATA (objfile)];
2703 goto define_a_symbol;
2704
2705 case N_ENTRY: /* Alternate entry point. */
2706 /* Relocate for dynamic loading. */
2707 valu += section_offsets[SECT_OFF_TEXT (objfile)];
2708 goto define_a_symbol;
2709
2710 /* The following symbol types we don't know how to process.
2711 Handle them in a "default" way, but complain to people who
2712 care. */
2713 default:
2714 case N_CATCH: /* Exception handler catcher. */
2715 case N_EHDECL: /* Exception handler name. */
2716 case N_PC: /* Global symbol in Pascal. */
2717 case N_M2C: /* Modula-2 compilation unit. */
2718 /* N_MOD2: overlaps with N_EHDECL. */
2719 case N_SCOPE: /* Modula-2 scope information. */
2720 case N_ECOML: /* End common (local name). */
2721 case N_NBTEXT: /* Gould Non-Base-Register symbols??? */
2722 case N_NBDATA:
2723 case N_NBBSS:
2724 case N_NBSTS:
2725 case N_NBLCS:
2726 unknown_symtype_complaint (hex_string (type));
2727 /* FALLTHROUGH */
2728
2729 define_a_symbol:
2730 /* These symbol types don't need the address field relocated,
2731 since it is either unused, or is absolute. */
2732 case N_GSYM: /* Global variable. */
2733 case N_NSYMS: /* Number of symbols (Ultrix). */
2734 case N_NOMAP: /* No map? (Ultrix). */
2735 case N_RSYM: /* Register variable. */
2736 case N_DEFD: /* Modula-2 GNU module dependency. */
2737 case N_SSYM: /* Struct or union element. */
2738 case N_LSYM: /* Local symbol in stack. */
2739 case N_PSYM: /* Parameter variable. */
2740 case N_LENG: /* Length of preceding symbol type. */
2741 if (name)
2742 {
2743 int deftype;
2744 const char *colon_pos = strchr (name, ':');
2745
2746 if (colon_pos == NULL)
2747 deftype = '\0';
2748 else
2749 deftype = colon_pos[1];
2750
2751 switch (deftype)
2752 {
2753 case 'f':
2754 case 'F':
2755 /* Deal with the SunPRO 3.0 compiler which omits the
2756 address from N_FUN symbols. */
2757 if (type == N_FUN
2758 && valu == section_offsets[SECT_OFF_TEXT (objfile)]
2759 && gdbarch_sofun_address_maybe_missing (gdbarch))
2760 {
2761 struct bound_minimal_symbol minsym
2762 = find_stab_function (name, get_last_source_file (),
2763 objfile);
2764 if (minsym.minsym != NULL)
2765 valu = BMSYMBOL_VALUE_ADDRESS (minsym);
2766 }
2767
2768 /* These addresses are absolute. */
2769 function_start_offset = valu;
2770
2771 within_function = 1;
2772
2773 if (get_context_stack_depth () > 1)
2774 {
2775 complaint (_("unmatched N_LBRAC before symtab pos %d"),
2776 symnum);
2777 break;
2778 }
2779
2780 if (!outermost_context_p ())
2781 {
2782 struct block *block;
2783
2784 cstk = pop_context ();
2785 /* Make a block for the local symbols within. */
2786 block = finish_block (cstk.name,
2787 cstk.old_blocks, NULL,
2788 cstk.start_addr, valu);
2789
2790 /* For C++, set the block's scope. */
2791 if (cstk.name->language () == language_cplus)
2792 cp_set_block_scope (cstk.name, block,
2793 &objfile->objfile_obstack);
2794 }
2795
2796 newobj = push_context (0, valu);
2797 newobj->name = define_symbol (valu, name, desc, type, objfile);
2798 break;
2799
2800 default:
2801 define_symbol (valu, name, desc, type, objfile);
2802 break;
2803 }
2804 }
2805 break;
2806
2807 /* We use N_OPT to carry the gcc2_compiled flag. Sun uses it
2808 for a bunch of other flags, too. Someday we may parse their
2809 flags; for now we ignore theirs and hope they'll ignore ours. */
2810 case N_OPT: /* Solaris 2: Compiler options. */
2811 if (name)
2812 {
2813 if (strcmp (name, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2814 {
2815 processing_gcc_compilation = 2;
2816 }
2817 else
2818 n_opt_found = 1;
2819 }
2820 break;
2821
2822 case N_MAIN: /* Name of main routine. */
2823 /* FIXME: If one has a symbol file with N_MAIN and then replaces
2824 it with a symbol file with "main" and without N_MAIN. I'm
2825 not sure exactly what rule to follow but probably something
2826 like: N_MAIN takes precedence over "main" no matter what
2827 objfile it is in; If there is more than one N_MAIN, choose
2828 the one in the symfile_objfile; If there is more than one
2829 N_MAIN within a given objfile, complain() and choose
2830 arbitrarily. (kingdon) */
2831 if (name != NULL)
2832 set_objfile_main_name (objfile, name, language_unknown);
2833 break;
2834
2835 /* The following symbol types can be ignored. */
2836 case N_OBJ: /* Solaris 2: Object file dir and name. */
2837 case N_PATCH: /* Solaris 2: Patch Run Time Checker. */
2838 /* N_UNDF: Solaris 2: File separator mark. */
2839 /* N_UNDF: -- we will never encounter it, since we only process
2840 one file's symbols at once. */
2841 case N_ENDM: /* Solaris 2: End of module. */
2842 case N_ALIAS: /* SunPro F77: alias name, ignore for now. */
2843 break;
2844 }
2845
2846 /* '#' is a GNU C extension to allow one symbol to refer to another
2847 related symbol.
2848
2849 Generally this is used so that an alias can refer to its main
2850 symbol. */
2851 gdb_assert (name);
2852 if (name[0] == '#')
2853 {
2854 /* Initialize symbol reference names and determine if this is a
2855 definition. If a symbol reference is being defined, go ahead
2856 and add it. Otherwise, just return. */
2857
2858 const char *s = name;
2859 int refnum;
2860
2861 /* If this stab defines a new reference ID that is not on the
2862 reference list, then put it on the reference list.
2863
2864 We go ahead and advance NAME past the reference, even though
2865 it is not strictly necessary at this time. */
2866 refnum = symbol_reference_defined (&s);
2867 if (refnum >= 0)
2868 if (!ref_search (refnum))
2869 ref_add (refnum, 0, name, valu);
2870 name = s;
2871 }
2872
2873 previous_stab_code = type;
2874 }
2875 \f
2876 /* FIXME: The only difference between this and elfstab_build_psymtabs
2877 is the call to install_minimal_symbols for elf, and the support for
2878 split sections. If the differences are really that small, the code
2879 should be shared. */
2880
2881 /* Scan and build partial symbols for an coff symbol file.
2882 The coff file has already been processed to get its minimal symbols.
2883
2884 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
2885 rolled into one.
2886
2887 OBJFILE is the object file we are reading symbols from.
2888 ADDR is the address relative to which the symbols are (e.g.
2889 the base address of the text segment).
2890 TEXTADDR is the address of the text section.
2891 TEXTSIZE is the size of the text section.
2892 STABSECTS is the list of .stab sections in OBJFILE.
2893 STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
2894 .stabstr section exists.
2895
2896 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
2897 adjusted for coff details. */
2898
2899 void
2900 coffstab_build_psymtabs (struct objfile *objfile,
2901 CORE_ADDR textaddr, unsigned int textsize,
2902 const std::vector<asection *> &stabsects,
2903 file_ptr stabstroffset, unsigned int stabstrsize)
2904 {
2905 int val;
2906 bfd *sym_bfd = objfile->obfd;
2907 const char *name = bfd_get_filename (sym_bfd);
2908 unsigned int stabsize;
2909
2910 /* Allocate struct to keep track of stab reading. */
2911 dbx_objfile_data_key.emplace (objfile);
2912
2913 DBX_TEXT_ADDR (objfile) = textaddr;
2914 DBX_TEXT_SIZE (objfile) = textsize;
2915
2916 #define COFF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
2917 DBX_SYMBOL_SIZE (objfile) = COFF_STABS_SYMBOL_SIZE;
2918 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
2919
2920 if (stabstrsize > bfd_get_size (sym_bfd))
2921 error (_("ridiculous string table size: %d bytes"), stabstrsize);
2922 DBX_STRINGTAB (objfile) = (char *)
2923 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
2924 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
2925
2926 /* Now read in the string table in one big gulp. */
2927
2928 val = bfd_seek (sym_bfd, stabstroffset, SEEK_SET);
2929 if (val < 0)
2930 perror_with_name (name);
2931 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
2932 if (val != stabstrsize)
2933 perror_with_name (name);
2934
2935 stabsread_new_init ();
2936 free_header_files ();
2937 init_header_files ();
2938
2939 processing_acc_compilation = 1;
2940
2941 /* In a coff file, we've already installed the minimal symbols that came
2942 from the coff (non-stab) symbol table, so always act like an
2943 incremental load here. */
2944 scoped_restore save_symbuf_sections
2945 = make_scoped_restore (&symbuf_sections);
2946 if (stabsects.size () == 1)
2947 {
2948 stabsize = bfd_section_size (stabsects[0]);
2949 DBX_SYMCOUNT (objfile) = stabsize / DBX_SYMBOL_SIZE (objfile);
2950 DBX_SYMTAB_OFFSET (objfile) = stabsects[0]->filepos;
2951 }
2952 else
2953 {
2954 DBX_SYMCOUNT (objfile) = 0;
2955 for (asection *section : stabsects)
2956 {
2957 stabsize = bfd_section_size (section);
2958 DBX_SYMCOUNT (objfile) += stabsize / DBX_SYMBOL_SIZE (objfile);
2959 }
2960
2961 DBX_SYMTAB_OFFSET (objfile) = stabsects[0]->filepos;
2962
2963 sect_idx = 1;
2964 symbuf_sections = &stabsects;
2965 symbuf_left = bfd_section_size (stabsects[0]);
2966 symbuf_read = 0;
2967 }
2968
2969 dbx_symfile_read (objfile, 0);
2970 }
2971 \f
2972 /* Scan and build partial symbols for an ELF symbol file.
2973 This ELF file has already been processed to get its minimal symbols.
2974
2975 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
2976 rolled into one.
2977
2978 OBJFILE is the object file we are reading symbols from.
2979 ADDR is the address relative to which the symbols are (e.g.
2980 the base address of the text segment).
2981 STABSECT is the BFD section information for the .stab section.
2982 STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
2983 .stabstr section exists.
2984
2985 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
2986 adjusted for elf details. */
2987
2988 void
2989 elfstab_build_psymtabs (struct objfile *objfile, asection *stabsect,
2990 file_ptr stabstroffset, unsigned int stabstrsize)
2991 {
2992 int val;
2993 bfd *sym_bfd = objfile->obfd;
2994 const char *name = bfd_get_filename (sym_bfd);
2995
2996 stabsread_new_init ();
2997
2998 /* Allocate struct to keep track of stab reading. */
2999 dbx_objfile_data_key.emplace (objfile);
3000
3001 /* Find the first and last text address. dbx_symfile_read seems to
3002 want this. */
3003 find_text_range (sym_bfd, objfile);
3004
3005 #define ELF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
3006 DBX_SYMBOL_SIZE (objfile) = ELF_STABS_SYMBOL_SIZE;
3007 DBX_SYMCOUNT (objfile)
3008 = bfd_section_size (stabsect) / DBX_SYMBOL_SIZE (objfile);
3009 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
3010 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos;
3011 DBX_STAB_SECTION (objfile) = stabsect;
3012
3013 if (stabstrsize > bfd_get_size (sym_bfd))
3014 error (_("ridiculous string table size: %d bytes"), stabstrsize);
3015 DBX_STRINGTAB (objfile) = (char *)
3016 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
3017 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
3018
3019 /* Now read in the string table in one big gulp. */
3020
3021 val = bfd_seek (sym_bfd, stabstroffset, SEEK_SET);
3022 if (val < 0)
3023 perror_with_name (name);
3024 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
3025 if (val != stabstrsize)
3026 perror_with_name (name);
3027
3028 stabsread_new_init ();
3029 free_header_files ();
3030 init_header_files ();
3031
3032 processing_acc_compilation = 1;
3033
3034 symbuf_read = 0;
3035 symbuf_left = bfd_section_size (stabsect);
3036
3037 scoped_restore restore_stabs_data = make_scoped_restore (&stabs_data);
3038 gdb::unique_xmalloc_ptr<gdb_byte> data_holder;
3039
3040 stabs_data = symfile_relocate_debug_section (objfile, stabsect, NULL);
3041 if (stabs_data)
3042 data_holder.reset (stabs_data);
3043
3044 /* In an elf file, we've already installed the minimal symbols that came
3045 from the elf (non-stab) symbol table, so always act like an
3046 incremental load here. dbx_symfile_read should not generate any new
3047 minimal symbols, since we will have already read the ELF dynamic symbol
3048 table and normal symbol entries won't be in the ".stab" section; but in
3049 case it does, it will install them itself. */
3050 dbx_symfile_read (objfile, 0);
3051 }
3052 \f
3053 /* Scan and build partial symbols for a file with special sections for stabs
3054 and stabstrings. The file has already been processed to get its minimal
3055 symbols, and any other symbols that might be necessary to resolve GSYMs.
3056
3057 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
3058 rolled into one.
3059
3060 OBJFILE is the object file we are reading symbols from.
3061 ADDR is the address relative to which the symbols are (e.g. the base address
3062 of the text segment).
3063 STAB_NAME is the name of the section that contains the stabs.
3064 STABSTR_NAME is the name of the section that contains the stab strings.
3065
3066 This routine is mostly copied from dbx_symfile_init and
3067 dbx_symfile_read. */
3068
3069 void
3070 stabsect_build_psymtabs (struct objfile *objfile, char *stab_name,
3071 char *stabstr_name, char *text_name)
3072 {
3073 int val;
3074 bfd *sym_bfd = objfile->obfd;
3075 const char *name = bfd_get_filename (sym_bfd);
3076 asection *stabsect;
3077 asection *stabstrsect;
3078 asection *text_sect;
3079
3080 stabsect = bfd_get_section_by_name (sym_bfd, stab_name);
3081 stabstrsect = bfd_get_section_by_name (sym_bfd, stabstr_name);
3082
3083 if (!stabsect)
3084 return;
3085
3086 if (!stabstrsect)
3087 error (_("stabsect_build_psymtabs: Found stabs (%s), "
3088 "but not string section (%s)"),
3089 stab_name, stabstr_name);
3090
3091 dbx_objfile_data_key.emplace (objfile);
3092
3093 text_sect = bfd_get_section_by_name (sym_bfd, text_name);
3094 if (!text_sect)
3095 error (_("Can't find %s section in symbol file"), text_name);
3096 DBX_TEXT_ADDR (objfile) = bfd_section_vma (text_sect);
3097 DBX_TEXT_SIZE (objfile) = bfd_section_size (text_sect);
3098
3099 DBX_SYMBOL_SIZE (objfile) = sizeof (struct external_nlist);
3100 DBX_SYMCOUNT (objfile) = bfd_section_size (stabsect)
3101 / DBX_SYMBOL_SIZE (objfile);
3102 DBX_STRINGTAB_SIZE (objfile) = bfd_section_size (stabstrsect);
3103 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos; /* XXX - FIXME: POKING
3104 INSIDE BFD DATA
3105 STRUCTURES */
3106
3107 if (DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
3108 error (_("ridiculous string table size: %d bytes"),
3109 DBX_STRINGTAB_SIZE (objfile));
3110 DBX_STRINGTAB (objfile) = (char *)
3111 obstack_alloc (&objfile->objfile_obstack,
3112 DBX_STRINGTAB_SIZE (objfile) + 1);
3113 OBJSTAT (objfile, sz_strtab += DBX_STRINGTAB_SIZE (objfile) + 1);
3114
3115 /* Now read in the string table in one big gulp. */
3116
3117 val = bfd_get_section_contents (sym_bfd, /* bfd */
3118 stabstrsect, /* bfd section */
3119 DBX_STRINGTAB (objfile), /* input buffer */
3120 0, /* offset into section */
3121 DBX_STRINGTAB_SIZE (objfile)); /* amount to
3122 read */
3123
3124 if (!val)
3125 perror_with_name (name);
3126
3127 stabsread_new_init ();
3128 free_header_files ();
3129 init_header_files ();
3130
3131 /* Now, do an incremental load. */
3132
3133 processing_acc_compilation = 1;
3134 dbx_symfile_read (objfile, 0);
3135 }
3136 \f
3137 static const struct sym_fns aout_sym_fns =
3138 {
3139 dbx_new_init, /* init anything gbl to entire symtab */
3140 dbx_symfile_init, /* read initial info, setup for sym_read() */
3141 dbx_symfile_read, /* read a symbol file into symtab */
3142 dbx_symfile_finish, /* finished with file, cleanup */
3143 default_symfile_offsets, /* parse user's offsets to internal form */
3144 default_symfile_segments, /* Get segment information from a file. */
3145 NULL,
3146 default_symfile_relocate, /* Relocate a debug section. */
3147 NULL, /* sym_probe_fns */
3148 };
3149
3150 void _initialize_dbxread ();
3151 void
3152 _initialize_dbxread ()
3153 {
3154 add_symtab_fns (bfd_target_aout_flavour, &aout_sym_fns);
3155 }