[BACK]Return to pte.h CVS log [TXT][DIR] Up to [local] / sys / arch / mips64 / include

Annotation of sys/arch/mips64/include/pte.h, Revision 1.1

1.1     ! nbrk        1: /*     $OpenBSD: pte.h,v 1.5 2007/04/27 18:15:55 miod Exp $    */
        !             2:
        !             3: /*
        !             4:  * Copyright (c) 1988 University of Utah.
        !             5:  * Copyright (c) 1992, 1993
        !             6:  *     The Regents of the University of California.  All rights reserved.
        !             7:  *
        !             8:  * This code is derived from software contributed to Berkeley by
        !             9:  * the Systems Programming Group of the University of Utah Computer
        !            10:  * Science Department and Ralph Campbell.
        !            11:  *
        !            12:  * Redistribution and use in source and binary forms, with or without
        !            13:  * modification, are permitted provided that the following conditions
        !            14:  * are met:
        !            15:  * 1. Redistributions of source code must retain the above copyright
        !            16:  *    notice, this list of conditions and the following disclaimer.
        !            17:  * 2. Redistributions in binary form must reproduce the above copyright
        !            18:  *    notice, this list of conditions and the following disclaimer in the
        !            19:  *    documentation and/or other materials provided with the distribution.
        !            20:  * 3. Neither the name of the University nor the names of its contributors
        !            21:  *    may be used to endorse or promote products derived from this software
        !            22:  *    without specific prior written permission.
        !            23:  *
        !            24:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
        !            25:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
        !            26:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
        !            27:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
        !            28:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
        !            29:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
        !            30:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
        !            31:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
        !            32:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
        !            33:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
        !            34:  * SUCH DAMAGE.
        !            35:  *
        !            36:  *     from: Utah Hdr: pte.h 1.11 89/09/03
        !            37:  *     from: @(#)pte.h 8.1 (Berkeley) 6/10/93
        !            38:  */
        !            39:
        !            40: /*
        !            41:  * R4000 hardware page table entry
        !            42:  */
        !            43:
        !            44: #ifndef _LOCORE
        !            45:
        !            46: /*
        !            47:  * Structure defining an tlb entry data set.
        !            48:  */
        !            49:
        !            50: struct tlb_entry {
        !            51:        u_int64_t       tlb_mask;
        !            52:        u_int64_t       tlb_hi;
        !            53:        u_int64_t       tlb_lo0;
        !            54:        u_int64_t       tlb_lo1;
        !            55: };
        !            56:
        !            57: typedef union pt_entry {
        !            58:        unsigned int    pt_entry;       /* for copying, etc. */
        !            59:        unsigned int    pt_pte;         /* XXX void */
        !            60: } pt_entry_t;  /* Mips page table entry */
        !            61: #endif /* _LOCORE */
        !            62:
        !            63: #define        PT_ENTRY_NULL   ((pt_entry_t *) 0)
        !            64:
        !            65: #define PG_RO          0x40000000      /* SW */
        !            66:
        !            67: #define        PG_SVPN         0xfffff000      /* Software page no mask */
        !            68: #define        PG_HVPN         0xffffe000      /* Hardware page no mask */
        !            69: #define        PG_ODDPG        0x00001000      /* Odd even pte entry */
        !            70: #define        PG_ASID         0x000000ff      /* Address space ID */
        !            71: #define        PG_G            0x00000001      /* HW */
        !            72: #define        PG_V            0x00000002
        !            73: #define        PG_NV           0x00000000
        !            74: #define        PG_M            0x00000004
        !            75: #define        PG_ATTR         0x0000003f
        !            76: #define        PG_UNCACHED     0x00000010
        !            77: #define        PG_CACHED_NC    0x00000018      /* Cached, non coherent */
        !            78: #define        PG_CACHED_CE    0x00000020      /* Cached, coherent exclusive */
        !            79: #define        PG_CACHED_CEW   0x00000028      /* Cached, coherent exclusive write */
        !            80: #define        PG_CACHEMODE    0x00000038
        !            81: #ifdef TGT_COHERENT
        !            82: #define        PG_CACHED       PG_CACHED_CE
        !            83: #else
        !            84: #define        PG_CACHED       PG_CACHED_NC
        !            85: #endif
        !            86: #define        PG_ROPAGE       (PG_V | PG_RO | PG_CACHED) /* Write protected */
        !            87: #define        PG_RWPAGE       (PG_V | PG_M | PG_CACHED)  /* Not w-prot not clean */
        !            88: #define        PG_CWPAGE       (PG_V | PG_CACHED)         /* Not w-prot but clean */
        !            89: #define        PG_IOPAGE       (PG_G | PG_V | PG_M | PG_UNCACHED)
        !            90: #define        PG_FRAME        0x3fffffc0
        !            91: #define PG_SHIFT       6
        !            92:
        !            93: #define        pfn_to_pad(x)   (((vaddr_t)(x) & PG_FRAME) << PG_SHIFT)
        !            94: #define vad_to_pfn(x)  (((vaddr_t)(x) >> PG_SHIFT) & PG_FRAME)
        !            95: /* User virtual to pte page entry */
        !            96: #define uvtopte(adr)   (((adr) >> PGSHIFT) & (NPTEPG -1))
        !            97:
        !            98: #define        PG_SIZE_4K      0x00000000
        !            99: #define        PG_SIZE_16K     0x00006000
        !           100: #define        PG_SIZE_64K     0x0001e000
        !           101: #define        PG_SIZE_256K    0x0007e000
        !           102: #define        PG_SIZE_1M      0x001fe000
        !           103: #define        PG_SIZE_4M      0x007fe000
        !           104: #define        PG_SIZE_16M     0x01ffe000
        !           105:
        !           106: #if defined(_KERNEL) && !defined(_LOCORE)
        !           107:
        !           108: /*
        !           109:  * Kernel virtual address to page table entry and visa versa.
        !           110:  */
        !           111: #define        kvtopte(va) \
        !           112:        (Sysmap + (((vaddr_t)(va) - VM_MIN_KERNEL_ADDRESS) >> PGSHIFT))
        !           113:
        !           114: extern pt_entry_t *Sysmap;             /* kernel pte table */
        !           115: extern u_int Sysmapsize;               /* number of pte's in Sysmap */
        !           116: #endif

CVSweb