pte.h revision 1.7 1 1.7 skrll /* $NetBSD: pte.h,v 1.7 2019/08/15 09:07:34 skrll Exp $ */
2 1.1 matt
3 1.1 matt /*-
4 1.1 matt * Copyright (c) 2014 The NetBSD Foundation, Inc.
5 1.1 matt * All rights reserved.
6 1.1 matt *
7 1.1 matt * This code is derived from software contributed to The NetBSD Foundation
8 1.1 matt * by Matt Thomas of 3am Software Foundry.
9 1.1 matt *
10 1.1 matt * Redistribution and use in source and binary forms, with or without
11 1.1 matt * modification, are permitted provided that the following conditions
12 1.1 matt * are met:
13 1.1 matt * 1. Redistributions of source code must retain the above copyright
14 1.1 matt * notice, this list of conditions and the following disclaimer.
15 1.1 matt * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 matt * notice, this list of conditions and the following disclaimer in the
17 1.1 matt * documentation and/or other materials provided with the distribution.
18 1.1 matt *
19 1.1 matt * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 matt * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 matt * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 matt * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 matt * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 matt * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 matt * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 matt * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 matt * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 matt * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 matt * POSSIBILITY OF SUCH DAMAGE.
30 1.1 matt */
31 1.1 matt
32 1.1 matt #ifndef _AARCH64_PTE_H_
33 1.1 matt #define _AARCH64_PTE_H_
34 1.1 matt
35 1.1 matt #ifdef __aarch64__
36 1.1 matt
37 1.3 ryo #ifndef _LOCORE
38 1.3 ryo typedef uint64_t pd_entry_t; /* L0(512G) / L1(1G) / L2(2M) table entry */
39 1.3 ryo typedef uint64_t pt_entry_t; /* L3(4k) table entry */
40 1.3 ryo #endif /* _LOCORE */
41 1.1 matt
42 1.3 ryo /*
43 1.3 ryo * translation table, block, and page descriptors
44 1.3 ryo */
45 1.3 ryo #define LX_TBL_NSTABLE __BIT(63) /* inherited next level */
46 1.3 ryo #define LX_TBL_APTABLE __BITS(62,61) /* inherited next level */
47 1.7 skrll #define LX_TBL_APTABLE_NOEFFECT __SHIFTIN(0,LX_TBL_APTABLE)
48 1.7 skrll #define LX_TBL_APTABLE_EL0_NOACCESS __SHIFTIN(1,LX_TBL_APTABLE)
49 1.7 skrll #define LX_TBL_APTABLE_RO __SHIFTIN(2,LX_TBL_APTABLE)
50 1.7 skrll #define LX_TBL_APTABLE_RO_EL0_NOREAD __SHIFTIN(3,LX_TBL_APTABLE)
51 1.3 ryo #define LX_TBL_UXNTABLE __BIT(60) /* inherited next level */
52 1.3 ryo #define LX_TBL_PXNTABLE __BIT(59) /* inherited next level */
53 1.3 ryo #define LX_BLKPAG_OS __BITS(58, 55)
54 1.7 skrll #define LX_BLKPAG_OS_0 __SHIFTIN(1,LX_BLKPAG_OS)
55 1.7 skrll #define LX_BLKPAG_OS_1 __SHIFTIN(2,LX_BLKPAG_OS)
56 1.7 skrll #define LX_BLKPAG_OS_2 __SHIFTIN(4,LX_BLKPAG_OS)
57 1.7 skrll #define LX_BLKPAG_OS_3 __SHIFTIN(8,LX_BLKPAG_OS)
58 1.3 ryo #define LX_BLKPAG_UXN __BIT(54) /* Unprivileged Execute Never */
59 1.3 ryo #define LX_BLKPAG_PXN __BIT(53) /* Privileged Execute Never */
60 1.3 ryo #define LX_BLKPAG_CONTIG __BIT(52) /* Hint of TLB cache */
61 1.6 skrll #define LX_BLKPAG_DBM __BIT(51) /* Dirty Bit Modifier (V8.1) */
62 1.3 ryo #define LX_TBL_PA __BITS(47, 12)
63 1.3 ryo #define LX_BLKPAG_OA __BITS(47, 12)
64 1.3 ryo #define LX_BLKPAG_NG __BIT(11) /* Not Global */
65 1.3 ryo #define LX_BLKPAG_AF __BIT(10) /* Access Flag */
66 1.3 ryo #define LX_BLKPAG_SH __BITS(9,8) /* Shareability */
67 1.7 skrll #define LX_BLKPAG_SH_NS __SHIFTIN(0,LX_BLKPAG_SH) /* Non Shareable */
68 1.7 skrll #define LX_BLKPAG_SH_OS __SHIFTIN(2,LX_BLKPAG_SH) /* Outer Shareable */
69 1.7 skrll #define LX_BLKPAG_SH_IS __SHIFTIN(3,LX_BLKPAG_SH) /* Inner Shareable */
70 1.3 ryo #define LX_BLKPAG_AP __BIT(7)
71 1.7 skrll #define LX_BLKPAG_AP_RW __SHIFTIN(0,LX_BLKPAG_AP) /* RW */
72 1.7 skrll #define LX_BLKPAG_AP_RO __SHIFTIN(1,LX_BLKPAG_AP) /* RO */
73 1.3 ryo #define LX_BLKPAG_APUSER __BIT(6)
74 1.3 ryo #define LX_BLKPAG_NS __BIT(5)
75 1.3 ryo #define LX_BLKPAG_ATTR_INDX __BITS(4,2) /* refer MAIR_EL1 attr<n> */
76 1.4 ryo #define LX_BLKPAG_ATTR_INDX_0 __SHIFTIN(0,LX_BLKPAG_ATTR_INDX)
77 1.4 ryo #define LX_BLKPAG_ATTR_INDX_1 __SHIFTIN(1,LX_BLKPAG_ATTR_INDX)
78 1.4 ryo #define LX_BLKPAG_ATTR_INDX_2 __SHIFTIN(2,LX_BLKPAG_ATTR_INDX)
79 1.4 ryo #define LX_BLKPAG_ATTR_INDX_3 __SHIFTIN(3,LX_BLKPAG_ATTR_INDX)
80 1.3 ryo #define LX_TYPE __BIT(1)
81 1.7 skrll #define LX_TYPE_BLK __SHIFTIN(0, LX_TYPE)
82 1.7 skrll #define LX_TYPE_TBL __SHIFTIN(1, LX_TYPE)
83 1.7 skrll #define L3_TYPE_PAG __SHIFTIN(1, LX_TYPE)
84 1.1 matt #define LX_VALID __BIT(0)
85 1.1 matt
86 1.3 ryo #define L1_BLK_OA __BITS(47, 30) /* 1GB */
87 1.3 ryo #define L2_BLK_OA __BITS(47, 21) /* 2MB */
88 1.3 ryo #define L3_PAG_OA __BITS(47, 12) /* 4KB */
89 1.3 ryo
90 1.3 ryo
91 1.3 ryo /* L0 table, 512GB/entry * 512 */
92 1.3 ryo #define L0_SHIFT 39
93 1.3 ryo #define L0_ADDR_BITS __BITS(47,39)
94 1.3 ryo #define L0_SIZE (1UL << L0_SHIFT)
95 1.3 ryo #define L0_OFFSET (L0_SIZE - 1UL)
96 1.3 ryo #define L0_FRAME (~L0_OFFSET)
97 1.3 ryo /* L0_BLOCK Level 0 doesn't support block translation */
98 1.3 ryo #define L0_TABLE (LX_TYPE_TBL | LX_VALID)
99 1.3 ryo
100 1.3 ryo /* L1 table, 1GB/entry * 512 */
101 1.3 ryo #define L1_SHIFT 30
102 1.3 ryo #define L1_ADDR_BITS __BITS(38,30)
103 1.3 ryo #define L1_SIZE (1UL << L1_SHIFT)
104 1.3 ryo #define L1_OFFSET (L1_SIZE - 1UL)
105 1.3 ryo #define L1_FRAME (~L1_OFFSET)
106 1.3 ryo #define L1_BLOCK (LX_BLKPAG_NG | LX_TYPE_BLK | LX_VALID)
107 1.3 ryo #define L1_TABLE (LX_TYPE_TBL | LX_VALID)
108 1.3 ryo
109 1.3 ryo /* L2 table, 2MB/entry * 512 */
110 1.3 ryo #define L2_SHIFT 21
111 1.3 ryo #define L2_ADDR_BITS __BITS(29,21)
112 1.3 ryo #define L2_SIZE (1UL << L2_SHIFT)
113 1.3 ryo #define L2_OFFSET (L2_SIZE - 1UL)
114 1.3 ryo #define L2_FRAME (~L2_OFFSET)
115 1.3 ryo #define L2_BLOCK (LX_BLKPAG_NG | LX_TYPE_BLK | LX_VALID)
116 1.3 ryo #define L2_TABLE (LX_TYPE_TBL | LX_VALID)
117 1.3 ryo #define L2_BLOCK_MASK __BITS(47,21)
118 1.3 ryo
119 1.3 ryo /* L3 table, 4KB/entry * 512 */
120 1.3 ryo #define L3_SHIFT 12
121 1.3 ryo #define L3_ADDR_BITS __BITS(20,12)
122 1.3 ryo #define L3_SIZE (1UL << L3_SHIFT)
123 1.3 ryo #define L3_OFFSET (L3_SIZE - 1UL)
124 1.3 ryo #define L3_FRAME (~L3_OFFSET)
125 1.3 ryo #define L3_PAGE (LX_BLKPAG_NG | L3_TYPE_PAG | LX_VALID)
126 1.3 ryo
127 1.3 ryo #define Ln_ENTRIES_SHIFT 9
128 1.3 ryo #define Ln_ENTRIES (1 << Ln_ENTRIES_SHIFT)
129 1.3 ryo #define Ln_TABLE_SIZE (8 << Ln_ENTRIES_SHIFT)
130 1.3 ryo
131 1.3 ryo
132 1.3 ryo /* TCR_EL1 - Translation Control Register */
133 1.7 skrll #define TCR_TBI1 __BIT(38) /* ignore Top Byte TTBR1_EL1 */
134 1.7 skrll #define TCR_TBI0 __BIT(37) /* ignore Top Byte TTBR0_EL1 */
135 1.7 skrll #define TCR_AS64K __BIT(36) /* Use 64K ASIDs */
136 1.7 skrll #define TCR_IPS __BITS(34,32) /* Intermediate PhysAdr Size */
137 1.7 skrll #define TCR_IPS_256TB __SHIFTIN(5,TCR_IPS) /* 48 bits (256 TB) */
138 1.7 skrll #define TCR_IPS_64TB __SHIFTIN(4,TCR_IPS) /* 44 bits (16 TB) */
139 1.7 skrll #define TCR_IPS_4TB __SHIFTIN(3,TCR_IPS) /* 42 bits ( 4 TB) */
140 1.7 skrll #define TCR_IPS_1TB __SHIFTIN(2,TCR_IPS) /* 40 bits ( 1 TB) */
141 1.7 skrll #define TCR_IPS_64GB __SHIFTIN(1,TCR_IPS) /* 36 bits (64 GB) */
142 1.7 skrll #define TCR_IPS_4GB __SHIFTIN(0,TCR_IPS) /* 32 bits (4 GB) */
143 1.7 skrll #define TCR_TG1 __BITS(31,30) /* TTBR1 Page Granule Size */
144 1.7 skrll #define TCR_TG1_16KB __SHIFTIN(1,TCR_TG1) /* 16KB page size */
145 1.7 skrll #define TCR_TG1_4KB __SHIFTIN(2,TCR_TG1) /* 4KB page size */
146 1.7 skrll #define TCR_TG1_64KB __SHIFTIN(3,TCR_TG1) /* 64KB page size */
147 1.7 skrll #define TCR_SH1 __BITS(29,28)
148 1.7 skrll #define TCR_SH1_NONE __SHIFTIN(0,TCR_SH1)
149 1.7 skrll #define TCR_SH1_OUTER __SHIFTIN(2,TCR_SH1)
150 1.7 skrll #define TCR_SH1_INNER __SHIFTIN(3,TCR_SH1)
151 1.7 skrll #define TCR_ORGN1 __BITS(27,26) /* TTBR1 Outer cacheability */
152 1.7 skrll #define TCR_ORGN1_NC __SHIFTIN(0,TCR_ORGN1) /* Non Cacheable */
153 1.7 skrll #define TCR_ORGN1_WB_WA __SHIFTIN(1,TCR_ORGN1) /* WriteBack WriteAllocate */
154 1.7 skrll #define TCR_ORGN1_WT __SHIFTIN(2,TCR_ORGN1) /* WriteThrough */
155 1.7 skrll #define TCR_ORGN1_WB __SHIFTIN(3,TCR_ORGN1) /* WriteBack */
156 1.7 skrll #define TCR_IRGN1 __BITS(25,24) /* TTBR1 Inner cacheability */
157 1.7 skrll #define TCR_IRGN1_NC __SHIFTIN(0,TCR_IRGN1) /* Non Cacheable */
158 1.7 skrll #define TCR_IRGN1_WB_WA __SHIFTIN(1,TCR_IRGN1) /* WriteBack WriteAllocate */
159 1.7 skrll #define TCR_IRGN1_WT __SHIFTIN(2,TCR_IRGN1) /* WriteThrough */
160 1.7 skrll #define TCR_IRGN1_WB __SHIFTIN(3,TCR_IRGN1) /* WriteBack */
161 1.7 skrll #define TCR_EPD1 __BIT(23) /* Walk Disable for TTBR1_EL1 */
162 1.7 skrll #define TCR_A1 __BIT(22) /* ASID is in TTBR1_EL1 */
163 1.7 skrll #define TCR_T1SZ __BITS(21,16) /* Size offset for TTBR1_EL1 */
164 1.7 skrll #define TCR_TG0 __BITS(15,14) /* TTBR0 Page Granule Size */
165 1.7 skrll #define TCR_TG0_16KB __SHIFTIN(1,TCR_TG1) /* 16KB page size */
166 1.7 skrll #define TCR_TG0_4KB __SHIFTIN(2,TCR_TG1) /* 4KB page size */
167 1.7 skrll #define TCR_TG0_64KB __SHIFTIN(3,TCR_TG1) /* 64KB page size */
168 1.7 skrll #define TCR_SH0 __BITS(13,12)
169 1.7 skrll #define TCR_SH0_NONE __SHIFTIN(0,TCR_SH0)
170 1.7 skrll #define TCR_SH0_OUTER __SHIFTIN(2,TCR_SH0)
171 1.7 skrll #define TCR_SH0_INNER __SHIFTIN(3,TCR_SH0)
172 1.7 skrll #define TCR_ORGN0 __BITS(11,10) /* TTBR0 Outer cacheability */
173 1.7 skrll #define TCR_ORGN0_NC __SHIFTIN(0,TCR_ORGN0) /* Non Cacheable */
174 1.7 skrll #define TCR_ORGN0_WB_WA __SHIFTIN(1,TCR_ORGN0) /* WriteBack WriteAllocate */
175 1.7 skrll #define TCR_ORGN0_WT __SHIFTIN(2,TCR_ORGN0) /* WriteThrough */
176 1.7 skrll #define TCR_ORGN0_WB __SHIFTIN(3,TCR_ORGN0) /* WriteBack */
177 1.7 skrll #define TCR_IRGN0 __BITS(9,8) /* TTBR0 Inner cacheability */
178 1.7 skrll #define TCR_IRGN0_NC __SHIFTIN(0,TCR_IRGN0) /* Non Cacheable */
179 1.7 skrll #define TCR_IRGN0_WB_WA __SHIFTIN(1,TCR_IRGN0) /* WriteBack WriteAllocate */
180 1.7 skrll #define TCR_IRGN0_WT __SHIFTIN(2,TCR_IRGN0) /* WriteThrough */
181 1.7 skrll #define TCR_IRGN0_WB __SHIFTIN(3,TCR_IRGN0) /* WriteBack */
182 1.7 skrll #define TCR_EPD0 __BIT(7) /* Walk Disable for TTBR0 */
183 1.7 skrll #define TCR_T0SZ __BITS(5,0) /* Size offset for TTBR0_EL1 */
184 1.3 ryo
185 1.3 ryo
186 1.3 ryo /* TTBR0_EL1, TTBR1_EL1 - Translation Table Base Register */
187 1.3 ryo #define TTBR_ASID __BITS(63,48)
188 1.3 ryo #define TTBR_BADDR __BITS(47,0)
189 1.3 ryo
190 1.5 ryo #define TTBR_SEL_VA __BIT(63) /* which TTBR is selected */
191 1.5 ryo
192 1.1 matt
193 1.1 matt #elif defined(__arm__)
194 1.1 matt
195 1.1 matt #include <arm/pte.h>
196 1.1 matt
197 1.1 matt #endif /* __aarch64__/__arm__ */
198 1.1 matt
199 1.1 matt #endif /* _AARCH64_PTE_H_ */
200