xref: /netbsd-src/sys/arch/arm/arm32/genassym.cf (revision da5f4674a3fc214be3572d358b66af40ab9401e7)
1#	$NetBSD: genassym.cf,v 1.24 2003/05/22 19:18:31 thorpej Exp $
2
3# Copyright (c) 1982, 1990 The Regents of the University of California.
4# All rights reserved.
5#
6# This code is derived from software contributed to Berkeley by
7# William Jolitz.
8#
9# Redistribution and use in source and binary forms, with or without
10# modification, are permitted provided that the following conditions
11# are met:
12# 1. Redistributions of source code must retain the above copyright
13#    notice, this list of conditions and the following disclaimer.
14# 2. Redistributions in binary form must reproduce the above copyright
15#    notice, this list of conditions and the following disclaimer in the
16#    documentation and/or other materials provided with the distribution.
17# 3. All advertising materials mentioning features or use of this software
18#    must display the following acknowledgement:
19#	This product includes software developed by the University of
20#	California, Berkeley and its contributors.
21# 4. Neither the name of the University nor the names of its contributors
22#    may be used to endorse or promote products derived from this software
23#    without specific prior written permission.
24#
25# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
26# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28# ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
29# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35# SUCH DAMAGE.
36
37include <sys/param.h>
38include <sys/systm.h>
39include <sys/proc.h>
40include <sys/resourcevar.h>
41include <sys/device.h>
42include <sys/user.h>
43include <sys/signal.h>
44
45include <uvm/uvm_extern.h>
46
47include <arm/fiq.h>
48
49include <machine/pmap.h>
50include <machine/frame.h>
51include <machine/vmparam.h>
52
53include "opt_multiprocessor.h"
54
55define	__PROG32		1
56ifdef __ARM_FIQ_INDIRECT
57define	__ARM_FIQ_INDIRECT	1
58endif
59
60define	VM_MIN_ADDRESS		VM_MIN_ADDRESS
61define	VM_MAXUSER_ADDRESS	VM_MAXUSER_ADDRESS
62
63define	DOMAIN_CLIENT		DOMAIN_CLIENT
64define	PMAP_DOMAIN_KERNEL	PMAP_DOMAIN_KERNEL
65
66ifdef PMAP_INCLUDE_PTE_SYNC
67define	PMAP_INCLUDE_PTE_SYNC	1
68endif
69
70define	PAGE_SIZE		PAGE_SIZE
71define	UPAGES			UPAGES
72define	PGSHIFT			PGSHIFT
73
74# Important offsets into the lwp and proc structs & associated constants
75define	L_FORW			offsetof(struct lwp, l_forw)
76define	L_BACK			offsetof(struct lwp, l_back)
77define	L_ADDR			offsetof(struct lwp, l_addr)
78define	L_CPU			offsetof(struct lwp, l_cpu)
79define	L_PRIORITY		offsetof(struct lwp, l_priority)
80define	L_WCHAN			offsetof(struct lwp, l_wchan)
81define	L_STAT			offsetof(struct lwp, l_stat)
82define	L_PROC			offsetof(struct lwp, l_proc)
83define	P_NRAS			offsetof(struct proc, p_nras)
84
85# Process status constants
86define	LSONPROC		LSONPROC
87
88define	PCB_TF			offsetof(struct pcb, pcb_tf)
89define	PCB_PAGEDIR		offsetof(struct pcb, pcb_pagedir)
90define	PCB_PL1VEC		offsetof(struct pcb, pcb_pl1vec)
91define	PCB_L1VEC		offsetof(struct pcb, pcb_l1vec)
92define	PCB_DACR		offsetof(struct pcb, pcb_dacr)
93define	PCB_CSTATE		offsetof(struct pcb, pcb_cstate)
94define	PCB_FLAGS		offsetof(struct pcb, pcb_flags)
95define	PCB_R8			offsetof(struct pcb, pcb_un.un_32.pcb32_r8)
96define	PCB_R9			offsetof(struct pcb, pcb_un.un_32.pcb32_r9)
97define	PCB_R10			offsetof(struct pcb, pcb_un.un_32.pcb32_r10)
98define	PCB_R11			offsetof(struct pcb, pcb_un.un_32.pcb32_r11)
99define	PCB_R12			offsetof(struct pcb, pcb_un.un_32.pcb32_r12)
100define	PCB_SP			offsetof(struct pcb, pcb_un.un_32.pcb32_sp)
101define	PCB_LR			offsetof(struct pcb, pcb_un.un_32.pcb32_lr)
102define	PCB_PC			offsetof(struct pcb, pcb_un.un_32.pcb32_pc)
103define	PCB_UND_SP		offsetof(struct pcb, pcb_un.un_32.pcb32_und_sp)
104define	PCB_ONFAULT		offsetof(struct pcb, pcb_onfault)
105
106define	USER_SIZE		sizeof(struct user)
107
108define	V_TRAP			offsetof(struct uvmexp, traps)
109define	V_INTR			offsetof(struct uvmexp, intrs)
110define	V_SOFT			offsetof(struct uvmexp, softs)
111
112define	VM_MAP			offsetof(struct vmspace, vm_map)
113define	VM_PMAP			offsetof(struct vmspace, vm_map.pmap)
114
115define	CS_TLB_ID		offsetof(union pmap_cache_state, cs_tlb_id)
116define	CS_TLB_D		offsetof(union pmap_cache_state, cs_tlb_d)
117define	CS_TLB			offsetof(union pmap_cache_state, cs_tlb)
118define	CS_CACHE_ID		offsetof(union pmap_cache_state, cs_cache_id)
119define	CS_CACHE_D		offsetof(union pmap_cache_state, cs_cache_d)
120define	CS_CACHE		offsetof(union pmap_cache_state, cs_cache)
121define	CS_ALL			offsetof(union pmap_cache_state, cs_all)
122define	PMAP_CSTATE		offsetof(struct pmap, pm_cstate)
123
124define	PR_BASE			offsetof(struct uprof, pr_base)
125define	PR_SIZE			offsetof(struct uprof, pr_size)
126define	PR_OFF			offsetof(struct uprof, pr_off)
127define	PR_SCALE		offsetof(struct uprof, pr_scale)
128
129define	SIGTRAP			SIGTRAP
130define	SIGEMT			SIGEMT
131
132define	TF_R0			offsetof(struct trapframe, tf_r0)
133define	TF_R10			offsetof(struct trapframe, tf_r10)
134define	TF_PC			offsetof(struct trapframe, tf_pc)
135
136define	PROCSIZE		sizeof(struct proc)
137define	TRAPFRAMESIZE		sizeof(struct trapframe)
138
139define	CF_IDCACHE_WBINV_ALL	offsetof(struct cpu_functions, cf_idcache_wbinv_all)
140define	CF_DCACHE_WB_RANGE	offsetof(struct cpu_functions, cf_dcache_wb_range)
141define	CF_TLB_FLUSHID_SE	offsetof(struct cpu_functions, cf_tlb_flushID_SE)
142define	CF_CONTEXT_SWITCH	offsetof(struct cpu_functions, cf_context_switch)
143define	CF_SLEEP		offsetof(struct cpu_functions, cf_sleep)
144
145define	CI_CURPRIORITY		offsetof(struct cpu_info, ci_schedstate.spc_curpriority)
146ifdef MULTIPROCESSOR
147define	CI_CURLWP		offsetof(struct cpu_info, ci_curlwp)
148define	CI_CURPCB		offsetof(struct cpu_info, ci_curpcb)
149endif
150