Just testing checkins.
[deliverable/binutils-gdb.git] / gdb / dbxread.c
1 /* Read dbx symbol tables and convert to internal format, for GDB.
2 Copyright 1986, 1987, 1988, 1989, 1990, 1991 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 2 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, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
19
20 /* This module provides three functions: dbx_symfile_init,
21 which initializes to read a symbol file; dbx_new_init, which
22 discards existing cached information when all symbols are being
23 discarded; and dbx_symfile_read, which reads a symbol table
24 from a file.
25
26 dbx_symfile_read only does the minimum work necessary for letting the
27 user "name" things symbolically; it does not read the entire symtab.
28 Instead, it reads the external and static symbols and puts them in partial
29 symbol tables. When more extensive information is requested of a
30 file, the corresponding partial symbol table is mutated into a full
31 fledged symbol table by going back and reading the symbols
32 for real. dbx_psymtab_to_symtab() is the function that does this */
33
34 #include "defs.h"
35 #include <string.h>
36
37 #if defined(USG) || defined(__CYGNUSCLIB__)
38 #include <sys/types.h>
39 #include <fcntl.h>
40 #define L_SET 0
41 #define L_INCR 1
42 #endif
43
44 #include <obstack.h>
45 #include <sys/param.h>
46 #ifndef NO_SYS_FILE
47 #include <sys/file.h>
48 #endif
49 #include <sys/stat.h>
50 #include <ctype.h>
51 #include "symtab.h"
52 #include "breakpoint.h"
53 #include "command.h"
54 #include "target.h"
55 #include "gdbcore.h" /* for bfd stuff */
56 #include "libbfd.h" /* FIXME Secret internal BFD stuff (bfd_read) */
57 #include "libaout.h" /* FIXME Secret internal BFD stuff for a.out */
58 #include "symfile.h"
59 #include "objfiles.h"
60 #include "buildsym.h"
61 #include "stabsread.h"
62 #include "gdb-stabs.h"
63 #include "demangle.h"
64 #include "language.h" /* Needed inside partial-stab.h */
65 #include "complaints.h"
66
67 #include "aout/aout64.h"
68 #include "aout/stab_gnu.h" /* We always use GNU stabs, not native, now */
69
70 /* Each partial symbol table entry contains a pointer to private data for the
71 read_symtab() function to use when expanding a partial symbol table entry
72 to a full symbol table entry.
73
74 For dbxread this structure contains the offset within the file symbol table
75 of first local symbol for this file, and length (in bytes) of the section
76 of the symbol table devoted to this file's symbols (actually, the section
77 bracketed may contain more than just this file's symbols). It also contains
78 further information needed to locate the symbols if they are in an ELF file.
79
80 If ldsymlen is 0, the only reason for this thing's existence is the
81 dependency list. Nothing else will happen when it is read in. */
82
83 #define LDSYMOFF(p) (((struct symloc *)((p)->read_symtab_private))->ldsymoff)
84 #define LDSYMLEN(p) (((struct symloc *)((p)->read_symtab_private))->ldsymlen)
85 #define SYMLOC(p) ((struct symloc *)((p)->read_symtab_private))
86 #define SYMBOL_SIZE(p) (SYMLOC(p)->symbol_size)
87 #define SYMBOL_OFFSET(p) (SYMLOC(p)->symbol_offset)
88 #define STRING_OFFSET(p) (SYMLOC(p)->string_offset)
89 #define FILE_STRING_OFFSET(p) (SYMLOC(p)->file_string_offset)
90
91 struct symloc {
92 int ldsymoff;
93 int ldsymlen;
94 int symbol_size;
95 int symbol_offset;
96 int string_offset;
97 int file_string_offset;
98 };
99
100 /* Macro to determine which symbols to ignore when reading the first symbol
101 of a file. Some machines override this definition. */
102 #ifndef IGNORE_SYMBOL
103 /* This code is used on Ultrix systems. Ignore it */
104 #define IGNORE_SYMBOL(type) (type == (int)N_NSYMS)
105 #endif
106
107 /* Macro for name of symbol to indicate a file compiled with gcc. */
108 #ifndef GCC_COMPILED_FLAG_SYMBOL
109 #define GCC_COMPILED_FLAG_SYMBOL "gcc_compiled."
110 #endif
111
112 /* Macro for name of symbol to indicate a file compiled with gcc2. */
113 #ifndef GCC2_COMPILED_FLAG_SYMBOL
114 #define GCC2_COMPILED_FLAG_SYMBOL "gcc2_compiled."
115 #endif
116
117 /* Define this as 1 if a pcc declaration of a char or short argument
118 gives the correct address. Otherwise assume pcc gives the
119 address of the corresponding int, which is not the same on a
120 big-endian machine. */
121
122 #ifndef BELIEVE_PCC_PROMOTION
123 #define BELIEVE_PCC_PROMOTION 0
124 #endif
125
126 /* Remember what we deduced to be the source language of this psymtab. */
127
128 static enum language psymtab_language = language_unknown;
129
130 /* Nonzero means give verbose info on gdb action. From main.c. */
131 extern int info_verbose;
132
133 /* The BFD for this file -- implicit parameter to next_symbol_text. */
134
135 static bfd *symfile_bfd;
136
137 /* The size of each symbol in the symbol file (in external form).
138 This is set by dbx_symfile_read when building psymtabs, and by
139 dbx_psymtab_to_symtab when building symtabs. */
140
141 static unsigned symbol_size;
142
143 /* This is the offset of the symbol table in the executable file */
144 static unsigned symbol_table_offset;
145
146 /* This is the offset of the string table in the executable file */
147 static unsigned string_table_offset;
148
149 /* For elf+stab executables, the n_strx field is not a simple index
150 into the string table. Instead, each .o file has a base offset
151 in the string table, and the associated symbols contain offsets
152 from this base. The following two variables contain the base
153 offset for the current and next .o files. */
154 static unsigned int file_string_table_offset;
155 static unsigned int next_file_string_table_offset;
156
157 /* Complaints about the symbols we have encountered. */
158
159 struct complaint lbrac_complaint =
160 {"bad block start address patched", 0, 0};
161
162 struct complaint string_table_offset_complaint =
163 {"bad string table offset in symbol %d", 0, 0};
164
165 struct complaint unknown_symtype_complaint =
166 {"unknown symbol type %s", 0, 0};
167
168 struct complaint lbrac_rbrac_complaint =
169 {"block start larger than block end", 0, 0};
170
171 struct complaint lbrac_unmatched_complaint =
172 {"unmatched N_LBRAC before symtab pos %d", 0, 0};
173
174 struct complaint lbrac_mismatch_complaint =
175 {"N_LBRAC/N_RBRAC symbol mismatch at symtab pos %d", 0, 0};
176
177 struct complaint repeated_header_complaint =
178 {"\"repeated\" header file not previously seen, at symtab pos %d", 0, 0};
179
180 struct complaint repeated_header_name_complaint =
181 {"\"repeated\" header file not previously seen, named %s", 0, 0};
182 \f
183 /* During initial symbol readin, we need to have a structure to keep
184 track of which psymtabs have which bincls in them. This structure
185 is used during readin to setup the list of dependencies within each
186 partial symbol table. */
187
188 struct header_file_location
189 {
190 char *name; /* Name of header file */
191 int instance; /* See above */
192 struct partial_symtab *pst; /* Partial symtab that has the
193 BINCL/EINCL defs for this file */
194 };
195
196 /* The actual list and controling variables */
197 static struct header_file_location *bincl_list, *next_bincl;
198 static int bincls_allocated;
199
200 /* Local function prototypes */
201
202 static void
203 free_header_files PARAMS ((void));
204
205 static void
206 init_header_files PARAMS ((void));
207
208 static struct pending *
209 copy_pending PARAMS ((struct pending *, int, struct pending *));
210
211 static struct symtab *
212 read_ofile_symtab PARAMS ((struct objfile *, int, int, CORE_ADDR, int,
213 struct section_offsets *));
214
215 static void
216 dbx_psymtab_to_symtab PARAMS ((struct partial_symtab *));
217
218 static void
219 dbx_psymtab_to_symtab_1 PARAMS ((struct partial_symtab *));
220
221 static void
222 read_dbx_symtab PARAMS ((struct section_offsets *, struct objfile *,
223 CORE_ADDR, int));
224
225 static void
226 free_bincl_list PARAMS ((struct objfile *));
227
228 static struct partial_symtab *
229 find_corresponding_bincl_psymtab PARAMS ((char *, int));
230
231 static void
232 add_bincl_to_list PARAMS ((struct partial_symtab *, char *, int));
233
234 static void
235 init_bincl_list PARAMS ((int, struct objfile *));
236
237 static void
238 init_psymbol_list PARAMS ((struct objfile *));
239
240 static char *
241 dbx_next_symbol_text PARAMS ((void));
242
243 static void
244 fill_symbuf PARAMS ((bfd *));
245
246 static void
247 dbx_symfile_init PARAMS ((struct objfile *));
248
249 static void
250 dbx_new_init PARAMS ((struct objfile *));
251
252 static void
253 dbx_symfile_read PARAMS ((struct objfile *, struct section_offsets *, int));
254
255 static void
256 dbx_symfile_finish PARAMS ((struct objfile *));
257
258 static void
259 record_minimal_symbol PARAMS ((char *, CORE_ADDR, int, struct objfile *));
260
261 static void
262 add_new_header_file PARAMS ((char *, int));
263
264 static void
265 add_old_header_file PARAMS ((char *, int));
266
267 static void
268 add_this_object_header_file PARAMS ((int));
269
270 /* Free up old header file tables */
271
272 static void
273 free_header_files ()
274 {
275 register int i;
276
277 if (header_files != NULL)
278 {
279 for (i = 0; i < n_header_files; i++)
280 {
281 free (header_files[i].name);
282 }
283 free ((PTR)header_files);
284 header_files = NULL;
285 n_header_files = 0;
286 }
287 if (this_object_header_files)
288 {
289 free ((PTR)this_object_header_files);
290 this_object_header_files = NULL;
291 }
292 n_allocated_header_files = 0;
293 n_allocated_this_object_header_files = 0;
294 }
295
296 /* Allocate new header file tables */
297
298 static void
299 init_header_files ()
300 {
301 n_header_files = 0;
302 n_allocated_header_files = 10;
303 header_files = (struct header_file *)
304 xmalloc (10 * sizeof (struct header_file));
305
306 n_allocated_this_object_header_files = 10;
307 this_object_header_files = (int *) xmalloc (10 * sizeof (int));
308 }
309
310 /* Add header file number I for this object file
311 at the next successive FILENUM. */
312
313 static void
314 add_this_object_header_file (i)
315 int i;
316 {
317 if (n_this_object_header_files == n_allocated_this_object_header_files)
318 {
319 n_allocated_this_object_header_files *= 2;
320 this_object_header_files
321 = (int *) xrealloc ((char *) this_object_header_files,
322 n_allocated_this_object_header_files * sizeof (int));
323 }
324
325 this_object_header_files[n_this_object_header_files++] = i;
326 }
327
328 /* Add to this file an "old" header file, one already seen in
329 a previous object file. NAME is the header file's name.
330 INSTANCE is its instance code, to select among multiple
331 symbol tables for the same header file. */
332
333 static void
334 add_old_header_file (name, instance)
335 char *name;
336 int instance;
337 {
338 register struct header_file *p = header_files;
339 register int i;
340
341 for (i = 0; i < n_header_files; i++)
342 if (STREQ (p[i].name, name) && instance == p[i].instance)
343 {
344 add_this_object_header_file (i);
345 return;
346 }
347 complain (&repeated_header_complaint, symnum);
348 complain (&repeated_header_name_complaint, name);
349 }
350
351 /* Add to this file a "new" header file: definitions for its types follow.
352 NAME is the header file's name.
353 Most often this happens only once for each distinct header file,
354 but not necessarily. If it happens more than once, INSTANCE has
355 a different value each time, and references to the header file
356 use INSTANCE values to select among them.
357
358 dbx output contains "begin" and "end" markers for each new header file,
359 but at this level we just need to know which files there have been;
360 so we record the file when its "begin" is seen and ignore the "end". */
361
362 static void
363 add_new_header_file (name, instance)
364 char *name;
365 int instance;
366 {
367 register int i;
368
369 /* Make sure there is room for one more header file. */
370
371 if (n_header_files == n_allocated_header_files)
372 {
373 n_allocated_header_files *= 2;
374 header_files = (struct header_file *)
375 xrealloc ((char *) header_files,
376 (n_allocated_header_files * sizeof (struct header_file)));
377 }
378
379 /* Create an entry for this header file. */
380
381 i = n_header_files++;
382 header_files[i].name = savestring (name, strlen(name));
383 header_files[i].instance = instance;
384 header_files[i].length = 10;
385 header_files[i].vector
386 = (struct type **) xmalloc (10 * sizeof (struct type *));
387 memset (header_files[i].vector, 0, 10 * sizeof (struct type *));
388
389 add_this_object_header_file (i);
390 }
391
392 #if 0
393 static struct type **
394 explicit_lookup_type (real_filenum, index)
395 int real_filenum, index;
396 {
397 register struct header_file *f = &header_files[real_filenum];
398
399 if (index >= f->length)
400 {
401 f->length *= 2;
402 f->vector = (struct type **)
403 xrealloc (f->vector, f->length * sizeof (struct type *));
404 bzero (&f->vector[f->length / 2],
405 f->length * sizeof (struct type *) / 2);
406 }
407 return &f->vector[index];
408 }
409 #endif
410 \f
411 static void
412 record_minimal_symbol (name, address, type, objfile)
413 char *name;
414 CORE_ADDR address;
415 int type;
416 struct objfile *objfile;
417 {
418 enum minimal_symbol_type ms_type;
419
420 switch (type &~ N_EXT) {
421 case N_TEXT: ms_type = mst_text; break;
422 case N_DATA: ms_type = mst_data; break;
423 case N_BSS: ms_type = mst_bss; break;
424 case N_ABS: ms_type = mst_abs; break;
425 #ifdef N_SETV
426 case N_SETV: ms_type = mst_data; break;
427 #endif
428 default: ms_type = mst_unknown; break;
429 }
430
431 prim_record_minimal_symbol (obsavestring (name, strlen (name), &objfile -> symbol_obstack),
432 address, ms_type);
433 }
434 \f
435 /* Scan and build partial symbols for a symbol file.
436 We have been initialized by a call to dbx_symfile_init, which
437 put all the relevant info into a "struct dbx_symfile_info",
438 hung off the objfile structure.
439
440 SECTION_OFFSETS contains offsets relative to which the symbols in the
441 various sections are (depending where the sections were actually loaded).
442 MAINLINE is true if we are reading the main symbol
443 table (as opposed to a shared lib or dynamically loaded file). */
444
445 static void
446 dbx_symfile_read (objfile, section_offsets, mainline)
447 struct objfile *objfile;
448 struct section_offsets *section_offsets;
449 int mainline; /* FIXME comments above */
450 {
451 bfd *sym_bfd;
452 int val;
453
454 sym_bfd = objfile->obfd;
455 val = bfd_seek (objfile->obfd, DBX_SYMTAB_OFFSET (objfile), L_SET);
456 if (val < 0)
457 perror_with_name (objfile->name);
458
459 /* If we are reinitializing, or if we have never loaded syms yet, init */
460 if (mainline || objfile->global_psymbols.size == 0 || objfile->static_psymbols.size == 0)
461 init_psymbol_list (objfile);
462
463 symbol_size = DBX_SYMBOL_SIZE (objfile);
464 symbol_table_offset = DBX_SYMTAB_OFFSET (objfile);
465
466 pending_blocks = 0;
467 make_cleanup (really_free_pendings, 0);
468
469 init_minimal_symbol_collection ();
470 make_cleanup (discard_minimal_symbols, 0);
471
472 /* Now that the symbol table data of the executable file are all in core,
473 process them and define symbols accordingly. */
474
475 read_dbx_symtab (section_offsets, objfile,
476 bfd_section_vma (sym_bfd, DBX_TEXT_SECT (objfile)),
477 bfd_section_size (sym_bfd, DBX_TEXT_SECT (objfile)));
478
479 /* Install any minimal symbols that have been collected as the current
480 minimal symbols for this objfile. */
481
482 install_minimal_symbols (objfile);
483
484 if (!have_partial_symbols ()) {
485 wrap_here ("");
486 printf_filtered ("(no debugging symbols found)...");
487 wrap_here ("");
488 }
489 }
490
491 /* Initialize anything that needs initializing when a completely new
492 symbol file is specified (not just adding some symbols from another
493 file, e.g. a shared library). */
494
495 static void
496 dbx_new_init (ignore)
497 struct objfile *ignore;
498 {
499 stabsread_new_init ();
500 buildsym_new_init ();
501 init_header_files ();
502 }
503
504
505 /* dbx_symfile_init ()
506 is the dbx-specific initialization routine for reading symbols.
507 It is passed a struct objfile which contains, among other things,
508 the BFD for the file whose symbols are being read, and a slot for a pointer
509 to "private data" which we fill with goodies.
510
511 We read the string table into malloc'd space and stash a pointer to it.
512
513 Since BFD doesn't know how to read debug symbols in a format-independent
514 way (and may never do so...), we have to do it ourselves. We will never
515 be called unless this is an a.out (or very similar) file.
516 FIXME, there should be a cleaner peephole into the BFD environment here. */
517
518 #define DBX_STRINGTAB_SIZE_SIZE sizeof(long) /* FIXME */
519
520 static void
521 dbx_symfile_init (objfile)
522 struct objfile *objfile;
523 {
524 int val;
525 bfd *sym_bfd = objfile->obfd;
526 char *name = bfd_get_filename (sym_bfd);
527 unsigned char size_temp[DBX_STRINGTAB_SIZE_SIZE];
528
529 /* Allocate struct to keep track of the symfile */
530 objfile->sym_private = (PTR)
531 xmmalloc (objfile -> md, sizeof (struct dbx_symfile_info));
532
533 /* FIXME POKING INSIDE BFD DATA STRUCTURES */
534 #define STRING_TABLE_OFFSET (sym_bfd->origin + obj_str_filepos (sym_bfd))
535 #define SYMBOL_TABLE_OFFSET (sym_bfd->origin + obj_sym_filepos (sym_bfd))
536
537 /* FIXME POKING INSIDE BFD DATA STRUCTURES */
538
539 DBX_SYMFILE_INFO (objfile)->stab_section_info = NULL;
540 DBX_TEXT_SECT (objfile) = bfd_get_section_by_name (sym_bfd, ".text");
541 if (!DBX_TEXT_SECT (objfile))
542 error ("Can't find .text section in symbol file");
543
544 DBX_SYMBOL_SIZE (objfile) = obj_symbol_entry_size (sym_bfd);
545 DBX_SYMCOUNT (objfile) = bfd_get_symcount (sym_bfd);
546 DBX_SYMTAB_OFFSET (objfile) = SYMBOL_TABLE_OFFSET;
547
548 /* Read the string table and stash it away in the psymbol_obstack. It is
549 only needed as long as we need to expand psymbols into full symbols,
550 so when we blow away the psymbol the string table goes away as well.
551 Note that gdb used to use the results of attempting to malloc the
552 string table, based on the size it read, as a form of sanity check
553 for botched byte swapping, on the theory that a byte swapped string
554 table size would be so totally bogus that the malloc would fail. Now
555 that we put in on the psymbol_obstack, we can't do this since gdb gets
556 a fatal error (out of virtual memory) if the size is bogus. We can
557 however at least check to see if the size is less than the size of
558 the size field itself, or larger than the size of the entire file.
559 Note that all valid string tables have a size greater than zero, since
560 the bytes used to hold the size are included in the count. */
561
562 if (STRING_TABLE_OFFSET == 0)
563 {
564 DBX_STRINGTAB_SIZE (objfile) = 0;
565 DBX_STRINGTAB (objfile) = NULL;
566 }
567 else
568 {
569 val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, L_SET);
570 if (val < 0)
571 perror_with_name (name);
572
573 memset ((PTR) size_temp, 0, sizeof (size_temp));
574 val = bfd_read ((PTR) size_temp, sizeof (size_temp), 1, sym_bfd);
575 if (val < 0)
576 perror_with_name (name);
577
578 DBX_STRINGTAB_SIZE (objfile) = bfd_h_get_32 (sym_bfd, size_temp);
579
580 if (DBX_STRINGTAB_SIZE (objfile) < sizeof (size_temp)
581 || DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
582 error ("ridiculous string table size (%d bytes).",
583 DBX_STRINGTAB_SIZE (objfile));
584
585 DBX_STRINGTAB (objfile) =
586 (char *) obstack_alloc (&objfile -> psymbol_obstack,
587 DBX_STRINGTAB_SIZE (objfile));
588
589 /* Now read in the string table in one big gulp. */
590
591 val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, L_SET);
592 if (val < 0)
593 perror_with_name (name);
594 val = bfd_read (DBX_STRINGTAB (objfile), DBX_STRINGTAB_SIZE (objfile), 1,
595 sym_bfd);
596 if (val != DBX_STRINGTAB_SIZE (objfile))
597 perror_with_name (name);
598 }
599 }
600
601 /* Perform any local cleanups required when we are done with a particular
602 objfile. I.E, we are in the process of discarding all symbol information
603 for an objfile, freeing up all memory held for it, and unlinking the
604 objfile struct from the global list of known objfiles. */
605
606 static void
607 dbx_symfile_finish (objfile)
608 struct objfile *objfile;
609 {
610 if (objfile->sym_private != NULL)
611 {
612 mfree (objfile -> md, objfile->sym_private);
613 }
614 free_header_files ();
615 }
616
617 \f
618 /* Buffer for reading the symbol table entries. */
619 static struct internal_nlist symbuf[4096];
620 static int symbuf_idx;
621 static int symbuf_end;
622
623 /* Name of last function encountered. Used in Solaris to approximate
624 object file boundaries. */
625 static char *last_function_name;
626
627 /* The address in memory of the string table of the object file we are
628 reading (which might not be the "main" object file, but might be a
629 shared library or some other dynamically loaded thing). This is set
630 by read_dbx_symtab when building psymtabs, and by read_ofile_symtab
631 when building symtabs, and is used only by next_symbol_text. */
632 static char *stringtab_global;
633
634 /* Refill the symbol table input buffer
635 and set the variables that control fetching entries from it.
636 Reports an error if no data available.
637 This function can read past the end of the symbol table
638 (into the string table) but this does no harm. */
639
640 static void
641 fill_symbuf (sym_bfd)
642 bfd *sym_bfd;
643 {
644 int nbytes = bfd_read ((PTR)symbuf, sizeof (symbuf), 1, sym_bfd);
645 if (nbytes < 0)
646 perror_with_name (bfd_get_filename (sym_bfd));
647 else if (nbytes == 0)
648 error ("Premature end of file reading symbol table");
649 symbuf_end = nbytes / symbol_size;
650 symbuf_idx = 0;
651 }
652
653 #define SWAP_SYMBOL(symp, abfd) \
654 { \
655 (symp)->n_strx = bfd_h_get_32(abfd, \
656 (unsigned char *)&(symp)->n_strx); \
657 (symp)->n_desc = bfd_h_get_16 (abfd, \
658 (unsigned char *)&(symp)->n_desc); \
659 (symp)->n_value = bfd_h_get_32 (abfd, \
660 (unsigned char *)&(symp)->n_value); \
661 }
662
663 /* Invariant: The symbol pointed to by symbuf_idx is the first one
664 that hasn't been swapped. Swap the symbol at the same time
665 that symbuf_idx is incremented. */
666
667 /* dbx allows the text of a symbol name to be continued into the
668 next symbol name! When such a continuation is encountered
669 (a \ at the end of the text of a name)
670 call this function to get the continuation. */
671
672 static char *
673 dbx_next_symbol_text ()
674 {
675 if (symbuf_idx == symbuf_end)
676 fill_symbuf (symfile_bfd);
677 symnum++;
678 SWAP_SYMBOL(&symbuf[symbuf_idx], symfile_bfd);
679 return symbuf[symbuf_idx++].n_strx + stringtab_global
680 + file_string_table_offset;
681 }
682 \f
683 /* Initializes storage for all of the partial symbols that will be
684 created by read_dbx_symtab and subsidiaries. */
685
686 static void
687 init_psymbol_list (objfile)
688 struct objfile *objfile;
689 {
690 /* Free any previously allocated psymbol lists. */
691 if (objfile -> global_psymbols.list)
692 mfree (objfile -> md, (PTR)objfile -> global_psymbols.list);
693 if (objfile -> static_psymbols.list)
694 mfree (objfile -> md, (PTR)objfile -> static_psymbols.list);
695
696 /* Current best guess is that there are approximately a twentieth
697 of the total symbols (in a debugging file) are global or static
698 oriented symbols */
699 objfile -> global_psymbols.size = DBX_SYMCOUNT (objfile) / 10;
700 objfile -> static_psymbols.size = DBX_SYMCOUNT (objfile) / 10;
701 objfile -> global_psymbols.next = objfile -> global_psymbols.list = (struct partial_symbol *)
702 xmmalloc (objfile -> md, objfile -> global_psymbols.size * sizeof (struct partial_symbol));
703 objfile -> static_psymbols.next = objfile -> static_psymbols.list = (struct partial_symbol *)
704 xmmalloc (objfile -> md, objfile -> static_psymbols.size * sizeof (struct partial_symbol));
705 }
706
707 /* Initialize the list of bincls to contain none and have some
708 allocated. */
709
710 static void
711 init_bincl_list (number, objfile)
712 int number;
713 struct objfile *objfile;
714 {
715 bincls_allocated = number;
716 next_bincl = bincl_list = (struct header_file_location *)
717 xmmalloc (objfile -> md, bincls_allocated * sizeof(struct header_file_location));
718 }
719
720 /* Add a bincl to the list. */
721
722 static void
723 add_bincl_to_list (pst, name, instance)
724 struct partial_symtab *pst;
725 char *name;
726 int instance;
727 {
728 if (next_bincl >= bincl_list + bincls_allocated)
729 {
730 int offset = next_bincl - bincl_list;
731 bincls_allocated *= 2;
732 bincl_list = (struct header_file_location *)
733 xmrealloc (pst->objfile->md, (char *)bincl_list,
734 bincls_allocated * sizeof (struct header_file_location));
735 next_bincl = bincl_list + offset;
736 }
737 next_bincl->pst = pst;
738 next_bincl->instance = instance;
739 next_bincl++->name = name;
740 }
741
742 /* Given a name, value pair, find the corresponding
743 bincl in the list. Return the partial symtab associated
744 with that header_file_location. */
745
746 static struct partial_symtab *
747 find_corresponding_bincl_psymtab (name, instance)
748 char *name;
749 int instance;
750 {
751 struct header_file_location *bincl;
752
753 for (bincl = bincl_list; bincl < next_bincl; bincl++)
754 if (bincl->instance == instance
755 && STREQ (name, bincl->name))
756 return bincl->pst;
757
758 return (struct partial_symtab *) 0;
759 }
760
761 /* Free the storage allocated for the bincl list. */
762
763 static void
764 free_bincl_list (objfile)
765 struct objfile *objfile;
766 {
767 mfree (objfile -> md, (PTR)bincl_list);
768 bincls_allocated = 0;
769 }
770
771 /* Given pointers to an a.out symbol table in core containing dbx
772 style data, setup partial_symtab's describing each source file for
773 which debugging information is available.
774 SYMFILE_NAME is the name of the file we are reading from
775 and SECTION_OFFSETS is the set of offsets for the various sections
776 of the file (a set of zeros if the mainline program). */
777
778 static void
779 read_dbx_symtab (section_offsets, objfile, text_addr, text_size)
780 struct section_offsets *section_offsets;
781 struct objfile *objfile;
782 CORE_ADDR text_addr;
783 int text_size;
784 {
785 register struct internal_nlist *bufp = 0; /* =0 avoids gcc -Wall glitch */
786 register char *namestring;
787 int nsl;
788 int past_first_source_file = 0;
789 CORE_ADDR last_o_file_start = 0;
790 struct cleanup *old_chain;
791 bfd *abfd;
792
793 /* End of the text segment of the executable file. */
794 CORE_ADDR end_of_text_addr;
795
796 /* Current partial symtab */
797 struct partial_symtab *pst;
798
799 /* List of current psymtab's include files */
800 char **psymtab_include_list;
801 int includes_allocated;
802 int includes_used;
803
804 /* Index within current psymtab dependency list */
805 struct partial_symtab **dependency_list;
806 int dependencies_used, dependencies_allocated;
807
808 /* FIXME. We probably want to change stringtab_global rather than add this
809 while processing every symbol entry. FIXME. */
810 file_string_table_offset = 0;
811 next_file_string_table_offset = 0;
812
813 stringtab_global = DBX_STRINGTAB (objfile);
814
815 pst = (struct partial_symtab *) 0;
816
817 includes_allocated = 30;
818 includes_used = 0;
819 psymtab_include_list = (char **) alloca (includes_allocated *
820 sizeof (char *));
821
822 dependencies_allocated = 30;
823 dependencies_used = 0;
824 dependency_list =
825 (struct partial_symtab **) alloca (dependencies_allocated *
826 sizeof (struct partial_symtab *));
827
828 old_chain = make_cleanup (free_objfile, objfile);
829
830 /* Init bincl list */
831 init_bincl_list (20, objfile);
832 make_cleanup (free_bincl_list, objfile);
833
834 last_source_file = NULL;
835
836 #ifdef END_OF_TEXT_DEFAULT
837 end_of_text_addr = END_OF_TEXT_DEFAULT;
838 #else
839 end_of_text_addr = text_addr + section_offsets->offsets[SECT_OFF_TEXT]
840 + text_size; /* Relocate */
841 #endif
842
843 symfile_bfd = objfile->obfd; /* For next_text_symbol */
844 abfd = objfile->obfd;
845 symbuf_end = symbuf_idx = 0;
846 next_symbol_text_func = dbx_next_symbol_text;
847
848 for (symnum = 0; symnum < DBX_SYMCOUNT (objfile); symnum++)
849 {
850 /* Get the symbol for this run and pull out some info */
851 QUIT; /* allow this to be interruptable */
852 if (symbuf_idx == symbuf_end)
853 fill_symbuf (abfd);
854 bufp = &symbuf[symbuf_idx++];
855
856 /*
857 * Special case to speed up readin.
858 */
859 if (bufp->n_type == (unsigned char)N_SLINE) continue;
860
861 SWAP_SYMBOL (bufp, abfd);
862
863 /* Ok. There is a lot of code duplicated in the rest of this
864 switch statement (for efficiency reasons). Since I don't
865 like duplicating code, I will do my penance here, and
866 describe the code which is duplicated:
867
868 *) The assignment to namestring.
869 *) The call to strchr.
870 *) The addition of a partial symbol the the two partial
871 symbol lists. This last is a large section of code, so
872 I've imbedded it in the following macro.
873 */
874
875 /* Set namestring based on bufp. If the string table index is invalid,
876 give a fake name, and print a single error message per symbol file read,
877 rather than abort the symbol reading or flood the user with messages. */
878
879 /*FIXME: Too many adds and indirections in here for the inner loop. */
880 #define SET_NAMESTRING()\
881 if (((unsigned)bufp->n_strx + file_string_table_offset) >= \
882 DBX_STRINGTAB_SIZE (objfile)) { \
883 complain (&string_table_offset_complaint, symnum); \
884 namestring = "foo"; \
885 } else \
886 namestring = bufp->n_strx + file_string_table_offset + \
887 DBX_STRINGTAB (objfile)
888
889 #define CUR_SYMBOL_TYPE bufp->n_type
890 #define CUR_SYMBOL_VALUE bufp->n_value
891 #define DBXREAD_ONLY
892 #define START_PSYMTAB(ofile,secoff,fname,low,symoff,global_syms,static_syms)\
893 start_psymtab(ofile, secoff, fname, low, symoff, global_syms, static_syms)
894 #define END_PSYMTAB(pst,ilist,ninc,c_off,c_text,dep_list,n_deps)\
895 end_psymtab(pst,ilist,ninc,c_off,c_text,dep_list,n_deps)
896
897 #include "partial-stab.h"
898 }
899
900 /* If there's stuff to be cleaned up, clean it up. */
901 if (DBX_SYMCOUNT (objfile) > 0 /* We have some syms */
902 /*FIXME, does this have a bug at start address 0? */
903 && last_o_file_start
904 && objfile -> ei.entry_point < bufp->n_value
905 && objfile -> ei.entry_point >= last_o_file_start)
906 {
907 objfile -> ei.entry_file_lowpc = last_o_file_start;
908 objfile -> ei.entry_file_highpc = bufp->n_value;
909 }
910
911 if (pst)
912 {
913 end_psymtab (pst, psymtab_include_list, includes_used,
914 symnum * symbol_size, end_of_text_addr,
915 dependency_list, dependencies_used);
916 }
917
918 free_bincl_list (objfile);
919 discard_cleanups (old_chain);
920 }
921
922 /* Allocate and partially fill a partial symtab. It will be
923 completely filled at the end of the symbol list.
924
925 SYMFILE_NAME is the name of the symbol-file we are reading from, and ADDR
926 is the address relative to which its symbols are (incremental) or 0
927 (normal). */
928
929
930 struct partial_symtab *
931 start_psymtab (objfile, section_offsets,
932 filename, textlow, ldsymoff, global_syms, static_syms)
933 struct objfile *objfile;
934 struct section_offsets *section_offsets;
935 char *filename;
936 CORE_ADDR textlow;
937 int ldsymoff;
938 struct partial_symbol *global_syms;
939 struct partial_symbol *static_syms;
940 {
941 struct partial_symtab *result =
942 start_psymtab_common(objfile, section_offsets,
943 filename, textlow, global_syms, static_syms);
944
945 result->read_symtab_private = (char *)
946 obstack_alloc (&objfile -> psymbol_obstack, sizeof (struct symloc));
947 LDSYMOFF(result) = ldsymoff;
948 result->read_symtab = dbx_psymtab_to_symtab;
949 SYMBOL_SIZE(result) = symbol_size;
950 SYMBOL_OFFSET(result) = symbol_table_offset;
951 STRING_OFFSET(result) = string_table_offset;
952 FILE_STRING_OFFSET(result) = file_string_table_offset;
953
954 /* If we're handling an ELF file, drag some section-relocation info
955 for this source file out of the ELF symbol table, to compensate for
956 Sun brain death. This replaces the section_offsets in this psymtab,
957 if successful. */
958 elfstab_offset_sections (objfile, result);
959
960 /* Deduce the source language from the filename for this psymtab. */
961 psymtab_language = deduce_language_from_filename (filename);
962
963 return result;
964 }
965
966 /* Close off the current usage of a partial_symbol table entry. This
967 involves setting the correct number of includes (with a realloc),
968 setting the high text mark, setting the symbol length in the
969 executable, and setting the length of the global and static lists
970 of psymbols.
971
972 The global symbols and static symbols are then seperately sorted.
973
974 Then the partial symtab is put on the global list.
975 *** List variables and peculiarities of same. ***
976 */
977
978 void
979 end_psymtab (pst, include_list, num_includes, capping_symbol_offset,
980 capping_text, dependency_list, number_dependencies)
981 struct partial_symtab *pst;
982 char **include_list;
983 int num_includes;
984 int capping_symbol_offset;
985 CORE_ADDR capping_text;
986 struct partial_symtab **dependency_list;
987 int number_dependencies;
988 /* struct partial_symbol *capping_global, *capping_static;*/
989 {
990 int i;
991 struct partial_symtab *p1;
992 struct objfile *objfile = pst -> objfile;
993
994 if (capping_symbol_offset != -1)
995 LDSYMLEN(pst) = capping_symbol_offset - LDSYMOFF(pst);
996 pst->texthigh = capping_text;
997
998 /* Under Solaris, the N_SO symbols always have a value of 0,
999 instead of the usual address of the .o file. Therefore,
1000 we have to do some tricks to fill in texthigh and textlow.
1001 The first trick is in partial-stab.h: if we see a static
1002 or global function, and the textlow for the current pst
1003 is still 0, then we use that function's address for
1004 the textlow of the pst.
1005
1006 Now, to fill in texthigh, we remember the last function seen
1007 in the .o file (also in partial-stab.h). Also, there's a hack in
1008 bfd/elf.c and gdb/elfread.c to pass the ELF st_size field
1009 to here via the misc_info field. Therefore, we can fill in
1010 a reliable texthigh by taking the address plus size of the
1011 last function in the file.
1012
1013 Unfortunately, that does not cover the case where the last function
1014 in the file is static. See the paragraph below for more comments
1015 on this situation.
1016
1017 Finally, if we have a valid textlow for the current file, we run
1018 down the partial_symtab_list filling in previous texthighs that
1019 are still unknown. */
1020
1021 if (pst->texthigh == 0 && last_function_name) {
1022 char *p;
1023 int n;
1024 struct minimal_symbol *minsym;
1025
1026 p = strchr (last_function_name, ':');
1027 if (p == NULL)
1028 p = last_function_name;
1029 n = p - last_function_name;
1030 p = alloca (n + 1);
1031 strncpy (p, last_function_name, n);
1032 p[n] = 0;
1033
1034 minsym = lookup_minimal_symbol (p, objfile);
1035
1036 if (minsym) {
1037 pst->texthigh = SYMBOL_VALUE_ADDRESS (minsym) +
1038 (int) MSYMBOL_INFO (minsym);
1039 } else {
1040 /* This file ends with a static function, and it's
1041 difficult to imagine how hard it would be to track down
1042 the elf symbol. Luckily, most of the time no one will notice,
1043 since the next file will likely be compiled with -g, so
1044 the code below will copy the first fuction's start address
1045 back to our texthigh variable. (Also, if this file is the
1046 last one in a dynamically linked program, texthigh already
1047 has the right value.) If the next file isn't compiled
1048 with -g, then the last function in this file winds up owning
1049 all of the text space up to the next -g file, or the end (minus
1050 shared libraries). This only matters for single stepping,
1051 and even then it will still work, except that it will single
1052 step through all of the covered functions, instead of setting
1053 breakpoints around them as it usualy does. This makes it
1054 pretty slow, but at least it doesn't fail.
1055
1056 We can fix this with a fairly big change to bfd, but we need
1057 to coordinate better with Cygnus if we want to do that. FIXME. */
1058 }
1059 last_function_name = NULL;
1060 }
1061
1062 /* this test will be true if the last .o file is only data */
1063 if (pst->textlow == 0)
1064 pst->textlow = pst->texthigh;
1065
1066 /* If we know our own starting text address, then walk through all other
1067 psymtabs for this objfile, and if any didn't know their ending text
1068 address, set it to our starting address. Take care to not set our
1069 own ending address to our starting address, nor to set addresses on
1070 `dependency' files that have both textlow and texthigh zero. */
1071 if (pst->textlow) {
1072 ALL_OBJFILE_PSYMTABS (objfile, p1) {
1073 if (p1->texthigh == 0 && p1->textlow != 0 && p1 != pst) {
1074 p1->texthigh = pst->textlow;
1075 /* if this file has only data, then make textlow match texthigh */
1076 if (p1->textlow == 0)
1077 p1->textlow = p1->texthigh;
1078 }
1079 }
1080 }
1081
1082 /* End of kludge for patching Solaris textlow and texthigh. */
1083
1084
1085 pst->n_global_syms =
1086 objfile->global_psymbols.next - (objfile->global_psymbols.list + pst->globals_offset);
1087 pst->n_static_syms =
1088 objfile->static_psymbols.next - (objfile->static_psymbols.list + pst->statics_offset);
1089
1090 pst->number_of_dependencies = number_dependencies;
1091 if (number_dependencies)
1092 {
1093 pst->dependencies = (struct partial_symtab **)
1094 obstack_alloc (&objfile->psymbol_obstack,
1095 number_dependencies * sizeof (struct partial_symtab *));
1096 memcpy (pst->dependencies, dependency_list,
1097 number_dependencies * sizeof (struct partial_symtab *));
1098 }
1099 else
1100 pst->dependencies = 0;
1101
1102 for (i = 0; i < num_includes; i++)
1103 {
1104 struct partial_symtab *subpst =
1105 allocate_psymtab (include_list[i], objfile);
1106
1107 subpst->section_offsets = pst->section_offsets;
1108 subpst->read_symtab_private =
1109 (char *) obstack_alloc (&objfile->psymbol_obstack,
1110 sizeof (struct symloc));
1111 LDSYMOFF(subpst) =
1112 LDSYMLEN(subpst) =
1113 subpst->textlow =
1114 subpst->texthigh = 0;
1115
1116 /* We could save slight bits of space by only making one of these,
1117 shared by the entire set of include files. FIXME-someday. */
1118 subpst->dependencies = (struct partial_symtab **)
1119 obstack_alloc (&objfile->psymbol_obstack,
1120 sizeof (struct partial_symtab *));
1121 subpst->dependencies[0] = pst;
1122 subpst->number_of_dependencies = 1;
1123
1124 subpst->globals_offset =
1125 subpst->n_global_syms =
1126 subpst->statics_offset =
1127 subpst->n_static_syms = 0;
1128
1129 subpst->readin = 0;
1130 subpst->symtab = 0;
1131 subpst->read_symtab = dbx_psymtab_to_symtab;
1132 }
1133
1134 sort_pst_symbols (pst);
1135
1136 /* If there is already a psymtab or symtab for a file of this name, remove it.
1137 (If there is a symtab, more drastic things also happen.)
1138 This happens in VxWorks. */
1139 free_named_symtabs (pst->filename);
1140
1141 if (num_includes == 0
1142 && number_dependencies == 0
1143 && pst->n_global_syms == 0
1144 && pst->n_static_syms == 0) {
1145 /* Throw away this psymtab, it's empty. We can't deallocate it, since
1146 it is on the obstack, but we can forget to chain it on the list. */
1147 struct partial_symtab *prev_pst;
1148
1149 /* First, snip it out of the psymtab chain */
1150
1151 if (pst->objfile->psymtabs == pst)
1152 pst->objfile->psymtabs = pst->next;
1153 else
1154 for (prev_pst = pst->objfile->psymtabs; prev_pst; prev_pst = pst->next)
1155 if (prev_pst->next == pst)
1156 prev_pst->next = pst->next;
1157
1158 /* Next, put it on a free list for recycling */
1159
1160 pst->next = pst->objfile->free_psymtabs;
1161 pst->objfile->free_psymtabs = pst;
1162 }
1163 }
1164 \f
1165 static void
1166 dbx_psymtab_to_symtab_1 (pst)
1167 struct partial_symtab *pst;
1168 {
1169 struct cleanup *old_chain;
1170 int i;
1171
1172 if (!pst)
1173 return;
1174
1175 if (pst->readin)
1176 {
1177 fprintf (stderr, "Psymtab for %s already read in. Shouldn't happen.\n",
1178 pst->filename);
1179 return;
1180 }
1181
1182 /* Read in all partial symtabs on which this one is dependent */
1183 for (i = 0; i < pst->number_of_dependencies; i++)
1184 if (!pst->dependencies[i]->readin)
1185 {
1186 /* Inform about additional files that need to be read in. */
1187 if (info_verbose)
1188 {
1189 fputs_filtered (" ", stdout);
1190 wrap_here ("");
1191 fputs_filtered ("and ", stdout);
1192 wrap_here ("");
1193 printf_filtered ("%s...", pst->dependencies[i]->filename);
1194 wrap_here (""); /* Flush output */
1195 fflush (stdout);
1196 }
1197 dbx_psymtab_to_symtab_1 (pst->dependencies[i]);
1198 }
1199
1200 if (LDSYMLEN(pst)) /* Otherwise it's a dummy */
1201 {
1202 /* Init stuff necessary for reading in symbols */
1203 stabsread_init ();
1204 buildsym_init ();
1205 old_chain = make_cleanup (really_free_pendings, 0);
1206 file_string_table_offset = FILE_STRING_OFFSET (pst);
1207 symbol_size = SYMBOL_SIZE (pst);
1208
1209 /* Read in this file's symbols */
1210 bfd_seek (pst->objfile->obfd, SYMBOL_OFFSET (pst), L_SET);
1211 pst->symtab =
1212 read_ofile_symtab (pst->objfile, LDSYMOFF(pst), LDSYMLEN(pst),
1213 pst->textlow, pst->texthigh - pst->textlow,
1214 pst->section_offsets);
1215 sort_symtab_syms (pst->symtab);
1216
1217 do_cleanups (old_chain);
1218 }
1219
1220 pst->readin = 1;
1221 }
1222
1223 /* Read in all of the symbols for a given psymtab for real.
1224 Be verbose about it if the user wants that. */
1225
1226 static void
1227 dbx_psymtab_to_symtab (pst)
1228 struct partial_symtab *pst;
1229 {
1230 bfd *sym_bfd;
1231
1232 if (!pst)
1233 return;
1234
1235 if (pst->readin)
1236 {
1237 fprintf (stderr, "Psymtab for %s already read in. Shouldn't happen.\n",
1238 pst->filename);
1239 return;
1240 }
1241
1242 if (LDSYMLEN(pst) || pst->number_of_dependencies)
1243 {
1244 /* Print the message now, before reading the string table,
1245 to avoid disconcerting pauses. */
1246 if (info_verbose)
1247 {
1248 printf_filtered ("Reading in symbols for %s...", pst->filename);
1249 fflush (stdout);
1250 }
1251
1252 sym_bfd = pst->objfile->obfd;
1253
1254 next_symbol_text_func = dbx_next_symbol_text;
1255
1256 dbx_psymtab_to_symtab_1 (pst);
1257
1258 /* Match with global symbols. This only needs to be done once,
1259 after all of the symtabs and dependencies have been read in. */
1260 scan_file_globals (pst->objfile);
1261
1262 /* Finish up the debug error message. */
1263 if (info_verbose)
1264 printf_filtered ("done.\n");
1265 }
1266 }
1267
1268 /* Read in a defined section of a specific object file's symbols.
1269
1270 DESC is the file descriptor for the file, positioned at the
1271 beginning of the symtab
1272 SYM_OFFSET is the offset within the file of
1273 the beginning of the symbols we want to read
1274 SYM_SIZE is the size of the symbol info to read in.
1275 TEXT_OFFSET is the beginning of the text segment we are reading symbols for
1276 TEXT_SIZE is the size of the text segment read in.
1277 SECTION_OFFSETS are the relocation offsets which get added to each symbol. */
1278
1279 static struct symtab *
1280 read_ofile_symtab (objfile, sym_offset, sym_size, text_offset, text_size,
1281 section_offsets)
1282 struct objfile *objfile;
1283 int sym_offset;
1284 int sym_size;
1285 CORE_ADDR text_offset;
1286 int text_size;
1287 struct section_offsets *section_offsets;
1288 {
1289 register char *namestring;
1290 register struct internal_nlist *bufp;
1291 unsigned char type;
1292 unsigned max_symnum;
1293 register bfd *abfd;
1294 struct symtab *rtn;
1295
1296 current_objfile = objfile;
1297 subfile_stack = NULL;
1298
1299 stringtab_global = DBX_STRINGTAB (objfile);
1300 last_source_file = NULL;
1301
1302 abfd = objfile->obfd;
1303 symfile_bfd = objfile->obfd; /* Implicit param to next_text_symbol */
1304 symbuf_end = symbuf_idx = 0;
1305
1306 /* It is necessary to actually read one symbol *before* the start
1307 of this symtab's symbols, because the GCC_COMPILED_FLAG_SYMBOL
1308 occurs before the N_SO symbol.
1309
1310 Detecting this in read_dbx_symtab
1311 would slow down initial readin, so we look for it here instead. */
1312 if (!processing_acc_compilation && sym_offset >= (int)symbol_size)
1313 {
1314 bfd_seek (symfile_bfd, sym_offset - symbol_size, L_INCR);
1315 fill_symbuf (abfd);
1316 bufp = &symbuf[symbuf_idx++];
1317 SWAP_SYMBOL (bufp, abfd);
1318
1319 SET_NAMESTRING ();
1320
1321 processing_gcc_compilation = 0;
1322 if (bufp->n_type == N_TEXT)
1323 {
1324 if (STREQ (namestring, GCC_COMPILED_FLAG_SYMBOL))
1325 processing_gcc_compilation = 1;
1326 else if (STREQ (namestring, GCC2_COMPILED_FLAG_SYMBOL))
1327 processing_gcc_compilation = 2;
1328 }
1329
1330 /* Try to select a C++ demangling based on the compilation unit
1331 producer. */
1332
1333 if (processing_gcc_compilation)
1334 {
1335 #if 1 /* Works, but is experimental. -fnf */
1336 if (AUTO_DEMANGLING)
1337 {
1338 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
1339 }
1340 #endif
1341 }
1342 }
1343 else
1344 {
1345 /* The N_SO starting this symtab is the first symbol, so we
1346 better not check the symbol before it. I'm not this can
1347 happen, but it doesn't hurt to check for it. */
1348 bfd_seek (symfile_bfd, sym_offset, L_INCR);
1349 processing_gcc_compilation = 0;
1350 }
1351
1352 if (symbuf_idx == symbuf_end)
1353 fill_symbuf (abfd);
1354 bufp = &symbuf[symbuf_idx];
1355 if (bufp->n_type != (unsigned char)N_SO)
1356 error("First symbol in segment of executable not a source symbol");
1357
1358 max_symnum = sym_size / symbol_size;
1359
1360 for (symnum = 0;
1361 symnum < max_symnum;
1362 symnum++)
1363 {
1364 QUIT; /* Allow this to be interruptable */
1365 if (symbuf_idx == symbuf_end)
1366 fill_symbuf(abfd);
1367 bufp = &symbuf[symbuf_idx++];
1368 SWAP_SYMBOL (bufp, abfd);
1369
1370 type = bufp->n_type;
1371
1372 SET_NAMESTRING ();
1373
1374 if (type & N_STAB) {
1375 process_one_symbol (type, bufp->n_desc, bufp->n_value,
1376 namestring, section_offsets, objfile);
1377 }
1378 /* We skip checking for a new .o or -l file; that should never
1379 happen in this routine. */
1380 else if (type == N_TEXT)
1381 {
1382 /* I don't think this code will ever be executed, because
1383 the GCC_COMPILED_FLAG_SYMBOL usually is right before
1384 the N_SO symbol which starts this source file.
1385 However, there is no reason not to accept
1386 the GCC_COMPILED_FLAG_SYMBOL anywhere. */
1387
1388 if (STREQ (namestring, GCC_COMPILED_FLAG_SYMBOL))
1389 processing_gcc_compilation = 1;
1390 else if (STREQ (namestring, GCC2_COMPILED_FLAG_SYMBOL))
1391 processing_gcc_compilation = 2;
1392
1393 #if 1 /* Works, but is experimental. -fnf */
1394 if (AUTO_DEMANGLING)
1395 {
1396 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
1397 }
1398 #endif
1399 }
1400 else if (type & N_EXT || type == (unsigned char)N_TEXT
1401 || type == (unsigned char)N_NBTEXT
1402 ) {
1403 /* Global symbol: see if we came across a dbx defintion for
1404 a corresponding symbol. If so, store the value. Remove
1405 syms from the chain when their values are stored, but
1406 search the whole chain, as there may be several syms from
1407 different files with the same name. */
1408 /* This is probably not true. Since the files will be read
1409 in one at a time, each reference to a global symbol will
1410 be satisfied in each file as it appears. So we skip this
1411 section. */
1412 ;
1413 }
1414 }
1415
1416 current_objfile = NULL;
1417
1418 /* In a Solaris elf file, this variable, which comes from the
1419 value of the N_SO symbol, will still be 0. Luckily, text_offset,
1420 which comes from pst->textlow is correct. */
1421 if (last_source_start_addr == 0)
1422 last_source_start_addr = text_offset;
1423
1424 rtn = end_symtab (text_offset + text_size, 0, 0, objfile);
1425 end_stabs ();
1426 return (rtn);
1427 }
1428 \f
1429 /* This handles a single symbol from the symbol-file, building symbols
1430 into a GDB symtab. It takes these arguments and an implicit argument.
1431
1432 TYPE is the type field of the ".stab" symbol entry.
1433 DESC is the desc field of the ".stab" entry.
1434 VALU is the value field of the ".stab" entry.
1435 NAME is the symbol name, in our address space.
1436 SECTION_OFFSETS is a set of amounts by which the sections of this object
1437 file were relocated when it was loaded into memory.
1438 All symbols that refer
1439 to memory locations need to be offset by these amounts.
1440 OBJFILE is the object file from which we are reading symbols.
1441 It is used in end_symtab. */
1442
1443 void
1444 process_one_symbol (type, desc, valu, name, section_offsets, objfile)
1445 int type, desc;
1446 CORE_ADDR valu;
1447 char *name;
1448 struct section_offsets *section_offsets;
1449 struct objfile *objfile;
1450 {
1451 #ifndef SUN_FIXED_LBRAC_BUG
1452 /* This records the last pc address we've seen. We depend on there being
1453 an SLINE or FUN or SO before the first LBRAC, since the variable does
1454 not get reset in between reads of different symbol files. */
1455 static CORE_ADDR last_pc_address;
1456 #endif
1457 register struct context_stack *new;
1458 /* This remembers the address of the start of a function. It is used
1459 because in Solaris 2, N_LBRAC, N_RBRAC, and N_SLINE entries are
1460 relative to the current function's start address. On systems
1461 other than Solaris 2, this just holds the SECT_OFF_TEXT value, and is
1462 used to relocate these symbol types rather than SECTION_OFFSETS. */
1463 static CORE_ADDR function_start_offset;
1464 char *colon_pos;
1465
1466 #ifndef BLOCK_ADDRESS_FUNCTION_RELATIVE
1467 /* N_LBRAC, N_RBRAC and N_SLINE entries are not relative to the
1468 function start address, so just use the text offset. */
1469 function_start_offset = ANOFFSET (section_offsets, SECT_OFF_TEXT);
1470 #endif
1471
1472 /* Something is wrong if we see real data before
1473 seeing a source file name. */
1474
1475 if (last_source_file == NULL && type != (unsigned char)N_SO)
1476 {
1477 /* Currently this ignores N_ENTRY on Gould machines, N_NSYM on machines
1478 where that code is defined. */
1479 if (IGNORE_SYMBOL (type))
1480 return;
1481
1482 /* FIXME, this should not be an error, since it precludes extending
1483 the symbol table information in this way... */
1484 error ("Invalid symbol data: does not start by identifying a source file.");
1485 }
1486
1487 switch (type)
1488 {
1489 case N_FUN:
1490 case N_FNAME:
1491 #if 0
1492 /* It seems that the Sun ANSI C compiler (acc) replaces N_FUN with N_GSYM and
1493 N_STSYM with a type code of f or F. Can't enable this until we get some
1494 stuff straightened out with psymtabs. FIXME. */
1495
1496 case N_GSYM:
1497 case N_STSYM:
1498 #endif /* 0 */
1499
1500 /* Relocate for dynamic loading */
1501 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1502
1503 /* Either of these types of symbols indicates the start of
1504 a new function. We must process its "name" normally for dbx,
1505 but also record the start of a new lexical context, and possibly
1506 also the end of the lexical context for the previous function. */
1507 /* This is not always true. This type of symbol may indicate a
1508 text segment variable. */
1509
1510 colon_pos = strchr (name, ':');
1511 if (!colon_pos++
1512 || (*colon_pos != 'f' && *colon_pos != 'F'))
1513 {
1514 define_symbol (valu, name, desc, type, objfile);
1515 break;
1516 }
1517
1518 #ifndef SUN_FIXED_LBRAC_BUG
1519 last_pc_address = valu; /* Save for SunOS bug circumcision */
1520 #endif
1521
1522 #ifdef BLOCK_ADDRESS_FUNCTION_RELATIVE
1523 /* On Solaris 2.0 compilers, the block addresses and N_SLINE's
1524 are relative to the start of the function. On normal systems,
1525 and when using gcc on Solaris 2.0, these addresses are just
1526 absolute, or relative to the N_SO, depending on
1527 BLOCK_ADDRESS_ABSOLUTE. */
1528 function_start_offset = valu;
1529 #endif
1530
1531 within_function = 1;
1532 if (context_stack_depth > 0)
1533 {
1534 new = pop_context ();
1535 /* Make a block for the local symbols within. */
1536 finish_block (new->name, &local_symbols, new->old_blocks,
1537 new->start_addr, valu, objfile);
1538 }
1539 /* Stack must be empty now. */
1540 if (context_stack_depth != 0)
1541 complain (&lbrac_unmatched_complaint, symnum);
1542
1543 new = push_context (0, valu);
1544 new->name = define_symbol (valu, name, desc, type, objfile);
1545 break;
1546
1547 case N_LBRAC:
1548 /* This "symbol" just indicates the start of an inner lexical
1549 context within a function. */
1550
1551 #if defined(BLOCK_ADDRESS_ABSOLUTE) || defined(BLOCK_ADDRESS_FUNCTION_RELATIVE)
1552 /* Relocate for dynamic loading and Sun ELF acc fn-relative syms. */
1553 valu += function_start_offset;
1554 #else
1555 /* On most machines, the block addresses are relative to the
1556 N_SO, the linker did not relocate them (sigh). */
1557 valu += last_source_start_addr;
1558 #endif
1559
1560 #ifndef SUN_FIXED_LBRAC_BUG
1561 if (valu < last_pc_address) {
1562 /* Patch current LBRAC pc value to match last handy pc value */
1563 complain (&lbrac_complaint);
1564 valu = last_pc_address;
1565 }
1566 #endif
1567 new = push_context (desc, valu);
1568 break;
1569
1570 case N_RBRAC:
1571 /* This "symbol" just indicates the end of an inner lexical
1572 context that was started with N_LBRAC. */
1573
1574 #if defined(BLOCK_ADDRESS_ABSOLUTE) || defined(BLOCK_ADDRESS_FUNCTION_RELATIVE)
1575 /* Relocate for dynamic loading and Sun ELF acc fn-relative syms. */
1576 valu += function_start_offset;
1577 #else
1578 /* On most machines, the block addresses are relative to the
1579 N_SO, the linker did not relocate them (sigh). */
1580 valu += last_source_start_addr;
1581 #endif
1582
1583 new = pop_context();
1584 if (desc != new->depth)
1585 complain (&lbrac_mismatch_complaint, symnum);
1586
1587 /* Some compilers put the variable decls inside of an
1588 LBRAC/RBRAC block. This macro should be nonzero if this
1589 is true. DESC is N_DESC from the N_RBRAC symbol.
1590 GCC_P is true if we've detected the GCC_COMPILED_SYMBOL
1591 or the GCC2_COMPILED_SYMBOL. */
1592 #if !defined (VARIABLES_INSIDE_BLOCK)
1593 #define VARIABLES_INSIDE_BLOCK(desc, gcc_p) 0
1594 #endif
1595
1596 /* Can only use new->locals as local symbols here if we're in
1597 gcc or on a machine that puts them before the lbrack. */
1598 if (!VARIABLES_INSIDE_BLOCK(desc, processing_gcc_compilation))
1599 local_symbols = new->locals;
1600
1601 /* If this is not the outermost LBRAC...RBRAC pair in the
1602 function, its local symbols preceded it, and are the ones
1603 just recovered from the context stack. Defined the block for them.
1604
1605 If this is the outermost LBRAC...RBRAC pair, there is no
1606 need to do anything; leave the symbols that preceded it
1607 to be attached to the function's own block. However, if
1608 it is so, we need to indicate that we just moved outside
1609 of the function. */
1610 if (local_symbols
1611 && (context_stack_depth
1612 > !VARIABLES_INSIDE_BLOCK(desc, processing_gcc_compilation)))
1613 {
1614 /* FIXME Muzzle a compiler bug that makes end < start. */
1615 if (new->start_addr > valu)
1616 {
1617 complain (&lbrac_rbrac_complaint);
1618 new->start_addr = valu;
1619 }
1620 /* Make a block for the local symbols within. */
1621 finish_block (0, &local_symbols, new->old_blocks,
1622 new->start_addr, valu, objfile);
1623 }
1624 else
1625 {
1626 within_function = 0;
1627 }
1628 if (VARIABLES_INSIDE_BLOCK(desc, processing_gcc_compilation))
1629 /* Now pop locals of block just finished. */
1630 local_symbols = new->locals;
1631 break;
1632
1633 case N_FN:
1634 case N_FN_SEQ:
1635 /* This kind of symbol indicates the start of an object file. */
1636 /* Relocate for dynamic loading */
1637 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1638 break;
1639
1640 case N_SO:
1641 /* This type of symbol indicates the start of data
1642 for one source file.
1643 Finish the symbol table of the previous source file
1644 (if any) and start accumulating a new symbol table. */
1645 /* Relocate for dynamic loading */
1646 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1647
1648 #ifndef SUN_FIXED_LBRAC_BUG
1649 last_pc_address = valu; /* Save for SunOS bug circumcision */
1650 #endif
1651
1652 #ifdef PCC_SOL_BROKEN
1653 /* pcc bug, occasionally puts out SO for SOL. */
1654 if (context_stack_depth > 0)
1655 {
1656 start_subfile (name, NULL);
1657 break;
1658 }
1659 #endif
1660 if (last_source_file)
1661 {
1662 /* Check if previous symbol was also an N_SO (with some
1663 sanity checks). If so, that one was actually the directory
1664 name, and the current one is the real file name.
1665 Patch things up. */
1666 if (previous_stab_code == (unsigned char) N_SO)
1667 {
1668 patch_subfile_names (current_subfile, name);
1669 break; /* Ignore repeated SOs */
1670 }
1671 end_symtab (valu, 0, 0, objfile);
1672 end_stabs ();
1673 }
1674 start_stabs ();
1675 start_symtab (name, NULL, valu);
1676 break;
1677
1678
1679 case N_SOL:
1680 /* This type of symbol indicates the start of data for
1681 a sub-source-file, one whose contents were copied or
1682 included in the compilation of the main source file
1683 (whose name was given in the N_SO symbol.) */
1684 /* Relocate for dynamic loading */
1685 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1686 start_subfile (name, current_subfile->dirname);
1687 break;
1688
1689 case N_BINCL:
1690 push_subfile ();
1691 add_new_header_file (name, valu);
1692 start_subfile (name, current_subfile->dirname);
1693 break;
1694
1695 case N_EINCL:
1696 start_subfile (pop_subfile (), current_subfile->dirname);
1697 break;
1698
1699 case N_EXCL:
1700 add_old_header_file (name, valu);
1701 break;
1702
1703 case N_SLINE:
1704 /* This type of "symbol" really just records
1705 one line-number -- core-address correspondence.
1706 Enter it in the line list for this symbol table. */
1707 /* Relocate for dynamic loading and for ELF acc fn-relative syms. */
1708 valu += function_start_offset;
1709 #ifndef SUN_FIXED_LBRAC_BUG
1710 last_pc_address = valu; /* Save for SunOS bug circumcision */
1711 #endif
1712 record_line (current_subfile, desc, valu);
1713 break;
1714
1715 case N_BCOMM:
1716 if (common_block)
1717 error ("Invalid symbol data: common within common at symtab pos %d",
1718 symnum);
1719 common_block = local_symbols;
1720 common_block_i = local_symbols ? local_symbols->nsyms : 0;
1721 break;
1722
1723 case N_ECOMM:
1724 /* Symbols declared since the BCOMM are to have the common block
1725 start address added in when we know it. common_block points to
1726 the first symbol after the BCOMM in the local_symbols list;
1727 copy the list and hang it off the symbol for the common block name
1728 for later fixup. */
1729 {
1730 int i;
1731 struct symbol *sym =
1732 (struct symbol *) xmmalloc (objfile -> md, sizeof (struct symbol));
1733 memset (sym, 0, sizeof *sym);
1734 SYMBOL_NAME (sym) = savestring (name, strlen (name));
1735 SYMBOL_CLASS (sym) = LOC_BLOCK;
1736 SYMBOL_NAMESPACE (sym) = (enum namespace)((long)
1737 copy_pending (local_symbols, common_block_i, common_block));
1738 i = hashname (SYMBOL_NAME (sym));
1739 SYMBOL_VALUE_CHAIN (sym) = global_sym_chain[i];
1740 global_sym_chain[i] = sym;
1741 common_block = 0;
1742 break;
1743 }
1744
1745 /* The following symbol types need to have the appropriate offset added
1746 to their value; then we process symbol definitions in the name. */
1747
1748 case N_STSYM: /* Static symbol in data seg */
1749 case N_LCSYM: /* Static symbol in BSS seg */
1750 case N_ROSYM: /* Static symbol in Read-only data seg */
1751 /* HORRID HACK DEPT. However, it's Sun's furgin' fault. FIXME.
1752 Solaris2's stabs-in-coff makes *most* symbols relative
1753 but leaves a few absolute. N_STSYM and friends sit on the fence.
1754 .stab "foo:S...",N_STSYM is absolute (ld relocates it)
1755 .stab "foo:V...",N_STSYM is relative (section base subtracted).
1756 This leaves us no choice but to search for the 'S' or 'V'...
1757 (or pass the whole section_offsets stuff down ONE MORE function
1758 call level, which we really don't want to do). */
1759 {
1760 char *p;
1761 p = strchr (name, ':');
1762 if (p != 0 && p[1] == 'S')
1763 {
1764 /* FIXME! We relocate it by the TEXT offset, in case the
1765 whole module moved in memory. But this is wrong, since
1766 the sections can side around independently. */
1767 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1768 goto define_a_symbol;
1769 }
1770 /* Since it's not the kludge case, re-dispatch to the right handler. */
1771 switch (type) {
1772 case N_STSYM: goto case_N_STSYM;
1773 case N_LCSYM: goto case_N_LCSYM;
1774 case N_ROSYM: goto case_N_ROSYM;
1775 default: abort();
1776 }
1777 }
1778
1779 case_N_STSYM: /* Static symbol in data seg */
1780 case N_DSLINE: /* Source line number, data seg */
1781 valu += ANOFFSET (section_offsets, SECT_OFF_DATA);
1782 goto define_a_symbol;
1783
1784 case_N_LCSYM: /* Static symbol in BSS seg */
1785 case N_BSLINE: /* Source line number, bss seg */
1786 /* N_BROWS: overlaps with N_BSLINE */
1787 valu += ANOFFSET (section_offsets, SECT_OFF_BSS);
1788 goto define_a_symbol;
1789
1790 case_N_ROSYM: /* Static symbol in Read-only data seg */
1791 valu += ANOFFSET (section_offsets, SECT_OFF_RODATA);
1792 goto define_a_symbol;
1793
1794 case N_ENTRY: /* Alternate entry point */
1795 /* Relocate for dynamic loading */
1796 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1797 goto define_a_symbol;
1798
1799 /* The following symbol types don't need the address field relocated,
1800 since it is either unused, or is absolute. */
1801 define_a_symbol:
1802 case N_GSYM: /* Global variable */
1803 case N_NSYMS: /* Number of symbols (ultrix) */
1804 case N_NOMAP: /* No map? (ultrix) */
1805 case N_RSYM: /* Register variable */
1806 case N_DEFD: /* Modula-2 GNU module dependency */
1807 case N_SSYM: /* Struct or union element */
1808 case N_LSYM: /* Local symbol in stack */
1809 case N_PSYM: /* Parameter variable */
1810 case N_LENG: /* Length of preceding symbol type */
1811 if (name)
1812 define_symbol (valu, name, desc, type, objfile);
1813 break;
1814
1815 /* We use N_OPT to carry the gcc2_compiled flag. Sun uses it
1816 for a bunch of other flags, too. Someday we may parse their
1817 flags; for now we ignore theirs and hope they'll ignore ours. */
1818 case N_OPT: /* Solaris 2: Compiler options */
1819 if (name)
1820 {
1821 if (STREQ (name, GCC2_COMPILED_FLAG_SYMBOL))
1822 {
1823 processing_gcc_compilation = 2;
1824 #if 1 /* Works, but is experimental. -fnf */
1825 if (AUTO_DEMANGLING)
1826 {
1827 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
1828 }
1829 #endif
1830 }
1831 }
1832 break;
1833
1834 /* The following symbol types can be ignored. */
1835 case N_OBJ: /* Solaris 2: Object file dir and name */
1836 /* N_UNDF: Solaris 2: file separator mark */
1837 /* N_UNDF: -- we will never encounter it, since we only process one
1838 file's symbols at once. */
1839 case N_ENDM: /* Solaris 2: End of module */
1840 case N_MAIN: /* Name of main routine. */
1841 break;
1842
1843 /* The following symbol types we don't know how to process. Handle
1844 them in a "default" way, but complain to people who care. */
1845 default:
1846 case N_CATCH: /* Exception handler catcher */
1847 case N_EHDECL: /* Exception handler name */
1848 case N_PC: /* Global symbol in Pascal */
1849 case N_M2C: /* Modula-2 compilation unit */
1850 /* N_MOD2: overlaps with N_EHDECL */
1851 case N_SCOPE: /* Modula-2 scope information */
1852 case N_ECOML: /* End common (local name) */
1853 case N_NBTEXT: /* Gould Non-Base-Register symbols??? */
1854 case N_NBDATA:
1855 case N_NBBSS:
1856 case N_NBSTS:
1857 case N_NBLCS:
1858 complain (&unknown_symtype_complaint, local_hex_string(type));
1859 if (name)
1860 define_symbol (valu, name, desc, type, objfile);
1861 }
1862
1863 previous_stab_code = type;
1864 }
1865 \f
1866 /* Copy a pending list, used to record the contents of a common
1867 block for later fixup. */
1868 static struct pending *
1869 copy_pending (beg, begi, end)
1870 struct pending *beg;
1871 int begi;
1872 struct pending *end;
1873 {
1874 struct pending *new = 0;
1875 struct pending *next;
1876
1877 for (next = beg; next != 0 && (next != end || begi < end->nsyms);
1878 next = next->next, begi = 0)
1879 {
1880 register int j;
1881 for (j = begi; j < next->nsyms; j++)
1882 add_symbol_to_list (next->symbol[j], &new);
1883 }
1884 return new;
1885 }
1886 \f
1887 /* Scan and build partial symbols for an ELF symbol file.
1888 This ELF file has already been processed to get its minimal symbols,
1889 and any DWARF symbols that were in it.
1890
1891 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
1892 rolled into one.
1893
1894 OBJFILE is the object file we are reading symbols from.
1895 ADDR is the address relative to which the symbols are (e.g.
1896 the base address of the text segment).
1897 MAINLINE is true if we are reading the main symbol
1898 table (as opposed to a shared lib or dynamically loaded file).
1899 STABOFFSET and STABSIZE define the location in OBJFILE where the .stab
1900 section exists.
1901 STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
1902 .stabstr section exists.
1903
1904 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
1905 adjusted for elf details. */
1906
1907 void
1908 elfstab_build_psymtabs (objfile, section_offsets, mainline,
1909 staboffset, stabsize,
1910 stabstroffset, stabstrsize)
1911 struct objfile *objfile;
1912 struct section_offsets *section_offsets;
1913 int mainline;
1914 file_ptr staboffset;
1915 unsigned int stabsize;
1916 file_ptr stabstroffset;
1917 unsigned int stabstrsize;
1918 {
1919 int val;
1920 bfd *sym_bfd = objfile->obfd;
1921 char *name = bfd_get_filename (sym_bfd);
1922 struct dbx_symfile_info *info;
1923
1924 /* There is already a dbx_symfile_info allocated by our caller.
1925 It might even contain some info from the ELF symtab to help us. */
1926 info = (struct dbx_symfile_info *) objfile->sym_private;
1927
1928 DBX_TEXT_SECT (objfile) = bfd_get_section_by_name (sym_bfd, ".text");
1929 if (!DBX_TEXT_SECT (objfile))
1930 error ("Can't find .text section in symbol file");
1931
1932 #define ELF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
1933 DBX_SYMBOL_SIZE (objfile) = ELF_STABS_SYMBOL_SIZE;
1934 DBX_SYMCOUNT (objfile) = stabsize / DBX_SYMBOL_SIZE (objfile);
1935 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
1936 DBX_SYMTAB_OFFSET (objfile) = staboffset;
1937
1938 if (stabstrsize < 0 /* FIXME: stabstrsize is unsigned; never true! */
1939 || stabstrsize > bfd_get_size (sym_bfd))
1940 error ("ridiculous string table size: %d bytes", stabstrsize);
1941 DBX_STRINGTAB (objfile) = (char *)
1942 obstack_alloc (&objfile->psymbol_obstack, stabstrsize+1);
1943
1944 /* Now read in the string table in one big gulp. */
1945
1946 val = bfd_seek (sym_bfd, stabstroffset, L_SET);
1947 if (val < 0)
1948 perror_with_name (name);
1949 val = bfd_read (DBX_STRINGTAB (objfile), stabstrsize, 1, sym_bfd);
1950 if (val != stabstrsize)
1951 perror_with_name (name);
1952
1953 stabsread_new_init ();
1954 buildsym_new_init ();
1955 free_header_files ();
1956 init_header_files ();
1957 install_minimal_symbols (objfile);
1958
1959 processing_acc_compilation = 1;
1960
1961 /* In an elf file, we've already installed the minimal symbols that came
1962 from the elf (non-stab) symbol table, so always act like an
1963 incremental load here. */
1964 dbx_symfile_read (objfile, section_offsets, 0);
1965 }
1966 \f
1967 /* Scan and build partial symbols for a PA symbol file.
1968 This PA file has already been processed to get its minimal symbols.
1969
1970 OBJFILE is the object file we are reading symbols from.
1971 ADDR is the address relative to which the symbols are (e.g.
1972 the base address of the text segment).
1973 MAINLINE is true if we are reading the main symbol
1974 table (as opposed to a shared lib or dynamically loaded file).
1975
1976 */
1977
1978 void
1979 pastab_build_psymtabs (objfile, section_offsets, mainline)
1980 struct objfile *objfile;
1981 struct section_offsets *section_offsets;
1982 int mainline;
1983 {
1984 free_header_files ();
1985 init_header_files ();
1986
1987 /* In a PA file, we've already installed the minimal symbols that came
1988 from the PA (non-stab) symbol table, so always act like an
1989 incremental load here. */
1990
1991 dbx_symfile_read (objfile, section_offsets, mainline);
1992 }
1993 \f
1994 /* Parse the user's idea of an offset for dynamic linking, into our idea
1995 of how to represent it for fast symbol reading. */
1996
1997 static struct section_offsets *
1998 dbx_symfile_offsets (objfile, addr)
1999 struct objfile *objfile;
2000 CORE_ADDR addr;
2001 {
2002 struct section_offsets *section_offsets;
2003 int i;
2004
2005 section_offsets = (struct section_offsets *)
2006 obstack_alloc (&objfile -> psymbol_obstack,
2007 sizeof (struct section_offsets) +
2008 sizeof (section_offsets->offsets) * (SECT_OFF_MAX-1));
2009
2010 for (i = 0; i < SECT_OFF_MAX; i++)
2011 ANOFFSET (section_offsets, i) = addr;
2012
2013 return section_offsets;
2014 }
2015 \f
2016 /* Register our willingness to decode symbols for SunOS and a.out and
2017 b.out files handled by BFD... */
2018 static struct sym_fns sunos_sym_fns =
2019 {
2020 "sunOs", /* sym_name: name or name prefix of BFD target type */
2021 6, /* sym_namelen: number of significant sym_name chars */
2022 dbx_new_init, /* sym_new_init: init anything gbl to entire symtab */
2023 dbx_symfile_init, /* sym_init: read initial info, setup for sym_read() */
2024 dbx_symfile_read, /* sym_read: read a symbol file into symtab */
2025 dbx_symfile_finish, /* sym_finish: finished with file, cleanup */
2026 dbx_symfile_offsets, /* sym_offsets: parse user's offsets to internal form */
2027 NULL /* next: pointer to next struct sym_fns */
2028 };
2029
2030 static struct sym_fns aout_sym_fns =
2031 {
2032 "a.out", /* sym_name: name or name prefix of BFD target type */
2033 5, /* sym_namelen: number of significant sym_name chars */
2034 dbx_new_init, /* sym_new_init: init anything gbl to entire symtab */
2035 dbx_symfile_init, /* sym_init: read initial info, setup for sym_read() */
2036 dbx_symfile_read, /* sym_read: read a symbol file into symtab */
2037 dbx_symfile_finish, /* sym_finish: finished with file, cleanup */
2038 dbx_symfile_offsets, /* sym_offsets: parse user's offsets to internal form */
2039 NULL /* next: pointer to next struct sym_fns */
2040 };
2041
2042 static struct sym_fns bout_sym_fns =
2043 {
2044 "b.out", /* sym_name: name or name prefix of BFD target type */
2045 5, /* sym_namelen: number of significant sym_name chars */
2046 dbx_new_init, /* sym_new_init: init anything gbl to entire symtab */
2047 dbx_symfile_init, /* sym_init: read initial info, setup for sym_read() */
2048 dbx_symfile_read, /* sym_read: read a symbol file into symtab */
2049 dbx_symfile_finish, /* sym_finish: finished with file, cleanup */
2050 dbx_symfile_offsets, /* sym_offsets: parse user's offsets to internal form */
2051 NULL /* next: pointer to next struct sym_fns */
2052 };
2053
2054 void
2055 _initialize_dbxread ()
2056 {
2057 add_symtab_fns(&sunos_sym_fns);
2058 add_symtab_fns(&aout_sym_fns);
2059 add_symtab_fns(&bout_sym_fns);
2060 }
This page took 0.084827 seconds and 4 git commands to generate.