Home | History | Annotate | Line # | Download | only in include
ecoff_machdep.h revision 1.19.108.1
      1  1.19.108.1      yamt /*	$NetBSD: ecoff_machdep.h,v 1.19.108.1 2010/03/11 15:02:38 yamt Exp $	*/
      2         1.3       cgd 
      3         1.1     glass /*
      4         1.7  jonathan  * Copyright (c) 1997 Jonathan Stone
      5         1.7  jonathan  * All rights reserved.
      6         1.7  jonathan  *
      7         1.1     glass  * Copyright (c) 1994 Adam Glass
      8         1.1     glass  * All rights reserved.
      9         1.1     glass  *
     10         1.1     glass  * Redistribution and use in source and binary forms, with or without
     11         1.1     glass  * modification, are permitted provided that the following conditions
     12         1.1     glass  * are met:
     13         1.1     glass  * 1. Redistributions of source code must retain the above copyright
     14         1.1     glass  *    notice, this list of conditions and the following disclaimer.
     15         1.1     glass  * 2. Redistributions in binary form must reproduce the above copyright
     16         1.1     glass  *    notice, this list of conditions and the following disclaimer in the
     17         1.1     glass  *    documentation and/or other materials provided with the distribution.
     18         1.1     glass  * 3. All advertising materials mentioning features or use of this software
     19         1.1     glass  *    must display the following acknowledgement:
     20         1.1     glass  *	This product includes software developed by Adam Glass.
     21         1.1     glass  * 4. The name of the Author may not be used to endorse or promote products
     22         1.1     glass  *    derived from this software without specific prior written permission.
     23         1.1     glass  *
     24         1.1     glass  * THIS SOFTWARE IS PROVIDED BY Adam Glass ``AS IS'' AND
     25         1.1     glass  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     26         1.1     glass  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     27         1.1     glass  * ARE DISCLAIMED.  IN NO EVENT SHALL Adam Glass BE LIABLE
     28         1.1     glass  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     29         1.1     glass  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     30         1.1     glass  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     31         1.1     glass  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     32         1.1     glass  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     33         1.1     glass  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     34         1.1     glass  * SUCH DAMAGE.
     35         1.1     glass  */
     36         1.1     glass 
     37         1.2     glass #define ECOFF_LDPGSZ 4096
     38         1.2     glass 
     39         1.1     glass #define ECOFF_PAD
     40         1.1     glass 
     41         1.1     glass #define ECOFF_MACHDEP \
     42         1.5       cgd         u_long gprmask; \
     43         1.5       cgd         u_long cprmask[4]; \
     44         1.5       cgd         u_long gp_value
     45        1.12  jonathan #ifdef _KERNEL
     46        1.12  jonathan #include <mips/cpu.h>		/* mips CPU architecture levels */
     47        1.12  jonathan #define _MIPS3_OK() CPUISMIPS3
     48        1.12  jonathan #else
     49        1.13    mhitch #define _MIPS3_OK() 1
     50        1.12  jonathan #endif
     51         1.1     glass 
     52        1.16    simonb 
     53        1.15    tsubai #define ECOFF_MAGIC_MIPSEB	0x0160	/* mips1, big-endian */
     54        1.11  jonathan #define ECOFF_MAGIC_MIPSEL	0x0162	/* mips1, little-endian */
     55        1.11  jonathan #define ECOFF_MAGIC_MIPSEL3	0x0142	/* mips3, little-endian */
     56        1.11  jonathan 
     57        1.15    tsubai #if BYTE_ORDER == LITTLE_ENDIAN
     58        1.11  jonathan #define ECOFF_BADMAG(ep) \
     59        1.11  jonathan     (!								\
     60        1.11  jonathan 	((ep)->f.f_magic == ECOFF_MAGIC_MIPSEL ||		\
     61        1.12  jonathan 	 (_MIPS3_OK() && (ep)->f.f_magic == ECOFF_MAGIC_MIPSEL3)) \
     62        1.11  jonathan     )
     63        1.15    tsubai #endif
     64        1.15    tsubai #if BYTE_ORDER == BIG_ENDIAN
     65        1.15    tsubai #define ECOFF_BADMAG(ep) ((ep)->f.f_magic != ECOFF_MAGIC_MIPSEB)
     66        1.15    tsubai #endif
     67        1.11  jonathan 
     68         1.1     glass 
     69         1.5       cgd #define ECOFF_SEGMENT_ALIGNMENT(ep) ((ep)->a.vstamp < 23 ? 8 : 16)
     70         1.6  jonathan 
     71        1.14  jonathan #ifdef _KERNEL
     72        1.14  jonathan struct proc;
     73        1.14  jonathan struct exec_package;
     74  1.19.108.1      yamt void	cpu_exec_ecoff_setregs(struct lwp *, struct exec_package *, vaddr_t);
     75        1.14  jonathan #endif	/* _KERNEL */
     76         1.7  jonathan 
     77         1.7  jonathan 
     78         1.7  jonathan /*
     79         1.7  jonathan  * ECOFF symbol definitions for 32-bit mips.
     80         1.7  jonathan  * XXX 64-bit (mips3?) may be different.
     81         1.7  jonathan  */
     82         1.7  jonathan struct ecoff_symhdr {
     83         1.7  jonathan 	int16_t		magic;
     84         1.7  jonathan 	int16_t		vstamp;
     85         1.8  jonathan 	int32_t		ilineMax;
     86         1.8  jonathan 	int32_t		cbLine;
     87         1.8  jonathan 	int32_t		cbLineOffset;
     88         1.8  jonathan 	int32_t		idnMax;
     89         1.8  jonathan 	int32_t		cbDnOffset;
     90         1.8  jonathan 	int32_t		ipdMax;
     91         1.8  jonathan 	int32_t		cbPdOffset;
     92         1.8  jonathan 	int32_t		isymMax;
     93         1.8  jonathan 	int32_t		cbSymOffset;
     94         1.8  jonathan 	int32_t		ioptMax;
     95         1.8  jonathan 	int32_t		cbOptOffset;
     96         1.8  jonathan 	int32_t		iauxMax;
     97         1.8  jonathan 	int32_t		cbAuxOffset;
     98         1.8  jonathan 	int32_t		issMax;
     99         1.8  jonathan 	int32_t		cbSsOffset;
    100         1.8  jonathan 	int32_t		issExtMax;
    101         1.8  jonathan 	int32_t		cbSsExtOffset;
    102         1.8  jonathan 	int32_t		ifdMax;
    103         1.8  jonathan 	int32_t		cbFdOffset;
    104         1.8  jonathan 	int32_t		crfd;
    105         1.8  jonathan 	int32_t		cbRfdOffset;
    106         1.8  jonathan 	int32_t		iextMax;
    107         1.8  jonathan 	int32_t		cbExtOffset;
    108         1.7  jonathan };
    109         1.8  jonathan 
    110         1.8  jonathan /* Macro for field name used by cgd's Alpha-derived code */
    111         1.8  jonathan #define esymMax iextMax
    112         1.8  jonathan 
    113         1.7  jonathan 
    114         1.7  jonathan struct ecoff_extsym {
    115         1.9  jonathan 	u_int16_t	es_flags;
    116         1.9  jonathan 	u_int16_t	es_ifd;
    117         1.7  jonathan 	int32_t		es_strindex;
    118         1.7  jonathan 	int32_t		es_value;
    119         1.7  jonathan 	unsigned	es_type:6;
    120         1.7  jonathan 	unsigned	es_class:5;
    121         1.7  jonathan 	unsigned	:1;
    122         1.7  jonathan 	unsigned	es_symauxindex:20;
    123         1.7  jonathan };
    124