genassym.cf revision 1.39
11.39Sthorpej#	$NetBSD: genassym.cf,v 1.39 2023/12/27 03:03:41 thorpej Exp $
21.1Smycroft
31.1Smycroft#
41.1Smycroft# Copyright (c) 1982, 1990, 1993
51.1Smycroft#	The Regents of the University of California.  All rights reserved.
61.1Smycroft#
71.1Smycroft# Redistribution and use in source and binary forms, with or without
81.1Smycroft# modification, are permitted provided that the following conditions
91.1Smycroft# are met:
101.1Smycroft# 1. Redistributions of source code must retain the above copyright
111.1Smycroft#    notice, this list of conditions and the following disclaimer.
121.1Smycroft# 2. Redistributions in binary form must reproduce the above copyright
131.1Smycroft#    notice, this list of conditions and the following disclaimer in the
141.1Smycroft#    documentation and/or other materials provided with the distribution.
151.31Stsutsui# 3. Neither the name of the University nor the names of its contributors
161.1Smycroft#    may be used to endorse or promote products derived from this software
171.1Smycroft#    without specific prior written permission.
181.1Smycroft#
191.1Smycroft# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
201.1Smycroft# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
211.1Smycroft# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
221.1Smycroft# ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
231.1Smycroft# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
241.1Smycroft# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
251.1Smycroft# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
261.1Smycroft# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
271.1Smycroft# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
281.1Smycroft# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
291.1Smycroft# SUCH DAMAGE.
301.1Smycroft#
311.1Smycroft#	@(#)genassym.c	8.3 (Berkeley) 1/4/94
321.1Smycroft#
331.1Smycroft
341.1Smycroftinclude <sys/param.h>
351.1Smycroftinclude <sys/buf.h>
361.1Smycroftinclude <sys/proc.h>
371.1Smycroftinclude <sys/mbuf.h>
381.1Smycroftinclude <sys/msgbuf.h>
391.24Sthorpejinclude <sys/queue.h>
401.1Smycroftinclude <sys/syscall.h>
411.1Smycroft
421.8Sscwinclude <uvm/uvm_extern.h>
431.8Sscw
441.1Smycroftinclude <machine/cpu.h>
451.1Smycroftinclude <machine/psl.h>
461.35Srmindinclude <machine/pcb.h>
471.1Smycroftinclude <machine/prom.h>
481.1Smycroftinclude <machine/pte.h>
491.1Smycroft
501.1Smycroftdefine	__XXX_BUG_FODDER	0
511.1Smycroft
521.1Smycroft# CPU options
531.1Smycroftifdef M68020
541.1Smycroftdefine	M68020			1
551.1Smycroftendif
561.1Smycroftifdef M68030
571.1Smycroftdefine	M68030			1
581.1Smycroftendif
591.1Smycroftifdef M68040
601.1Smycroftdefine	M68040			1
611.1Smycroftendif
621.1Smycroftifdef M68060
631.1Smycroftdefine	M68060			1
641.1Smycroftendif
651.1Smycroft
661.1Smycroft# MMU options
671.1Smycroftdefine	M68K_MMU_MOTOROLA	1
681.1Smycroft
691.1Smycroft# values for mmutype
701.1Smycroftdefine	MMU_68060		MMU_68060
711.1Smycroftdefine	MMU_68040		MMU_68040
721.1Smycroftdefine	MMU_68030		MMU_68030
731.1Smycroftdefine	MMU_68851		MMU_68851
741.1Smycroft
751.1Smycroft# values for cputype
761.1Smycroftdefine	CPU_68020		CPU_68020
771.1Smycroftdefine	CPU_68030		CPU_68030
781.1Smycroftdefine	CPU_68040		CPU_68040
791.1Smycroftdefine	CPU_68060		CPU_68060
801.4Sscw
811.4Sscw# values for fputype
821.4Sscwdefine	FPU_68881		FPU_68881
831.4Sscwdefine	FPU_68882		FPU_68882
841.4Sscwdefine	FPU_68040		FPU_68040
851.18Sscwdefine	FPU_68060		FPU_68060
861.1Smycroft
871.1Smycroft# values for machineid
881.1Smycroftdefine	MVME_147		MVME_147
891.1Smycroftdefine	MVME_162		MVME_162
901.1Smycroftdefine	MVME_166		MVME_166
911.1Smycroftdefine	MVME_167		MVME_167
921.1Smycroftdefine	MVME_172		MVME_172
931.1Smycroftdefine	MVME_177		MVME_177
941.1Smycroft
951.1Smycroft# values for ectype
961.1Smycroftdefine	EC_PHYS			EC_PHYS
971.1Smycroftdefine	EC_NONE			EC_NONE
981.1Smycroftdefine	EC_VIRT			EC_VIRT
991.1Smycroft
1001.1Smycroftdefine	UPAGES			UPAGES
1011.1Smycroftdefine	USPACE			USPACE
1021.25Sthorpejdefine	PAGE_SIZE		PAGE_SIZE
1031.1Smycroftdefine	PGSHIFT			PGSHIFT
1041.8Sscwdefine	USRSTACK		USRSTACK
1051.1Smycroft
1061.1Smycroft# boot stuff
1071.1Smycroftdefine	RB_SBOOT		RB_SBOOT
1081.1Smycroft
1091.1Smycroft# Bug stuff
1101.1Smycroftdefine	MVMEPROM_EXIT		MVMEPROM_EXIT
1111.1Smycroftdefine	MVMEPROM_GETBRDID	MVMEPROM_GETBRDID
1121.1Smycroftdefine	MVMEPROM_OUTSTRCRLF	MVMEPROM_OUTSTRCRLF
1131.1Smycroftdefine	MVMEPROM_BRDID_SIZE	sizeof(struct mvmeprom_brdid)
1141.1Smycroftdefine	MVMEPROM_BRDID_MODEL_OFFSET	offsetof(struct mvmeprom_brdid, model)
1151.1Smycroft
1161.39Sthorpej# MMU configuration constants (from pmap.h)
1171.39Sthorpejexport	MMU51_SRP_BITS
1181.39Sthorpejexport	MMU51_CRP_BITS
1191.39Sthorpejexport	MMU51_TCR_BITS
1201.39Sthorpejexport	MMU40_TCR_BITS
1211.39Sthorpej
1221.24Sthorpej# lwp & proc fields and values
1231.33Srminddefine	L_PCB			offsetof(struct lwp, l_addr)
1241.24Sthorpejdefine	L_PROC			offsetof(struct lwp, l_proc)
1251.24Sthorpejdefine	L_MD_REGS		offsetof(struct lwp, l_md.md_regs)
1261.24Sthorpejdefine	L_MD_FLAGS		offsetof(struct lwp, l_md.md_flags)
1271.24Sthorpejdefine	P_FLAG			offsetof(struct proc, p_flag)
1281.27Sdsldefine	P_RASLIST		offsetof(struct proc, p_raslist)
1291.1Smycroftdefine	P_VMSPACE		offsetof(struct proc, p_vmspace)
1301.1Smycroft
1311.1Smycroft# interrupt/fault metering
1321.34Smattdefine	CI_NINTR		offsetof(struct cpu_info, ci_data.cpu_nintr)
1331.1Smycroft
1341.1Smycroft# PSL values (should just include psl.h?)
1351.1Smycroftdefine	PSL_S			PSL_S
1361.1Smycroftdefine	PSL_IPL7		PSL_IPL7
1371.1Smycroftdefine	PSL_LOWIPL		PSL_LOWIPL
1381.1Smycroftdefine	PSL_HIGHIPL		PSL_HIGHIPL
1391.1Smycroftdefine	PSL_USER		PSL_USER
1401.15Sitohydefine	PSL_TS			PSL_T | PSL_S
1411.1Smycroftdefine	SPL1			PSL_S | PSL_IPL1
1421.1Smycroftdefine	SPL2			PSL_S | PSL_IPL2
1431.1Smycroftdefine	SPL3			PSL_S | PSL_IPL3
1441.1Smycroftdefine	SPL4			PSL_S | PSL_IPL4
1451.1Smycroftdefine	SPL5			PSL_S | PSL_IPL5
1461.1Smycroftdefine	SPL6			PSL_S | PSL_IPL6
1471.1Smycroft
1481.1Smycroft# magic
1491.1Smycroftdefine	FC_USERD		FC_USERD
1501.11Sscwdefine	INTIOBASE147	INTIOBASE147
1511.11Sscwdefine	INTIOTOP147		INTIOTOP147
1521.18Sscwdefine	INTIOBASE1xx	INTIOBASE1xx
1531.18Sscwdefine	INTIOTOP1xx		INTIOTOP1xx
1541.1Smycroftdefine	CACHE_ON		CACHE_ON
1551.1Smycroftdefine	CACHE_OFF		CACHE_OFF
1561.18Sscwdefine	CACHE40_OFF		CACHE40_OFF
1571.1Smycroftdefine	CACHE_CLR		CACHE_CLR
1581.1Smycroftdefine	IC_CLEAR		IC_CLEAR
1591.1Smycroftdefine	DC_CLEAR		DC_CLEAR
1601.18Sscwdefine	IC60_CUBC		IC60_CUBC
1611.18Sscwdefine	IC60_CABC		IC60_CABC
1621.1Smycroft
1631.1Smycroft# pte/ste bits
1641.1Smycroftdefine	PG_V			PG_V
1651.1Smycroftdefine	PG_NV			PG_NV
1661.1Smycroftdefine	PG_RO			PG_RO
1671.1Smycroftdefine	PG_RW			PG_RW
1681.1Smycroftdefine	PG_CI			PG_CI
1691.1Smycroftdefine	PG_PROT			PG_PROT
1701.1Smycroftdefine	PG_FRAME		PG_FRAME
1711.1Smycroftdefine	SG_V			SG_V
1721.1Smycroftdefine	SG_NV			SG_NV
1731.1Smycroftdefine	SG_RW			SG_RW
1741.1Smycroftdefine	SG_FRAME		SG_FRAME
1751.1Smycroftdefine	SG_ISHIFT		SG_ISHIFT
1761.1Smycroft
1771.1Smycroft# pcb fields
1781.1Smycroftdefine	PCB_PS			offsetof(struct pcb, pcb_ps)
1791.1Smycroftdefine	PCB_USP			offsetof(struct pcb, pcb_usp)
1801.1Smycroftdefine	PCB_REGS		offsetof(struct pcb, pcb_regs)
1811.1Smycroftdefine	PCB_ONFAULT		offsetof(struct pcb, pcb_onfault)
1821.1Smycroftdefine	PCB_FPCTX		offsetof(struct pcb, pcb_fpregs)
1831.1Smycroftdefine	SIZEOF_PCB		sizeof(struct pcb)
1841.24Sthorpej
1851.24Sthorpej# frame offsets
1861.24Sthorpejdefine	TF_PC			offsetof(struct frame, f_pc)
1871.1Smycroft
1881.1Smycroft# exception frame offset/sizes
1891.1Smycroftdefine	FR_SP			offsetof(struct frame, f_regs[15])
1901.1Smycroftdefine	FR_HW			offsetof(struct frame, f_sr)
1911.1Smycroftdefine	FR_ADJ			offsetof(struct frame, f_stackadj)
1921.11Sscwdefine	FR_SIZE			sizeof(struct trapframe)
1931.19Stsutsui
1941.19Stsutsui# FP frame offsets
1951.19Stsutsuidefine	FPF_REGS		offsetof(struct fpframe, fpf_regs[0])
1961.19Stsutsuidefine	FPF_FPCR		offsetof(struct fpframe, fpf_fpcr)
1971.19Stsutsuidefine	FPF_FPSR		offsetof(struct fpframe, fpf_fpsr)
1981.19Stsutsuidefine	FPF_FPI			offsetof(struct fpframe, fpf_fpiar)
1991.1Smycroft
2001.1Smycroft# system calls
2011.1Smycroftdefine	SYS_exit		SYS_exit
2021.1Smycroftdefine	SYS_execve		SYS_execve
2031.26Scldefine	SYS_compat_16___sigreturn14	SYS_compat_16___sigreturn14
2041.10Sthorpejdefine	SYS_compat_13_sigreturn13 SYS_compat_13_sigreturn13
2051.1Smycroft
2061.1Smycroft# errno
2071.1Smycroftdefine	EFAULT			EFAULT
2081.1Smycroftdefine	ENAMETOOLONG		ENAMETOOLONG
209