NetBSD/sys/arch/sun3/sun3x/genassym.c

191 lines
5.1 KiB
C

/* $NetBSD: genassym.c,v 1.3 1997/01/23 22:40:38 gwr Exp $ */
/*
* Copyright (c) 1994, 1995 Gordon W. Ross
* Copyright (c) 1993 Adam Glass
* Copyright (c) 1982, 1990, 1993
* The Regents of the University of California. 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 the University of
* California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 THE REGENTS OR CONTRIBUTORS 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.
*
* from: @(#)genassym.c 8.3 (Berkeley) 1/4/94
*/
#include <sys/param.h>
#include <sys/types.h>
#include <sys/cdefs.h>
#include <sys/errno.h>
#include <sys/proc.h>
#include <sys/syscall.h>
#include <vm/vm.h>
#include <machine/cpu.h>
#include <machine/pcb.h>
#include <machine/pmap.h>
#include <machine/psl.h>
#include <machine/pte.h>
#include <machine/mon.h>
#include <machine/vmparam.h>
#include <machine/dvma.h>
#include "buserr.h"
#include "machdep.h"
/* Note: Avoid /usr/include for cross compilation! */
extern void printf __P((char *fmt, ...));
extern void exit __P((int));
#if 1 /* XXX - Temporary hack... */
/*
* Make this work correctly on a SPARC!
* Should be able to fix this by adding:
* __attribute__((packed)) where needed.
*/
struct mytrapframe {
int tf_regs[16];
short tf_pad;
short tf_stackadj;
u_short tf_sr;
u_short tf_pc[2]; /* XXX was: u_int tf_pc; */
u_short tf_format:4,
tf_vector:12;
};
#define trapframe mytrapframe
#endif /* XXX */
void
def(what, val)
char *what;
int val;
{
printf("#define\t%s\t", what);
/* Hack to make the output easier to verify. */
if ((val < -99) || (val > 999))
printf("0x%x\n", val);
else
printf("%d\n", val);
}
#ifdef __STDC__
#define def1(name) def(#name, name)
#else
#define def1(name) def("name", name)
#endif
main()
{
struct pcb *pcb = (struct pcb *) 0;
struct proc *p = (struct proc *) 0;
struct vmspace *vms = (struct vmspace *) 0;
struct trapframe *tf = (struct trapframe *) 0;
struct fpframe *fpf = (struct fpframe *) 0;
/* bus error stuff */
/* def1(BUSERR_REG); XXX */
/* def1(BUSERR_MMU); XXX */
/* 68k isms */
def1(PSL_LOWIPL);
def1(PSL_HIGHIPL);
def1(PSL_USER);
def1(PSL_S);
def1(FC_CONTROL);
def1(FC_SUPERD);
def1(FC_USERD);
def1(IC_CLEAR);
def1(DC_CLEAR);
def1(CACHE_CLR);
/* sun3 memory map */
def1(DVMA_SPACE_START);
def1(MONSTART);
def1(PROM_BASE);
def1(USRSTACK);
/* kernel-isms */
def1(KERNBASE);
def1(USPACE);
/* system calls */
def1(SYS_sigreturn);
/* errno-isms */
def1(EFAULT);
def1(ENAMETOOLONG);
/* trap types: locore.s includes trap.h */
/*
* unix structure-isms
*/
/* proc fields and values */
def("P_FORW", &p->p_forw);
def("P_BACK", &p->p_back);
def("P_VMSPACE", &p->p_vmspace);
def("P_ADDR", &p->p_addr);
def("P_PRIORITY", &p->p_priority);
def("P_STAT", &p->p_stat);
def("P_WCHAN", &p->p_wchan);
def("P_FLAG", &p->p_flag);
def("P_MDFLAG", &p->p_md.md_flags);
def("P_MDREGS", &p->p_md.md_regs);
def1(SRUN);
/* HP-UX trace bit */
def("MDP_TRCB", ffs(MDP_HPUXTRACE) - 1);
/* VM structure fields */
def("VM_PMAP", &vms->vm_pmap);
def("VM_PMAP_MMUCRP", &vms->vm_pmap.pm_mmucrp);
def("VM_PMAP_A_TMGR", &vms->vm_pmap.pm_a_tmgr);
/* pcb offsets */
def("PCB_FLAGS", &pcb->pcb_flags);
def("PCB_PS", &pcb->pcb_ps);
def("PCB_USP", &pcb->pcb_usp);
def("PCB_REGS", pcb->pcb_regs);
def("PCB_ONFAULT", &pcb->pcb_onfault);
def("PCB_FPCTX", &pcb->pcb_fpregs);
def("SIZEOF_PCB", sizeof(*pcb));
/* exception frame offset/sizes */
def("FR_SP", &tf->tf_regs[15]);
def("FR_ADJ", &tf->tf_stackadj);
def("FR_HW", &tf->tf_sr);
def("FR_SIZE", sizeof(*tf));
/* FP frame offsets */
def("FPF_REGS", &fpf->fpf_regs[0]);
def("FPF_FPCR", &fpf->fpf_fpcr);
exit(0);
}