mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-18 12:24:38 +08:00
3c02636b4e
objfiles.h (struct objfiles): Add section_offsets, num_sections. symfile.c (syms_from_objfile), xcoffread.c (xcoff_symfile_offsets): Set them. symtab.h (struct general_symbol_info): Add section field. minsyms.c (prim_record_minimal_symbol{,_and_info}): Set it. xcoffread.c: Set section for symbols and msymbols. (struct symtab): Add block_line_section field. buildsym.c (end_symtab): Set it. (end_symtab and callers): Add section parameter. objfiles.c (objfile_relocate): New funciton. xcoffexec.c (vmap_symtab): Use it. xcoffsolib.h (struct vmap): Remove unused fields. config/rs6000/tm-rs6000.h, stack.c, xcoffexec.c: Remove CORE_NEEDS_RELOCATION, symtab_relocated. config/rs6000/tm-rs6000.h: Remove use of loadinfotext. rs6000-tdep.c: Make loadinfotext static. breakpoint.c (fixup_breakpoints): Doc fix. symtab.h (struct symtab), config/rs6000/tm-rs6000.h, buildsym.c (end_symtab): primary field replaces nonreloc.
58 lines
2.0 KiB
C
58 lines
2.0 KiB
C
/* Data structures for RS/6000 shared libraries, for GDB.
|
|
Copyright 1991, 1992 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
|
|
|
|
/*
|
|
the vmap struct is used to describe the virtual address space of
|
|
the target we are manipulating. The first entry is always the "exec"
|
|
file. Subsequent entries correspond to other objects that are
|
|
mapped into the address space of a process created from the "exec" file.
|
|
These are either in response to exec()ing the file, in which case all
|
|
shared libraries are loaded, or a "load" system call, followed by the
|
|
user's issuance of a "load" command. */
|
|
|
|
struct vmap {
|
|
struct vmap *nxt; /* ^ to next in chain */
|
|
bfd *bfd; /* BFD for mappable object library */
|
|
char *name; /* ^ to object file name */
|
|
char *member; /* ^ to member name */
|
|
CORE_ADDR tstart; /* virtual addr where member is mapped */
|
|
CORE_ADDR tend; /* virtual upper bound of member */
|
|
CORE_ADDR tadj; /* heuristically derived adjustment */
|
|
CORE_ADDR dstart; /* virtual address of data start */
|
|
CORE_ADDR dend; /* vitrual address of data end */
|
|
|
|
/* This is NULL for the exec-file. */
|
|
struct objfile *objfile;
|
|
|
|
unsigned loaded:1; /* True if symbols are loaded */
|
|
unsigned padding:15;
|
|
};
|
|
|
|
|
|
struct vmap_and_bfd {
|
|
bfd *pbfd;
|
|
struct vmap *pvmap;
|
|
};
|
|
|
|
extern struct vmap *vmap;
|
|
|
|
void
|
|
add_text_to_loadinfo PARAMS ((CORE_ADDR textaddr, CORE_ADDR dataaddr));
|
|
|