vmparam.h revision 1.28 1 1.28 thorpej /* $NetBSD: vmparam.h,v 1.28 2001/04/29 22:44:33 thorpej Exp $ */
2 1.13 cgd
3 1.1 mw /*
4 1.1 mw * Copyright (c) 1988 University of Utah.
5 1.1 mw * Copyright (c) 1982, 1986, 1990 The Regents of the University of California.
6 1.1 mw * All rights reserved.
7 1.1 mw *
8 1.1 mw * This code is derived from software contributed to Berkeley by
9 1.1 mw * the Systems Programming Group of the University of Utah Computer
10 1.1 mw * Science Department.
11 1.1 mw *
12 1.1 mw * Redistribution and use in source and binary forms, with or without
13 1.1 mw * modification, are permitted provided that the following conditions
14 1.1 mw * are met:
15 1.1 mw * 1. Redistributions of source code must retain the above copyright
16 1.1 mw * notice, this list of conditions and the following disclaimer.
17 1.1 mw * 2. Redistributions in binary form must reproduce the above copyright
18 1.1 mw * notice, this list of conditions and the following disclaimer in the
19 1.1 mw * documentation and/or other materials provided with the distribution.
20 1.1 mw * 3. All advertising materials mentioning features or use of this software
21 1.1 mw * must display the following acknowledgement:
22 1.1 mw * This product includes software developed by the University of
23 1.1 mw * California, Berkeley and its contributors.
24 1.1 mw * 4. Neither the name of the University nor the names of its contributors
25 1.1 mw * may be used to endorse or promote products derived from this software
26 1.1 mw * without specific prior written permission.
27 1.1 mw *
28 1.1 mw * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29 1.1 mw * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30 1.1 mw * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31 1.1 mw * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32 1.1 mw * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 1.1 mw * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34 1.1 mw * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35 1.1 mw * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36 1.1 mw * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37 1.1 mw * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38 1.1 mw * SUCH DAMAGE.
39 1.1 mw *
40 1.3 mw * from: Utah $Hdr: vmparam.h 1.16 91/01/18$
41 1.3 mw *
42 1.3 mw * @(#)vmparam.h 7.3 (Berkeley) 5/7/91
43 1.1 mw */
44 1.9 chopps #ifndef _MACHINE_VMPARAM_H_
45 1.9 chopps #define _MACHINE_VMPARAM_H_
46 1.4 mw
47 1.4 mw #include <machine/pte.h>
48 1.4 mw
49 1.1 mw /*
50 1.1 mw * Machine dependent constants for HP300
51 1.1 mw */
52 1.27 thorpej
53 1.27 thorpej /*
54 1.27 thorpej * We use 8K pages on the Amiga. Override the PAGE_* definitions
55 1.27 thorpej * to be compie-time constants.
56 1.27 thorpej */
57 1.27 thorpej #define PAGE_SHIFT 13
58 1.27 thorpej #define PAGE_SIZE (1 << PAGE_SHIFT)
59 1.27 thorpej #define PAGE_MASK (PAGE_SIZE - 1)
60 1.27 thorpej
61 1.1 mw /*
62 1.1 mw * USRTEXT is the start of the user text/data space, while USRSTACK
63 1.1 mw * is the top (end) of the user stack. LOWPAGES and HIGHPAGES are
64 1.1 mw * the number of pages from the beginning of the P0 region to the
65 1.1 mw * beginning of the text and from the beginning of the P1 region to the
66 1.1 mw * beginning of the stack respectively.
67 1.1 mw *
68 1.1 mw * These are a mixture of i386, sun3 and hp settings..
69 1.1 mw */
70 1.1 mw
71 1.1 mw /* Sun settings. Still hope, that I might get sun3 binaries to work... */
72 1.1 mw #define USRTEXT 0x2000
73 1.18 is #ifndef USRSTACK
74 1.6 chopps #define USRSTACK 0x0E000000
75 1.18 is #endif
76 1.1 mw #define LOWPAGES btoc(USRTEXT)
77 1.7 chopps #define KUSER_AREA (-UPAGES*NBPG)
78 1.1 mw /*
79 1.1 mw * Virtual memory related constants, all in bytes
80 1.1 mw */
81 1.1 mw
82 1.1 mw #ifndef MAXTSIZ
83 1.1 mw #define MAXTSIZ (6*1024*1024) /* max text size */
84 1.1 mw #endif
85 1.1 mw #ifndef DFLDSIZ
86 1.1 mw #define DFLDSIZ (32*1024*1024) /* initial data size limit */
87 1.1 mw #endif
88 1.1 mw #ifndef MAXDSIZ
89 1.14 veego #define MAXDSIZ (128*1024*1024) /* max data size */
90 1.1 mw #endif
91 1.1 mw #ifndef DFLSSIZ
92 1.1 mw #define DFLSSIZ (2*1024*1024) /* initial stack size limit */
93 1.1 mw #endif
94 1.1 mw #ifndef MAXSSIZ
95 1.14 veego #define MAXSSIZ (32*1024*1024) /* max stack size */
96 1.1 mw #endif
97 1.1 mw
98 1.1 mw /*
99 1.1 mw * Sizes of the system and user portions of the system page table.
100 1.1 mw */
101 1.1 mw /* SYSPTSIZE IS SILLY; IT SHOULD BE COMPUTED AT BOOT TIME */
102 1.12 chopps #define SYSPTSIZE (2 * NPTEPG) /* 16mb */
103 1.1 mw #define USRPTSIZE (1 * NPTEPG) /* 16mb */
104 1.1 mw
105 1.1 mw /*
106 1.1 mw * PTEs for mapping user space into the kernel for phyio operations.
107 1.1 mw * One page is enough to handle 16Mb of simultaneous raw IO operations.
108 1.1 mw */
109 1.1 mw #ifndef USRIOSIZE
110 1.1 mw #define USRIOSIZE (1 * NPTEPG) /* 16mb */
111 1.1 mw #endif
112 1.1 mw
113 1.1 mw /*
114 1.1 mw * PTEs for system V style shared memory.
115 1.1 mw * This is basically slop for kmempt which we actually allocate (malloc) from.
116 1.1 mw */
117 1.1 mw #ifndef SHMMAXPGS
118 1.1 mw #define SHMMAXPGS (1 * NPTEPG) /* 16mb */
119 1.1 mw #endif
120 1.1 mw
121 1.1 mw /*
122 1.1 mw * The time for a process to be blocked before being very swappable.
123 1.1 mw * This is a number of seconds which the system takes as being a non-trivial
124 1.1 mw * amount of real time. You probably shouldn't change this;
125 1.1 mw * it is used in subtle ways (fractions and multiples of it are, that is, like
126 1.1 mw * half of a ``long time'', almost a long time, etc.)
127 1.1 mw * It is related to human patience and other factors which don't really
128 1.1 mw * change over time.
129 1.1 mw */
130 1.1 mw #define MAXSLP 20
131 1.1 mw
132 1.1 mw /*
133 1.11 chopps * user/kernel map constants
134 1.1 mw */
135 1.22 is #define VM_MIN_ADDRESS ((vaddr_t)0) /* user min */
136 1.22 is #define VM_MAX_ADDRESS ((vaddr_t)(USRSTACK)) /* user max */
137 1.22 is #define VM_MAXUSER_ADDRESS ((vaddr_t)(VM_MAX_ADDRESS)) /* same */
138 1.22 is #define VM_MIN_KERNEL_ADDRESS ((vaddr_t)0)
139 1.22 is #define VM_MAX_KERNEL_ADDRESS ((vaddr_t)(0-NBPG))
140 1.1 mw
141 1.11 chopps /*
142 1.11 chopps * virtual sizes (bytes) for various kernel submaps
143 1.11 chopps */
144 1.23 ragge #define VM_PHYS_SIZE (USRIOSIZE*NBPG)
145 1.18 is
146 1.18 is /*
147 1.18 is * Our bootloader currently passes up to 16 segments (but this is variable)
148 1.18 is * Normally, the biggest of them is used for the kernel, and the kernel
149 1.18 is * segment is given to VM first.
150 1.18 is */
151 1.18 is #define VM_PHYSSEG_MAX (16)
152 1.18 is #define VM_PHYSSEG_STRAT VM_PSTRAT_RANDOM
153 1.18 is #define VM_PHYSSEG_NOADD /* XXX this should be done right later */
154 1.19 mhitch
155 1.19 mhitch /*
156 1.19 mhitch * Allow supporting Zorro-II memory as lower priority:
157 1.19 mhitch *
158 1.19 mhitch * - DEFAULT for Zorro-III memory (presumably 32 bit)
159 1.19 mhitch * - ZORROII for Zorro-II memory (16 bit, Zorro-II DMA)
160 1.19 mhitch */
161 1.19 mhitch
162 1.19 mhitch #define VM_NFREELIST 2
163 1.19 mhitch #define VM_FREELIST_DEFAULT 0
164 1.19 mhitch #define VM_FREELIST_ZORROII 1
165 1.28 thorpej
166 1.28 thorpej #define VM_MDPAGE_MEMBERS /* XXX nothing yet */
167 1.28 thorpej #define VM_MDPAGE_INIT(pg) /* XXX nothing yet */
168 1.28 thorpej #define PMAP_PHYSSEG /* XXX for now */
169 1.18 is
170 1.18 is /*
171 1.18 is * pmap-specific data stored in the vm_physmem[] array.
172 1.18 is */
173 1.18 is struct pmap_physseg {
174 1.18 is struct pv_entry *pvent; /* pv table for this seg */
175 1.18 is char *attrs; /* page attributes for this seg */
176 1.18 is };
177 1.1 mw
178 1.11 chopps /*
179 1.11 chopps * number of kernel PT pages (initial only, can grow dynamically)
180 1.11 chopps */
181 1.26 is #define VM_KERNEL_PT_PAGES ((vm_size_t)8) /* XXX: SYSPTSIZE */
182 1.9 chopps #endif /* !_MACHINE_VMPARAM_H_ */
183