change minsyms not to be relocated at read-time
[deliverable/binutils-gdb.git] / gdb / xcoffread.c
1 /* Read AIX xcoff symbol tables and convert to internal format, for GDB.
2 Copyright (C) 1986-2014 Free Software Foundation, Inc.
3 Derived from coffread.c, dbxread.c, and a lot of hacking.
4 Contributed by IBM Corporation.
5
6 This file is part of GDB.
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
20
21 #include "defs.h"
22 #include "bfd.h"
23
24 #include <sys/types.h>
25 #include <fcntl.h>
26 #include <ctype.h>
27 #include <string.h>
28
29 #ifdef HAVE_SYS_FILE_H
30 #include <sys/file.h>
31 #endif
32 #include <sys/stat.h>
33
34 #include "coff/internal.h"
35 #include "libcoff.h" /* FIXME, internal data from BFD */
36 #include "coff/xcoff.h"
37 #include "libxcoff.h"
38 #include "coff/rs6000.h"
39 #include "xcoffread.h"
40
41 #include "symtab.h"
42 #include "gdbtypes.h"
43 /* FIXME: ezannoni/2004-02-13 Verify if the include below is really needed. */
44 #include "symfile.h"
45 #include "objfiles.h"
46 #include "buildsym.h"
47 #include "stabsread.h"
48 #include "expression.h"
49 #include "complaints.h"
50 #include "psympriv.h"
51
52 #include "gdb-stabs.h"
53
54 /* For interface with stabsread.c. */
55 #include "aout/stab_gnu.h"
56
57 \f
58 /* Key for XCOFF-associated data. */
59
60 static const struct objfile_data *xcoff_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
68 /* First symbol number for this file. */
69
70 int first_symnum;
71
72 /* Number of symbols in 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 numsyms 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 numsyms;
79
80 /* Position of the start of the line number information for this
81 psymtab. */
82 unsigned int lineno_off;
83 };
84
85 /* Remember what we deduced to be the source language of this psymtab. */
86
87 static enum language psymtab_language = language_unknown;
88 \f
89
90 /* Simplified internal version of coff symbol table information. */
91
92 struct coff_symbol
93 {
94 char *c_name;
95 int c_symnum; /* Symbol number of this entry. */
96 int c_naux; /* 0 if syment only, 1 if syment + auxent. */
97 CORE_ADDR c_value;
98 unsigned char c_sclass;
99 int c_secnum;
100 unsigned int c_type;
101 };
102
103 /* Last function's saved coff symbol `cs'. */
104
105 static struct coff_symbol fcn_cs_saved;
106
107 static bfd *symfile_bfd;
108
109 /* Core address of start and end of text of current source file.
110 This is calculated from the first function seen after a C_FILE
111 symbol. */
112
113
114 static CORE_ADDR cur_src_end_addr;
115
116 /* Core address of the end of the first object file. */
117
118 static CORE_ADDR first_object_file_end;
119
120 /* Initial symbol-table-debug-string vector length. */
121
122 #define INITIAL_STABVECTOR_LENGTH 40
123
124 /* Nonzero if within a function (so symbols should be local,
125 if nothing says specifically). */
126
127 int within_function;
128
129 /* Size of a COFF symbol. I think it is always 18, so I'm not sure
130 there is any reason not to just use a #define, but might as well
131 ask BFD for the size and store it here, I guess. */
132
133 static unsigned local_symesz;
134
135 struct coff_symfile_info
136 {
137 file_ptr min_lineno_offset; /* Where in file lowest line#s are. */
138 file_ptr max_lineno_offset; /* 1+last byte of line#s in file. */
139
140 /* Pointer to the string table. */
141 char *strtbl;
142
143 /* Pointer to debug section. */
144 char *debugsec;
145
146 /* Pointer to the a.out symbol table. */
147 char *symtbl;
148
149 /* Number of symbols in symtbl. */
150 int symtbl_num_syms;
151
152 /* Offset in data section to TOC anchor. */
153 CORE_ADDR toc_offset;
154 };
155
156 /* Convenience macro to access the per-objfile XCOFF data. */
157
158 #define XCOFF_DATA(objfile) \
159 ((struct coff_symfile_info *) objfile_data ((objfile), \
160 xcoff_objfile_data_key))
161
162 /* XCOFF names for dwarf sections. There is no compressed sections. */
163
164 static const struct dwarf2_debug_sections dwarf2_xcoff_names = {
165 { ".dwinfo", NULL },
166 { ".dwabrev", NULL },
167 { ".dwline", NULL },
168 { ".dwloc", NULL },
169 { NULL, NULL }, /* debug_macinfo */
170 { NULL, NULL }, /* debug_macro */
171 { ".dwstr", NULL },
172 { ".dwrnges", NULL },
173 { NULL, NULL }, /* debug_types */
174 { NULL, NULL }, /* debug_addr */
175 { ".dwframe", NULL },
176 { NULL, NULL }, /* eh_frame */
177 { NULL, NULL }, /* gdb_index */
178 23
179 };
180
181 static void
182 bf_notfound_complaint (void)
183 {
184 complaint (&symfile_complaints,
185 _("line numbers off, `.bf' symbol not found"));
186 }
187
188 static void
189 ef_complaint (int arg1)
190 {
191 complaint (&symfile_complaints,
192 _("Mismatched .ef symbol ignored starting at symnum %d"), arg1);
193 }
194
195 static void
196 eb_complaint (int arg1)
197 {
198 complaint (&symfile_complaints,
199 _("Mismatched .eb symbol ignored starting at symnum %d"), arg1);
200 }
201
202 static void xcoff_initial_scan (struct objfile *, int);
203
204 static void scan_xcoff_symtab (struct objfile *);
205
206 static char *xcoff_next_symbol_text (struct objfile *);
207
208 static void record_include_begin (struct coff_symbol *);
209
210 static void
211 enter_line_range (struct subfile *, unsigned, unsigned,
212 CORE_ADDR, CORE_ADDR, unsigned *);
213
214 static void init_stringtab (bfd *, file_ptr, struct objfile *);
215
216 static void xcoff_symfile_init (struct objfile *);
217
218 static void xcoff_new_init (struct objfile *);
219
220 static void xcoff_symfile_finish (struct objfile *);
221
222 static char *coff_getfilename (union internal_auxent *, struct objfile *);
223
224 static void read_symbol (struct internal_syment *, int);
225
226 static int read_symbol_lineno (int);
227
228 static CORE_ADDR read_symbol_nvalue (int);
229
230 static struct symbol *process_xcoff_symbol (struct coff_symbol *,
231 struct objfile *);
232
233 static void read_xcoff_symtab (struct objfile *, struct partial_symtab *);
234
235 #if 0
236 static void add_stab_to_list (char *, struct pending_stabs **);
237 #endif
238
239 static int compare_lte (const void *, const void *);
240
241 static struct linetable *arrange_linetable (struct linetable *);
242
243 static void record_include_end (struct coff_symbol *);
244
245 static void process_linenos (CORE_ADDR, CORE_ADDR);
246 \f
247
248 /* Translate from a COFF section number (target_index) to a SECT_OFF_*
249 code. */
250 static int secnum_to_section (int, struct objfile *);
251 static asection *secnum_to_bfd_section (int, struct objfile *);
252
253 struct find_targ_sec_arg
254 {
255 int targ_index;
256 int *resultp;
257 asection **bfd_sect;
258 struct objfile *objfile;
259 };
260
261 static void find_targ_sec (bfd *, asection *, void *);
262
263 static void
264 find_targ_sec (bfd *abfd, asection *sect, void *obj)
265 {
266 struct find_targ_sec_arg *args = (struct find_targ_sec_arg *) obj;
267 struct objfile *objfile = args->objfile;
268
269 if (sect->target_index == args->targ_index)
270 {
271 /* This is the section. Figure out what SECT_OFF_* code it is. */
272 if (bfd_get_section_flags (abfd, sect) & SEC_CODE)
273 *args->resultp = SECT_OFF_TEXT (objfile);
274 else if (bfd_get_section_flags (abfd, sect) & SEC_LOAD)
275 *args->resultp = SECT_OFF_DATA (objfile);
276 else
277 *args->resultp = gdb_bfd_section_index (abfd, sect);
278 *args->bfd_sect = sect;
279 }
280 }
281
282 /* Search all BFD sections for the section whose target_index is
283 equal to N_SCNUM. Set *BFD_SECT to that section. The section's
284 associated index in the objfile's section_offset table is also
285 stored in *SECNUM.
286
287 If no match is found, *BFD_SECT is set to NULL, and *SECNUM
288 is set to the text section's number. */
289
290 static void
291 xcoff_secnum_to_sections (int n_scnum, struct objfile *objfile,
292 asection **bfd_sect, int *secnum)
293 {
294 struct find_targ_sec_arg args;
295
296 args.targ_index = n_scnum;
297 args.resultp = secnum;
298 args.bfd_sect = bfd_sect;
299 args.objfile = objfile;
300
301 *bfd_sect = NULL;
302 *secnum = SECT_OFF_TEXT (objfile);
303
304 bfd_map_over_sections (objfile->obfd, find_targ_sec, &args);
305 }
306
307 /* Return the section number (SECT_OFF_*) that N_SCNUM points to. */
308
309 static int
310 secnum_to_section (int n_scnum, struct objfile *objfile)
311 {
312 int secnum;
313 asection *ignored;
314
315 xcoff_secnum_to_sections (n_scnum, objfile, &ignored, &secnum);
316 return secnum;
317 }
318
319 /* Return the BFD section that N_SCNUM points to. */
320
321 static asection *
322 secnum_to_bfd_section (int n_scnum, struct objfile *objfile)
323 {
324 int ignored;
325 asection *bfd_sect;
326
327 xcoff_secnum_to_sections (n_scnum, objfile, &bfd_sect, &ignored);
328 return bfd_sect;
329 }
330 \f
331 /* add a given stab string into given stab vector. */
332
333 #if 0
334
335 static void
336 add_stab_to_list (char *stabname, struct pending_stabs **stabvector)
337 {
338 if (*stabvector == NULL)
339 {
340 *stabvector = (struct pending_stabs *)
341 xmalloc (sizeof (struct pending_stabs) +
342 INITIAL_STABVECTOR_LENGTH * sizeof (char *));
343 (*stabvector)->count = 0;
344 (*stabvector)->length = INITIAL_STABVECTOR_LENGTH;
345 }
346 else if ((*stabvector)->count >= (*stabvector)->length)
347 {
348 (*stabvector)->length += INITIAL_STABVECTOR_LENGTH;
349 *stabvector = (struct pending_stabs *)
350 xrealloc ((char *) *stabvector, sizeof (struct pending_stabs) +
351 (*stabvector)->length * sizeof (char *));
352 }
353 (*stabvector)->stab[(*stabvector)->count++] = stabname;
354 }
355
356 #endif
357 \f/* *INDENT-OFF* */
358 /* Linenos are processed on a file-by-file basis.
359
360 Two reasons:
361
362 1) xlc (IBM's native c compiler) postpones static function code
363 emission to the end of a compilation unit. This way it can
364 determine if those functions (statics) are needed or not, and
365 can do some garbage collection (I think). This makes line
366 numbers and corresponding addresses unordered, and we end up
367 with a line table like:
368
369
370 lineno addr
371 foo() 10 0x100
372 20 0x200
373 30 0x300
374
375 foo3() 70 0x400
376 80 0x500
377 90 0x600
378
379 static foo2()
380 40 0x700
381 50 0x800
382 60 0x900
383
384 and that breaks gdb's binary search on line numbers, if the
385 above table is not sorted on line numbers. And that sort
386 should be on function based, since gcc can emit line numbers
387 like:
388
389 10 0x100 - for the init/test part of a for stmt.
390 20 0x200
391 30 0x300
392 10 0x400 - for the increment part of a for stmt.
393
394 arrange_linetable() will do this sorting.
395
396 2) aix symbol table might look like:
397
398 c_file // beginning of a new file
399 .bi // beginning of include file
400 .ei // end of include file
401 .bi
402 .ei
403
404 basically, .bi/.ei pairs do not necessarily encapsulate
405 their scope. They need to be recorded, and processed later
406 on when we come the end of the compilation unit.
407 Include table (inclTable) and process_linenos() handle
408 that. */
409 /* *INDENT-ON* */
410
411
412
413 /* compare line table entry addresses. */
414
415 static int
416 compare_lte (const void *lte1p, const void *lte2p)
417 {
418 struct linetable_entry *lte1 = (struct linetable_entry *) lte1p;
419 struct linetable_entry *lte2 = (struct linetable_entry *) lte2p;
420
421 return lte1->pc - lte2->pc;
422 }
423
424 /* Given a line table with function entries are marked, arrange its
425 functions in ascending order and strip off function entry markers
426 and return it in a newly created table. If the old one is good
427 enough, return the old one. */
428 /* FIXME: I think all this stuff can be replaced by just passing
429 sort_linevec = 1 to end_symtab. */
430
431 static struct linetable *
432 arrange_linetable (struct linetable *oldLineTb)
433 {
434 int ii, jj, newline, /* new line count */
435 function_count; /* # of functions */
436
437 struct linetable_entry *fentry; /* function entry vector */
438 int fentry_size; /* # of function entries */
439 struct linetable *newLineTb; /* new line table */
440 int extra_lines = 0;
441
442 #define NUM_OF_FUNCTIONS 20
443
444 fentry_size = NUM_OF_FUNCTIONS;
445 fentry = (struct linetable_entry *)
446 xmalloc (fentry_size * sizeof (struct linetable_entry));
447
448 for (function_count = 0, ii = 0; ii < oldLineTb->nitems; ++ii)
449 {
450 if (oldLineTb->item[ii].line == 0)
451 { /* Function entry found. */
452 if (function_count >= fentry_size)
453 { /* Make sure you have room. */
454 fentry_size *= 2;
455 fentry = (struct linetable_entry *)
456 xrealloc (fentry,
457 fentry_size * sizeof (struct linetable_entry));
458 }
459 fentry[function_count].line = ii;
460 fentry[function_count].pc = oldLineTb->item[ii].pc;
461 ++function_count;
462
463 /* If the function was compiled with XLC, we may have to add an
464 extra line entry later. Reserve space for that. */
465 if (ii + 1 < oldLineTb->nitems
466 && oldLineTb->item[ii].pc != oldLineTb->item[ii + 1].pc)
467 extra_lines++;
468 }
469 }
470
471 if (function_count == 0)
472 {
473 xfree (fentry);
474 return oldLineTb;
475 }
476 else if (function_count > 1)
477 qsort (fentry, function_count,
478 sizeof (struct linetable_entry), compare_lte);
479
480 /* Allocate a new line table. */
481 newLineTb = (struct linetable *)
482 xmalloc
483 (sizeof (struct linetable) +
484 (oldLineTb->nitems - function_count + extra_lines) * sizeof (struct linetable_entry));
485
486 /* If line table does not start with a function beginning, copy up until
487 a function begin. */
488
489 newline = 0;
490 if (oldLineTb->item[0].line != 0)
491 for (newline = 0;
492 newline < oldLineTb->nitems && oldLineTb->item[newline].line; ++newline)
493 newLineTb->item[newline] = oldLineTb->item[newline];
494
495 /* Now copy function lines one by one. */
496
497 for (ii = 0; ii < function_count; ++ii)
498 {
499 /* If the function was compiled with XLC, we may have to add an
500 extra line to cover the function prologue. */
501 jj = fentry[ii].line;
502 if (jj + 1 < oldLineTb->nitems
503 && oldLineTb->item[jj].pc != oldLineTb->item[jj + 1].pc)
504 {
505 newLineTb->item[newline] = oldLineTb->item[jj];
506 newLineTb->item[newline].line = oldLineTb->item[jj + 1].line;
507 newline++;
508 }
509
510 for (jj = fentry[ii].line + 1;
511 jj < oldLineTb->nitems && oldLineTb->item[jj].line != 0;
512 ++jj, ++newline)
513 newLineTb->item[newline] = oldLineTb->item[jj];
514 }
515 xfree (fentry);
516 /* The number of items in the line table must include these
517 extra lines which were added in case of XLC compiled functions. */
518 newLineTb->nitems = oldLineTb->nitems - function_count + extra_lines;
519 return newLineTb;
520 }
521
522 /* include file support: C_BINCL/C_EINCL pairs will be kept in the
523 following `IncludeChain'. At the end of each symtab (end_symtab),
524 we will determine if we should create additional symtab's to
525 represent if (the include files. */
526
527
528 typedef struct _inclTable
529 {
530 char *name; /* include filename */
531
532 /* Offsets to the line table. end points to the last entry which is
533 part of this include file. */
534 int begin, end;
535
536 struct subfile *subfile;
537 unsigned funStartLine; /* Start line # of its function. */
538 }
539 InclTable;
540
541 #define INITIAL_INCLUDE_TABLE_LENGTH 20
542 static InclTable *inclTable; /* global include table */
543 static int inclIndx; /* last entry to table */
544 static int inclLength; /* table length */
545 static int inclDepth; /* nested include depth */
546
547 static void allocate_include_entry (void);
548
549 static void
550 record_include_begin (struct coff_symbol *cs)
551 {
552 if (inclDepth)
553 {
554 /* In xcoff, we assume include files cannot be nested (not in .c files
555 of course, but in corresponding .s files.). */
556
557 /* This can happen with old versions of GCC.
558 GCC 2.3.3-930426 does not exhibit this on a test case which
559 a user said produced the message for him. */
560 complaint (&symfile_complaints, _("Nested C_BINCL symbols"));
561 }
562 ++inclDepth;
563
564 allocate_include_entry ();
565
566 inclTable[inclIndx].name = cs->c_name;
567 inclTable[inclIndx].begin = cs->c_value;
568 }
569
570 static void
571 record_include_end (struct coff_symbol *cs)
572 {
573 InclTable *pTbl;
574
575 if (inclDepth == 0)
576 {
577 complaint (&symfile_complaints, _("Mismatched C_BINCL/C_EINCL pair"));
578 }
579
580 allocate_include_entry ();
581
582 pTbl = &inclTable[inclIndx];
583 pTbl->end = cs->c_value;
584
585 --inclDepth;
586 ++inclIndx;
587 }
588
589 static void
590 allocate_include_entry (void)
591 {
592 if (inclTable == NULL)
593 {
594 inclTable = (InclTable *)
595 xmalloc (sizeof (InclTable) * INITIAL_INCLUDE_TABLE_LENGTH);
596 memset (inclTable,
597 '\0', sizeof (InclTable) * INITIAL_INCLUDE_TABLE_LENGTH);
598 inclLength = INITIAL_INCLUDE_TABLE_LENGTH;
599 inclIndx = 0;
600 }
601 else if (inclIndx >= inclLength)
602 {
603 inclLength += INITIAL_INCLUDE_TABLE_LENGTH;
604 inclTable = (InclTable *)
605 xrealloc (inclTable, sizeof (InclTable) * inclLength);
606 memset (inclTable + inclLength - INITIAL_INCLUDE_TABLE_LENGTH,
607 '\0', sizeof (InclTable) * INITIAL_INCLUDE_TABLE_LENGTH);
608 }
609 }
610
611 /* Global variable to pass the psymtab down to all the routines involved
612 in psymtab to symtab processing. */
613 static struct partial_symtab *this_symtab_psymtab;
614
615 /* Objfile related to this_symtab_psymtab; set at the same time. */
616 static struct objfile *this_symtab_objfile;
617
618 /* given the start and end addresses of a compilation unit (or a csect,
619 at times) process its lines and create appropriate line vectors. */
620
621 static void
622 process_linenos (CORE_ADDR start, CORE_ADDR end)
623 {
624 int offset, ii;
625 file_ptr max_offset
626 = XCOFF_DATA (this_symtab_objfile)->max_lineno_offset;
627
628 /* subfile structure for the main compilation unit. */
629 struct subfile main_subfile;
630
631 /* In the main source file, any time we see a function entry, we
632 reset this variable to function's absolute starting line number.
633 All the following line numbers in the function are relative to
634 this, and we record absolute line numbers in record_line(). */
635
636 unsigned int main_source_baseline = 0;
637
638 unsigned *firstLine;
639
640 offset =
641 ((struct symloc *) this_symtab_psymtab->read_symtab_private)->lineno_off;
642 if (offset == 0)
643 goto return_after_cleanup;
644
645 memset (&main_subfile, '\0', sizeof (main_subfile));
646
647 if (inclIndx == 0)
648 /* All source lines were in the main source file. None in include
649 files. */
650
651 enter_line_range (&main_subfile, offset, 0, start, end,
652 &main_source_baseline);
653
654 else
655 {
656 /* There was source with line numbers in include files. */
657
658 int linesz =
659 coff_data (this_symtab_objfile->obfd)->local_linesz;
660 main_source_baseline = 0;
661
662 for (ii = 0; ii < inclIndx; ++ii)
663 {
664 struct subfile *tmpSubfile;
665
666 /* If there is main file source before include file, enter it. */
667 if (offset < inclTable[ii].begin)
668 {
669 enter_line_range
670 (&main_subfile, offset, inclTable[ii].begin - linesz,
671 start, 0, &main_source_baseline);
672 }
673
674 if (strcmp (inclTable[ii].name, get_last_source_file ()) == 0)
675 {
676 /* The entry in the include table refers to the main source
677 file. Add the lines to the main subfile. */
678
679 main_source_baseline = inclTable[ii].funStartLine;
680 enter_line_range
681 (&main_subfile, inclTable[ii].begin, inclTable[ii].end,
682 start, 0, &main_source_baseline);
683 inclTable[ii].subfile = &main_subfile;
684 }
685 else
686 {
687 /* Have a new subfile for the include file. */
688
689 tmpSubfile = inclTable[ii].subfile =
690 (struct subfile *) xmalloc (sizeof (struct subfile));
691
692 memset (tmpSubfile, '\0', sizeof (struct subfile));
693 firstLine = &(inclTable[ii].funStartLine);
694
695 /* Enter include file's lines now. */
696 enter_line_range (tmpSubfile, inclTable[ii].begin,
697 inclTable[ii].end, start, 0, firstLine);
698 }
699
700 if (offset <= inclTable[ii].end)
701 offset = inclTable[ii].end + linesz;
702 }
703
704 /* All the include files' line have been processed at this point. Now,
705 enter remaining lines of the main file, if any left. */
706 if (offset < max_offset + 1 - linesz)
707 {
708 enter_line_range (&main_subfile, offset, 0, start, end,
709 &main_source_baseline);
710 }
711 }
712
713 /* Process main file's line numbers. */
714 if (main_subfile.line_vector)
715 {
716 struct linetable *lineTb, *lv;
717
718 lv = main_subfile.line_vector;
719
720 /* Line numbers are not necessarily ordered. xlc compilation will
721 put static function to the end. */
722
723 lineTb = arrange_linetable (lv);
724 if (lv == lineTb)
725 {
726 current_subfile->line_vector = (struct linetable *)
727 xrealloc (lv, (sizeof (struct linetable)
728 + lv->nitems * sizeof (struct linetable_entry)));
729 }
730 else
731 {
732 xfree (lv);
733 current_subfile->line_vector = lineTb;
734 }
735
736 current_subfile->line_vector_length =
737 current_subfile->line_vector->nitems;
738 }
739
740 /* Now, process included files' line numbers. */
741
742 for (ii = 0; ii < inclIndx; ++ii)
743 {
744 if (inclTable[ii].subfile != ((struct subfile *) &main_subfile)
745 && (inclTable[ii].subfile)->line_vector) /* Useless if!!!
746 FIXMEmgo */
747 {
748 struct linetable *lineTb, *lv;
749
750 lv = (inclTable[ii].subfile)->line_vector;
751
752 /* Line numbers are not necessarily ordered. xlc compilation will
753 put static function to the end. */
754
755 lineTb = arrange_linetable (lv);
756
757 push_subfile ();
758
759 /* For the same include file, we might want to have more than one
760 subfile. This happens if we have something like:
761
762 ......
763 #include "foo.h"
764 ......
765 #include "foo.h"
766 ......
767
768 while foo.h including code in it. (stupid but possible)
769 Since start_subfile() looks at the name and uses an
770 existing one if finds, we need to provide a fake name and
771 fool it. */
772
773 #if 0
774 start_subfile (inclTable[ii].name, (char *) 0);
775 #else
776 {
777 /* Pick a fake name that will produce the same results as this
778 one when passed to deduce_language_from_filename. Kludge on
779 top of kludge. */
780 char *fakename = strrchr (inclTable[ii].name, '.');
781
782 if (fakename == NULL)
783 fakename = " ?";
784 start_subfile (fakename, (char *) 0);
785 xfree (current_subfile->name);
786 }
787 current_subfile->name = xstrdup (inclTable[ii].name);
788 #endif
789
790 if (lv == lineTb)
791 {
792 current_subfile->line_vector =
793 (struct linetable *) xrealloc
794 (lv, (sizeof (struct linetable)
795 + lv->nitems * sizeof (struct linetable_entry)));
796
797 }
798 else
799 {
800 xfree (lv);
801 current_subfile->line_vector = lineTb;
802 }
803
804 current_subfile->line_vector_length =
805 current_subfile->line_vector->nitems;
806 start_subfile (pop_subfile (), (char *) 0);
807 }
808 }
809
810 return_after_cleanup:
811
812 /* We don't want to keep alloc/free'ing the global include file table. */
813 inclIndx = 0;
814
815 /* Start with a fresh subfile structure for the next file. */
816 memset (&main_subfile, '\0', sizeof (struct subfile));
817 }
818
819 static void
820 aix_process_linenos (struct objfile *objfile)
821 {
822 /* There is no linenos to read if there are only dwarf info. */
823 if (this_symtab_psymtab == NULL)
824 return;
825
826 /* Process line numbers and enter them into line vector. */
827 process_linenos (last_source_start_addr, cur_src_end_addr);
828 }
829
830
831 /* Enter a given range of lines into the line vector.
832 can be called in the following two ways:
833 enter_line_range (subfile, beginoffset, endoffset,
834 startaddr, 0, firstLine) or
835 enter_line_range (subfile, beginoffset, 0,
836 startaddr, endaddr, firstLine)
837
838 endoffset points to the last line table entry that we should pay
839 attention to. */
840
841 static void
842 enter_line_range (struct subfile *subfile, unsigned beginoffset,
843 unsigned endoffset, /* offsets to line table */
844 CORE_ADDR startaddr, /* offsets to line table */
845 CORE_ADDR endaddr, unsigned *firstLine)
846 {
847 struct objfile *objfile = this_symtab_objfile;
848 struct gdbarch *gdbarch = get_objfile_arch (objfile);
849 unsigned int curoffset;
850 CORE_ADDR addr;
851 void *ext_lnno;
852 struct internal_lineno int_lnno;
853 unsigned int limit_offset;
854 bfd *abfd;
855 int linesz;
856
857 if (endoffset == 0 && startaddr == 0 && endaddr == 0)
858 return;
859 curoffset = beginoffset;
860 limit_offset = XCOFF_DATA (objfile)->max_lineno_offset;
861
862 if (endoffset != 0)
863 {
864 if (endoffset >= limit_offset)
865 {
866 complaint (&symfile_complaints,
867 _("Bad line table offset in C_EINCL directive"));
868 return;
869 }
870 limit_offset = endoffset;
871 }
872 else
873 limit_offset -= 1;
874
875 abfd = objfile->obfd;
876 linesz = coff_data (abfd)->local_linesz;
877 ext_lnno = alloca (linesz);
878
879 while (curoffset <= limit_offset)
880 {
881 bfd_seek (abfd, curoffset, SEEK_SET);
882 bfd_bread (ext_lnno, linesz, abfd);
883 bfd_coff_swap_lineno_in (abfd, ext_lnno, &int_lnno);
884
885 /* Find the address this line represents. */
886 addr = (int_lnno.l_lnno
887 ? int_lnno.l_addr.l_paddr
888 : read_symbol_nvalue (int_lnno.l_addr.l_symndx));
889 addr += ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
890
891 if (addr < startaddr || (endaddr && addr >= endaddr))
892 return;
893
894 if (int_lnno.l_lnno == 0)
895 {
896 *firstLine = read_symbol_lineno (int_lnno.l_addr.l_symndx);
897 record_line (subfile, 0, gdbarch_addr_bits_remove (gdbarch, addr));
898 --(*firstLine);
899 }
900 else
901 record_line (subfile, *firstLine + int_lnno.l_lnno,
902 gdbarch_addr_bits_remove (gdbarch, addr));
903 curoffset += linesz;
904 }
905 }
906
907
908 /* Save the vital information for use when closing off the current file.
909 NAME is the file name the symbols came from, START_ADDR is the first
910 text address for the file, and SIZE is the number of bytes of text. */
911
912 #define complete_symtab(name, start_addr) { \
913 set_last_source_file (name); \
914 last_source_start_addr = start_addr; \
915 }
916
917
918 /* Refill the symbol table input buffer
919 and set the variables that control fetching entries from it.
920 Reports an error if no data available.
921 This function can read past the end of the symbol table
922 (into the string table) but this does no harm. */
923
924 /* Create a new minimal symbol (using prim_record_minimal_symbol_and_info).
925
926 Creation of all new minimal symbols should go through this function
927 rather than calling the various prim_record_[...] functions in order
928 to make sure that all symbol addresses get properly relocated.
929
930 Arguments are:
931
932 NAME - the symbol's name (but if NAME starts with a period, that
933 leading period is discarded).
934 ADDRESS - the symbol's address, prior to relocation. This function
935 relocates the address before recording the minimal symbol.
936 MS_TYPE - the symbol's type.
937 N_SCNUM - the symbol's XCOFF section number.
938 OBJFILE - the objfile associated with the minimal symbol. */
939
940 static void
941 record_minimal_symbol (const char *name, CORE_ADDR address,
942 enum minimal_symbol_type ms_type,
943 int n_scnum,
944 struct objfile *objfile)
945 {
946 int section = secnum_to_section (n_scnum, objfile);
947
948 if (name[0] == '.')
949 ++name;
950
951 prim_record_minimal_symbol_and_info (name, address, ms_type,
952 secnum_to_section (n_scnum, objfile),
953 objfile);
954 }
955
956 /* xcoff has static blocks marked in `.bs', `.es' pairs. They cannot be
957 nested. At any given time, a symbol can only be in one static block.
958 This is the base address of current static block, zero if non exists. */
959
960 static int static_block_base = 0;
961
962 /* Section number for the current static block. */
963
964 static int static_block_section = -1;
965
966 /* true if space for symbol name has been allocated. */
967
968 static int symname_alloced = 0;
969
970 /* Next symbol to read. Pointer into raw seething symbol table. */
971
972 static char *raw_symbol;
973
974 /* This is the function which stabsread.c calls to get symbol
975 continuations. */
976
977 static char *
978 xcoff_next_symbol_text (struct objfile *objfile)
979 {
980 struct internal_syment symbol;
981 char *retval;
982
983 /* FIXME: is this the same as the passed arg? */
984 if (this_symtab_objfile)
985 objfile = this_symtab_objfile;
986
987 bfd_coff_swap_sym_in (objfile->obfd, raw_symbol, &symbol);
988 if (symbol.n_zeroes)
989 {
990 complaint (&symfile_complaints, _("Unexpected symbol continuation"));
991
992 /* Return something which points to '\0' and hope the symbol reading
993 code does something reasonable. */
994 retval = "";
995 }
996 else if (symbol.n_sclass & 0x80)
997 {
998 retval = XCOFF_DATA (objfile)->debugsec + symbol.n_offset;
999 raw_symbol += coff_data (objfile->obfd)->local_symesz;
1000 ++symnum;
1001 }
1002 else
1003 {
1004 complaint (&symfile_complaints, _("Unexpected symbol continuation"));
1005
1006 /* Return something which points to '\0' and hope the symbol reading
1007 code does something reasonable. */
1008 retval = "";
1009 }
1010 return retval;
1011 }
1012
1013 /* Read symbols for a given partial symbol table. */
1014
1015 static void
1016 read_xcoff_symtab (struct objfile *objfile, struct partial_symtab *pst)
1017 {
1018 bfd *abfd = objfile->obfd;
1019 char *raw_auxptr; /* Pointer to first raw aux entry for sym. */
1020 struct coff_symfile_info *xcoff = XCOFF_DATA (objfile);
1021 char *strtbl = xcoff->strtbl;
1022 char *debugsec = xcoff->debugsec;
1023 const char *debugfmt = bfd_xcoff_is_xcoff64 (abfd) ? "XCOFF64" : "XCOFF";
1024
1025 struct internal_syment symbol[1];
1026 union internal_auxent main_aux;
1027 struct coff_symbol cs[1];
1028 CORE_ADDR file_start_addr = 0;
1029 CORE_ADDR file_end_addr = 0;
1030
1031 int next_file_symnum = -1;
1032 unsigned int max_symnum;
1033 int just_started = 1;
1034 int depth = 0;
1035 CORE_ADDR fcn_start_addr = 0;
1036
1037 struct coff_symbol fcn_stab_saved = { 0 };
1038
1039 /* fcn_cs_saved is global because process_xcoff_symbol needs it. */
1040 union internal_auxent fcn_aux_saved = main_aux;
1041 struct context_stack *new;
1042
1043 char *filestring = " _start_ "; /* Name of the current file. */
1044
1045 const char *last_csect_name; /* Last seen csect's name. */
1046
1047 this_symtab_psymtab = pst;
1048 this_symtab_objfile = objfile;
1049
1050 /* Get the appropriate COFF "constants" related to the file we're
1051 handling. */
1052 local_symesz = coff_data (abfd)->local_symesz;
1053
1054 set_last_source_file (NULL);
1055 last_csect_name = 0;
1056
1057 start_stabs ();
1058 start_symtab (filestring, (char *) NULL, file_start_addr);
1059 record_debugformat (debugfmt);
1060 symnum = ((struct symloc *) pst->read_symtab_private)->first_symnum;
1061 max_symnum =
1062 symnum + ((struct symloc *) pst->read_symtab_private)->numsyms;
1063 first_object_file_end = 0;
1064
1065 raw_symbol = xcoff->symtbl + symnum * local_symesz;
1066
1067 while (symnum < max_symnum)
1068 {
1069 QUIT; /* make this command interruptable. */
1070
1071 /* READ_ONE_SYMBOL (symbol, cs, symname_alloced); */
1072 /* read one symbol into `cs' structure. After processing the
1073 whole symbol table, only string table will be kept in memory,
1074 symbol table and debug section of xcoff will be freed. Thus
1075 we can mark symbols with names in string table as
1076 `alloced'. */
1077 {
1078 int ii;
1079
1080 /* Swap and align the symbol into a reasonable C structure. */
1081 bfd_coff_swap_sym_in (abfd, raw_symbol, symbol);
1082
1083 cs->c_symnum = symnum;
1084 cs->c_naux = symbol->n_numaux;
1085 if (symbol->n_zeroes)
1086 {
1087 symname_alloced = 0;
1088 /* We must use the original, unswapped, name here so the name field
1089 pointed to by cs->c_name will persist throughout xcoffread. If
1090 we use the new field, it gets overwritten for each symbol. */
1091 cs->c_name = ((struct external_syment *) raw_symbol)->e.e_name;
1092 /* If it's exactly E_SYMNMLEN characters long it isn't
1093 '\0'-terminated. */
1094 if (cs->c_name[E_SYMNMLEN - 1] != '\0')
1095 {
1096 char *p;
1097
1098 p = obstack_alloc (&objfile->objfile_obstack, E_SYMNMLEN + 1);
1099 strncpy (p, cs->c_name, E_SYMNMLEN);
1100 p[E_SYMNMLEN] = '\0';
1101 cs->c_name = p;
1102 symname_alloced = 1;
1103 }
1104 }
1105 else if (symbol->n_sclass & 0x80)
1106 {
1107 cs->c_name = debugsec + symbol->n_offset;
1108 symname_alloced = 0;
1109 }
1110 else
1111 {
1112 /* in string table */
1113 cs->c_name = strtbl + (int) symbol->n_offset;
1114 symname_alloced = 1;
1115 }
1116 cs->c_value = symbol->n_value;
1117 cs->c_sclass = symbol->n_sclass;
1118 cs->c_secnum = symbol->n_scnum;
1119 cs->c_type = (unsigned) symbol->n_type;
1120
1121 raw_symbol += local_symesz;
1122 ++symnum;
1123
1124 /* Save addr of first aux entry. */
1125 raw_auxptr = raw_symbol;
1126
1127 /* Skip all the auxents associated with this symbol. */
1128 for (ii = symbol->n_numaux; ii; --ii)
1129 {
1130 raw_symbol += coff_data (abfd)->local_auxesz;
1131 ++symnum;
1132 }
1133 }
1134
1135 /* if symbol name starts with ".$" or "$", ignore it. */
1136 if (cs->c_name[0] == '$'
1137 || (cs->c_name[1] == '$' && cs->c_name[0] == '.'))
1138 continue;
1139
1140 if (cs->c_symnum == next_file_symnum && cs->c_sclass != C_FILE)
1141 {
1142 if (get_last_source_file ())
1143 {
1144 pst->symtab = end_symtab (cur_src_end_addr, objfile,
1145 SECT_OFF_TEXT (objfile));
1146 end_stabs ();
1147 }
1148
1149 start_stabs ();
1150 start_symtab ("_globals_", (char *) NULL, (CORE_ADDR) 0);
1151 record_debugformat (debugfmt);
1152 cur_src_end_addr = first_object_file_end;
1153 /* Done with all files, everything from here on is globals. */
1154 }
1155
1156 if ((cs->c_sclass == C_EXT || cs->c_sclass == C_HIDEXT)
1157 && cs->c_naux == 1)
1158 {
1159 /* Dealing with a symbol with a csect entry. */
1160
1161 #define CSECT(PP) ((PP)->x_csect)
1162 #define CSECT_LEN(PP) (CSECT(PP).x_scnlen.l)
1163 #define CSECT_ALIGN(PP) (SMTYP_ALIGN(CSECT(PP).x_smtyp))
1164 #define CSECT_SMTYP(PP) (SMTYP_SMTYP(CSECT(PP).x_smtyp))
1165 #define CSECT_SCLAS(PP) (CSECT(PP).x_smclas)
1166
1167 /* Convert the auxent to something we can access. */
1168 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1169 0, cs->c_naux, &main_aux);
1170
1171 switch (CSECT_SMTYP (&main_aux))
1172 {
1173
1174 case XTY_ER:
1175 /* Ignore all external references. */
1176 continue;
1177
1178 case XTY_SD:
1179 /* A section description. */
1180 {
1181 switch (CSECT_SCLAS (&main_aux))
1182 {
1183
1184 case XMC_PR:
1185 {
1186
1187 /* A program csect is seen. We have to allocate one
1188 symbol table for each program csect. Normally gdb
1189 prefers one symtab for each source file. In case
1190 of AIX, one source file might include more than one
1191 [PR] csect, and they don't have to be adjacent in
1192 terms of the space they occupy in memory. Thus, one
1193 single source file might get fragmented in the
1194 memory and gdb's file start and end address
1195 approach does not work! GCC (and I think xlc) seem
1196 to put all the code in the unnamed program csect. */
1197
1198 if (last_csect_name)
1199 {
1200 complete_symtab (filestring, file_start_addr);
1201 cur_src_end_addr = file_end_addr;
1202 end_symtab (file_end_addr, objfile,
1203 SECT_OFF_TEXT (objfile));
1204 end_stabs ();
1205 start_stabs ();
1206 /* Give all csects for this source file the same
1207 name. */
1208 start_symtab (filestring, NULL, (CORE_ADDR) 0);
1209 record_debugformat (debugfmt);
1210 }
1211
1212 /* If this is the very first csect seen,
1213 basically `__start'. */
1214 if (just_started)
1215 {
1216 first_object_file_end
1217 = cs->c_value + CSECT_LEN (&main_aux);
1218 just_started = 0;
1219 }
1220
1221 file_start_addr =
1222 cs->c_value + ANOFFSET (objfile->section_offsets,
1223 SECT_OFF_TEXT (objfile));
1224 file_end_addr = file_start_addr + CSECT_LEN (&main_aux);
1225
1226 if (cs->c_name && (cs->c_name[0] == '.' || cs->c_name[0] == '@'))
1227 last_csect_name = cs->c_name;
1228 }
1229 continue;
1230
1231 /* All other symbols are put into the minimal symbol
1232 table only. */
1233
1234 case XMC_RW:
1235 continue;
1236
1237 case XMC_TC0:
1238 continue;
1239
1240 case XMC_TC:
1241 continue;
1242
1243 default:
1244 /* Ignore the symbol. */
1245 continue;
1246 }
1247 }
1248 break;
1249
1250 case XTY_LD:
1251
1252 switch (CSECT_SCLAS (&main_aux))
1253 {
1254 case XMC_PR:
1255 /* a function entry point. */
1256 function_entry_point:
1257
1258 fcn_start_addr = cs->c_value;
1259
1260 /* save the function header info, which will be used
1261 when `.bf' is seen. */
1262 fcn_cs_saved = *cs;
1263 fcn_aux_saved = main_aux;
1264 continue;
1265
1266 case XMC_GL:
1267 /* shared library function trampoline code entry point. */
1268 continue;
1269
1270 case XMC_DS:
1271 /* The symbols often have the same names as debug symbols for
1272 functions, and confuse lookup_symbol. */
1273 continue;
1274
1275 default:
1276 /* xlc puts each variable in a separate csect, so we get
1277 an XTY_SD for each variable. But gcc puts several
1278 variables in a csect, so that each variable only gets
1279 an XTY_LD. This will typically be XMC_RW; I suspect
1280 XMC_RO and XMC_BS might be possible too.
1281 These variables are put in the minimal symbol table
1282 only. */
1283 continue;
1284 }
1285 break;
1286
1287 case XTY_CM:
1288 /* Common symbols are put into the minimal symbol table only. */
1289 continue;
1290
1291 default:
1292 break;
1293 }
1294 }
1295
1296 /* If explicitly specified as a function, treat is as one. This check
1297 evaluates to true for @FIX* bigtoc CSECT symbols, so it must occur
1298 after the above CSECT check. */
1299 if (ISFCN (cs->c_type) && cs->c_sclass != C_TPDEF)
1300 {
1301 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1302 0, cs->c_naux, &main_aux);
1303 goto function_entry_point;
1304 }
1305
1306 switch (cs->c_sclass)
1307 {
1308 case C_FILE:
1309
1310 /* c_value field contains symnum of next .file entry in table
1311 or symnum of first global after last .file. */
1312
1313 next_file_symnum = cs->c_value;
1314
1315 /* Complete symbol table for last object file containing
1316 debugging information. */
1317
1318 /* Whether or not there was a csect in the previous file, we
1319 have to call `end_stabs' and `start_stabs' to reset
1320 type_vector, line_vector, etc. structures. */
1321
1322 complete_symtab (filestring, file_start_addr);
1323 cur_src_end_addr = file_end_addr;
1324 end_symtab (file_end_addr, objfile, SECT_OFF_TEXT (objfile));
1325 end_stabs ();
1326
1327 /* XCOFF, according to the AIX 3.2 documentation, puts the
1328 filename in cs->c_name. But xlc 1.3.0.2 has decided to
1329 do things the standard COFF way and put it in the auxent.
1330 We use the auxent if the symbol is ".file" and an auxent
1331 exists, otherwise use the symbol itself. Simple
1332 enough. */
1333 if (!strcmp (cs->c_name, ".file") && cs->c_naux > 0)
1334 {
1335 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1336 0, cs->c_naux, &main_aux);
1337 filestring = coff_getfilename (&main_aux, objfile);
1338 }
1339 else
1340 filestring = cs->c_name;
1341
1342 start_stabs ();
1343 start_symtab (filestring, (char *) NULL, (CORE_ADDR) 0);
1344 record_debugformat (debugfmt);
1345 last_csect_name = 0;
1346
1347 /* reset file start and end addresses. A compilation unit
1348 with no text (only data) should have zero file
1349 boundaries. */
1350 file_start_addr = file_end_addr = 0;
1351 break;
1352
1353 case C_FUN:
1354 fcn_stab_saved = *cs;
1355 break;
1356
1357 case C_FCN:
1358 if (strcmp (cs->c_name, ".bf") == 0)
1359 {
1360 CORE_ADDR off = ANOFFSET (objfile->section_offsets,
1361 SECT_OFF_TEXT (objfile));
1362
1363 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1364 0, cs->c_naux, &main_aux);
1365
1366 within_function = 1;
1367
1368 new = push_context (0, fcn_start_addr + off);
1369
1370 new->name = define_symbol
1371 (fcn_cs_saved.c_value + off,
1372 fcn_stab_saved.c_name, 0, 0, objfile);
1373 if (new->name != NULL)
1374 SYMBOL_SECTION (new->name) = SECT_OFF_TEXT (objfile);
1375 }
1376 else if (strcmp (cs->c_name, ".ef") == 0)
1377 {
1378 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1379 0, cs->c_naux, &main_aux);
1380
1381 /* The value of .ef is the address of epilogue code;
1382 not useful for gdb. */
1383 /* { main_aux.x_sym.x_misc.x_lnsz.x_lnno
1384 contains number of lines to '}' */
1385
1386 if (context_stack_depth <= 0)
1387 { /* We attempted to pop an empty context stack. */
1388 ef_complaint (cs->c_symnum);
1389 within_function = 0;
1390 break;
1391 }
1392 new = pop_context ();
1393 /* Stack must be empty now. */
1394 if (context_stack_depth > 0 || new == NULL)
1395 {
1396 ef_complaint (cs->c_symnum);
1397 within_function = 0;
1398 break;
1399 }
1400
1401 finish_block (new->name, &local_symbols, new->old_blocks,
1402 new->start_addr,
1403 (fcn_cs_saved.c_value
1404 + fcn_aux_saved.x_sym.x_misc.x_fsize
1405 + ANOFFSET (objfile->section_offsets,
1406 SECT_OFF_TEXT (objfile))),
1407 objfile);
1408 within_function = 0;
1409 }
1410 break;
1411
1412 case C_BSTAT:
1413 /* Begin static block. */
1414 {
1415 struct internal_syment symbol;
1416
1417 read_symbol (&symbol, cs->c_value);
1418 static_block_base = symbol.n_value;
1419 static_block_section =
1420 secnum_to_section (symbol.n_scnum, objfile);
1421 }
1422 break;
1423
1424 case C_ESTAT:
1425 /* End of static block. */
1426 static_block_base = 0;
1427 static_block_section = -1;
1428 break;
1429
1430 case C_ARG:
1431 case C_REGPARM:
1432 case C_REG:
1433 case C_TPDEF:
1434 case C_STRTAG:
1435 case C_UNTAG:
1436 case C_ENTAG:
1437 {
1438 complaint (&symfile_complaints,
1439 _("Unrecognized storage class %d."),
1440 cs->c_sclass);
1441 }
1442 break;
1443
1444 case C_LABEL:
1445 case C_NULL:
1446 /* Ignore these. */
1447 break;
1448
1449 case C_HIDEXT:
1450 case C_STAT:
1451 break;
1452
1453 case C_BINCL:
1454 /* beginning of include file */
1455 /* In xlc output, C_BINCL/C_EINCL pair doesn't show up in sorted
1456 order. Thus, when wee see them, we might not know enough info
1457 to process them. Thus, we'll be saving them into a table
1458 (inclTable) and postpone their processing. */
1459
1460 record_include_begin (cs);
1461 break;
1462
1463 case C_EINCL:
1464 /* End of include file. */
1465 /* See the comment after case C_BINCL. */
1466 record_include_end (cs);
1467 break;
1468
1469 case C_BLOCK:
1470 if (strcmp (cs->c_name, ".bb") == 0)
1471 {
1472 depth++;
1473 new = push_context (depth,
1474 (cs->c_value
1475 + ANOFFSET (objfile->section_offsets,
1476 SECT_OFF_TEXT (objfile))));
1477 }
1478 else if (strcmp (cs->c_name, ".eb") == 0)
1479 {
1480 if (context_stack_depth <= 0)
1481 { /* We attempted to pop an empty context stack. */
1482 eb_complaint (cs->c_symnum);
1483 break;
1484 }
1485 new = pop_context ();
1486 if (depth-- != new->depth)
1487 {
1488 eb_complaint (cs->c_symnum);
1489 break;
1490 }
1491 if (local_symbols && context_stack_depth > 0)
1492 {
1493 /* Make a block for the local symbols within. */
1494 finish_block (new->name, &local_symbols, new->old_blocks,
1495 new->start_addr,
1496 (cs->c_value
1497 + ANOFFSET (objfile->section_offsets,
1498 SECT_OFF_TEXT (objfile))),
1499 objfile);
1500 }
1501 local_symbols = new->locals;
1502 }
1503 break;
1504
1505 default:
1506 process_xcoff_symbol (cs, objfile);
1507 break;
1508 }
1509 }
1510
1511 if (get_last_source_file ())
1512 {
1513 struct symtab *s;
1514
1515 complete_symtab (filestring, file_start_addr);
1516 cur_src_end_addr = file_end_addr;
1517 s = end_symtab (file_end_addr, objfile, SECT_OFF_TEXT (objfile));
1518 /* When reading symbols for the last C_FILE of the objfile, try
1519 to make sure that we set pst->symtab to the symtab for the
1520 file, not to the _globals_ symtab. I'm not sure whether this
1521 actually works right or when/if it comes up. */
1522 if (pst->symtab == NULL)
1523 pst->symtab = s;
1524 end_stabs ();
1525 }
1526 }
1527
1528 #define SYMBOL_DUP(SYMBOL1, SYMBOL2) \
1529 (SYMBOL2) = (struct symbol *) \
1530 obstack_alloc (&objfile->objfile_obstack, sizeof (struct symbol)); \
1531 *(SYMBOL2) = *(SYMBOL1);
1532
1533
1534 #define SYMNAME_ALLOC(NAME, ALLOCED) \
1535 ((ALLOCED) ? (NAME) : obstack_copy0 (&objfile->objfile_obstack, \
1536 (NAME), strlen (NAME)))
1537
1538
1539 /* process one xcoff symbol. */
1540
1541 static struct symbol *
1542 process_xcoff_symbol (struct coff_symbol *cs, struct objfile *objfile)
1543 {
1544 struct symbol onesymbol;
1545 struct symbol *sym = &onesymbol;
1546 struct symbol *sym2 = NULL;
1547 char *name, *pp;
1548
1549 int sec;
1550 CORE_ADDR off;
1551
1552 if (cs->c_secnum < 0)
1553 {
1554 /* The value is a register number, offset within a frame, etc.,
1555 and does not get relocated. */
1556 off = 0;
1557 sec = -1;
1558 }
1559 else
1560 {
1561 sec = secnum_to_section (cs->c_secnum, objfile);
1562 off = ANOFFSET (objfile->section_offsets, sec);
1563 }
1564
1565 name = cs->c_name;
1566 if (name[0] == '.')
1567 ++name;
1568
1569 initialize_symbol (sym);
1570
1571 /* default assumptions */
1572 SYMBOL_VALUE_ADDRESS (sym) = cs->c_value + off;
1573 SYMBOL_DOMAIN (sym) = VAR_DOMAIN;
1574 SYMBOL_SECTION (sym) = secnum_to_section (cs->c_secnum, objfile);
1575
1576 if (ISFCN (cs->c_type))
1577 {
1578 /* At this point, we don't know the type of the function. This
1579 will be patched with the type from its stab entry later on in
1580 patch_block_stabs (), unless the file was compiled without -g. */
1581
1582 SYMBOL_SET_LINKAGE_NAME (sym, SYMNAME_ALLOC (name, symname_alloced));
1583 SYMBOL_TYPE (sym) = objfile_type (objfile)->nodebug_text_symbol;
1584
1585 SYMBOL_ACLASS_INDEX (sym) = LOC_BLOCK;
1586 SYMBOL_DUP (sym, sym2);
1587
1588 if (cs->c_sclass == C_EXT)
1589 add_symbol_to_list (sym2, &global_symbols);
1590 else if (cs->c_sclass == C_HIDEXT || cs->c_sclass == C_STAT)
1591 add_symbol_to_list (sym2, &file_symbols);
1592 }
1593 else
1594 {
1595 /* In case we can't figure out the type, provide default. */
1596 SYMBOL_TYPE (sym) = objfile_type (objfile)->nodebug_data_symbol;
1597
1598 switch (cs->c_sclass)
1599 {
1600 #if 0
1601 /* The values of functions and global symbols are now resolved
1602 via the global_sym_chain in stabsread.c. */
1603 case C_FUN:
1604 if (fcn_cs_saved.c_sclass == C_EXT)
1605 add_stab_to_list (name, &global_stabs);
1606 else
1607 add_stab_to_list (name, &file_stabs);
1608 break;
1609
1610 case C_GSYM:
1611 add_stab_to_list (name, &global_stabs);
1612 break;
1613 #endif
1614
1615 case C_BCOMM:
1616 common_block_start (cs->c_name, objfile);
1617 break;
1618
1619 case C_ECOMM:
1620 common_block_end (objfile);
1621 break;
1622
1623 default:
1624 complaint (&symfile_complaints, _("Unexpected storage class: %d"),
1625 cs->c_sclass);
1626 /* FALLTHROUGH */
1627
1628 case C_DECL:
1629 case C_PSYM:
1630 case C_RPSYM:
1631 case C_ECOML:
1632 case C_LSYM:
1633 case C_RSYM:
1634 case C_GSYM:
1635
1636 {
1637 sym = define_symbol (cs->c_value + off, cs->c_name, 0, 0, objfile);
1638 if (sym != NULL)
1639 {
1640 SYMBOL_SECTION (sym) = sec;
1641 }
1642 return sym;
1643 }
1644
1645 case C_STSYM:
1646
1647 /* For xlc (not GCC), the 'V' symbol descriptor is used for
1648 all statics and we need to distinguish file-scope versus
1649 function-scope using within_function. We do this by
1650 changing the string we pass to define_symbol to use 'S'
1651 where we need to, which is not necessarily super-clean,
1652 but seems workable enough. */
1653
1654 if (*name == ':')
1655 return NULL;
1656
1657 pp = strchr (name, ':');
1658 if (pp == NULL)
1659 return NULL;
1660
1661 ++pp;
1662 if (*pp == 'V' && !within_function)
1663 *pp = 'S';
1664 sym = define_symbol ((cs->c_value
1665 + ANOFFSET (objfile->section_offsets,
1666 static_block_section)),
1667 cs->c_name, 0, 0, objfile);
1668 if (sym != NULL)
1669 {
1670 SYMBOL_VALUE_ADDRESS (sym) += static_block_base;
1671 SYMBOL_SECTION (sym) = static_block_section;
1672 }
1673 return sym;
1674
1675 }
1676 }
1677 return sym2;
1678 }
1679
1680 /* Extract the file name from the aux entry of a C_FILE symbol.
1681 Result is in static storage and is only good for temporary use. */
1682
1683 static char *
1684 coff_getfilename (union internal_auxent *aux_entry, struct objfile *objfile)
1685 {
1686 static char buffer[BUFSIZ];
1687
1688 if (aux_entry->x_file.x_n.x_zeroes == 0)
1689 strcpy (buffer, (XCOFF_DATA (objfile)->strtbl
1690 + aux_entry->x_file.x_n.x_offset));
1691 else
1692 {
1693 strncpy (buffer, aux_entry->x_file.x_fname, FILNMLEN);
1694 buffer[FILNMLEN] = '\0';
1695 }
1696 return (buffer);
1697 }
1698
1699 /* Set *SYMBOL to symbol number symno in symtbl. */
1700 static void
1701 read_symbol (struct internal_syment *symbol, int symno)
1702 {
1703 struct coff_symfile_info *xcoff = XCOFF_DATA (this_symtab_objfile);
1704 int nsyms = xcoff->symtbl_num_syms;
1705 char *stbl = xcoff->symtbl;
1706
1707 if (symno < 0 || symno >= nsyms)
1708 {
1709 complaint (&symfile_complaints, _("Invalid symbol offset"));
1710 symbol->n_value = 0;
1711 symbol->n_scnum = -1;
1712 return;
1713 }
1714 bfd_coff_swap_sym_in (this_symtab_objfile->obfd,
1715 stbl + (symno * local_symesz),
1716 symbol);
1717 }
1718
1719 /* Get value corresponding to symbol number symno in symtbl. */
1720
1721 static CORE_ADDR
1722 read_symbol_nvalue (int symno)
1723 {
1724 struct internal_syment symbol[1];
1725
1726 read_symbol (symbol, symno);
1727 return symbol->n_value;
1728 }
1729
1730
1731 /* Find the address of the function corresponding to symno, where
1732 symno is the symbol pointed to by the linetable. */
1733
1734 static int
1735 read_symbol_lineno (int symno)
1736 {
1737 struct objfile *objfile = this_symtab_objfile;
1738 int xcoff64 = bfd_xcoff_is_xcoff64 (objfile->obfd);
1739
1740 struct coff_symfile_info *info = XCOFF_DATA (objfile);
1741 int nsyms = info->symtbl_num_syms;
1742 char *stbl = info->symtbl;
1743 char *strtbl = info->strtbl;
1744
1745 struct internal_syment symbol[1];
1746 union internal_auxent main_aux[1];
1747
1748 if (symno < 0)
1749 {
1750 bf_notfound_complaint ();
1751 return 0;
1752 }
1753
1754 /* Note that just searching for a short distance (e.g. 50 symbols)
1755 is not enough, at least in the following case.
1756
1757 .extern foo
1758 [many .stabx entries]
1759 [a few functions, referring to foo]
1760 .globl foo
1761 .bf
1762
1763 What happens here is that the assembler moves the .stabx entries
1764 to right before the ".bf" for foo, but the symbol for "foo" is before
1765 all the stabx entries. See PR gdb/2222. */
1766
1767 /* Maintaining a table of .bf entries might be preferable to this search.
1768 If I understand things correctly it would need to be done only for
1769 the duration of a single psymtab to symtab conversion. */
1770 while (symno < nsyms)
1771 {
1772 bfd_coff_swap_sym_in (symfile_bfd,
1773 stbl + (symno * local_symesz), symbol);
1774 if (symbol->n_sclass == C_FCN)
1775 {
1776 char *name = xcoff64 ? strtbl + symbol->n_offset : symbol->n_name;
1777
1778 if (strcmp (name, ".bf") == 0)
1779 goto gotit;
1780 }
1781 symno += symbol->n_numaux + 1;
1782 }
1783
1784 bf_notfound_complaint ();
1785 return 0;
1786
1787 gotit:
1788 /* Take aux entry and return its lineno. */
1789 symno++;
1790 bfd_coff_swap_aux_in (objfile->obfd, stbl + symno * local_symesz,
1791 symbol->n_type, symbol->n_sclass,
1792 0, symbol->n_numaux, main_aux);
1793
1794 return main_aux->x_sym.x_misc.x_lnsz.x_lnno;
1795 }
1796
1797 /* Support for line number handling. */
1798
1799 /* This function is called for every section; it finds the outer limits
1800 * of the line table (minimum and maximum file offset) so that the
1801 * mainline code can read the whole thing for efficiency.
1802 */
1803 static void
1804 find_linenos (struct bfd *abfd, struct bfd_section *asect, void *vpinfo)
1805 {
1806 struct coff_symfile_info *info;
1807 int size, count;
1808 file_ptr offset, maxoff;
1809
1810 count = asect->lineno_count;
1811
1812 if (strcmp (asect->name, ".text") != 0 || count == 0)
1813 return;
1814
1815 size = count * coff_data (abfd)->local_linesz;
1816 info = (struct coff_symfile_info *) vpinfo;
1817 offset = asect->line_filepos;
1818 maxoff = offset + size;
1819
1820 if (offset < info->min_lineno_offset || info->min_lineno_offset == 0)
1821 info->min_lineno_offset = offset;
1822
1823 if (maxoff > info->max_lineno_offset)
1824 info->max_lineno_offset = maxoff;
1825 }
1826 \f
1827 static void
1828 xcoff_psymtab_to_symtab_1 (struct objfile *objfile, struct partial_symtab *pst)
1829 {
1830 struct cleanup *old_chain;
1831 int i;
1832
1833 if (!pst)
1834 return;
1835
1836 if (pst->readin)
1837 {
1838 fprintf_unfiltered
1839 (gdb_stderr, "Psymtab for %s already read in. Shouldn't happen.\n",
1840 pst->filename);
1841 return;
1842 }
1843
1844 /* Read in all partial symtabs on which this one is dependent. */
1845 for (i = 0; i < pst->number_of_dependencies; i++)
1846 if (!pst->dependencies[i]->readin)
1847 {
1848 /* Inform about additional files that need to be read in. */
1849 if (info_verbose)
1850 {
1851 fputs_filtered (" ", gdb_stdout);
1852 wrap_here ("");
1853 fputs_filtered ("and ", gdb_stdout);
1854 wrap_here ("");
1855 printf_filtered ("%s...", pst->dependencies[i]->filename);
1856 wrap_here (""); /* Flush output */
1857 gdb_flush (gdb_stdout);
1858 }
1859 xcoff_psymtab_to_symtab_1 (objfile, pst->dependencies[i]);
1860 }
1861
1862 if (((struct symloc *) pst->read_symtab_private)->numsyms != 0)
1863 {
1864 /* Init stuff necessary for reading in symbols. */
1865 stabsread_init ();
1866 buildsym_init ();
1867 old_chain = make_cleanup (really_free_pendings, 0);
1868
1869 read_xcoff_symtab (objfile, pst);
1870
1871 do_cleanups (old_chain);
1872 }
1873
1874 pst->readin = 1;
1875 }
1876
1877 /* Read in all of the symbols for a given psymtab for real.
1878 Be verbose about it if the user wants that. SELF is not NULL. */
1879
1880 static void
1881 xcoff_read_symtab (struct partial_symtab *self, struct objfile *objfile)
1882 {
1883 if (self->readin)
1884 {
1885 fprintf_unfiltered
1886 (gdb_stderr, "Psymtab for %s already read in. Shouldn't happen.\n",
1887 self->filename);
1888 return;
1889 }
1890
1891 if (((struct symloc *) self->read_symtab_private)->numsyms != 0
1892 || self->number_of_dependencies)
1893 {
1894 /* Print the message now, before reading the string table,
1895 to avoid disconcerting pauses. */
1896 if (info_verbose)
1897 {
1898 printf_filtered ("Reading in symbols for %s...", self->filename);
1899 gdb_flush (gdb_stdout);
1900 }
1901
1902 next_symbol_text_func = xcoff_next_symbol_text;
1903
1904 xcoff_psymtab_to_symtab_1 (objfile, self);
1905
1906 /* Match with global symbols. This only needs to be done once,
1907 after all of the symtabs and dependencies have been read in. */
1908 scan_file_globals (objfile);
1909
1910 /* Finish up the debug error message. */
1911 if (info_verbose)
1912 printf_filtered ("done.\n");
1913 }
1914 }
1915 \f
1916 static void
1917 xcoff_new_init (struct objfile *objfile)
1918 {
1919 stabsread_new_init ();
1920 buildsym_new_init ();
1921 }
1922
1923 /* Do initialization in preparation for reading symbols from OBJFILE.
1924
1925 We will only be called if this is an XCOFF or XCOFF-like file.
1926 BFD handles figuring out the format of the file, and code in symfile.c
1927 uses BFD's determination to vector to us. */
1928
1929 static void
1930 xcoff_symfile_init (struct objfile *objfile)
1931 {
1932 struct coff_symfile_info *xcoff;
1933
1934 /* Allocate struct to keep track of the symfile. */
1935 xcoff = XNEW (struct coff_symfile_info);
1936 set_objfile_data (objfile, xcoff_objfile_data_key, xcoff);
1937
1938 /* XCOFF objects may be reordered, so set OBJF_REORDERED. If we
1939 find this causes a significant slowdown in gdb then we could
1940 set it in the debug symbol readers only when necessary. */
1941 objfile->flags |= OBJF_REORDERED;
1942 }
1943
1944 /* Perform any local cleanups required when we are done with a particular
1945 objfile. I.E, we are in the process of discarding all symbol information
1946 for an objfile, freeing up all memory held for it, and unlinking the
1947 objfile struct from the global list of known objfiles. */
1948
1949 static void
1950 xcoff_symfile_finish (struct objfile *objfile)
1951 {
1952 /* Start with a fresh include table for the next objfile. */
1953 if (inclTable)
1954 {
1955 xfree (inclTable);
1956 inclTable = NULL;
1957 }
1958 inclIndx = inclLength = inclDepth = 0;
1959
1960 dwarf2_free_objfile (objfile);
1961 }
1962
1963
1964 static void
1965 init_stringtab (bfd *abfd, file_ptr offset, struct objfile *objfile)
1966 {
1967 long length;
1968 int val;
1969 unsigned char lengthbuf[4];
1970 char *strtbl;
1971 struct coff_symfile_info *xcoff = XCOFF_DATA (objfile);
1972
1973 xcoff->strtbl = NULL;
1974
1975 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
1976 error (_("cannot seek to string table in %s: %s"),
1977 bfd_get_filename (abfd), bfd_errmsg (bfd_get_error ()));
1978
1979 val = bfd_bread ((char *) lengthbuf, sizeof lengthbuf, abfd);
1980 length = bfd_h_get_32 (abfd, lengthbuf);
1981
1982 /* If no string table is needed, then the file may end immediately
1983 after the symbols. Just return with `strtbl' set to NULL. */
1984
1985 if (val != sizeof lengthbuf || length < sizeof lengthbuf)
1986 return;
1987
1988 /* Allocate string table from objfile_obstack. We will need this table
1989 as long as we have its symbol table around. */
1990
1991 strtbl = (char *) obstack_alloc (&objfile->objfile_obstack, length);
1992 xcoff->strtbl = strtbl;
1993
1994 /* Copy length buffer, the first byte is usually zero and is
1995 used for stabs with a name length of zero. */
1996 memcpy (strtbl, lengthbuf, sizeof lengthbuf);
1997 if (length == sizeof lengthbuf)
1998 return;
1999
2000 val = bfd_bread (strtbl + sizeof lengthbuf, length - sizeof lengthbuf, abfd);
2001
2002 if (val != length - sizeof lengthbuf)
2003 error (_("cannot read string table from %s: %s"),
2004 bfd_get_filename (abfd), bfd_errmsg (bfd_get_error ()));
2005 if (strtbl[length - 1] != '\0')
2006 error (_("bad symbol file: string table "
2007 "does not end with null character"));
2008
2009 return;
2010 }
2011 \f
2012 /* If we have not yet seen a function for this psymtab, this is 0. If we
2013 have seen one, it is the offset in the line numbers of the line numbers
2014 for the psymtab. */
2015 static unsigned int first_fun_line_offset;
2016
2017 /* Allocate and partially fill a partial symtab. It will be
2018 completely filled at the end of the symbol list.
2019
2020 SYMFILE_NAME is the name of the symbol-file we are reading from, and ADDR
2021 is the address relative to which its symbols are (incremental) or 0
2022 (normal). */
2023
2024 static struct partial_symtab *
2025 xcoff_start_psymtab (struct objfile *objfile,
2026 const char *filename, int first_symnum,
2027 struct partial_symbol **global_syms,
2028 struct partial_symbol **static_syms)
2029 {
2030 struct partial_symtab *result =
2031 start_psymtab_common (objfile, objfile->section_offsets,
2032 filename,
2033 /* We fill in textlow later. */
2034 0,
2035 global_syms, static_syms);
2036
2037 result->read_symtab_private = obstack_alloc (&objfile->objfile_obstack,
2038 sizeof (struct symloc));
2039 ((struct symloc *) result->read_symtab_private)->first_symnum = first_symnum;
2040 result->read_symtab = xcoff_read_symtab;
2041
2042 /* Deduce the source language from the filename for this psymtab. */
2043 psymtab_language = deduce_language_from_filename (filename);
2044
2045 return result;
2046 }
2047
2048 /* Close off the current usage of PST.
2049 Returns PST, or NULL if the partial symtab was empty and thrown away.
2050
2051 CAPPING_SYMBOL_NUMBER is the end of pst (exclusive).
2052
2053 INCLUDE_LIST, NUM_INCLUDES, DEPENDENCY_LIST, and NUMBER_DEPENDENCIES
2054 are the information for includes and dependencies. */
2055
2056 static struct partial_symtab *
2057 xcoff_end_psymtab (struct objfile *objfile, struct partial_symtab *pst,
2058 const char **include_list, int num_includes,
2059 int capping_symbol_number,
2060 struct partial_symtab **dependency_list,
2061 int number_dependencies, int textlow_not_set)
2062 {
2063 int i;
2064
2065 if (capping_symbol_number != -1)
2066 ((struct symloc *) pst->read_symtab_private)->numsyms =
2067 capping_symbol_number
2068 - ((struct symloc *) pst->read_symtab_private)->first_symnum;
2069 ((struct symloc *) pst->read_symtab_private)->lineno_off =
2070 first_fun_line_offset;
2071 first_fun_line_offset = 0;
2072 pst->n_global_syms = objfile->global_psymbols.next
2073 - (objfile->global_psymbols.list + pst->globals_offset);
2074 pst->n_static_syms = objfile->static_psymbols.next
2075 - (objfile->static_psymbols.list + pst->statics_offset);
2076
2077 pst->number_of_dependencies = number_dependencies;
2078 if (number_dependencies)
2079 {
2080 pst->dependencies = (struct partial_symtab **)
2081 obstack_alloc (&objfile->objfile_obstack,
2082 number_dependencies * sizeof (struct partial_symtab *));
2083 memcpy (pst->dependencies, dependency_list,
2084 number_dependencies * sizeof (struct partial_symtab *));
2085 }
2086 else
2087 pst->dependencies = 0;
2088
2089 for (i = 0; i < num_includes; i++)
2090 {
2091 struct partial_symtab *subpst =
2092 allocate_psymtab (include_list[i], objfile);
2093
2094 subpst->section_offsets = pst->section_offsets;
2095 subpst->read_symtab_private = obstack_alloc (&objfile->objfile_obstack,
2096 sizeof (struct symloc));
2097 ((struct symloc *) subpst->read_symtab_private)->first_symnum = 0;
2098 ((struct symloc *) subpst->read_symtab_private)->numsyms = 0;
2099 subpst->textlow = 0;
2100 subpst->texthigh = 0;
2101
2102 /* We could save slight bits of space by only making one of these,
2103 shared by the entire set of include files. FIXME-someday. */
2104 subpst->dependencies = (struct partial_symtab **)
2105 obstack_alloc (&objfile->objfile_obstack,
2106 sizeof (struct partial_symtab *));
2107 subpst->dependencies[0] = pst;
2108 subpst->number_of_dependencies = 1;
2109
2110 subpst->globals_offset =
2111 subpst->n_global_syms =
2112 subpst->statics_offset =
2113 subpst->n_static_syms = 0;
2114
2115 subpst->readin = 0;
2116 subpst->symtab = 0;
2117 subpst->read_symtab = pst->read_symtab;
2118 }
2119
2120 sort_pst_symbols (objfile, pst);
2121
2122 if (num_includes == 0
2123 && number_dependencies == 0
2124 && pst->n_global_syms == 0
2125 && pst->n_static_syms == 0)
2126 {
2127 /* Throw away this psymtab, it's empty. We can't deallocate it, since
2128 it is on the obstack, but we can forget to chain it on the list. */
2129 /* Empty psymtabs happen as a result of header files which don't have
2130 any symbols in them. There can be a lot of them. */
2131
2132 discard_psymtab (objfile, pst);
2133
2134 /* Indicate that psymtab was thrown away. */
2135 pst = (struct partial_symtab *) NULL;
2136 }
2137 return pst;
2138 }
2139
2140 /* Swap raw symbol at *RAW and put the name in *NAME, the symbol in
2141 *SYMBOL, the first auxent in *AUX. Advance *RAW and *SYMNUMP over
2142 the symbol and its auxents. */
2143
2144 static void
2145 swap_sym (struct internal_syment *symbol, union internal_auxent *aux,
2146 const char **name, char **raw, unsigned int *symnump,
2147 struct objfile *objfile)
2148 {
2149 bfd_coff_swap_sym_in (objfile->obfd, *raw, symbol);
2150 if (symbol->n_zeroes)
2151 {
2152 /* If it's exactly E_SYMNMLEN characters long it isn't
2153 '\0'-terminated. */
2154 if (symbol->n_name[E_SYMNMLEN - 1] != '\0')
2155 {
2156 /* FIXME: wastes memory for symbols which we don't end up putting
2157 into the minimal symbols. */
2158 char *p;
2159
2160 p = obstack_alloc (&objfile->objfile_obstack, E_SYMNMLEN + 1);
2161 strncpy (p, symbol->n_name, E_SYMNMLEN);
2162 p[E_SYMNMLEN] = '\0';
2163 *name = p;
2164 }
2165 else
2166 /* Point to the unswapped name as that persists as long as the
2167 objfile does. */
2168 *name = ((struct external_syment *) *raw)->e.e_name;
2169 }
2170 else if (symbol->n_sclass & 0x80)
2171 {
2172 *name = XCOFF_DATA (objfile)->debugsec + symbol->n_offset;
2173 }
2174 else
2175 {
2176 *name = XCOFF_DATA (objfile)->strtbl + symbol->n_offset;
2177 }
2178 ++*symnump;
2179 *raw += coff_data (objfile->obfd)->local_symesz;
2180 if (symbol->n_numaux > 0)
2181 {
2182 bfd_coff_swap_aux_in (objfile->obfd, *raw, symbol->n_type,
2183 symbol->n_sclass, 0, symbol->n_numaux, aux);
2184
2185 *symnump += symbol->n_numaux;
2186 *raw += coff_data (objfile->obfd)->local_symesz * symbol->n_numaux;
2187 }
2188 }
2189
2190 static void
2191 function_outside_compilation_unit_complaint (const char *arg1)
2192 {
2193 complaint (&symfile_complaints,
2194 _("function `%s' appears to be defined "
2195 "outside of all compilation units"),
2196 arg1);
2197 }
2198
2199 static void
2200 scan_xcoff_symtab (struct objfile *objfile)
2201 {
2202 struct gdbarch *gdbarch = get_objfile_arch (objfile);
2203 CORE_ADDR toc_offset = 0; /* toc offset value in data section. */
2204 const char *filestring = NULL;
2205
2206 const char *namestring;
2207 int past_first_source_file = 0;
2208 bfd *abfd;
2209 asection *bfd_sect;
2210 unsigned int nsyms;
2211
2212 /* Current partial symtab */
2213 struct partial_symtab *pst;
2214
2215 /* List of current psymtab's include files. */
2216 const char **psymtab_include_list;
2217 int includes_allocated;
2218 int includes_used;
2219
2220 /* Index within current psymtab dependency list. */
2221 struct partial_symtab **dependency_list;
2222 int dependencies_used, dependencies_allocated;
2223
2224 char *sraw_symbol;
2225 struct internal_syment symbol;
2226 union internal_auxent main_aux[5];
2227 unsigned int ssymnum;
2228
2229 const char *last_csect_name = NULL; /* Last seen csect's name and value. */
2230 CORE_ADDR last_csect_val = 0;
2231 int last_csect_sec = 0;
2232 int misc_func_recorded = 0; /* true if any misc. function. */
2233 int textlow_not_set = 1;
2234
2235 pst = (struct partial_symtab *) 0;
2236
2237 includes_allocated = 30;
2238 includes_used = 0;
2239 psymtab_include_list = (const char **) alloca (includes_allocated *
2240 sizeof (const char *));
2241
2242 dependencies_allocated = 30;
2243 dependencies_used = 0;
2244 dependency_list =
2245 (struct partial_symtab **) alloca (dependencies_allocated *
2246 sizeof (struct partial_symtab *));
2247
2248 set_last_source_file (NULL);
2249
2250 abfd = objfile->obfd;
2251 next_symbol_text_func = xcoff_next_symbol_text;
2252
2253 sraw_symbol = XCOFF_DATA (objfile)->symtbl;
2254 nsyms = XCOFF_DATA (objfile)->symtbl_num_syms;
2255 ssymnum = 0;
2256 while (ssymnum < nsyms)
2257 {
2258 int sclass;
2259
2260 QUIT;
2261
2262 bfd_coff_swap_sym_in (abfd, sraw_symbol, &symbol);
2263 sclass = symbol.n_sclass;
2264
2265 switch (sclass)
2266 {
2267 case C_EXT:
2268 case C_HIDEXT:
2269 {
2270 /* The CSECT auxent--always the last auxent. */
2271 union internal_auxent csect_aux;
2272 unsigned int symnum_before = ssymnum;
2273
2274 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
2275 &ssymnum, objfile);
2276 if (symbol.n_numaux > 1)
2277 {
2278 bfd_coff_swap_aux_in
2279 (objfile->obfd,
2280 sraw_symbol - coff_data (abfd)->local_symesz,
2281 symbol.n_type,
2282 symbol.n_sclass,
2283 symbol.n_numaux - 1,
2284 symbol.n_numaux,
2285 &csect_aux);
2286 }
2287 else
2288 csect_aux = main_aux[0];
2289
2290 /* If symbol name starts with ".$" or "$", ignore it. */
2291 if (namestring[0] == '$'
2292 || (namestring[0] == '.' && namestring[1] == '$'))
2293 break;
2294
2295 switch (csect_aux.x_csect.x_smtyp & 0x7)
2296 {
2297 case XTY_SD:
2298 switch (csect_aux.x_csect.x_smclas)
2299 {
2300 case XMC_PR:
2301 if (last_csect_name)
2302 {
2303 /* If no misc. function recorded in the last
2304 seen csect, enter it as a function. This
2305 will take care of functions like strcmp()
2306 compiled by xlc. */
2307
2308 if (!misc_func_recorded)
2309 {
2310 record_minimal_symbol
2311 (last_csect_name, last_csect_val,
2312 mst_text, last_csect_sec, objfile);
2313 misc_func_recorded = 1;
2314 }
2315
2316 if (pst != NULL)
2317 {
2318 /* We have to allocate one psymtab for
2319 each program csect, because their text
2320 sections need not be adjacent. */
2321 xcoff_end_psymtab
2322 (objfile, pst, psymtab_include_list,
2323 includes_used, symnum_before, dependency_list,
2324 dependencies_used, textlow_not_set);
2325 includes_used = 0;
2326 dependencies_used = 0;
2327 /* Give all psymtabs for this source file the same
2328 name. */
2329 pst = xcoff_start_psymtab
2330 (objfile,
2331 filestring,
2332 symnum_before,
2333 objfile->global_psymbols.next,
2334 objfile->static_psymbols.next);
2335 }
2336 }
2337 /* Activate the misc_func_recorded mechanism for
2338 compiler- and linker-generated CSECTs like ".strcmp"
2339 and "@FIX1". */
2340 if (namestring && (namestring[0] == '.'
2341 || namestring[0] == '@'))
2342 {
2343 last_csect_name = namestring;
2344 last_csect_val = symbol.n_value;
2345 last_csect_sec = symbol.n_scnum;
2346 }
2347 if (pst != NULL)
2348 {
2349 CORE_ADDR highval =
2350 symbol.n_value + csect_aux.x_csect.x_scnlen.l;
2351
2352 if (highval > pst->texthigh)
2353 pst->texthigh = highval;
2354 if (pst->textlow == 0 || symbol.n_value < pst->textlow)
2355 pst->textlow = symbol.n_value;
2356 }
2357 misc_func_recorded = 0;
2358 break;
2359
2360 case XMC_RW:
2361 case XMC_TD:
2362 /* Data variables are recorded in the minimal symbol
2363 table, except for section symbols. */
2364 if (*namestring != '.')
2365 record_minimal_symbol
2366 (namestring, symbol.n_value,
2367 sclass == C_HIDEXT ? mst_file_data : mst_data,
2368 symbol.n_scnum, objfile);
2369 break;
2370
2371 case XMC_TC0:
2372 if (toc_offset)
2373 warning (_("More than one XMC_TC0 symbol found."));
2374 toc_offset = symbol.n_value;
2375
2376 /* Make TOC offset relative to start address of
2377 section. */
2378 bfd_sect = secnum_to_bfd_section (symbol.n_scnum, objfile);
2379 if (bfd_sect)
2380 toc_offset -= bfd_section_vma (objfile->obfd, bfd_sect);
2381 break;
2382
2383 case XMC_TC:
2384 /* These symbols tell us where the TOC entry for a
2385 variable is, not the variable itself. */
2386 break;
2387
2388 default:
2389 break;
2390 }
2391 break;
2392
2393 case XTY_LD:
2394 switch (csect_aux.x_csect.x_smclas)
2395 {
2396 case XMC_PR:
2397 /* A function entry point. */
2398
2399 if (first_fun_line_offset == 0 && symbol.n_numaux > 1)
2400 first_fun_line_offset =
2401 main_aux[0].x_sym.x_fcnary.x_fcn.x_lnnoptr;
2402 {
2403 record_minimal_symbol
2404 (namestring, symbol.n_value,
2405 sclass == C_HIDEXT ? mst_file_text : mst_text,
2406 symbol.n_scnum, objfile);
2407 misc_func_recorded = 1;
2408 }
2409 break;
2410
2411 case XMC_GL:
2412 /* shared library function trampoline code entry
2413 point. */
2414
2415 /* record trampoline code entries as
2416 mst_solib_trampoline symbol. When we lookup mst
2417 symbols, we will choose mst_text over
2418 mst_solib_trampoline. */
2419 record_minimal_symbol
2420 (namestring, symbol.n_value,
2421 mst_solib_trampoline, symbol.n_scnum, objfile);
2422 misc_func_recorded = 1;
2423 break;
2424
2425 case XMC_DS:
2426 /* The symbols often have the same names as
2427 debug symbols for functions, and confuse
2428 lookup_symbol. */
2429 break;
2430
2431 default:
2432
2433 /* xlc puts each variable in a separate csect,
2434 so we get an XTY_SD for each variable. But
2435 gcc puts several variables in a csect, so
2436 that each variable only gets an XTY_LD. We
2437 still need to record them. This will
2438 typically be XMC_RW; I suspect XMC_RO and
2439 XMC_BS might be possible too. */
2440 if (*namestring != '.')
2441 record_minimal_symbol
2442 (namestring, symbol.n_value,
2443 sclass == C_HIDEXT ? mst_file_data : mst_data,
2444 symbol.n_scnum, objfile);
2445 break;
2446 }
2447 break;
2448
2449 case XTY_CM:
2450 switch (csect_aux.x_csect.x_smclas)
2451 {
2452 case XMC_RW:
2453 case XMC_BS:
2454 /* Common variables are recorded in the minimal symbol
2455 table, except for section symbols. */
2456 if (*namestring != '.')
2457 record_minimal_symbol
2458 (namestring, symbol.n_value,
2459 sclass == C_HIDEXT ? mst_file_bss : mst_bss,
2460 symbol.n_scnum, objfile);
2461 break;
2462 }
2463 break;
2464
2465 default:
2466 break;
2467 }
2468 }
2469 break;
2470 case C_FILE:
2471 {
2472 unsigned int symnum_before;
2473
2474 symnum_before = ssymnum;
2475 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
2476 &ssymnum, objfile);
2477
2478 /* See if the last csect needs to be recorded. */
2479
2480 if (last_csect_name && !misc_func_recorded)
2481 {
2482 /* If no misc. function recorded in the last seen csect, enter
2483 it as a function. This will take care of functions like
2484 strcmp() compiled by xlc. */
2485
2486 record_minimal_symbol (last_csect_name, last_csect_val,
2487 mst_text, last_csect_sec, objfile);
2488 misc_func_recorded = 1;
2489 }
2490
2491 if (pst)
2492 {
2493 xcoff_end_psymtab (objfile, pst, psymtab_include_list,
2494 includes_used, symnum_before,
2495 dependency_list, dependencies_used,
2496 textlow_not_set);
2497 includes_used = 0;
2498 dependencies_used = 0;
2499 }
2500 first_fun_line_offset = 0;
2501
2502 /* XCOFF, according to the AIX 3.2 documentation, puts the
2503 filename in cs->c_name. But xlc 1.3.0.2 has decided to
2504 do things the standard COFF way and put it in the auxent.
2505 We use the auxent if the symbol is ".file" and an auxent
2506 exists, otherwise use the symbol itself. */
2507 if (!strcmp (namestring, ".file") && symbol.n_numaux > 0)
2508 {
2509 filestring = coff_getfilename (&main_aux[0], objfile);
2510 }
2511 else
2512 filestring = namestring;
2513
2514 pst = xcoff_start_psymtab (objfile,
2515 filestring,
2516 symnum_before,
2517 objfile->global_psymbols.next,
2518 objfile->static_psymbols.next);
2519 last_csect_name = NULL;
2520 }
2521 break;
2522
2523 default:
2524 {
2525 complaint (&symfile_complaints,
2526 _("Storage class %d not recognized during scan"),
2527 sclass);
2528 }
2529 /* FALLTHROUGH */
2530
2531 /* C_FCN is .bf and .ef symbols. I think it is sufficient
2532 to handle only the C_FUN and C_EXT. */
2533 case C_FCN:
2534
2535 case C_BSTAT:
2536 case C_ESTAT:
2537 case C_ARG:
2538 case C_REGPARM:
2539 case C_REG:
2540 case C_TPDEF:
2541 case C_STRTAG:
2542 case C_UNTAG:
2543 case C_ENTAG:
2544 case C_LABEL:
2545 case C_NULL:
2546
2547 /* C_EINCL means we are switching back to the main file. But there
2548 is no reason to care; the only thing we want to know about
2549 includes is the names of all the included (.h) files. */
2550 case C_EINCL:
2551
2552 case C_BLOCK:
2553
2554 /* I don't think C_STAT is used in xcoff; C_HIDEXT appears to be
2555 used instead. */
2556 case C_STAT:
2557
2558 /* I don't think the name of the common block (as opposed to the
2559 variables within it) is something which is user visible
2560 currently. */
2561 case C_BCOMM:
2562 case C_ECOMM:
2563
2564 case C_PSYM:
2565 case C_RPSYM:
2566
2567 /* I think we can ignore C_LSYM; types on xcoff seem to use C_DECL
2568 so C_LSYM would appear to be only for locals. */
2569 case C_LSYM:
2570
2571 case C_AUTO:
2572 case C_RSYM:
2573 {
2574 /* We probably could save a few instructions by assuming that
2575 C_LSYM, C_PSYM, etc., never have auxents. */
2576 int naux1 = symbol.n_numaux + 1;
2577
2578 ssymnum += naux1;
2579 sraw_symbol += bfd_coff_symesz (abfd) * naux1;
2580 }
2581 break;
2582
2583 case C_BINCL:
2584 {
2585 /* Mark down an include file in the current psymtab. */
2586 enum language tmp_language;
2587
2588 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
2589 &ssymnum, objfile);
2590
2591 tmp_language = deduce_language_from_filename (namestring);
2592
2593 /* Only change the psymtab's language if we've learned
2594 something useful (eg. tmp_language is not language_unknown).
2595 In addition, to match what start_subfile does, never change
2596 from C++ to C. */
2597 if (tmp_language != language_unknown
2598 && (tmp_language != language_c
2599 || psymtab_language != language_cplus))
2600 psymtab_language = tmp_language;
2601
2602 /* In C++, one may expect the same filename to come round many
2603 times, when code is coming alternately from the main file
2604 and from inline functions in other files. So I check to see
2605 if this is a file we've seen before -- either the main
2606 source file, or a previously included file.
2607
2608 This seems to be a lot of time to be spending on N_SOL, but
2609 things like "break c-exp.y:435" need to work (I
2610 suppose the psymtab_include_list could be hashed or put
2611 in a binary tree, if profiling shows this is a major hog). */
2612 if (pst && strcmp (namestring, pst->filename) == 0)
2613 continue;
2614
2615 {
2616 int i;
2617
2618 for (i = 0; i < includes_used; i++)
2619 if (strcmp (namestring, psymtab_include_list[i]) == 0)
2620 {
2621 i = -1;
2622 break;
2623 }
2624 if (i == -1)
2625 continue;
2626 }
2627 psymtab_include_list[includes_used++] = namestring;
2628 if (includes_used >= includes_allocated)
2629 {
2630 const char **orig = psymtab_include_list;
2631
2632 psymtab_include_list = (const char **)
2633 alloca ((includes_allocated *= 2) *
2634 sizeof (const char *));
2635 memcpy (psymtab_include_list, orig,
2636 includes_used * sizeof (const char *));
2637 }
2638 continue;
2639 }
2640 case C_FUN:
2641 /* The value of the C_FUN is not the address of the function (it
2642 appears to be the address before linking), but as long as it
2643 is smaller than the actual address, then find_pc_partial_function
2644 will use the minimal symbols instead. I hope. */
2645
2646 case C_GSYM:
2647 case C_ECOML:
2648 case C_DECL:
2649 case C_STSYM:
2650 {
2651 char *p;
2652
2653 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
2654 &ssymnum, objfile);
2655
2656 p = strchr (namestring, ':');
2657 if (!p)
2658 continue; /* Not a debugging symbol. */
2659
2660 /* Main processing section for debugging symbols which
2661 the initial read through the symbol tables needs to worry
2662 about. If we reach this point, the symbol which we are
2663 considering is definitely one we are interested in.
2664 p must also contain the (valid) index into the namestring
2665 which indicates the debugging type symbol. */
2666
2667 switch (p[1])
2668 {
2669 case 'S':
2670 symbol.n_value += ANOFFSET (objfile->section_offsets,
2671 SECT_OFF_DATA (objfile));
2672
2673 if (gdbarch_static_transform_name_p (gdbarch))
2674 namestring = gdbarch_static_transform_name
2675 (gdbarch, namestring);
2676
2677 add_psymbol_to_list (namestring, p - namestring, 1,
2678 VAR_DOMAIN, LOC_STATIC,
2679 &objfile->static_psymbols,
2680 0, symbol.n_value,
2681 psymtab_language, objfile);
2682 continue;
2683
2684 case 'G':
2685 symbol.n_value += ANOFFSET (objfile->section_offsets,
2686 SECT_OFF_DATA (objfile));
2687 /* The addresses in these entries are reported to be
2688 wrong. See the code that reads 'G's for symtabs. */
2689 add_psymbol_to_list (namestring, p - namestring, 1,
2690 VAR_DOMAIN, LOC_STATIC,
2691 &objfile->global_psymbols,
2692 0, symbol.n_value,
2693 psymtab_language, objfile);
2694 continue;
2695
2696 case 'T':
2697 /* When a 'T' entry is defining an anonymous enum, it
2698 may have a name which is the empty string, or a
2699 single space. Since they're not really defining a
2700 symbol, those shouldn't go in the partial symbol
2701 table. We do pick up the elements of such enums at
2702 'check_enum:', below. */
2703 if (p >= namestring + 2
2704 || (p == namestring + 1
2705 && namestring[0] != ' '))
2706 {
2707 add_psymbol_to_list (namestring, p - namestring, 1,
2708 STRUCT_DOMAIN, LOC_TYPEDEF,
2709 &objfile->static_psymbols,
2710 symbol.n_value, 0,
2711 psymtab_language, objfile);
2712 if (p[2] == 't')
2713 {
2714 /* Also a typedef with the same name. */
2715 add_psymbol_to_list (namestring, p - namestring, 1,
2716 VAR_DOMAIN, LOC_TYPEDEF,
2717 &objfile->static_psymbols,
2718 symbol.n_value, 0,
2719 psymtab_language, objfile);
2720 p += 1;
2721 }
2722 }
2723 goto check_enum;
2724
2725 case 't':
2726 if (p != namestring) /* a name is there, not just :T... */
2727 {
2728 add_psymbol_to_list (namestring, p - namestring, 1,
2729 VAR_DOMAIN, LOC_TYPEDEF,
2730 &objfile->static_psymbols,
2731 symbol.n_value, 0,
2732 psymtab_language, objfile);
2733 }
2734 check_enum:
2735 /* If this is an enumerated type, we need to
2736 add all the enum constants to the partial symbol
2737 table. This does not cover enums without names, e.g.
2738 "enum {a, b} c;" in C, but fortunately those are
2739 rare. There is no way for GDB to find those from the
2740 enum type without spending too much time on it. Thus
2741 to solve this problem, the compiler needs to put out the
2742 enum in a nameless type. GCC2 does this. */
2743
2744 /* We are looking for something of the form
2745 <name> ":" ("t" | "T") [<number> "="] "e"
2746 {<constant> ":" <value> ","} ";". */
2747
2748 /* Skip over the colon and the 't' or 'T'. */
2749 p += 2;
2750 /* This type may be given a number. Also, numbers can come
2751 in pairs like (0,26). Skip over it. */
2752 while ((*p >= '0' && *p <= '9')
2753 || *p == '(' || *p == ',' || *p == ')'
2754 || *p == '=')
2755 p++;
2756
2757 if (*p++ == 'e')
2758 {
2759 /* The aix4 compiler emits extra crud before the
2760 members. */
2761 if (*p == '-')
2762 {
2763 /* Skip over the type (?). */
2764 while (*p != ':')
2765 p++;
2766
2767 /* Skip over the colon. */
2768 p++;
2769 }
2770
2771 /* We have found an enumerated type. */
2772 /* According to comments in read_enum_type
2773 a comma could end it instead of a semicolon.
2774 I don't know where that happens.
2775 Accept either. */
2776 while (*p && *p != ';' && *p != ',')
2777 {
2778 char *q;
2779
2780 /* Check for and handle cretinous dbx symbol name
2781 continuation! */
2782 if (*p == '\\' || (*p == '?' && p[1] == '\0'))
2783 p = next_symbol_text (objfile);
2784
2785 /* Point to the character after the name
2786 of the enum constant. */
2787 for (q = p; *q && *q != ':'; q++)
2788 ;
2789 /* Note that the value doesn't matter for
2790 enum constants in psymtabs, just in symtabs. */
2791 add_psymbol_to_list (p, q - p, 1,
2792 VAR_DOMAIN, LOC_CONST,
2793 &objfile->static_psymbols, 0,
2794 0, psymtab_language, objfile);
2795 /* Point past the name. */
2796 p = q;
2797 /* Skip over the value. */
2798 while (*p && *p != ',')
2799 p++;
2800 /* Advance past the comma. */
2801 if (*p)
2802 p++;
2803 }
2804 }
2805 continue;
2806
2807 case 'c':
2808 /* Constant, e.g. from "const" in Pascal. */
2809 add_psymbol_to_list (namestring, p - namestring, 1,
2810 VAR_DOMAIN, LOC_CONST,
2811 &objfile->static_psymbols, symbol.n_value,
2812 0, psymtab_language, objfile);
2813 continue;
2814
2815 case 'f':
2816 if (! pst)
2817 {
2818 int name_len = p - namestring;
2819 char *name = xmalloc (name_len + 1);
2820
2821 memcpy (name, namestring, name_len);
2822 name[name_len] = '\0';
2823 function_outside_compilation_unit_complaint (name);
2824 xfree (name);
2825 }
2826 symbol.n_value += ANOFFSET (objfile->section_offsets,
2827 SECT_OFF_TEXT (objfile));
2828 add_psymbol_to_list (namestring, p - namestring, 1,
2829 VAR_DOMAIN, LOC_BLOCK,
2830 &objfile->static_psymbols,
2831 0, symbol.n_value,
2832 psymtab_language, objfile);
2833 continue;
2834
2835 /* Global functions were ignored here, but now they
2836 are put into the global psymtab like one would expect.
2837 They're also in the minimal symbol table. */
2838 case 'F':
2839 if (! pst)
2840 {
2841 int name_len = p - namestring;
2842 char *name = xmalloc (name_len + 1);
2843
2844 memcpy (name, namestring, name_len);
2845 name[name_len] = '\0';
2846 function_outside_compilation_unit_complaint (name);
2847 xfree (name);
2848 }
2849
2850 /* We need only the minimal symbols for these
2851 loader-generated definitions. Keeping the global
2852 symbols leads to "in psymbols but not in symbols"
2853 errors. */
2854 if (strncmp (namestring, "@FIX", 4) == 0)
2855 continue;
2856
2857 symbol.n_value += ANOFFSET (objfile->section_offsets,
2858 SECT_OFF_TEXT (objfile));
2859 add_psymbol_to_list (namestring, p - namestring, 1,
2860 VAR_DOMAIN, LOC_BLOCK,
2861 &objfile->global_psymbols,
2862 0, symbol.n_value,
2863 psymtab_language, objfile);
2864 continue;
2865
2866 /* Two things show up here (hopefully); static symbols of
2867 local scope (static used inside braces) or extensions
2868 of structure symbols. We can ignore both. */
2869 case 'V':
2870 case '(':
2871 case '0':
2872 case '1':
2873 case '2':
2874 case '3':
2875 case '4':
2876 case '5':
2877 case '6':
2878 case '7':
2879 case '8':
2880 case '9':
2881 case '-':
2882 case '#': /* For symbol identification (used in
2883 live ranges). */
2884 continue;
2885
2886 case ':':
2887 /* It is a C++ nested symbol. We don't need to record it
2888 (I don't think); if we try to look up foo::bar::baz,
2889 then symbols for the symtab containing foo should get
2890 read in, I think. */
2891 /* Someone says sun cc puts out symbols like
2892 /foo/baz/maclib::/usr/local/bin/maclib,
2893 which would get here with a symbol type of ':'. */
2894 continue;
2895
2896 default:
2897 /* Unexpected symbol descriptor. The second and
2898 subsequent stabs of a continued stab can show up
2899 here. The question is whether they ever can mimic
2900 a normal stab--it would be nice if not, since we
2901 certainly don't want to spend the time searching to
2902 the end of every string looking for a
2903 backslash. */
2904
2905 complaint (&symfile_complaints,
2906 _("unknown symbol descriptor `%c'"), p[1]);
2907
2908 /* Ignore it; perhaps it is an extension that we don't
2909 know about. */
2910 continue;
2911 }
2912 }
2913 }
2914 }
2915
2916 if (pst)
2917 {
2918 xcoff_end_psymtab (objfile, pst, psymtab_include_list, includes_used,
2919 ssymnum, dependency_list,
2920 dependencies_used, textlow_not_set);
2921 }
2922
2923 /* Record the toc offset value of this symbol table into objfile
2924 structure. If no XMC_TC0 is found, toc_offset should be zero.
2925 Another place to obtain this information would be file auxiliary
2926 header. */
2927
2928 XCOFF_DATA (objfile)->toc_offset = toc_offset;
2929 }
2930
2931 /* Return the toc offset value for a given objfile. */
2932
2933 CORE_ADDR
2934 xcoff_get_toc_offset (struct objfile *objfile)
2935 {
2936 if (objfile)
2937 return XCOFF_DATA (objfile)->toc_offset;
2938 return 0;
2939 }
2940
2941 /* Scan and build partial symbols for a symbol file.
2942 We have been initialized by a call to dbx_symfile_init, which
2943 put all the relevant info into a "struct dbx_symfile_info",
2944 hung off the objfile structure.
2945
2946 SECTION_OFFSETS contains offsets relative to which the symbols in the
2947 various sections are (depending where the sections were actually
2948 loaded). */
2949
2950 static void
2951 xcoff_initial_scan (struct objfile *objfile, int symfile_flags)
2952 {
2953 bfd *abfd;
2954 int val;
2955 struct cleanup *back_to;
2956 int num_symbols; /* # of symbols */
2957 file_ptr symtab_offset; /* symbol table and */
2958 file_ptr stringtab_offset; /* string table file offsets */
2959 struct coff_symfile_info *info;
2960 const char *name;
2961 unsigned int size;
2962
2963 info = XCOFF_DATA (objfile);
2964 symfile_bfd = abfd = objfile->obfd;
2965 name = objfile_name (objfile);
2966
2967 num_symbols = bfd_get_symcount (abfd); /* # of symbols */
2968 symtab_offset = obj_sym_filepos (abfd); /* symbol table file offset */
2969 stringtab_offset = symtab_offset +
2970 num_symbols * coff_data (abfd)->local_symesz;
2971
2972 info->min_lineno_offset = 0;
2973 info->max_lineno_offset = 0;
2974 bfd_map_over_sections (abfd, find_linenos, info);
2975
2976 if (num_symbols > 0)
2977 {
2978 /* Read the string table. */
2979 init_stringtab (abfd, stringtab_offset, objfile);
2980
2981 /* Read the .debug section, if present. */
2982 {
2983 struct bfd_section *secp;
2984 bfd_size_type length;
2985 bfd_byte *debugsec = NULL;
2986
2987 secp = bfd_get_section_by_name (abfd, ".debug");
2988 if (secp)
2989 {
2990 length = bfd_section_size (abfd, secp);
2991 if (length)
2992 {
2993 debugsec = obstack_alloc (&objfile->objfile_obstack, length);
2994
2995 if (!bfd_get_full_section_contents (abfd, secp, &debugsec))
2996 {
2997 error (_("Error reading .debug section of `%s': %s"),
2998 name, bfd_errmsg (bfd_get_error ()));
2999 }
3000 }
3001 }
3002 info->debugsec = (char *) debugsec;
3003 }
3004 }
3005
3006 /* Read the symbols. We keep them in core because we will want to
3007 access them randomly in read_symbol*. */
3008 val = bfd_seek (abfd, symtab_offset, SEEK_SET);
3009 if (val < 0)
3010 error (_("Error reading symbols from %s: %s"),
3011 name, bfd_errmsg (bfd_get_error ()));
3012 size = coff_data (abfd)->local_symesz * num_symbols;
3013 info->symtbl = obstack_alloc (&objfile->objfile_obstack, size);
3014 info->symtbl_num_syms = num_symbols;
3015
3016 val = bfd_bread (info->symtbl, size, abfd);
3017 if (val != size)
3018 perror_with_name (_("reading symbol table"));
3019
3020 /* If we are reinitializing, or if we have never loaded syms yet, init. */
3021 if (objfile->global_psymbols.size == 0 && objfile->static_psymbols.size == 0)
3022 /* I'm not sure how how good num_symbols is; the rule of thumb in
3023 init_psymbol_list was developed for a.out. On the one hand,
3024 num_symbols includes auxents. On the other hand, it doesn't
3025 include N_SLINE. */
3026 init_psymbol_list (objfile, num_symbols);
3027
3028 free_pending_blocks ();
3029 back_to = make_cleanup (really_free_pendings, 0);
3030
3031 init_minimal_symbol_collection ();
3032 make_cleanup_discard_minimal_symbols ();
3033
3034 /* Now that the symbol table data of the executable file are all in core,
3035 process them and define symbols accordingly. */
3036
3037 scan_xcoff_symtab (objfile);
3038
3039 /* Install any minimal symbols that have been collected as the current
3040 minimal symbols for this objfile. */
3041
3042 install_minimal_symbols (objfile);
3043
3044 /* DWARF2 sections. */
3045
3046 if (dwarf2_has_info (objfile, &dwarf2_xcoff_names))
3047 dwarf2_build_psymtabs (objfile);
3048
3049 dwarf2_build_frame_info (objfile);
3050
3051 do_cleanups (back_to);
3052 }
3053 \f
3054 static void
3055 xcoff_symfile_offsets (struct objfile *objfile,
3056 const struct section_addr_info *addrs)
3057 {
3058 const char *first_section_name;
3059
3060 default_symfile_offsets (objfile, addrs);
3061
3062 /* Oneof the weird side-effects of default_symfile_offsets is that
3063 it sometimes sets some section indices to zero for sections that,
3064 in fact do not exist. See the body of default_symfile_offsets
3065 for more info on when that happens. Undo that, as this then allows
3066 us to test whether the associated section exists or not, and then
3067 access it quickly (without searching it again). */
3068
3069 if (objfile->num_sections == 0)
3070 return; /* Is that even possible? Better safe than sorry. */
3071
3072 first_section_name
3073 = bfd_section_name (objfile->obfd, objfile->sections[0].the_bfd_section);
3074
3075 if (objfile->sect_index_text == 0
3076 && strcmp (first_section_name, ".text") != 0)
3077 objfile->sect_index_text = -1;
3078
3079 if (objfile->sect_index_data == 0
3080 && strcmp (first_section_name, ".data") != 0)
3081 objfile->sect_index_data = -1;
3082
3083 if (objfile->sect_index_bss == 0
3084 && strcmp (first_section_name, ".bss") != 0)
3085 objfile->sect_index_bss = -1;
3086
3087 if (objfile->sect_index_rodata == 0
3088 && strcmp (first_section_name, ".rodata") != 0)
3089 objfile->sect_index_rodata = -1;
3090 }
3091
3092 /* Register our ability to parse symbols for xcoff BFD files. */
3093
3094 static const struct sym_fns xcoff_sym_fns =
3095 {
3096
3097 /* It is possible that coff and xcoff should be merged as
3098 they do have fundamental similarities (for example, the extra storage
3099 classes used for stabs could presumably be recognized in any COFF file).
3100 However, in addition to obvious things like all the csect hair, there are
3101 some subtler differences between xcoffread.c and coffread.c, notably
3102 the fact that coffread.c has no need to read in all the symbols, but
3103 xcoffread.c reads all the symbols and does in fact randomly access them
3104 (in C_BSTAT and line number processing). */
3105
3106 xcoff_new_init, /* init anything gbl to entire symtab */
3107 xcoff_symfile_init, /* read initial info, setup for sym_read() */
3108 xcoff_initial_scan, /* read a symbol file into symtab */
3109 NULL, /* sym_read_psymbols */
3110 xcoff_symfile_finish, /* finished with file, cleanup */
3111 xcoff_symfile_offsets, /* xlate offsets ext->int form */
3112 default_symfile_segments, /* Get segment information from a file. */
3113 aix_process_linenos,
3114 default_symfile_relocate, /* Relocate a debug section. */
3115 NULL, /* sym_probe_fns */
3116 &psym_functions
3117 };
3118
3119 /* Same as xcoff_get_n_import_files, but for core files. */
3120
3121 static int
3122 xcoff_get_core_n_import_files (bfd *abfd)
3123 {
3124 asection *sect = bfd_get_section_by_name (abfd, ".ldinfo");
3125 gdb_byte buf[4];
3126 file_ptr offset = 0;
3127 int n_entries = 0;
3128
3129 if (sect == NULL)
3130 return -1; /* Not a core file. */
3131
3132 for (offset = 0; offset < bfd_get_section_size (sect);)
3133 {
3134 int next;
3135
3136 n_entries++;
3137
3138 if (!bfd_get_section_contents (abfd, sect, buf, offset, 4))
3139 return -1;
3140 next = bfd_get_32 (abfd, buf);
3141 if (next == 0)
3142 break; /* This is the last entry. */
3143 offset += next;
3144 }
3145
3146 /* Return the number of entries, excluding the first one, which is
3147 the path to the executable that produced this core file. */
3148 return n_entries - 1;
3149 }
3150
3151 /* Return the number of import files (shared libraries) that the given
3152 BFD depends on. Return -1 if this number could not be computed. */
3153
3154 int
3155 xcoff_get_n_import_files (bfd *abfd)
3156 {
3157 asection *sect = bfd_get_section_by_name (abfd, ".loader");
3158 gdb_byte buf[4];
3159 int l_nimpid;
3160
3161 /* If the ".loader" section does not exist, the objfile is probably
3162 not an executable. Might be a core file... */
3163 if (sect == NULL)
3164 return xcoff_get_core_n_import_files (abfd);
3165
3166 /* The number of entries in the Import Files Table is stored in
3167 field l_nimpid. This field is always at offset 16, and is
3168 always 4 bytes long. Read those 4 bytes. */
3169
3170 if (!bfd_get_section_contents (abfd, sect, buf, 16, 4))
3171 return -1;
3172 l_nimpid = bfd_get_32 (abfd, buf);
3173
3174 /* By convention, the first entry is the default LIBPATH value
3175 to be used by the system loader, so it does not count towards
3176 the number of import files. */
3177 return l_nimpid - 1;
3178 }
3179
3180 /* Free the per-objfile xcoff data. */
3181
3182 static void
3183 xcoff_free_info (struct objfile *objfile, void *arg)
3184 {
3185 xfree (arg);
3186 }
3187
3188 /* Provide a prototype to silence -Wmissing-prototypes. */
3189 extern initialize_file_ftype _initialize_xcoffread;
3190
3191 void
3192 _initialize_xcoffread (void)
3193 {
3194 add_symtab_fns (bfd_target_xcoff_flavour, &xcoff_sym_fns);
3195
3196 xcoff_objfile_data_key = register_objfile_data_with_cleanup (NULL,
3197 xcoff_free_info);
3198 }
This page took 0.094705 seconds and 5 git commands to generate.