mirror of
https://github.com/darlinghq/darling-gdb.git
synced 2024-12-05 19:07:07 +00:00
2aefe6e4ae
* xcoffread.c (retrieve_tracebackinfo): Move assignment out of while condition. * xcoffread.c (enter_line_range): complain() on bad endoffset. xcoffread.c: Doc fixes. Tue Mar 9 09:56:12 1993 Jim Kingdon (kingdon@cygnus.com) * tm-rs6000.h (CORE_NEEDS_RELOCATION): Just call xcoff_relocate_core. xcoffexec.c (xcoff_relocate_core): New function. (text_adjustment): Removed. (add_vmap): Return the vmap. rs6000-tdep.c (add_text_to_loadinfo): No longer static. Fri Mar 5 05:22:46 1993 Jim Kingdon (kingdon@cygnus.com) * xcoffsolib.h: Add objfile member to struct vmap. xcoff{exec,solib}.c: Use it, not lookup_objfile_bfd. xcoffexec.c (add_vmap): Allocate objfiles here.
60 lines
2.1 KiB
C
60 lines
2.1 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;
|
|
|
|
CORE_ADDR ostart; /* objext start ??? */
|
|
unsigned loaded:1; /* True if symbols are loaded */
|
|
unsigned reloced:1; /* True, if symbols relocated */
|
|
unsigned padding:14;
|
|
};
|
|
|
|
|
|
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));
|
|
|