param.h revision 1.2 1 /* $NetBSD: param.h,v 1.2 2003/04/01 20:47:25 thorpej Exp $ */
2
3 /* $OpenBSD: param.h,v 1.12 2001/07/06 02:07:41 provos Exp $ */
4
5 /*
6 * Copyright (c) 1988-1994, The University of Utah and
7 * the Computer Systems Laboratory at the University of Utah (CSL).
8 * All rights reserved.
9 *
10 * Permission to use, copy, modify and distribute this software is hereby
11 * granted provided that (1) source code retains these copyright, permission,
12 * and disclaimer notices, and (2) redistributions including binaries
13 * reproduce the notices in supporting documentation, and (3) all advertising
14 * materials mentioning features or use of this software display the following
15 * acknowledgement: ``This product includes software developed by the
16 * Computer Systems Laboratory at the University of Utah.''
17 *
18 * THE UNIVERSITY OF UTAH AND CSL ALLOW FREE USE OF THIS SOFTWARE IN ITS "AS
19 * IS" CONDITION. THE UNIVERSITY OF UTAH AND CSL DISCLAIM ANY LIABILITY OF
20 * ANY KIND FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
21 *
22 * CSL requests users of this software to return to csl-dist (at) cs.utah.edu any
23 * improvements that they make and grant CSL redistribution rights.
24 *
25 * Utah $Hdr: param.h 1.18 94/12/16$
26 */
27
28 #if !defined(_POSIX_SOURCE) && !defined(_XOPEN_SOURCE)
29 #include <machine/cpu.h>
30 #endif
31
32 /*
33 * Machine dependent constants for PA-RISC.
34 */
35
36 #define _MACHINE_ARCH hppa
37 #define MACHINE_ARCH "hppa"
38 #define MID_MACHINE MID_HPUX800
39
40 /*
41 * Round p (pointer or byte index) up to a correctly-aligned value for all
42 * data types (int, long, ...). The result is u_int and must be cast to
43 * any desired pointer type.
44 */
45 #define ALIGNBYTES 7
46 #define ALIGN(p) (((u_long)(p) + ALIGNBYTES) &~ ALIGNBYTES)
47 #define ALIGNED_POINTER(p,t) ((((u_long)(p)) & (sizeof(t) - 1)) == 0)
48
49 #define PGSHIFT 12 /* LOG2(NBPG) */
50 #define NBPG (1 << PGSHIFT) /* bytes/page */
51 #define PGOFSET (NBPG-1) /* byte offset into page */
52
53 #define SEGSHIFT (PGSHIFT + (PGSHIFT-PTESHIFT)) /* LOG2(NBSEG) */
54 #define NBSEG (1 << SEGSHIFT) /* bytes/segment (quadrant) */
55 #define SEGOFSET (NBSEG-1) /* byte offset into segment */
56
57 #define KERNBASE 0x00000000 /* start of kernel virtual */
58 #define BTOPKERNBASE ((u_long)KERNBASE >> PGSHIFT)
59
60 #define DEV_BSIZE 512
61 #define DEV_BSHIFT 9 /* log2(DEV_BSIZE) */
62 #define BLKDEV_IOSIZE 2048
63 #define MAXPHYS (64 * 1024) /* max raw I/O transfer size */
64
65 #define SSIZE (1) /* initial stack size/NBPG */
66 #define SINCR (1) /* increment of stack/NBPG */
67
68 #define UADDR 0x7ffe6000 /* u-area lives here */
69 #define USHIFT (3) /* log2(UPAGES) */
70 #define UPAGES (1<<USHIFT) /* pages of u-area */
71 #define USPACE (UPAGES * NBPG) /* pages for user struct and kstack */
72
73 #ifndef MSGBUFSIZE
74 #define MSGBUFSIZE 2*NBPG /* default message buffer size */
75 #endif
76
77 /*
78 * Constants related to network buffer management.
79 * MCLBYTES must be no larger than the software page size, and,
80 * on machines that exchange pages of input or output buffers with mbuf
81 * clusters (MAPPED_MBUFS), MCLBYTES must also be an integral multiple
82 * of the hardware page size.
83 */
84 #define MSIZE 256 /* size of an mbuf */
85 #define MCLSHIFT 11
86 #define MCLBYTES (1 << MCLSHIFT) /* large enough for ether MTU */
87 #define MCLOFSET (MCLBYTES - 1)
88 #ifndef NMBCLUSTERS
89 #define NMBCLUSTERS (2048) /* cl map size: 1MB */
90 #endif
91
92 /*
93 * Size of kernel malloc arena in logical pages
94 */
95 #define NKMEMPAGES_MIN_DEFAULT ((16 * 1024 * 1024) >> PAGE_SHIFT)
96 #define NKMEMPAGES_MAX_DEFAULT ((16 * 1024 * 1024) >> PAGE_SHIFT)
97
98 /* pages ("clicks") (4096 bytes) to disk blocks */
99 #define ctod(x) ((x)<<(PGSHIFT-DEV_BSHIFT))
100 #define dtoc(x) ((x)>>(PGSHIFT-DEV_BSHIFT))
101
102 /* pages to bytes */
103 #define ctob(x) ((x)<<PGSHIFT)
104 #define btoc(x) (((unsigned)(x)+(NBPG-1))>>PGSHIFT)
105
106 #define btodb(bytes) ((unsigned)(bytes) >> DEV_BSHIFT)
107 #define dbtob(db) ((unsigned)(db) << DEV_BSHIFT)
108
109 /*
110 * Map a ``block device block'' to a file system block.
111 * This should be device dependent, and should use the bsize
112 * field from the disk label.
113 * For now though just use DEV_BSIZE.
114 */
115 #define bdbtofsb(bn) ((bn) / (BLKDEV_IOSIZE/DEV_BSIZE))
116
117 /*
118 * Mach derived conversion macros
119 */
120 #define hppa_round_page(x) ((((unsigned long)(x)) + NBPG - 1) & ~(NBPG-1))
121 #define hppa_trunc_page(x) ((unsigned long)(x) & ~(NBPG-1))
122
123 #define btop(x) ((unsigned long)(x) >> PGSHIFT)
124 #define ptob(x) ((unsigned long)(x) << PGSHIFT)
125
126 #ifdef _KERNEL
127 #ifdef COMPAT_HPUX
128 /*
129 * Constants/macros for HPUX multiple mapping of user address space.
130 * Pages in the first 256Mb are mapped in at every 256Mb segment.
131 */
132 #define HPMMMASK 0xF0000000
133 #define ISHPMMADDR(v) 0 /* XXX ...jef */
134 #define HPMMBASEADDR(v) ((unsigned)(v) & ~HPMMMASK)
135 #endif
136
137 #endif
138