param.h revision 1.2 1 /* $NetBSD: param.h,v 1.2 1997/02/24 23:21:33 fvdl Exp $ */
2
3 /*-
4 * Copyright (C) 1995, 1996 Wolfgang Solfrank.
5 * Copyright (C) 1995, 1996 TooLs GmbH.
6 * All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 * 3. All advertising materials mentioning features or use of this software
17 * must display the following acknowledgement:
18 * This product includes software developed by TooLs GmbH.
19 * 4. The name of TooLs GmbH may not be used to endorse or promote products
20 * derived from this software without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
23 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
27 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
28 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
29 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
30 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
31 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34 #ifdef _KERNEL
35 #ifndef _LOCORE
36 #include <machine/cpu.h>
37 #endif /* _LOCORE */
38 #endif
39
40 /*
41 * Machine dependent constants for PowerPC (32-bit only currently)
42 */
43 #define MACHINE "powerpc"
44 #define MACHINE_ARCH "powerpc"
45 #define MID_MACHINE MID_POWERPC
46
47 #define ALIGNBYTES (sizeof(double) - 1)
48 #define ALIGN(p) (((u_int)(p) + ALIGNBYTES) & ~ALIGNBYTES)
49 #define ALIGNED_POINTER(p,t) ((((u_long)(p)) & (sizeof(t)-1)) == 0)
50
51 #define PGSHIFT 12
52 #define NBPG (1 << PGSHIFT) /* Page size */
53 #define PGOFSET (NBPG - 1)
54
55 #define DEV_BSHIFT 9 /* log2(DEV_BSIZE) */
56 #define DEV_BSIZE (1 << DEV_BSHIFT)
57 #define BLKDEV_IOSIZE NBPG
58 #define MAXPHYS (64 * 1024) /* max raw I/O transfer size */
59
60 #define CLSIZELOG2 0
61 #define CLSIZE (1 << CLSIZELOG2)
62
63 #define UPAGES 4
64 #define USPACE (UPAGES * NBPG)
65
66 #define KERNBASE 0x100000
67
68 /*
69 * Constants related to network buffer management.
70 * MCLBYTES must be no larger than CLBYTES (the software page size), and,
71 * on machines that exchange pages of input or output buffers with mbuf
72 * clusters (MAPPED_MBUFS), MCLBYTES must also be an integral multiple
73 * of the hardware page size.
74 */
75 #define MSIZE 128 /* size of an mbuf */
76 #define MCLSHIFT 11 /* convert bytes to m_buf clusters */
77 #define MCLBYTES (1 << MCLSHIFT) /* size of a m_buf cluster */
78
79 #ifndef NMBCLUSTERS
80 #ifdef GATEWAY
81 #define NMBCLUSTERS 512 /* map size, max cluster allocation */
82 #else
83 #define NMBCLUSTERS 256 /* map size, max cluster allocation */
84 #endif
85 #endif
86
87 /*
88 * Size of kernel malloc arena in CLBYTES-sized logical pages.
89 */
90 #ifndef NKMEMCLUSTERS
91 #define NKMEMCLUSTERS (128 * 1024 * 1024 / CLBYTES)
92 #endif
93
94 /*
95 * pages ("clicks") to disk blocks
96 */
97 #define ctod(x) ((x) << (PGSHIFT - DEV_BSHIFT))
98 #define dtoc(x) ((x) >> (PGSHIFT - DEV_BSHIFT))
99 /*
100 * bytes to pages
101 */
102 #define ctob(x) ((x) << PGSHIFT)
103 #define btoc(x) (((x) + PGOFSET) >> PGSHIFT)
104
105 /*
106 * bytes to disk blocks
107 */
108 #define dbtob(x) ((x) << DEV_BSHIFT)
109 #define btodb(x) ((x) >> DEV_BSHIFT)
110
111 /*
112 * Segment handling stuff
113 */
114 #define SEGMENT_LENGTH 0x10000000
115 #define SEGMENT_MASK 0xf0000000
116
117 /*
118 * Fixed segments
119 */
120 #define USER_SR 13
121 #define KERNEL_SR 14
122 #define KERNEL_SEGMENT (0xfffff0 + KERNEL_SR)
123 #define EMPTY_SEGMENT 0xfffff0
124 #define USER_ADDR ((void *)(USER_SR << ADDR_SR_SHFT))
125
126 /*
127 * Some system constants
128 */
129 #ifndef HTABENTS
130 #define HTABENTS 1024 /* Number of hashslots in HTAB */
131 #endif
132 #ifndef NPMAPS
133 #define NPMAPS 32768 /* Number of pmaps in system */
134 #endif
135
136 /*
137 * Temporary kludge till we do (ov)bcopy in assembler
138 */
139 #define ovbcopy bcopy
140