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