param.h revision 1.4
1/*	$NetBSD: param.h,v 1.4 1998/05/28 08:12:15 sakamoto 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		"ofppc"
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#ifndef	MSGBUFSIZE
67#define	MSGBUFSIZE	NBPG		/* default message buffer size */
68#endif
69
70#define	KERNBASE	0x100000
71
72/*
73 * Constants related to network buffer management.
74 * MCLBYTES must be no larger than CLBYTES (the software page size), and,
75 * on machines that exchange pages of input or output buffers with mbuf
76 * clusters (MAPPED_MBUFS), MCLBYTES must also be an integral multiple
77 * of the hardware page size.
78 */
79#define	MSIZE		128		/* size of an mbuf */
80#define	MCLSHIFT	11		/* convert bytes to m_buf clusters */
81#define	MCLBYTES	(1 << MCLSHIFT)	/* size of a m_buf cluster */
82
83#ifndef NMBCLUSTERS
84
85#if defined(_KERNEL) && !defined(_LKM)
86#include "opt_gateway.h"
87#endif /* _KERNEL && ! _LKM */
88
89#ifdef GATEWAY
90#define	NMBCLUSTERS	512		/* map size, max cluster allocation */
91#else
92#define	NMBCLUSTERS	256		/* map size, max cluster allocation */
93#endif
94#endif
95
96/*
97 * Size of kernel malloc arena in CLBYTES-sized logical pages.
98 */
99#ifndef	NKMEMCLUSTERS
100#define	NKMEMCLUSTERS	(128 * 1024 * 1024 / CLBYTES)
101#endif
102
103/*
104 * pages ("clicks") to disk blocks
105 */
106#define	ctod(x)		((x) << (PGSHIFT - DEV_BSHIFT))
107#define	dtoc(x)		((x) >> (PGSHIFT - DEV_BSHIFT))
108/*
109 * bytes to pages
110 */
111#define	ctob(x)		((x) << PGSHIFT)
112#define	btoc(x)		(((x) + PGOFSET) >> PGSHIFT)
113
114/*
115 * bytes to disk blocks
116 */
117#define	dbtob(x)	((x) << DEV_BSHIFT)
118#define	btodb(x)	((x) >> DEV_BSHIFT)
119
120/*
121 * Segment handling stuff
122 */
123#define	SEGMENT_LENGTH	0x10000000
124#define	SEGMENT_MASK	0xf0000000
125
126/*
127 * Fixed segments
128 */
129#define	USER_SR		13
130#define	KERNEL_SR	14
131#define	KERNEL_SEGMENT	(0xfffff0 + KERNEL_SR)
132#define	EMPTY_SEGMENT	0xfffff0
133#define	USER_ADDR	((void *)(USER_SR << ADDR_SR_SHFT))
134
135/*
136 * Some system constants
137 */
138#ifndef	NPMAPS
139#define	NPMAPS		32768	/* Number of pmaps in system */
140#endif
141
142/*
143 * Temporary kludge till we do (ov)bcopy in assembler
144 */
145#define	ovbcopy	bcopy
146