vmparam.h revision 1.1 1 1.1 matt /*-
2 1.1 matt * Copyright (c) 2001 The NetBSD Foundation, Inc.
3 1.1 matt * All rights reserved.
4 1.1 matt *
5 1.1 matt * This code is derived from software contributed to The NetBSD Foundation
6 1.1 matt * by Matt Thomas <matt (at) 3am-softwre.com> of Allegro Networks, Inc.
7 1.1 matt *
8 1.1 matt * Redistribution and use in source and binary forms, with or without
9 1.1 matt * modification, are permitted provided that the following conditions
10 1.1 matt * are met:
11 1.1 matt * 1. Redistributions of source code must retain the above copyright
12 1.1 matt * notice, this list of conditions and the following disclaimer.
13 1.1 matt * 2. Redistributions in binary form must reproduce the above copyright
14 1.1 matt * notice, this list of conditions and the following disclaimer in the
15 1.1 matt * documentation and/or other materials provided with the distribution.
16 1.1 matt * 3. All advertising materials mentioning features or use of this software
17 1.1 matt * must display the following acknowledgement:
18 1.1 matt * This product includes software developed by the NetBSD
19 1.1 matt * Foundation, Inc. and its contributors.
20 1.1 matt * 4. Neither the name of The NetBSD Foundation nor the names of its
21 1.1 matt * contributors may be used to endorse or promote products derived
22 1.1 matt * from this software without specific prior written permission.
23 1.1 matt *
24 1.1 matt * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
25 1.1 matt * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
26 1.1 matt * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
27 1.1 matt * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
28 1.1 matt * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29 1.1 matt * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30 1.1 matt * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31 1.1 matt * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32 1.1 matt * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33 1.1 matt * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34 1.1 matt * POSSIBILITY OF SUCH DAMAGE.
35 1.1 matt */
36 1.1 matt
37 1.1 matt #ifndef _POWERPC_OEA_VMPARAM_H_
38 1.1 matt #define _POWERPC_OEA_VMPARAM_H_
39 1.1 matt
40 1.1 matt #include <sys/queue.h>
41 1.1 matt
42 1.1 matt /*
43 1.1 matt * Most of the definitions in this can be overriden by a machine-specific
44 1.1 matt * vmparam.h if required. Otherwise a port can just include this file
45 1.1 matt * get the right thing to happen.
46 1.1 matt */
47 1.1 matt
48 1.1 matt #ifndef USRSTACK
49 1.1 matt #define USRSTACK VM_MAXUSER_ADDRESS
50 1.1 matt #endif
51 1.1 matt
52 1.1 matt #ifndef MAXTSIZ
53 1.1 matt #define MAXTSIZ (64*1024*1024) /* maximum text size */
54 1.1 matt #endif
55 1.1 matt
56 1.1 matt #ifndef MAXDSIZ
57 1.1 matt #define MAXDSIZ (1024*1024*1024) /* maximum data size */
58 1.1 matt #endif
59 1.1 matt
60 1.1 matt #ifndef MAXSSIZ
61 1.1 matt #define MAXSSIZ (32*1024*1024) /* maximum stack size */
62 1.1 matt #endif
63 1.1 matt
64 1.1 matt #ifndef DFLDSIZ
65 1.1 matt #define DFLDSIZ (128*1024*1024) /* default data size */
66 1.1 matt #endif
67 1.1 matt
68 1.1 matt #ifndef DFLSSIZ
69 1.1 matt #define DFLSSIZ (2*1024*1024) /* default stack size */
70 1.1 matt #endif
71 1.1 matt
72 1.1 matt /*
73 1.1 matt * Default maximum amount of shared memory pages
74 1.1 matt */
75 1.1 matt #ifndef SHMMAXPGS
76 1.1 matt #define SHMMAXPGS 1024
77 1.1 matt #endif
78 1.1 matt
79 1.1 matt /*
80 1.1 matt * Default number of pages in the user raw I/O map.
81 1.1 matt */
82 1.1 matt #ifndef USRIOSIZE
83 1.1 matt #define USRIOSIZE 1024
84 1.1 matt #endif
85 1.1 matt
86 1.1 matt /*
87 1.1 matt * The number of seconds for a process to be blocked before being
88 1.1 matt * considered very swappable.
89 1.1 matt */
90 1.1 matt #ifndef MAXSLP
91 1.1 matt #define MAXSLP 20
92 1.1 matt #endif
93 1.1 matt
94 1.1 matt /*
95 1.1 matt * Segment handling stuff
96 1.1 matt */
97 1.1 matt #define SEGMENT_LENGTH 0x10000000
98 1.1 matt #define SEGMENT_MASK 0xf0000000
99 1.1 matt
100 1.1 matt /*
101 1.1 matt * Macros to manipulate VSIDs
102 1.1 matt */
103 1.1 matt #if 0
104 1.1 matt /*
105 1.1 matt * Move the SR# to the top 4 bits to make the lower 20 bits entirely random
106 1.1 matt * so to give better PTE distribution.
107 1.1 matt */
108 1.1 matt #define VSID_MAKE(sr, hash) (((sr) << (ADDR_SR_SHFT-4))|((hash) & 0xfffff))
109 1.1 matt #define VSID_TO_SR(vsid) (((vsid) >> (ADDR_SR_SHFT-4)) & 0xF)
110 1.1 matt #define VSID_TO_HASH(vsid) ((vsid) & 0xfffff)
111 1.1 matt #define VSID_SR_INCREMENT 0x00100000
112 1.1 matt #else
113 1.1 matt #define VSID_MAKE(sr, hash) ((sr) | (((hash) & 0xfffff) << 4))
114 1.1 matt #define VSID_TO_SR(vsid) ((vsid) & 0xF)
115 1.1 matt #define VSID_TO_HASH(vsid) (((vsid) >> 4) & 0xfffff)
116 1.1 matt #define VSID_SR_INCREMENT 0x00000001
117 1.1 matt #endif
118 1.1 matt
119 1.1 matt /*
120 1.1 matt * Fixed segments
121 1.1 matt */
122 1.1 matt #ifndef USER_SR
123 1.1 matt #define USER_SR 12
124 1.1 matt #endif
125 1.1 matt #define KERNEL_SR 13
126 1.1 matt #define KERNEL2_SR 14
127 1.1 matt #define KERNEL2_SEGMENT VSID_MAKE(KERNEL2_SR, KERNEL_VSIDBITS)
128 1.1 matt #define KERNEL_VSIDBITS 0xfffff
129 1.1 matt #define KERNEL_SEGMENT VSID_MAKE(KERNEL_SR, KERNEL_VSIDBITS)
130 1.1 matt #define EMPTY_SEGMENT VSID_MAKE(0, KERNEL_VSIDBITS)
131 1.1 matt #define USER_ADDR ((void *)(USER_SR << ADDR_SR_SHFT))
132 1.1 matt
133 1.1 matt /*
134 1.1 matt * Some system constants
135 1.1 matt */
136 1.1 matt #ifndef NPMAPS
137 1.1 matt #define NPMAPS 32768 /* Number of pmaps in system */
138 1.1 matt #endif
139 1.1 matt
140 1.1 matt #define VM_MIN_ADDRESS ((vaddr_t) 0)
141 1.1 matt #define VM_MAXUSER_ADDRESS ((vaddr_t) 0xfffff000)
142 1.1 matt #define VM_MAX_ADDRESS VM_MAXUSER_ADDRESS
143 1.1 matt #define VM_MIN_KERNEL_ADDRESS ((vaddr_t) (KERNEL_SR << ADDR_SR_SHFT))
144 1.1 matt #define VM_MAX_KERNEL_ADDRESS (VM_MIN_KERNEL_ADDRESS + 2*SEGMENT_LENGTH)
145 1.1 matt
146 1.1 matt #ifndef VM_PHYSSEG_MAX
147 1.1 matt #define VM_PHYSSEG_MAX 16
148 1.1 matt #endif
149 1.1 matt #define VM_PHYSSEG_STRAT VM_PSTRAT_BIGFIRST
150 1.1 matt #define VM_PHYSSEG_NOADD
151 1.1 matt
152 1.1 matt #ifndef VM_PHYS_SIZE
153 1.1 matt #define VM_PHYS_SIZE (USRIOSIZE * PAGE_SIZE)
154 1.1 matt #endif
155 1.1 matt
156 1.1 matt #ifndef VM_MAX_KERNEL_BUF
157 1.1 matt #define VM_MAX_KERNEL_BUF (SEGMENT_LENGTH * 3 / 4)
158 1.1 matt #endif
159 1.1 matt
160 1.1 matt #define VM_NFREELIST 16 /* 16 distinct memory segments */
161 1.1 matt #define VM_FREELIST_DEFAULT 0
162 1.1 matt #define VM_FREELIST_FIRST256 1
163 1.1 matt #define VM_FREELIST_FIRST16 2
164 1.1 matt #define VM_FREELIST_MAX 3
165 1.1 matt
166 1.1 matt #ifndef _LOCORE
167 1.1 matt
168 1.1 matt LIST_HEAD(pvo_head, pvo_entry);
169 1.1 matt
170 1.1 matt #if __NetBSD_Version__ > 105180000
171 1.1 matt #define __HAVE_VM_PAGE_MD
172 1.1 matt
173 1.1 matt struct vm_page_md {
174 1.1 matt struct pvo_head mdpg_pvoh;
175 1.1 matt unsigned int mdpg_attrs;
176 1.1 matt };
177 1.1 matt
178 1.1 matt #define VM_MDPAGE_INIT(pg) do { \
179 1.1 matt LIST_INIT(&(pg)->mdpage.mdpg_pvoh); \
180 1.1 matt (pg)->mdpage.mdpg_attrs = 0; \
181 1.1 matt } while (/*CONSTCOND*/0)
182 1.1 matt
183 1.1 matt #else
184 1.1 matt
185 1.1 matt #define __HAVE_PMAP_PHYSSEG
186 1.1 matt
187 1.1 matt struct pmap_physseg {
188 1.1 matt struct pvo_head *pvoh;
189 1.1 matt char *attrs;
190 1.1 matt };
191 1.1 matt
192 1.1 matt #endif
193 1.1 matt
194 1.1 matt #endif /* _LOCORE */
195 1.1 matt
196 1.1 matt #endif /* _POWERPC_OEA_VMPARAM_H_ */
197