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