]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gprof/corefile.c
* corefile.c: Rename from core.c.
[thirdparty/binutils-gdb.git] / gprof / corefile.c
CommitLineData
5489fcc3
KR
1#include "libiberty.h"
2#include "gprof.h"
43870aec 3#include "corefile.h"
5489fcc3
KR
4#include "symtab.h"
5
6bfd *core_bfd;
7int core_num_syms;
8asymbol **core_syms;
9asection *core_text_sect;
10PTR core_text_space;
11
c3de2a19
ILT
12int min_insn_size;
13int offset_to_code;
14
64c50fc5
JL
15/* For mapping symbols to specific .o files during file ordering. */
16struct function_map {
17 char *function_name;
18 char *file_name;
19};
20
21struct function_map *symbol_map;
6b84886a 22unsigned int symbol_map_count;
64c50fc5 23
c3de2a19
ILT
24extern void i386_find_call PARAMS ((Sym *, bfd_vma, bfd_vma));
25extern void alpha_find_call PARAMS ((Sym *, bfd_vma, bfd_vma));
26extern void vax_find_call PARAMS ((Sym *, bfd_vma, bfd_vma));
27extern void tahoe_find_call PARAMS ((Sym *, bfd_vma, bfd_vma));
28extern void sparc_find_call PARAMS ((Sym *, bfd_vma, bfd_vma));
29
64c50fc5
JL
30static void
31DEFUN (read_function_mappings, (filename), const char *filename)
32{
33 FILE *file = fopen (filename, "r");
34 char dummy[1024];
35 int count = 0;
36
37 if (!file)
38 {
16a02269 39 fprintf (stderr, _("%s: could not open %s.\n"), whoami, filename);
64c50fc5
JL
40 done (1);
41 }
42
43 /* First parse the mapping file so we know how big we need to
44 make our tables. We also do some sanity checks at this
45 time. */
46 while (!feof (file))
47 {
48 int matches;
49
50 matches = fscanf (file, "%[^\n:]", dummy);
51 if (!matches)
52 {
16a02269 53 fprintf (stderr, _("%s: unable to parse mapping file %s.\n"),
64c50fc5
JL
54 whoami, filename);
55 done (1);
56 }
57
58 /* Just skip messages about files with no symbols. */
59 if (!strncmp (dummy, "No symbols in ", 14))
60 {
61 fscanf (file, "\n");
62 continue;
63 }
64
65 /* Don't care what else is on this line at this point. */
66 fscanf (file, "%[^\n]\n", dummy);
67 count++;
68 }
69
70 /* Now we know how big we need to make our table. */
1c34a108
ILT
71 symbol_map = ((struct function_map *)
72 xmalloc (count * sizeof (struct function_map)));
64c50fc5
JL
73
74 /* Rewind the input file so we can read it again. */
75 rewind (file);
76
77 /* Read each entry and put it into the table. */
78 count = 0;
79 while (!feof (file))
80 {
81 int matches;
82 char *tmp;
83
84 matches = fscanf (file, "%[^\n:]", dummy);
85 if (!matches)
86 {
16a02269 87 fprintf (stderr, _("%s: unable to parse mapping file %s.\n"),
64c50fc5
JL
88 whoami, filename);
89 done (1);
90 }
91
92 /* Just skip messages about files with no symbols. */
93 if (!strncmp (dummy, "No symbols in ", 14))
94 {
95 fscanf (file, "\n");
96 continue;
97 }
98
99 /* dummy has the filename, go ahead and copy it. */
100 symbol_map[count].file_name = xmalloc (strlen (dummy) + 1);
101 strcpy (symbol_map[count].file_name, dummy);
102
103 /* Now we need the function name. */
104 fscanf (file, "%[^\n]\n", dummy);
105 tmp = strrchr (dummy, ' ') + 1;
106 symbol_map[count].function_name = xmalloc (strlen (tmp) + 1);
107 strcpy (symbol_map[count].function_name, tmp);
108 count++;
109 }
110
111 /* Record the size of the map table for future reference. */
112 symbol_map_count = count;
113}
5489fcc3
KR
114
115void
12516a37 116DEFUN (core_init, (a_out_name), const char *a_out_name)
5489fcc3 117{
12516a37
KR
118 core_bfd = bfd_openr (a_out_name, 0);
119
120 if (!core_bfd)
121 {
122 perror (a_out_name);
123 done (1);
03c35bcb 124 }
12516a37
KR
125
126 if (!bfd_check_format (core_bfd, bfd_object))
127 {
16a02269 128 fprintf (stderr, _("%s: %s: not in a.out format\n"), whoami, a_out_name);
12516a37 129 done (1);
03c35bcb 130 }
12516a37
KR
131
132 /* get core's text section: */
133 core_text_sect = bfd_get_section_by_name (core_bfd, ".text");
134 if (!core_text_sect)
135 {
136 core_text_sect = bfd_get_section_by_name (core_bfd, "$CODE$");
137 if (!core_text_sect)
138 {
16a02269 139 fprintf (stderr, _("%s: can't find .text section in %s\n"),
12516a37
KR
140 whoami, a_out_name);
141 done (1);
03c35bcb
KR
142 }
143 }
12516a37
KR
144
145 /* read core's symbol table: */
146
147 /* this will probably give us more than we need, but that's ok: */
148 core_num_syms = bfd_get_symtab_upper_bound (core_bfd);
149 if (core_num_syms < 0)
150 {
151 fprintf (stderr, "%s: %s: %s\n", whoami, a_out_name,
152 bfd_errmsg (bfd_get_error ()));
153 done (1);
03c35bcb 154 }
12516a37
KR
155
156 core_syms = (asymbol **) xmalloc (core_num_syms);
157 core_num_syms = bfd_canonicalize_symtab (core_bfd, core_syms);
158 if (core_num_syms < 0)
159 {
160 fprintf (stderr, "%s: %s: %s\n", whoami, a_out_name,
161 bfd_errmsg (bfd_get_error ()));
162 done (1);
03c35bcb 163 }
64c50fc5 164
c3de2a19
ILT
165 min_insn_size = 1;
166 offset_to_code = 0;
167
168 switch (bfd_get_arch (core_bfd))
169 {
170 case bfd_arch_vax:
171 case bfd_arch_tahoe:
172 offset_to_code = 2;
173 break;
174
175 case bfd_arch_alpha:
176 min_insn_size = 4;
177 break;
178
179 default:
ed302e5d 180 break;
c3de2a19
ILT
181 }
182
64c50fc5
JL
183 if (function_mapping_file)
184 read_function_mappings (function_mapping_file);
03c35bcb 185}
5489fcc3
KR
186
187
188/*
189 * Read in the text space of an a.out file
190 */
191void
12516a37 192DEFUN (core_get_text_space, (core_bfd), bfd * core_bfd)
5489fcc3 193{
12516a37
KR
194 core_text_space = (PTR) malloc (core_text_sect->_raw_size);
195
196 if (!core_text_space)
5489fcc3 197 {
16a02269 198 fprintf (stderr, _("%s: ran out room for %ld bytes of text space\n"),
12516a37
KR
199 whoami, core_text_sect->_raw_size);
200 done (1);
03c35bcb 201 }
12516a37
KR
202 if (!bfd_get_section_contents (core_bfd, core_text_sect, core_text_space,
203 0, core_text_sect->_raw_size))
204 {
205 bfd_perror ("bfd_get_section_contents");
206 free (core_text_space);
207 core_text_space = 0;
03c35bcb 208 }
12516a37
KR
209 if (!core_text_space)
210 {
16a02269 211 fprintf (stderr, _("%s: can't do -c\n"), whoami);
03c35bcb
KR
212 }
213}
5489fcc3
KR
214
215
c3de2a19
ILT
216void
217DEFUN (find_call, (parent, p_lowpc, p_highpc),
218 Sym * parent AND bfd_vma p_lowpc AND bfd_vma p_highpc)
219{
220 switch (bfd_get_arch (core_bfd))
221 {
222 case bfd_arch_i386:
223 i386_find_call (parent, p_lowpc, p_highpc);
224 break;
225
226 case bfd_arch_alpha:
227 alpha_find_call (parent, p_lowpc, p_highpc);
228 break;
229
230 case bfd_arch_vax:
231 vax_find_call (parent, p_lowpc, p_highpc);
232 break;
233
234 case bfd_arch_sparc:
235 sparc_find_call (parent, p_lowpc, p_highpc);
236 break;
237
238 case bfd_arch_tahoe:
239 tahoe_find_call (parent, p_lowpc, p_highpc);
240 break;
241
242 default:
16a02269 243 fprintf (stderr, _("%s: -c not supported on architecture %s\n"),
c3de2a19
ILT
244 whoami, bfd_printable_name(core_bfd));
245
246 /* Don't give the error more than once. */
247 ignore_direct_calls = FALSE;
248 }
249}
250
5489fcc3
KR
251/*
252 * Return class of symbol SYM. The returned class can be any of:
12516a37
KR
253 * 0 -> symbol is not interesting to us
254 * 'T' -> symbol is a global name
255 * 't' -> symbol is a local (static) name
5489fcc3
KR
256 */
257static int
12516a37 258DEFUN (core_sym_class, (sym), asymbol * sym)
5489fcc3 259{
12516a37
KR
260 symbol_info syminfo;
261 const char *name;
262 char sym_prefix;
263 int i;
264
0f579087 265 if (sym->section == NULL || (sym->flags & BSF_DEBUGGING) != 0)
12516a37
KR
266 {
267 return 0;
03c35bcb 268 }
12516a37 269
0f579087
ILT
270 /*
271 * Must be a text symbol, and static text symbols don't qualify if
272 * ignore_static_funcs set.
273 */
12516a37
KR
274 if (ignore_static_funcs && (sym->flags & BSF_LOCAL))
275 {
276 DBG (AOUTDEBUG, printf ("[core_sym_class] %s: not a function\n",
5489fcc3 277 sym->name));
12516a37 278 return 0;
03c35bcb 279 }
5489fcc3 280
12516a37
KR
281 bfd_get_symbol_info (core_bfd, sym, &syminfo);
282 i = syminfo.type;
5489fcc3 283
12516a37
KR
284 if (i == 'T')
285 {
286 return i; /* it's a global symbol */
03c35bcb 287 }
5489fcc3 288
a3da1edc
ILT
289 if (i == 'W')
290 {
291 /* Treat weak symbols as text symbols. FIXME: a weak symbol may
292 also be a data symbol. */
293 return 'T';
294 }
295
12516a37
KR
296 if (i != 't')
297 {
298 /* not a static text symbol */
299 DBG (AOUTDEBUG, printf ("[core_sym_class] %s is of class %c\n",
5489fcc3 300 sym->name, i));
12516a37 301 return 0;
03c35bcb 302 }
12516a37
KR
303
304 /* do some more filtering on static function-names: */
305
306 if (ignore_static_funcs)
307 {
308 return 0;
03c35bcb 309 }
12516a37
KR
310 /*
311 * Can't zero-length name or funny characters in name, where
312 * `funny' includes: `.' (.o file names) and `$' (Pascal labels).
313 */
314 if (!sym->name || sym->name[0] == '\0')
5489fcc3 315 {
12516a37 316 return 0;
03c35bcb 317 }
12516a37
KR
318
319 for (name = sym->name; *name; ++name)
320 {
321 if (*name == '.' || *name == '$')
322 {
323 return 0;
03c35bcb
KR
324 }
325 }
12516a37
KR
326 /*
327 * On systems where the C compiler adds an underscore to all
328 * names, static names without underscores seem usually to be
329 * labels in hand written assembler in the library. We don't want
330 * these names. This is certainly necessary on a Sparc running
331 * SunOS 4.1 (try profiling a program that does a lot of
332 * division). I don't know whether it has harmful side effects on
333 * other systems. Perhaps it should be made configurable.
334 */
335 sym_prefix = bfd_get_symbol_leading_char (core_bfd);
df928c8f 336 if ((sym_prefix && sym_prefix != sym->name[0])
12516a37
KR
337 /*
338 * GCC may add special symbols to help gdb figure out the file
339 * language. We want to ignore these, since sometimes they mask
340 * the real function. (dj@ctron)
341 */
342 || !strncmp (sym->name, "__gnu_compiled", 14)
343 || !strncmp (sym->name, "___gnu_compiled", 15))
344 {
345 return 0;
03c35bcb 346 }
32843f94
JL
347
348 /* If the object file supports marking of function symbols, then we can
349 zap anything that doesn't have BSF_FUNCTION set. */
350 if (ignore_non_functions && (sym->flags & BSF_FUNCTION) == 0)
351 return 0;
352
12516a37 353 return 't'; /* it's a static text symbol */
03c35bcb 354}
5489fcc3
KR
355
356
357/*
358 * Get whatever source info we can get regarding address ADDR:
359 */
360static bool
12516a37
KR
361DEFUN (get_src_info, (addr, filename, name, line_num),
362 bfd_vma addr AND const char **filename AND const char **name
363 AND int *line_num)
5489fcc3 364{
12516a37
KR
365 const char *fname = 0, *func_name = 0;
366 int l = 0;
5489fcc3 367
12516a37
KR
368 if (bfd_find_nearest_line (core_bfd, core_text_sect, core_syms,
369 addr - core_text_sect->vma,
643f17d2 370 &fname, &func_name, (unsigned int *) &l)
12516a37 371 && fname && func_name && l)
5489fcc3 372 {
12516a37 373 DBG (AOUTDEBUG, printf ("[get_src_info] 0x%lx -> %s:%d (%s)\n",
5489fcc3 374 addr, fname, l, func_name));
12516a37
KR
375 *filename = fname;
376 *name = func_name;
377 *line_num = l;
378 return TRUE;
379 }
380 else
381 {
382 DBG (AOUTDEBUG, printf ("[get_src_info] no info for 0x%lx (%s:%d,%s)\n",
5489fcc3
KR
383 (long) addr, fname ? fname : "<unknown>", l,
384 func_name ? func_name : "<unknown>"));
12516a37 385 return FALSE;
03c35bcb
KR
386 }
387}
5489fcc3
KR
388
389
390/*
391 * Read in symbol table from core. One symbol per function is
392 * entered.
393 */
394void
12516a37 395DEFUN (core_create_function_syms, (core_bfd), bfd * core_bfd)
5489fcc3 396{
12516a37 397 bfd_vma min_vma = ~0, max_vma = 0;
12516a37 398 int class;
6b84886a
ILT
399 long i, found, skip;
400 unsigned int j;
12516a37
KR
401
402 /* pass 1 - determine upper bound on number of function names: */
403 symtab.len = 0;
404 for (i = 0; i < core_num_syms; ++i)
405 {
406 if (!core_sym_class (core_syms[i]))
407 {
408 continue;
03c35bcb 409 }
64c50fc5
JL
410
411 /* This should be replaced with a binary search or hashed
412 search. Gross.
413
414 Don't create a symtab entry for a function that has
415 a mapping to a file, unless it's the first function
416 in the file. */
417 skip = 0;
418 for (j = 0; j < symbol_map_count; j++)
419 if (!strcmp (core_syms[i]->name, symbol_map[j].function_name))
420 {
421 if (j > 0 && ! strcmp (symbol_map [j].file_name,
422 symbol_map [j - 1].file_name))
423 skip = 1;
424 break;
425 }
426 if (!skip)
427 ++symtab.len;
03c35bcb 428 }
12516a37
KR
429
430 if (symtab.len == 0)
431 {
16a02269 432 fprintf (stderr, _("%s: file `%s' has no symbols\n"), whoami, a_out_name);
12516a37 433 done (1);
03c35bcb 434 }
12516a37
KR
435
436 /* the "+ 2" is for the sentinels: */
437 symtab.base = (Sym *) xmalloc ((symtab.len + 2) * sizeof (Sym));
438
439 /* pass 2 - create symbols: */
440
441 symtab.limit = symtab.base;
442 for (i = 0; i < core_num_syms; ++i)
443 {
444 class = core_sym_class (core_syms[i]);
445 if (!class)
446 {
447 DBG (AOUTDEBUG,
448 printf ("[core_create_function_syms] rejecting: 0x%lx %s\n",
5489fcc3 449 core_syms[i]->value, core_syms[i]->name));
12516a37 450 continue;
03c35bcb 451 }
64c50fc5
JL
452 /* This should be replaced with a binary search or hashed
453 search. Gross. */
454
455 skip = 0;
456 found = 0;
457 for (j = 0; j < symbol_map_count; j++)
458 if (!strcmp (core_syms[i]->name, symbol_map[j].function_name))
459 {
460 if (j > 0 && ! strcmp (symbol_map [j].file_name,
461 symbol_map [j - 1].file_name))
462 skip = 1;
463 else
464 found = j;
465 break;
466 }
467
468 if (skip)
469 continue;
5489fcc3 470
12516a37 471 sym_init (symtab.limit);
5489fcc3 472
12516a37 473 /* symbol offsets are always section-relative: */
5489fcc3 474
12516a37 475 symtab.limit->addr = core_syms[i]->value + core_syms[i]->section->vma;
64c50fc5
JL
476 if (symbol_map_count
477 && !strcmp (core_syms[i]->name, symbol_map[found].function_name))
478 {
479 symtab.limit->name = symbol_map[found].file_name;
480 symtab.limit->mapped = 1;
481 }
482 else
483 {
484 symtab.limit->name = core_syms[i]->name;
485 symtab.limit->mapped = 0;
486 }
5489fcc3 487
c3de2a19
ILT
488 /* Lookup filename and line number, if we can */
489
df928c8f
ILT
490 {
491 const char *filename, *func_name;
492
493 if (get_src_info (symtab.limit->addr, &filename, &func_name,
494 &symtab.limit->line_num))
495 {
496 symtab.limit->file = source_file_lookup_path (filename);
497
c3de2a19
ILT
498 /* FIXME: Checking __osf__ here does not work with a cross
499 gprof. */
500#ifdef __osf__
501 /*
502 * Suppress symbols that are not function names. This is
503 * useful to suppress code-labels and aliases.
504 *
505 * This is known to be useful under DEC's OSF/1. Under SunOS 4.x,
506 * labels do not appear in the symbol table info, so this isn't
507 * necessary.
508 */
509
df928c8f
ILT
510 if (strcmp (symtab.limit->name, func_name) != 0)
511 {
512 /*
513 * The symbol's address maps to a different name, so
514 * it can't be a function-entry point. This happens
515 * for labels, for example.
516 */
517 DBG (AOUTDEBUG,
518 printf ("[core_create_function_syms: rej %s (maps to %s)\n",
519 symtab.limit->name, func_name));
520 continue;
521 }
c3de2a19 522#endif
df928c8f
ILT
523 }
524 }
5489fcc3 525
12516a37
KR
526 symtab.limit->is_func = TRUE;
527 symtab.limit->is_bb_head = TRUE;
528 if (class == 't')
529 {
530 symtab.limit->is_static = TRUE;
03c35bcb 531 }
12516a37
KR
532
533 min_vma = MIN (symtab.limit->addr, min_vma);
534 max_vma = MAX (symtab.limit->addr, max_vma);
535
536 /*
537 * If we see "main" without an initial '_', we assume names
538 * are *not* prefixed by '_'.
539 */
540 if (symtab.limit->name[0] == 'm' && discard_underscores
541 && strcmp (symtab.limit->name, "main") == 0)
5489fcc3 542 {
12516a37 543 discard_underscores = 0;
03c35bcb 544 }
5489fcc3 545
12516a37
KR
546 DBG (AOUTDEBUG, printf ("[core_create_function_syms] %ld %s 0x%lx\n",
547 (long) (symtab.limit - symtab.base),
5489fcc3 548 symtab.limit->name, symtab.limit->addr));
12516a37 549 ++symtab.limit;
03c35bcb 550 }
5489fcc3 551
12516a37 552 /* create sentinels: */
5489fcc3 553
12516a37
KR
554 sym_init (symtab.limit);
555 symtab.limit->name = "<locore>";
556 symtab.limit->addr = 0;
557 symtab.limit->end_addr = min_vma - 1;
558 ++symtab.limit;
5489fcc3 559
12516a37
KR
560 sym_init (symtab.limit);
561 symtab.limit->name = "<hicore>";
562 symtab.limit->addr = max_vma + 1;
563 symtab.limit->end_addr = ~0;
564 ++symtab.limit;
5489fcc3 565
12516a37
KR
566 symtab.len = symtab.limit - symtab.base;
567 symtab_finalize (&symtab);
03c35bcb 568}
5489fcc3
KR
569
570
571/*
572 * Read in symbol table from core. One symbol per line of source code
573 * is entered.
574 */
575void
12516a37 576DEFUN (core_create_line_syms, (core_bfd), bfd * core_bfd)
5489fcc3 577{
12516a37
KR
578 char prev_name[PATH_MAX], prev_filename[PATH_MAX];
579 bfd_vma vma, min_vma = ~0, max_vma = 0;
c3de2a19 580 bfd_vma offset;
12516a37
KR
581 Sym *prev, dummy, *sentinel, *sym;
582 const char *filename;
c3de2a19 583 int prev_line_num;
12516a37
KR
584 Sym_Table ltab;
585 /*
586 * Create symbols for functions as usual. This is necessary in
587 * cases where parts of a program were not compiled with -g. For
588 * those parts we still want to get info at the function level:
589 */
590 core_create_function_syms (core_bfd);
591
592 /* pass 1 - counter number of symbols: */
593
594 /*
595 * To find all line information, walk through all possible
596 * text-space addresses (one by one!) and get the debugging
597 * info for each address. When the debugging info changes,
598 * it is time to create a new symbol.
599 *
600 * Of course, this is rather slow and it would be better if
c3de2a19 601 * bfd would provide an iterator for enumerating all line infos
12516a37
KR
602 */
603 prev_name[0] = '\0';
604 ltab.len = 0;
12516a37
KR
605 prev_filename[0] = '\0';
606 prev_line_num = 0;
c3de2a19 607 for (offset = 0; offset < core_text_sect->_raw_size; offset += min_insn_size)
12516a37
KR
608 {
609 vma = core_text_sect->vma + offset;
610 if (!get_src_info (vma, &filename, &dummy.name, &dummy.line_num)
611 || (prev_line_num == dummy.line_num &&
612 strcmp (prev_name, dummy.name) == 0
613 && strcmp (prev_filename, filename) == 0))
5489fcc3 614 {
12516a37 615 continue;
03c35bcb 616 }
12516a37
KR
617
618 ++ltab.len;
619 prev_line_num = dummy.line_num;
620 strcpy (prev_name, dummy.name);
621 strcpy (prev_filename, filename);
622
12516a37
KR
623 min_vma = MIN (vma, min_vma);
624 max_vma = MAX (vma, max_vma);
03c35bcb 625 }
12516a37 626
12516a37
KR
627 /* make room for function symbols, too: */
628 ltab.len += symtab.len;
629 ltab.base = (Sym *) xmalloc (ltab.len * sizeof (Sym));
630 ltab.limit = ltab.base;
631
632 /* pass 2 - create symbols: */
633
c3de2a19
ILT
634 /* We now set is_static as we go along, rather than by running
635 through the symbol table at the end.
636
637 The old way called symtab_finalize before the is_static pass,
638 causing a problem since symtab_finalize uses is_static as part of
639 its address conflict resolution algorithm. Since global symbols
640 were prefered over static symbols, and all line symbols were
641 global at that point, static function names that conflicted with
642 their own line numbers (static, but labeled as global) were
643 rejected in favor of the line num.
644
645 This was not the desired functionality. We always want to keep
646 our function symbols and discard any conflicting line symbols.
647 Perhaps symtab_finalize should be modified to make this
648 distinction as well, but the current fix works and the code is a
649 lot cleaner now. */
650
12516a37 651 prev = 0;
c3de2a19 652 for (offset = 0; offset < core_text_sect->_raw_size; offset += min_insn_size)
12516a37
KR
653 {
654 sym_init (ltab.limit);
655 if (!get_src_info (core_text_sect->vma + offset, &filename,
656 &ltab.limit->name, &ltab.limit->line_num)
657 || (prev && prev->line_num == ltab.limit->line_num
658 && strcmp (prev->name, ltab.limit->name) == 0
659 && strcmp (prev->file->name, filename) == 0))
5489fcc3 660 {
12516a37 661 continue;
03c35bcb 662 }
12516a37
KR
663
664 /* make name pointer a malloc'ed string: */
d75ea6de 665 ltab.limit->name = xstrdup (ltab.limit->name);
12516a37
KR
666 ltab.limit->file = source_file_lookup_path (filename);
667
668 ltab.limit->addr = core_text_sect->vma + offset;
c3de2a19
ILT
669
670 /* Set is_static based on the enclosing function, using either:
671 * 1) the previous symbol, if it's from the same function, or
672 * 2) a symtab lookup
673 */
674
675 if (prev && ltab.limit->file == prev->file &&
676 strcmp (ltab.limit->name, prev->name) == 0)
677 {
678 ltab.limit->is_static = prev->is_static;
679 }
680 else
681 {
682 sym = sym_lookup(&symtab, ltab.limit->addr);
683 ltab.limit->is_static = sym->is_static;
684 }
685
12516a37
KR
686 prev = ltab.limit;
687
688 /*
689 * If we see "main" without an initial '_', we assume names
690 * are *not* prefixed by '_'.
691 */
692 if (ltab.limit->name[0] == 'm' && discard_underscores
693 && strcmp (ltab.limit->name, "main") == 0)
694 {
695 discard_underscores = 0;
03c35bcb 696 }
5489fcc3 697
12516a37 698 DBG (AOUTDEBUG, printf ("[core_create_line_syms] %d %s 0x%lx\n",
c3de2a19 699 ltab.limit - ltab.base, ltab.limit->name,
5489fcc3 700 ltab.limit->addr));
12516a37 701 ++ltab.limit;
03c35bcb 702 }
12516a37
KR
703
704 /* update sentinels: */
705
706 sentinel = sym_lookup (&symtab, 0);
707 if (strcmp (sentinel->name, "<locore>") == 0
708 && min_vma <= sentinel->end_addr)
709 {
710 sentinel->end_addr = min_vma - 1;
03c35bcb 711 }
12516a37
KR
712
713 sentinel = sym_lookup (&symtab, ~0);
714 if (strcmp (sentinel->name, "<hicore>") == 0 && max_vma >= sentinel->addr)
715 {
716 sentinel->addr = max_vma + 1;
03c35bcb 717 }
5489fcc3 718
12516a37
KR
719 /* copy in function symbols: */
720 memcpy (ltab.limit, symtab.base, symtab.len * sizeof (Sym));
721 ltab.limit += symtab.len;
5489fcc3 722
6b84886a 723 if ((unsigned int) (ltab.limit - ltab.base) != ltab.len)
5489fcc3 724 {
12516a37 725 fprintf (stderr,
16a02269 726 _("%s: somebody miscounted: ltab.len=%d instead of %ld\n"),
c3de2a19 727 whoami, ltab.len, (long) (ltab.limit - ltab.base));
12516a37 728 done (1);
03c35bcb 729 }
12516a37
KR
730
731 /* finalize ltab and make it symbol table: */
732
733 symtab_finalize (&ltab);
734 free (symtab.base);
735 symtab = ltab;
736
03c35bcb 737}