mmu.h revision 60972f37b111e11c7b4abcfc08e54c7839fe5e63
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2007 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#ifndef _SYS_MMU_H
#define _SYS_MMU_H
#pragma ident "%Z%%M% %I% %E% SMI"
#ifdef __cplusplus
extern "C" {
#endif
#ifndef _ASM
#endif
#include <sys/hypervisor_api.h>
/*
* Definitions for the SOFT MMU
*/
#define FAST_IMMU_MISS_TT 0x64
#define FAST_DMMU_MISS_TT 0x68
#define FAST_PROT_TT 0x6c
/*
* Constants defining alternate spaces
* and register layouts within them,
* and a few other interesting assembly constants.
*/
/*
* vaddr offsets of various registers
*/
/*
* Pseudo Synchronous Fault Status Register Layout
*
* IMMU and DMMU maintain their own pseudo SFSR Register
*
* +------------------------------------------------+
* | Reserved | Context | FT |
* +----------------------|-------------------------+
* 63 32 31 16 15 0
*
*/
/*
* Definition of FT (Fault Type) bit field of sfsr.
*/
#define FT_NONE 0x00
#define SFSR_FT_SHIFT 0 /* amt. to shift right to get flt type */
/*
* MMU TAG TARGET register Layout
*
* +---------------+------+-------------------------+
* | context | -- | virtual address [63:22] |
* +---------------+------+-------------------------+
* 63 48 47 42 41 0
*
* Some sun4v processors only use a 13-bit context ID, so bits 61-63 will be
* zero in that case. This layout allows us to use the same code for any sun4v
* processors, whether they support 13 bit or 16 bit context IDs (or something
* in between).
*/
#define TTARGET_CTX_SHIFT 48
#define TTARGET_VA_SHIFT 22
/*
* Pseudo MMU TAG ACCESS register Layout
*
* +-------------------------+------------------+
* | virtual address [63:13] | 0 | type |
* +-------------------------+------------------+
* 63 13 12 2 1 0
*
* 16-bit context IDs don't fit into the 13 bit field as they did on sun4u,
* so we use a context type, 0 = kernel context, 1 = invalid context,
* 2 = user context.
*/
#define TAGACC_CTX_MASK 0x1FFF
#define TAGACC_SHIFT 13
#define TAGACC_VADDR_MASK (~TAGACC_CTX_MASK)
/*
*/
#define CTXREG_CTX_MASK 0xFFFF
/*
* The kernel always runs in KCONTEXT, and no user mappings
* are ever valid in it (so any user access pagefaults).
*/
#define KCONTEXT 0
/*
* FLUSH_ADDR is used in the flush instruction to guarantee stores to mmu
* registers complete. It is selected so it won't miss in the tlb.
*/
#define MIN_NCTXS_BITS 2
#ifdef __cplusplus
}
#endif
#endif /* _SYS_MMU_H */