vmparam.h revision 1.24 1 1.24 rin /* $NetBSD: vmparam.h,v 1.24 2017/02/02 21:50:23 rin Exp $ */
2 1.2 dbj
3 1.2 dbj /*
4 1.2 dbj * This file was taken from from mvme68k/include/vmparam.h and
5 1.2 dbj * should probably be re-synced when needed.
6 1.2 dbj * Darrin B Jewell <jewell (at) mit.edu> Fri Aug 28 03:22:07 1998
7 1.2 dbj * original cvs id: NetBSD: vmparam.h,v 1.9 1998/08/22 10:55:34 scw Exp
8 1.2 dbj */
9 1.1 dbj
10 1.1 dbj /*
11 1.23 rmind * Copyright (c) 1988 University of Utah.
12 1.1 dbj * Copyright (c) 1982, 1986, 1990, 1993
13 1.1 dbj * The Regents of the University of California. All rights reserved.
14 1.16 agc *
15 1.16 agc * This code is derived from software contributed to Berkeley by
16 1.16 agc * the Systems Programming Group of the University of Utah Computer
17 1.16 agc * Science Department.
18 1.16 agc *
19 1.16 agc * Redistribution and use in source and binary forms, with or without
20 1.16 agc * modification, are permitted provided that the following conditions
21 1.16 agc * are met:
22 1.16 agc * 1. Redistributions of source code must retain the above copyright
23 1.16 agc * notice, this list of conditions and the following disclaimer.
24 1.16 agc * 2. Redistributions in binary form must reproduce the above copyright
25 1.16 agc * notice, this list of conditions and the following disclaimer in the
26 1.16 agc * documentation and/or other materials provided with the distribution.
27 1.16 agc * 3. Neither the name of the University nor the names of its contributors
28 1.16 agc * may be used to endorse or promote products derived from this software
29 1.16 agc * without specific prior written permission.
30 1.16 agc *
31 1.16 agc * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
32 1.16 agc * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
33 1.16 agc * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
34 1.16 agc * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
35 1.16 agc * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 1.16 agc * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37 1.16 agc * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38 1.16 agc * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
39 1.16 agc * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
40 1.16 agc * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
41 1.16 agc * SUCH DAMAGE.
42 1.16 agc *
43 1.16 agc * from: Utah $Hdr: vmparam.h 1.16 91/01/18$
44 1.16 agc *
45 1.16 agc * @(#)vmparam.h 8.2 (Berkeley) 4/19/94
46 1.16 agc */
47 1.1 dbj
48 1.1 dbj #ifndef _NEXT68K_VMPARAM_H_
49 1.1 dbj #define _NEXT68K_VMPARAM_H_
50 1.1 dbj
51 1.1 dbj /*
52 1.1 dbj * Machine dependent constants for NEXT68K
53 1.1 dbj */
54 1.9 thorpej
55 1.9 thorpej /*
56 1.9 thorpej * We use 4K pages on the NeXT. Override the PAGE_* definitions
57 1.9 thorpej * to be compile-time constants.
58 1.9 thorpej */
59 1.21 tsutsui #define PAGE_SHIFT PGSHIFT
60 1.9 thorpej #define PAGE_SIZE (1 << PAGE_SHIFT)
61 1.9 thorpej #define PAGE_MASK (PAGE_SIZE - 1)
62 1.2 dbj
63 1.1 dbj /*
64 1.14 thorpej * USRSTACK is the top (end) of the user stack.
65 1.1 dbj *
66 1.1 dbj * NOTE: the ONLY reason that HIGHPAGES is 0x100 instead of UPAGES (3)
67 1.1 dbj * is for HPUX compatibility. Why?? Because HPUX's debuggers
68 1.1 dbj * have the user's stack hard-wired at FFF00000 for post-mortems,
69 1.1 dbj * and we must be compatible...
70 1.1 dbj */
71 1.15 thorpej #define USRSTACK (-HIGHPAGES*PAGE_SIZE) /* Start of user stack */
72 1.1 dbj #define BTOPUSRSTACK (0x100000-HIGHPAGES) /* btop(USRSTACK) */
73 1.1 dbj #define P1PAGES 0x100000
74 1.15 thorpej #define HIGHPAGES (0x100000/PAGE_SIZE)
75 1.1 dbj
76 1.1 dbj /*
77 1.1 dbj * Virtual memory related constants, all in bytes
78 1.1 dbj */
79 1.1 dbj #ifndef MAXTSIZ
80 1.1 dbj #define MAXTSIZ (8*1024*1024) /* max text size */
81 1.1 dbj #endif
82 1.1 dbj #ifndef DFLDSIZ
83 1.1 dbj #define DFLDSIZ (16*1024*1024) /* initial data size limit */
84 1.1 dbj #endif
85 1.1 dbj #ifndef MAXDSIZ
86 1.1 dbj #define MAXDSIZ (64*1024*1024) /* max data size */
87 1.1 dbj #endif
88 1.1 dbj #ifndef DFLSSIZ
89 1.1 dbj #define DFLSSIZ (512*1024) /* initial stack size limit */
90 1.1 dbj #endif
91 1.1 dbj #ifndef MAXSSIZ
92 1.1 dbj #define MAXSSIZ MAXDSIZ /* max stack size */
93 1.1 dbj #endif
94 1.1 dbj
95 1.1 dbj /*
96 1.1 dbj * PTEs for mapping user space into the kernel for phyio operations.
97 1.1 dbj * One page is enough to handle 4Mb of simultaneous raw IO operations.
98 1.1 dbj */
99 1.1 dbj #ifndef USRIOSIZE
100 1.1 dbj #define USRIOSIZE (1 * NPTEPG) /* 4mb */
101 1.1 dbj #endif
102 1.1 dbj
103 1.1 dbj /*
104 1.1 dbj * Mach derived constants
105 1.1 dbj */
106 1.1 dbj
107 1.1 dbj /* user/kernel map constants */
108 1.2 dbj #define VM_MIN_ADDRESS ((vaddr_t)0)
109 1.2 dbj #define VM_MAXUSER_ADDRESS ((vaddr_t)0xFFF00000)
110 1.2 dbj #define VM_MAX_ADDRESS ((vaddr_t)0xFFF00000)
111 1.2 dbj #define VM_MIN_KERNEL_ADDRESS ((vaddr_t)0)
112 1.17 yamt #define VM_MAX_KERNEL_ADDRESS ((vaddr_t)(0-PAGE_SIZE*NPTEPG*2))
113 1.1 dbj
114 1.1 dbj /* virtual sizes (bytes) for various kernel submaps */
115 1.15 thorpej #define VM_PHYS_SIZE (USRIOSIZE*PAGE_SIZE)
116 1.1 dbj
117 1.1 dbj /* # of kernel PT pages (initial only, can grow dynamically) */
118 1.24 rin #define VM_KERNEL_PT_PAGES ((vsize_t)2)
119 1.2 dbj
120 1.2 dbj /*
121 1.2 dbj * Constants which control the way the VM system deals with memory segments.
122 1.2 dbj */
123 1.3 dbj #define VM_PHYSSEG_MAX 5 /* @@@ should really come from N_SIMM */
124 1.2 dbj #define VM_PHYSSEG_STRAT VM_PSTRAT_RANDOM
125 1.3 dbj #define VM_NFREELIST 1
126 1.2 dbj #define VM_FREELIST_DEFAULT 0
127 1.11 thorpej
128 1.12 thorpej #define __HAVE_PMAP_PHYSSEG
129 1.11 thorpej
130 1.2 dbj /*
131 1.2 dbj * pmap-specific data stored in the vm_physmem[] array.
132 1.2 dbj */
133 1.2 dbj struct pmap_physseg {
134 1.20 thorpej struct pv_header *pvheader; /* pv table for this seg */
135 1.2 dbj };
136 1.1 dbj
137 1.2 dbj #endif /* _MVME68K_VMPARAM_H_ */
138