xref: /netbsd-src/sys/arch/newsmips/include/machConst.h (revision 95e1ffb15694e54f29f8baaa4232152b703c2a5a)
1*95e1ffb1Schristos /*	$NetBSD: machConst.h,v 1.4 2005/12/11 12:18:24 christos Exp $	*/
2117df8f7Stsubai /*
3117df8f7Stsubai  * Copyright (c) 1992, 1993
4117df8f7Stsubai  *	The Regents of the University of California.  All rights reserved.
5117df8f7Stsubai  *
6117df8f7Stsubai  * This code is derived from software contributed to Berkeley by
7117df8f7Stsubai  * Ralph Campbell, and Kazumasa Utashiro of Software Research
8117df8f7Stsubai  * Associates, Inc.
9117df8f7Stsubai  *
10117df8f7Stsubai  * Redistribution and use in source and binary forms, with or without
11117df8f7Stsubai  * modification, are permitted provided that the following conditions
12117df8f7Stsubai  * are met:
13117df8f7Stsubai  * 1. Redistributions of source code must retain the above copyright
14117df8f7Stsubai  *    notice, this list of conditions and the following disclaimer.
15117df8f7Stsubai  * 2. Redistributions in binary form must reproduce the above copyright
16117df8f7Stsubai  *    notice, this list of conditions and the following disclaimer in the
17117df8f7Stsubai  *    documentation and/or other materials provided with the distribution.
18aad01611Sagc  * 3. Neither the name of the University nor the names of its contributors
19117df8f7Stsubai  *    may be used to endorse or promote products derived from this software
20117df8f7Stsubai  *    without specific prior written permission.
21117df8f7Stsubai  *
22117df8f7Stsubai  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23117df8f7Stsubai  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24117df8f7Stsubai  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25117df8f7Stsubai  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26117df8f7Stsubai  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27117df8f7Stsubai  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28117df8f7Stsubai  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29117df8f7Stsubai  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30117df8f7Stsubai  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31117df8f7Stsubai  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32117df8f7Stsubai  * SUCH DAMAGE.
33117df8f7Stsubai  *
34117df8f7Stsubai  *	@(#)machConst.h	8.1 (Berkeley) 6/11/93
35117df8f7Stsubai  *
36117df8f7Stsubai  * machConst.h --
37117df8f7Stsubai  *
38117df8f7Stsubai  *	Machine dependent constants.
39117df8f7Stsubai  *
40117df8f7Stsubai  *	Copyright (C) 1989 Digital Equipment Corporation.
41117df8f7Stsubai  *	Permission to use, copy, modify, and distribute this software and
42117df8f7Stsubai  *	its documentation for any purpose and without fee is hereby granted,
43117df8f7Stsubai  *	provided that the above copyright notice appears in all copies.
44117df8f7Stsubai  *	Digital Equipment Corporation makes no representations about the
45117df8f7Stsubai  *	suitability of this software for any purpose.  It is provided "as is"
46117df8f7Stsubai  *	without express or implied warranty.
47117df8f7Stsubai  *
48117df8f7Stsubai  * from: $Header: /sprite/src/kernel/mach/ds3100.md/RCS/machConst.h,
49117df8f7Stsubai  *	v 9.2 89/10/21 15:55:22 jhh Exp $ SPRITE (DECWRL)
50117df8f7Stsubai  * from: $Header: /sprite/src/kernel/mach/ds3100.md/RCS/machAddrs.h,
51117df8f7Stsubai  *	v 1.2 89/08/15 18:28:21 rab Exp $ SPRITE (DECWRL)
52117df8f7Stsubai  * from: $Header: /sprite/src/kernel/vm/ds3100.md/RCS/vmPmaxConst.h,
53117df8f7Stsubai  *	v 9.1 89/09/18 17:33:00 shirriff Exp $ SPRITE (DECWRL)
54117df8f7Stsubai  */
55117df8f7Stsubai 
56117df8f7Stsubai #ifndef _MACHCONST
57117df8f7Stsubai #define _MACHCONST
58117df8f7Stsubai 
59117df8f7Stsubai /*#define BETWEEN(x,a,b)	((unsigned)(x) >= (a) && (unsigned)(x) < (b))*/
60117df8f7Stsubai 
61117df8f7Stsubai #define MACH_IS_UNMAPPED(x) (((unsigned int)(x)) >> 30 == 2)	/* 10xx... */
62117df8f7Stsubai #define MACH_IS_CACHED(x)   (((unsigned int)(x)) >> 29 == 4)	/* 100x... */
63117df8f7Stsubai #define MACH_IS_UNCACHED(x) (((unsigned int)(x)) >> 29 == 5)	/* 101x... */
64117df8f7Stsubai 
65117df8f7Stsubai #define	MACH_IS_MAPPED(x) 1	/* XXX */
66117df8f7Stsubai 
67117df8f7Stsubai #define	MACH_IS_USPACE(x)   ((unsigned int)(x) < MIPS_KSEG0_START)
68117df8f7Stsubai 
69117df8f7Stsubai #define	MACH_KERNWORK_ADDR		0x800001c0
70117df8f7Stsubai #define	MACH_MAXMEMSIZE_ADDR		(MACH_KERNWORK_ADDR + 0 * 4)
71117df8f7Stsubai #define	MACH_BOOTSW_ADDR		(MACH_KERNWORK_ADDR + 1 * 4)
72117df8f7Stsubai #define	MACH_BOOTDEV_ADDR		(MACH_KERNWORK_ADDR + 2 * 4)
73117df8f7Stsubai #define	MACH_HOWTO_ADDR			(MACH_KERNWORK_ADDR + 3 * 4)
74117df8f7Stsubai #define	MACH_BP_ADDR			(MACH_KERNWORK_ADDR + 4 * 4)
75117df8f7Stsubai #define	MACH_MONARG_ADDR		(MACH_KERNWORK_ADDR + 5 * 4)
76117df8f7Stsubai 
77117df8f7Stsubai #endif /* _MACHCONST */
78