485 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			485 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Declarations of internal format of MIPS ECOFF symbols.
 | |
|    Originally contributed by MIPS Computer Systems and Third Eye Software.
 | |
|    Changes contributed by Cygnus Support are in the public domain.  
 | |
| 
 | |
|    This file is just aggregated with the files that make up the GNU
 | |
|    release; it is not considered part of GAS, GDB, or other GNU
 | |
|    programs.  */
 | |
| 
 | |
| /*
 | |
|  * |-----------------------------------------------------------|
 | |
|  * | Copyright (c) 1992, 1991, 1990 MIPS Computer Systems, Inc.|
 | |
|  * | MIPS Computer Systems, Inc. grants reproduction and use   |
 | |
|  * | rights to all parties, PROVIDED that this comment is      |
 | |
|  * | maintained in the copy.                                   |
 | |
|  * |-----------------------------------------------------------|
 | |
|  */
 | |
| #ifndef _SYM_H
 | |
| #define _SYM_H
 | |
| 
 | |
| /* (C) Copyright 1984 by Third Eye Software, Inc.
 | |
|  *
 | |
|  * Third Eye Software, Inc. grants reproduction and use rights to
 | |
|  * all parties, PROVIDED that this comment is maintained in the copy.
 | |
|  *
 | |
|  * Third Eye makes no claims about the applicability of this
 | |
|  * symbol table to a particular use.
 | |
|  */
 | |
| 
 | |
| /* 
 | |
|  * This file contains the definition of the Third Eye Symbol Table.
 | |
|  *
 | |
|  * Symbols are assumed to be in 'encounter order' - i.e. the order that
 | |
|  * the things they represent were encountered by the compiler/assembler/loader.
 | |
|  * EXCEPT for globals!	These are assumed to be bunched together,
 | |
|  * probably right after the last 'normal' symbol.  Globals ARE sorted
 | |
|  * in ascending order.
 | |
|  *
 | |
|  * -----------------------------------------------------------------------
 | |
|  * A brief word about Third Eye naming/use conventions:
 | |
|  *
 | |
|  * All arrays and index's are 0 based.
 | |
|  * All "ifooMax" values are the highest legal value PLUS ONE. This makes
 | |
|  * them good for allocating arrays, etc. All checks are "ifoo < ifooMax".
 | |
|  *
 | |
|  * "isym"	Index into the SYMbol table.
 | |
|  * "ipd"	Index into the Procedure Descriptor array.
 | |
|  * "ifd"	Index into the File Descriptor array.
 | |
|  * "iss"	Index into String Space.
 | |
|  * "cb"		Count of Bytes.
 | |
|  * "rgPd"	array whose domain is "0..ipdMax-1" and RanGe is PDR.
 | |
|  * "rgFd"	array whose domain is "0..ifdMax-1" and RanGe is FDR.
 | |
|  */
 | |
| 
 | |
| 
 | |
| /* 
 | |
|  * Symbolic Header (HDR) structure.
 | |
|  * As long as all the pointers are set correctly,
 | |
|  * we don't care WHAT order the various sections come out in!
 | |
|  *
 | |
|  * A file produced solely for the use of CDB will probably NOT have
 | |
|  * any instructions or data areas in it, as these are available
 | |
|  * in the original.
 | |
|  */
 | |
| 
 | |
| typedef struct {
 | |
| 	short	magic;		/* to verify validity of the table */
 | |
| 	short	vstamp;		/* version stamp */
 | |
| 	long	ilineMax;	/* number of line number entries */
 | |
| 	bfd_vma	cbLine;		/* number of bytes for line number entries */
 | |
| 	bfd_vma	cbLineOffset;	/* offset to start of line number entries*/
 | |
| 	long	idnMax;		/* max index into dense number table */
 | |
| 	bfd_vma	cbDnOffset;	/* offset to start dense number table */
 | |
| 	long	ipdMax;		/* number of procedures */
 | |
| 	bfd_vma	cbPdOffset;	/* offset to procedure descriptor table */
 | |
| 	long	isymMax;	/* number of local symbols */
 | |
| 	bfd_vma	cbSymOffset;	/* offset to start of local symbols*/
 | |
| 	long	ioptMax;	/* max index into optimization symbol entries */
 | |
| 	bfd_vma	cbOptOffset;	/* offset to optimization symbol entries */
 | |
| 	long	iauxMax;	/* number of auxillary symbol entries */
 | |
| 	bfd_vma	cbAuxOffset;	/* offset to start of auxillary symbol entries*/
 | |
| 	long	issMax;		/* max index into local strings */
 | |
| 	bfd_vma	cbSsOffset;	/* offset to start of local strings */
 | |
| 	long	issExtMax;	/* max index into external strings */
 | |
| 	bfd_vma	cbSsExtOffset;	/* offset to start of external strings */
 | |
| 	long	ifdMax;		/* number of file descriptor entries */
 | |
| 	bfd_vma	cbFdOffset;	/* offset to file descriptor table */
 | |
| 	long	crfd;		/* number of relative file descriptor entries */
 | |
| 	bfd_vma	cbRfdOffset;	/* offset to relative file descriptor table */
 | |
| 	long	iextMax;	/* max index into external symbols */
 | |
| 	bfd_vma	cbExtOffset;	/* offset to start of external symbol entries*/
 | |
| 	/* If you add machine dependent fields, add them here */
 | |
| 	} HDRR, *pHDRR; 
 | |
| #define cbHDRR sizeof(HDRR)
 | |
| #define hdrNil ((pHDRR)0)
 | |
| 
 | |
| /*
 | |
|  * The FDR and PDR structures speed mapping of address <-> name.
 | |
|  * They are sorted in ascending memory order and are kept in
 | |
|  * memory by CDB at runtime.
 | |
|  */
 | |
| 
 | |
| /* 
 | |
|  * File Descriptor
 | |
|  *
 | |
|  * There is one of these for EVERY FILE, whether compiled with
 | |
|  * full debugging symbols or not.  The name of a file should be
 | |
|  * the path name given to the compiler.	 This allows the user
 | |
|  * to simply specify the names of the directories where the COMPILES
 | |
|  * were done, and we will be able to find their files.
 | |
|  * A field whose comment starts with "R - " indicates that it will be
 | |
|  * setup at runtime.
 | |
|  */
 | |
| typedef struct fdr {
 | |
| 	bfd_vma	adr;		/* memory address of beginning of file */
 | |
| 	long	rss;		/* file name (of source, if known) */
 | |
| 	long	issBase;	/* file's string space */
 | |
| 	bfd_vma	cbSs;		/* number of bytes in the ss */
 | |
| 	long	isymBase;	/* beginning of symbols */
 | |
| 	long	csym;		/* count file's of symbols */
 | |
| 	long	ilineBase;	/* file's line symbols */
 | |
| 	long	cline;		/* count of file's line symbols */
 | |
| 	long	ioptBase;	/* file's optimization entries */
 | |
| 	long	copt;		/* count of file's optimization entries */
 | |
| 	unsigned short ipdFirst;/* start of procedures for this file */
 | |
| 	short	cpd;		/* count of procedures for this file */
 | |
| 	long	iauxBase;	/* file's auxiliary entries */
 | |
| 	long	caux;		/* count of file's auxiliary entries */
 | |
| 	long	rfdBase;	/* index into the file indirect table */
 | |
| 	long	crfd;		/* count file indirect entries */
 | |
| 	unsigned lang: 5;	/* language for this file */
 | |
| 	unsigned fMerge : 1;	/* whether this file can be merged */
 | |
| 	unsigned fReadin : 1;	/* true if it was read in (not just created) */
 | |
| 	unsigned fBigendian : 1;/* if set, was compiled on big endian machine */
 | |
| 				/*	aux's will be in compile host's sex */
 | |
| 	unsigned glevel : 2;	/* level this file was compiled with */
 | |
| 	unsigned reserved : 22;  /* reserved for future use */
 | |
| 	bfd_vma	cbLineOffset;	/* byte offset from header for this file ln's */
 | |
| 	bfd_vma	cbLine;		/* size of lines for this file */
 | |
| 	} FDR, *pFDR;
 | |
| #define cbFDR sizeof(FDR)
 | |
| #define fdNil ((pFDR)0)
 | |
| #define ifdNil -1
 | |
| #define ifdTemp 0
 | |
| #define ilnNil -1
 | |
| 
 | |
| 
 | |
| /* 
 | |
|  * Procedure Descriptor
 | |
|  *
 | |
|  * There is one of these for EVERY TEXT LABEL.
 | |
|  * If a procedure is in a file with full symbols, then isym
 | |
|  * will point to the PROC symbols, else it will point to the
 | |
|  * global symbol for the label.
 | |
|  */
 | |
| 
 | |
| typedef struct pdr {
 | |
| 	bfd_vma	adr;		/* memory address of start of procedure */
 | |
| 	long	isym;		/* start of local symbol entries */
 | |
| 	long	iline;		/* start of line number entries*/
 | |
| 	long	regmask;	/* save register mask */
 | |
| 	long	regoffset;	/* save register offset */
 | |
| 	long	iopt;		/* start of optimization symbol entries*/
 | |
| 	long	fregmask;	/* save floating point register mask */
 | |
| 	long	fregoffset;	/* save floating point register offset */
 | |
| 	long	frameoffset;	/* frame size */
 | |
| 	short	framereg;	/* frame pointer register */
 | |
| 	short	pcreg;		/* offset or reg of return pc */
 | |
| 	long	lnLow;		/* lowest line in the procedure */
 | |
| 	long	lnHigh;		/* highest line in the procedure */
 | |
| 	bfd_vma	cbLineOffset;	/* byte offset for this procedure from the fd base */
 | |
| 	/* These fields are new for 64 bit ECOFF.  */
 | |
| 	unsigned gp_prologue : 8; /* byte size of GP prologue */
 | |
| 	unsigned gp_used : 1;	/* true if the procedure uses GP */
 | |
| 	unsigned reg_frame : 1;	/* true if register frame procedure */
 | |
| 	unsigned prof : 1;	/* true if compiled with -pg */
 | |
| 	unsigned reserved : 13;	/* reserved: must be zero */
 | |
| 	unsigned localoff : 8;	/* offset of local variables from vfp */
 | |
| 	} PDR, *pPDR;
 | |
| #define cbPDR sizeof(PDR)
 | |
| #define pdNil ((pPDR) 0)
 | |
| #define ipdNil	-1
 | |
| 
 | |
| /*
 | |
|  * The structure of the runtime procedure descriptor created by the loader
 | |
|  * for use by the static exception system.
 | |
|  */
 | |
| /*
 | |
|  * If 0'd out because exception_info chokes Visual C++ and because there
 | |
|  * don't seem to be any references to this structure elsewhere in gdb.
 | |
|  */
 | |
| #if 0
 | |
| typedef struct runtime_pdr {
 | |
| 	bfd_vma	adr;		/* memory address of start of procedure */
 | |
| 	long	regmask;	/* save register mask */
 | |
| 	long	regoffset;	/* save register offset */
 | |
| 	long	fregmask;	/* save floating point register mask */
 | |
| 	long	fregoffset;	/* save floating point register offset */
 | |
| 	long	frameoffset;	/* frame size */
 | |
| 	short	framereg;	/* frame pointer register */
 | |
| 	short	pcreg;		/* offset or reg of return pc */
 | |
| 	long	irpss;		/* index into the runtime string table */
 | |
| 	long	reserved;
 | |
| 	struct exception_info *exception_info;/* pointer to exception array */
 | |
| } RPDR, *pRPDR;
 | |
| #define cbRPDR sizeof(RPDR)
 | |
| #define rpdNil ((pRPDR) 0)
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * Line Numbers
 | |
|  *
 | |
|  * Line Numbers are segregated from the normal symbols because they
 | |
|  * are [1] smaller , [2] are of no interest to your
 | |
|  * average loader, and [3] are never needed in the middle of normal
 | |
|  * scanning and therefore slow things down.
 | |
|  *
 | |
|  * By definition, the first LINER for any given procedure will have
 | |
|  * the first line of a procedure and represent the first address.
 | |
|  */
 | |
| 
 | |
| typedef	long LINER, *pLINER;
 | |
| #define lineNil ((pLINER)0)
 | |
| #define cbLINER sizeof(LINER)
 | |
| #define ilineNil	-1
 | |
| 
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * The Symbol Structure		(GFW, to those who Know!)
 | |
|  */
 | |
| 
 | |
| typedef struct {
 | |
| 	long	iss;		/* index into String Space of name */
 | |
| 	bfd_vma	value;		/* value of symbol */
 | |
| 	unsigned st : 6;	/* symbol type */
 | |
| 	unsigned sc  : 5;	/* storage class - text, data, etc */
 | |
| 	unsigned reserved : 1;	/* reserved */
 | |
| 	unsigned index : 20;	/* index into sym/aux table */
 | |
| 	} SYMR, *pSYMR;
 | |
| #define symNil ((pSYMR)0)
 | |
| #define cbSYMR sizeof(SYMR)
 | |
| #define isymNil -1
 | |
| #define indexNil 0xfffff
 | |
| #define issNil -1
 | |
| #define issNull 0
 | |
| 
 | |
| 
 | |
| /* The following converts a memory resident string to an iss.
 | |
|  * This hack is recognized in SbFIss, in sym.c of the debugger.
 | |
|  */
 | |
| #define IssFSb(sb) (0x80000000 | ((unsigned long)(sb)))
 | |
| 
 | |
| /* E X T E R N A L   S Y M B O L  R E C O R D
 | |
|  *
 | |
|  *	Same as the SYMR except it contains file context to determine where
 | |
|  *	the index is.
 | |
|  */
 | |
| typedef struct ecoff_extr {
 | |
| 	unsigned jmptbl:1;	/* symbol is a jump table entry for shlibs */
 | |
| 	unsigned cobol_main:1;	/* symbol is a cobol main procedure */
 | |
| 	unsigned weakext:1;	/* symbol is weak external */
 | |
| 	unsigned reserved:13;	/* reserved for future use */
 | |
| 	int	ifd;		/* where the iss and index fields point into */
 | |
| 	SYMR	asym;		/* symbol for the external */
 | |
| 	} EXTR, *pEXTR;
 | |
| #define extNil ((pEXTR)0)
 | |
| #define cbEXTR sizeof(EXTR)
 | |
| 
 | |
| 
 | |
| /* A U X I L L A R Y   T Y P E	 I N F O R M A T I O N */
 | |
| 
 | |
| /*
 | |
|  * Type Information Record
 | |
|  */
 | |
| typedef struct {
 | |
| 	unsigned fBitfield : 1; /* set if bit width is specified */
 | |
| 	unsigned continued : 1; /* indicates additional TQ info in next AUX */
 | |
| 	unsigned bt  : 6;	/* basic type */
 | |
| 	unsigned tq4 : 4;
 | |
| 	unsigned tq5 : 4;
 | |
| 	/* ---- 16 bit boundary ---- */
 | |
| 	unsigned tq0 : 4;
 | |
| 	unsigned tq1 : 4;	/* 6 type qualifiers - tqPtr, etc. */
 | |
| 	unsigned tq2 : 4;
 | |
| 	unsigned tq3 : 4;
 | |
| 	} TIR, *pTIR;
 | |
| #define cbTIR sizeof(TIR)
 | |
| #define tiNil ((pTIR)0)
 | |
| #define itqMax 6
 | |
| 
 | |
| /*
 | |
|  * Relative symbol record
 | |
|  *
 | |
|  * If the rfd field is 4095, the index field indexes into the global symbol
 | |
|  *	table.
 | |
|  */
 | |
| 
 | |
| typedef struct {
 | |
| 	unsigned	rfd : 12;    /* index into the file indirect table */
 | |
| 	unsigned	index : 20; /* index int sym/aux/iss tables */
 | |
| 	} RNDXR, *pRNDXR;
 | |
| #define cbRNDXR sizeof(RNDXR)
 | |
| #define rndxNil ((pRNDXR)0)
 | |
| 
 | |
| /* dense numbers or sometimes called block numbers are stored in this type,
 | |
|  *	a rfd of 0xffffffff is an index into the global table.
 | |
|  */
 | |
| typedef struct {
 | |
| 	unsigned long	rfd;    /* index into the file table */
 | |
| 	unsigned long	index; 	/* index int sym/aux/iss tables */
 | |
| 	} DNR, *pDNR;
 | |
| #define cbDNR sizeof(DNR)
 | |
| #define dnNil ((pDNR)0)
 | |
| 
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * Auxillary information occurs only if needed.
 | |
|  * It ALWAYS occurs in this order when present.
 | |
| 
 | |
| 	    isymMac		used by stProc only
 | |
| 	    TIR			type info
 | |
| 	    TIR			additional TQ info (if first TIR was not enough)
 | |
| 	    rndx		if (bt == btStruct,btUnion,btEnum,btSet,btRange,
 | |
| 				    btTypedef):
 | |
| 				    rsym.index == iaux for btSet or btRange
 | |
| 				    else rsym.index == isym
 | |
| 	    dimLow		btRange, btSet
 | |
| 	    dimMac		btRange, btSet
 | |
| 	    rndx0		As many as there are tq arrays
 | |
| 	    dimLow0
 | |
| 	    dimHigh0
 | |
| 	    ...
 | |
| 	    rndxMax-1
 | |
| 	    dimLowMax-1
 | |
| 	    dimHighMax-1
 | |
| 	    width in bits	if (bit field), width in bits.
 | |
|  */
 | |
| #define cAuxMax (6 + (idimMax*3))
 | |
| 
 | |
| /* a union of all possible info in the AUX universe */
 | |
| typedef union {
 | |
| 	TIR	ti;		/* type information record */
 | |
| 	RNDXR	rndx;		/* relative index into symbol table */
 | |
| 	long	dnLow;		/* low dimension */
 | |
| 	long	dnHigh;		/* high dimension */
 | |
| 	long	isym;		/* symbol table index (end of proc) */
 | |
| 	long	iss;		/* index into string space (not used) */
 | |
| 	long	width;		/* width for non-default sized struc fields */
 | |
| 	long	count;		/* count of ranges for variant arm */
 | |
| 	} AUXU, *pAUXU;
 | |
| #define cbAUXU sizeof(AUXU)
 | |
| #define auxNil ((pAUXU)0)
 | |
| #define iauxNil -1
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * Optimization symbols
 | |
|  *
 | |
|  * Optimization symbols contain some overlap information with the normal
 | |
|  * symbol table. In particular, the proc information
 | |
|  * is somewhat redundant but necessary to easily find the other information
 | |
|  * present. 
 | |
|  *
 | |
|  * All of the offsets are relative to the beginning of the last otProc
 | |
|  */
 | |
| 
 | |
| typedef struct {
 | |
| 	unsigned ot: 8;		/* optimization type */
 | |
| 	unsigned value: 24;	/* address where we are moving it to */
 | |
| 	RNDXR	rndx;		/* points to a symbol or opt entry */
 | |
| 	unsigned long	offset;	/* relative offset this occured */
 | |
| 	} OPTR, *pOPTR;
 | |
| #define optNil	((pOPTR) 0)
 | |
| #define cbOPTR sizeof(OPTR)
 | |
| #define ioptNil -1
 | |
| 
 | |
| /*
 | |
|  * File Indirect
 | |
|  *
 | |
|  * When a symbol is referenced across files the following procedure is used:
 | |
|  *	1) use the file index to get the File indirect entry.
 | |
|  *	2) use the file indirect entry to get the File descriptor.
 | |
|  *	3) add the sym index to the base of that file's sym table
 | |
|  *
 | |
|  */
 | |
| 
 | |
| typedef long RFDT, *pRFDT;
 | |
| #define cbRFDT sizeof(RFDT)
 | |
| #define rfdNil	-1
 | |
| 
 | |
| /*
 | |
|  * The file indirect table in the mips loader is known as an array of FITs.
 | |
|  * This is done to keep the code in the loader readable in the area where
 | |
|  * these tables are merged.  Note this is only a name change.
 | |
|  */
 | |
| typedef long FIT, *pFIT;
 | |
| #define cbFIT	sizeof(FIT)
 | |
| #define ifiNil	-1
 | |
| #define fiNil	((pFIT) 0)
 | |
| 
 | |
| #ifdef _LANGUAGE_PASCAL
 | |
| #define ifdNil -1
 | |
| #define ilnNil -1
 | |
| #define ipdNil -1
 | |
| #define ilineNil -1
 | |
| #define isymNil -1
 | |
| #define indexNil 16#fffff
 | |
| #define issNil -1
 | |
| #define issNull 0
 | |
| #define itqMax 6
 | |
| #define iauxNil -1
 | |
| #define ioptNil -1
 | |
| #define rfdNil -1
 | |
| #define ifiNil -1
 | |
| #endif	/* _LANGUAGE_PASCAL */
 | |
| 
 | |
| 
 | |
| /* Dense numbers
 | |
|  *
 | |
|  * Rather than use file index, symbol index pairs to represent symbols
 | |
|  *	and globals, we use dense number so that they can be easily embeded
 | |
|  *	in intermediate code and the programs that process them can
 | |
|  *	use direct access tabls instead of hash table (which would be
 | |
|  *	necesary otherwise because of the sparse name space caused by
 | |
|  *	file index, symbol index pairs. Dense number are represented
 | |
|  *	by RNDXRs.
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * The following table defines the meaning of each SYM field as
 | |
|  * a function of the "st". (scD/B == scData OR scBss)
 | |
|  *
 | |
|  * Note: the value "isymMac" is used by symbols that have the concept
 | |
|  * of enclosing a block of related information.	 This value is the
 | |
|  * isym of the first symbol AFTER the end associated with the primary
 | |
|  * symbol. For example if a procedure was at isym==90 and had an
 | |
|  * isymMac==155, the associated end would be at isym==154, and the
 | |
|  * symbol at 155 would probably (although not necessarily) be the
 | |
|  * symbol for the next procedure.  This allows rapid skipping over
 | |
|  * internal information of various sorts. "stEnd"s ALWAYS have the
 | |
|  * isym of the primary symbol that started the block.
 | |
|  * 
 | |
| 
 | |
| ST		SC	VALUE		INDEX
 | |
| --------	------	--------	------
 | |
| stFile		scText	address		isymMac
 | |
| stLabel		scText	address		---
 | |
| stGlobal	scD/B	address		iaux
 | |
| stStatic	scD/B	address		iaux
 | |
| stParam		scAbs	offset		iaux
 | |
| stLocal		scAbs	offset		iaux
 | |
| stProc		scText	address		iaux	(isymMac is first AUX)
 | |
| stStaticProc	scText	address		iaux	(isymMac is first AUX)
 | |
| 
 | |
| stMember	scNil	ordinal		---	(if member of enum)
 | |
| 	(mipsread thinks the case below has a bit, not byte, offset.)
 | |
| stMember	scNil	byte offset	iaux	(if member of struct/union)
 | |
| stMember	scBits	bit offset	iaux	(bit field spec)
 | |
| 
 | |
| stBlock		scText	address		isymMac (text block)
 | |
| 	(the code seems to think that rather than scNil, we see scInfo for
 | |
| 	 the two cases below.)
 | |
| stBlock		scNil	cb		isymMac (struct/union member define)
 | |
| stBlock		scNil	cMembers	isymMac (enum member define)
 | |
| 
 | |
| 	(New types added by SGI to simplify things:)
 | |
| stStruct	scInfo	cb		isymMac (struct type define)
 | |
| stUnion		scInfo	cb		isymMac (union  type define)
 | |
| stEnum		scInfo	cMembers	isymMac (enum   type define)
 | |
| 
 | |
| stEnd		scText	address		isymStart
 | |
| stEnd		scNil	-------		isymStart (struct/union/enum)
 | |
| 
 | |
| stTypedef	scNil	-------		iaux
 | |
| stRegReloc	sc???	value		old register number
 | |
| stForward	sc???	new address	isym to original symbol
 | |
| 
 | |
| stConstant	scInfo	value		--- (scalar)
 | |
| stConstant	scInfo	iss		--- (complex, e.g. string)
 | |
| 
 | |
|  *
 | |
|  */
 | |
| #endif
 |