Home | History | Annotate | Line # | Download | only in include
mipsNN.h revision 1.3
      1  1.3     cgd /*	$NetBSD: mipsNN.h,v 1.3 2003/02/07 17:38:48 cgd Exp $	*/
      2  1.1  simonb 
      3  1.1  simonb /*
      4  1.1  simonb  * Copyright 2000, 2001
      5  1.1  simonb  * Broadcom Corporation. All rights reserved.
      6  1.3     cgd  *
      7  1.1  simonb  * This software is furnished under license and may be used and copied only
      8  1.1  simonb  * in accordance with the following terms and conditions.  Subject to these
      9  1.1  simonb  * conditions, you may download, copy, install, use, modify and distribute
     10  1.1  simonb  * modified or unmodified copies of this software in source and/or binary
     11  1.1  simonb  * form. No title or ownership is transferred hereby.
     12  1.3     cgd  *
     13  1.1  simonb  * 1) Any source code used, modified or distributed must reproduce and
     14  1.1  simonb  *    retain this copyright notice and list of conditions as they appear in
     15  1.1  simonb  *    the source file.
     16  1.3     cgd  *
     17  1.1  simonb  * 2) No right is granted to use any trade name, trademark, or logo of
     18  1.3     cgd  *    Broadcom Corporation.  The "Broadcom Corporation" name may not be
     19  1.3     cgd  *    used to endorse or promote products derived from this software
     20  1.3     cgd  *    without the prior written permission of Broadcom Corporation.
     21  1.3     cgd  *
     22  1.1  simonb  * 3) THIS SOFTWARE IS PROVIDED "AS-IS" AND ANY EXPRESS OR IMPLIED
     23  1.1  simonb  *    WARRANTIES, INCLUDING BUT NOT LIMITED TO, ANY IMPLIED WARRANTIES OF
     24  1.1  simonb  *    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR
     25  1.1  simonb  *    NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL BROADCOM BE LIABLE
     26  1.1  simonb  *    FOR ANY DAMAGES WHATSOEVER, AND IN PARTICULAR, BROADCOM SHALL NOT BE
     27  1.1  simonb  *    LIABLE FOR DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     28  1.1  simonb  *    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     29  1.1  simonb  *    SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
     30  1.1  simonb  *    BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
     31  1.1  simonb  *    WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
     32  1.1  simonb  *    OR OTHERWISE), EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     33  1.1  simonb  */
     34  1.1  simonb 
     35  1.1  simonb /*
     36  1.1  simonb  * Values related to the MIPS32/MIPS64 Privileged Resource Architecture.
     37  1.1  simonb  */
     38  1.1  simonb 
     39  1.1  simonb #define	_MIPSNN_SHIFT(reg)	__MIPSNN_SHIFT(reg)
     40  1.1  simonb #define	__MIPSNN_SHIFT(reg)	MIPSNN_ ## reg ## _SHIFT
     41  1.1  simonb #define	_MIPSNN_MASK(reg)	__MIPSNN_MASK(reg)
     42  1.1  simonb #define	__MIPSNN_MASK(reg)	MIPSNN_ ## reg ## _MASK
     43  1.1  simonb 
     44  1.1  simonb #define	MIPSNN_GET(reg, x)						\
     45  1.1  simonb     ((unsigned)((x) & _MIPSNN_MASK(reg)) >> _MIPSNN_SHIFT(reg))
     46  1.1  simonb #define	MIPSNN_PUT(reg, val)						\
     47  1.1  simonb     (((x) << _MIPSNN_SHIFT(reg)) & _MIPSNN_MASK(reg))
     48  1.1  simonb 
     49  1.1  simonb /*
     50  1.1  simonb  * Values in Configuration Register (CP0 Register 16, Select 0)
     51  1.1  simonb  */
     52  1.1  simonb 
     53  1.1  simonb /* "M" (R): Configuration Register 1 present if set.  Defined as always set. */
     54  1.1  simonb #define	MIPSNN_CFG_M		0x80000000
     55  1.1  simonb 
     56  1.1  simonb /* Reserved for CPU implementations. */
     57  1.1  simonb //	reserved		0x7fff0000
     58  1.1  simonb 
     59  1.1  simonb /* "BE" (R): Big endian if set, little endian if clear. */
     60  1.1  simonb #define	MIPSNN_CFG_BE		0x00008000
     61  1.1  simonb 
     62  1.1  simonb /* "AT" (R): architecture type implemented by processor */
     63  1.1  simonb #define	MIPSNN_CFG_AT_MASK	0x00006000
     64  1.1  simonb #define	MIPSNN_CFG_AT_SHIFT	13
     65  1.1  simonb 
     66  1.1  simonb #define	MIPSNN_CFG_AT_MIPS32	0		/* MIPS32 */
     67  1.1  simonb #define	MIPSNN_CFG_AT_MIPS64S	1		/* MIPS64S */
     68  1.1  simonb #define	MIPSNN_CFG_AT_MIPS64	2		/* MIPS64 */
     69  1.1  simonb //	reserved		3
     70  1.1  simonb 
     71  1.1  simonb /* "AR" (R): Architecture revision level implemented by proc. */
     72  1.1  simonb #define	MIPSNN_CFG_AR_MASK	0x00001c00
     73  1.1  simonb #define	MIPSNN_CFG_AR_SHIFT	10
     74  1.1  simonb 
     75  1.1  simonb #define	MIPSNN_CFG_AR_REV1	0		/* Revision 1 */
     76  1.1  simonb //	reserved		other values
     77  1.1  simonb 
     78  1.1  simonb /* "MT" (R): MMU type implemented by processor */
     79  1.1  simonb #define	MIPSNN_CFG_MT_MASK	0x00000380
     80  1.1  simonb #define	MIPSNN_CFG_MT_SHIFT	7
     81  1.1  simonb 
     82  1.1  simonb #define	MIPSNN_CFG_MT_NONE	0		/* No MMU */
     83  1.1  simonb #define	MIPSNN_CFG_MT_TLB	1		/* Std TLB */
     84  1.1  simonb #define	MIPSNN_CFG_MT_BAT	2		/* Std BAT */
     85  1.1  simonb #define	MIPSNN_CFG_MT_FIXED	3		/* Std Fixed mapping */
     86  1.1  simonb //	reserved		other values
     87  1.1  simonb 
     88  1.1  simonb /* Reserved.  Write as 0, reads as 0. */
     89  1.2  simonb //	reserved		0x00000070
     90  1.2  simonb 
     91  1.2  simonb /* "M" (R): Virtual instruction cache if set. */
     92  1.2  simonb #define	MIPSNN_CFG_VI		0x00000008
     93  1.1  simonb 
     94  1.1  simonb /* "K0" (RW): Kseg0 coherency algorithm.  (values are TLB_ATTRs) */
     95  1.1  simonb #define	MIPSNN_CFG_K0_MASK	0x00000007
     96  1.1  simonb #define	MIPSNN_CFG_K0_SHIFT	0
     97  1.1  simonb 
     98  1.1  simonb 
     99  1.1  simonb /*
    100  1.1  simonb  * Values in Configuration Register 1 (CP0 Register 16, Select 1)
    101  1.1  simonb  */
    102  1.1  simonb 
    103  1.1  simonb /* Reserved for Configuration Register 2 present.  Write as 0, reads as 0. */
    104  1.1  simonb //	reserved		0x80000000
    105  1.1  simonb 
    106  1.1  simonb /* MS (R): Number of TLB entries - 1. */
    107  1.1  simonb #define	MIPSNN_CFG1_MS_MASK	0x7e000000
    108  1.1  simonb #define	MIPSNN_CFG1_MS_SHIFT	25
    109  1.1  simonb 
    110  1.1  simonb #define	MIPSNN_CFG1_MS(x)	(MIPSNN_GET(CFG1_MS, (x)) + 1)
    111  1.1  simonb 
    112  1.1  simonb /* "IS" (R): (Primary) I-cache sets per way. */
    113  1.1  simonb #define	MIPSNN_CFG1_IS_MASK	0x01c00000
    114  1.1  simonb #define	MIPSNN_CFG1_IS_SHIFT	22
    115  1.1  simonb 
    116  1.1  simonb #define	MIPSNN_CFG1_IS_RSVD	7		/* rsvd value, otherwise: */
    117  1.1  simonb #define	MIPSNN_CFG1_IS(x)	(64 << MIPSNN_GET(CFG1_IS, (x)))
    118  1.1  simonb 
    119  1.1  simonb /* "IL" (R): (Primary) I-cache line size. */
    120  1.1  simonb #define	MIPSNN_CFG1_IL_MASK	0x00380000
    121  1.1  simonb #define	MIPSNN_CFG1_IL_SHIFT	19
    122  1.1  simonb 
    123  1.1  simonb #define	MIPSNN_CFG1_IL_NONE	0		/* No I-cache, */
    124  1.1  simonb #define	MIPSNN_CFG1_IL_RSVD	7		/* rsvd value, otherwise: */
    125  1.1  simonb #define	MIPSNN_CFG1_IL(x)	(2 << MIPSNN_GET(CFG1_IL, (x)))
    126  1.1  simonb 
    127  1.1  simonb /* "IA" (R): (Primary) I-cache associativity (ways - 1). */
    128  1.1  simonb #define	MIPSNN_CFG1_IA_MASK	0x00070000
    129  1.1  simonb #define	MIPSNN_CFG1_IA_SHIFT	16
    130  1.1  simonb 
    131  1.1  simonb #define	MIPSNN_CFG1_IA(x)	MIPSNN_GET(CFG1_IA, (x))
    132  1.1  simonb 
    133  1.1  simonb /* "DS" (R): (Primary) D-cache sets per way. */
    134  1.1  simonb #define	MIPSNN_CFG1_DS_MASK	0x0000e000
    135  1.1  simonb #define	MIPSNN_CFG1_DS_SHIFT	13
    136  1.1  simonb 
    137  1.1  simonb #define	MIPSNN_CFG1_DS_RSVD	7		/* rsvd value, otherwise: */
    138  1.1  simonb #define	MIPSNN_CFG1_DS(x)	(64 << MIPSNN_GET(CFG1_DS, (x)))
    139  1.1  simonb 
    140  1.1  simonb /* "DL" (R): (Primary) D-cache line size. */
    141  1.1  simonb #define	MIPSNN_CFG1_DL_MASK	0x00001c00
    142  1.1  simonb #define	MIPSNN_CFG1_DL_SHIFT	10
    143  1.1  simonb 
    144  1.1  simonb #define	MIPSNN_CFG1_DL_NONE	0		/* No D-cache, */
    145  1.1  simonb #define	MIPSNN_CFG1_DL_RSVD	7		/* rsvd value, otherwise: */
    146  1.1  simonb #define	MIPSNN_CFG1_DL(x)	(2 << MIPSNN_GET(CFG1_DL, (x)))
    147  1.1  simonb 
    148  1.1  simonb /* "DA" (R): (Primary) D-cache associativity (ways - 1). */
    149  1.1  simonb #define	MIPSNN_CFG1_DA_MASK	0x00000380
    150  1.1  simonb #define	MIPSNN_CFG1_DA_SHIFT	7
    151  1.1  simonb 
    152  1.1  simonb #define	MIPSNN_CFG1_DA(x)	MIPSNN_GET(CFG1_DA, (x))
    153  1.1  simonb 
    154  1.1  simonb /* Reserved.  Write as 0, reads as 0. */
    155  1.1  simonb //	reserved		0x00000060
    156  1.1  simonb 
    157  1.1  simonb /* "PC" (R): Performance Counters implemented if set. */
    158  1.1  simonb #define	MIPSNN_CFG1_PC		0x00000010
    159  1.1  simonb 
    160  1.1  simonb /* "WR" (R): Watch registers implemented if set. */
    161  1.1  simonb #define	MIPSNN_CFG1_WR		0x00000008
    162  1.1  simonb 
    163  1.1  simonb /* "CA" (R): Code compressiong (MIPS16) implemented if set. */
    164  1.1  simonb #define	MIPSNN_CFG1_CA		0x00000004
    165  1.1  simonb 
    166  1.1  simonb /* "EP" (R): EJTAG implemented if set. */
    167  1.1  simonb #define	MIPSNN_CFG1_EP		0x00000002
    168  1.1  simonb 
    169  1.1  simonb /* "FP" (R): FPU implemented if set. */
    170  1.1  simonb #define	MIPSNN_CFG1_FP		0x00000001
    171