blob: bbd397cff6c8bb9782ac26bd96ae03131a92c802 [file] [log] [blame]
Stepan Moskovchenko2e8c8ba2011-02-24 18:00:41 -08001/* Copyright (c) 2010-2011, Code Aurora Forum. All rights reserved.
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -07002 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 *
12 * You should have received a copy of the GNU General Public License
13 * along with this program; if not, write to the Free Software
14 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
15 * 02110-1301, USA.
16 */
17
18#ifndef __ARCH_ARM_MACH_MSM_IOMMU_HW_8XXX_H
19#define __ARCH_ARM_MACH_MSM_IOMMU_HW_8XXX_H
20
21#define CTX_SHIFT 12
22
23#define GET_GLOBAL_REG(reg, base) (readl((base) + (reg)))
24#define GET_CTX_REG(reg, base, ctx) \
25 (readl((base) + (reg) + ((ctx) << CTX_SHIFT)))
26
27#define SET_GLOBAL_REG(reg, base, val) writel((val), ((base) + (reg)))
28
29#define SET_CTX_REG(reg, base, ctx, val) \
30 writel((val), ((base) + (reg) + ((ctx) << CTX_SHIFT)))
31
32/* Wrappers for numbered registers */
33#define SET_GLOBAL_REG_N(b, n, r, v) SET_GLOBAL_REG(b, ((r) + (n << 2)), (v))
34#define GET_GLOBAL_REG_N(b, n, r) GET_GLOBAL_REG(b, ((r) + (n << 2)))
35
36/* Field wrappers */
37#define GET_GLOBAL_FIELD(b, r, F) GET_FIELD(((b) + (r)), F##_MASK, F##_SHIFT)
38#define GET_CONTEXT_FIELD(b, c, r, F) \
39 GET_FIELD(((b) + (r) + ((c) << CTX_SHIFT)), F##_MASK, F##_SHIFT)
40
41#define SET_GLOBAL_FIELD(b, r, F, v) \
42 SET_FIELD(((b) + (r)), F##_MASK, F##_SHIFT, (v))
43#define SET_CONTEXT_FIELD(b, c, r, F, v) \
44 SET_FIELD(((b) + (r) + ((c) << CTX_SHIFT)), F##_MASK, F##_SHIFT, (v))
45
46#define GET_FIELD(addr, mask, shift) ((readl(addr) >> (shift)) & (mask))
47
48#define SET_FIELD(addr, mask, shift, v) \
49do { \
50 int t = readl(addr); \
51 writel((t & ~((mask) << (shift))) + (((v) & (mask)) << (shift)), addr);\
52} while (0)
53
54
55#define NUM_FL_PTE 4096
56#define NUM_SL_PTE 256
Stepan Moskovchenko08bd6832010-11-15 18:19:35 -080057#define NUM_TEX_CLASS 8
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -070058
59/* First-level page table bits */
60#define FL_BASE_MASK 0xFFFFFC00
61#define FL_TYPE_TABLE (1 << 0)
62#define FL_TYPE_SECT (2 << 0)
63#define FL_SUPERSECTION (1 << 18)
64#define FL_AP_WRITE (1 << 10)
65#define FL_AP_READ (1 << 11)
66#define FL_SHARED (1 << 16)
Stepan Moskovchenko08bd6832010-11-15 18:19:35 -080067#define FL_BUFFERABLE (1 << 2)
68#define FL_CACHEABLE (1 << 3)
69#define FL_TEX0 (1 << 12)
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -070070#define FL_OFFSET(va) (((va) & 0xFFF00000) >> 20)
Stepan Moskovchenko2e8c8ba2011-02-24 18:00:41 -080071#define FL_NG (1 << 17)
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -070072
73/* Second-level page table bits */
74#define SL_BASE_MASK_LARGE 0xFFFF0000
75#define SL_BASE_MASK_SMALL 0xFFFFF000
76#define SL_TYPE_LARGE (1 << 0)
77#define SL_TYPE_SMALL (2 << 0)
78#define SL_AP0 (1 << 4)
79#define SL_AP1 (2 << 4)
80#define SL_SHARED (1 << 10)
Stepan Moskovchenko08bd6832010-11-15 18:19:35 -080081#define SL_BUFFERABLE (1 << 2)
82#define SL_CACHEABLE (1 << 3)
83#define SL_TEX0 (1 << 6)
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -070084#define SL_OFFSET(va) (((va) & 0xFF000) >> 12)
Stepan Moskovchenko2e8c8ba2011-02-24 18:00:41 -080085#define SL_NG (1 << 11)
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -070086
Stepan Moskovchenko08bd6832010-11-15 18:19:35 -080087/* Memory type and cache policy attributes */
88#define MT_SO 0
89#define MT_DEV 1
90#define MT_NORMAL 2
91#define CP_NONCACHED 0
92#define CP_WB_WA 1
93#define CP_WT 2
94#define CP_WB_NWA 3
95
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -070096/* Global register setters / getters */
97#define SET_M2VCBR_N(b, N, v) SET_GLOBAL_REG_N(M2VCBR_N, N, (b), (v))
98#define SET_CBACR_N(b, N, v) SET_GLOBAL_REG_N(CBACR_N, N, (b), (v))
99#define SET_TLBRSW(b, v) SET_GLOBAL_REG(TLBRSW, (b), (v))
100#define SET_TLBTR0(b, v) SET_GLOBAL_REG(TLBTR0, (b), (v))
101#define SET_TLBTR1(b, v) SET_GLOBAL_REG(TLBTR1, (b), (v))
102#define SET_TLBTR2(b, v) SET_GLOBAL_REG(TLBTR2, (b), (v))
103#define SET_TESTBUSCR(b, v) SET_GLOBAL_REG(TESTBUSCR, (b), (v))
104#define SET_GLOBAL_TLBIALL(b, v) SET_GLOBAL_REG(GLOBAL_TLBIALL, (b), (v))
105#define SET_TLBIVMID(b, v) SET_GLOBAL_REG(TLBIVMID, (b), (v))
106#define SET_CR(b, v) SET_GLOBAL_REG(CR, (b), (v))
107#define SET_EAR(b, v) SET_GLOBAL_REG(EAR, (b), (v))
108#define SET_ESR(b, v) SET_GLOBAL_REG(ESR, (b), (v))
109#define SET_ESRRESTORE(b, v) SET_GLOBAL_REG(ESRRESTORE, (b), (v))
110#define SET_ESYNR0(b, v) SET_GLOBAL_REG(ESYNR0, (b), (v))
111#define SET_ESYNR1(b, v) SET_GLOBAL_REG(ESYNR1, (b), (v))
112#define SET_RPU_ACR(b, v) SET_GLOBAL_REG(RPU_ACR, (b), (v))
113
114#define GET_M2VCBR_N(b, N) GET_GLOBAL_REG_N(M2VCBR_N, N, (b))
115#define GET_CBACR_N(b, N) GET_GLOBAL_REG_N(CBACR_N, N, (b))
116#define GET_TLBTR0(b) GET_GLOBAL_REG(TLBTR0, (b))
117#define GET_TLBTR1(b) GET_GLOBAL_REG(TLBTR1, (b))
118#define GET_TLBTR2(b) GET_GLOBAL_REG(TLBTR2, (b))
119#define GET_TESTBUSCR(b) GET_GLOBAL_REG(TESTBUSCR, (b))
120#define GET_GLOBAL_TLBIALL(b) GET_GLOBAL_REG(GLOBAL_TLBIALL, (b))
121#define GET_TLBIVMID(b) GET_GLOBAL_REG(TLBIVMID, (b))
122#define GET_CR(b) GET_GLOBAL_REG(CR, (b))
123#define GET_EAR(b) GET_GLOBAL_REG(EAR, (b))
124#define GET_ESR(b) GET_GLOBAL_REG(ESR, (b))
125#define GET_ESRRESTORE(b) GET_GLOBAL_REG(ESRRESTORE, (b))
126#define GET_ESYNR0(b) GET_GLOBAL_REG(ESYNR0, (b))
127#define GET_ESYNR1(b) GET_GLOBAL_REG(ESYNR1, (b))
128#define GET_REV(b) GET_GLOBAL_REG(REV, (b))
129#define GET_IDR(b) GET_GLOBAL_REG(IDR, (b))
130#define GET_RPU_ACR(b) GET_GLOBAL_REG(RPU_ACR, (b))
131
132
133/* Context register setters/getters */
134#define SET_SCTLR(b, c, v) SET_CTX_REG(SCTLR, (b), (c), (v))
135#define SET_ACTLR(b, c, v) SET_CTX_REG(ACTLR, (b), (c), (v))
136#define SET_CONTEXTIDR(b, c, v) SET_CTX_REG(CONTEXTIDR, (b), (c), (v))
137#define SET_TTBR0(b, c, v) SET_CTX_REG(TTBR0, (b), (c), (v))
138#define SET_TTBR1(b, c, v) SET_CTX_REG(TTBR1, (b), (c), (v))
139#define SET_TTBCR(b, c, v) SET_CTX_REG(TTBCR, (b), (c), (v))
140#define SET_PAR(b, c, v) SET_CTX_REG(PAR, (b), (c), (v))
141#define SET_FSR(b, c, v) SET_CTX_REG(FSR, (b), (c), (v))
142#define SET_FSRRESTORE(b, c, v) SET_CTX_REG(FSRRESTORE, (b), (c), (v))
143#define SET_FAR(b, c, v) SET_CTX_REG(FAR, (b), (c), (v))
144#define SET_FSYNR0(b, c, v) SET_CTX_REG(FSYNR0, (b), (c), (v))
145#define SET_FSYNR1(b, c, v) SET_CTX_REG(FSYNR1, (b), (c), (v))
146#define SET_PRRR(b, c, v) SET_CTX_REG(PRRR, (b), (c), (v))
147#define SET_NMRR(b, c, v) SET_CTX_REG(NMRR, (b), (c), (v))
148#define SET_TLBLKCR(b, c, v) SET_CTX_REG(TLBLCKR, (b), (c), (v))
149#define SET_V2PSR(b, c, v) SET_CTX_REG(V2PSR, (b), (c), (v))
150#define SET_TLBFLPTER(b, c, v) SET_CTX_REG(TLBFLPTER, (b), (c), (v))
151#define SET_TLBSLPTER(b, c, v) SET_CTX_REG(TLBSLPTER, (b), (c), (v))
152#define SET_BFBCR(b, c, v) SET_CTX_REG(BFBCR, (b), (c), (v))
153#define SET_CTX_TLBIALL(b, c, v) SET_CTX_REG(CTX_TLBIALL, (b), (c), (v))
154#define SET_TLBIASID(b, c, v) SET_CTX_REG(TLBIASID, (b), (c), (v))
155#define SET_TLBIVA(b, c, v) SET_CTX_REG(TLBIVA, (b), (c), (v))
156#define SET_TLBIVAA(b, c, v) SET_CTX_REG(TLBIVAA, (b), (c), (v))
157#define SET_V2PPR(b, c, v) SET_CTX_REG(V2PPR, (b), (c), (v))
158#define SET_V2PPW(b, c, v) SET_CTX_REG(V2PPW, (b), (c), (v))
159#define SET_V2PUR(b, c, v) SET_CTX_REG(V2PUR, (b), (c), (v))
160#define SET_V2PUW(b, c, v) SET_CTX_REG(V2PUW, (b), (c), (v))
161#define SET_RESUME(b, c, v) SET_CTX_REG(RESUME, (b), (c), (v))
162
163#define GET_SCTLR(b, c) GET_CTX_REG(SCTLR, (b), (c))
164#define GET_ACTLR(b, c) GET_CTX_REG(ACTLR, (b), (c))
165#define GET_CONTEXTIDR(b, c) GET_CTX_REG(CONTEXTIDR, (b), (c))
166#define GET_TTBR0(b, c) GET_CTX_REG(TTBR0, (b), (c))
167#define GET_TTBR1(b, c) GET_CTX_REG(TTBR1, (b), (c))
168#define GET_TTBCR(b, c) GET_CTX_REG(TTBCR, (b), (c))
169#define GET_PAR(b, c) GET_CTX_REG(PAR, (b), (c))
170#define GET_FSR(b, c) GET_CTX_REG(FSR, (b), (c))
171#define GET_FSRRESTORE(b, c) GET_CTX_REG(FSRRESTORE, (b), (c))
172#define GET_FAR(b, c) GET_CTX_REG(FAR, (b), (c))
173#define GET_FSYNR0(b, c) GET_CTX_REG(FSYNR0, (b), (c))
174#define GET_FSYNR1(b, c) GET_CTX_REG(FSYNR1, (b), (c))
175#define GET_PRRR(b, c) GET_CTX_REG(PRRR, (b), (c))
176#define GET_NMRR(b, c) GET_CTX_REG(NMRR, (b), (c))
177#define GET_TLBLCKR(b, c) GET_CTX_REG(TLBLCKR, (b), (c))
178#define GET_V2PSR(b, c) GET_CTX_REG(V2PSR, (b), (c))
179#define GET_TLBFLPTER(b, c) GET_CTX_REG(TLBFLPTER, (b), (c))
180#define GET_TLBSLPTER(b, c) GET_CTX_REG(TLBSLPTER, (b), (c))
181#define GET_BFBCR(b, c) GET_CTX_REG(BFBCR, (b), (c))
182#define GET_CTX_TLBIALL(b, c) GET_CTX_REG(CTX_TLBIALL, (b), (c))
183#define GET_TLBIASID(b, c) GET_CTX_REG(TLBIASID, (b), (c))
184#define GET_TLBIVA(b, c) GET_CTX_REG(TLBIVA, (b), (c))
185#define GET_TLBIVAA(b, c) GET_CTX_REG(TLBIVAA, (b), (c))
186#define GET_V2PPR(b, c) GET_CTX_REG(V2PPR, (b), (c))
187#define GET_V2PPW(b, c) GET_CTX_REG(V2PPW, (b), (c))
188#define GET_V2PUR(b, c) GET_CTX_REG(V2PUR, (b), (c))
189#define GET_V2PUW(b, c) GET_CTX_REG(V2PUW, (b), (c))
190#define GET_RESUME(b, c) GET_CTX_REG(RESUME, (b), (c))
191
192
193/* Global field setters / getters */
194/* Global Field Setters: */
195/* CBACR_N */
196#define SET_RWVMID(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWVMID, v)
197#define SET_RWE(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWE, v)
198#define SET_RWGE(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWGE, v)
199#define SET_CBVMID(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), CBVMID, v)
200#define SET_IRPTNDX(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), IRPTNDX, v)
201
202
203/* M2VCBR_N */
204#define SET_VMID(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), VMID, v)
205#define SET_CBNDX(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), CBNDX, v)
206#define SET_BYPASSD(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BYPASSD, v)
207#define SET_BPRCOSH(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCOSH, v)
208#define SET_BPRCISH(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCISH, v)
209#define SET_BPRCNSH(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCNSH, v)
210#define SET_BPSHCFG(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPSHCFG, v)
211#define SET_NSCFG(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), NSCFG, v)
212#define SET_BPMTCFG(b, n, v) SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMTCFG, v)
213#define SET_BPMEMTYPE(b, n, v) \
214 SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMEMTYPE, v)
215
216
217/* CR */
218#define SET_RPUE(b, v) SET_GLOBAL_FIELD(b, CR, RPUE, v)
219#define SET_RPUERE(b, v) SET_GLOBAL_FIELD(b, CR, RPUERE, v)
220#define SET_RPUEIE(b, v) SET_GLOBAL_FIELD(b, CR, RPUEIE, v)
221#define SET_DCDEE(b, v) SET_GLOBAL_FIELD(b, CR, DCDEE, v)
222#define SET_CLIENTPD(b, v) SET_GLOBAL_FIELD(b, CR, CLIENTPD, v)
223#define SET_STALLD(b, v) SET_GLOBAL_FIELD(b, CR, STALLD, v)
224#define SET_TLBLKCRWE(b, v) SET_GLOBAL_FIELD(b, CR, TLBLKCRWE, v)
225#define SET_CR_TLBIALLCFG(b, v) SET_GLOBAL_FIELD(b, CR, CR_TLBIALLCFG, v)
226#define SET_TLBIVMIDCFG(b, v) SET_GLOBAL_FIELD(b, CR, TLBIVMIDCFG, v)
227#define SET_CR_HUME(b, v) SET_GLOBAL_FIELD(b, CR, CR_HUME, v)
228
229
230/* ESR */
231#define SET_CFG(b, v) SET_GLOBAL_FIELD(b, ESR, CFG, v)
232#define SET_BYPASS(b, v) SET_GLOBAL_FIELD(b, ESR, BYPASS, v)
233#define SET_ESR_MULTI(b, v) SET_GLOBAL_FIELD(b, ESR, ESR_MULTI, v)
234
235
236/* ESYNR0 */
237#define SET_ESYNR0_AMID(b, v) SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AMID, v)
238#define SET_ESYNR0_APID(b, v) SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_APID, v)
239#define SET_ESYNR0_ABID(b, v) SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ABID, v)
240#define SET_ESYNR0_AVMID(b, v) SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AVMID, v)
241#define SET_ESYNR0_ATID(b, v) SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ATID, v)
242
243
244/* ESYNR1 */
245#define SET_ESYNR1_AMEMTYPE(b, v) \
246 SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AMEMTYPE, v)
247#define SET_ESYNR1_ASHARED(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASHARED, v)
248#define SET_ESYNR1_AINNERSHARED(b, v) \
249 SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINNERSHARED, v)
250#define SET_ESYNR1_APRIV(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APRIV, v)
251#define SET_ESYNR1_APROTNS(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APROTNS, v)
252#define SET_ESYNR1_AINST(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINST, v)
253#define SET_ESYNR1_AWRITE(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AWRITE, v)
254#define SET_ESYNR1_ABURST(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ABURST, v)
255#define SET_ESYNR1_ALEN(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALEN, v)
256#define SET_ESYNR1_ASIZE(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASIZE, v)
257#define SET_ESYNR1_ALOCK(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALOCK, v)
258#define SET_ESYNR1_AOOO(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AOOO, v)
259#define SET_ESYNR1_AFULL(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AFULL, v)
260#define SET_ESYNR1_AC(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AC, v)
261#define SET_ESYNR1_DCD(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_DCD, v)
262
263
264/* TESTBUSCR */
265#define SET_TBE(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, TBE, v)
266#define SET_SPDMBE(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, SPDMBE, v)
267#define SET_WGSEL(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, WGSEL, v)
268#define SET_TBLSEL(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, TBLSEL, v)
269#define SET_TBHSEL(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, TBHSEL, v)
270#define SET_SPDM0SEL(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM0SEL, v)
271#define SET_SPDM1SEL(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM1SEL, v)
272#define SET_SPDM2SEL(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM2SEL, v)
273#define SET_SPDM3SEL(b, v) SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM3SEL, v)
274
275
276/* TLBIVMID */
277#define SET_TLBIVMID_VMID(b, v) SET_GLOBAL_FIELD(b, TLBIVMID, TLBIVMID_VMID, v)
278
279
280/* TLBRSW */
281#define SET_TLBRSW_INDEX(b, v) SET_GLOBAL_FIELD(b, TLBRSW, TLBRSW_INDEX, v)
282#define SET_TLBBFBS(b, v) SET_GLOBAL_FIELD(b, TLBRSW, TLBBFBS, v)
283
284
285/* TLBTR0 */
286#define SET_PR(b, v) SET_GLOBAL_FIELD(b, TLBTR0, PR, v)
287#define SET_PW(b, v) SET_GLOBAL_FIELD(b, TLBTR0, PW, v)
288#define SET_UR(b, v) SET_GLOBAL_FIELD(b, TLBTR0, UR, v)
289#define SET_UW(b, v) SET_GLOBAL_FIELD(b, TLBTR0, UW, v)
290#define SET_XN(b, v) SET_GLOBAL_FIELD(b, TLBTR0, XN, v)
291#define SET_NSDESC(b, v) SET_GLOBAL_FIELD(b, TLBTR0, NSDESC, v)
292#define SET_ISH(b, v) SET_GLOBAL_FIELD(b, TLBTR0, ISH, v)
293#define SET_SH(b, v) SET_GLOBAL_FIELD(b, TLBTR0, SH, v)
294#define SET_MT(b, v) SET_GLOBAL_FIELD(b, TLBTR0, MT, v)
295#define SET_DPSIZR(b, v) SET_GLOBAL_FIELD(b, TLBTR0, DPSIZR, v)
296#define SET_DPSIZC(b, v) SET_GLOBAL_FIELD(b, TLBTR0, DPSIZC, v)
297
298
299/* TLBTR1 */
300#define SET_TLBTR1_VMID(b, v) SET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_VMID, v)
301#define SET_TLBTR1_PA(b, v) SET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_PA, v)
302
303
304/* TLBTR2 */
305#define SET_TLBTR2_ASID(b, v) SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_ASID, v)
306#define SET_TLBTR2_V(b, v) SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_V, v)
307#define SET_TLBTR2_NSTID(b, v) SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NSTID, v)
308#define SET_TLBTR2_NV(b, v) SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NV, v)
309#define SET_TLBTR2_VA(b, v) SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_VA, v)
310
311
312/* Global Field Getters */
313/* CBACR_N */
314#define GET_RWVMID(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWVMID)
315#define GET_RWE(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWE)
316#define GET_RWGE(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWGE)
317#define GET_CBVMID(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), CBVMID)
318#define GET_IRPTNDX(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), IRPTNDX)
319
320
321/* M2VCBR_N */
322#define GET_VMID(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), VMID)
323#define GET_CBNDX(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), CBNDX)
324#define GET_BYPASSD(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BYPASSD)
325#define GET_BPRCOSH(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCOSH)
326#define GET_BPRCISH(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCISH)
327#define GET_BPRCNSH(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCNSH)
328#define GET_BPSHCFG(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPSHCFG)
329#define GET_NSCFG(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), NSCFG)
330#define GET_BPMTCFG(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMTCFG)
331#define GET_BPMEMTYPE(b, n) GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMEMTYPE)
332
333
334/* CR */
335#define GET_RPUE(b) GET_GLOBAL_FIELD(b, CR, RPUE)
336#define GET_RPUERE(b) GET_GLOBAL_FIELD(b, CR, RPUERE)
337#define GET_RPUEIE(b) GET_GLOBAL_FIELD(b, CR, RPUEIE)
338#define GET_DCDEE(b) GET_GLOBAL_FIELD(b, CR, DCDEE)
339#define GET_CLIENTPD(b) GET_GLOBAL_FIELD(b, CR, CLIENTPD)
340#define GET_STALLD(b) GET_GLOBAL_FIELD(b, CR, STALLD)
341#define GET_TLBLKCRWE(b) GET_GLOBAL_FIELD(b, CR, TLBLKCRWE)
342#define GET_CR_TLBIALLCFG(b) GET_GLOBAL_FIELD(b, CR, CR_TLBIALLCFG)
343#define GET_TLBIVMIDCFG(b) GET_GLOBAL_FIELD(b, CR, TLBIVMIDCFG)
344#define GET_CR_HUME(b) GET_GLOBAL_FIELD(b, CR, CR_HUME)
345
346
347/* ESR */
348#define GET_CFG(b) GET_GLOBAL_FIELD(b, ESR, CFG)
349#define GET_BYPASS(b) GET_GLOBAL_FIELD(b, ESR, BYPASS)
350#define GET_ESR_MULTI(b) GET_GLOBAL_FIELD(b, ESR, ESR_MULTI)
351
352
353/* ESYNR0 */
354#define GET_ESYNR0_AMID(b) GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AMID)
355#define GET_ESYNR0_APID(b) GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_APID)
356#define GET_ESYNR0_ABID(b) GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ABID)
357#define GET_ESYNR0_AVMID(b) GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AVMID)
358#define GET_ESYNR0_ATID(b) GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ATID)
359
360
361/* ESYNR1 */
362#define GET_ESYNR1_AMEMTYPE(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AMEMTYPE)
363#define GET_ESYNR1_ASHARED(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASHARED)
364#define GET_ESYNR1_AINNERSHARED(b) \
365 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINNERSHARED)
366#define GET_ESYNR1_APRIV(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APRIV)
367#define GET_ESYNR1_APROTNS(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APROTNS)
368#define GET_ESYNR1_AINST(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINST)
369#define GET_ESYNR1_AWRITE(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AWRITE)
370#define GET_ESYNR1_ABURST(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ABURST)
371#define GET_ESYNR1_ALEN(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALEN)
372#define GET_ESYNR1_ASIZE(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASIZE)
373#define GET_ESYNR1_ALOCK(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALOCK)
374#define GET_ESYNR1_AOOO(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AOOO)
375#define GET_ESYNR1_AFULL(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AFULL)
376#define GET_ESYNR1_AC(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AC)
377#define GET_ESYNR1_DCD(b) GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_DCD)
378
379
380/* IDR */
381#define GET_NM2VCBMT(b) GET_GLOBAL_FIELD(b, IDR, NM2VCBMT)
382#define GET_HTW(b) GET_GLOBAL_FIELD(b, IDR, HTW)
383#define GET_HUM(b) GET_GLOBAL_FIELD(b, IDR, HUM)
384#define GET_TLBSIZE(b) GET_GLOBAL_FIELD(b, IDR, TLBSIZE)
385#define GET_NCB(b) GET_GLOBAL_FIELD(b, IDR, NCB)
386#define GET_NIRPT(b) GET_GLOBAL_FIELD(b, IDR, NIRPT)
387
388
389/* REV */
390#define GET_MAJOR(b) GET_GLOBAL_FIELD(b, REV, MAJOR)
391#define GET_MINOR(b) GET_GLOBAL_FIELD(b, REV, MINOR)
392
393
394/* TESTBUSCR */
395#define GET_TBE(b) GET_GLOBAL_FIELD(b, TESTBUSCR, TBE)
396#define GET_SPDMBE(b) GET_GLOBAL_FIELD(b, TESTBUSCR, SPDMBE)
397#define GET_WGSEL(b) GET_GLOBAL_FIELD(b, TESTBUSCR, WGSEL)
398#define GET_TBLSEL(b) GET_GLOBAL_FIELD(b, TESTBUSCR, TBLSEL)
399#define GET_TBHSEL(b) GET_GLOBAL_FIELD(b, TESTBUSCR, TBHSEL)
400#define GET_SPDM0SEL(b) GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM0SEL)
401#define GET_SPDM1SEL(b) GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM1SEL)
402#define GET_SPDM2SEL(b) GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM2SEL)
403#define GET_SPDM3SEL(b) GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM3SEL)
404
405
406/* TLBIVMID */
407#define GET_TLBIVMID_VMID(b) GET_GLOBAL_FIELD(b, TLBIVMID, TLBIVMID_VMID)
408
409
410/* TLBTR0 */
411#define GET_PR(b) GET_GLOBAL_FIELD(b, TLBTR0, PR)
412#define GET_PW(b) GET_GLOBAL_FIELD(b, TLBTR0, PW)
413#define GET_UR(b) GET_GLOBAL_FIELD(b, TLBTR0, UR)
414#define GET_UW(b) GET_GLOBAL_FIELD(b, TLBTR0, UW)
415#define GET_XN(b) GET_GLOBAL_FIELD(b, TLBTR0, XN)
416#define GET_NSDESC(b) GET_GLOBAL_FIELD(b, TLBTR0, NSDESC)
417#define GET_ISH(b) GET_GLOBAL_FIELD(b, TLBTR0, ISH)
418#define GET_SH(b) GET_GLOBAL_FIELD(b, TLBTR0, SH)
419#define GET_MT(b) GET_GLOBAL_FIELD(b, TLBTR0, MT)
420#define GET_DPSIZR(b) GET_GLOBAL_FIELD(b, TLBTR0, DPSIZR)
421#define GET_DPSIZC(b) GET_GLOBAL_FIELD(b, TLBTR0, DPSIZC)
422
423
424/* TLBTR1 */
425#define GET_TLBTR1_VMID(b) GET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_VMID)
426#define GET_TLBTR1_PA(b) GET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_PA)
427
428
429/* TLBTR2 */
430#define GET_TLBTR2_ASID(b) GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_ASID)
431#define GET_TLBTR2_V(b) GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_V)
432#define GET_TLBTR2_NSTID(b) GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NSTID)
433#define GET_TLBTR2_NV(b) GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NV)
434#define GET_TLBTR2_VA(b) GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_VA)
435
436
437/* Context Register setters / getters */
438/* Context Register setters */
439/* ACTLR */
440#define SET_CFERE(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, CFERE, v)
441#define SET_CFEIE(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, CFEIE, v)
442#define SET_PTSHCFG(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, PTSHCFG, v)
443#define SET_RCOSH(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, RCOSH, v)
444#define SET_RCISH(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, RCISH, v)
445#define SET_RCNSH(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, RCNSH, v)
446#define SET_PRIVCFG(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, PRIVCFG, v)
447#define SET_DNA(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, DNA, v)
448#define SET_DNLV2PA(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, DNLV2PA, v)
449#define SET_TLBMCFG(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, TLBMCFG, v)
450#define SET_CFCFG(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, CFCFG, v)
451#define SET_TIPCF(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, TIPCF, v)
452#define SET_V2PCFG(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, V2PCFG, v)
453#define SET_HUME(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, HUME, v)
454#define SET_PTMTCFG(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, PTMTCFG, v)
455#define SET_PTMEMTYPE(b, c, v) SET_CONTEXT_FIELD(b, c, ACTLR, PTMEMTYPE, v)
456
457
458/* BFBCR */
459#define SET_BFBDFE(b, c, v) SET_CONTEXT_FIELD(b, c, BFBCR, BFBDFE, v)
460#define SET_BFBSFE(b, c, v) SET_CONTEXT_FIELD(b, c, BFBCR, BFBSFE, v)
461#define SET_SFVS(b, c, v) SET_CONTEXT_FIELD(b, c, BFBCR, SFVS, v)
462#define SET_FLVIC(b, c, v) SET_CONTEXT_FIELD(b, c, BFBCR, FLVIC, v)
463#define SET_SLVIC(b, c, v) SET_CONTEXT_FIELD(b, c, BFBCR, SLVIC, v)
464
465
466/* CONTEXTIDR */
467#define SET_CONTEXTIDR_ASID(b, c, v) \
468 SET_CONTEXT_FIELD(b, c, CONTEXTIDR, CONTEXTIDR_ASID, v)
469#define SET_CONTEXTIDR_PROCID(b, c, v) \
470 SET_CONTEXT_FIELD(b, c, CONTEXTIDR, PROCID, v)
471
472
473/* FSR */
474#define SET_TF(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, TF, v)
475#define SET_AFF(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, AFF, v)
476#define SET_APF(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, APF, v)
477#define SET_TLBMF(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, TLBMF, v)
478#define SET_HTWDEEF(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, HTWDEEF, v)
479#define SET_HTWSEEF(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, HTWSEEF, v)
480#define SET_MHF(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, MHF, v)
481#define SET_SL(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, SL, v)
482#define SET_SS(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, SS, v)
483#define SET_MULTI(b, c, v) SET_CONTEXT_FIELD(b, c, FSR, MULTI, v)
484
485
486/* FSYNR0 */
487#define SET_AMID(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR0, AMID, v)
488#define SET_APID(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR0, APID, v)
489#define SET_ABID(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR0, ABID, v)
490#define SET_ATID(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR0, ATID, v)
491
492
493/* FSYNR1 */
494#define SET_AMEMTYPE(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, AMEMTYPE, v)
495#define SET_ASHARED(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, ASHARED, v)
496#define SET_AINNERSHARED(b, c, v) \
497 SET_CONTEXT_FIELD(b, c, FSYNR1, AINNERSHARED, v)
498#define SET_APRIV(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, APRIV, v)
499#define SET_APROTNS(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, APROTNS, v)
500#define SET_AINST(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, AINST, v)
501#define SET_AWRITE(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, AWRITE, v)
502#define SET_ABURST(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, ABURST, v)
503#define SET_ALEN(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, ALEN, v)
504#define SET_FSYNR1_ASIZE(b, c, v) \
505 SET_CONTEXT_FIELD(b, c, FSYNR1, FSYNR1_ASIZE, v)
506#define SET_ALOCK(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, ALOCK, v)
507#define SET_AFULL(b, c, v) SET_CONTEXT_FIELD(b, c, FSYNR1, AFULL, v)
508
509
510/* NMRR */
511#define SET_ICPC0(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC0, v)
512#define SET_ICPC1(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC1, v)
513#define SET_ICPC2(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC2, v)
514#define SET_ICPC3(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC3, v)
515#define SET_ICPC4(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC4, v)
516#define SET_ICPC5(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC5, v)
517#define SET_ICPC6(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC6, v)
518#define SET_ICPC7(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, ICPC7, v)
519#define SET_OCPC0(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC0, v)
520#define SET_OCPC1(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC1, v)
521#define SET_OCPC2(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC2, v)
522#define SET_OCPC3(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC3, v)
523#define SET_OCPC4(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC4, v)
524#define SET_OCPC5(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC5, v)
525#define SET_OCPC6(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC6, v)
526#define SET_OCPC7(b, c, v) SET_CONTEXT_FIELD(b, c, NMRR, OCPC7, v)
527
528
529/* PAR */
530#define SET_FAULT(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT, v)
531
532#define SET_FAULT_TF(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_TF, v)
533#define SET_FAULT_AFF(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_AFF, v)
534#define SET_FAULT_APF(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_APF, v)
535#define SET_FAULT_TLBMF(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_TLBMF, v)
536#define SET_FAULT_HTWDEEF(b, c, v) \
537 SET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWDEEF, v)
538#define SET_FAULT_HTWSEEF(b, c, v) \
539 SET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWSEEF, v)
540#define SET_FAULT_MHF(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_MHF, v)
541#define SET_FAULT_SL(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_SL, v)
542#define SET_FAULT_SS(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_SS, v)
543
544#define SET_NOFAULT_SS(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_SS, v)
545#define SET_NOFAULT_MT(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_MT, v)
546#define SET_NOFAULT_SH(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_SH, v)
547#define SET_NOFAULT_NS(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_NS, v)
548#define SET_NOFAULT_NOS(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_NOS, v)
549#define SET_NPFAULT_PA(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, NPFAULT_PA, v)
550
551
552/* PRRR */
553#define SET_MTC0(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC0, v)
554#define SET_MTC1(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC1, v)
555#define SET_MTC2(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC2, v)
556#define SET_MTC3(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC3, v)
557#define SET_MTC4(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC4, v)
558#define SET_MTC5(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC5, v)
559#define SET_MTC6(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC6, v)
560#define SET_MTC7(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, MTC7, v)
561#define SET_SHDSH0(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, SHDSH0, v)
562#define SET_SHDSH1(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, SHDSH1, v)
563#define SET_SHNMSH0(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, SHNMSH0, v)
564#define SET_SHNMSH1(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, SHNMSH1, v)
565#define SET_NOS0(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS0, v)
566#define SET_NOS1(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS1, v)
567#define SET_NOS2(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS2, v)
568#define SET_NOS3(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS3, v)
569#define SET_NOS4(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS4, v)
570#define SET_NOS5(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS5, v)
571#define SET_NOS6(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS6, v)
572#define SET_NOS7(b, c, v) SET_CONTEXT_FIELD(b, c, PRRR, NOS7, v)
573
574
575/* RESUME */
576#define SET_TNR(b, c, v) SET_CONTEXT_FIELD(b, c, RESUME, TNR, v)
577
578
579/* SCTLR */
580#define SET_M(b, c, v) SET_CONTEXT_FIELD(b, c, SCTLR, M, v)
581#define SET_TRE(b, c, v) SET_CONTEXT_FIELD(b, c, SCTLR, TRE, v)
582#define SET_AFE(b, c, v) SET_CONTEXT_FIELD(b, c, SCTLR, AFE, v)
583#define SET_HAF(b, c, v) SET_CONTEXT_FIELD(b, c, SCTLR, HAF, v)
584#define SET_BE(b, c, v) SET_CONTEXT_FIELD(b, c, SCTLR, BE, v)
585#define SET_AFFD(b, c, v) SET_CONTEXT_FIELD(b, c, SCTLR, AFFD, v)
586
587
588/* TLBLKCR */
589#define SET_LKE(b, c, v) SET_CONTEXT_FIELD(b, c, TLBLKCR, LKE, v)
590#define SET_TLBLKCR_TLBIALLCFG(b, c, v) \
591 SET_CONTEXT_FIELD(b, c, TLBLKCR, TLBLCKR_TLBIALLCFG, v)
592#define SET_TLBIASIDCFG(b, c, v) \
593 SET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIASIDCFG, v)
594#define SET_TLBIVAACFG(b, c, v) SET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIVAACFG, v)
595#define SET_FLOOR(b, c, v) SET_CONTEXT_FIELD(b, c, TLBLKCR, FLOOR, v)
596#define SET_VICTIM(b, c, v) SET_CONTEXT_FIELD(b, c, TLBLKCR, VICTIM, v)
597
598
599/* TTBCR */
600#define SET_N(b, c, v) SET_CONTEXT_FIELD(b, c, TTBCR, N, v)
601#define SET_PD0(b, c, v) SET_CONTEXT_FIELD(b, c, TTBCR, PD0, v)
602#define SET_PD1(b, c, v) SET_CONTEXT_FIELD(b, c, TTBCR, PD1, v)
603
604
605/* TTBR0 */
606#define SET_TTBR0_IRGNH(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNH, v)
607#define SET_TTBR0_SH(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_SH, v)
608#define SET_TTBR0_ORGN(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_ORGN, v)
609#define SET_TTBR0_NOS(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_NOS, v)
610#define SET_TTBR0_IRGNL(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNL, v)
611#define SET_TTBR0_PA(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_PA, v)
612
613
614/* TTBR1 */
615#define SET_TTBR1_IRGNH(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNH, v)
616#define SET_TTBR1_SH(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_SH, v)
617#define SET_TTBR1_ORGN(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_ORGN, v)
618#define SET_TTBR1_NOS(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_NOS, v)
619#define SET_TTBR1_IRGNL(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNL, v)
620#define SET_TTBR1_PA(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_PA, v)
621
622
623/* V2PSR */
624#define SET_HIT(b, c, v) SET_CONTEXT_FIELD(b, c, V2PSR, HIT, v)
625#define SET_INDEX(b, c, v) SET_CONTEXT_FIELD(b, c, V2PSR, INDEX, v)
626
627
628/* V2Pxx UW UR PW PR */
629#define SET_V2PUW_INDEX(b, c, v) SET_CONTEXT_FIELD(b, c, V2PUW, V2Pxx_INDEX, v)
630#define SET_V2PUW_VA(b, c, v) SET_CONTEXT_FIELD(b, c, V2PUW, V2Pxx_VA, v)
631
632#define SET_V2PUR_INDEX(b, c, v) SET_CONTEXT_FIELD(b, c, V2PUR, V2Pxx_INDEX, v)
633#define SET_V2PUR_VA(b, c, v) SET_CONTEXT_FIELD(b, c, V2PUR, V2Pxx_VA, v)
634
635#define SET_V2PPW_INDEX(b, c, v) SET_CONTEXT_FIELD(b, c, V2PPW, V2Pxx_INDEX, v)
636#define SET_V2PPW_VA(b, c, v) SET_CONTEXT_FIELD(b, c, V2PPW, V2Pxx_VA, v)
637
638#define SET_V2PPR_INDEX(b, c, v) SET_CONTEXT_FIELD(b, c, V2PPR, V2Pxx_INDEX, v)
639#define SET_V2PPR_VA(b, c, v) SET_CONTEXT_FIELD(b, c, V2PPR, V2Pxx_VA, v)
640
641
642/* Context Register getters */
643/* ACTLR */
644#define GET_CFERE(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, CFERE)
645#define GET_CFEIE(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, CFEIE)
646#define GET_PTSHCFG(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, PTSHCFG)
647#define GET_RCOSH(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, RCOSH)
648#define GET_RCISH(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, RCISH)
649#define GET_RCNSH(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, RCNSH)
650#define GET_PRIVCFG(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, PRIVCFG)
651#define GET_DNA(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, DNA)
652#define GET_DNLV2PA(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, DNLV2PA)
653#define GET_TLBMCFG(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, TLBMCFG)
654#define GET_CFCFG(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, CFCFG)
655#define GET_TIPCF(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, TIPCF)
656#define GET_V2PCFG(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, V2PCFG)
657#define GET_HUME(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, HUME)
658#define GET_PTMTCFG(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, PTMTCFG)
659#define GET_PTMEMTYPE(b, c) GET_CONTEXT_FIELD(b, c, ACTLR, PTMEMTYPE)
660
661/* BFBCR */
662#define GET_BFBDFE(b, c) GET_CONTEXT_FIELD(b, c, BFBCR, BFBDFE)
663#define GET_BFBSFE(b, c) GET_CONTEXT_FIELD(b, c, BFBCR, BFBSFE)
664#define GET_SFVS(b, c) GET_CONTEXT_FIELD(b, c, BFBCR, SFVS)
665#define GET_FLVIC(b, c) GET_CONTEXT_FIELD(b, c, BFBCR, FLVIC)
666#define GET_SLVIC(b, c) GET_CONTEXT_FIELD(b, c, BFBCR, SLVIC)
667
668
669/* CONTEXTIDR */
670#define GET_CONTEXTIDR_ASID(b, c) \
671 GET_CONTEXT_FIELD(b, c, CONTEXTIDR, CONTEXTIDR_ASID)
672#define GET_CONTEXTIDR_PROCID(b, c) GET_CONTEXT_FIELD(b, c, CONTEXTIDR, PROCID)
673
674
675/* FSR */
676#define GET_TF(b, c) GET_CONTEXT_FIELD(b, c, FSR, TF)
677#define GET_AFF(b, c) GET_CONTEXT_FIELD(b, c, FSR, AFF)
678#define GET_APF(b, c) GET_CONTEXT_FIELD(b, c, FSR, APF)
679#define GET_TLBMF(b, c) GET_CONTEXT_FIELD(b, c, FSR, TLBMF)
680#define GET_HTWDEEF(b, c) GET_CONTEXT_FIELD(b, c, FSR, HTWDEEF)
681#define GET_HTWSEEF(b, c) GET_CONTEXT_FIELD(b, c, FSR, HTWSEEF)
682#define GET_MHF(b, c) GET_CONTEXT_FIELD(b, c, FSR, MHF)
683#define GET_SL(b, c) GET_CONTEXT_FIELD(b, c, FSR, SL)
684#define GET_SS(b, c) GET_CONTEXT_FIELD(b, c, FSR, SS)
685#define GET_MULTI(b, c) GET_CONTEXT_FIELD(b, c, FSR, MULTI)
686
687
688/* FSYNR0 */
689#define GET_AMID(b, c) GET_CONTEXT_FIELD(b, c, FSYNR0, AMID)
690#define GET_APID(b, c) GET_CONTEXT_FIELD(b, c, FSYNR0, APID)
691#define GET_ABID(b, c) GET_CONTEXT_FIELD(b, c, FSYNR0, ABID)
692#define GET_ATID(b, c) GET_CONTEXT_FIELD(b, c, FSYNR0, ATID)
693
694
695/* FSYNR1 */
696#define GET_AMEMTYPE(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, AMEMTYPE)
697#define GET_ASHARED(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, ASHARED)
698#define GET_AINNERSHARED(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, AINNERSHARED)
699#define GET_APRIV(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, APRIV)
700#define GET_APROTNS(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, APROTNS)
701#define GET_AINST(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, AINST)
702#define GET_AWRITE(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, AWRITE)
703#define GET_ABURST(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, ABURST)
704#define GET_ALEN(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, ALEN)
705#define GET_FSYNR1_ASIZE(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, FSYNR1_ASIZE)
706#define GET_ALOCK(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, ALOCK)
707#define GET_AFULL(b, c) GET_CONTEXT_FIELD(b, c, FSYNR1, AFULL)
708
709
710/* NMRR */
711#define GET_ICPC0(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC0)
712#define GET_ICPC1(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC1)
713#define GET_ICPC2(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC2)
714#define GET_ICPC3(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC3)
715#define GET_ICPC4(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC4)
716#define GET_ICPC5(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC5)
717#define GET_ICPC6(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC6)
718#define GET_ICPC7(b, c) GET_CONTEXT_FIELD(b, c, NMRR, ICPC7)
719#define GET_OCPC0(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC0)
720#define GET_OCPC1(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC1)
721#define GET_OCPC2(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC2)
722#define GET_OCPC3(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC3)
723#define GET_OCPC4(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC4)
724#define GET_OCPC5(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC5)
725#define GET_OCPC6(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC6)
726#define GET_OCPC7(b, c) GET_CONTEXT_FIELD(b, c, NMRR, OCPC7)
Stepan Moskovchenko08bd6832010-11-15 18:19:35 -0800727#define NMRR_ICP(nmrr, n) (((nmrr) & (3 << ((n) * 2))) >> ((n) * 2))
728#define NMRR_OCP(nmrr, n) (((nmrr) & (3 << ((n) * 2 + 16))) >> \
729 ((n) * 2 + 16))
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -0700730
731/* PAR */
732#define GET_FAULT(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT)
733
734#define GET_FAULT_TF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_TF)
735#define GET_FAULT_AFF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_AFF)
736#define GET_FAULT_APF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_APF)
737#define GET_FAULT_TLBMF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_TLBMF)
738#define GET_FAULT_HTWDEEF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWDEEF)
739#define GET_FAULT_HTWSEEF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWSEEF)
740#define GET_FAULT_MHF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_MHF)
741#define GET_FAULT_SL(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_SL)
742#define GET_FAULT_SS(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_SS)
743
744#define GET_NOFAULT_SS(b, c) GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_SS)
745#define GET_NOFAULT_MT(b, c) GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_MT)
746#define GET_NOFAULT_SH(b, c) GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_SH)
747#define GET_NOFAULT_NS(b, c) GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_NS)
748#define GET_NOFAULT_NOS(b, c) GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_NOS)
749#define GET_NPFAULT_PA(b, c) GET_CONTEXT_FIELD(b, c, PAR, PAR_NPFAULT_PA)
750
751
752/* PRRR */
753#define GET_MTC0(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC0)
754#define GET_MTC1(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC1)
755#define GET_MTC2(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC2)
756#define GET_MTC3(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC3)
757#define GET_MTC4(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC4)
758#define GET_MTC5(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC5)
759#define GET_MTC6(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC6)
760#define GET_MTC7(b, c) GET_CONTEXT_FIELD(b, c, PRRR, MTC7)
761#define GET_SHDSH0(b, c) GET_CONTEXT_FIELD(b, c, PRRR, SHDSH0)
762#define GET_SHDSH1(b, c) GET_CONTEXT_FIELD(b, c, PRRR, SHDSH1)
763#define GET_SHNMSH0(b, c) GET_CONTEXT_FIELD(b, c, PRRR, SHNMSH0)
764#define GET_SHNMSH1(b, c) GET_CONTEXT_FIELD(b, c, PRRR, SHNMSH1)
765#define GET_NOS0(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS0)
766#define GET_NOS1(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS1)
767#define GET_NOS2(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS2)
768#define GET_NOS3(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS3)
769#define GET_NOS4(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS4)
770#define GET_NOS5(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS5)
771#define GET_NOS6(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS6)
772#define GET_NOS7(b, c) GET_CONTEXT_FIELD(b, c, PRRR, NOS7)
Stepan Moskovchenko08bd6832010-11-15 18:19:35 -0800773#define PRRR_NOS(prrr, n) ((prrr) & (1 << ((n) + 24)) ? 1 : 0)
774#define PRRR_MT(prrr, n) ((((prrr) & (3 << ((n) * 2))) >> ((n) * 2)))
Stepan Moskovchenko0720d1f2010-08-24 18:31:10 -0700775
776
777/* RESUME */
778#define GET_TNR(b, c) GET_CONTEXT_FIELD(b, c, RESUME, TNR)
779
780
781/* SCTLR */
782#define GET_M(b, c) GET_CONTEXT_FIELD(b, c, SCTLR, M)
783#define GET_TRE(b, c) GET_CONTEXT_FIELD(b, c, SCTLR, TRE)
784#define GET_AFE(b, c) GET_CONTEXT_FIELD(b, c, SCTLR, AFE)
785#define GET_HAF(b, c) GET_CONTEXT_FIELD(b, c, SCTLR, HAF)
786#define GET_BE(b, c) GET_CONTEXT_FIELD(b, c, SCTLR, BE)
787#define GET_AFFD(b, c) GET_CONTEXT_FIELD(b, c, SCTLR, AFFD)
788
789
790/* TLBLKCR */
791#define GET_LKE(b, c) GET_CONTEXT_FIELD(b, c, TLBLKCR, LKE)
792#define GET_TLBLCKR_TLBIALLCFG(b, c) \
793 GET_CONTEXT_FIELD(b, c, TLBLKCR, TLBLCKR_TLBIALLCFG)
794#define GET_TLBIASIDCFG(b, c) GET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIASIDCFG)
795#define GET_TLBIVAACFG(b, c) GET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIVAACFG)
796#define GET_FLOOR(b, c) GET_CONTEXT_FIELD(b, c, TLBLKCR, FLOOR)
797#define GET_VICTIM(b, c) GET_CONTEXT_FIELD(b, c, TLBLKCR, VICTIM)
798
799
800/* TTBCR */
801#define GET_N(b, c) GET_CONTEXT_FIELD(b, c, TTBCR, N)
802#define GET_PD0(b, c) GET_CONTEXT_FIELD(b, c, TTBCR, PD0)
803#define GET_PD1(b, c) GET_CONTEXT_FIELD(b, c, TTBCR, PD1)
804
805
806/* TTBR0 */
807#define GET_TTBR0_IRGNH(b, c) GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNH)
808#define GET_TTBR0_SH(b, c) GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_SH)
809#define GET_TTBR0_ORGN(b, c) GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_ORGN)
810#define GET_TTBR0_NOS(b, c) GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_NOS)
811#define GET_TTBR0_IRGNL(b, c) GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNL)
812#define GET_TTBR0_PA(b, c) GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_PA)
813
814
815/* TTBR1 */
816#define GET_TTBR1_IRGNH(b, c) GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNH)
817#define GET_TTBR1_SH(b, c) GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_SH)
818#define GET_TTBR1_ORGN(b, c) GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_ORGN)
819#define GET_TTBR1_NOS(b, c) GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_NOS)
820#define GET_TTBR1_IRGNL(b, c) GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNL)
821#define GET_TTBR1_PA(b, c) GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_PA)
822
823
824/* V2PSR */
825#define GET_HIT(b, c) GET_CONTEXT_FIELD(b, c, V2PSR, HIT)
826#define GET_INDEX(b, c) GET_CONTEXT_FIELD(b, c, V2PSR, INDEX)
827
828
829/* V2Pxx UW UR PW PR */
830#define GET_V2PUW_INDEX(b, c) GET_CONTEXT_FIELD(b, c, V2PUW, V2Pxx_INDEX)
831#define GET_V2PUW_VA(b, c) GET_CONTEXT_FIELD(b, c, V2PUW, V2Pxx_VA)
832
833#define GET_V2PUR_INDEX(b, c) GET_CONTEXT_FIELD(b, c, V2PUR, V2Pxx_INDEX)
834#define GET_V2PUR_VA(b, c) GET_CONTEXT_FIELD(b, c, V2PUR, V2Pxx_VA)
835
836#define GET_V2PPW_INDEX(b, c) GET_CONTEXT_FIELD(b, c, V2PPW, V2Pxx_INDEX)
837#define GET_V2PPW_VA(b, c) GET_CONTEXT_FIELD(b, c, V2PPW, V2Pxx_VA)
838
839#define GET_V2PPR_INDEX(b, c) GET_CONTEXT_FIELD(b, c, V2PPR, V2Pxx_INDEX)
840#define GET_V2PPR_VA(b, c) GET_CONTEXT_FIELD(b, c, V2PPR, V2Pxx_VA)
841
842
843/* Global Registers */
844#define M2VCBR_N (0xFF000)
845#define CBACR_N (0xFF800)
846#define TLBRSW (0xFFE00)
847#define TLBTR0 (0xFFE80)
848#define TLBTR1 (0xFFE84)
849#define TLBTR2 (0xFFE88)
850#define TESTBUSCR (0xFFE8C)
851#define GLOBAL_TLBIALL (0xFFF00)
852#define TLBIVMID (0xFFF04)
853#define CR (0xFFF80)
854#define EAR (0xFFF84)
855#define ESR (0xFFF88)
856#define ESRRESTORE (0xFFF8C)
857#define ESYNR0 (0xFFF90)
858#define ESYNR1 (0xFFF94)
859#define REV (0xFFFF4)
860#define IDR (0xFFFF8)
861#define RPU_ACR (0xFFFFC)
862
863
864/* Context Bank Registers */
865#define SCTLR (0x000)
866#define ACTLR (0x004)
867#define CONTEXTIDR (0x008)
868#define TTBR0 (0x010)
869#define TTBR1 (0x014)
870#define TTBCR (0x018)
871#define PAR (0x01C)
872#define FSR (0x020)
873#define FSRRESTORE (0x024)
874#define FAR (0x028)
875#define FSYNR0 (0x02C)
876#define FSYNR1 (0x030)
877#define PRRR (0x034)
878#define NMRR (0x038)
879#define TLBLCKR (0x03C)
880#define V2PSR (0x040)
881#define TLBFLPTER (0x044)
882#define TLBSLPTER (0x048)
883#define BFBCR (0x04C)
884#define CTX_TLBIALL (0x800)
885#define TLBIASID (0x804)
886#define TLBIVA (0x808)
887#define TLBIVAA (0x80C)
888#define V2PPR (0x810)
889#define V2PPW (0x814)
890#define V2PUR (0x818)
891#define V2PUW (0x81C)
892#define RESUME (0x820)
893
894
895/* Global Register Fields */
896/* CBACRn */
897#define RWVMID (RWVMID_MASK << RWVMID_SHIFT)
898#define RWE (RWE_MASK << RWE_SHIFT)
899#define RWGE (RWGE_MASK << RWGE_SHIFT)
900#define CBVMID (CBVMID_MASK << CBVMID_SHIFT)
901#define IRPTNDX (IRPTNDX_MASK << IRPTNDX_SHIFT)
902
903
904/* CR */
905#define RPUE (RPUE_MASK << RPUE_SHIFT)
906#define RPUERE (RPUERE_MASK << RPUERE_SHIFT)
907#define RPUEIE (RPUEIE_MASK << RPUEIE_SHIFT)
908#define DCDEE (DCDEE_MASK << DCDEE_SHIFT)
909#define CLIENTPD (CLIENTPD_MASK << CLIENTPD_SHIFT)
910#define STALLD (STALLD_MASK << STALLD_SHIFT)
911#define TLBLKCRWE (TLBLKCRWE_MASK << TLBLKCRWE_SHIFT)
912#define CR_TLBIALLCFG (CR_TLBIALLCFG_MASK << CR_TLBIALLCFG_SHIFT)
913#define TLBIVMIDCFG (TLBIVMIDCFG_MASK << TLBIVMIDCFG_SHIFT)
914#define CR_HUME (CR_HUME_MASK << CR_HUME_SHIFT)
915
916
917/* ESR */
918#define CFG (CFG_MASK << CFG_SHIFT)
919#define BYPASS (BYPASS_MASK << BYPASS_SHIFT)
920#define ESR_MULTI (ESR_MULTI_MASK << ESR_MULTI_SHIFT)
921
922
923/* ESYNR0 */
924#define ESYNR0_AMID (ESYNR0_AMID_MASK << ESYNR0_AMID_SHIFT)
925#define ESYNR0_APID (ESYNR0_APID_MASK << ESYNR0_APID_SHIFT)
926#define ESYNR0_ABID (ESYNR0_ABID_MASK << ESYNR0_ABID_SHIFT)
927#define ESYNR0_AVMID (ESYNR0_AVMID_MASK << ESYNR0_AVMID_SHIFT)
928#define ESYNR0_ATID (ESYNR0_ATID_MASK << ESYNR0_ATID_SHIFT)
929
930
931/* ESYNR1 */
932#define ESYNR1_AMEMTYPE (ESYNR1_AMEMTYPE_MASK << ESYNR1_AMEMTYPE_SHIFT)
933#define ESYNR1_ASHARED (ESYNR1_ASHARED_MASK << ESYNR1_ASHARED_SHIFT)
934#define ESYNR1_AINNERSHARED (ESYNR1_AINNERSHARED_MASK<< \
935 ESYNR1_AINNERSHARED_SHIFT)
936#define ESYNR1_APRIV (ESYNR1_APRIV_MASK << ESYNR1_APRIV_SHIFT)
937#define ESYNR1_APROTNS (ESYNR1_APROTNS_MASK << ESYNR1_APROTNS_SHIFT)
938#define ESYNR1_AINST (ESYNR1_AINST_MASK << ESYNR1_AINST_SHIFT)
939#define ESYNR1_AWRITE (ESYNR1_AWRITE_MASK << ESYNR1_AWRITE_SHIFT)
940#define ESYNR1_ABURST (ESYNR1_ABURST_MASK << ESYNR1_ABURST_SHIFT)
941#define ESYNR1_ALEN (ESYNR1_ALEN_MASK << ESYNR1_ALEN_SHIFT)
942#define ESYNR1_ASIZE (ESYNR1_ASIZE_MASK << ESYNR1_ASIZE_SHIFT)
943#define ESYNR1_ALOCK (ESYNR1_ALOCK_MASK << ESYNR1_ALOCK_SHIFT)
944#define ESYNR1_AOOO (ESYNR1_AOOO_MASK << ESYNR1_AOOO_SHIFT)
945#define ESYNR1_AFULL (ESYNR1_AFULL_MASK << ESYNR1_AFULL_SHIFT)
946#define ESYNR1_AC (ESYNR1_AC_MASK << ESYNR1_AC_SHIFT)
947#define ESYNR1_DCD (ESYNR1_DCD_MASK << ESYNR1_DCD_SHIFT)
948
949
950/* IDR */
951#define NM2VCBMT (NM2VCBMT_MASK << NM2VCBMT_SHIFT)
952#define HTW (HTW_MASK << HTW_SHIFT)
953#define HUM (HUM_MASK << HUM_SHIFT)
954#define TLBSIZE (TLBSIZE_MASK << TLBSIZE_SHIFT)
955#define NCB (NCB_MASK << NCB_SHIFT)
956#define NIRPT (NIRPT_MASK << NIRPT_SHIFT)
957
958
959/* M2VCBRn */
960#define VMID (VMID_MASK << VMID_SHIFT)
961#define CBNDX (CBNDX_MASK << CBNDX_SHIFT)
962#define BYPASSD (BYPASSD_MASK << BYPASSD_SHIFT)
963#define BPRCOSH (BPRCOSH_MASK << BPRCOSH_SHIFT)
964#define BPRCISH (BPRCISH_MASK << BPRCISH_SHIFT)
965#define BPRCNSH (BPRCNSH_MASK << BPRCNSH_SHIFT)
966#define BPSHCFG (BPSHCFG_MASK << BPSHCFG_SHIFT)
967#define NSCFG (NSCFG_MASK << NSCFG_SHIFT)
968#define BPMTCFG (BPMTCFG_MASK << BPMTCFG_SHIFT)
969#define BPMEMTYPE (BPMEMTYPE_MASK << BPMEMTYPE_SHIFT)
970
971
972/* REV */
973#define IDR_MINOR (MINOR_MASK << MINOR_SHIFT)
974#define IDR_MAJOR (MAJOR_MASK << MAJOR_SHIFT)
975
976
977/* TESTBUSCR */
978#define TBE (TBE_MASK << TBE_SHIFT)
979#define SPDMBE (SPDMBE_MASK << SPDMBE_SHIFT)
980#define WGSEL (WGSEL_MASK << WGSEL_SHIFT)
981#define TBLSEL (TBLSEL_MASK << TBLSEL_SHIFT)
982#define TBHSEL (TBHSEL_MASK << TBHSEL_SHIFT)
983#define SPDM0SEL (SPDM0SEL_MASK << SPDM0SEL_SHIFT)
984#define SPDM1SEL (SPDM1SEL_MASK << SPDM1SEL_SHIFT)
985#define SPDM2SEL (SPDM2SEL_MASK << SPDM2SEL_SHIFT)
986#define SPDM3SEL (SPDM3SEL_MASK << SPDM3SEL_SHIFT)
987
988
989/* TLBIVMID */
990#define TLBIVMID_VMID (TLBIVMID_VMID_MASK << TLBIVMID_VMID_SHIFT)
991
992
993/* TLBRSW */
994#define TLBRSW_INDEX (TLBRSW_INDEX_MASK << TLBRSW_INDEX_SHIFT)
995#define TLBBFBS (TLBBFBS_MASK << TLBBFBS_SHIFT)
996
997
998/* TLBTR0 */
999#define PR (PR_MASK << PR_SHIFT)
1000#define PW (PW_MASK << PW_SHIFT)
1001#define UR (UR_MASK << UR_SHIFT)
1002#define UW (UW_MASK << UW_SHIFT)
1003#define XN (XN_MASK << XN_SHIFT)
1004#define NSDESC (NSDESC_MASK << NSDESC_SHIFT)
1005#define ISH (ISH_MASK << ISH_SHIFT)
1006#define SH (SH_MASK << SH_SHIFT)
1007#define MT (MT_MASK << MT_SHIFT)
1008#define DPSIZR (DPSIZR_MASK << DPSIZR_SHIFT)
1009#define DPSIZC (DPSIZC_MASK << DPSIZC_SHIFT)
1010
1011
1012/* TLBTR1 */
1013#define TLBTR1_VMID (TLBTR1_VMID_MASK << TLBTR1_VMID_SHIFT)
1014#define TLBTR1_PA (TLBTR1_PA_MASK << TLBTR1_PA_SHIFT)
1015
1016
1017/* TLBTR2 */
1018#define TLBTR2_ASID (TLBTR2_ASID_MASK << TLBTR2_ASID_SHIFT)
1019#define TLBTR2_V (TLBTR2_V_MASK << TLBTR2_V_SHIFT)
1020#define TLBTR2_NSTID (TLBTR2_NSTID_MASK << TLBTR2_NSTID_SHIFT)
1021#define TLBTR2_NV (TLBTR2_NV_MASK << TLBTR2_NV_SHIFT)
1022#define TLBTR2_VA (TLBTR2_VA_MASK << TLBTR2_VA_SHIFT)
1023
1024
1025/* Context Register Fields */
1026/* ACTLR */
1027#define CFERE (CFERE_MASK << CFERE_SHIFT)
1028#define CFEIE (CFEIE_MASK << CFEIE_SHIFT)
1029#define PTSHCFG (PTSHCFG_MASK << PTSHCFG_SHIFT)
1030#define RCOSH (RCOSH_MASK << RCOSH_SHIFT)
1031#define RCISH (RCISH_MASK << RCISH_SHIFT)
1032#define RCNSH (RCNSH_MASK << RCNSH_SHIFT)
1033#define PRIVCFG (PRIVCFG_MASK << PRIVCFG_SHIFT)
1034#define DNA (DNA_MASK << DNA_SHIFT)
1035#define DNLV2PA (DNLV2PA_MASK << DNLV2PA_SHIFT)
1036#define TLBMCFG (TLBMCFG_MASK << TLBMCFG_SHIFT)
1037#define CFCFG (CFCFG_MASK << CFCFG_SHIFT)
1038#define TIPCF (TIPCF_MASK << TIPCF_SHIFT)
1039#define V2PCFG (V2PCFG_MASK << V2PCFG_SHIFT)
1040#define HUME (HUME_MASK << HUME_SHIFT)
1041#define PTMTCFG (PTMTCFG_MASK << PTMTCFG_SHIFT)
1042#define PTMEMTYPE (PTMEMTYPE_MASK << PTMEMTYPE_SHIFT)
1043
1044
1045/* BFBCR */
1046#define BFBDFE (BFBDFE_MASK << BFBDFE_SHIFT)
1047#define BFBSFE (BFBSFE_MASK << BFBSFE_SHIFT)
1048#define SFVS (SFVS_MASK << SFVS_SHIFT)
1049#define FLVIC (FLVIC_MASK << FLVIC_SHIFT)
1050#define SLVIC (SLVIC_MASK << SLVIC_SHIFT)
1051
1052
1053/* CONTEXTIDR */
1054#define CONTEXTIDR_ASID (CONTEXTIDR_ASID_MASK << CONTEXTIDR_ASID_SHIFT)
1055#define PROCID (PROCID_MASK << PROCID_SHIFT)
1056
1057
1058/* FSR */
1059#define TF (TF_MASK << TF_SHIFT)
1060#define AFF (AFF_MASK << AFF_SHIFT)
1061#define APF (APF_MASK << APF_SHIFT)
1062#define TLBMF (TLBMF_MASK << TLBMF_SHIFT)
1063#define HTWDEEF (HTWDEEF_MASK << HTWDEEF_SHIFT)
1064#define HTWSEEF (HTWSEEF_MASK << HTWSEEF_SHIFT)
1065#define MHF (MHF_MASK << MHF_SHIFT)
1066#define SL (SL_MASK << SL_SHIFT)
1067#define SS (SS_MASK << SS_SHIFT)
1068#define MULTI (MULTI_MASK << MULTI_SHIFT)
1069
1070
1071/* FSYNR0 */
1072#define AMID (AMID_MASK << AMID_SHIFT)
1073#define APID (APID_MASK << APID_SHIFT)
1074#define ABID (ABID_MASK << ABID_SHIFT)
1075#define ATID (ATID_MASK << ATID_SHIFT)
1076
1077
1078/* FSYNR1 */
1079#define AMEMTYPE (AMEMTYPE_MASK << AMEMTYPE_SHIFT)
1080#define ASHARED (ASHARED_MASK << ASHARED_SHIFT)
1081#define AINNERSHARED (AINNERSHARED_MASK << AINNERSHARED_SHIFT)
1082#define APRIV (APRIV_MASK << APRIV_SHIFT)
1083#define APROTNS (APROTNS_MASK << APROTNS_SHIFT)
1084#define AINST (AINST_MASK << AINST_SHIFT)
1085#define AWRITE (AWRITE_MASK << AWRITE_SHIFT)
1086#define ABURST (ABURST_MASK << ABURST_SHIFT)
1087#define ALEN (ALEN_MASK << ALEN_SHIFT)
1088#define FSYNR1_ASIZE (FSYNR1_ASIZE_MASK << FSYNR1_ASIZE_SHIFT)
1089#define ALOCK (ALOCK_MASK << ALOCK_SHIFT)
1090#define AFULL (AFULL_MASK << AFULL_SHIFT)
1091
1092
1093/* NMRR */
1094#define ICPC0 (ICPC0_MASK << ICPC0_SHIFT)
1095#define ICPC1 (ICPC1_MASK << ICPC1_SHIFT)
1096#define ICPC2 (ICPC2_MASK << ICPC2_SHIFT)
1097#define ICPC3 (ICPC3_MASK << ICPC3_SHIFT)
1098#define ICPC4 (ICPC4_MASK << ICPC4_SHIFT)
1099#define ICPC5 (ICPC5_MASK << ICPC5_SHIFT)
1100#define ICPC6 (ICPC6_MASK << ICPC6_SHIFT)
1101#define ICPC7 (ICPC7_MASK << ICPC7_SHIFT)
1102#define OCPC0 (OCPC0_MASK << OCPC0_SHIFT)
1103#define OCPC1 (OCPC1_MASK << OCPC1_SHIFT)
1104#define OCPC2 (OCPC2_MASK << OCPC2_SHIFT)
1105#define OCPC3 (OCPC3_MASK << OCPC3_SHIFT)
1106#define OCPC4 (OCPC4_MASK << OCPC4_SHIFT)
1107#define OCPC5 (OCPC5_MASK << OCPC5_SHIFT)
1108#define OCPC6 (OCPC6_MASK << OCPC6_SHIFT)
1109#define OCPC7 (OCPC7_MASK << OCPC7_SHIFT)
1110
1111
1112/* PAR */
1113#define FAULT (FAULT_MASK << FAULT_SHIFT)
1114/* If a fault is present, these are the
1115same as the fault fields in the FAR */
1116#define FAULT_TF (FAULT_TF_MASK << FAULT_TF_SHIFT)
1117#define FAULT_AFF (FAULT_AFF_MASK << FAULT_AFF_SHIFT)
1118#define FAULT_APF (FAULT_APF_MASK << FAULT_APF_SHIFT)
1119#define FAULT_TLBMF (FAULT_TLBMF_MASK << FAULT_TLBMF_SHIFT)
1120#define FAULT_HTWDEEF (FAULT_HTWDEEF_MASK << FAULT_HTWDEEF_SHIFT)
1121#define FAULT_HTWSEEF (FAULT_HTWSEEF_MASK << FAULT_HTWSEEF_SHIFT)
1122#define FAULT_MHF (FAULT_MHF_MASK << FAULT_MHF_SHIFT)
1123#define FAULT_SL (FAULT_SL_MASK << FAULT_SL_SHIFT)
1124#define FAULT_SS (FAULT_SS_MASK << FAULT_SS_SHIFT)
1125
1126/* If NO fault is present, the following fields are in effect */
1127/* (FAULT remains as before) */
1128#define PAR_NOFAULT_SS (PAR_NOFAULT_SS_MASK << PAR_NOFAULT_SS_SHIFT)
1129#define PAR_NOFAULT_MT (PAR_NOFAULT_MT_MASK << PAR_NOFAULT_MT_SHIFT)
1130#define PAR_NOFAULT_SH (PAR_NOFAULT_SH_MASK << PAR_NOFAULT_SH_SHIFT)
1131#define PAR_NOFAULT_NS (PAR_NOFAULT_NS_MASK << PAR_NOFAULT_NS_SHIFT)
1132#define PAR_NOFAULT_NOS (PAR_NOFAULT_NOS_MASK << PAR_NOFAULT_NOS_SHIFT)
1133#define PAR_NPFAULT_PA (PAR_NPFAULT_PA_MASK << PAR_NPFAULT_PA_SHIFT)
1134
1135
1136/* PRRR */
1137#define MTC0 (MTC0_MASK << MTC0_SHIFT)
1138#define MTC1 (MTC1_MASK << MTC1_SHIFT)
1139#define MTC2 (MTC2_MASK << MTC2_SHIFT)
1140#define MTC3 (MTC3_MASK << MTC3_SHIFT)
1141#define MTC4 (MTC4_MASK << MTC4_SHIFT)
1142#define MTC5 (MTC5_MASK << MTC5_SHIFT)
1143#define MTC6 (MTC6_MASK << MTC6_SHIFT)
1144#define MTC7 (MTC7_MASK << MTC7_SHIFT)
1145#define SHDSH0 (SHDSH0_MASK << SHDSH0_SHIFT)
1146#define SHDSH1 (SHDSH1_MASK << SHDSH1_SHIFT)
1147#define SHNMSH0 (SHNMSH0_MASK << SHNMSH0_SHIFT)
1148#define SHNMSH1 (SHNMSH1_MASK << SHNMSH1_SHIFT)
1149#define NOS0 (NOS0_MASK << NOS0_SHIFT)
1150#define NOS1 (NOS1_MASK << NOS1_SHIFT)
1151#define NOS2 (NOS2_MASK << NOS2_SHIFT)
1152#define NOS3 (NOS3_MASK << NOS3_SHIFT)
1153#define NOS4 (NOS4_MASK << NOS4_SHIFT)
1154#define NOS5 (NOS5_MASK << NOS5_SHIFT)
1155#define NOS6 (NOS6_MASK << NOS6_SHIFT)
1156#define NOS7 (NOS7_MASK << NOS7_SHIFT)
1157
1158
1159/* RESUME */
1160#define TNR (TNR_MASK << TNR_SHIFT)
1161
1162
1163/* SCTLR */
1164#define M (M_MASK << M_SHIFT)
1165#define TRE (TRE_MASK << TRE_SHIFT)
1166#define AFE (AFE_MASK << AFE_SHIFT)
1167#define HAF (HAF_MASK << HAF_SHIFT)
1168#define BE (BE_MASK << BE_SHIFT)
1169#define AFFD (AFFD_MASK << AFFD_SHIFT)
1170
1171
1172/* TLBIASID */
1173#define TLBIASID_ASID (TLBIASID_ASID_MASK << TLBIASID_ASID_SHIFT)
1174
1175
1176/* TLBIVA */
1177#define TLBIVA_ASID (TLBIVA_ASID_MASK << TLBIVA_ASID_SHIFT)
1178#define TLBIVA_VA (TLBIVA_VA_MASK << TLBIVA_VA_SHIFT)
1179
1180
1181/* TLBIVAA */
1182#define TLBIVAA_VA (TLBIVAA_VA_MASK << TLBIVAA_VA_SHIFT)
1183
1184
1185/* TLBLCKR */
1186#define LKE (LKE_MASK << LKE_SHIFT)
1187#define TLBLCKR_TLBIALLCFG (TLBLCKR_TLBIALLCFG_MASK<<TLBLCKR_TLBIALLCFG_SHIFT)
1188#define TLBIASIDCFG (TLBIASIDCFG_MASK << TLBIASIDCFG_SHIFT)
1189#define TLBIVAACFG (TLBIVAACFG_MASK << TLBIVAACFG_SHIFT)
1190#define FLOOR (FLOOR_MASK << FLOOR_SHIFT)
1191#define VICTIM (VICTIM_MASK << VICTIM_SHIFT)
1192
1193
1194/* TTBCR */
1195#define N (N_MASK << N_SHIFT)
1196#define PD0 (PD0_MASK << PD0_SHIFT)
1197#define PD1 (PD1_MASK << PD1_SHIFT)
1198
1199
1200/* TTBR0 */
1201#define TTBR0_IRGNH (TTBR0_IRGNH_MASK << TTBR0_IRGNH_SHIFT)
1202#define TTBR0_SH (TTBR0_SH_MASK << TTBR0_SH_SHIFT)
1203#define TTBR0_ORGN (TTBR0_ORGN_MASK << TTBR0_ORGN_SHIFT)
1204#define TTBR0_NOS (TTBR0_NOS_MASK << TTBR0_NOS_SHIFT)
1205#define TTBR0_IRGNL (TTBR0_IRGNL_MASK << TTBR0_IRGNL_SHIFT)
1206#define TTBR0_PA (TTBR0_PA_MASK << TTBR0_PA_SHIFT)
1207
1208
1209/* TTBR1 */
1210#define TTBR1_IRGNH (TTBR1_IRGNH_MASK << TTBR1_IRGNH_SHIFT)
1211#define TTBR1_SH (TTBR1_SH_MASK << TTBR1_SH_SHIFT)
1212#define TTBR1_ORGN (TTBR1_ORGN_MASK << TTBR1_ORGN_SHIFT)
1213#define TTBR1_NOS (TTBR1_NOS_MASK << TTBR1_NOS_SHIFT)
1214#define TTBR1_IRGNL (TTBR1_IRGNL_MASK << TTBR1_IRGNL_SHIFT)
1215#define TTBR1_PA (TTBR1_PA_MASK << TTBR1_PA_SHIFT)
1216
1217
1218/* V2PSR */
1219#define HIT (HIT_MASK << HIT_SHIFT)
1220#define INDEX (INDEX_MASK << INDEX_SHIFT)
1221
1222
1223/* V2Pxx */
1224#define V2Pxx_INDEX (V2Pxx_INDEX_MASK << V2Pxx_INDEX_SHIFT)
1225#define V2Pxx_VA (V2Pxx_VA_MASK << V2Pxx_VA_SHIFT)
1226
1227
1228/* Global Register Masks */
1229/* CBACRn */
1230#define RWVMID_MASK 0x1F
1231#define RWE_MASK 0x01
1232#define RWGE_MASK 0x01
1233#define CBVMID_MASK 0x1F
1234#define IRPTNDX_MASK 0xFF
1235
1236
1237/* CR */
1238#define RPUE_MASK 0x01
1239#define RPUERE_MASK 0x01
1240#define RPUEIE_MASK 0x01
1241#define DCDEE_MASK 0x01
1242#define CLIENTPD_MASK 0x01
1243#define STALLD_MASK 0x01
1244#define TLBLKCRWE_MASK 0x01
1245#define CR_TLBIALLCFG_MASK 0x01
1246#define TLBIVMIDCFG_MASK 0x01
1247#define CR_HUME_MASK 0x01
1248
1249
1250/* ESR */
1251#define CFG_MASK 0x01
1252#define BYPASS_MASK 0x01
1253#define ESR_MULTI_MASK 0x01
1254
1255
1256/* ESYNR0 */
1257#define ESYNR0_AMID_MASK 0xFF
1258#define ESYNR0_APID_MASK 0x1F
1259#define ESYNR0_ABID_MASK 0x07
1260#define ESYNR0_AVMID_MASK 0x1F
1261#define ESYNR0_ATID_MASK 0xFF
1262
1263
1264/* ESYNR1 */
1265#define ESYNR1_AMEMTYPE_MASK 0x07
1266#define ESYNR1_ASHARED_MASK 0x01
1267#define ESYNR1_AINNERSHARED_MASK 0x01
1268#define ESYNR1_APRIV_MASK 0x01
1269#define ESYNR1_APROTNS_MASK 0x01
1270#define ESYNR1_AINST_MASK 0x01
1271#define ESYNR1_AWRITE_MASK 0x01
1272#define ESYNR1_ABURST_MASK 0x01
1273#define ESYNR1_ALEN_MASK 0x0F
1274#define ESYNR1_ASIZE_MASK 0x01
1275#define ESYNR1_ALOCK_MASK 0x03
1276#define ESYNR1_AOOO_MASK 0x01
1277#define ESYNR1_AFULL_MASK 0x01
1278#define ESYNR1_AC_MASK 0x01
1279#define ESYNR1_DCD_MASK 0x01
1280
1281
1282/* IDR */
1283#define NM2VCBMT_MASK 0x1FF
1284#define HTW_MASK 0x01
1285#define HUM_MASK 0x01
1286#define TLBSIZE_MASK 0x0F
1287#define NCB_MASK 0xFF
1288#define NIRPT_MASK 0xFF
1289
1290
1291/* M2VCBRn */
1292#define VMID_MASK 0x1F
1293#define CBNDX_MASK 0xFF
1294#define BYPASSD_MASK 0x01
1295#define BPRCOSH_MASK 0x01
1296#define BPRCISH_MASK 0x01
1297#define BPRCNSH_MASK 0x01
1298#define BPSHCFG_MASK 0x03
1299#define NSCFG_MASK 0x03
1300#define BPMTCFG_MASK 0x01
1301#define BPMEMTYPE_MASK 0x07
1302
1303
1304/* REV */
1305#define MINOR_MASK 0x0F
1306#define MAJOR_MASK 0x0F
1307
1308
1309/* TESTBUSCR */
1310#define TBE_MASK 0x01
1311#define SPDMBE_MASK 0x01
1312#define WGSEL_MASK 0x03
1313#define TBLSEL_MASK 0x03
1314#define TBHSEL_MASK 0x03
1315#define SPDM0SEL_MASK 0x0F
1316#define SPDM1SEL_MASK 0x0F
1317#define SPDM2SEL_MASK 0x0F
1318#define SPDM3SEL_MASK 0x0F
1319
1320
1321/* TLBIMID */
1322#define TLBIVMID_VMID_MASK 0x1F
1323
1324
1325/* TLBRSW */
1326#define TLBRSW_INDEX_MASK 0xFF
1327#define TLBBFBS_MASK 0x03
1328
1329
1330/* TLBTR0 */
1331#define PR_MASK 0x01
1332#define PW_MASK 0x01
1333#define UR_MASK 0x01
1334#define UW_MASK 0x01
1335#define XN_MASK 0x01
1336#define NSDESC_MASK 0x01
1337#define ISH_MASK 0x01
1338#define SH_MASK 0x01
1339#define MT_MASK 0x07
1340#define DPSIZR_MASK 0x07
1341#define DPSIZC_MASK 0x07
1342
1343
1344/* TLBTR1 */
1345#define TLBTR1_VMID_MASK 0x1F
1346#define TLBTR1_PA_MASK 0x000FFFFF
1347
1348
1349/* TLBTR2 */
1350#define TLBTR2_ASID_MASK 0xFF
1351#define TLBTR2_V_MASK 0x01
1352#define TLBTR2_NSTID_MASK 0x01
1353#define TLBTR2_NV_MASK 0x01
1354#define TLBTR2_VA_MASK 0x000FFFFF
1355
1356
1357/* Global Register Shifts */
1358/* CBACRn */
1359#define RWVMID_SHIFT 0
1360#define RWE_SHIFT 8
1361#define RWGE_SHIFT 9
1362#define CBVMID_SHIFT 16
1363#define IRPTNDX_SHIFT 24
1364
1365
1366/* CR */
1367#define RPUE_SHIFT 0
1368#define RPUERE_SHIFT 1
1369#define RPUEIE_SHIFT 2
1370#define DCDEE_SHIFT 3
1371#define CLIENTPD_SHIFT 4
1372#define STALLD_SHIFT 5
1373#define TLBLKCRWE_SHIFT 6
1374#define CR_TLBIALLCFG_SHIFT 7
1375#define TLBIVMIDCFG_SHIFT 8
1376#define CR_HUME_SHIFT 9
1377
1378
1379/* ESR */
1380#define CFG_SHIFT 0
1381#define BYPASS_SHIFT 1
1382#define ESR_MULTI_SHIFT 31
1383
1384
1385/* ESYNR0 */
1386#define ESYNR0_AMID_SHIFT 0
1387#define ESYNR0_APID_SHIFT 8
1388#define ESYNR0_ABID_SHIFT 13
1389#define ESYNR0_AVMID_SHIFT 16
1390#define ESYNR0_ATID_SHIFT 24
1391
1392
1393/* ESYNR1 */
1394#define ESYNR1_AMEMTYPE_SHIFT 0
1395#define ESYNR1_ASHARED_SHIFT 3
1396#define ESYNR1_AINNERSHARED_SHIFT 4
1397#define ESYNR1_APRIV_SHIFT 5
1398#define ESYNR1_APROTNS_SHIFT 6
1399#define ESYNR1_AINST_SHIFT 7
1400#define ESYNR1_AWRITE_SHIFT 8
1401#define ESYNR1_ABURST_SHIFT 10
1402#define ESYNR1_ALEN_SHIFT 12
1403#define ESYNR1_ASIZE_SHIFT 16
1404#define ESYNR1_ALOCK_SHIFT 20
1405#define ESYNR1_AOOO_SHIFT 22
1406#define ESYNR1_AFULL_SHIFT 24
1407#define ESYNR1_AC_SHIFT 30
1408#define ESYNR1_DCD_SHIFT 31
1409
1410
1411/* IDR */
1412#define NM2VCBMT_SHIFT 0
1413#define HTW_SHIFT 9
1414#define HUM_SHIFT 10
1415#define TLBSIZE_SHIFT 12
1416#define NCB_SHIFT 16
1417#define NIRPT_SHIFT 24
1418
1419
1420/* M2VCBRn */
1421#define VMID_SHIFT 0
1422#define CBNDX_SHIFT 8
1423#define BYPASSD_SHIFT 16
1424#define BPRCOSH_SHIFT 17
1425#define BPRCISH_SHIFT 18
1426#define BPRCNSH_SHIFT 19
1427#define BPSHCFG_SHIFT 20
1428#define NSCFG_SHIFT 22
1429#define BPMTCFG_SHIFT 24
1430#define BPMEMTYPE_SHIFT 25
1431
1432
1433/* REV */
1434#define MINOR_SHIFT 0
1435#define MAJOR_SHIFT 4
1436
1437
1438/* TESTBUSCR */
1439#define TBE_SHIFT 0
1440#define SPDMBE_SHIFT 1
1441#define WGSEL_SHIFT 8
1442#define TBLSEL_SHIFT 12
1443#define TBHSEL_SHIFT 14
1444#define SPDM0SEL_SHIFT 16
1445#define SPDM1SEL_SHIFT 20
1446#define SPDM2SEL_SHIFT 24
1447#define SPDM3SEL_SHIFT 28
1448
1449
1450/* TLBIMID */
1451#define TLBIVMID_VMID_SHIFT 0
1452
1453
1454/* TLBRSW */
1455#define TLBRSW_INDEX_SHIFT 0
1456#define TLBBFBS_SHIFT 8
1457
1458
1459/* TLBTR0 */
1460#define PR_SHIFT 0
1461#define PW_SHIFT 1
1462#define UR_SHIFT 2
1463#define UW_SHIFT 3
1464#define XN_SHIFT 4
1465#define NSDESC_SHIFT 6
1466#define ISH_SHIFT 7
1467#define SH_SHIFT 8
1468#define MT_SHIFT 9
1469#define DPSIZR_SHIFT 16
1470#define DPSIZC_SHIFT 20
1471
1472
1473/* TLBTR1 */
1474#define TLBTR1_VMID_SHIFT 0
1475#define TLBTR1_PA_SHIFT 12
1476
1477
1478/* TLBTR2 */
1479#define TLBTR2_ASID_SHIFT 0
1480#define TLBTR2_V_SHIFT 8
1481#define TLBTR2_NSTID_SHIFT 9
1482#define TLBTR2_NV_SHIFT 10
1483#define TLBTR2_VA_SHIFT 12
1484
1485
1486/* Context Register Masks */
1487/* ACTLR */
1488#define CFERE_MASK 0x01
1489#define CFEIE_MASK 0x01
1490#define PTSHCFG_MASK 0x03
1491#define RCOSH_MASK 0x01
1492#define RCISH_MASK 0x01
1493#define RCNSH_MASK 0x01
1494#define PRIVCFG_MASK 0x03
1495#define DNA_MASK 0x01
1496#define DNLV2PA_MASK 0x01
1497#define TLBMCFG_MASK 0x03
1498#define CFCFG_MASK 0x01
1499#define TIPCF_MASK 0x01
1500#define V2PCFG_MASK 0x03
1501#define HUME_MASK 0x01
1502#define PTMTCFG_MASK 0x01
1503#define PTMEMTYPE_MASK 0x07
1504
1505
1506/* BFBCR */
1507#define BFBDFE_MASK 0x01
1508#define BFBSFE_MASK 0x01
1509#define SFVS_MASK 0x01
1510#define FLVIC_MASK 0x0F
1511#define SLVIC_MASK 0x0F
1512
1513
1514/* CONTEXTIDR */
1515#define CONTEXTIDR_ASID_MASK 0xFF
1516#define PROCID_MASK 0x00FFFFFF
1517
1518
1519/* FSR */
1520#define TF_MASK 0x01
1521#define AFF_MASK 0x01
1522#define APF_MASK 0x01
1523#define TLBMF_MASK 0x01
1524#define HTWDEEF_MASK 0x01
1525#define HTWSEEF_MASK 0x01
1526#define MHF_MASK 0x01
1527#define SL_MASK 0x01
1528#define SS_MASK 0x01
1529#define MULTI_MASK 0x01
1530
1531
1532/* FSYNR0 */
1533#define AMID_MASK 0xFF
1534#define APID_MASK 0x1F
1535#define ABID_MASK 0x07
1536#define ATID_MASK 0xFF
1537
1538
1539/* FSYNR1 */
1540#define AMEMTYPE_MASK 0x07
1541#define ASHARED_MASK 0x01
1542#define AINNERSHARED_MASK 0x01
1543#define APRIV_MASK 0x01
1544#define APROTNS_MASK 0x01
1545#define AINST_MASK 0x01
1546#define AWRITE_MASK 0x01
1547#define ABURST_MASK 0x01
1548#define ALEN_MASK 0x0F
1549#define FSYNR1_ASIZE_MASK 0x07
1550#define ALOCK_MASK 0x03
1551#define AFULL_MASK 0x01
1552
1553
1554/* NMRR */
1555#define ICPC0_MASK 0x03
1556#define ICPC1_MASK 0x03
1557#define ICPC2_MASK 0x03
1558#define ICPC3_MASK 0x03
1559#define ICPC4_MASK 0x03
1560#define ICPC5_MASK 0x03
1561#define ICPC6_MASK 0x03
1562#define ICPC7_MASK 0x03
1563#define OCPC0_MASK 0x03
1564#define OCPC1_MASK 0x03
1565#define OCPC2_MASK 0x03
1566#define OCPC3_MASK 0x03
1567#define OCPC4_MASK 0x03
1568#define OCPC5_MASK 0x03
1569#define OCPC6_MASK 0x03
1570#define OCPC7_MASK 0x03
1571
1572
1573/* PAR */
1574#define FAULT_MASK 0x01
1575/* If a fault is present, these are the
1576same as the fault fields in the FAR */
1577#define FAULT_TF_MASK 0x01
1578#define FAULT_AFF_MASK 0x01
1579#define FAULT_APF_MASK 0x01
1580#define FAULT_TLBMF_MASK 0x01
1581#define FAULT_HTWDEEF_MASK 0x01
1582#define FAULT_HTWSEEF_MASK 0x01
1583#define FAULT_MHF_MASK 0x01
1584#define FAULT_SL_MASK 0x01
1585#define FAULT_SS_MASK 0x01
1586
1587/* If NO fault is present, the following
1588 * fields are in effect
1589 * (FAULT remains as before) */
1590#define PAR_NOFAULT_SS_MASK 0x01
1591#define PAR_NOFAULT_MT_MASK 0x07
1592#define PAR_NOFAULT_SH_MASK 0x01
1593#define PAR_NOFAULT_NS_MASK 0x01
1594#define PAR_NOFAULT_NOS_MASK 0x01
1595#define PAR_NPFAULT_PA_MASK 0x000FFFFF
1596
1597
1598/* PRRR */
1599#define MTC0_MASK 0x03
1600#define MTC1_MASK 0x03
1601#define MTC2_MASK 0x03
1602#define MTC3_MASK 0x03
1603#define MTC4_MASK 0x03
1604#define MTC5_MASK 0x03
1605#define MTC6_MASK 0x03
1606#define MTC7_MASK 0x03
1607#define SHDSH0_MASK 0x01
1608#define SHDSH1_MASK 0x01
1609#define SHNMSH0_MASK 0x01
1610#define SHNMSH1_MASK 0x01
1611#define NOS0_MASK 0x01
1612#define NOS1_MASK 0x01
1613#define NOS2_MASK 0x01
1614#define NOS3_MASK 0x01
1615#define NOS4_MASK 0x01
1616#define NOS5_MASK 0x01
1617#define NOS6_MASK 0x01
1618#define NOS7_MASK 0x01
1619
1620
1621/* RESUME */
1622#define TNR_MASK 0x01
1623
1624
1625/* SCTLR */
1626#define M_MASK 0x01
1627#define TRE_MASK 0x01
1628#define AFE_MASK 0x01
1629#define HAF_MASK 0x01
1630#define BE_MASK 0x01
1631#define AFFD_MASK 0x01
1632
1633
1634/* TLBIASID */
1635#define TLBIASID_ASID_MASK 0xFF
1636
1637
1638/* TLBIVA */
1639#define TLBIVA_ASID_MASK 0xFF
1640#define TLBIVA_VA_MASK 0x000FFFFF
1641
1642
1643/* TLBIVAA */
1644#define TLBIVAA_VA_MASK 0x000FFFFF
1645
1646
1647/* TLBLCKR */
1648#define LKE_MASK 0x01
1649#define TLBLCKR_TLBIALLCFG_MASK 0x01
1650#define TLBIASIDCFG_MASK 0x01
1651#define TLBIVAACFG_MASK 0x01
1652#define FLOOR_MASK 0xFF
1653#define VICTIM_MASK 0xFF
1654
1655
1656/* TTBCR */
1657#define N_MASK 0x07
1658#define PD0_MASK 0x01
1659#define PD1_MASK 0x01
1660
1661
1662/* TTBR0 */
1663#define TTBR0_IRGNH_MASK 0x01
1664#define TTBR0_SH_MASK 0x01
1665#define TTBR0_ORGN_MASK 0x03
1666#define TTBR0_NOS_MASK 0x01
1667#define TTBR0_IRGNL_MASK 0x01
1668#define TTBR0_PA_MASK 0x0003FFFF
1669
1670
1671/* TTBR1 */
1672#define TTBR1_IRGNH_MASK 0x01
1673#define TTBR1_SH_MASK 0x01
1674#define TTBR1_ORGN_MASK 0x03
1675#define TTBR1_NOS_MASK 0x01
1676#define TTBR1_IRGNL_MASK 0x01
1677#define TTBR1_PA_MASK 0x0003FFFF
1678
1679
1680/* V2PSR */
1681#define HIT_MASK 0x01
1682#define INDEX_MASK 0xFF
1683
1684
1685/* V2Pxx */
1686#define V2Pxx_INDEX_MASK 0xFF
1687#define V2Pxx_VA_MASK 0x000FFFFF
1688
1689
1690/* Context Register Shifts */
1691/* ACTLR */
1692#define CFERE_SHIFT 0
1693#define CFEIE_SHIFT 1
1694#define PTSHCFG_SHIFT 2
1695#define RCOSH_SHIFT 4
1696#define RCISH_SHIFT 5
1697#define RCNSH_SHIFT 6
1698#define PRIVCFG_SHIFT 8
1699#define DNA_SHIFT 10
1700#define DNLV2PA_SHIFT 11
1701#define TLBMCFG_SHIFT 12
1702#define CFCFG_SHIFT 14
1703#define TIPCF_SHIFT 15
1704#define V2PCFG_SHIFT 16
1705#define HUME_SHIFT 18
1706#define PTMTCFG_SHIFT 20
1707#define PTMEMTYPE_SHIFT 21
1708
1709
1710/* BFBCR */
1711#define BFBDFE_SHIFT 0
1712#define BFBSFE_SHIFT 1
1713#define SFVS_SHIFT 2
1714#define FLVIC_SHIFT 4
1715#define SLVIC_SHIFT 8
1716
1717
1718/* CONTEXTIDR */
1719#define CONTEXTIDR_ASID_SHIFT 0
1720#define PROCID_SHIFT 8
1721
1722
1723/* FSR */
1724#define TF_SHIFT 1
1725#define AFF_SHIFT 2
1726#define APF_SHIFT 3
1727#define TLBMF_SHIFT 4
1728#define HTWDEEF_SHIFT 5
1729#define HTWSEEF_SHIFT 6
1730#define MHF_SHIFT 7
1731#define SL_SHIFT 16
1732#define SS_SHIFT 30
1733#define MULTI_SHIFT 31
1734
1735
1736/* FSYNR0 */
1737#define AMID_SHIFT 0
1738#define APID_SHIFT 8
1739#define ABID_SHIFT 13
1740#define ATID_SHIFT 24
1741
1742
1743/* FSYNR1 */
1744#define AMEMTYPE_SHIFT 0
1745#define ASHARED_SHIFT 3
1746#define AINNERSHARED_SHIFT 4
1747#define APRIV_SHIFT 5
1748#define APROTNS_SHIFT 6
1749#define AINST_SHIFT 7
1750#define AWRITE_SHIFT 8
1751#define ABURST_SHIFT 10
1752#define ALEN_SHIFT 12
1753#define FSYNR1_ASIZE_SHIFT 16
1754#define ALOCK_SHIFT 20
1755#define AFULL_SHIFT 24
1756
1757
1758/* NMRR */
1759#define ICPC0_SHIFT 0
1760#define ICPC1_SHIFT 2
1761#define ICPC2_SHIFT 4
1762#define ICPC3_SHIFT 6
1763#define ICPC4_SHIFT 8
1764#define ICPC5_SHIFT 10
1765#define ICPC6_SHIFT 12
1766#define ICPC7_SHIFT 14
1767#define OCPC0_SHIFT 16
1768#define OCPC1_SHIFT 18
1769#define OCPC2_SHIFT 20
1770#define OCPC3_SHIFT 22
1771#define OCPC4_SHIFT 24
1772#define OCPC5_SHIFT 26
1773#define OCPC6_SHIFT 28
1774#define OCPC7_SHIFT 30
1775
1776
1777/* PAR */
1778#define FAULT_SHIFT 0
1779/* If a fault is present, these are the
1780same as the fault fields in the FAR */
1781#define FAULT_TF_SHIFT 1
1782#define FAULT_AFF_SHIFT 2
1783#define FAULT_APF_SHIFT 3
1784#define FAULT_TLBMF_SHIFT 4
1785#define FAULT_HTWDEEF_SHIFT 5
1786#define FAULT_HTWSEEF_SHIFT 6
1787#define FAULT_MHF_SHIFT 7
1788#define FAULT_SL_SHIFT 16
1789#define FAULT_SS_SHIFT 30
1790
1791/* If NO fault is present, the following
1792 * fields are in effect
1793 * (FAULT remains as before) */
1794#define PAR_NOFAULT_SS_SHIFT 1
1795#define PAR_NOFAULT_MT_SHIFT 4
1796#define PAR_NOFAULT_SH_SHIFT 7
1797#define PAR_NOFAULT_NS_SHIFT 9
1798#define PAR_NOFAULT_NOS_SHIFT 10
1799#define PAR_NPFAULT_PA_SHIFT 12
1800
1801
1802/* PRRR */
1803#define MTC0_SHIFT 0
1804#define MTC1_SHIFT 2
1805#define MTC2_SHIFT 4
1806#define MTC3_SHIFT 6
1807#define MTC4_SHIFT 8
1808#define MTC5_SHIFT 10
1809#define MTC6_SHIFT 12
1810#define MTC7_SHIFT 14
1811#define SHDSH0_SHIFT 16
1812#define SHDSH1_SHIFT 17
1813#define SHNMSH0_SHIFT 18
1814#define SHNMSH1_SHIFT 19
1815#define NOS0_SHIFT 24
1816#define NOS1_SHIFT 25
1817#define NOS2_SHIFT 26
1818#define NOS3_SHIFT 27
1819#define NOS4_SHIFT 28
1820#define NOS5_SHIFT 29
1821#define NOS6_SHIFT 30
1822#define NOS7_SHIFT 31
1823
1824
1825/* RESUME */
1826#define TNR_SHIFT 0
1827
1828
1829/* SCTLR */
1830#define M_SHIFT 0
1831#define TRE_SHIFT 1
1832#define AFE_SHIFT 2
1833#define HAF_SHIFT 3
1834#define BE_SHIFT 4
1835#define AFFD_SHIFT 5
1836
1837
1838/* TLBIASID */
1839#define TLBIASID_ASID_SHIFT 0
1840
1841
1842/* TLBIVA */
1843#define TLBIVA_ASID_SHIFT 0
1844#define TLBIVA_VA_SHIFT 12
1845
1846
1847/* TLBIVAA */
1848#define TLBIVAA_VA_SHIFT 12
1849
1850
1851/* TLBLCKR */
1852#define LKE_SHIFT 0
1853#define TLBLCKR_TLBIALLCFG_SHIFT 1
1854#define TLBIASIDCFG_SHIFT 2
1855#define TLBIVAACFG_SHIFT 3
1856#define FLOOR_SHIFT 8
1857#define VICTIM_SHIFT 8
1858
1859
1860/* TTBCR */
1861#define N_SHIFT 3
1862#define PD0_SHIFT 4
1863#define PD1_SHIFT 5
1864
1865
1866/* TTBR0 */
1867#define TTBR0_IRGNH_SHIFT 0
1868#define TTBR0_SH_SHIFT 1
1869#define TTBR0_ORGN_SHIFT 3
1870#define TTBR0_NOS_SHIFT 5
1871#define TTBR0_IRGNL_SHIFT 6
1872#define TTBR0_PA_SHIFT 14
1873
1874
1875/* TTBR1 */
1876#define TTBR1_IRGNH_SHIFT 0
1877#define TTBR1_SH_SHIFT 1
1878#define TTBR1_ORGN_SHIFT 3
1879#define TTBR1_NOS_SHIFT 5
1880#define TTBR1_IRGNL_SHIFT 6
1881#define TTBR1_PA_SHIFT 14
1882
1883
1884/* V2PSR */
1885#define HIT_SHIFT 0
1886#define INDEX_SHIFT 8
1887
1888
1889/* V2Pxx */
1890#define V2Pxx_INDEX_SHIFT 0
1891#define V2Pxx_VA_SHIFT 12
1892
1893#endif