# $NetBSD: genassym.cf,v 1.33 2018/12/19 13:57:46 maxv Exp $ #- # Copyright (c) 1997 The NetBSD Foundation, Inc. # All rights reserved. # # This code is derived from software contributed to The NetBSD Foundation # by Leo Weppelman. # # 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. # # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 FOUNDATION 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. # ifdef _KERNEL_OPT include "opt_mbtype.h" endif include include include include include include include include include include include include include include include define _XXX_CIRCUMVENT_BUG 1 # CPU options ifdef M68020 define M68020 1 endif ifdef M68030 define M68030 1 endif ifdef M68040 define M68040 1 endif ifdef M68060 define M68060 1 endif # lwp & proc fields and values define L_PCB offsetof(struct lwp, l_addr) define L_PRIORITY offsetof(struct lwp, l_priority) define L_STAT offsetof(struct lwp, l_stat) define L_WCHAN offsetof(struct lwp, l_wchan) define L_PROC offsetof(struct lwp, l_proc) define L_MD_REGS offsetof(struct lwp, l_md.md_regs) define L_MD_FLAGS offsetof(struct lwp, l_md.md_flags) define P_FLAG offsetof(struct proc, p_flag) define P_RASLIST offsetof(struct proc, p_raslist) define P_VMSPACE offsetof(struct proc, p_vmspace) # lwp fields and values define LSSLEEP LSSLEEP define LSRUN LSRUN define LSONPROC LSONPROC # interrupt/fault metering define CI_NINTR offsetof(struct cpu_info, ci_data.cpu_nintr) # general constants define UPAGES UPAGES define USPACE USPACE define PAGE_SIZE PAGE_SIZE define PGSHIFT PGSHIFT define USRSTACK USRSTACK define T_BUSERR T_BUSERR define T_ADDRERR T_ADDRERR define T_ILLINST T_ILLINST define T_ZERODIV T_ZERODIV define T_CHKINST T_CHKINST define T_TRAPVINST T_TRAPVINST define T_PRIVINST T_PRIVINST define T_TRACE T_TRACE define T_MMUFLT T_MMUFLT define T_SSIR T_SSIR define T_FMTERR T_FMTERR define T_COPERR T_COPERR define T_FPERR T_FPERR define T_ASTFLT T_ASTFLT define T_TRAP15 T_TRAP15 define T_FPEMULI T_FPEMULI define T_FPEMULD T_FPEMULD # PSL values define PSL_S PSL_S define PSL_IPL7 PSL_IPL7 define PSL_LOWIPL PSL_LOWIPL define PSL_HIGHIPL PSL_HIGHIPL define PSL_USER PSL_USER define PSL_TS PSL_T | PSL_S define SPL1 PSL_S | PSL_IPL1 define SPL2 PSL_S | PSL_IPL2 define SPL3 PSL_S | PSL_IPL3 define SPL4 PSL_S | PSL_IPL4 define SPL5 PSL_S | PSL_IPL5 define SPL6 PSL_S | PSL_IPL6 # Various MMU/cache related constants define FC_USERD FC_USERD define FC_SUPERD FC_SUPERD define CACHE_ON CACHE_ON define CACHE_OFF CACHE_OFF define CACHE_CLR CACHE_CLR define IC_CLEAR IC_CLEAR define DC_CLEAR DC_CLEAR define CACHE40_ON CACHE40_ON define CACHE40_OFF CACHE40_OFF define CACHE60_ON CACHE60_ON define IC60_CABC IC60_CABC define IC60_CUBC IC60_CUBC # pte/ste bits define PG_V PG_V define PG_NV PG_NV define PG_RO PG_RO define PG_RW PG_RW define PG_CI PG_CI define PG_PROT PG_PROT define PG_FRAME PG_FRAME define SG_V SG_V define SG_NV SG_NV define SG_RW SG_RW define SG_FRAME SG_FRAME # pcb fields define PCB_FLAGS offsetof(struct pcb, pcb_flags) define PCB_PS offsetof(struct pcb, pcb_ps) define PCB_USP offsetof(struct pcb, pcb_usp) define PCB_REGS offsetof(struct pcb, pcb_regs) define PCB_ONFAULT offsetof(struct pcb, pcb_onfault) define PCB_FPCTX offsetof(struct pcb, pcb_fpregs) define SIZEOF_PCB sizeof(struct pcb) # frame offsets define TF_PC offsetof(struct frame, f_pc) # exception frame offset/sizes define FR_SP offsetof(struct frame, f_regs[15]) define FR_HW offsetof(struct frame, f_sr) define FR_ADJ offsetof(struct frame, f_stackadj) define FR_SIZE sizeof(struct trapframe) define SP SP # FP frame offsets define FPF_REGS offsetof(struct fpframe, fpf_regs[0]) define FPF_FPCR offsetof(struct fpframe, fpf_fpcr) define FPF_FPSR offsetof(struct fpframe, fpf_fpsr) define FPF_FPI offsetof(struct fpframe, fpf_fpiar) # system calls define SYS_exit SYS_exit define SYS_execve SYS_execve define SYS_compat_16___sigreturn14 SYS_compat_16___sigreturn14 define SYS_compat_13_sigreturn13 SYS_compat_13_sigreturn13 # processor type from loader define ATARI_68020 ATARI_68020 define ATARI_68030 ATARI_68030 define ATARI_68040 ATARI_68040 define ATARI_68060 ATARI_68060 # values for mmutype define MMU_68030 MMU_68030 define MMU_68851 MMU_68851 define MMU_68040 MMU_68040 # values for cputype define CPU_68020 CPU_68020 define CPU_68030 CPU_68030 define CPU_68040 CPU_68040 define CPU_68060 CPU_68060 # values for fputype define FPU_68881 FPU_68881 define FPU_68882 FPU_68882 define FPU_68040 FPU_68040 define FPU_68060 FPU_68060 ifdef _ATARIHW_ # AD_SCU definition needs this... quote #define stio_addr 0 define SCU_SOFTINT AD_SCU + offsetof(struct scu, sys_int) define SCU_SYSMASK AD_SCU + offsetof(struct scu, sys_mask) endif