param.h revision 1.11.12.1       1  1.11.12.1    skrll /*	$NetBSD: param.h,v 1.11.12.1 2004/08/03 10:40:16 skrll Exp $	*/
      2        1.1   itojun 
      3        1.1   itojun /*-
      4        1.9      uch  * Copyright (c) 2002 The NetBSD Foundation, Inc. All rights reserved.
      5        1.1   itojun  * Copyright (c) 1990 The Regents of the University of California.
      6        1.1   itojun  * All rights reserved.
      7        1.1   itojun  *
      8        1.1   itojun  * This code is derived from software contributed to Berkeley by
      9        1.1   itojun  * William Jolitz.
     10        1.1   itojun  *
     11        1.1   itojun  * Redistribution and use in source and binary forms, with or without
     12        1.1   itojun  * modification, are permitted provided that the following conditions
     13        1.1   itojun  * are met:
     14        1.1   itojun  * 1. Redistributions of source code must retain the above copyright
     15        1.1   itojun  *    notice, this list of conditions and the following disclaimer.
     16        1.1   itojun  * 2. Redistributions in binary form must reproduce the above copyright
     17        1.1   itojun  *    notice, this list of conditions and the following disclaimer in the
     18        1.1   itojun  *    documentation and/or other materials provided with the distribution.
     19  1.11.12.1    skrll  * 3. Neither the name of the University nor the names of its contributors
     20        1.1   itojun  *    may be used to endorse or promote products derived from this software
     21        1.1   itojun  *    without specific prior written permission.
     22        1.1   itojun  *
     23        1.1   itojun  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24        1.1   itojun  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25        1.1   itojun  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26        1.1   itojun  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27        1.1   itojun  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28        1.1   itojun  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29        1.1   itojun  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30        1.1   itojun  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31        1.1   itojun  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32        1.1   itojun  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33        1.1   itojun  * SUCH DAMAGE.
     34        1.1   itojun  *
     35        1.1   itojun  *	@(#)param.h	5.8 (Berkeley) 6/28/91
     36        1.1   itojun  */
     37        1.1   itojun 
     38        1.1   itojun /*
     39        1.8      uch  * SuperH dependent constants.
     40        1.1   itojun  */
     41        1.1   itojun 
     42       1.11      uch #ifndef _SH3_PARAM_H_
     43       1.11      uch #define	_SH3_PARAM_H_
     44       1.11      uch 
     45        1.8      uch #if defined(_KERNEL) && !defined(_LOCORE)
     46       1.11      uch #include <sh3/cpu.h>
     47        1.1   itojun #endif
     48        1.1   itojun 
     49       1.11      uch /* NetBSD/sh3 is 4KB page */
     50       1.11      uch #define	PGSHIFT			12
     51       1.11      uch #define	NBPG			(1 << PGSHIFT)
     52       1.11      uch #define	PGOFSET			(NBPG - 1)
     53       1.11      uch 
     54        1.1   itojun /*
     55        1.1   itojun  * Round p (pointer or byte index) up to a correctly-aligned value
     56        1.1   itojun  * for all data types (int, long, ...).   The result is u_int and
     57        1.1   itojun  * must be cast to any desired pointer type.
     58        1.1   itojun  *
     59        1.1   itojun  * ALIGNED_POINTER is a boolean macro that checks whether an address
     60        1.1   itojun  * is valid to fetch data elements of type t from on this architecture.
     61        1.1   itojun  * This does not reflect the optimal alignment, just the possibility
     62        1.1   itojun  * (within reasonable limits).
     63        1.1   itojun  *
     64        1.1   itojun  */
     65       1.10      uch #define	ALIGNBYTES		(sizeof(int) - 1)
     66       1.10      uch #define	ALIGN(p)		(((u_int)(p) + ALIGNBYTES) & ~ALIGNBYTES)
     67       1.10      uch #define	ALIGNED_POINTER(p, t)	((((u_long)(p)) & (sizeof(t) - 1)) == 0)
     68        1.1   itojun 
     69        1.1   itojun #define	DEV_BSHIFT	9		/* log2(DEV_BSIZE) */
     70        1.1   itojun #define	DEV_BSIZE	(1 << DEV_BSHIFT)
     71        1.1   itojun #define	BLKDEV_IOSIZE	2048
     72        1.1   itojun #define	MAXPHYS		(64 * 1024)	/* max raw I/O transfer size */
     73        1.1   itojun 
     74        1.8      uch /*
     75        1.8      uch  * u-space.
     76        1.8      uch  */
     77        1.9      uch #define	UPAGES		3		/* pages of u-area */
     78        1.1   itojun #define	USPACE		(UPAGES * NBPG)	/* total size of u-area */
     79        1.9      uch #if UPAGES == 1
     80        1.9      uch #error "too small u-area"
     81        1.9      uch #elif UPAGES == 2
     82        1.9      uch #define	P1_STACK	/* kernel stack is P1-area */
     83        1.9      uch #else
     84        1.9      uch #undef	P1_STACK	/* kernel stack is P3-area */
     85        1.9      uch #endif
     86        1.1   itojun 
     87        1.1   itojun #ifndef MSGBUFSIZE
     88       1.10      uch #define	MSGBUFSIZE	NBPG		/* default message buffer size */
     89        1.1   itojun #endif
     90        1.1   itojun 
     91        1.1   itojun /*
     92        1.1   itojun  * Constants related to network buffer management.
     93        1.2    ragge  * MCLBYTES must be no larger than NBPG (the software page size), and,
     94        1.1   itojun  * on machines that exchange pages of input or output buffers with mbuf
     95        1.1   itojun  * clusters (MAPPED_MBUFS), MCLBYTES must also be an integral multiple
     96        1.1   itojun  * of the hardware page size.
     97        1.1   itojun  */
     98        1.4   itojun #define	MSIZE		256		/* size of an mbuf */
     99        1.1   itojun 
    100        1.1   itojun #ifndef MCLSHIFT
    101        1.6   simonb #define	MCLSHIFT	11		/* convert bytes to m_buf clusters */
    102        1.6   simonb 					/* 2K cluster can hold Ether frame */
    103        1.1   itojun #endif	/* MCLSHIFT */
    104        1.1   itojun 
    105        1.1   itojun #define	MCLBYTES	(1 << MCLSHIFT)	/* size of a m_buf cluster */
    106        1.1   itojun 
    107        1.1   itojun #ifndef NMBCLUSTERS
    108        1.6   simonb #if defined(_KERNEL_OPT)
    109        1.6   simonb #include "opt_gateway.h"
    110        1.6   simonb #endif
    111        1.6   simonb 
    112        1.1   itojun #ifdef GATEWAY
    113        1.1   itojun #define	NMBCLUSTERS	512		/* map size, max cluster allocation */
    114        1.1   itojun #else
    115        1.1   itojun #define	NMBCLUSTERS	256		/* map size, max cluster allocation */
    116        1.1   itojun #endif
    117        1.1   itojun #endif
    118        1.1   itojun 
    119        1.1   itojun /*
    120        1.3  thorpej  * Minimum and maximum sizes of the kernel malloc arena in PAGE_SIZE-sized
    121        1.3  thorpej  * logical pages.
    122        1.1   itojun  */
    123        1.3  thorpej #define	NKMEMPAGES_MIN_DEFAULT	((6 * 1024 * 1024) >> PAGE_SHIFT)
    124        1.3  thorpej #define	NKMEMPAGES_MAX_DEFAULT	((6 * 1024 * 1024) >> PAGE_SHIFT)
    125        1.1   itojun 
    126        1.1   itojun /* pages ("clicks") to disk blocks */
    127        1.1   itojun #define	ctod(x)		((x) << (PGSHIFT - DEV_BSHIFT))
    128        1.1   itojun #define	dtoc(x)		((x) >> (PGSHIFT - DEV_BSHIFT))
    129        1.1   itojun 
    130        1.1   itojun /* bytes to pages */
    131        1.1   itojun #define	ctob(x)		((x) << PGSHIFT)
    132        1.1   itojun #define	btoc(x)		(((x) + PGOFSET) >> PGSHIFT)
    133        1.1   itojun 
    134        1.1   itojun /* bytes to disk blocks */
    135        1.1   itojun #define	dbtob(x)	((x) << DEV_BSHIFT)
    136        1.1   itojun #define	btodb(x)	((x) >> DEV_BSHIFT)
    137       1.11      uch #endif /* !_SH3_PARAM_H_ */
    138