OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [gdb-5.0/] [include/] [coff/] [h8500.h] - Diff between revs 107 and 1765

Only display areas with differences | Details | Blame | View Log

Rev 107 Rev 1765
/*** coff information for Hitachi H8/500 */
/*** coff information for Hitachi H8/500 */
 
 
/********************** FILE HEADER **********************/
/********************** FILE HEADER **********************/
 
 
struct external_filehdr {
struct external_filehdr {
        char f_magic[2];        /* magic number                 */
        char f_magic[2];        /* magic number                 */
        char f_nscns[2];        /* number of sections           */
        char f_nscns[2];        /* number of sections           */
        char f_timdat[4];       /* time & date stamp            */
        char f_timdat[4];       /* time & date stamp            */
        char f_symptr[4];       /* file pointer to symtab       */
        char f_symptr[4];       /* file pointer to symtab       */
        char f_nsyms[4];        /* number of symtab entries     */
        char f_nsyms[4];        /* number of symtab entries     */
        char f_opthdr[2];       /* sizeof(optional hdr)         */
        char f_opthdr[2];       /* sizeof(optional hdr)         */
        char f_flags[2];        /* flags                        */
        char f_flags[2];        /* flags                        */
};
};
 
 
 
 
 
 
#define H8500MAGIC      0x8500
#define H8500MAGIC      0x8500
 
 
 
 
#define H8500BADMAG(x) ((0xffff && ((x).f_magic)!=H8500MAGIC))
#define H8500BADMAG(x) ((0xffff && ((x).f_magic)!=H8500MAGIC))
 
 
#define FILHDR  struct external_filehdr
#define FILHDR  struct external_filehdr
#define FILHSZ  20
#define FILHSZ  20
 
 
 
 
/********************** AOUT "OPTIONAL HEADER" **********************/
/********************** AOUT "OPTIONAL HEADER" **********************/
 
 
 
 
typedef struct
typedef struct
{
{
  char  magic[2];               /* type of file                         */
  char  magic[2];               /* type of file                         */
  char  vstamp[2];              /* version stamp                        */
  char  vstamp[2];              /* version stamp                        */
  char  tsize[4];               /* text size in bytes, padded to FW bdry*/
  char  tsize[4];               /* text size in bytes, padded to FW bdry*/
  char  dsize[4];               /* initialized data "  "                */
  char  dsize[4];               /* initialized data "  "                */
  char  bsize[4];               /* uninitialized data "   "             */
  char  bsize[4];               /* uninitialized data "   "             */
  char  entry[4];               /* entry pt.                            */
  char  entry[4];               /* entry pt.                            */
  char  text_start[4];          /* base of text used for this file */
  char  text_start[4];          /* base of text used for this file */
  char  data_start[4];          /* base of data used for this file */
  char  data_start[4];          /* base of data used for this file */
}
}
AOUTHDR;
AOUTHDR;
 
 
 
 
#define AOUTHDRSZ 28
#define AOUTHDRSZ 28
#define AOUTSZ 28
#define AOUTSZ 28
 
 
 
 
 
 
 
 
/********************** SECTION HEADER **********************/
/********************** SECTION HEADER **********************/
 
 
 
 
struct external_scnhdr {
struct external_scnhdr {
        char            s_name[8];      /* section name                 */
        char            s_name[8];      /* section name                 */
        char            s_paddr[4];     /* physical address, aliased s_nlib */
        char            s_paddr[4];     /* physical address, aliased s_nlib */
        char            s_vaddr[4];     /* virtual address              */
        char            s_vaddr[4];     /* virtual address              */
        char            s_size[4];      /* section size                 */
        char            s_size[4];      /* section size                 */
        char            s_scnptr[4];    /* file ptr to raw data for section */
        char            s_scnptr[4];    /* file ptr to raw data for section */
        char            s_relptr[4];    /* file ptr to relocation       */
        char            s_relptr[4];    /* file ptr to relocation       */
        char            s_lnnoptr[4];   /* file ptr to line numbers     */
        char            s_lnnoptr[4];   /* file ptr to line numbers     */
        char            s_nreloc[2];    /* number of relocation entries */
        char            s_nreloc[2];    /* number of relocation entries */
        char            s_nlnno[2];     /* number of line number entries*/
        char            s_nlnno[2];     /* number of line number entries*/
        char            s_flags[4];     /* flags                        */
        char            s_flags[4];     /* flags                        */
};
};
 
 
/*
/*
 * names of "special" sections
 * names of "special" sections
 */
 */
#define _TEXT   ".text"
#define _TEXT   ".text"
#define _DATA   ".data"
#define _DATA   ".data"
#define _BSS    ".bss"
#define _BSS    ".bss"
 
 
 
 
#define SCNHDR  struct external_scnhdr
#define SCNHDR  struct external_scnhdr
#define SCNHSZ  40
#define SCNHSZ  40
 
 
 
 
/********************** LINE NUMBERS **********************/
/********************** LINE NUMBERS **********************/
 
 
/* 1 line number entry for every "breakpointable" source line in a section.
/* 1 line number entry for every "breakpointable" source line in a section.
 * Line numbers are grouped on a per function basis; first entry in a function
 * Line numbers are grouped on a per function basis; first entry in a function
 * grouping will have l_lnno = 0 and in place of physical address will be the
 * grouping will have l_lnno = 0 and in place of physical address will be the
 * symbol table index of the function name.
 * symbol table index of the function name.
 */
 */
struct external_lineno {
struct external_lineno {
        union {
        union {
                char l_symndx[4];       /* function name symbol index, iff l_lnno == 0*/
                char l_symndx[4];       /* function name symbol index, iff l_lnno == 0*/
                char l_paddr[4];        /* (physical) address of line number    */
                char l_paddr[4];        /* (physical) address of line number    */
        } l_addr;
        } l_addr;
        char l_lnno[4]; /* line number          */
        char l_lnno[4]; /* line number          */
};
};
 
 
#define GET_LINENO_LNNO(abfd, ext) bfd_h_get_32(abfd, (bfd_byte *) (ext->l_lnno));
#define GET_LINENO_LNNO(abfd, ext) bfd_h_get_32(abfd, (bfd_byte *) (ext->l_lnno));
#define PUT_LINENO_LNNO(abfd,val, ext) bfd_h_put_32(abfd,val,  (bfd_byte *) (ext->l_lnno));
#define PUT_LINENO_LNNO(abfd,val, ext) bfd_h_put_32(abfd,val,  (bfd_byte *) (ext->l_lnno));
 
 
#define LINENO  struct external_lineno
#define LINENO  struct external_lineno
#define LINESZ  8
#define LINESZ  8
 
 
 
 
/********************** SYMBOLS **********************/
/********************** SYMBOLS **********************/
 
 
#define E_SYMNMLEN      8       /* # characters in a symbol name        */
#define E_SYMNMLEN      8       /* # characters in a symbol name        */
#define E_FILNMLEN      14      /* # characters in a file name          */
#define E_FILNMLEN      14      /* # characters in a file name          */
#define E_DIMNUM        4       /* # array dimensions in auxiliary entry */
#define E_DIMNUM        4       /* # array dimensions in auxiliary entry */
 
 
struct external_syment
struct external_syment
{
{
  union {
  union {
    char e_name[E_SYMNMLEN];
    char e_name[E_SYMNMLEN];
    struct {
    struct {
      char e_zeroes[4];
      char e_zeroes[4];
      char e_offset[4];
      char e_offset[4];
    } e;
    } e;
  } e;
  } e;
  char e_value[4];
  char e_value[4];
  char e_scnum[2];
  char e_scnum[2];
  char e_type[2];
  char e_type[2];
  char e_sclass[1];
  char e_sclass[1];
  char e_numaux[1];
  char e_numaux[1];
};
};
 
 
 
 
 
 
#define N_BTMASK        (017)
#define N_BTMASK        (017)
#define N_TMASK         (060)
#define N_TMASK         (060)
#define N_BTSHFT        (4)
#define N_BTSHFT        (4)
#define N_TSHIFT        (2)
#define N_TSHIFT        (2)
 
 
 
 
union external_auxent {
union external_auxent {
        struct {
        struct {
                char x_tagndx[4];       /* str, un, or enum tag indx */
                char x_tagndx[4];       /* str, un, or enum tag indx */
                union {
                union {
                        struct {
                        struct {
                            char  x_lnno[2]; /* declaration line number */
                            char  x_lnno[2]; /* declaration line number */
                            char  x_size[2]; /* str/union/array size */
                            char  x_size[2]; /* str/union/array size */
                        } x_lnsz;
                        } x_lnsz;
                        char x_fsize[4];        /* size of function */
                        char x_fsize[4];        /* size of function */
                } x_misc;
                } x_misc;
                union {
                union {
                        struct {                /* if ISFCN, tag, or .bb */
                        struct {                /* if ISFCN, tag, or .bb */
                            char x_lnnoptr[4];  /* ptr to fcn line # */
                            char x_lnnoptr[4];  /* ptr to fcn line # */
                            char x_endndx[4];   /* entry ndx past block end */
                            char x_endndx[4];   /* entry ndx past block end */
                        } x_fcn;
                        } x_fcn;
                        struct {                /* if ISARY, up to 4 dimen. */
                        struct {                /* if ISARY, up to 4 dimen. */
                            char x_dimen[E_DIMNUM][2];
                            char x_dimen[E_DIMNUM][2];
                        } x_ary;
                        } x_ary;
                } x_fcnary;
                } x_fcnary;
                char x_tvndx[2];                /* tv index */
                char x_tvndx[2];                /* tv index */
        } x_sym;
        } x_sym;
 
 
        union {
        union {
                char x_fname[E_FILNMLEN];
                char x_fname[E_FILNMLEN];
                struct {
                struct {
                        char x_zeroes[4];
                        char x_zeroes[4];
                        char x_offset[4];
                        char x_offset[4];
                } x_n;
                } x_n;
        } x_file;
        } x_file;
 
 
        struct {
        struct {
                char x_scnlen[4];                       /* section length */
                char x_scnlen[4];                       /* section length */
                char x_nreloc[2];       /* # relocation entries */
                char x_nreloc[2];       /* # relocation entries */
                char x_nlinno[2];       /* # line numbers */
                char x_nlinno[2];       /* # line numbers */
        } x_scn;
        } x_scn;
 
 
        struct {
        struct {
                char x_tvfill[4];       /* tv fill value */
                char x_tvfill[4];       /* tv fill value */
                char x_tvlen[2];        /* length of .tv */
                char x_tvlen[2];        /* length of .tv */
                char x_tvran[2][2];     /* tv range */
                char x_tvran[2][2];     /* tv range */
        } x_tv;         /* info about .tv section (in auxent of symbol .tv)) */
        } x_tv;         /* info about .tv section (in auxent of symbol .tv)) */
 
 
 
 
};
};
 
 
#define SYMENT  struct external_syment
#define SYMENT  struct external_syment
#define SYMESZ  18      
#define SYMESZ  18      
#define AUXENT  union external_auxent
#define AUXENT  union external_auxent
#define AUXESZ  18
#define AUXESZ  18
 
 
 
 
 
 
/********************** RELOCATION DIRECTIVES **********************/
/********************** RELOCATION DIRECTIVES **********************/
 
 
/* The external reloc has an offset field, because some of the reloc
/* The external reloc has an offset field, because some of the reloc
   types on the h8 don't have room in the instruction for the entire
   types on the h8 don't have room in the instruction for the entire
   offset - eg the strange jump and high page addressing modes */
   offset - eg the strange jump and high page addressing modes */
 
 
struct external_reloc {
struct external_reloc {
  char r_vaddr[4];
  char r_vaddr[4];
  char r_symndx[4];
  char r_symndx[4];
  char r_offset[4];
  char r_offset[4];
  char r_type[2];
  char r_type[2];
  char r_stuff[2];
  char r_stuff[2];
};
};
 
 
 
 
#define RELOC struct external_reloc
#define RELOC struct external_reloc
#define RELSZ 16
#define RELSZ 16
 
 
 
 
 
 
 
 
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.