param.h revision 879
1209513Simp/*-
2209513Simp * Copyright (c) 1990 The Regents of the University of California.
3209552Simp * All rights reserved.
4209513Simp *
5209513Simp * This code is derived from software contributed to Berkeley by
6209513Simp * William Jolitz.
7209513Simp *
8209513Simp * Redistribution and use in source and binary forms, with or without
9209513Simp * modification, are permitted provided that the following conditions
10209513Simp * are met:
11209513Simp * 1. Redistributions of source code must retain the above copyright
12209513Simp *    notice, this list of conditions and the following disclaimer.
13209513Simp * 2. Redistributions in binary form must reproduce the above copyright
14209513Simp *    notice, this list of conditions and the following disclaimer in the
15209513Simp *    documentation and/or other materials provided with the distribution.
16209513Simp * 3. All advertising materials mentioning features or use of this software
17209513Simp *    must display the following acknowledgement:
18209513Simp *	This product includes software developed by the University of
19209513Simp *	California, Berkeley and its contributors.
20209513Simp * 4. Neither the name of the University nor the names of its contributors
21209513Simp *    may be used to endorse or promote products derived from this software
22209513Simp *    without specific prior written permission.
23209513Simp *
24209513Simp * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
25209513Simp * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26209513Simp * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27209513Simp * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28211489Simp * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29211489Simp * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30209513Simp * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31209513Simp * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32211489Simp * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33211489Simp * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34211489Simp * SUCH DAMAGE.
35211489Simp *
36211489Simp *	from: @(#)param.h	5.8 (Berkeley) 6/28/91
37211489Simp *	$Id: param.h,v 1.10 1993/11/18 05:02:05 rgrimes Exp $
38211489Simp */
39211489Simp
40209513Simp#ifndef _MACHINE_PARAM_H_
41209513Simp#define _MACHINE_PARAM_H_ 1
42209513Simp
43209513Simp/*
44209513Simp * Machine dependent constants for Intel 386.
45209513Simp */
46209513Simp
47209513Simp#define MACHINE		"i386"
48209513Simp#define MID_MACHINE	MID_I386
49209513Simp
50209513Simp/*
51209513Simp * Round p (pointer or byte index) up to a correctly-aligned value
52209513Simp * for all data types (int, long, ...).   The result is u_int and
53209513Simp * must be cast to any desired pointer type.
54209513Simp */
55209513Simp#define ALIGNBYTES	(sizeof(int) - 1)
56209513Simp#define ALIGN(p)	(((u_int)(p) + ALIGNBYTES) &~ ALIGNBYTES)
57209513Simp
58211489Simp/* XXX PGSHIFT and PG_SHIFT are two names for the same thing */
59211489Simp#define PGSHIFT		12		/* LOG2(NBPG) */
60211489Simp#define NBPG		(1 << PGSHIFT)	/* bytes/page */
61211489Simp#define PGOFSET		(NBPG-1)	/* byte offset into page */
62209513Simp#define NPTEPG		(NBPG/(sizeof (struct pte)))
63209513Simp
64209513Simp/* XXX PDRSHIFT and PD_SHIFT are two names for the same thing */
65209513Simp#define PDRSHIFT	22		/* LOG2(NBPDR) */
66209513Simp#define NBPDR		(1 << PDRSHIFT)	/* bytes/page dir */
67209513Simp#define PDROFSET	(NBPDR-1)	/* byte offset into page dir */
68209513Simp
69209513Simp/*
70209513Simp * XXX This should really be KPTDPTDI << PDRSHIFT, but since KPTDPTDI is
71209513Simp * defined in pmap.h which is included after this we can't do that
72209513Simp * (YET!)
73209513Simp */
74209513Simp#define KERNBASE	0xFE000000UL	/* start of kernel virtual */
75#define BTOPKERNBASE	(KERNBASE >> PGSHIFT)
76
77#define DEV_BSHIFT	9		/* log2(DEV_BSIZE) */
78#define DEV_BSIZE	(1 << DEV_BSHIFT)
79
80#define BLKDEV_IOSIZE	2048
81#define MAXPHYS		(64 * 1024)	/* max raw I/O transfer size */
82
83#define CLSIZELOG2	0
84#define CLSIZE		(1 << CLSIZELOG2)
85
86/* NOTE: SSIZE, SINCR and UPAGES must be multiples of CLSIZE */
87#define SSIZE	1		/* initial stack size/NBPG */
88#define SINCR	1		/* increment of stack/NBPG */
89
90#define UPAGES	2		/* pages of u-area */
91
92/*
93 * Constants related to network buffer management.
94 * MCLBYTES must be no larger than CLBYTES (the software page size), and,
95 * on machines that exchange pages of input or output buffers with mbuf
96 * clusters (MAPPED_MBUFS), MCLBYTES must also be an integral multiple
97 * of the hardware page size.
98 */
99#ifndef	MSIZE
100#define MSIZE		128		/* size of an mbuf */
101#endif	/* MSIZE */
102
103#ifndef	MCLSHIFT
104#define MCLSHIFT	11		/* convert bytes to m_buf clusters */
105#endif	/* MCLSHIFT */
106#define MCLBYTES	(1 << MCLSHIFT)	/* size of an m_buf cluster */
107#define MCLOFSET	(MCLBYTES - 1)	/* offset within an m_buf cluster */
108
109#ifndef NMBCLUSTERS
110#ifdef GATEWAY
111#define NMBCLUSTERS	512		/* map size, max cluster allocation */
112#else
113#define NMBCLUSTERS	256		/* map size, max cluster allocation */
114#endif	/* GATEWAY */
115#endif	/* NMBCLUSTERS */
116
117/*
118 * Some macros for units conversion
119 */
120/* Core clicks (4096 bytes) to segments and vice versa */
121#define ctos(x)	(x)
122#define stoc(x)	(x)
123
124/* Core clicks (4096 bytes) to disk blocks */
125#define ctod(x)	((x)<<(PGSHIFT-DEV_BSHIFT))
126#define dtoc(x)	((x)>>(PGSHIFT-DEV_BSHIFT))
127#define dtob(x)	((x)<<DEV_BSHIFT)
128
129/* clicks to bytes */
130#define ctob(x)	((x)<<PGSHIFT)
131
132/* bytes to clicks */
133#define btoc(x)	(((unsigned)(x)+(NBPG-1))>>PGSHIFT)
134
135#define btodb(bytes)	 		/* calculates (bytes / DEV_BSIZE) */ \
136	((unsigned)(bytes) >> DEV_BSHIFT)
137#define dbtob(db)			/* calculates (db * DEV_BSIZE) */ \
138	((unsigned)(db) << DEV_BSHIFT)
139
140/*
141 * Map a ``block device block'' to a file system block.
142 * This should be device dependent, and will be if we
143 * add an entry to cdevsw/bdevsw for that purpose.
144 * For now though just use DEV_BSIZE.
145 */
146#define bdbtofsb(bn)	((bn) / (BLKDEV_IOSIZE/DEV_BSIZE))
147
148/*
149 * Mach derived conversion macros
150 */
151#define i386_round_pdr(x)	((((unsigned)(x)) + NBPDR - 1) & ~(NBPDR-1))
152#define i386_trunc_pdr(x)	((unsigned)(x) & ~(NBPDR-1))
153#define i386_round_page(x)	((((unsigned)(x)) + NBPG - 1) & ~(NBPG-1))
154#define i386_trunc_page(x)	((unsigned)(x) & ~(NBPG-1))
155#define i386_btod(x)		((unsigned)(x) >> PDRSHIFT)
156#define i386_dtob(x)		((unsigned)(x) << PDRSHIFT)
157#define i386_btop(x)		((unsigned)(x) >> PGSHIFT)
158#define i386_ptob(x)		((unsigned)(x) << PGSHIFT)
159
160#endif /* _MACHINE_PARAM_H_ */
161