root / lab4 / .minix-src / include / uvm / uvm_param.h @ 13
History | View | Annotate | Download (7.63 KB)
1 | 13 | up20180614 | /* $NetBSD: uvm_param.h,v 1.35 2015/09/26 20:28:38 christos Exp $ */
|
---|---|---|---|
2 | |||
3 | /*
|
||
4 | * Copyright (c) 1991, 1993
|
||
5 | * The Regents of the University of California. All rights reserved.
|
||
6 | *
|
||
7 | * This code is derived from software contributed to Berkeley by
|
||
8 | * The Mach Operating System project at Carnegie-Mellon University.
|
||
9 | *
|
||
10 | * Redistribution and use in source and binary forms, with or without
|
||
11 | * modification, are permitted provided that the following conditions
|
||
12 | * are met:
|
||
13 | * 1. Redistributions of source code must retain the above copyright
|
||
14 | * notice, this list of conditions and the following disclaimer.
|
||
15 | * 2. Redistributions in binary form must reproduce the above copyright
|
||
16 | * notice, this list of conditions and the following disclaimer in the
|
||
17 | * documentation and/or other materials provided with the distribution.
|
||
18 | * 3. Neither the name of the University nor the names of its contributors
|
||
19 | * may be used to endorse or promote products derived from this software
|
||
20 | * without specific prior written permission.
|
||
21 | *
|
||
22 | * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||
23 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
24 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
25 | * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||
26 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||
27 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||
28 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
29 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||
30 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||
31 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||
32 | * SUCH DAMAGE.
|
||
33 | *
|
||
34 | * @(#)vm_param.h 8.2 (Berkeley) 1/9/95
|
||
35 | *
|
||
36 | *
|
||
37 | * Copyright (c) 1987, 1990 Carnegie-Mellon University.
|
||
38 | * All rights reserved.
|
||
39 | *
|
||
40 | * Authors: Avadis Tevanian, Jr., Michael Wayne Young
|
||
41 | *
|
||
42 | * Permission to use, copy, modify and distribute this software and
|
||
43 | * its documentation is hereby granted, provided that both the copyright
|
||
44 | * notice and this permission notice appear in all copies of the
|
||
45 | * software, derivative works or modified versions, and any portions
|
||
46 | * thereof, and that both notices appear in supporting documentation.
|
||
47 | *
|
||
48 | * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
|
||
49 | * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
|
||
50 | * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
|
||
51 | *
|
||
52 | * Carnegie Mellon requests users of this software to return to
|
||
53 | *
|
||
54 | * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
|
||
55 | * School of Computer Science
|
||
56 | * Carnegie Mellon University
|
||
57 | * Pittsburgh PA 15213-3890
|
||
58 | *
|
||
59 | * any improvements or extensions that they make and grant Carnegie the
|
||
60 | * rights to redistribute these changes.
|
||
61 | */
|
||
62 | |||
63 | /*
|
||
64 | * Machine independent virtual memory parameters.
|
||
65 | */
|
||
66 | |||
67 | #ifndef _VM_PARAM_
|
||
68 | #define _VM_PARAM_
|
||
69 | |||
70 | #ifdef _KERNEL_OPT
|
||
71 | #include "opt_modular.h" |
||
72 | #include "opt_uvm.h" |
||
73 | #endif
|
||
74 | #ifdef _KERNEL
|
||
75 | #include <sys/types.h> |
||
76 | #include <machine/vmparam.h> |
||
77 | #include <sys/resourcevar.h> |
||
78 | #endif
|
||
79 | |||
80 | #if defined(_KERNEL)
|
||
81 | |||
82 | #if defined(PAGE_SIZE)
|
||
83 | |||
84 | /*
|
||
85 | * If PAGE_SIZE is defined at this stage, it must be a constant.
|
||
86 | */
|
||
87 | |||
88 | #if PAGE_SIZE == 0 |
||
89 | #error Invalid PAGE_SIZE definition
|
||
90 | #endif
|
||
91 | |||
92 | /*
|
||
93 | * If the platform does not need to support a variable PAGE_SIZE,
|
||
94 | * then provide default values for MIN_PAGE_SIZE and MAX_PAGE_SIZE.
|
||
95 | */
|
||
96 | |||
97 | #if !defined(MIN_PAGE_SIZE)
|
||
98 | #define MIN_PAGE_SIZE PAGE_SIZE
|
||
99 | #endif /* ! MIN_PAGE_SIZE */ |
||
100 | |||
101 | #if !defined(MAX_PAGE_SIZE)
|
||
102 | #define MAX_PAGE_SIZE PAGE_SIZE
|
||
103 | #endif /* ! MAX_PAGE_SIZE */ |
||
104 | |||
105 | #else /* ! PAGE_SIZE */ |
||
106 | |||
107 | /*
|
||
108 | * PAGE_SIZE is not a constant; MIN_PAGE_SIZE and MAX_PAGE_SIZE must
|
||
109 | * be defined.
|
||
110 | */
|
||
111 | |||
112 | #if !defined(MIN_PAGE_SIZE)
|
||
113 | #error MIN_PAGE_SIZE not defined
|
||
114 | #endif
|
||
115 | |||
116 | #if !defined(MAX_PAGE_SIZE)
|
||
117 | #error MAX_PAGE_SIZE not defined
|
||
118 | #endif
|
||
119 | |||
120 | #endif /* PAGE_SIZE */ |
||
121 | |||
122 | /*
|
||
123 | * MIN_PAGE_SIZE and MAX_PAGE_SIZE must be constants.
|
||
124 | */
|
||
125 | |||
126 | #if MIN_PAGE_SIZE == 0 |
||
127 | #error Invalid MIN_PAGE_SIZE definition
|
||
128 | #endif
|
||
129 | |||
130 | #if MAX_PAGE_SIZE == 0 |
||
131 | #error Invalid MAX_PAGE_SIZE definition
|
||
132 | #endif
|
||
133 | |||
134 | /*
|
||
135 | * If MIN_PAGE_SIZE and MAX_PAGE_SIZE are not equal, then we must use
|
||
136 | * non-constant PAGE_SIZE, et al for LKMs.
|
||
137 | */
|
||
138 | #if (MIN_PAGE_SIZE != MAX_PAGE_SIZE)
|
||
139 | #define __uvmexp_pagesize
|
||
140 | #if defined(_LKM) || defined(_MODULE)
|
||
141 | #undef PAGE_SIZE
|
||
142 | #undef PAGE_MASK
|
||
143 | #undef PAGE_SHIFT
|
||
144 | #endif
|
||
145 | #endif
|
||
146 | |||
147 | /*
|
||
148 | * Now provide PAGE_SIZE, PAGE_MASK, and PAGE_SHIFT if we do not
|
||
149 | * have ones that are compile-time constants.
|
||
150 | */
|
||
151 | #if !defined(PAGE_SIZE)
|
||
152 | extern const int *const uvmexp_pagesize; |
||
153 | extern const int *const uvmexp_pagemask; |
||
154 | extern const int *const uvmexp_pageshift; |
||
155 | #define PAGE_SIZE (*uvmexp_pagesize) /* size of page */ |
||
156 | #define PAGE_MASK (*uvmexp_pagemask) /* size of page - 1 */ |
||
157 | #define PAGE_SHIFT (*uvmexp_pageshift) /* bits to shift for pages */ |
||
158 | #endif /* PAGE_SIZE */ |
||
159 | |||
160 | #endif /* _KERNEL */ |
||
161 | |||
162 | /*
|
||
163 | * CTL_VM identifiers
|
||
164 | */
|
||
165 | #define VM_METER 1 /* struct vmmeter */ |
||
166 | #define VM_LOADAVG 2 /* struct loadavg */ |
||
167 | #define VM_UVMEXP 3 /* struct uvmexp */ |
||
168 | #define VM_NKMEMPAGES 4 /* kmem_map pages */ |
||
169 | #define VM_UVMEXP2 5 /* struct uvmexp_sysctl */ |
||
170 | #define VM_ANONMIN 6 |
||
171 | #define VM_EXECMIN 7 |
||
172 | #define VM_FILEMIN 8 |
||
173 | #define VM_MAXSLP 9 |
||
174 | #define VM_USPACE 10 |
||
175 | #define VM_ANONMAX 11 |
||
176 | #define VM_EXECMAX 12 |
||
177 | #define VM_FILEMAX 13 |
||
178 | #define VM_MINADDRESS 14 |
||
179 | #define VM_MAXADDRESS 15 |
||
180 | #define VM_PROC 16 /* process information */ |
||
181 | |||
182 | #define VM_MAXID 17 /* number of valid vm ids */ |
||
183 | |||
184 | #define VM_PROC_MAP 1 /* struct kinfo_vmentry */ |
||
185 | |||
186 | #define CTL_VM_NAMES { \
|
||
187 | { 0, 0 }, \ |
||
188 | { "vmmeter", CTLTYPE_STRUCT }, \
|
||
189 | { "loadavg", CTLTYPE_STRUCT }, \
|
||
190 | { "uvmexp", CTLTYPE_STRUCT }, \
|
||
191 | { "nkmempages", CTLTYPE_INT }, \
|
||
192 | { "uvmexp2", CTLTYPE_STRUCT }, \
|
||
193 | { "anonmin", CTLTYPE_INT }, \
|
||
194 | { "execmin", CTLTYPE_INT }, \
|
||
195 | { "filemin", CTLTYPE_INT }, \
|
||
196 | { "maxslp", CTLTYPE_INT }, \
|
||
197 | { "uspace", CTLTYPE_INT }, \
|
||
198 | { "anonmax", CTLTYPE_INT }, \
|
||
199 | { "execmax", CTLTYPE_INT }, \
|
||
200 | { "filemax", CTLTYPE_INT }, \
|
||
201 | { "minaddress", CTLTYPE_LONG }, \
|
||
202 | { "maxaddress", CTLTYPE_LONG }, \
|
||
203 | { "proc", CTLTYPE_STRUCT }, \
|
||
204 | } |
||
205 | |||
206 | #ifndef ASSEMBLER
|
||
207 | /*
|
||
208 | * Convert addresses to pages and vice versa.
|
||
209 | * No rounding is used.
|
||
210 | */
|
||
211 | #ifdef _KERNEL
|
||
212 | #define atop(x) (((paddr_t)(x)) >> PAGE_SHIFT)
|
||
213 | #define ptoa(x) (((paddr_t)(x)) << PAGE_SHIFT)
|
||
214 | |||
215 | /*
|
||
216 | * Round off or truncate to the nearest page. These will work
|
||
217 | * for either addresses or counts (i.e., 1 byte rounds to 1 page).
|
||
218 | */
|
||
219 | #define round_page(x) (((x) + PAGE_MASK) & ~PAGE_MASK)
|
||
220 | #define trunc_page(x) ((x) & ~PAGE_MASK)
|
||
221 | |||
222 | #ifndef VM_DEFAULT_ADDRESS_BOTTOMUP
|
||
223 | #define VM_DEFAULT_ADDRESS_BOTTOMUP(da, sz) \
|
||
224 | round_page((vaddr_t)(da) + (vsize_t)maxdmap) |
||
225 | #endif
|
||
226 | |||
227 | #ifndef VM_DEFAULT_ADDRESS_TOPDOWN
|
||
228 | #define VM_DEFAULT_ADDRESS_TOPDOWN(da, sz) \
|
||
229 | trunc_page(VM_MAXUSER_ADDRESS - MAXSSIZ - (sz)) |
||
230 | #endif
|
||
231 | |||
232 | extern int ubc_nwins; /* number of UBC mapping windows */ |
||
233 | extern int ubc_winshift; /* shift for a UBC mapping window */ |
||
234 | extern u_int uvm_emap_size; /* size of emap */ |
||
235 | |||
236 | #else
|
||
237 | /* out-of-kernel versions of round_page and trunc_page */
|
||
238 | #if !defined(__minix)
|
||
239 | #define round_page(x) \
|
||
240 | ((((vaddr_t)(x) + (vm_page_size - 1)) / vm_page_size) * \
|
||
241 | vm_page_size) |
||
242 | #define trunc_page(x) \
|
||
243 | ((((vaddr_t)(x)) / vm_page_size) * vm_page_size) |
||
244 | #else
|
||
245 | /* LSC: Minix always uses the same definition of those. */
|
||
246 | #define round_page(x) (((x) + PAGE_MASK) & ~PAGE_MASK)
|
||
247 | #define trunc_page(x) ((x) & ~PAGE_MASK)
|
||
248 | #endif /* !defined(__minix) */ |
||
249 | |||
250 | #endif /* _KERNEL */ |
||
251 | |||
252 | /*
|
||
253 | * typedefs, necessary for standard UVM headers.
|
||
254 | */
|
||
255 | |||
256 | typedef unsigned int uvm_flag_t; |
||
257 | |||
258 | typedef int vm_inherit_t; /* XXX: inheritance codes */ |
||
259 | typedef off_t voff_t; /* XXX: offset within a uvm_object */ |
||
260 | typedef voff_t pgoff_t; /* XXX: number of pages within a uvm object */ |
||
261 | |||
262 | #endif /* ASSEMBLER */ |
||
263 | #endif /* _VM_PARAM_ */ |