aboutsummaryrefslogtreecommitdiff
path: root/include/coff-i960.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/coff-i960.h')
-rwxr-xr-xinclude/coff-i960.h132
1 files changed, 99 insertions, 33 deletions
diff --git a/include/coff-i960.h b/include/coff-i960.h
index db21c4b..bf33d5a 100755
--- a/include/coff-i960.h
+++ b/include/coff-i960.h
@@ -7,23 +7,34 @@
/********************** FILE HEADER **********************/
-struct filehdr {
- unsigned short f_magic; /* magic number */
- unsigned short f_nscns; /* number of sections */
- long f_timdat; /* time & date stamp */
- long f_symptr; /* file pointer to symtab */
- long f_nsyms; /* number of symtab entries */
- unsigned short f_opthdr; /* sizeof(optional hdr) */
- unsigned short f_flags; /* flags */
+struct external_filehdr {
+ char f_magic[2]; /* magic number */
+ char f_nscns[2]; /* number of sections */
+ char f_timdat[4]; /* time & date stamp */
+ char f_symptr[4]; /* file pointer to symtab */
+ char f_nsyms[4]; /* number of symtab entries */
+ char f_opthdr[2]; /* sizeof(optional hdr) */
+ char f_flags[2]; /* flags */
+};
+
+struct internal_filehdr
+{
+ unsigned short f_magic; /* magic number */
+ unsigned short f_nscns; /* number of sections */
+ long f_timdat; /* time & date stamp */
+ long f_symptr; /* file pointer to symtab */
+ long f_nsyms; /* number of symtab entries */
+ unsigned short f_opthdr; /* sizeof(optional hdr) */
+ unsigned short f_flags; /* flags */
};
/* Bits for f_flags:
- * F_RELFLG relocation info stripped from file
- * F_EXEC file is executable (no unresolved external references)
- * F_LNNO line numbers stripped from file
- * F_LSYMS local symbols stripped from file
- * F_AR32WR file has byte ordering of an AR32WR machine (e.g. vax)
- */
+* F_RELFLG relocation info stripped from file
+* F_EXEC file is executable (no unresolved external references)
+* F_LNNO line numbers stripped from file
+* F_LSYMS local symbols stripped from file
+* F_AR32WR file has byte ordering of an AR32WR machine (e.g. vax)
+*/
#define F_RELFLG (0x0001)
#define F_EXEC (0x0002)
@@ -32,9 +43,9 @@ struct filehdr {
#define F_AR32WR (0x0010)
/*
- * Intel 80960 (I960) processor flags.
- * F_I960TYPE == mask for processor type field.
- */
+* Intel 80960 (I960) processor flags.
+* F_I960TYPE == mask for processor type field.
+*/
#define F_I960TYPE (0xf000)
#define F_I960CORE (0x1000)
@@ -45,19 +56,35 @@ struct filehdr {
#define F_I960CA (0x5000)
#define F_I960KA (0x6000)
#define F_I960SA (0x6000)
-
- /*
- * i80960 Magic Numbers
- */
+
+
+/* Mips magics */
+#define MIPSEBMAGIC 0x160
+#define MIPSELMAGIC 0x161
+#define SMIPSEBMAGIC 0x6001
+#define SMIPSELMAGIC 0x162 /*0x6201*/
+#define MIPSEBUMAGIC 0x0180
+#define MIPSELUMAGIC 0x0182
+
+
+
+#define ECOFFBADMAG(x) (((x).f_magic!=MIPSEBMAGIC) &&\
+ ((x).f_magic!=MIPSELMAGIC) &&\
+ ((x).f_magic!=SMIPSEBMAGIC) &&\
+ ((x).f_magic!=SMIPSELMAGIC) &&\
+ ((x).f_magic!=MIPSEBUMAGIC) &&\
+ ((x).f_magic!=MIPSELUMAGIC))
+
+/** i80960 Magic Numbers
+*/
#define I960ROMAGIC (0x160) /* read-only text segments */
#define I960RWMAGIC (0x161) /* read-write text segments */
#define I960BADMAG(x) (((x).f_magic!=I960ROMAGIC) && ((x).f_magic!=I960RWMAGIC))
-#define FILHDR struct filehdr
-#define FILHSZ sizeof(FILHDR)
-
+#define FILHDR struct external_filehdr
+#define FILHSZ 20
/********************** AOUT "OPTIONAL HEADER" **********************/
@@ -89,7 +116,7 @@ typedef struct {
#define SASMAGIC (010000) /* (?) "Single Address Space" */
#define MASMAGIC (020000) /* (?) "Multiple (separate I/D) Addr. Spaces" */
-typedef struct aouthdr {
+struct internal_aouthdr {
short magic; /* type of file */
short vstamp; /* version stamp */
unsigned long tsize; /* text size in bytes, padded to FW bdry*/
@@ -101,9 +128,31 @@ typedef struct aouthdr {
#endif
unsigned long entry; /* entry pt. */
unsigned long text_start; /* base of text used for this file */
- unsigned long data_start; /* base of data used for this file */
- unsigned long tagentries; /* number of tag entries to follow */
-} AOUTHDR;
+ unsigned long data_start; /* base of data used for this
+ file */
+#ifndef MIPS
+ unsigned long tagentries; /* number of tag entries to
+ follow */
+#endif
+
+} ;
+
+
+typedef struct
+{
+ char magic[2]; /* type of file */
+ char vstamp[2]; /* version stamp */
+ char tsize[4]; /* text size in bytes, padded to FW bdry*/
+ char dsize[4]; /* initialized data " " */
+ char bsize[4]; /* uninitialized data " " */
+ char entry[4]; /* entry pt. */
+ char text_start[4]; /* base of text used for this file */
+ char data_start[4]; /* base of data used for this file */
+#ifndef MIPS
+ char tagentries[4]; /* number of tag entries to follow */
+#endif
+}
+AOUTHDR;
/* return a pointer to the tag bits array */
@@ -163,7 +212,7 @@ typedef struct aouthdr {
/********************** SECTION HEADER **********************/
-struct scnhdr {
+struct internal_scnhdr {
char s_name[8]; /* section name */
long s_paddr; /* physical address, aliased s_nlib */
long s_vaddr; /* virtual address */
@@ -180,6 +229,23 @@ struct scnhdr {
#endif
};
+struct external_scnhdr {
+ char s_name[8]; /* section name */
+ char s_paddr[4]; /* physical address, aliased s_nlib */
+ char s_vaddr[4]; /* virtual address */
+ char s_size[4]; /* section size */
+ char s_scnptr[4]; /* file ptr to raw data for section */
+ char s_relptr[4]; /* file ptr to relocation */
+ char s_lnnoptr[4]; /* file ptr to line numbers */
+ char s_nreloc[2]; /* number of relocation entries */
+ char s_nlnno[2]; /* number of line number entries*/
+ char s_flags[4]; /* flags */
+#ifndef MIPS
+ /* This field exists in Intel COFF, not in Mips ECOFF. */
+ char s_align[4]; /* section alignment */
+#endif
+};
+
/*
* names of "special" sections
*/
@@ -211,7 +277,7 @@ struct scnhdr {
#define STYP_REVERSE_PAD (0x4000) /* section will be padded with no-op instructions wherever padding is necessary and there is a
word of contiguous bytes beginning on a word boundary. */
-#define SCNHDR struct scnhdr
+#define SCNHDR struct external_scnhdr
#define SCNHSZ sizeof(SCNHDR)
@@ -227,7 +293,7 @@ struct external_lineno {
char l_symndx[4]; /* function name symbol index, iff l_lnno == 0*/
char l_paddr[4]; /* (physical) address of line number */
} l_addr;
- unsigned short l_lnno; /* line number */
+ char l_lnno[2]; /* line number */
char padding[2]; /* force alignment */
};
@@ -462,9 +528,9 @@ union internal_auxent {
};
#define SYMENT struct external_syment
-#define SYMESZ sizeof(SYMENT)
+#define SYMESZ sizeof(SYMENT) /* FIXME - calc by hand */
#define AUXENT union external_auxent
-#define AUXESZ sizeof(AUXENT)
+#define AUXESZ sizeof(AUXENT) /* FIXME - calc by hand */
# define _ETEXT "_etext"