270 lines
8.4 KiB
C
270 lines
8.4 KiB
C
|
/* $XFree86: xc/programs/Xserver/hw/xfree86/loader/loader.h,v 1.25 2001/02/22 23:17:09 dawes Exp $ */
|
||
|
|
||
|
/*
|
||
|
*
|
||
|
* Copyright 1995-1998 by Metro Link, Inc.
|
||
|
*
|
||
|
* Permission to use, copy, modify, distribute, and sell this software and its
|
||
|
* documentation for any purpose is hereby granted without fee, provided that
|
||
|
* the above copyright notice appear in all copies and that both that
|
||
|
* copyright notice and this permission notice appear in supporting
|
||
|
* documentation, and that the name of Metro Link, Inc. not be used in
|
||
|
* advertising or publicity pertaining to distribution of the software without
|
||
|
* specific, written prior permission. Metro Link, Inc. makes no
|
||
|
* representations about the suitability of this software for any purpose.
|
||
|
* It is provided "as is" without express or implied warranty.
|
||
|
*
|
||
|
* METRO LINK, INC. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||
|
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
||
|
* EVENT SHALL METRO LINK, INC. BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||
|
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
|
||
|
* DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
||
|
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||
|
* PERFORMANCE OF THIS SOFTWARE.
|
||
|
*/
|
||
|
#ifndef _LOADER_H
|
||
|
#define _LOADER_H
|
||
|
|
||
|
#include "sym.h"
|
||
|
|
||
|
#if defined(Lynx) && defined(sun)
|
||
|
#define const /**/
|
||
|
#endif
|
||
|
|
||
|
#if (defined(__i386__) || defined(__ix86)) && !defined(i386)
|
||
|
#define i386
|
||
|
#endif
|
||
|
|
||
|
#include <X11/Xosdefs.h>
|
||
|
#include <X11/Xfuncproto.h>
|
||
|
#include <X11/Xmd.h>
|
||
|
|
||
|
/* For LOOKUP definition */
|
||
|
#include "sym.h"
|
||
|
|
||
|
#define LD_UNKNOWN -1
|
||
|
#define LD_ARCHIVE 0
|
||
|
#define LD_ELFOBJECT 1
|
||
|
#define LD_COFFOBJECT 2
|
||
|
#define LD_XCOFFOBJECT 3
|
||
|
#define LD_AOUTOBJECT 4
|
||
|
#define LD_AOUTDLOBJECT 5
|
||
|
#define LD_ELFDLOBJECT 6
|
||
|
|
||
|
#define LD_PROCESSED_ARCHIVE -1
|
||
|
|
||
|
/* #define UNINIT_SECTION */
|
||
|
#define HANDLE_IN_HASH_ENTRY
|
||
|
|
||
|
/*
|
||
|
* COFF Section nmumbers
|
||
|
*/
|
||
|
#define N_TEXT 1
|
||
|
#define N_DATA 2
|
||
|
#define N_BSS 3
|
||
|
#define N_COMMENT 4
|
||
|
|
||
|
#define TestFree(a) if (a) { xfree (a); a = NULL; }
|
||
|
|
||
|
#define HASHDIV 10
|
||
|
#define HASHSIZE (1<<HASHDIV)
|
||
|
|
||
|
typedef struct _elf_reloc *ELFRelocPtr;
|
||
|
typedef struct _elf_COMMON *ELFCommonPtr;
|
||
|
typedef struct _coff_reloc *COFFRelocPtr;
|
||
|
typedef struct _coff_COMMON *COFFCommonPtr;
|
||
|
typedef struct AOUT_RELOC *AOUTRelocPtr;
|
||
|
typedef struct AOUT_COMMON *AOUTCommonPtr;
|
||
|
|
||
|
typedef struct _LoaderReloc {
|
||
|
int modtype;
|
||
|
struct _LoaderReloc *next;
|
||
|
COFFRelocPtr coff_reloc;
|
||
|
ELFRelocPtr elf_reloc;
|
||
|
AOUTRelocPtr aout_reloc;
|
||
|
} LoaderRelocRec, *LoaderRelocPtr;
|
||
|
|
||
|
typedef struct _loader_item *itemPtr;
|
||
|
typedef struct _loader_item {
|
||
|
char *name ;
|
||
|
void *address ;
|
||
|
itemPtr next ;
|
||
|
int handle ;
|
||
|
int module ;
|
||
|
itemPtr exports;
|
||
|
#if defined(__powerpc__)
|
||
|
/*
|
||
|
* PowerPC file formats require special routines in some circumstances
|
||
|
* to assist in the linking process. See the specific loader for
|
||
|
* more details.
|
||
|
*/
|
||
|
union {
|
||
|
unsigned short plt[8]; /* ELF */
|
||
|
unsigned short glink[14]; /* XCOFF */
|
||
|
} code ;
|
||
|
#endif
|
||
|
} itemRec ;
|
||
|
|
||
|
/* The following structures provide an interface to GDB (note that GDB
|
||
|
has copies of the definitions - if you change anything here make
|
||
|
sure that the changes are also made to GDB */
|
||
|
|
||
|
typedef struct {
|
||
|
char *name; /* Name of this symbol */
|
||
|
unsigned int namelen; /* Name of this module */
|
||
|
void *addr; /* Start address of the .text section */
|
||
|
} LDRCommon, *LDRCommonPtr;
|
||
|
|
||
|
typedef struct x_LDRModuleRec{
|
||
|
unsigned int version; /* Version of this struct */
|
||
|
char *name; /* Name of this module */
|
||
|
unsigned int namelen; /* Length of name */
|
||
|
void *text; /* Start address of the .text section */
|
||
|
void *data; /* Start address of the .data section */
|
||
|
void *rodata; /* Start address of the .rodata section */
|
||
|
void *bss; /* Start address of the .bss section */
|
||
|
LDRCommonPtr commons; /* List of commmon symbols */
|
||
|
int commonslen; /* Number of common symbols */
|
||
|
struct x_LDRModuleRec *next; /* Next module record in chain */
|
||
|
} LDRModuleRec, *LDRModulePtr;
|
||
|
|
||
|
extern char DebuggerPresent;
|
||
|
extern LDRModulePtr ModList;
|
||
|
extern LDRCommonPtr ldrCommons;
|
||
|
extern int nCommons;
|
||
|
|
||
|
/*
|
||
|
* The loader uses loader specific alloc/calloc/free functions that
|
||
|
* are mapped to either to the regular Xserver functions, or in a couple
|
||
|
* of special cases, mapped to the C library functions.
|
||
|
*/
|
||
|
#if !defined(PowerMAX_OS) && !(defined(linux) && (defined(__alpha__) || defined(__powerpc__) || defined(__ia64__))) && 0
|
||
|
#define xf86loadermalloc(size) xalloc(size)
|
||
|
#define xf86loaderrealloc(ptr,size) xrealloc(ptr,size)
|
||
|
#define xf86loadercalloc(num,size) xcalloc(num,size)
|
||
|
#define xf86loaderfree(ptr) xfree(ptr)
|
||
|
#define xf86loaderstrdup(ptr) xstrdup(ptr)
|
||
|
#else
|
||
|
/*
|
||
|
* On Some OSes, xalloc() et al uses mmap to allocate space for large
|
||
|
* allocation. This has the effect of placing the text section of some
|
||
|
* modules very far away from the rest which are placed on the heap.
|
||
|
* Certain relocations are limited in the size of the offsets that can be
|
||
|
* handled, and this seperation causes these relocation to overflow. This
|
||
|
* is fixed by just using the C library allocation functions for the loader
|
||
|
* to ensure that all text sections are located on the heap. OSes that have
|
||
|
* this problem are:
|
||
|
* PowerMAX_OS/PPC
|
||
|
* Linux/Alpha
|
||
|
* Linux/PPC
|
||
|
* Linux/IA-64
|
||
|
*/
|
||
|
#define xf86loadermalloc(size) malloc(size)
|
||
|
#define xf86loaderrealloc(ptr,size) realloc(ptr,size)
|
||
|
#define xf86loadercalloc(num,size) calloc(num,size)
|
||
|
#define xf86loaderfree(ptr) free(ptr)
|
||
|
#define xf86loaderstrdup(ptr) strdup(ptr)
|
||
|
#endif
|
||
|
|
||
|
typedef struct _loader *loaderPtr;
|
||
|
|
||
|
/*
|
||
|
* _loader_funcs hold the entry points for a module format.
|
||
|
*/
|
||
|
|
||
|
typedef void * (*LoadModuleProcPtr)(loaderPtr modrec, int fd, LOOKUP **);
|
||
|
typedef void (*ResolveSymbolsProcPtr)(void *);
|
||
|
typedef int (*CheckForUnresolvedProcPtr)(void *);
|
||
|
typedef char * (*AddressToSectionProcPtr)(void *, unsigned long);
|
||
|
typedef void (*LoaderUnloadProcPtr)(void *);
|
||
|
|
||
|
typedef struct _loader_funcs {
|
||
|
LoadModuleProcPtr LoadModule;
|
||
|
ResolveSymbolsProcPtr ResolveSymbols;
|
||
|
CheckForUnresolvedProcPtr CheckForUnresolved;
|
||
|
AddressToSectionProcPtr AddressToSection;
|
||
|
LoaderUnloadProcPtr LoaderUnload;
|
||
|
LoaderRelocRec pRelocs; /* type specific relocations */
|
||
|
} loader_funcs;
|
||
|
|
||
|
/* Each module loaded has a loaderRec */
|
||
|
typedef struct _loader {
|
||
|
int handle; /* Unique id used to remove symbols from
|
||
|
this module when it is unloaded */
|
||
|
int module; /* Unique id to identify compilation units */
|
||
|
char *name;
|
||
|
char *cname;
|
||
|
void *private; /* format specific data */
|
||
|
loader_funcs *funcs; /* funcs for operating on this module */
|
||
|
loaderPtr next;
|
||
|
} loaderRec;
|
||
|
|
||
|
/* Compiled-in version information */
|
||
|
typedef struct {
|
||
|
INT32 xf86Version;
|
||
|
INT32 ansicVersion;
|
||
|
INT32 videodrvVersion;
|
||
|
INT32 xinputVersion;
|
||
|
INT32 extensionVersion;
|
||
|
INT32 fontVersion;
|
||
|
} ModuleVersions;
|
||
|
extern ModuleVersions LoaderVersionInfo;
|
||
|
|
||
|
extern unsigned long LoaderOptions;
|
||
|
|
||
|
/* Internal Functions */
|
||
|
|
||
|
void LoaderAddSymbols(int, int, LOOKUP *);
|
||
|
void LoaderDefaultFunc(void);
|
||
|
void LoaderDuplicateSymbol(const char *, const int);
|
||
|
#if 0
|
||
|
void LoaderFixups(void);
|
||
|
#endif
|
||
|
void LoaderResolve(void);
|
||
|
int LoaderResolveSymbols(void);
|
||
|
int _LoaderHandleUnresolved(char *, char *);
|
||
|
void LoaderHashAdd(itemPtr);
|
||
|
itemPtr LoaderHashDelete(const char *);
|
||
|
itemPtr LoaderHashFind(const char *);
|
||
|
void LoaderHashTraverse(void *, int (*)(void *, itemPtr));
|
||
|
void LoaderPrintAddress(const char *);
|
||
|
void LoaderPrintItem(itemPtr);
|
||
|
void LoaderPrintSymbol(unsigned long);
|
||
|
void LoaderDumpSymbols(void);
|
||
|
char *_LoaderModuleToName(int);
|
||
|
int _LoaderAddressToSection(const unsigned long, const char **, const char **);
|
||
|
int LoaderOpen(const char *, const char *, int, int *, int *, int *);
|
||
|
int LoaderHandleOpen(int);
|
||
|
|
||
|
/*
|
||
|
* File interface functions
|
||
|
*/
|
||
|
void *_LoaderFileToMem(int fd, unsigned long offset, int size, char *label);
|
||
|
void _LoaderFreeFileMem(void *addr, int size);
|
||
|
int _LoaderFileRead(int fd, unsigned int offset, void *addr, int size);
|
||
|
|
||
|
/*
|
||
|
* Relocation list manipulation routines
|
||
|
*/
|
||
|
LoaderRelocPtr _LoaderGetRelocations(void *);
|
||
|
|
||
|
/*
|
||
|
* object to name lookup routines
|
||
|
*/
|
||
|
char * _LoaderHandleToName(int handle);
|
||
|
char * _LoaderHandleToCanonicalName(int handle);
|
||
|
|
||
|
/*
|
||
|
* Entry points for the different loader types
|
||
|
*/
|
||
|
#include "aoutloader.h"
|
||
|
#include "coffloader.h"
|
||
|
#include "elfloader.h"
|
||
|
#include "dlloader.h"
|
||
|
/* LD_ARCHIVE */
|
||
|
void *ARCHIVELoadModule(loaderPtr, int, LOOKUP **);
|
||
|
|
||
|
extern void _loader_debug_state(void);
|
||
|
|
||
|
#endif /* _LOADER_H */
|