genassym.cf revision 1.49
11.49Smatt#	$NetBSD: genassym.cf,v 1.49 2012/08/16 17:35:01 matt Exp $
21.1Schris
31.1Schris# Copyright (c) 1982, 1990 The Regents of the University of California.
41.1Schris# All rights reserved.
51.1Schris#
61.1Schris# This code is derived from software contributed to Berkeley by
71.1Schris# William Jolitz.
81.1Schris#
91.1Schris# Redistribution and use in source and binary forms, with or without
101.1Schris# modification, are permitted provided that the following conditions
111.1Schris# are met:
121.1Schris# 1. Redistributions of source code must retain the above copyright
131.1Schris#    notice, this list of conditions and the following disclaimer.
141.1Schris# 2. Redistributions in binary form must reproduce the above copyright
151.1Schris#    notice, this list of conditions and the following disclaimer in the
161.1Schris#    documentation and/or other materials provided with the distribution.
171.41Stsutsui# 3. Neither the name of the University nor the names of its contributors
181.1Schris#    may be used to endorse or promote products derived from this software
191.1Schris#    without specific prior written permission.
201.1Schris#
211.1Schris# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
221.1Schris# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
231.1Schris# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
241.1Schris# ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
251.1Schris# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
261.1Schris# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
271.1Schris# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
281.1Schris# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
291.1Schris# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
301.1Schris# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
311.1Schris# SUCH DAMAGE.
321.1Schris
331.1Schrisinclude <sys/param.h>
341.1Schrisinclude <sys/systm.h>
351.25Sscwinclude <sys/mbuf.h>
361.1Schrisinclude <sys/proc.h>
371.1Schrisinclude <sys/resourcevar.h>
381.1Schrisinclude <sys/device.h>
391.1Schrisinclude <sys/signal.h>
401.25Sscwinclude <netinet/in.h>
411.25Sscwinclude <netinet/in_systm.h>
421.25Sscwinclude <netinet/ip.h>
431.25Sscwinclude <netinet/ip6.h>
441.25Sscwinclude <netinet/ip_var.h>
451.1Schris
461.1Schrisinclude <uvm/uvm_extern.h>
471.8Sthorpej
481.8Sthorpejinclude <arm/fiq.h>
491.1Schris
501.45Smattinclude <arm/arm32/pte.h>
511.1Schrisinclude <machine/pmap.h>
521.1Schrisinclude <machine/frame.h>
531.49Smattinclude <machine/pcb.h>
541.1Schrisinclude <machine/vmparam.h>
551.6Sthorpej
561.16Sbjh21include "opt_multiprocessor.h"
571.26Sscwinclude "opt_compat_netbsd.h"
581.26Sscwinclude "opt_execfmt.h"
591.16Sbjh21
601.6Sthorpejdefine	__PROG32		1
611.10Sthorpejifdef __ARM_FIQ_INDIRECT
621.10Sthorpejdefine	__ARM_FIQ_INDIRECT	1
631.10Sthorpejendif
641.1Schris
651.37Smattifdef __HAVE_FAST_SOFTINTS
661.37Smattdefine	__HAVE_FAST_SOFTINTS	1
671.37Smattendif
681.37Smatt
691.40Smattifdef __HAVE_UNNESTED_INTRS
701.40Smattdefine	__HAVE_UNNESTED_INTRS	1
711.40Smattendif
721.40Smatt
731.31Smattdefine	KERNEL_BASE		KERNEL_BASE
741.1Schrisdefine	VM_MIN_ADDRESS		VM_MIN_ADDRESS
751.1Schrisdefine	VM_MAXUSER_ADDRESS	VM_MAXUSER_ADDRESS
761.22Sscw
771.22Sscwdefine	PMAP_DOMAIN_KERNEL	PMAP_DOMAIN_KERNEL
781.45Smattdefine	DOMAIN_CLIENT		DOMAIN_CLIENT
791.45Smattdefine	L1_S_PROTO_generic	L1_S_PROTO_generic
801.45Smattdefine	L1_S_PROTO_armv7	L1_S_PROTO_armv7
811.45Smattdefine	L1_S_PROTO_xscale	L1_S_PROTO_xscale
821.45Smattif ARM_NMMUS == 1
831.45Smattdefine	L1_S_PROTO		L1_S_PROTO
841.45Smattendif
851.45Smattdefine	L1_S_FRAME		L1_S_FRAME
861.45Smattdefine	L1_S_SHIFT		L1_S_SHIFT
871.45Smattdefine	L1_S_SIZE		L1_S_SIZE
881.45Smattdefine	L1_S_B			L1_S_B
891.45Smattdefine	L1_S_C			L1_S_C
901.45Smattdefine	L1_S_AP_KRW		L1_S_AP(AP_KRW)
911.45Smattdefine	L1_S_APv7_KRW		L1_S_AP(AP7_KRW)
921.45Smattdefine	L1_TABLE_SIZE		L1_TABLE_SIZE
931.45Smattdefine	L1_TYPE_S		L1_TYPE_S
941.45Smattdefine	L1_S_DOM_KERNEL		L1_S_DOM(PMAP_DOMAIN_KERNEL)
951.23Sthorpej
961.23Sthorpejifdef PMAP_INCLUDE_PTE_SYNC
971.23Sthorpejdefine	PMAP_INCLUDE_PTE_SYNC	1
981.22Sscwendif
991.1Schris
1001.21Sthorpejdefine	PAGE_SIZE		PAGE_SIZE
1011.1Schrisdefine	UPAGES			UPAGES
1021.1Schrisdefine	PGSHIFT			PGSHIFT
1031.1Schris
1041.20Sthorpej# Important offsets into the lwp and proc structs & associated constants
1051.42Srminddefine	L_PCB			offsetof(struct lwp, l_addr)
1061.20Sthorpejdefine	L_CPU			offsetof(struct lwp, l_cpu)
1071.20Sthorpejdefine	L_PRIORITY		offsetof(struct lwp, l_priority)
1081.20Sthorpejdefine	L_WCHAN			offsetof(struct lwp, l_wchan)
1091.20Sthorpejdefine	L_STAT			offsetof(struct lwp, l_stat)
1101.20Sthorpejdefine	L_PROC			offsetof(struct lwp, l_proc)
1111.39Smattdefine	L_CTXSWTCH		offsetof(struct lwp, l_ctxswtch)
1121.46Smattdefine	L_PRIVATE		offsetof(struct lwp, l_private)
1131.49Smattdefine	L_MD_FLAGS		offsetof(struct lwp, l_md.md_flags)
1141.49Smattdefine	L_MD_TF			offsetof(struct lwp, l_md.md_tf)
1151.49Smattdefine	MDLWP_NOALIGNFLT	MDLWP_NOALIGNFLT
1161.49Smatt
1171.27Sdsldefine	P_RASLIST		offsetof(struct proc, p_raslist)
1181.1Schris
1191.19Sbjh21define	PCB_R8			offsetof(struct pcb, pcb_un.un_32.pcb32_r8)
1201.19Sbjh21define	PCB_R9			offsetof(struct pcb, pcb_un.un_32.pcb32_r9)
1211.19Sbjh21define	PCB_R10			offsetof(struct pcb, pcb_un.un_32.pcb32_r10)
1221.5Stoshiidefine	PCB_R11			offsetof(struct pcb, pcb_un.un_32.pcb32_r11)
1231.5Stoshiidefine	PCB_R12			offsetof(struct pcb, pcb_un.un_32.pcb32_r12)
1241.5Stoshiidefine	PCB_SP			offsetof(struct pcb, pcb_un.un_32.pcb32_sp)
1251.5Stoshiidefine	PCB_LR			offsetof(struct pcb, pcb_un.un_32.pcb32_lr)
1261.5Stoshiidefine	PCB_PC			offsetof(struct pcb, pcb_un.un_32.pcb32_pc)
1271.39Smattdefine	PCB_USER_PID_RW		offsetof(struct pcb, pcb_un.un_32.pcb32_user_pid_rw)
1281.1Schrisdefine	PCB_ONFAULT		offsetof(struct pcb, pcb_onfault)
1291.1Schris
1301.44Srminddefine	PCB_SIZE		sizeof(struct pcb)
1311.1Schris
1321.1Schrisdefine	VM_MAP			offsetof(struct vmspace, vm_map)
1331.1Schrisdefine	VM_PMAP			offsetof(struct vmspace, vm_map.pmap)
1341.1Schris
1351.1Schrisdefine	PR_BASE			offsetof(struct uprof, pr_base)
1361.1Schrisdefine	PR_SIZE			offsetof(struct uprof, pr_size)
1371.1Schrisdefine	PR_OFF			offsetof(struct uprof, pr_off)
1381.1Schrisdefine	PR_SCALE		offsetof(struct uprof, pr_scale)
1391.1Schris
1401.1Schrisdefine	SIGTRAP			SIGTRAP
1411.1Schrisdefine	SIGEMT			SIGEMT
1421.1Schris
1431.1Schrisdefine	TF_R0			offsetof(struct trapframe, tf_r0)
1441.1Schrisdefine	TF_R10			offsetof(struct trapframe, tf_r10)
1451.1Schrisdefine	TF_PC			offsetof(struct trapframe, tf_pc)
1461.1Schris
1471.1Schrisdefine	PROCSIZE		sizeof(struct proc)
1481.1Schrisdefine	TRAPFRAMESIZE		sizeof(struct trapframe)
1491.1Schris
1501.9Sthorpejdefine	CF_IDCACHE_WBINV_ALL	offsetof(struct cpu_functions, cf_idcache_wbinv_all)
1511.22Sscwdefine	CF_DCACHE_WB_RANGE	offsetof(struct cpu_functions, cf_dcache_wb_range)
1521.22Sscwdefine	CF_TLB_FLUSHID_SE	offsetof(struct cpu_functions, cf_tlb_flushID_SE)
1531.1Schrisdefine	CF_CONTEXT_SWITCH	offsetof(struct cpu_functions, cf_context_switch)
1541.1Schrisdefine	CF_SLEEP		offsetof(struct cpu_functions, cf_sleep)
1551.26Sscwdefine	CF_CONTROL		offsetof(struct cpu_functions, cf_control)
1561.1Schris
1571.1Schrisdefine	CI_CURPRIORITY		offsetof(struct cpu_info, ci_schedstate.spc_curpriority)
1581.39Smattifndef PROCESS_ID_IS_CURLWP
1591.20Sthorpejdefine	CI_CURLWP		offsetof(struct cpu_info, ci_curlwp)
1601.39Smattendif
1611.39Smattdefine	CI_CPL			offsetof(struct cpu_info, ci_cpl)
1621.39Smattdefine	CI_ASTPENDING		offsetof(struct cpu_info, ci_astpending)
1631.39Smattdefine	CI_WANT_RESCHED		offsetof(struct cpu_info, ci_want_resched)
1641.39Smattdefine	CI_INTR_DEPTH		offsetof(struct cpu_info, ci_intr_depth)
1651.39Smattdefine	CI_MTX_COUNT		offsetof(struct cpu_info, ci_mtx_count)
1661.29Smanuif defined(EXEC_AOUT)
1671.26Sscwdefine	CI_CTRL			offsetof(struct cpu_info, ci_ctrl)
1681.16Sbjh21endif
1691.40Smattifdef __HAVE_FAST_SOFTINTS
1701.40Smattdefine	CI_SOFTINTS		offsetof(struct cpu_info, ci_softints)
1711.40Smattendif
1721.43Smattdefine	CI_CC_NTRAP		offsetof(struct cpu_info, ci_data.cpu_ntrap)
1731.43Smattdefine	CI_CC_NINTR		offsetof(struct cpu_info, ci_data.cpu_nintr)
1741.43Smattdefine	CI_CC_NSOFT		offsetof(struct cpu_info, ci_data.cpu_nsoft)
1751.43Smatt
1761.25Sscw
1771.25Sscw# Constants required for in_cksum() and friends.
1781.25Sscwdefine	M_LEN				offsetof(struct mbuf, m_len)
1791.25Sscwdefine	M_DATA				offsetof(struct mbuf, m_data)
1801.25Sscwdefine	M_NEXT				offsetof(struct mbuf, m_next)
1811.25Sscwdefine	IP_SRC				offsetof(struct ip, ip_src)
1821.25Sscwdefine	IP_DST				offsetof(struct ip, ip_dst)
183