Home | History | Annotate | Line # | Download | only in include
      1  1.5     skrll /*	$NetBSD: pte.h,v 1.5 2019/04/16 12:25:17 skrll Exp $	*/
      2  1.1  fredette 
      3  1.3     skrll /*	$OpenBSD: pte.h,v 1.11 2002/09/05 18:41:19 mickey Exp $	*/
      4  1.1  fredette 
      5  1.5     skrll /*
      6  1.1  fredette  * Copyright (c) 1990,1993,1994 The University of Utah and
      7  1.1  fredette  * the Computer Systems Laboratory at the University of Utah (CSL).
      8  1.1  fredette  * All rights reserved.
      9  1.1  fredette  *
     10  1.1  fredette  * Permission to use, copy, modify and distribute this software is hereby
     11  1.1  fredette  * granted provided that (1) source code retains these copyright, permission,
     12  1.1  fredette  * and disclaimer notices, and (2) redistributions including binaries
     13  1.1  fredette  * reproduce the notices in supporting documentation, and (3) all advertising
     14  1.1  fredette  * materials mentioning features or use of this software display the following
     15  1.1  fredette  * acknowledgement: ``This product includes software developed by the
     16  1.1  fredette  * Computer Systems Laboratory at the University of Utah.''
     17  1.1  fredette  *
     18  1.1  fredette  * THE UNIVERSITY OF UTAH AND CSL ALLOW FREE USE OF THIS SOFTWARE IN ITS "AS
     19  1.1  fredette  * IS" CONDITION.  THE UNIVERSITY OF UTAH AND CSL DISCLAIM ANY LIABILITY OF
     20  1.1  fredette  * ANY KIND FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
     21  1.1  fredette  *
     22  1.1  fredette  * CSL requests users of this software to return to csl-dist (at) cs.utah.edu any
     23  1.1  fredette  * improvements that they make and grant CSL redistribution rights.
     24  1.1  fredette  *
     25  1.1  fredette  * 	Utah $Hdr: pmap.h 1.24 94/12/14$
     26  1.1  fredette  *	Author: Mike Hibler, Bob Wheeler, University of Utah CSL, 9/90
     27  1.1  fredette  */
     28  1.1  fredette 
     29  1.1  fredette #ifndef	_HPPA_PTE_H_
     30  1.1  fredette #define	_HPPA_PTE_H_
     31  1.1  fredette 
     32  1.3     skrll typedef	uint32_t	pt_entry_t;
     33  1.3     skrll 
     34  1.3     skrll #define	PTE_PROT_SHIFT	19
     35  1.3     skrll #define	PTE_PROT(tlb)	((tlb) >> PTE_PROT_SHIFT)
     36  1.3     skrll #define	TLB_PROT(pte)	((pte) << PTE_PROT_SHIFT)
     37  1.3     skrll #define	PDE_MASK	(0xffc00000)
     38  1.3     skrll #define	PDE_SIZE	(0x00400000)
     39  1.3     skrll #define	PTE_MASK	(0x003ff000)
     40  1.3     skrll #define	PTE_PAGE(pte)	((pte) & ~PGOFSET)
     41  1.3     skrll 
     42  1.1  fredette /* TLB access/protection values */
     43  1.4     skrll /*			0x80000000 has no pt_entry_t equivalent */
     44  1.3     skrll #define	TLB_WIRED	0x40000000	/* software only */
     45  1.3     skrll #define	TLB_REFTRAP	0x20000000	/* bit 2, T */
     46  1.3     skrll #define	TLB_DIRTY	0x10000000	/* bit 3, D */
     47  1.3     skrll #define	TLB_BREAK	0x08000000	/* bit 4, B */
     48  1.3     skrll #define	TLB_AR_MASK	0x07f00000	/* bits 5-11, Access Rights */
     49  1.3     skrll #define	TLB_READ	0x00000000
     50  1.3     skrll #define	TLB_WRITE	0x01000000
     51  1.3     skrll #define	TLB_EXECUTE	0x02000000
     52  1.3     skrll #define	TLB_GATEWAY	0x04000000
     53  1.3     skrll #define	TLB_USER	0x00f00000
     54  1.3     skrll #define	 TLB_AR_NA	0x07300000
     55  1.3     skrll #define	 TLB_AR_R	TLB_READ
     56  1.3     skrll #define	 TLB_AR_RW	TLB_READ|TLB_WRITE
     57  1.3     skrll #define	 TLB_AR_RX	TLB_READ|TLB_EXECUTE
     58  1.3     skrll #define	 TLB_AR_RWX	TLB_READ|TLB_WRITE|TLB_EXECUTE
     59  1.4     skrll #define	TLB_UNCACHEABLE	0x00080000	/* bit 12, U */
     60  1.3     skrll 					/* bit 13-30, Access ID */
     61  1.4     skrll #define	TLB_PID_MASK	0x0000fffe
     62  1.4     skrll /*			0x00000001 has no pt_entry_t equivalent */
     63  1.1  fredette 
     64  1.3     skrll #define TLB_BITS	\
     65  1.3     skrll 	"\177\020"	/* New bitmask */		\
     66  1.4     skrll 	"b\036wired\0"		/* bit 30 (1) */		\
     67  1.4     skrll 	"b\035T\0"		/* bit 29 (2) */		\
     68  1.4     skrll 	"b\034D\0"		/* bit 28 (3) */		\
     69  1.4     skrll 	"b\033B\0"		/* bit 27 (4) */		\
     70  1.4     skrll 	"b\023U\0"		/* bit 19 (12) */		\
     71  1.4     skrll 	"f\024\07ar\0"		/* bit 20 (11) .. 26 (5) */	\
     72  1.4     skrll 	    "=\x73" "------\0"					\
     73  1.4     skrll 	    "=\x00" "r-----\0"					\
     74  1.4     skrll 	    "=\x10" "rw----\0"					\
     75  1.4     skrll 	    "=\x20" "r-x---\0"					\
     76  1.4     skrll 	    "=\x30" "rwx---\0"					\
     77  1.4     skrll 	    "=\x0f" "r--r--\0"					\
     78  1.4     skrll 	    "=\x1f" "rw-rw-\0"					\
     79  1.4     skrll 	    "=\x2f" "r-xr-x\0"					\
     80  1.4     skrll 	    "=\x3f" "rwxrwx\0"					\
     81  1.4     skrll 	    "=\x4c" "gate\0"					\
     82  1.4     skrll 	    "=\x2c" "break\0"					\
     83  1.4     skrll 	"f\001\017pid\0\0"	 /* bit 1 (30) .. 15 (16)	*/
     84  1.1  fredette 
     85  1.1  fredette /* protection for a gateway page */
     86  1.3     skrll #define	TLB_GATE_PROT	0x04c00000
     87  1.1  fredette 
     88  1.1  fredette /* protection for break page */
     89  1.3     skrll #define	TLB_BREAK_PROT	0x02c00000
     90  1.1  fredette 
     91  1.1  fredette #endif	/* _HPPA_PTE_H_ */
     92