Convert xcoffread.c to type-safe registry API

This changes xcoffread.c to use the type-safe registry API.  It also
renames coff_symfile_info to xcoff_symfile_info, to avoid any possible
ODR violation.

gdb/ChangeLog
2019-05-08  Tom Tromey  <tom@tromey.com>

	* xcoffread.c (struct xcoff_symfile_info): Rename from
	coff_symfile_info.  Add initializers.
	(xcoff_objfile_data_key): Move lower.  Change type.
	(XCOFF_DATA): Rewrite.
	(xcoff_free_info): Remove.
	(xcoff_symfile_init, _initialize_xcoffread, read_xcoff_symtab)
	(read_symbol, read_symbol_lineno, find_linenos, init_stringtab)
	(xcoff_initial_scan): Update.
This commit is contained in:
Tom Tromey 2019-04-30 22:18:10 -06:00
parent 0923243872
commit 02dc647ed6
2 changed files with 32 additions and 36 deletions

View File

@ -1,3 +1,14 @@
2019-05-08 Tom Tromey <tom@tromey.com>
* xcoffread.c (struct xcoff_symfile_info): Rename from
coff_symfile_info. Add initializers.
(xcoff_objfile_data_key): Move lower. Change type.
(XCOFF_DATA): Rewrite.
(xcoff_free_info): Remove.
(xcoff_symfile_init, _initialize_xcoffread, read_xcoff_symtab)
(read_symbol, read_symbol_lineno, find_linenos, init_stringtab)
(xcoff_initial_scan): Update.
2019-05-08 Tom Tromey <tom@tromey.com>
* solib-svr4.c (struct svr4_info): Add initializers and

View File

@ -53,10 +53,6 @@
#include "aout/stab_gnu.h"
/* Key for XCOFF-associated data. */
static const struct objfile_data *xcoff_objfile_data_key;
/* We put a pointer to this structure in the read_symtab_private field
of the psymtab. */
@ -125,32 +121,35 @@ static CORE_ADDR first_object_file_end;
static unsigned local_symesz;
struct coff_symfile_info
struct xcoff_symfile_info
{
file_ptr min_lineno_offset; /* Where in file lowest line#s are. */
file_ptr max_lineno_offset; /* 1+last byte of line#s in file. */
file_ptr min_lineno_offset {}; /* Where in file lowest line#s are. */
file_ptr max_lineno_offset {}; /* 1+last byte of line#s in file. */
/* Pointer to the string table. */
char *strtbl;
char *strtbl = nullptr;
/* Pointer to debug section. */
char *debugsec;
char *debugsec = nullptr;
/* Pointer to the a.out symbol table. */
char *symtbl;
char *symtbl = nullptr;
/* Number of symbols in symtbl. */
int symtbl_num_syms;
int symtbl_num_syms = 0;
/* Offset in data section to TOC anchor. */
CORE_ADDR toc_offset;
CORE_ADDR toc_offset = 0;
};
/* Key for XCOFF-associated data. */
static const struct objfile_key<xcoff_symfile_info> xcoff_objfile_data_key;
/* Convenience macro to access the per-objfile XCOFF data. */
#define XCOFF_DATA(objfile) \
((struct coff_symfile_info *) objfile_data ((objfile), \
xcoff_objfile_data_key))
xcoff_objfile_data_key.get (objfile)
/* XCOFF names for dwarf sections. There is no compressed sections. */
@ -1006,7 +1005,7 @@ read_xcoff_symtab (struct objfile *objfile, struct partial_symtab *pst)
{
bfd *abfd = objfile->obfd;
char *raw_auxptr; /* Pointer to first raw aux entry for sym. */
struct coff_symfile_info *xcoff = XCOFF_DATA (objfile);
struct xcoff_symfile_info *xcoff = XCOFF_DATA (objfile);
char *strtbl = xcoff->strtbl;
char *debugsec = xcoff->debugsec;
const char *debugfmt = bfd_xcoff_is_xcoff64 (abfd) ? "XCOFF64" : "XCOFF";
@ -1710,7 +1709,7 @@ coff_getfilename (union internal_auxent *aux_entry, struct objfile *objfile)
static void
read_symbol (struct internal_syment *symbol, int symno)
{
struct coff_symfile_info *xcoff = XCOFF_DATA (this_symtab_objfile);
struct xcoff_symfile_info *xcoff = XCOFF_DATA (this_symtab_objfile);
int nsyms = xcoff->symtbl_num_syms;
char *stbl = xcoff->symtbl;
@ -1747,7 +1746,7 @@ read_symbol_lineno (int symno)
struct objfile *objfile = this_symtab_objfile;
int xcoff64 = bfd_xcoff_is_xcoff64 (objfile->obfd);
struct coff_symfile_info *info = XCOFF_DATA (objfile);
struct xcoff_symfile_info *info = XCOFF_DATA (objfile);
int nsyms = info->symtbl_num_syms;
char *stbl = info->symtbl;
char *strtbl = info->strtbl;
@ -1813,7 +1812,7 @@ gotit:
static void
find_linenos (struct bfd *abfd, struct bfd_section *asect, void *vpinfo)
{
struct coff_symfile_info *info;
struct xcoff_symfile_info *info;
int size, count;
file_ptr offset, maxoff;
@ -1823,7 +1822,7 @@ find_linenos (struct bfd *abfd, struct bfd_section *asect, void *vpinfo)
return;
size = count * coff_data (abfd)->local_linesz;
info = (struct coff_symfile_info *) vpinfo;
info = (struct xcoff_symfile_info *) vpinfo;
offset = asect->line_filepos;
maxoff = offset + size;
@ -1934,11 +1933,8 @@ xcoff_new_init (struct objfile *objfile)
static void
xcoff_symfile_init (struct objfile *objfile)
{
struct coff_symfile_info *xcoff;
/* Allocate struct to keep track of the symfile. */
xcoff = XNEW (struct coff_symfile_info);
set_objfile_data (objfile, xcoff_objfile_data_key, xcoff);
xcoff_objfile_data_key.emplace (objfile);
/* XCOFF objects may be reordered, so set OBJF_REORDERED. If we
find this causes a significant slowdown in gdb then we could
@ -1971,7 +1967,7 @@ init_stringtab (bfd *abfd, file_ptr offset, struct objfile *objfile)
int val;
unsigned char lengthbuf[4];
char *strtbl;
struct coff_symfile_info *xcoff = XCOFF_DATA (objfile);
struct xcoff_symfile_info *xcoff = XCOFF_DATA (objfile);
xcoff->strtbl = NULL;
@ -2925,7 +2921,7 @@ xcoff_initial_scan (struct objfile *objfile, symfile_add_flags symfile_flags)
int num_symbols; /* # of symbols */
file_ptr symtab_offset; /* symbol table and */
file_ptr stringtab_offset; /* string table file offsets */
struct coff_symfile_info *info;
struct xcoff_symfile_info *info;
const char *name;
unsigned int size;
@ -3143,19 +3139,8 @@ xcoff_get_n_import_files (bfd *abfd)
return l_nimpid - 1;
}
/* Free the per-objfile xcoff data. */
static void
xcoff_free_info (struct objfile *objfile, void *arg)
{
xfree (arg);
}
void
_initialize_xcoffread (void)
{
add_symtab_fns (bfd_target_xcoff_flavour, &xcoff_sym_fns);
xcoff_objfile_data_key = register_objfile_data_with_cleanup (NULL,
xcoff_free_info);
}