diff options
author | Patrick Wildt <patrick@cvs.openbsd.org> | 2013-04-26 05:05:35 +0000 |
---|---|---|
committer | Patrick Wildt <patrick@cvs.openbsd.org> | 2013-04-26 05:05:35 +0000 |
commit | 65c3dca0c7d3e0d6ead2864e804408a0c77d0dee (patch) | |
tree | 32854b6b96b2e3457d97c366c2fca0c30668adb0 | |
parent | 13e430946251c98ed7eeb594b1d1d3c5459a9231 (diff) |
Update and clean ARMv7 specific defines in the PTE header file.
ok bmercer@
-rw-r--r-- | sys/arch/arm/include/pte.h | 44 |
1 files changed, 26 insertions, 18 deletions
diff --git a/sys/arch/arm/include/pte.h b/sys/arch/arm/include/pte.h index b4deeb13f09..4a1cf99d9c2 100644 --- a/sys/arch/arm/include/pte.h +++ b/sys/arch/arm/include/pte.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pte.h,v 1.3 2011/11/07 15:31:13 miod Exp $ */ +/* $OpenBSD: pte.h,v 1.4 2013/04/26 05:05:34 patrick Exp $ */ /* $NetBSD: pte.h,v 1.6 2003/04/18 11:08:28 scw Exp $ */ /* @@ -133,8 +133,8 @@ typedef uint32_t pt_entry_t; /* L2 table entry */ #define L1_TYPE_INV 0x00 /* Invalid (fault) */ #define L1_TYPE_C 0x01 /* Coarse L2 */ -#define L1_TYPE_S 0x02 /* Section */ -#define L1_TYPE_F 0x03 /* Fine L2 */ +#define L1_TYPE_S 0x02 /* Section or Supersection */ +#define L1_TYPE_F 0x03 /* Fine L2 (pre-V7) */ #define L1_TYPE_MASK 0x03 /* mask of type bits */ /* L1 Section Descriptor */ @@ -149,13 +149,15 @@ typedef uint32_t pt_entry_t; /* L2 table entry */ #define L1_S_XSCALE_P 0x00000200 /* ECC enable for this section */ #define L1_S_XSCALE_TEX(x) ((x) << 12) /* Type Extension */ -#define L1_S_V7_TEX(x) ((x) << 12) /* Type Extension */ -#define L1_S_V7_NS(x) ((x) << 12) /* */ -#define L1_S_V7_nG(x) ((x) << 12) /* */ -#define L1_S_V7_S(x) ((x) << 12) /* */ -#define L1_S_V7_S(x) ((x) << 12) /* */ +#define L1_S_V7_TEX(x) (((x) & 0x7) << 12) /* Type Extension */ +#define L1_S_V7_TEX_MASK (0x7 << 12) /* Type Extension */ +#define L1_S_V7_NS 0x00080000 /* Non-secure */ +#define L1_S_V7_SS 0x00040000 /* Supersection */ +#define L1_S_V7_nG 0x00020000 /* not Global */ +#define L1_S_V7_S 0x00010000 /* Shareable */ #define L1_S_V7_AP(x) ((((x) & 0x4) << 13) | (((x) & 3) << 10)) /* AP */ -#define L1_S_V7_XN(x) ((x) << 4) /* */ +#define L1_S_V7_IMP 0x00000200 /* implementation defined */ +#define L1_S_V7_XN 0x00000010 /* eXecute Never */ /* L1 Coarse Descriptor */ #define L1_C_IMP0 0x00000004 /* implementation defined */ @@ -167,6 +169,9 @@ typedef uint32_t pt_entry_t; /* L2 table entry */ #define L1_C_XSCALE_P 0x00000200 /* ECC enable for this section */ +#define L1_C_V7_NS 0x00000008 /* Non-secure */ +#define L1_C_V7_IMP 0x00000200 /* implementation defined */ + /* L1 Fine Descriptor */ #define L1_F_IMP0 0x00000004 /* implementation defined */ #define L1_F_IMP1 0x00000008 /* implementation defined */ @@ -184,7 +189,7 @@ typedef uint32_t pt_entry_t; /* L2 table entry */ #define L2_TYPE_INV 0x00 /* Invalid (fault) */ #define L2_TYPE_L 0x01 /* Large Page */ #define L2_TYPE_S 0x02 /* Small Page */ -#define L2_TYPE_T 0x03 /* Tiny Page */ +#define L2_TYPE_T 0x03 /* Tiny Page (pre-V7) */ #define L2_TYPE_MASK 0x03 /* mask of type bits */ /* @@ -206,17 +211,19 @@ typedef uint32_t pt_entry_t; /* L2 table entry */ #define L2_XSCALE_L_TEX(x) ((x) << 12) /* Type Extension */ #define L2_XSCALE_T_TEX(x) ((x) << 6) /* Type Extension */ -#define L2_V7_L_TEX(x) ((x) << 12) /* Type Extension */ -#define L2_V7_L_XN(x) ((x) << 15) /* eXecute Never */ -#define L2_V7_T_TEX(x) ((x) << 6) /* Type Extension */ -#define L2_V7_T_XN(x) ((x) << 0) /* eXecute Never */ +#define L2_V7_L_TEX(x) (((x) & 0x7) << 12) /* Type Extension */ +#define L2_V7_L_TEX_MASK (0x7 << 12) /* Type Extension */ +#define L2_V7_L_XN 0x00008000 /* eXecute Never */ +#define L2_V7_S_TEX(x) (((x) & 0x7) << 6) /* Type Extension */ +#define L2_V7_S_TEX_MASK (0x7 << 6) /* Type Extension */ +#define L2_V7_S_XN 0x00000001 /* eXecute Never */ -#define L2_V7_AP(x) ((((x)& 4) << 7) | (((x) & 3) << 4)) /* AP */ -#define L2_V7_S(x) ((x) << 10) /* Shared */ -#define L2_V7_nG(x) ((x) << 10) /* not Global */ +#define L2_V7_AP(x) ((((x) & 0x04) << 7) | (((x) & 0x03) << 4)) /* AP */ +#define L2_V7_S 0x00000400 /* Shared */ +#define L2_V7_nG 0x00000200 /* not Global */ /* - * Access Permissions for L1 and L2 Descriptors. + * Access Permissions for L1 and L2 Descriptors. (except for V7) */ #define AP_W 0x01 /* writable */ #define AP_U 0x02 /* user */ @@ -228,6 +235,7 @@ typedef uint32_t pt_entry_t; /* L2 table entry */ * the R (ROM) bit is clear in CP15 register 1. */ #define AP_KR 0x00 /* kernel read */ +#define AP_V7_KR 0x05 #define AP_KRW 0x01 /* kernel read/write */ #define AP_KRWUR 0x02 /* kernel read/write usr read */ #define AP_KRWURW 0x03 /* kernel read/write usr read/write */ |