/* $NetBSD: ecoff_machdep.h,v 1.23 2017/02/23 18:56:12 christos Exp $ */
/*
* Copyright (c) 1997 Jonathan Stone
* All rights reserved.
*
* Copyright (c) 1994 Adam Glass
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by Adam Glass.
* 4. The name of the Author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY Adam Glass ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL Adam Glass BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#define ECOFF_LDPGSZ 4096
#define ECOFF_PAD
#define ECOFF32_PAD
#define ECOFF32_MACHDEP \
ecoff32_ulong gprmask; \
ecoff32_ulong cprmask[4]; \
ecoff32_ulong gp_value
#define ECOFF_MACHDEP \
u_long gprmask; \
u_long cprmask[4]; \
u_long gp_value
#ifdef _KERNEL
#include <mips/locore.h> /* mips CPU architecture levels */
#define _MIPS3_OK() CPUISMIPS3
#else
#define _MIPS3_OK() /*CONSTCOND*/1
#endif
#define ECOFF_MAGIC_MIPSEB 0x0160 /* mips1, big-endian */
#define ECOFF_MAGIC_MIPSEL 0x0162 /* mips1, little-endian */
#define ECOFF_MAGIC_MIPSEL3 0x0142 /* mips3, little-endian */
#if BYTE_ORDER == LITTLE_ENDIAN
#define ECOFF_BADMAG(ep) \
(! \
((ep)->f.f_magic == ECOFF_MAGIC_MIPSEL || \
(_MIPS3_OK() && (ep)->f.f_magic == ECOFF_MAGIC_MIPSEL3)) \
)
#endif
#if BYTE_ORDER == BIG_ENDIAN
#define ECOFF_BADMAG(ep) ((ep)->f.f_magic != ECOFF_MAGIC_MIPSEB)
#endif
#define ECOFF_SEGMENT_ALIGNMENT(ep) ((ep)->a.vstamp < 23 ? 8 : 16)
#define ECOFF32_SEGMENT_ALIGNMENT(ep) ((ep)->a.vstamp < 23 ? 8 : 16)
#ifdef _KERNEL
struct proc;
struct exec_package;
void cpu_exec_ecoff_setregs(struct lwp *, struct exec_package *, vaddr_t);
#endif /* _KERNEL */
struct ecoff32_symhdr {
int16_t magic;
int16_t vstamp;
int32_t ilineMax;
int32_t cbLine;
int32_t cbLineOffset;
int32_t idnMax;
int32_t cbDnOffset;
int32_t ipdMax;
int32_t cbPdOffset;
int32_t isymMax;
int32_t cbSymOffset;
int32_t ioptMax;
int32_t cbOptOffset;
int32_t iauxMax;
int32_t cbAuxOffset;
int32_t issMax;
int32_t cbSsOffset;
int32_t issExtMax;
int32_t cbSsExtOffset;
int32_t ifdMax;
int32_t cbFdOffset;
int32_t crfd;
int32_t cbRfdOffset;
int32_t iextMax;
int32_t cbExtOffset;
};
/*
* ECOFF symbol definitions for 32-bit mips.
* XXX 64-bit (mips3?) may be different.
*/
struct ecoff_symhdr {
int16_t magic;
int16_t vstamp;
int32_t ilineMax;
int32_t cbLine;
int32_t cbLineOffset;
int32_t idnMax;
int32_t cbDnOffset;
int32_t ipdMax;
int32_t cbPdOffset;
int32_t isymMax;
int32_t cbSymOffset;
int32_t ioptMax;
int32_t cbOptOffset;
int32_t iauxMax;
int32_t cbAuxOffset;
int32_t issMax;
int32_t cbSsOffset;
int32_t issExtMax;
int32_t cbSsExtOffset;
int32_t ifdMax;
int32_t cbFdOffset;
int32_t crfd;
int32_t cbRfdOffset;
int32_t iextMax;
int32_t cbExtOffset;
};
/* Macro for field name used by cgd's Alpha-derived code */
#define esymMax iextMax
struct ecoff_extsym {
u_int16_t es_flags;
u_int16_t es_ifd;
int32_t es_strindex;
int32_t es_value;
unsigned es_type:6;
unsigned es_class:5;
unsigned :1;
unsigned es_symauxindex:20;
};
struct ecoff32_extsym {
uint16_t es_flags;
uint16_t es_ifd;
int32_t es_strindex;
int32_t es_value;
unsigned es_type:6;
unsigned es_class:5;
unsigned :1;
unsigned es_symauxindex:20;
};