bfd/
[deliverable/binutils-gdb.git] / bfd / xsym.c
1 /* xSYM symbol-file support for BFD.
2 Copyright 1999, 2000, 2001, 2002, 2003, 2004
3 Free Software Foundation, Inc.
4
5 This file is part of BFD, the Binary File Descriptor library.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
20
21 #include "xsym.h"
22 #include "bfd.h"
23 #include "sysdep.h"
24 #include "libbfd.h"
25
26 #define bfd_sym_close_and_cleanup _bfd_generic_close_and_cleanup
27 #define bfd_sym_bfd_free_cached_info _bfd_generic_bfd_free_cached_info
28 #define bfd_sym_new_section_hook _bfd_generic_new_section_hook
29 #define bfd_sym_bfd_is_local_label_name bfd_generic_is_local_label_name
30 #define bfd_sym_get_lineno _bfd_nosymbols_get_lineno
31 #define bfd_sym_find_nearest_line _bfd_nosymbols_find_nearest_line
32 #define bfd_sym_bfd_make_debug_symbol _bfd_nosymbols_bfd_make_debug_symbol
33 #define bfd_sym_read_minisymbols _bfd_generic_read_minisymbols
34 #define bfd_sym_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
35 #define bfd_sym_get_reloc_upper_bound _bfd_norelocs_get_reloc_upper_bound
36 #define bfd_sym_canonicalize_reloc _bfd_norelocs_canonicalize_reloc
37 #define bfd_sym_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup
38 #define bfd_sym_set_arch_mach _bfd_generic_set_arch_mach
39 #define bfd_sym_get_section_contents _bfd_generic_get_section_contents
40 #define bfd_sym_set_section_contents _bfd_generic_set_section_contents
41 #define bfd_sym_bfd_get_relocated_section_contents bfd_generic_get_relocated_section_contents
42 #define bfd_sym_bfd_relax_section bfd_generic_relax_section
43 #define bfd_sym_bfd_gc_sections bfd_generic_gc_sections
44 #define bfd_sym_bfd_merge_sections bfd_generic_merge_sections
45 #define bfd_sym_bfd_is_group_section bfd_generic_is_group_section
46 #define bfd_sym_bfd_discard_group bfd_generic_discard_group
47 #define bfd_sym_section_already_linked \
48 _bfd_generic_section_already_linked
49 #define bfd_sym_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
50 #define bfd_sym_bfd_link_hash_table_free _bfd_generic_link_hash_table_free
51 #define bfd_sym_bfd_link_add_symbols _bfd_generic_link_add_symbols
52 #define bfd_sym_bfd_link_just_syms _bfd_generic_link_just_syms
53 #define bfd_sym_bfd_final_link _bfd_generic_final_link
54 #define bfd_sym_bfd_link_split_section _bfd_generic_link_split_section
55 #define bfd_sym_get_section_contents_in_window _bfd_generic_get_section_contents_in_window
56
57 static int pstrcmp PARAMS ((unsigned char *, unsigned char *));
58 static unsigned long compute_offset
59 PARAMS ((unsigned long, unsigned long, unsigned long, unsigned long));
60
61 extern const bfd_target sym_vec;
62
63 static int
64 pstrcmp (a, b)
65 unsigned char *a;
66 unsigned char *b;
67 {
68 unsigned char clen;
69 int ret;
70
71 clen = (a[0] > b[0]) ? a[0] : b[0];
72 ret = memcmp (a + 1, b + 1, clen);
73 if (ret != 0)
74 return ret;
75
76 if (a[0] == b[0])
77 return 0;
78 else if (a[0] < b[0])
79 return -1;
80 else
81 return 0;
82 }
83
84 static unsigned long
85 compute_offset (first_page, page_size, entry_size, index)
86 unsigned long first_page;
87 unsigned long page_size;
88 unsigned long entry_size;
89 unsigned long index;
90 {
91 unsigned long entries_per_page = page_size / entry_size;
92 unsigned long page_number = first_page + (index / entries_per_page);
93 unsigned long page_offset = (index % entries_per_page) * entry_size;
94
95 return (page_number * page_size) + page_offset;
96 }
97
98 bfd_boolean
99 bfd_sym_mkobject (abfd)
100 bfd *abfd ATTRIBUTE_UNUSED;
101 {
102 return 1;
103 }
104
105 void
106 bfd_sym_print_symbol (abfd, afile, symbol, how)
107 bfd *abfd ATTRIBUTE_UNUSED;
108 PTR afile ATTRIBUTE_UNUSED;
109 asymbol *symbol ATTRIBUTE_UNUSED;
110 bfd_print_symbol_type how ATTRIBUTE_UNUSED;
111 {
112 return;
113 }
114
115 bfd_boolean
116 bfd_sym_valid (abfd)
117 bfd *abfd;
118 {
119 if (abfd == NULL || abfd->xvec == NULL)
120 return 0;
121
122 return abfd->xvec == &sym_vec;
123 }
124
125 unsigned char *
126 bfd_sym_read_name_table (abfd, dshb)
127 bfd *abfd;
128 bfd_sym_header_block *dshb;
129 {
130 unsigned char *rstr;
131 long ret;
132 size_t table_size = dshb->dshb_nte.dti_page_count * dshb->dshb_page_size;
133 size_t table_offset = dshb->dshb_nte.dti_first_page * dshb->dshb_page_size;
134
135 rstr = (unsigned char *) bfd_alloc (abfd, table_size);
136 if (rstr == NULL)
137 return rstr;
138
139 bfd_seek (abfd, table_offset, SEEK_SET);
140 ret = bfd_bread (rstr, table_size, abfd);
141 if (ret < 0 || (unsigned long) ret != table_size)
142 {
143 bfd_release (abfd, rstr);
144 return NULL;
145 }
146
147 return rstr;
148 }
149
150 void
151 bfd_sym_parse_file_reference_v32 (buf, len, entry)
152 unsigned char *buf;
153 size_t len;
154 bfd_sym_file_reference *entry;
155 {
156 BFD_ASSERT (len == 6);
157
158 entry->fref_frte_index = bfd_getb16 (buf);
159 entry->fref_offset = bfd_getb32 (buf + 2);
160 }
161
162 void
163 bfd_sym_parse_disk_table_v32 (buf, len, table)
164 unsigned char *buf;
165 size_t len;
166 bfd_sym_table_info *table;
167 {
168 BFD_ASSERT (len == 8);
169
170 table->dti_first_page = bfd_getb16 (buf);
171 table->dti_page_count = bfd_getb16 (buf + 2);
172 table->dti_object_count = bfd_getb32 (buf + 4);
173 }
174
175 void
176 bfd_sym_parse_header_v32 (buf, len, header)
177 unsigned char *buf;
178 size_t len;
179 bfd_sym_header_block *header;
180 {
181 BFD_ASSERT (len == 154);
182
183 memcpy (header->dshb_id, buf, 32);
184 header->dshb_page_size = bfd_getb16 (buf + 32);
185 header->dshb_hash_page = bfd_getb16 (buf + 34);
186 header->dshb_root_mte = bfd_getb16 (buf + 36);
187 header->dshb_mod_date = bfd_getb32 (buf + 38);
188
189 bfd_sym_parse_disk_table_v32 (buf + 42, 8, &header->dshb_frte);
190 bfd_sym_parse_disk_table_v32 (buf + 50, 8, &header->dshb_rte);
191 bfd_sym_parse_disk_table_v32 (buf + 58, 8, &header->dshb_mte);
192 bfd_sym_parse_disk_table_v32 (buf + 66, 8, &header->dshb_cmte);
193 bfd_sym_parse_disk_table_v32 (buf + 74, 8, &header->dshb_cvte);
194 bfd_sym_parse_disk_table_v32 (buf + 82, 8, &header->dshb_csnte);
195 bfd_sym_parse_disk_table_v32 (buf + 90, 8, &header->dshb_clte);
196 bfd_sym_parse_disk_table_v32 (buf + 98, 8, &header->dshb_ctte);
197 bfd_sym_parse_disk_table_v32 (buf + 106, 8, &header->dshb_tte);
198 bfd_sym_parse_disk_table_v32 (buf + 114, 8, &header->dshb_nte);
199 bfd_sym_parse_disk_table_v32 (buf + 122, 8, &header->dshb_tinfo);
200 bfd_sym_parse_disk_table_v32 (buf + 130, 8, &header->dshb_fite);
201 bfd_sym_parse_disk_table_v32 (buf + 138, 8, &header->dshb_const);
202
203 memcpy (&header->dshb_file_creator, buf + 146, 4);
204 memcpy (&header->dshb_file_type, buf + 150, 4);
205 }
206
207 int
208 bfd_sym_read_header_v32 (abfd, header)
209 bfd *abfd;
210 bfd_sym_header_block *header;
211 {
212 unsigned char buf[154];
213 long ret;
214
215 ret = bfd_bread (buf, 154, abfd);
216 if (ret != 154)
217 return -1;
218
219 bfd_sym_parse_header_v32 (buf, 154, header);
220
221 return 0;
222 }
223
224 int
225 bfd_sym_read_header_v34 (abfd, header)
226 bfd *abfd ATTRIBUTE_UNUSED;
227 bfd_sym_header_block *header ATTRIBUTE_UNUSED;
228 {
229 abort ();
230 }
231
232 int
233 bfd_sym_read_header (abfd, header, version)
234 bfd *abfd;
235 bfd_sym_header_block *header;
236 bfd_sym_version version;
237 {
238 switch (version)
239 {
240 case BFD_SYM_VERSION_3_5:
241 case BFD_SYM_VERSION_3_4:
242 return bfd_sym_read_header_v34 (abfd, header);
243 case BFD_SYM_VERSION_3_3:
244 case BFD_SYM_VERSION_3_2:
245 return bfd_sym_read_header_v32 (abfd, header);
246 case BFD_SYM_VERSION_3_1:
247 default:
248 return FALSE;
249 }
250 }
251
252 int
253 bfd_sym_read_version (abfd, version)
254 bfd *abfd;
255 bfd_sym_version *version;
256 {
257 unsigned char version_string[32];
258 long ret;
259
260 ret = bfd_bread (version_string, sizeof (version_string), abfd);
261 if (ret != sizeof (version_string))
262 return -1;
263
264 if (pstrcmp (version_string, BFD_SYM_VERSION_STR_3_1) == 0)
265 *version = BFD_SYM_VERSION_3_1;
266 else if (pstrcmp (version_string, BFD_SYM_VERSION_STR_3_2) == 0)
267 *version = BFD_SYM_VERSION_3_2;
268 else if (pstrcmp (version_string, BFD_SYM_VERSION_STR_3_3) == 0)
269 *version = BFD_SYM_VERSION_3_3;
270 else if (pstrcmp (version_string, BFD_SYM_VERSION_STR_3_4) == 0)
271 *version = BFD_SYM_VERSION_3_4;
272 else if (pstrcmp (version_string, BFD_SYM_VERSION_STR_3_5) == 0)
273 *version = BFD_SYM_VERSION_3_5;
274 else
275 return -1;
276
277 return 0;
278 }
279
280 void
281 bfd_sym_display_table_summary (f, dti, name)
282 FILE *f;
283 bfd_sym_table_info *dti;
284 const char *name;
285 {
286 fprintf (f, "%-6s %13ld %13ld %13ld\n",
287 name,
288 dti->dti_first_page,
289 dti->dti_page_count,
290 dti->dti_object_count);
291 }
292
293 void
294 bfd_sym_display_header (f, dshb)
295 FILE *f;
296 bfd_sym_header_block *dshb;
297 {
298 fprintf (f, " Version: %.*s\n", dshb->dshb_id[0], dshb->dshb_id + 1);
299 fprintf (f, " Page Size: 0x%x\n", dshb->dshb_page_size);
300 fprintf (f, " Hash Page: %lu\n", dshb->dshb_hash_page);
301 fprintf (f, " Root MTE: %lu\n", dshb->dshb_root_mte);
302 fprintf (f, " Modification Date: ");
303 fprintf (f, "[unimplemented]");
304 fprintf (f, " (0x%lx)\n", dshb->dshb_mod_date);
305
306 fprintf (f, " File Creator: %.4s Type: %.4s\n\n",
307 dshb->dshb_file_creator, dshb->dshb_file_type);
308
309 fprintf (f, "Table Name First Page Page Count Object Count\n");
310 fprintf (f, "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n");
311
312 bfd_sym_display_table_summary (f, &dshb->dshb_nte, "NTE");
313 bfd_sym_display_table_summary (f, &dshb->dshb_rte, "RTE");
314 bfd_sym_display_table_summary (f, &dshb->dshb_mte, "MTE");
315 bfd_sym_display_table_summary (f, &dshb->dshb_frte, "FRTE");
316 bfd_sym_display_table_summary (f, &dshb->dshb_cmte, "CMTE");
317 bfd_sym_display_table_summary (f, &dshb->dshb_cvte, "CVTE");
318 bfd_sym_display_table_summary (f, &dshb->dshb_csnte, "CSNTE");
319 bfd_sym_display_table_summary (f, &dshb->dshb_clte, "CLTE");
320 bfd_sym_display_table_summary (f, &dshb->dshb_ctte, "CTTE");
321 bfd_sym_display_table_summary (f, &dshb->dshb_tte, "TTE");
322 bfd_sym_display_table_summary (f, &dshb->dshb_tinfo, "TINFO");
323 bfd_sym_display_table_summary (f, &dshb->dshb_fite, "FITE");
324 bfd_sym_display_table_summary (f, &dshb->dshb_const, "CONST");
325
326 fprintf (f, "\n");
327 }
328
329 void
330 bfd_sym_parse_resources_table_entry_v32 (buf, len, entry)
331 unsigned char *buf;
332 size_t len;
333 bfd_sym_resources_table_entry *entry;
334 {
335 BFD_ASSERT (len == 18);
336
337 memcpy (&entry->rte_res_type, buf, 4);
338 entry->rte_res_number = bfd_getb16 (buf + 4);
339 entry->rte_nte_index = bfd_getb32 (buf + 6);
340 entry->rte_mte_first = bfd_getb16 (buf + 10);
341 entry->rte_mte_last = bfd_getb16 (buf + 12);
342 entry->rte_res_size = bfd_getb32 (buf + 14);
343 }
344
345 void
346 bfd_sym_parse_modules_table_entry_v33 (buf, len, entry)
347 unsigned char *buf;
348 size_t len;
349 bfd_sym_modules_table_entry *entry;
350 {
351 BFD_ASSERT (len == 46);
352
353 entry->mte_rte_index = bfd_getb16 (buf);
354 entry->mte_res_offset = bfd_getb32 (buf + 2);
355 entry->mte_size = bfd_getb32 (buf + 6);
356 entry->mte_kind = buf[10];
357 entry->mte_scope = buf[11];
358 entry->mte_parent = bfd_getb16 (buf + 12);
359 bfd_sym_parse_file_reference_v32 (buf + 14, 6, &entry->mte_imp_fref);
360 entry->mte_imp_end = bfd_getb32 (buf + 20);
361 entry->mte_nte_index = bfd_getb32 (buf + 24);
362 entry->mte_cmte_index = bfd_getb16 (buf + 28);
363 entry->mte_cvte_index = bfd_getb32 (buf + 30);
364 entry->mte_clte_index = bfd_getb16 (buf + 34);
365 entry->mte_ctte_index = bfd_getb16 (buf + 36);
366 entry->mte_csnte_idx_1 = bfd_getb32 (buf + 38);
367 entry->mte_csnte_idx_2 = bfd_getb32 (buf + 42);
368 }
369
370 void
371 bfd_sym_parse_file_references_table_entry_v32 (buf, len, entry)
372 unsigned char *buf;
373 size_t len;
374 bfd_sym_file_references_table_entry *entry;
375 {
376 unsigned int type;
377
378 BFD_ASSERT (len == 10);
379
380 memset (entry, 0, sizeof (bfd_sym_file_references_table_entry));
381 type = bfd_getb16 (buf);
382
383 switch (type)
384 {
385 case BFD_SYM_END_OF_LIST_3_2:
386 entry->generic.type = BFD_SYM_END_OF_LIST;
387 break;
388
389 case BFD_SYM_FILE_NAME_INDEX_3_2:
390 entry->filename.type = BFD_SYM_FILE_NAME_INDEX;
391 entry->filename.nte_index = bfd_getb32 (buf + 2);
392 entry->filename.mod_date = bfd_getb32 (buf + 6);
393 break;
394
395 default:
396 entry->entry.mte_index = type;
397 entry->entry.file_offset = bfd_getb32 (buf + 2);
398 }
399 }
400
401 void
402 bfd_sym_parse_contained_modules_table_entry_v32 (buf, len, entry)
403 unsigned char *buf;
404 size_t len;
405 bfd_sym_contained_modules_table_entry *entry;
406 {
407 unsigned int type;
408
409 BFD_ASSERT (len == 6);
410
411 memset (entry, 0, sizeof (bfd_sym_contained_modules_table_entry));
412 type = bfd_getb16 (buf);
413
414 switch (type)
415 {
416 case BFD_SYM_END_OF_LIST_3_2:
417 entry->generic.type = BFD_SYM_END_OF_LIST;
418 break;
419
420 default:
421 entry->entry.mte_index = type;
422 entry->entry.nte_index = bfd_getb32 (buf + 2);
423 break;
424 }
425 }
426
427 void
428 bfd_sym_parse_contained_variables_table_entry_v32 (buf, len, entry)
429 unsigned char *buf;
430 size_t len;
431 bfd_sym_contained_variables_table_entry *entry;
432 {
433 unsigned int type;
434
435 BFD_ASSERT (len == 26);
436
437 memset (entry, 0, sizeof (bfd_sym_contained_variables_table_entry));
438 type = bfd_getb16 (buf);
439
440 switch (type)
441 {
442 case BFD_SYM_END_OF_LIST_3_2:
443 entry->generic.type = BFD_SYM_END_OF_LIST;
444 break;
445
446 case BFD_SYM_SOURCE_FILE_CHANGE_3_2:
447 entry->file.type = BFD_SYM_SOURCE_FILE_CHANGE;
448 bfd_sym_parse_file_reference_v32 (buf + 2, 6, &entry->file.fref);
449 break;
450
451 default:
452 entry->entry.tte_index = type;
453 entry->entry.nte_index = bfd_getb32 (buf + 2);
454 entry->entry.file_delta = bfd_getb16 (buf + 6);
455 entry->entry.scope = buf[8];
456 entry->entry.la_size = buf[9];
457
458 if (entry->entry.la_size == BFD_SYM_CVTE_SCA)
459 {
460 entry->entry.address.scstruct.sca_kind = buf[10];
461 entry->entry.address.scstruct.sca_class = buf[11];
462 entry->entry.address.scstruct.sca_offset = bfd_getb32 (buf + 12);
463 }
464 else if (entry->entry.la_size <= BFD_SYM_CVTE_SCA)
465 {
466 memcpy (&entry->entry.address.lastruct.la, buf + 10, BFD_SYM_CVTE_SCA);
467 entry->entry.address.lastruct.la_kind = buf[23];
468 }
469 else if (entry->entry.la_size == BFD_SYM_CVTE_BIG_LA)
470 {
471 entry->entry.address.biglastruct.big_la = bfd_getb32 (buf + 10);
472 entry->entry.address.biglastruct.big_la_kind = buf[12];
473 }
474 }
475 }
476
477 void
478 bfd_sym_parse_contained_statements_table_entry_v32 (buf, len, entry)
479 unsigned char *buf;
480 size_t len;
481 bfd_sym_contained_statements_table_entry *entry;
482 {
483 unsigned int type;
484
485 BFD_ASSERT (len == 8);
486
487 memset (entry, 0, sizeof (bfd_sym_contained_statements_table_entry));
488 type = bfd_getb16 (buf);
489
490 switch (type)
491 {
492 case BFD_SYM_END_OF_LIST_3_2:
493 entry->generic.type = BFD_SYM_END_OF_LIST;
494 break;
495
496 case BFD_SYM_SOURCE_FILE_CHANGE_3_2:
497 entry->file.type = BFD_SYM_SOURCE_FILE_CHANGE;
498 bfd_sym_parse_file_reference_v32 (buf + 2, 6, &entry->file.fref);
499 break;
500
501 default:
502 entry->entry.mte_index = type;
503 entry->entry.mte_offset = bfd_getb16 (buf + 2);
504 entry->entry.file_delta = bfd_getb32 (buf + 4);
505 break;
506 }
507 }
508
509 void
510 bfd_sym_parse_contained_labels_table_entry_v32 (buf, len, entry)
511 unsigned char *buf;
512 size_t len;
513 bfd_sym_contained_labels_table_entry *entry;
514 {
515 unsigned int type;
516
517 BFD_ASSERT (len == 12);
518
519 memset (entry, 0, sizeof (bfd_sym_contained_labels_table_entry));
520 type = bfd_getb16 (buf);
521
522 switch (type)
523 {
524 case BFD_SYM_END_OF_LIST_3_2:
525 entry->generic.type = BFD_SYM_END_OF_LIST;
526 break;
527
528 case BFD_SYM_SOURCE_FILE_CHANGE_3_2:
529 entry->file.type = BFD_SYM_SOURCE_FILE_CHANGE;
530 bfd_sym_parse_file_reference_v32 (buf + 2, 6, &entry->file.fref);
531 break;
532
533 default:
534 entry->entry.mte_index = type;
535 entry->entry.mte_offset = bfd_getb16 (buf + 2);
536 entry->entry.nte_index = bfd_getb32 (buf + 4);
537 entry->entry.file_delta = bfd_getb16 (buf + 8);
538 entry->entry.scope = bfd_getb16 (buf + 10);
539 break;
540 }
541 }
542
543 void
544 bfd_sym_parse_type_table_entry_v32 (buf, len, entry)
545 unsigned char *buf;
546 size_t len;
547 bfd_sym_type_table_entry *entry;
548 {
549 BFD_ASSERT (len == 4);
550
551 *entry = bfd_getb32 (buf);
552 }
553
554 int
555 bfd_sym_fetch_resources_table_entry (abfd, entry, index)
556 bfd *abfd;
557 bfd_sym_resources_table_entry *entry;
558 unsigned long index;
559 {
560 void (*parser) PARAMS ((unsigned char *, size_t,
561 bfd_sym_resources_table_entry *));
562 unsigned long offset;
563 unsigned long entry_size;
564 unsigned char buf[18];
565 bfd_sym_data_struct *sdata = NULL;
566
567 parser = NULL;
568 BFD_ASSERT (bfd_sym_valid (abfd));
569 sdata = abfd->tdata.sym_data;
570
571 if (index == 0)
572 return -1;
573
574 switch (sdata->version)
575 {
576 case BFD_SYM_VERSION_3_5:
577 case BFD_SYM_VERSION_3_4:
578 return -1;
579
580 case BFD_SYM_VERSION_3_3:
581 case BFD_SYM_VERSION_3_2:
582 entry_size = 18;
583 parser = bfd_sym_parse_resources_table_entry_v32;
584 break;
585
586 case BFD_SYM_VERSION_3_1:
587 default:
588 return -1;
589 }
590 if (parser == NULL)
591 return -1;
592
593 offset = compute_offset (sdata->header.dshb_rte.dti_first_page,
594 sdata->header.dshb_page_size,
595 entry_size, index);
596
597 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
598 return -1;
599 if (bfd_bread (buf, entry_size, abfd) != entry_size)
600 return -1;
601
602 (*parser) (buf, entry_size, entry);
603
604 return 0;
605 }
606
607 int
608 bfd_sym_fetch_modules_table_entry (abfd, entry, index)
609 bfd *abfd;
610 bfd_sym_modules_table_entry *entry;
611 unsigned long index;
612 {
613 void (*parser) PARAMS ((unsigned char *, size_t,
614 bfd_sym_modules_table_entry *));
615 unsigned long offset;
616 unsigned long entry_size;
617 unsigned char buf[46];
618 bfd_sym_data_struct *sdata = NULL;
619
620 parser = NULL;
621 BFD_ASSERT (bfd_sym_valid (abfd));
622 sdata = abfd->tdata.sym_data;
623
624 if (index == 0)
625 return -1;
626
627 switch (sdata->version)
628 {
629 case BFD_SYM_VERSION_3_5:
630 case BFD_SYM_VERSION_3_4:
631 return -1;
632
633 case BFD_SYM_VERSION_3_3:
634 entry_size = 46;
635 parser = bfd_sym_parse_modules_table_entry_v33;
636 break;
637
638 case BFD_SYM_VERSION_3_2:
639 case BFD_SYM_VERSION_3_1:
640 default:
641 return -1;
642 }
643 if (parser == NULL)
644 return -1;
645
646 offset = compute_offset (sdata->header.dshb_mte.dti_first_page,
647 sdata->header.dshb_page_size,
648 entry_size, index);
649
650 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
651 return -1;
652 if (bfd_bread (buf, entry_size, abfd) != entry_size)
653 return -1;
654
655 (*parser) (buf, entry_size, entry);
656
657 return 0;
658 }
659
660 int
661 bfd_sym_fetch_file_references_table_entry (abfd, entry, index)
662 bfd *abfd;
663 bfd_sym_file_references_table_entry *entry;
664 unsigned long index;
665 {
666 void (*parser) PARAMS ((unsigned char *, size_t,
667 bfd_sym_file_references_table_entry *));
668 unsigned long offset;
669 unsigned long entry_size = 0;
670 unsigned char buf[8];
671 bfd_sym_data_struct *sdata = NULL;
672
673 parser = NULL;
674 BFD_ASSERT (bfd_sym_valid (abfd));
675 sdata = abfd->tdata.sym_data;
676
677 if (index == 0)
678 return -1;
679
680 switch (sdata->version)
681 {
682 case BFD_SYM_VERSION_3_3:
683 case BFD_SYM_VERSION_3_2:
684 entry_size = 10;
685 parser = bfd_sym_parse_file_references_table_entry_v32;
686 break;
687
688 case BFD_SYM_VERSION_3_5:
689 case BFD_SYM_VERSION_3_4:
690 case BFD_SYM_VERSION_3_1:
691 default:
692 break;
693 }
694
695 if (parser == NULL)
696 return -1;
697
698 offset = compute_offset (sdata->header.dshb_frte.dti_first_page,
699 sdata->header.dshb_page_size,
700 entry_size, index);
701
702 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
703 return -1;
704 if (bfd_bread (buf, entry_size, abfd) != entry_size)
705 return -1;
706
707 (*parser) (buf, entry_size, entry);
708
709 return 0;
710 }
711
712 int
713 bfd_sym_fetch_contained_modules_table_entry (abfd, entry, index)
714 bfd *abfd;
715 bfd_sym_contained_modules_table_entry *entry;
716 unsigned long index;
717 {
718 void (*parser) PARAMS ((unsigned char *, size_t,
719 bfd_sym_contained_modules_table_entry *));
720 unsigned long offset;
721 unsigned long entry_size = 0;
722 unsigned char buf[6];
723 bfd_sym_data_struct *sdata = NULL;
724
725 parser = NULL;
726 BFD_ASSERT (bfd_sym_valid (abfd));
727 sdata = abfd->tdata.sym_data;
728
729 if (index == 0)
730 return -1;
731
732 switch (sdata->version)
733 {
734 case BFD_SYM_VERSION_3_3:
735 case BFD_SYM_VERSION_3_2:
736 entry_size = 6;
737 parser = bfd_sym_parse_contained_modules_table_entry_v32;
738 break;
739
740 case BFD_SYM_VERSION_3_5:
741 case BFD_SYM_VERSION_3_4:
742 case BFD_SYM_VERSION_3_1:
743 default:
744 break;
745 }
746
747 if (parser == NULL)
748 return -1;
749
750 offset = compute_offset (sdata->header.dshb_cmte.dti_first_page,
751 sdata->header.dshb_page_size,
752 entry_size, index);
753
754 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
755 return -1;
756 if (bfd_bread (buf, entry_size, abfd) != entry_size)
757 return -1;
758
759 (*parser) (buf, entry_size, entry);
760
761 return 0;
762 }
763
764 int
765 bfd_sym_fetch_contained_variables_table_entry (abfd, entry, index)
766 bfd *abfd;
767 bfd_sym_contained_variables_table_entry *entry;
768 unsigned long index;
769 {
770 void (*parser) PARAMS ((unsigned char *, size_t,
771 bfd_sym_contained_variables_table_entry *));
772 unsigned long offset;
773 unsigned long entry_size = 0;
774 unsigned char buf[26];
775 bfd_sym_data_struct *sdata = NULL;
776
777 parser = NULL;
778 BFD_ASSERT (bfd_sym_valid (abfd));
779 sdata = abfd->tdata.sym_data;
780
781 if (index == 0)
782 return -1;
783
784 switch (sdata->version)
785 {
786 case BFD_SYM_VERSION_3_3:
787 case BFD_SYM_VERSION_3_2:
788 entry_size = 26;
789 parser = bfd_sym_parse_contained_variables_table_entry_v32;
790 break;
791
792 case BFD_SYM_VERSION_3_5:
793 case BFD_SYM_VERSION_3_4:
794 case BFD_SYM_VERSION_3_1:
795 default:
796 break;
797 }
798
799 if (parser == NULL)
800 return -1;
801
802 offset = compute_offset (sdata->header.dshb_cvte.dti_first_page,
803 sdata->header.dshb_page_size,
804 entry_size, index);
805
806 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
807 return -1;
808 if (bfd_bread (buf, entry_size, abfd) != entry_size)
809 return -1;
810
811 (*parser) (buf, entry_size, entry);
812
813 return 0;
814 }
815
816 int
817 bfd_sym_fetch_contained_statements_table_entry (abfd, entry, index)
818 bfd *abfd;
819 bfd_sym_contained_statements_table_entry *entry;
820 unsigned long index;
821 {
822 void (*parser) PARAMS ((unsigned char *, size_t,
823 bfd_sym_contained_statements_table_entry *));
824 unsigned long offset;
825 unsigned long entry_size = 0;
826 unsigned char buf[8];
827 bfd_sym_data_struct *sdata = NULL;
828
829 parser = NULL;
830 BFD_ASSERT (bfd_sym_valid (abfd));
831 sdata = abfd->tdata.sym_data;
832
833 if (index == 0)
834 return -1;
835
836 switch (sdata->version)
837 {
838 case BFD_SYM_VERSION_3_3:
839 case BFD_SYM_VERSION_3_2:
840 entry_size = 8;
841 parser = bfd_sym_parse_contained_statements_table_entry_v32;
842 break;
843
844 case BFD_SYM_VERSION_3_5:
845 case BFD_SYM_VERSION_3_4:
846 case BFD_SYM_VERSION_3_1:
847 default:
848 break;
849 }
850
851 if (parser == NULL)
852 return -1;
853
854 offset = compute_offset (sdata->header.dshb_csnte.dti_first_page,
855 sdata->header.dshb_page_size,
856 entry_size, index);
857
858 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
859 return -1;
860 if (bfd_bread (buf, entry_size, abfd) != entry_size)
861 return -1;
862
863 (*parser) (buf, entry_size, entry);
864
865 return 0;
866 }
867
868 int
869 bfd_sym_fetch_contained_labels_table_entry (abfd, entry, index)
870 bfd *abfd;
871 bfd_sym_contained_labels_table_entry *entry;
872 unsigned long index;
873 {
874 void (*parser) PARAMS ((unsigned char *, size_t,
875 bfd_sym_contained_labels_table_entry *));
876 unsigned long offset;
877 unsigned long entry_size = 0;
878 unsigned char buf[12];
879 bfd_sym_data_struct *sdata = NULL;
880
881 parser = NULL;
882 BFD_ASSERT (bfd_sym_valid (abfd));
883 sdata = abfd->tdata.sym_data;
884
885 if (index == 0)
886 return -1;
887
888 switch (sdata->version)
889 {
890 case BFD_SYM_VERSION_3_3:
891 case BFD_SYM_VERSION_3_2:
892 entry_size = 12;
893 parser = bfd_sym_parse_contained_labels_table_entry_v32;
894 break;
895
896 case BFD_SYM_VERSION_3_5:
897 case BFD_SYM_VERSION_3_4:
898 case BFD_SYM_VERSION_3_1:
899 default:
900 break;
901 }
902
903 if (parser == NULL)
904 return -1;
905
906 offset = compute_offset (sdata->header.dshb_clte.dti_first_page,
907 sdata->header.dshb_page_size,
908 entry_size, index);
909
910 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
911 return -1;
912 if (bfd_bread (buf, entry_size, abfd) != entry_size)
913 return -1;
914
915 (*parser) (buf, entry_size, entry);
916
917 return 0;
918 }
919
920 int
921 bfd_sym_fetch_contained_types_table_entry (abfd, entry, index)
922 bfd *abfd;
923 bfd_sym_contained_types_table_entry *entry;
924 unsigned long index;
925 {
926 void (*parser) PARAMS ((unsigned char *, size_t,
927 bfd_sym_contained_types_table_entry *));
928 unsigned long offset;
929 unsigned long entry_size = 0;
930 unsigned char buf[0];
931 bfd_sym_data_struct *sdata = NULL;
932
933 parser = NULL;
934 BFD_ASSERT (bfd_sym_valid (abfd));
935 sdata = abfd->tdata.sym_data;
936
937 if (index == 0)
938 return -1;
939
940 switch (sdata->version)
941 {
942 case BFD_SYM_VERSION_3_3:
943 case BFD_SYM_VERSION_3_2:
944 entry_size = 0;
945 parser = NULL;
946 break;
947
948 case BFD_SYM_VERSION_3_5:
949 case BFD_SYM_VERSION_3_4:
950 case BFD_SYM_VERSION_3_1:
951 default:
952 break;
953 }
954
955 if (parser == NULL)
956 return -1;
957
958 offset = compute_offset (sdata->header.dshb_ctte.dti_first_page,
959 sdata->header.dshb_page_size,
960 entry_size, index);
961
962 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
963 return -1;
964 if (bfd_bread (buf, entry_size, abfd) != entry_size)
965 return -1;
966
967 (*parser) (buf, entry_size, entry);
968
969 return 0;
970 }
971
972 int
973 bfd_sym_fetch_file_references_index_table_entry (abfd, entry, index)
974 bfd *abfd;
975 bfd_sym_file_references_index_table_entry *entry;
976 unsigned long index;
977 {
978 void (*parser) PARAMS ((unsigned char *, size_t,
979 bfd_sym_file_references_index_table_entry *));
980 unsigned long offset;
981 unsigned long entry_size = 0;
982 unsigned char buf[0];
983 bfd_sym_data_struct *sdata = NULL;
984
985 parser = NULL;
986 BFD_ASSERT (bfd_sym_valid (abfd));
987 sdata = abfd->tdata.sym_data;
988
989 if (index == 0)
990 return -1;
991
992 switch (sdata->version)
993 {
994 case BFD_SYM_VERSION_3_3:
995 case BFD_SYM_VERSION_3_2:
996 entry_size = 0;
997 parser = NULL;
998 break;
999
1000 case BFD_SYM_VERSION_3_5:
1001 case BFD_SYM_VERSION_3_4:
1002 case BFD_SYM_VERSION_3_1:
1003 default:
1004 break;
1005 }
1006
1007 if (parser == NULL)
1008 return -1;
1009
1010 offset = compute_offset (sdata->header.dshb_fite.dti_first_page,
1011 sdata->header.dshb_page_size,
1012 entry_size, index);
1013
1014 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
1015 return -1;
1016 if (bfd_bread (buf, entry_size, abfd) != entry_size)
1017 return -1;
1018
1019 (*parser) (buf, entry_size, entry);
1020
1021 return 0;
1022 }
1023
1024 int
1025 bfd_sym_fetch_constant_pool_entry (abfd, entry, index)
1026 bfd *abfd;
1027 bfd_sym_constant_pool_entry *entry;
1028 unsigned long index;
1029 {
1030 void (*parser) PARAMS ((unsigned char *, size_t,
1031 bfd_sym_constant_pool_entry *));
1032 unsigned long offset;
1033 unsigned long entry_size = 0;
1034 unsigned char buf[0];
1035 bfd_sym_data_struct *sdata = NULL;
1036
1037 parser = NULL;
1038 BFD_ASSERT (bfd_sym_valid (abfd));
1039 sdata = abfd->tdata.sym_data;
1040
1041 if (index == 0)
1042 return -1;
1043
1044 switch (sdata->version)
1045 {
1046 case BFD_SYM_VERSION_3_3:
1047 case BFD_SYM_VERSION_3_2:
1048 entry_size = 0;
1049 parser = NULL;
1050 break;
1051
1052 case BFD_SYM_VERSION_3_5:
1053 case BFD_SYM_VERSION_3_4:
1054 case BFD_SYM_VERSION_3_1:
1055 default:
1056 break;
1057 }
1058
1059 if (parser == NULL)
1060 return -1;
1061
1062 offset = compute_offset (sdata->header.dshb_fite.dti_first_page,
1063 sdata->header.dshb_page_size,
1064 entry_size, index);
1065
1066 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
1067 return -1;
1068 if (bfd_bread (buf, entry_size, abfd) != entry_size)
1069 return -1;
1070
1071 (*parser) (buf, entry_size, entry);
1072
1073 return 0;
1074 }
1075
1076 int
1077 bfd_sym_fetch_type_table_entry (abfd, entry, index)
1078 bfd *abfd;
1079 bfd_sym_type_table_entry *entry;
1080 unsigned long index;
1081 {
1082 void (*parser) PARAMS ((unsigned char *, size_t,
1083 bfd_sym_type_table_entry *));
1084 unsigned long offset;
1085 unsigned long entry_size = 0;
1086 unsigned char buf[4];
1087 bfd_sym_data_struct *sdata = NULL;
1088
1089 parser = NULL;
1090 BFD_ASSERT (bfd_sym_valid (abfd));
1091 sdata = abfd->tdata.sym_data;
1092
1093 switch (sdata->version)
1094 {
1095 case BFD_SYM_VERSION_3_3:
1096 case BFD_SYM_VERSION_3_2:
1097 entry_size = 4;
1098 parser = bfd_sym_parse_type_table_entry_v32;
1099 break;
1100
1101 case BFD_SYM_VERSION_3_5:
1102 case BFD_SYM_VERSION_3_4:
1103 case BFD_SYM_VERSION_3_1:
1104 default:
1105 break;
1106 }
1107
1108 if (parser == NULL)
1109 return -1;
1110
1111 offset = compute_offset (sdata->header.dshb_tte.dti_first_page,
1112 sdata->header.dshb_page_size,
1113 entry_size, index);
1114
1115 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
1116 return -1;
1117 if (bfd_bread (buf, entry_size, abfd) != entry_size)
1118 return -1;
1119
1120 (*parser) (buf, entry_size, entry);
1121
1122 return 0;
1123 }
1124
1125 int
1126 bfd_sym_fetch_type_information_table_entry (abfd, entry, offset)
1127 bfd *abfd;
1128 bfd_sym_type_information_table_entry *entry;
1129 unsigned long offset;
1130 {
1131 unsigned char buf[4];
1132 bfd_sym_data_struct *sdata = NULL;
1133
1134 BFD_ASSERT (bfd_sym_valid (abfd));
1135 sdata = abfd->tdata.sym_data;
1136
1137 if (offset == 0)
1138 return -1;
1139
1140 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
1141 return -1;
1142
1143 if (bfd_bread (buf, 4, abfd) != 4)
1144 return -1;
1145 entry->nte_index = bfd_getb32 (buf);
1146
1147 if (bfd_bread (buf, 2, abfd) != 2)
1148 return -1;
1149 entry->physical_size = bfd_getb16 (buf);
1150
1151 if (entry->physical_size & 0x8000)
1152 {
1153 if (bfd_bread (buf, 4, abfd) != 4)
1154 return -1;
1155 entry->physical_size &= 0x7fff;
1156 entry->logical_size = bfd_getb32 (buf);
1157 entry->offset = offset + 10;
1158 }
1159 else
1160 {
1161 if (bfd_bread (buf, 2, abfd) != 2)
1162 return -1;
1163 entry->physical_size &= 0x7fff;
1164 entry->logical_size = bfd_getb16 (buf);
1165 entry->offset = offset + 8;
1166 }
1167
1168 return 0;
1169 }
1170
1171 int
1172 bfd_sym_fetch_type_table_information (abfd, entry, index)
1173 bfd *abfd;
1174 bfd_sym_type_information_table_entry *entry;
1175 unsigned long index;
1176 {
1177 bfd_sym_type_table_entry tindex;
1178 bfd_sym_data_struct *sdata = NULL;
1179
1180 BFD_ASSERT (bfd_sym_valid (abfd));
1181 sdata = abfd->tdata.sym_data;
1182
1183 if (sdata->header.dshb_tte.dti_object_count <= 99)
1184 return -1;
1185 if (index < 100)
1186 return -1;
1187
1188 if (bfd_sym_fetch_type_table_entry (abfd, &tindex, index - 100) < 0)
1189 return -1;
1190 if (bfd_sym_fetch_type_information_table_entry (abfd, entry, tindex) < 0)
1191 return -1;
1192
1193 return 0;
1194 }
1195
1196 const unsigned char *
1197 bfd_sym_symbol_name (abfd, index)
1198 bfd *abfd;
1199 unsigned long index;
1200 {
1201 bfd_sym_data_struct *sdata = NULL;
1202
1203 BFD_ASSERT (bfd_sym_valid (abfd));
1204 sdata = abfd->tdata.sym_data;
1205
1206 if (index == 0)
1207 return "";
1208
1209 index *= 2;
1210 if ((index / sdata->header.dshb_page_size)
1211 > sdata->header.dshb_nte.dti_page_count)
1212 return "\009[INVALID]";
1213
1214 return (const unsigned char *) sdata->name_table + index;
1215 }
1216
1217 const unsigned char *
1218 bfd_sym_module_name (abfd, index)
1219 bfd *abfd;
1220 unsigned long index;
1221 {
1222 bfd_sym_modules_table_entry entry;
1223
1224 if (bfd_sym_fetch_modules_table_entry (abfd, &entry, index) < 0)
1225 return "\011[INVALID]";
1226
1227 return bfd_sym_symbol_name (abfd, entry.mte_nte_index);
1228 }
1229
1230 const char *
1231 bfd_sym_unparse_storage_kind (kind)
1232 enum bfd_sym_storage_kind kind;
1233 {
1234 switch (kind)
1235 {
1236 case BFD_SYM_STORAGE_KIND_LOCAL: return "LOCAL";
1237 case BFD_SYM_STORAGE_KIND_VALUE: return "VALUE";
1238 case BFD_SYM_STORAGE_KIND_REFERENCE: return "REFERENCE";
1239 case BFD_SYM_STORAGE_KIND_WITH: return "WITH";
1240 default: return "[UNKNOWN]";
1241 }
1242 }
1243
1244 const char *
1245 bfd_sym_unparse_storage_class (kind)
1246 enum bfd_sym_storage_class kind;
1247 {
1248 switch (kind)
1249 {
1250 case BFD_SYM_STORAGE_CLASS_REGISTER: return "REGISTER";
1251 case BFD_SYM_STORAGE_CLASS_GLOBAL: return "GLOBAL";
1252 case BFD_SYM_STORAGE_CLASS_FRAME_RELATIVE: return "FRAME_RELATIVE";
1253 case BFD_SYM_STORAGE_CLASS_STACK_RELATIVE: return "STACK_RELATIVE";
1254 case BFD_SYM_STORAGE_CLASS_ABSOLUTE: return "ABSOLUTE";
1255 case BFD_SYM_STORAGE_CLASS_CONSTANT: return "CONSTANT";
1256 case BFD_SYM_STORAGE_CLASS_RESOURCE: return "RESOURCE";
1257 case BFD_SYM_STORAGE_CLASS_BIGCONSTANT: return "BIGCONSTANT";
1258 default: return "[UNKNOWN]";
1259 }
1260 }
1261
1262 const char *
1263 bfd_sym_unparse_module_kind (kind)
1264 enum bfd_sym_module_kind kind;
1265 {
1266 switch (kind)
1267 {
1268 case BFD_SYM_MODULE_KIND_NONE: return "NONE";
1269 case BFD_SYM_MODULE_KIND_PROGRAM: return "PROGRAM";
1270 case BFD_SYM_MODULE_KIND_UNIT: return "UNIT";
1271 case BFD_SYM_MODULE_KIND_PROCEDURE: return "PROCEDURE";
1272 case BFD_SYM_MODULE_KIND_FUNCTION: return "FUNCTION";
1273 case BFD_SYM_MODULE_KIND_DATA: return "DATA";
1274 case BFD_SYM_MODULE_KIND_BLOCK: return "BLOCK";
1275 default: return "[UNKNOWN]";
1276 }
1277 }
1278
1279 const char *
1280 bfd_sym_unparse_symbol_scope (scope)
1281 enum bfd_sym_symbol_scope scope;
1282 {
1283 switch (scope)
1284 {
1285 case BFD_SYM_SYMBOL_SCOPE_LOCAL: return "LOCAL";
1286 case BFD_SYM_SYMBOL_SCOPE_GLOBAL: return "GLOBAL";
1287 default:
1288 return "[UNKNOWN]";
1289 }
1290 }
1291
1292 void
1293 bfd_sym_print_file_reference (abfd, f, entry)
1294 bfd *abfd;
1295 FILE *f;
1296 bfd_sym_file_reference *entry;
1297 {
1298 bfd_sym_file_references_table_entry frtentry;
1299 int ret;
1300
1301 ret = bfd_sym_fetch_file_references_table_entry (abfd, &frtentry,
1302 entry->fref_frte_index);
1303 fprintf (f, "FILE ");
1304
1305 if ((ret < 0) || (frtentry.generic.type != BFD_SYM_FILE_NAME_INDEX))
1306 fprintf (f, "[INVALID]");
1307 else
1308 fprintf (f, "\"%.*s\"",
1309 bfd_sym_symbol_name (abfd, frtentry.filename.nte_index)[0],
1310 &bfd_sym_symbol_name (abfd, frtentry.filename.nte_index)[1]);
1311
1312 fprintf (f, " (FRTE %lu)", entry->fref_frte_index);
1313 }
1314
1315 void
1316 bfd_sym_print_resources_table_entry (abfd, f, entry)
1317 bfd *abfd;
1318 FILE *f;
1319 bfd_sym_resources_table_entry *entry;
1320 {
1321 fprintf (f, " \"%.*s\" (NTE %lu), type \"%.4s\", num %u, size %lu, MTE %lu -- %lu",
1322 bfd_sym_symbol_name (abfd, entry->rte_nte_index)[0],
1323 &bfd_sym_symbol_name (abfd, entry->rte_nte_index)[1],
1324 entry->rte_nte_index, entry->rte_res_type, entry->rte_res_number,
1325 entry->rte_res_size, entry->rte_mte_first, entry->rte_mte_last);
1326 }
1327
1328 void
1329 bfd_sym_print_modules_table_entry (abfd, f, entry)
1330 bfd *abfd;
1331 FILE *f;
1332 bfd_sym_modules_table_entry *entry;
1333 {
1334 fprintf (f, "\"%.*s\" (NTE %lu)",
1335 bfd_sym_symbol_name (abfd, entry->mte_nte_index)[0],
1336 &bfd_sym_symbol_name (abfd, entry->mte_nte_index)[1],
1337 entry->mte_nte_index);
1338
1339 fprintf (f, "\n ");
1340
1341 bfd_sym_print_file_reference (abfd, f, &entry->mte_imp_fref);
1342 fprintf (f, " range %lu -- %lu",
1343 entry->mte_imp_fref.fref_offset, entry->mte_imp_end);
1344
1345 fprintf (f, "\n ");
1346
1347 fprintf (f, "kind %s", bfd_sym_unparse_module_kind (entry->mte_kind));
1348 fprintf (f, ", scope %s", bfd_sym_unparse_symbol_scope (entry->mte_scope));
1349
1350 fprintf (f, ", RTE %lu, offset %lu, size %lu",
1351 entry->mte_rte_index, entry->mte_res_offset, entry->mte_size);
1352
1353 fprintf (f, "\n ");
1354
1355 fprintf (f, "CMTE %lu, CVTE %lu, CLTE %lu, CTTE %lu, CSNTE1 %lu, CSNTE2 %lu",
1356 entry->mte_cmte_index, entry->mte_cvte_index,
1357 entry->mte_clte_index, entry->mte_ctte_index,
1358 entry->mte_csnte_idx_1, entry->mte_csnte_idx_2);
1359
1360 if (entry->mte_parent != 0)
1361 fprintf (f, ", parent %lu", entry->mte_parent);
1362 else
1363 fprintf (f, ", no parent");
1364
1365 if (entry->mte_cmte_index != 0)
1366 fprintf (f, ", child %lu", entry->mte_cmte_index);
1367 else
1368 fprintf (f, ", no child");
1369
1370 #if 0
1371 {
1372 MTE bfd_sym_modules_table_entry pentry;
1373
1374 ret = bfd_sym_fetch_modules_table_entry (abfd, &pentry, entry->mte_parent);
1375 if (ret < 0)
1376 fprintf (f, " parent MTE %lu [INVALID]\n", entry->mte_parent);
1377 else
1378 fprintf (f, " parent MTE %lu \"%.*s\"\n",
1379 entry->mte_parent,
1380 bfd_sym_symbol_name (abfd, pentry.mte_nte_index)[0],
1381 &bfd_sym_symbol_name (abfd, pentry.mte_nte_index)[1]);
1382 }
1383 #endif
1384 }
1385
1386 void
1387 bfd_sym_print_file_references_table_entry (abfd, f, entry)
1388 bfd *abfd;
1389 FILE *f;
1390 bfd_sym_file_references_table_entry *entry;
1391 {
1392 switch (entry->generic.type)
1393 {
1394 case BFD_SYM_FILE_NAME_INDEX:
1395 fprintf (f, "FILE \"%.*s\" (NTE %lu), modtime ",
1396 bfd_sym_symbol_name (abfd, entry->filename.nte_index)[0],
1397 &bfd_sym_symbol_name (abfd, entry->filename.nte_index)[1],
1398 entry->filename.nte_index);
1399
1400 fprintf (f, "[UNIMPLEMENTED]");
1401 /* printModDate (entry->filename.mod_date); */
1402 fprintf (f, " (0x%lx)", entry->filename.mod_date);
1403 break;
1404
1405 case BFD_SYM_END_OF_LIST:
1406 fprintf (f, "END");
1407 break;
1408
1409 default:
1410 fprintf (f, "\"%.*s\" (MTE %lu), offset %lu",
1411 bfd_sym_module_name (abfd, entry->entry.mte_index)[0],
1412 &bfd_sym_module_name (abfd, entry->entry.mte_index)[1],
1413 entry->entry.mte_index,
1414 entry->entry.file_offset);
1415 break;
1416 }
1417 }
1418
1419 void
1420 bfd_sym_print_contained_modules_table_entry (abfd, f, entry)
1421 bfd *abfd;
1422 FILE *f;
1423 bfd_sym_contained_modules_table_entry *entry;
1424 {
1425 switch (entry->generic.type)
1426 {
1427 case BFD_SYM_END_OF_LIST:
1428 fprintf (f, "END");
1429 break;
1430
1431 default:
1432 fprintf (f, "\"%.*s\" (MTE %lu, NTE %lu)",
1433 bfd_sym_module_name (abfd, entry->entry.mte_index)[0],
1434 &bfd_sym_module_name (abfd, entry->entry.mte_index)[1],
1435 entry->entry.mte_index,
1436 entry->entry.nte_index);
1437 break;
1438 }
1439 }
1440
1441 void
1442 bfd_sym_print_contained_variables_table_entry (abfd, f, entry)
1443 bfd *abfd;
1444 FILE *f;
1445 bfd_sym_contained_variables_table_entry *entry;
1446 {
1447 if (entry->generic.type == BFD_SYM_END_OF_LIST)
1448 {
1449 fprintf (f, "END");
1450 return;
1451 }
1452
1453 if (entry->generic.type == BFD_SYM_SOURCE_FILE_CHANGE)
1454 {
1455 bfd_sym_print_file_reference (abfd, f, &entry->file.fref);
1456 fprintf (f, " offset %lu", entry->file.fref.fref_offset);
1457 return;
1458 }
1459
1460 fprintf (f, "\"%.*s\" (NTE %lu)",
1461 bfd_sym_symbol_name (abfd, entry->entry.nte_index)[0],
1462 &bfd_sym_symbol_name (abfd, entry->entry.nte_index)[1],
1463 entry->entry.nte_index);
1464
1465 fprintf (f, ", TTE %lu", entry->entry.tte_index);
1466 fprintf (f, ", offset %lu", entry->entry.file_delta);
1467 fprintf (f, ", scope %s", bfd_sym_unparse_symbol_scope (entry->entry.scope));
1468
1469 if (entry->entry.la_size == BFD_SYM_CVTE_SCA)
1470 fprintf (f, ", latype %s, laclass %s, laoffset %lu",
1471 bfd_sym_unparse_storage_kind (entry->entry.address.scstruct.sca_kind),
1472 bfd_sym_unparse_storage_class (entry->entry.address.scstruct.sca_class),
1473 entry->entry.address.scstruct.sca_offset);
1474 else if (entry->entry.la_size <= BFD_SYM_CVTE_LA_MAX_SIZE)
1475 {
1476 unsigned long i;
1477
1478 fprintf (f, ", la [");
1479 for (i = 0; i < entry->entry.la_size; i++)
1480 fprintf (f, "0x%02x ", entry->entry.address.lastruct.la[i]);
1481 fprintf (f, "]");
1482 }
1483 else if (entry->entry.la_size == BFD_SYM_CVTE_BIG_LA)
1484 fprintf (f, ", bigla %lu, biglakind %u",
1485 entry->entry.address.biglastruct.big_la,
1486 entry->entry.address.biglastruct.big_la_kind);
1487
1488 else
1489 fprintf (f, ", la [INVALID]");
1490 }
1491
1492 void
1493 bfd_sym_print_contained_statements_table_entry (abfd, f, entry)
1494 bfd *abfd;
1495 FILE *f;
1496 bfd_sym_contained_statements_table_entry *entry;
1497 {
1498 if (entry->generic.type == BFD_SYM_END_OF_LIST)
1499 {
1500 fprintf (f, "END");
1501 return;
1502 }
1503
1504 if (entry->generic.type == BFD_SYM_SOURCE_FILE_CHANGE)
1505 {
1506 bfd_sym_print_file_reference (abfd, f, &entry->file.fref);
1507 fprintf (f, " offset %lu", entry->file.fref.fref_offset);
1508 return;
1509 }
1510
1511 fprintf (f, "\"%.*s\" (MTE %lu), offset %lu, delta %lu",
1512 bfd_sym_module_name (abfd, entry->entry.mte_index)[0],
1513 &bfd_sym_module_name (abfd, entry->entry.mte_index)[1],
1514 entry->entry.mte_index,
1515 entry->entry.mte_offset,
1516 entry->entry.file_delta);
1517 }
1518
1519 void
1520 bfd_sym_print_contained_labels_table_entry (abfd, f, entry)
1521 bfd *abfd;
1522 FILE *f;
1523 bfd_sym_contained_labels_table_entry *entry;
1524 {
1525 if (entry->generic.type == BFD_SYM_END_OF_LIST)
1526 {
1527 fprintf (f, "END");
1528 return;
1529 }
1530
1531 if (entry->generic.type == BFD_SYM_SOURCE_FILE_CHANGE)
1532 {
1533 bfd_sym_print_file_reference (abfd, f, &entry->file.fref);
1534 fprintf (f, " offset %lu", entry->file.fref.fref_offset);
1535 return;
1536 }
1537
1538 fprintf (f, "\"%.*s\" (MTE %lu), offset %lu, delta %lu, scope %s",
1539 bfd_sym_module_name (abfd, entry->entry.mte_index)[0],
1540 &bfd_sym_module_name (abfd, entry->entry.mte_index)[1],
1541 entry->entry.mte_index,
1542 entry->entry.mte_offset,
1543 entry->entry.file_delta,
1544 bfd_sym_unparse_symbol_scope (entry->entry.scope));
1545 }
1546
1547 void
1548 bfd_sym_print_contained_types_table_entry (abfd, f, entry)
1549 bfd *abfd ATTRIBUTE_UNUSED;
1550 FILE *f;
1551 bfd_sym_contained_types_table_entry *entry ATTRIBUTE_UNUSED;
1552 {
1553 fprintf (f, "[UNIMPLEMENTED]");
1554 }
1555
1556 const char *
1557 bfd_sym_type_operator_name (num)
1558 unsigned char num;
1559 {
1560 switch (num)
1561 {
1562 case 1: return "TTE";
1563 case 2: return "PointerTo";
1564 case 3: return "ScalarOf";
1565 case 4: return "ConstantOf";
1566 case 5: return "EnumerationOf";
1567 case 6: return "VectorOf";
1568 case 7: return "RecordOf";
1569 case 8: return "UnionOf";
1570 case 9: return "SubRangeOf";
1571 case 10: return "SetOf";
1572 case 11: return "NamedTypeOf";
1573 case 12: return "ProcOf";
1574 case 13: return "ValueOf";
1575 case 14: return "ArrayOf";
1576 default: return "[UNKNOWN OPERATOR]";
1577 }
1578 }
1579
1580 const char *
1581 bfd_sym_type_basic_name (num)
1582 unsigned char num;
1583 {
1584 switch (num)
1585 {
1586 case 0: return "void";
1587 case 1: return "pascal string";
1588 case 2: return "unsigned long";
1589 case 3: return "signed long";
1590 case 4: return "extended (10 bytes)";
1591 case 5: return "pascal boolean (1 byte)";
1592 case 6: return "unsigned byte";
1593 case 7: return "signed byte";
1594 case 8: return "character (1 byte)";
1595 case 9: return "wide character (2 bytes)";
1596 case 10: return "unsigned short";
1597 case 11: return "signed short";
1598 case 12: return "singled";
1599 case 13: return "double";
1600 case 14: return "extended (12 bytes)";
1601 case 15: return "computational (8 bytes)";
1602 case 16: return "c string";
1603 case 17: return "as-is string";
1604 default: return "[UNKNOWN BASIC TYPE]";
1605 }
1606 }
1607
1608 int
1609 bfd_sym_fetch_long (buf, len, offset, offsetptr, value)
1610 unsigned char *buf;
1611 unsigned long len;
1612 unsigned long offset;
1613 unsigned long *offsetptr;
1614 long *value;
1615 {
1616 int ret;
1617
1618 if (offset >= len)
1619 {
1620 *value = 0;
1621 offset += 0;
1622 ret = -1;
1623 }
1624 else if (! (buf[offset] & 0x80))
1625 {
1626 *value = buf[offset];
1627 offset += 1;
1628 ret = 0;
1629 }
1630 else if (buf[offset] == 0xc0)
1631 {
1632 if ((offset + 5) > len)
1633 {
1634 *value = 0;
1635 offset = len;
1636 ret = -1;
1637 }
1638 else
1639 {
1640 *value = bfd_getb32 (buf + offset + 1);
1641 offset += 5;
1642 ret = 0;
1643 }
1644 }
1645 else if ((buf[offset] & 0xc0) == 0xc0)
1646 {
1647 *value = -(buf[offset] & 0x3f);
1648 offset += 1;
1649 ret = 0;
1650 }
1651 else if ((buf[offset] & 0xc0) == 0x80)
1652 {
1653 if ((offset + 2) > len)
1654 {
1655 *value = 0;
1656 offset = len;
1657 ret = -1;
1658 }
1659 else
1660 {
1661 *value = bfd_getb16 (buf + offset) & 0x3fff;
1662 offset += 2;
1663 ret = 0;
1664 }
1665 }
1666 else
1667 abort ();
1668
1669 if (offsetptr != NULL)
1670 *offsetptr = offset;
1671
1672 return ret;
1673 }
1674
1675 void
1676 bfd_sym_print_type_information (abfd, f, buf, len, offset, offsetptr)
1677 bfd *abfd;
1678 FILE *f;
1679 unsigned char *buf;
1680 unsigned long len;
1681 unsigned long offset;
1682 unsigned long *offsetptr;
1683 {
1684 unsigned int type;
1685
1686 if (offset >= len)
1687 {
1688 fprintf (f, "[NULL]");
1689
1690 if (offsetptr != NULL)
1691 *offsetptr = offset;
1692 return;
1693 }
1694
1695 type = buf[offset];
1696 offset++;
1697
1698 if (! (type & 0x80))
1699 {
1700 fprintf (f, "[%s] (0x%x)", bfd_sym_type_basic_name (type & 0x7f), type);
1701
1702 if (offsetptr != NULL)
1703 *offsetptr = offset;
1704 return;
1705 }
1706
1707 if (type & 0x40)
1708 fprintf (f, "[packed ");
1709 else
1710 fprintf (f, "[");
1711
1712 switch (type & 0x3f)
1713 {
1714 case 1:
1715 {
1716 long value;
1717 bfd_sym_type_information_table_entry tinfo;
1718
1719 bfd_sym_fetch_long (buf, len, offset, &offset, &value);
1720 if (value <= 0)
1721 fprintf (f, "[INVALID]");
1722 else
1723 {
1724 if (bfd_sym_fetch_type_table_information (abfd, &tinfo, value) < 0)
1725 fprintf (f, "[INVALID]");
1726 else
1727 fprintf (f, "\"%.*s\"",
1728 bfd_sym_symbol_name (abfd, tinfo.nte_index)[0],
1729 &bfd_sym_symbol_name (abfd, tinfo.nte_index)[1]);
1730 }
1731 fprintf (f, " (TTE %lu)", value);
1732 break;
1733 }
1734
1735 case 2:
1736 fprintf (f, "pointer (0x%x) to ", type);
1737 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1738 break;
1739
1740 case 3:
1741 {
1742 unsigned long value;
1743
1744 fprintf (f, "scalar (0x%x) of ", type);
1745 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1746 bfd_sym_fetch_long (buf, len, offset, &offset, &value);
1747 fprintf (f, " (%lu)", value);
1748 break;
1749 }
1750
1751 case 5:
1752 {
1753 unsigned long lower, upper, nelem;
1754 unsigned long i;
1755
1756 fprintf (f, "enumeration (0x%x) of ", type);
1757 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1758 bfd_sym_fetch_long (buf, len, offset, &offset, &lower);
1759 bfd_sym_fetch_long (buf, len, offset, &offset, &upper);
1760 bfd_sym_fetch_long (buf, len, offset, &offset, &nelem);
1761 fprintf (f, " from %lu to %lu with %lu elements: ", lower, upper, nelem);
1762
1763 for (i = 0; i < nelem; i++)
1764 {
1765 fprintf (f, "\n ");
1766 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1767 }
1768 break;
1769 }
1770
1771 case 6:
1772 fprintf (f, "vector (0x%x)", type);
1773 fprintf (f, "\n index ");
1774 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1775 fprintf (f, "\n target ");
1776 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1777 break;
1778
1779 case 7:
1780 case 8:
1781 {
1782 long nrec, eloff, i;
1783
1784 if ((type & 0x3f) == 7)
1785 fprintf (f, "record (0x%x) of ", type);
1786 else
1787 fprintf (f, "union (0x%x) of ", type);
1788
1789 bfd_sym_fetch_long (buf, len, offset, &offset, &nrec);
1790 fprintf (f, "%lu elements: ", nrec);
1791
1792 for (i = 0; i < nrec; i++)
1793 {
1794 bfd_sym_fetch_long (buf, len, offset, &offset, &eloff);
1795 fprintf (f, "\n ");
1796 fprintf (f, "offset %lu: ", eloff);
1797 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1798 }
1799 break;
1800 }
1801
1802 case 9:
1803 fprintf (f, "subrange (0x%x) of ", type);
1804 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1805 fprintf (f, " lower ");
1806 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1807 fprintf (f, " upper ");
1808 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1809 break;
1810
1811 case 11:
1812 {
1813 long value;
1814
1815 fprintf (f, "named type (0x%x) ", type);
1816 bfd_sym_fetch_long (buf, len, offset, &offset, &value);
1817 if (value <= 0)
1818 fprintf (f, "[INVALID]");
1819 else
1820 fprintf (f, "\"%.*s\"",
1821 bfd_sym_symbol_name (abfd, value)[0],
1822 &bfd_sym_symbol_name (abfd, value)[1]);
1823
1824 fprintf (f, " (NTE %lu) with type ", value);
1825 bfd_sym_print_type_information (abfd, f, buf, len, offset, &offset);
1826 break;
1827 }
1828
1829 default:
1830 fprintf (f, "%s (0x%x)", bfd_sym_type_operator_name (type), type);
1831 break;
1832 }
1833
1834 if (type == (0x40 | 0x6))
1835 {
1836 /* Vector. */
1837 long n, width, m;
1838 long l;
1839 long i;
1840
1841 bfd_sym_fetch_long (buf, len, offset, &offset, &n);
1842 bfd_sym_fetch_long (buf, len, offset, &offset, &width);
1843 bfd_sym_fetch_long (buf, len, offset, &offset, &m);
1844 /* fprintf (f, "\n "); */
1845 fprintf (f, " N %ld, width %ld, M %ld, ", n, width, m);
1846 for (i = 0; i < m; i++)
1847 {
1848 bfd_sym_fetch_long (buf, len, offset, &offset, &l);
1849 if (i != 0)
1850 fprintf (f, " ");
1851 fprintf (f, "%ld", l);
1852 }
1853 }
1854 else if (type & 0x40)
1855 {
1856 /* Other packed type. */
1857 long msb, lsb;
1858
1859 bfd_sym_fetch_long (buf, len, offset, &offset, &msb);
1860 bfd_sym_fetch_long (buf, len, offset, &offset, &lsb);
1861 /* fprintf (f, "\n "); */
1862 fprintf (f, " msb %ld, lsb %ld", msb, lsb);
1863 }
1864
1865 fprintf (f, "]");
1866
1867 if (offsetptr != NULL)
1868 *offsetptr = offset;
1869 }
1870
1871 void
1872 bfd_sym_print_type_information_table_entry (abfd, f, entry)
1873 bfd *abfd;
1874 FILE *f;
1875 bfd_sym_type_information_table_entry *entry;
1876 {
1877 unsigned char *buf;
1878 unsigned long offset;
1879 unsigned int i;
1880
1881 fprintf (f, "\"%.*s\" (NTE %lu), %lu bytes at %lu, logical size %lu",
1882 bfd_sym_symbol_name (abfd, entry->nte_index)[0],
1883 &bfd_sym_symbol_name (abfd, entry->nte_index)[1],
1884 entry->nte_index,
1885 entry->physical_size, entry->offset, entry->logical_size);
1886
1887 fprintf (f, "\n ");
1888
1889 buf = alloca (entry->physical_size);
1890 if (buf == NULL)
1891 {
1892 fprintf (f, "[ERROR]\n");
1893 return;
1894 }
1895 if (bfd_seek (abfd, entry->offset, SEEK_SET) < 0)
1896 {
1897 fprintf (f, "[ERROR]\n");
1898 return;
1899 }
1900 if (bfd_bread (buf, entry->physical_size, abfd) != entry->physical_size)
1901 {
1902 fprintf (f, "[ERROR]\n");
1903 return;
1904 }
1905
1906 fprintf (f, "[");
1907 for (i = 0; i < entry->physical_size; i++)
1908 {
1909 if (i == 0)
1910 fprintf (f, "0x%02x", buf[i]);
1911 else
1912 fprintf (f, " 0x%02x", buf[i]);
1913 }
1914
1915 fprintf (f, "]");
1916 fprintf (f, "\n ");
1917
1918 bfd_sym_print_type_information (abfd, f, buf, entry->physical_size, 0, &offset);
1919
1920 if (offset != entry->physical_size)
1921 fprintf (f, "\n [parser used %lu bytes instead of %lu]", offset, entry->physical_size); }
1922
1923 void
1924 bfd_sym_print_file_references_index_table_entry (abfd, f, entry)
1925 bfd *abfd ATTRIBUTE_UNUSED;
1926 FILE *f;
1927 bfd_sym_file_references_index_table_entry *entry ATTRIBUTE_UNUSED;
1928 {
1929 fprintf (f, "[UNIMPLEMENTED]");
1930 }
1931
1932 void
1933 bfd_sym_print_constant_pool_entry (abfd, f, entry)
1934 bfd *abfd ATTRIBUTE_UNUSED;
1935 FILE *f;
1936 bfd_sym_constant_pool_entry *entry ATTRIBUTE_UNUSED;
1937 {
1938 fprintf (f, "[UNIMPLEMENTED]");
1939 }
1940
1941 unsigned char *
1942 bfd_sym_display_name_table_entry (abfd, f, entry)
1943 bfd *abfd;
1944 FILE *f;
1945 unsigned char *entry;
1946 {
1947 unsigned long index;
1948 unsigned long offset;
1949 bfd_sym_data_struct *sdata = NULL;
1950
1951 BFD_ASSERT (bfd_sym_valid (abfd));
1952 sdata = abfd->tdata.sym_data;
1953 index = (entry - sdata->name_table) / 2;
1954
1955 if (sdata->version >= BFD_SYM_VERSION_3_4 && entry[0] == 255 && entry[1] == 0)
1956 {
1957 unsigned short length = bfd_getb16 (entry + 2);
1958 fprintf (f, "[%8lu] \"%.*s\"\n", index, length, entry + 4);
1959 offset = 2 + length + 1;
1960 }
1961 else
1962 {
1963 if (! (entry[0] == 0 || (entry[0] == 1 && entry[1] == '\0')))
1964 fprintf (f, "[%8lu] \"%.*s\"\n", index, entry[0], entry + 1);
1965
1966 if (sdata->version >= BFD_SYM_VERSION_3_4)
1967 offset = entry[0] + 2;
1968 else
1969 offset = entry[0] + 1;
1970 }
1971
1972 return (entry + offset + (offset % 2));
1973 }
1974
1975 void
1976 bfd_sym_display_name_table (abfd, f)
1977 bfd *abfd;
1978 FILE *f;
1979 {
1980 unsigned long name_table_len;
1981 unsigned char *name_table, *name_table_end, *cur;
1982 bfd_sym_data_struct *sdata = NULL;
1983
1984 BFD_ASSERT (bfd_sym_valid (abfd));
1985 sdata = abfd->tdata.sym_data;
1986
1987 name_table_len = sdata->header.dshb_nte.dti_page_count * sdata->header.dshb_page_size;
1988 name_table = sdata->name_table;
1989 name_table_end = name_table + name_table_len;
1990
1991 fprintf (f, "name table (NTE) contains %lu bytes:\n\n", name_table_len);
1992
1993 cur = name_table;
1994 for (;;)
1995 {
1996 cur = bfd_sym_display_name_table_entry (abfd, f, cur);
1997 if (cur >= name_table_end)
1998 break;
1999 }
2000 }
2001
2002 void
2003 bfd_sym_display_resources_table (abfd, f)
2004 bfd *abfd;
2005 FILE *f;
2006 {
2007 unsigned long i;
2008 bfd_sym_resources_table_entry entry;
2009 bfd_sym_data_struct *sdata = NULL;
2010
2011 BFD_ASSERT (bfd_sym_valid (abfd));
2012 sdata = abfd->tdata.sym_data;
2013
2014 fprintf (f, "resource table (RTE) contains %lu objects:\n\n",
2015 sdata->header.dshb_rte.dti_object_count);
2016
2017 for (i = 1; i <= sdata->header.dshb_rte.dti_object_count; i++)
2018 {
2019 if (bfd_sym_fetch_resources_table_entry (abfd, &entry, i) < 0)
2020 fprintf (f, " [%8lu] [INVALID]\n", i);
2021 else
2022 {
2023 fprintf (f, " [%8lu] ", i);
2024 bfd_sym_print_resources_table_entry (abfd, f, &entry);
2025 fprintf (f, "\n");
2026 }
2027 }
2028 }
2029
2030 void
2031 bfd_sym_display_modules_table (abfd, f)
2032 bfd *abfd;
2033 FILE *f;
2034 {
2035 unsigned long i;
2036 bfd_sym_modules_table_entry entry;
2037 bfd_sym_data_struct *sdata = NULL;
2038
2039 BFD_ASSERT (bfd_sym_valid (abfd));
2040 sdata = abfd->tdata.sym_data;
2041
2042 fprintf (f, "module table (MTE) contains %lu objects:\n\n",
2043 sdata->header.dshb_mte.dti_object_count);
2044
2045 for (i = 1; i <= sdata->header.dshb_mte.dti_object_count; i++)
2046 {
2047 if (bfd_sym_fetch_modules_table_entry (abfd, &entry, i) < 0)
2048 fprintf (f, " [%8lu] [INVALID]\n", i);
2049 else
2050 {
2051 fprintf (f, " [%8lu] ", i);
2052 bfd_sym_print_modules_table_entry (abfd, f, &entry);
2053 fprintf (f, "\n");
2054 }
2055 }
2056 }
2057
2058 void
2059 bfd_sym_display_file_references_table (abfd, f)
2060 bfd *abfd;
2061 FILE *f;
2062 {
2063 unsigned long i;
2064 bfd_sym_file_references_table_entry entry;
2065 bfd_sym_data_struct *sdata = NULL;
2066
2067 BFD_ASSERT (bfd_sym_valid (abfd));
2068 sdata = abfd->tdata.sym_data;
2069
2070 fprintf (f, "file reference table (FRTE) contains %lu objects:\n\n",
2071 sdata->header.dshb_frte.dti_object_count);
2072
2073 for (i = 1; i <= sdata->header.dshb_frte.dti_object_count; i++)
2074 {
2075 if (bfd_sym_fetch_file_references_table_entry (abfd, &entry, i) < 0)
2076 fprintf (f, " [%8lu] [INVALID]\n", i);
2077 else
2078 {
2079 fprintf (f, " [%8lu] ", i);
2080 bfd_sym_print_file_references_table_entry (abfd, f, &entry);
2081 fprintf (f, "\n");
2082 }
2083 }
2084 }
2085
2086 void
2087 bfd_sym_display_contained_modules_table (abfd, f)
2088 bfd *abfd;
2089 FILE *f;
2090 {
2091 unsigned long i;
2092 bfd_sym_contained_modules_table_entry entry;
2093 bfd_sym_data_struct *sdata = NULL;
2094
2095 BFD_ASSERT (bfd_sym_valid (abfd));
2096 sdata = abfd->tdata.sym_data;
2097
2098 fprintf (f, "contained modules table (CMTE) contains %lu objects:\n\n",
2099 sdata->header.dshb_cmte.dti_object_count);
2100
2101 for (i = 1; i <= sdata->header.dshb_cmte.dti_object_count; i++)
2102 {
2103 if (bfd_sym_fetch_contained_modules_table_entry (abfd, &entry, i) < 0)
2104 fprintf (f, " [%8lu] [INVALID]\n", i);
2105 else
2106 {
2107 fprintf (f, " [%8lu] ", i);
2108 bfd_sym_print_contained_modules_table_entry (abfd, f, &entry);
2109 fprintf (f, "\n");
2110 }
2111 }
2112 }
2113
2114 void
2115 bfd_sym_display_contained_variables_table (abfd, f)
2116 bfd *abfd;
2117 FILE *f;
2118 {
2119 unsigned long i;
2120 bfd_sym_contained_variables_table_entry entry;
2121 bfd_sym_data_struct *sdata = NULL;
2122
2123 BFD_ASSERT (bfd_sym_valid (abfd));
2124 sdata = abfd->tdata.sym_data;
2125
2126 fprintf (f, "contained variables table (CVTE) contains %lu objects:\n\n",
2127 sdata->header.dshb_cvte.dti_object_count);
2128
2129 for (i = 1; i <= sdata->header.dshb_cvte.dti_object_count; i++)
2130 {
2131 if (bfd_sym_fetch_contained_variables_table_entry (abfd, &entry, i) < 0)
2132 fprintf (f, " [%8lu] [INVALID]\n", i);
2133 else
2134 {
2135 fprintf (f, " [%8lu] ", i);
2136 bfd_sym_print_contained_variables_table_entry (abfd, f, &entry);
2137 fprintf (f, "\n");
2138 }
2139 }
2140
2141 fprintf (f, "\n");
2142 }
2143
2144 void
2145 bfd_sym_display_contained_statements_table (abfd, f)
2146 bfd *abfd;
2147 FILE *f;
2148 {
2149 unsigned long i;
2150 bfd_sym_contained_statements_table_entry entry;
2151 bfd_sym_data_struct *sdata = NULL;
2152
2153 BFD_ASSERT (bfd_sym_valid (abfd));
2154 sdata = abfd->tdata.sym_data;
2155
2156 fprintf (f, "contained statements table (CSNTE) contains %lu objects:\n\n",
2157 sdata->header.dshb_csnte.dti_object_count);
2158
2159 for (i = 1; i <= sdata->header.dshb_csnte.dti_object_count; i++)
2160 {
2161 if (bfd_sym_fetch_contained_statements_table_entry (abfd, &entry, i) < 0)
2162 fprintf (f, " [%8lu] [INVALID]\n", i);
2163 else
2164 {
2165 fprintf (f, " [%8lu] ", i);
2166 bfd_sym_print_contained_statements_table_entry (abfd, f, &entry);
2167 fprintf (f, "\n");
2168 }
2169 }
2170 }
2171
2172 void
2173 bfd_sym_display_contained_labels_table (abfd, f)
2174 bfd *abfd;
2175 FILE *f;
2176 {
2177 unsigned long i;
2178 bfd_sym_contained_labels_table_entry entry;
2179 bfd_sym_data_struct *sdata = NULL;
2180
2181 BFD_ASSERT (bfd_sym_valid (abfd));
2182 sdata = abfd->tdata.sym_data;
2183
2184 fprintf (f, "contained labels table (CLTE) contains %lu objects:\n\n",
2185 sdata->header.dshb_clte.dti_object_count);
2186
2187 for (i = 1; i <= sdata->header.dshb_clte.dti_object_count; i++)
2188 {
2189 if (bfd_sym_fetch_contained_labels_table_entry (abfd, &entry, i) < 0)
2190 fprintf (f, " [%8lu] [INVALID]\n", i);
2191 else
2192 {
2193 fprintf (f, " [%8lu] ", i);
2194 bfd_sym_print_contained_labels_table_entry (abfd, f, &entry);
2195 fprintf (f, "\n");
2196 }
2197 }
2198 }
2199
2200 void
2201 bfd_sym_display_contained_types_table (abfd, f)
2202 bfd *abfd;
2203 FILE *f;
2204 {
2205 unsigned long i;
2206 bfd_sym_contained_types_table_entry entry;
2207 bfd_sym_data_struct *sdata = NULL;
2208
2209 BFD_ASSERT (bfd_sym_valid (abfd));
2210 sdata = abfd->tdata.sym_data;
2211
2212 fprintf (f, "contained types table (CTTE) contains %lu objects:\n\n",
2213 sdata->header.dshb_ctte.dti_object_count);
2214
2215 for (i = 1; i <= sdata->header.dshb_ctte.dti_object_count; i++)
2216 {
2217 if (bfd_sym_fetch_contained_types_table_entry (abfd, &entry, i) < 0)
2218 fprintf (f, " [%8lu] [INVALID]\n", i);
2219 else
2220 {
2221 fprintf (f, " [%8lu] ", i);
2222 bfd_sym_print_contained_types_table_entry (abfd, f, &entry);
2223 fprintf (f, "\n");
2224 }
2225 }
2226 }
2227
2228 void
2229 bfd_sym_display_file_references_index_table (abfd, f)
2230 bfd *abfd;
2231 FILE *f;
2232 {
2233 unsigned long i;
2234 bfd_sym_file_references_index_table_entry entry;
2235 bfd_sym_data_struct *sdata = NULL;
2236
2237 BFD_ASSERT (bfd_sym_valid (abfd));
2238 sdata = abfd->tdata.sym_data;
2239
2240 fprintf (f, "file references index table (FITE) contains %lu objects:\n\n",
2241 sdata->header.dshb_fite.dti_object_count);
2242
2243 for (i = 1; i <= sdata->header.dshb_fite.dti_object_count; i++)
2244 {
2245 if (bfd_sym_fetch_file_references_index_table_entry (abfd, &entry, i) < 0)
2246 fprintf (f, " [%8lu] [INVALID]\n", i);
2247 else
2248 {
2249 fprintf (f, " [%8lu] ", i);
2250 bfd_sym_print_file_references_index_table_entry (abfd, f, &entry);
2251 fprintf (f, "\n");
2252 }
2253 }
2254 }
2255
2256 void
2257 bfd_sym_display_constant_pool (abfd, f)
2258 bfd *abfd;
2259 FILE *f;
2260 {
2261 unsigned long i;
2262 bfd_sym_constant_pool_entry entry;
2263 bfd_sym_data_struct *sdata = NULL;
2264
2265 BFD_ASSERT (bfd_sym_valid (abfd));
2266 sdata = abfd->tdata.sym_data;
2267
2268 fprintf (f, "constant pool (CONST) contains %lu objects:\n\n",
2269 sdata->header.dshb_const.dti_object_count);
2270
2271 for (i = 1; i <= sdata->header.dshb_const.dti_object_count; i++)
2272 {
2273 if (bfd_sym_fetch_constant_pool_entry (abfd, &entry, i) < 0)
2274 fprintf (f, " [%8lu] [INVALID]\n", i);
2275 else
2276 {
2277 fprintf (f, " [%8lu] ", i);
2278 bfd_sym_print_constant_pool_entry (abfd, f, &entry);
2279 fprintf (f, "\n");
2280 }
2281 }
2282 }
2283
2284 void
2285 bfd_sym_display_type_information_table (abfd, f)
2286 bfd *abfd;
2287 FILE *f;
2288 {
2289 unsigned long i;
2290 bfd_sym_type_table_entry index;
2291 bfd_sym_type_information_table_entry entry;
2292 bfd_sym_data_struct *sdata = NULL;
2293
2294 BFD_ASSERT (bfd_sym_valid (abfd));
2295 sdata = abfd->tdata.sym_data;
2296
2297 if (sdata->header.dshb_tte.dti_object_count > 99)
2298 fprintf (f, "type table (TINFO) contains %lu objects:\n\n",
2299 sdata->header.dshb_tte.dti_object_count - 99);
2300 else
2301 {
2302 fprintf (f, "type table (TINFO) contains [INVALID] objects:\n\n");
2303 return;
2304 }
2305
2306 for (i = 100; i <= sdata->header.dshb_tte.dti_object_count; i++)
2307 {
2308 if (bfd_sym_fetch_type_table_entry (abfd, &index, i - 100) < 0)
2309 fprintf (f, " [%8lu] [INVALID]\n", i);
2310 else
2311 {
2312 fprintf (f, " [%8lu] (TINFO %lu) ", i, index);
2313
2314 if (bfd_sym_fetch_type_information_table_entry (abfd, &entry, index) < 0)
2315 fprintf (f, "[INVALID]");
2316 else
2317 bfd_sym_print_type_information_table_entry (abfd, f, &entry);
2318
2319 fprintf (f, "\n");
2320 }
2321 }
2322 }
2323
2324 int
2325 bfd_sym_scan (abfd, version, mdata)
2326 bfd *abfd;
2327 bfd_sym_version version;
2328 bfd_sym_data_struct *mdata;
2329 {
2330 asection *bfdsec;
2331 const char *name = "symbols";
2332
2333 mdata->name_table = 0;
2334 mdata->sbfd = abfd;
2335 mdata->version = version;
2336
2337 bfd_seek (abfd, 0, SEEK_SET);
2338 if (bfd_sym_read_header (abfd, &mdata->header, mdata->version) != 0)
2339 return -1;
2340
2341 mdata->name_table = bfd_sym_read_name_table (abfd, &mdata->header);
2342 if (mdata->name_table == NULL)
2343 return -1;
2344
2345 bfdsec = bfd_make_section_anyway (abfd, name);
2346 if (bfdsec == NULL)
2347 return -1;
2348
2349 bfdsec->vma = 0;
2350 bfdsec->lma = 0;
2351 bfdsec->size = 0;
2352 bfdsec->filepos = 0;
2353 bfdsec->alignment_power = 0;
2354
2355 bfdsec->flags = SEC_HAS_CONTENTS;
2356
2357 abfd->tdata.sym_data = mdata;
2358
2359 return 0;
2360 }
2361
2362 const bfd_target *
2363 bfd_sym_object_p (abfd)
2364 bfd *abfd;
2365 {
2366 struct bfd_preserve preserve;
2367 bfd_sym_version version = -1;
2368
2369 preserve.marker = NULL;
2370 bfd_seek (abfd, 0, SEEK_SET);
2371 if (bfd_sym_read_version (abfd, &version) != 0)
2372 goto wrong;
2373
2374 preserve.marker = bfd_alloc (abfd, sizeof (bfd_sym_data_struct));
2375 if (preserve.marker == NULL
2376 || ! bfd_preserve_save (abfd, &preserve))
2377 goto fail;
2378
2379 if (bfd_sym_scan (abfd, version,
2380 (bfd_sym_data_struct *) preserve.marker) != 0)
2381 goto wrong;
2382
2383 bfd_preserve_finish (abfd, &preserve);
2384 return abfd->xvec;
2385
2386 wrong:
2387 bfd_set_error (bfd_error_wrong_format);
2388
2389 fail:
2390 if (preserve.marker != NULL)
2391 bfd_preserve_restore (abfd, &preserve);
2392 return NULL;
2393 }
2394
2395 asymbol *
2396 bfd_sym_make_empty_symbol (abfd)
2397 bfd *abfd;
2398 {
2399 return (asymbol *) bfd_alloc (abfd, sizeof (asymbol));
2400 }
2401
2402 void
2403 bfd_sym_get_symbol_info (abfd, symbol, ret)
2404 bfd *abfd ATTRIBUTE_UNUSED;
2405 asymbol *symbol;
2406 symbol_info *ret;
2407 {
2408 bfd_symbol_info (symbol, ret);
2409 }
2410
2411 long
2412 bfd_sym_get_symtab_upper_bound (abfd)
2413 bfd *abfd ATTRIBUTE_UNUSED;
2414 {
2415 return 0;
2416 }
2417
2418 long
2419 bfd_sym_canonicalize_symtab (abfd, sym)
2420 bfd *abfd ATTRIBUTE_UNUSED;
2421 asymbol **sym ATTRIBUTE_UNUSED;
2422 {
2423 return 0;
2424 }
2425
2426 int
2427 bfd_sym_sizeof_headers (abfd, exec)
2428 bfd *abfd ATTRIBUTE_UNUSED;
2429 bfd_boolean exec ATTRIBUTE_UNUSED;
2430 {
2431 return 0;
2432 }
2433
2434 const bfd_target sym_vec =
2435 {
2436 "sym", /* name */
2437 bfd_target_sym_flavour, /* flavour */
2438 BFD_ENDIAN_BIG, /* byteorder */
2439 BFD_ENDIAN_BIG, /* header_byteorder */
2440 (HAS_RELOC | EXEC_P | /* object flags */
2441 HAS_LINENO | HAS_DEBUG |
2442 HAS_SYMS | HAS_LOCALS | DYNAMIC | WP_TEXT | D_PAGED),
2443 (SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_CODE | SEC_DATA
2444 | SEC_ROM | SEC_HAS_CONTENTS), /* section_flags */
2445 0, /* symbol_leading_char */
2446 ' ', /* ar_pad_char */
2447 16, /* ar_max_namelen */
2448 bfd_getb64, bfd_getb_signed_64, bfd_putb64,
2449 bfd_getb32, bfd_getb_signed_32, bfd_putb32,
2450 bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* data */
2451 bfd_getb64, bfd_getb_signed_64, bfd_putb64,
2452 bfd_getb32, bfd_getb_signed_32, bfd_putb32,
2453 bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* hdrs */
2454 { /* bfd_check_format */
2455 _bfd_dummy_target,
2456 bfd_sym_object_p, /* bfd_check_format */
2457 _bfd_dummy_target,
2458 _bfd_dummy_target,
2459 },
2460 { /* bfd_set_format */
2461 bfd_false,
2462 bfd_sym_mkobject,
2463 bfd_false,
2464 bfd_false,
2465 },
2466 { /* bfd_write_contents */
2467 bfd_false,
2468 bfd_true,
2469 bfd_false,
2470 bfd_false,
2471 },
2472
2473 BFD_JUMP_TABLE_GENERIC (bfd_sym),
2474 BFD_JUMP_TABLE_COPY (_bfd_generic),
2475 BFD_JUMP_TABLE_CORE (_bfd_nocore),
2476 BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive),
2477 BFD_JUMP_TABLE_SYMBOLS (bfd_sym),
2478 BFD_JUMP_TABLE_RELOCS (bfd_sym),
2479 BFD_JUMP_TABLE_WRITE (bfd_sym),
2480 BFD_JUMP_TABLE_LINK (bfd_sym),
2481 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),
2482
2483 NULL,
2484
2485 NULL
2486 };
2487
This page took 0.081032 seconds and 5 git commands to generate.