Home | History | Annotate | Line # | Download | only in include
      1  1.4  christos /*	$NetBSD: machConst.h,v 1.4 2005/12/11 12:18:24 christos Exp $	*/
      2  1.1    tsubai /*
      3  1.1    tsubai  * Copyright (c) 1992, 1993
      4  1.1    tsubai  *	The Regents of the University of California.  All rights reserved.
      5  1.1    tsubai  *
      6  1.1    tsubai  * This code is derived from software contributed to Berkeley by
      7  1.1    tsubai  * Ralph Campbell, and Kazumasa Utashiro of Software Research
      8  1.1    tsubai  * Associates, Inc.
      9  1.1    tsubai  *
     10  1.1    tsubai  * Redistribution and use in source and binary forms, with or without
     11  1.1    tsubai  * modification, are permitted provided that the following conditions
     12  1.1    tsubai  * are met:
     13  1.1    tsubai  * 1. Redistributions of source code must retain the above copyright
     14  1.1    tsubai  *    notice, this list of conditions and the following disclaimer.
     15  1.1    tsubai  * 2. Redistributions in binary form must reproduce the above copyright
     16  1.1    tsubai  *    notice, this list of conditions and the following disclaimer in the
     17  1.1    tsubai  *    documentation and/or other materials provided with the distribution.
     18  1.3       agc  * 3. Neither the name of the University nor the names of its contributors
     19  1.1    tsubai  *    may be used to endorse or promote products derived from this software
     20  1.1    tsubai  *    without specific prior written permission.
     21  1.1    tsubai  *
     22  1.1    tsubai  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     23  1.1    tsubai  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     24  1.1    tsubai  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     25  1.1    tsubai  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     26  1.1    tsubai  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     27  1.1    tsubai  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     28  1.1    tsubai  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     29  1.1    tsubai  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     30  1.1    tsubai  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     31  1.1    tsubai  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     32  1.1    tsubai  * SUCH DAMAGE.
     33  1.1    tsubai  *
     34  1.1    tsubai  *	@(#)machConst.h	8.1 (Berkeley) 6/11/93
     35  1.1    tsubai  *
     36  1.1    tsubai  * machConst.h --
     37  1.1    tsubai  *
     38  1.1    tsubai  *	Machine dependent constants.
     39  1.1    tsubai  *
     40  1.1    tsubai  *	Copyright (C) 1989 Digital Equipment Corporation.
     41  1.1    tsubai  *	Permission to use, copy, modify, and distribute this software and
     42  1.1    tsubai  *	its documentation for any purpose and without fee is hereby granted,
     43  1.1    tsubai  *	provided that the above copyright notice appears in all copies.
     44  1.1    tsubai  *	Digital Equipment Corporation makes no representations about the
     45  1.1    tsubai  *	suitability of this software for any purpose.  It is provided "as is"
     46  1.1    tsubai  *	without express or implied warranty.
     47  1.1    tsubai  *
     48  1.1    tsubai  * from: $Header: /sprite/src/kernel/mach/ds3100.md/RCS/machConst.h,
     49  1.1    tsubai  *	v 9.2 89/10/21 15:55:22 jhh Exp $ SPRITE (DECWRL)
     50  1.1    tsubai  * from: $Header: /sprite/src/kernel/mach/ds3100.md/RCS/machAddrs.h,
     51  1.1    tsubai  *	v 1.2 89/08/15 18:28:21 rab Exp $ SPRITE (DECWRL)
     52  1.1    tsubai  * from: $Header: /sprite/src/kernel/vm/ds3100.md/RCS/vmPmaxConst.h,
     53  1.1    tsubai  *	v 9.1 89/09/18 17:33:00 shirriff Exp $ SPRITE (DECWRL)
     54  1.1    tsubai  */
     55  1.1    tsubai 
     56  1.1    tsubai #ifndef _MACHCONST
     57  1.1    tsubai #define _MACHCONST
     58  1.1    tsubai 
     59  1.1    tsubai /*#define BETWEEN(x,a,b)	((unsigned)(x) >= (a) && (unsigned)(x) < (b))*/
     60  1.1    tsubai 
     61  1.1    tsubai #define MACH_IS_UNMAPPED(x) (((unsigned int)(x)) >> 30 == 2)	/* 10xx... */
     62  1.1    tsubai #define MACH_IS_CACHED(x)   (((unsigned int)(x)) >> 29 == 4)	/* 100x... */
     63  1.1    tsubai #define MACH_IS_UNCACHED(x) (((unsigned int)(x)) >> 29 == 5)	/* 101x... */
     64  1.1    tsubai 
     65  1.1    tsubai #define	MACH_IS_MAPPED(x) 1	/* XXX */
     66  1.1    tsubai 
     67  1.1    tsubai #define	MACH_IS_USPACE(x)   ((unsigned int)(x) < MIPS_KSEG0_START)
     68  1.1    tsubai 
     69  1.1    tsubai #define	MACH_KERNWORK_ADDR		0x800001c0
     70  1.1    tsubai #define	MACH_MAXMEMSIZE_ADDR		(MACH_KERNWORK_ADDR + 0 * 4)
     71  1.1    tsubai #define	MACH_BOOTSW_ADDR		(MACH_KERNWORK_ADDR + 1 * 4)
     72  1.1    tsubai #define	MACH_BOOTDEV_ADDR		(MACH_KERNWORK_ADDR + 2 * 4)
     73  1.1    tsubai #define	MACH_HOWTO_ADDR			(MACH_KERNWORK_ADDR + 3 * 4)
     74  1.1    tsubai #define	MACH_BP_ADDR			(MACH_KERNWORK_ADDR + 4 * 4)
     75  1.1    tsubai #define	MACH_MONARG_ADDR		(MACH_KERNWORK_ADDR + 5 * 4)
     76  1.1    tsubai 
     77  1.1    tsubai #endif /* _MACHCONST */
     78