xref: /openbmc/linux/drivers/iommu/msm_iommu_hw-8xxx.h (revision 75bf465f0bc33e9b776a46d6a1b9b990f5fb7c37)
1*08dbd0f8SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
20b559df5SStephen Boyd /* Copyright (c) 2010-2011, Code Aurora Forum. All rights reserved.
30b559df5SStephen Boyd  */
40b559df5SStephen Boyd 
50b559df5SStephen Boyd #ifndef __ARCH_ARM_MACH_MSM_IOMMU_HW_8XXX_H
60b559df5SStephen Boyd #define __ARCH_ARM_MACH_MSM_IOMMU_HW_8XXX_H
70b559df5SStephen Boyd 
80b559df5SStephen Boyd #define CTX_SHIFT 12
90b559df5SStephen Boyd 
100b559df5SStephen Boyd #define GET_GLOBAL_REG(reg, base) (readl((base) + (reg)))
110b559df5SStephen Boyd #define GET_CTX_REG(reg, base, ctx) \
120b559df5SStephen Boyd 				(readl((base) + (reg) + ((ctx) << CTX_SHIFT)))
130b559df5SStephen Boyd 
140b559df5SStephen Boyd #define SET_GLOBAL_REG(reg, base, val)	writel((val), ((base) + (reg)))
150b559df5SStephen Boyd 
160b559df5SStephen Boyd #define SET_CTX_REG(reg, base, ctx, val) \
170b559df5SStephen Boyd 			writel((val), ((base) + (reg) + ((ctx) << CTX_SHIFT)))
180b559df5SStephen Boyd 
190b559df5SStephen Boyd /* Wrappers for numbered registers */
200b559df5SStephen Boyd #define SET_GLOBAL_REG_N(b, n, r, v) SET_GLOBAL_REG(b, ((r) + (n << 2)), (v))
210b559df5SStephen Boyd #define GET_GLOBAL_REG_N(b, n, r)    GET_GLOBAL_REG(b, ((r) + (n << 2)))
220b559df5SStephen Boyd 
230b559df5SStephen Boyd /* Field wrappers */
240b559df5SStephen Boyd #define GET_GLOBAL_FIELD(b, r, F)    GET_FIELD(((b) + (r)), F##_MASK, F##_SHIFT)
250b559df5SStephen Boyd #define GET_CONTEXT_FIELD(b, c, r, F)	\
260b559df5SStephen Boyd 	GET_FIELD(((b) + (r) + ((c) << CTX_SHIFT)), F##_MASK, F##_SHIFT)
270b559df5SStephen Boyd 
280b559df5SStephen Boyd #define SET_GLOBAL_FIELD(b, r, F, v) \
290b559df5SStephen Boyd 	SET_FIELD(((b) + (r)), F##_MASK, F##_SHIFT, (v))
300b559df5SStephen Boyd #define SET_CONTEXT_FIELD(b, c, r, F, v)	\
310b559df5SStephen Boyd 	SET_FIELD(((b) + (r) + ((c) << CTX_SHIFT)), F##_MASK, F##_SHIFT, (v))
320b559df5SStephen Boyd 
330b559df5SStephen Boyd #define GET_FIELD(addr, mask, shift)  ((readl(addr) >> (shift)) & (mask))
340b559df5SStephen Boyd 
350b559df5SStephen Boyd #define SET_FIELD(addr, mask, shift, v) \
360b559df5SStephen Boyd do { \
370b559df5SStephen Boyd 	int t = readl(addr); \
380b559df5SStephen Boyd 	writel((t & ~((mask) << (shift))) + (((v) & (mask)) << (shift)), addr);\
390b559df5SStephen Boyd } while (0)
400b559df5SStephen Boyd 
410b559df5SStephen Boyd 
420b559df5SStephen Boyd #define NUM_FL_PTE	4096
430b559df5SStephen Boyd #define NUM_SL_PTE	256
440b559df5SStephen Boyd #define NUM_TEX_CLASS	8
450b559df5SStephen Boyd 
460b559df5SStephen Boyd /* First-level page table bits */
470b559df5SStephen Boyd #define FL_BASE_MASK		0xFFFFFC00
480b559df5SStephen Boyd #define FL_TYPE_TABLE		(1 << 0)
490b559df5SStephen Boyd #define FL_TYPE_SECT		(2 << 0)
500b559df5SStephen Boyd #define FL_SUPERSECTION		(1 << 18)
510b559df5SStephen Boyd #define FL_AP_WRITE		(1 << 10)
520b559df5SStephen Boyd #define FL_AP_READ		(1 << 11)
530b559df5SStephen Boyd #define FL_SHARED		(1 << 16)
540b559df5SStephen Boyd #define FL_BUFFERABLE		(1 << 2)
550b559df5SStephen Boyd #define FL_CACHEABLE		(1 << 3)
560b559df5SStephen Boyd #define FL_TEX0			(1 << 12)
570b559df5SStephen Boyd #define FL_OFFSET(va)		(((va) & 0xFFF00000) >> 20)
580b559df5SStephen Boyd #define FL_NG			(1 << 17)
590b559df5SStephen Boyd 
600b559df5SStephen Boyd /* Second-level page table bits */
610b559df5SStephen Boyd #define SL_BASE_MASK_LARGE	0xFFFF0000
620b559df5SStephen Boyd #define SL_BASE_MASK_SMALL	0xFFFFF000
630b559df5SStephen Boyd #define SL_TYPE_LARGE		(1 << 0)
640b559df5SStephen Boyd #define SL_TYPE_SMALL		(2 << 0)
650b559df5SStephen Boyd #define SL_AP0			(1 << 4)
660b559df5SStephen Boyd #define SL_AP1			(2 << 4)
670b559df5SStephen Boyd #define SL_SHARED		(1 << 10)
680b559df5SStephen Boyd #define SL_BUFFERABLE		(1 << 2)
690b559df5SStephen Boyd #define SL_CACHEABLE		(1 << 3)
700b559df5SStephen Boyd #define SL_TEX0			(1 << 6)
710b559df5SStephen Boyd #define SL_OFFSET(va)		(((va) & 0xFF000) >> 12)
720b559df5SStephen Boyd #define SL_NG			(1 << 11)
730b559df5SStephen Boyd 
740b559df5SStephen Boyd /* Memory type and cache policy attributes */
750b559df5SStephen Boyd #define MT_SO			0
760b559df5SStephen Boyd #define MT_DEV			1
770b559df5SStephen Boyd #define MT_NORMAL		2
780b559df5SStephen Boyd #define CP_NONCACHED		0
790b559df5SStephen Boyd #define CP_WB_WA		1
800b559df5SStephen Boyd #define CP_WT			2
810b559df5SStephen Boyd #define CP_WB_NWA		3
820b559df5SStephen Boyd 
830b559df5SStephen Boyd /* Global register setters / getters */
840b559df5SStephen Boyd #define SET_M2VCBR_N(b, N, v)	 SET_GLOBAL_REG_N(M2VCBR_N, N, (b), (v))
850b559df5SStephen Boyd #define SET_CBACR_N(b, N, v)	 SET_GLOBAL_REG_N(CBACR_N, N, (b), (v))
860b559df5SStephen Boyd #define SET_TLBRSW(b, v)	 SET_GLOBAL_REG(TLBRSW, (b), (v))
870b559df5SStephen Boyd #define SET_TLBTR0(b, v)	 SET_GLOBAL_REG(TLBTR0, (b), (v))
880b559df5SStephen Boyd #define SET_TLBTR1(b, v)	 SET_GLOBAL_REG(TLBTR1, (b), (v))
890b559df5SStephen Boyd #define SET_TLBTR2(b, v)	 SET_GLOBAL_REG(TLBTR2, (b), (v))
900b559df5SStephen Boyd #define SET_TESTBUSCR(b, v)	 SET_GLOBAL_REG(TESTBUSCR, (b), (v))
910b559df5SStephen Boyd #define SET_GLOBAL_TLBIALL(b, v) SET_GLOBAL_REG(GLOBAL_TLBIALL, (b), (v))
920b559df5SStephen Boyd #define SET_TLBIVMID(b, v)	 SET_GLOBAL_REG(TLBIVMID, (b), (v))
930b559df5SStephen Boyd #define SET_CR(b, v)		 SET_GLOBAL_REG(CR, (b), (v))
940b559df5SStephen Boyd #define SET_EAR(b, v)		 SET_GLOBAL_REG(EAR, (b), (v))
950b559df5SStephen Boyd #define SET_ESR(b, v)		 SET_GLOBAL_REG(ESR, (b), (v))
960b559df5SStephen Boyd #define SET_ESRRESTORE(b, v)	 SET_GLOBAL_REG(ESRRESTORE, (b), (v))
970b559df5SStephen Boyd #define SET_ESYNR0(b, v)	 SET_GLOBAL_REG(ESYNR0, (b), (v))
980b559df5SStephen Boyd #define SET_ESYNR1(b, v)	 SET_GLOBAL_REG(ESYNR1, (b), (v))
990b559df5SStephen Boyd #define SET_RPU_ACR(b, v)	 SET_GLOBAL_REG(RPU_ACR, (b), (v))
1000b559df5SStephen Boyd 
1010b559df5SStephen Boyd #define GET_M2VCBR_N(b, N)	 GET_GLOBAL_REG_N(M2VCBR_N, N, (b))
1020b559df5SStephen Boyd #define GET_CBACR_N(b, N)	 GET_GLOBAL_REG_N(CBACR_N, N, (b))
1030b559df5SStephen Boyd #define GET_TLBTR0(b)		 GET_GLOBAL_REG(TLBTR0, (b))
1040b559df5SStephen Boyd #define GET_TLBTR1(b)		 GET_GLOBAL_REG(TLBTR1, (b))
1050b559df5SStephen Boyd #define GET_TLBTR2(b)		 GET_GLOBAL_REG(TLBTR2, (b))
1060b559df5SStephen Boyd #define GET_TESTBUSCR(b)	 GET_GLOBAL_REG(TESTBUSCR, (b))
1070b559df5SStephen Boyd #define GET_GLOBAL_TLBIALL(b)	 GET_GLOBAL_REG(GLOBAL_TLBIALL, (b))
1080b559df5SStephen Boyd #define GET_TLBIVMID(b)		 GET_GLOBAL_REG(TLBIVMID, (b))
1090b559df5SStephen Boyd #define GET_CR(b)		 GET_GLOBAL_REG(CR, (b))
1100b559df5SStephen Boyd #define GET_EAR(b)		 GET_GLOBAL_REG(EAR, (b))
1110b559df5SStephen Boyd #define GET_ESR(b)		 GET_GLOBAL_REG(ESR, (b))
1120b559df5SStephen Boyd #define GET_ESRRESTORE(b)	 GET_GLOBAL_REG(ESRRESTORE, (b))
1130b559df5SStephen Boyd #define GET_ESYNR0(b)		 GET_GLOBAL_REG(ESYNR0, (b))
1140b559df5SStephen Boyd #define GET_ESYNR1(b)		 GET_GLOBAL_REG(ESYNR1, (b))
1150b559df5SStephen Boyd #define GET_REV(b)		 GET_GLOBAL_REG(REV, (b))
1160b559df5SStephen Boyd #define GET_IDR(b)		 GET_GLOBAL_REG(IDR, (b))
1170b559df5SStephen Boyd #define GET_RPU_ACR(b)		 GET_GLOBAL_REG(RPU_ACR, (b))
1180b559df5SStephen Boyd 
1190b559df5SStephen Boyd 
1200b559df5SStephen Boyd /* Context register setters/getters */
1210b559df5SStephen Boyd #define SET_SCTLR(b, c, v)	 SET_CTX_REG(SCTLR, (b), (c), (v))
1220b559df5SStephen Boyd #define SET_ACTLR(b, c, v)	 SET_CTX_REG(ACTLR, (b), (c), (v))
1230b559df5SStephen Boyd #define SET_CONTEXTIDR(b, c, v)	 SET_CTX_REG(CONTEXTIDR, (b), (c), (v))
1240b559df5SStephen Boyd #define SET_TTBR0(b, c, v)	 SET_CTX_REG(TTBR0, (b), (c), (v))
1250b559df5SStephen Boyd #define SET_TTBR1(b, c, v)	 SET_CTX_REG(TTBR1, (b), (c), (v))
1260b559df5SStephen Boyd #define SET_TTBCR(b, c, v)	 SET_CTX_REG(TTBCR, (b), (c), (v))
1270b559df5SStephen Boyd #define SET_PAR(b, c, v)	 SET_CTX_REG(PAR, (b), (c), (v))
1280b559df5SStephen Boyd #define SET_FSR(b, c, v)	 SET_CTX_REG(FSR, (b), (c), (v))
1290b559df5SStephen Boyd #define SET_FSRRESTORE(b, c, v)	 SET_CTX_REG(FSRRESTORE, (b), (c), (v))
1300b559df5SStephen Boyd #define SET_FAR(b, c, v)	 SET_CTX_REG(FAR, (b), (c), (v))
1310b559df5SStephen Boyd #define SET_FSYNR0(b, c, v)	 SET_CTX_REG(FSYNR0, (b), (c), (v))
1320b559df5SStephen Boyd #define SET_FSYNR1(b, c, v)	 SET_CTX_REG(FSYNR1, (b), (c), (v))
1330b559df5SStephen Boyd #define SET_PRRR(b, c, v)	 SET_CTX_REG(PRRR, (b), (c), (v))
1340b559df5SStephen Boyd #define SET_NMRR(b, c, v)	 SET_CTX_REG(NMRR, (b), (c), (v))
1350b559df5SStephen Boyd #define SET_TLBLKCR(b, c, v)	 SET_CTX_REG(TLBLCKR, (b), (c), (v))
1360b559df5SStephen Boyd #define SET_V2PSR(b, c, v)	 SET_CTX_REG(V2PSR, (b), (c), (v))
1370b559df5SStephen Boyd #define SET_TLBFLPTER(b, c, v)	 SET_CTX_REG(TLBFLPTER, (b), (c), (v))
1380b559df5SStephen Boyd #define SET_TLBSLPTER(b, c, v)	 SET_CTX_REG(TLBSLPTER, (b), (c), (v))
1390b559df5SStephen Boyd #define SET_BFBCR(b, c, v)	 SET_CTX_REG(BFBCR, (b), (c), (v))
1400b559df5SStephen Boyd #define SET_CTX_TLBIALL(b, c, v) SET_CTX_REG(CTX_TLBIALL, (b), (c), (v))
1410b559df5SStephen Boyd #define SET_TLBIASID(b, c, v)	 SET_CTX_REG(TLBIASID, (b), (c), (v))
1420b559df5SStephen Boyd #define SET_TLBIVA(b, c, v)	 SET_CTX_REG(TLBIVA, (b), (c), (v))
1430b559df5SStephen Boyd #define SET_TLBIVAA(b, c, v)	 SET_CTX_REG(TLBIVAA, (b), (c), (v))
1440b559df5SStephen Boyd #define SET_V2PPR(b, c, v)	 SET_CTX_REG(V2PPR, (b), (c), (v))
1450b559df5SStephen Boyd #define SET_V2PPW(b, c, v)	 SET_CTX_REG(V2PPW, (b), (c), (v))
1460b559df5SStephen Boyd #define SET_V2PUR(b, c, v)	 SET_CTX_REG(V2PUR, (b), (c), (v))
1470b559df5SStephen Boyd #define SET_V2PUW(b, c, v)	 SET_CTX_REG(V2PUW, (b), (c), (v))
1480b559df5SStephen Boyd #define SET_RESUME(b, c, v)	 SET_CTX_REG(RESUME, (b), (c), (v))
1490b559df5SStephen Boyd 
1500b559df5SStephen Boyd #define GET_SCTLR(b, c)		 GET_CTX_REG(SCTLR, (b), (c))
1510b559df5SStephen Boyd #define GET_ACTLR(b, c)		 GET_CTX_REG(ACTLR, (b), (c))
1520b559df5SStephen Boyd #define GET_CONTEXTIDR(b, c)	 GET_CTX_REG(CONTEXTIDR, (b), (c))
1530b559df5SStephen Boyd #define GET_TTBR0(b, c)		 GET_CTX_REG(TTBR0, (b), (c))
1540b559df5SStephen Boyd #define GET_TTBR1(b, c)		 GET_CTX_REG(TTBR1, (b), (c))
1550b559df5SStephen Boyd #define GET_TTBCR(b, c)		 GET_CTX_REG(TTBCR, (b), (c))
1560b559df5SStephen Boyd #define GET_PAR(b, c)		 GET_CTX_REG(PAR, (b), (c))
1570b559df5SStephen Boyd #define GET_FSR(b, c)		 GET_CTX_REG(FSR, (b), (c))
1580b559df5SStephen Boyd #define GET_FSRRESTORE(b, c)	 GET_CTX_REG(FSRRESTORE, (b), (c))
1590b559df5SStephen Boyd #define GET_FAR(b, c)		 GET_CTX_REG(FAR, (b), (c))
1600b559df5SStephen Boyd #define GET_FSYNR0(b, c)	 GET_CTX_REG(FSYNR0, (b), (c))
1610b559df5SStephen Boyd #define GET_FSYNR1(b, c)	 GET_CTX_REG(FSYNR1, (b), (c))
1620b559df5SStephen Boyd #define GET_PRRR(b, c)		 GET_CTX_REG(PRRR, (b), (c))
1630b559df5SStephen Boyd #define GET_NMRR(b, c)		 GET_CTX_REG(NMRR, (b), (c))
1640b559df5SStephen Boyd #define GET_TLBLCKR(b, c)	 GET_CTX_REG(TLBLCKR, (b), (c))
1650b559df5SStephen Boyd #define GET_V2PSR(b, c)		 GET_CTX_REG(V2PSR, (b), (c))
1660b559df5SStephen Boyd #define GET_TLBFLPTER(b, c)	 GET_CTX_REG(TLBFLPTER, (b), (c))
1670b559df5SStephen Boyd #define GET_TLBSLPTER(b, c)	 GET_CTX_REG(TLBSLPTER, (b), (c))
1680b559df5SStephen Boyd #define GET_BFBCR(b, c)		 GET_CTX_REG(BFBCR, (b), (c))
1690b559df5SStephen Boyd #define GET_CTX_TLBIALL(b, c)	 GET_CTX_REG(CTX_TLBIALL, (b), (c))
1700b559df5SStephen Boyd #define GET_TLBIASID(b, c)	 GET_CTX_REG(TLBIASID, (b), (c))
1710b559df5SStephen Boyd #define GET_TLBIVA(b, c)	 GET_CTX_REG(TLBIVA, (b), (c))
1720b559df5SStephen Boyd #define GET_TLBIVAA(b, c)	 GET_CTX_REG(TLBIVAA, (b), (c))
1730b559df5SStephen Boyd #define GET_V2PPR(b, c)		 GET_CTX_REG(V2PPR, (b), (c))
1740b559df5SStephen Boyd #define GET_V2PPW(b, c)		 GET_CTX_REG(V2PPW, (b), (c))
1750b559df5SStephen Boyd #define GET_V2PUR(b, c)		 GET_CTX_REG(V2PUR, (b), (c))
1760b559df5SStephen Boyd #define GET_V2PUW(b, c)		 GET_CTX_REG(V2PUW, (b), (c))
1770b559df5SStephen Boyd #define GET_RESUME(b, c)	 GET_CTX_REG(RESUME, (b), (c))
1780b559df5SStephen Boyd 
1790b559df5SStephen Boyd 
1800b559df5SStephen Boyd /* Global field setters / getters */
1810b559df5SStephen Boyd /* Global Field Setters: */
1820b559df5SStephen Boyd /* CBACR_N */
1830b559df5SStephen Boyd #define SET_RWVMID(b, n, v)   SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWVMID, v)
1840b559df5SStephen Boyd #define SET_RWE(b, n, v)      SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWE, v)
1850b559df5SStephen Boyd #define SET_RWGE(b, n, v)     SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWGE, v)
1860b559df5SStephen Boyd #define SET_CBVMID(b, n, v)   SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), CBVMID, v)
1870b559df5SStephen Boyd #define SET_IRPTNDX(b, n, v)  SET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), IRPTNDX, v)
1880b559df5SStephen Boyd 
1890b559df5SStephen Boyd 
1900b559df5SStephen Boyd /* M2VCBR_N */
1910b559df5SStephen Boyd #define SET_VMID(b, n, v)     SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), VMID, v)
1920b559df5SStephen Boyd #define SET_CBNDX(b, n, v)    SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), CBNDX, v)
1930b559df5SStephen Boyd #define SET_BYPASSD(b, n, v)  SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BYPASSD, v)
1940b559df5SStephen Boyd #define SET_BPRCOSH(b, n, v)  SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCOSH, v)
1950b559df5SStephen Boyd #define SET_BPRCISH(b, n, v)  SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCISH, v)
1960b559df5SStephen Boyd #define SET_BPRCNSH(b, n, v)  SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCNSH, v)
1970b559df5SStephen Boyd #define SET_BPSHCFG(b, n, v)  SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPSHCFG, v)
1980b559df5SStephen Boyd #define SET_NSCFG(b, n, v)    SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), NSCFG, v)
1990b559df5SStephen Boyd #define SET_BPMTCFG(b, n, v)  SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMTCFG, v)
2000b559df5SStephen Boyd #define SET_BPMEMTYPE(b, n, v) \
2010b559df5SStephen Boyd 	SET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMEMTYPE, v)
2020b559df5SStephen Boyd 
2030b559df5SStephen Boyd 
2040b559df5SStephen Boyd /* CR */
2050b559df5SStephen Boyd #define SET_RPUE(b, v)		 SET_GLOBAL_FIELD(b, CR, RPUE, v)
2060b559df5SStephen Boyd #define SET_RPUERE(b, v)	 SET_GLOBAL_FIELD(b, CR, RPUERE, v)
2070b559df5SStephen Boyd #define SET_RPUEIE(b, v)	 SET_GLOBAL_FIELD(b, CR, RPUEIE, v)
2080b559df5SStephen Boyd #define SET_DCDEE(b, v)		 SET_GLOBAL_FIELD(b, CR, DCDEE, v)
2090b559df5SStephen Boyd #define SET_CLIENTPD(b, v)       SET_GLOBAL_FIELD(b, CR, CLIENTPD, v)
2100b559df5SStephen Boyd #define SET_STALLD(b, v)	 SET_GLOBAL_FIELD(b, CR, STALLD, v)
2110b559df5SStephen Boyd #define SET_TLBLKCRWE(b, v)      SET_GLOBAL_FIELD(b, CR, TLBLKCRWE, v)
2120b559df5SStephen Boyd #define SET_CR_TLBIALLCFG(b, v)  SET_GLOBAL_FIELD(b, CR, CR_TLBIALLCFG, v)
2130b559df5SStephen Boyd #define SET_TLBIVMIDCFG(b, v)    SET_GLOBAL_FIELD(b, CR, TLBIVMIDCFG, v)
2140b559df5SStephen Boyd #define SET_CR_HUME(b, v)        SET_GLOBAL_FIELD(b, CR, CR_HUME, v)
2150b559df5SStephen Boyd 
2160b559df5SStephen Boyd 
2170b559df5SStephen Boyd /* ESR */
2180b559df5SStephen Boyd #define SET_CFG(b, v)		 SET_GLOBAL_FIELD(b, ESR, CFG, v)
2190b559df5SStephen Boyd #define SET_BYPASS(b, v)	 SET_GLOBAL_FIELD(b, ESR, BYPASS, v)
2200b559df5SStephen Boyd #define SET_ESR_MULTI(b, v)      SET_GLOBAL_FIELD(b, ESR, ESR_MULTI, v)
2210b559df5SStephen Boyd 
2220b559df5SStephen Boyd 
2230b559df5SStephen Boyd /* ESYNR0 */
2240b559df5SStephen Boyd #define SET_ESYNR0_AMID(b, v)    SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AMID, v)
2250b559df5SStephen Boyd #define SET_ESYNR0_APID(b, v)    SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_APID, v)
2260b559df5SStephen Boyd #define SET_ESYNR0_ABID(b, v)    SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ABID, v)
2270b559df5SStephen Boyd #define SET_ESYNR0_AVMID(b, v)   SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AVMID, v)
2280b559df5SStephen Boyd #define SET_ESYNR0_ATID(b, v)    SET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ATID, v)
2290b559df5SStephen Boyd 
2300b559df5SStephen Boyd 
2310b559df5SStephen Boyd /* ESYNR1 */
2320b559df5SStephen Boyd #define SET_ESYNR1_AMEMTYPE(b, v) \
2330b559df5SStephen Boyd 			SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AMEMTYPE, v)
2340b559df5SStephen Boyd #define SET_ESYNR1_ASHARED(b, v)  SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASHARED, v)
2350b559df5SStephen Boyd #define SET_ESYNR1_AINNERSHARED(b, v) \
2360b559df5SStephen Boyd 			SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINNERSHARED, v)
2370b559df5SStephen Boyd #define SET_ESYNR1_APRIV(b, v)   SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APRIV, v)
2380b559df5SStephen Boyd #define SET_ESYNR1_APROTNS(b, v) SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APROTNS, v)
2390b559df5SStephen Boyd #define SET_ESYNR1_AINST(b, v)   SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINST, v)
2400b559df5SStephen Boyd #define SET_ESYNR1_AWRITE(b, v)  SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AWRITE, v)
2410b559df5SStephen Boyd #define SET_ESYNR1_ABURST(b, v)  SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ABURST, v)
2420b559df5SStephen Boyd #define SET_ESYNR1_ALEN(b, v)    SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALEN, v)
2430b559df5SStephen Boyd #define SET_ESYNR1_ASIZE(b, v)   SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASIZE, v)
2440b559df5SStephen Boyd #define SET_ESYNR1_ALOCK(b, v)   SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALOCK, v)
2450b559df5SStephen Boyd #define SET_ESYNR1_AOOO(b, v)    SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AOOO, v)
2460b559df5SStephen Boyd #define SET_ESYNR1_AFULL(b, v)   SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AFULL, v)
2470b559df5SStephen Boyd #define SET_ESYNR1_AC(b, v)      SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AC, v)
2480b559df5SStephen Boyd #define SET_ESYNR1_DCD(b, v)     SET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_DCD, v)
2490b559df5SStephen Boyd 
2500b559df5SStephen Boyd 
2510b559df5SStephen Boyd /* TESTBUSCR */
2520b559df5SStephen Boyd #define SET_TBE(b, v)		 SET_GLOBAL_FIELD(b, TESTBUSCR, TBE, v)
2530b559df5SStephen Boyd #define SET_SPDMBE(b, v)	 SET_GLOBAL_FIELD(b, TESTBUSCR, SPDMBE, v)
2540b559df5SStephen Boyd #define SET_WGSEL(b, v)		 SET_GLOBAL_FIELD(b, TESTBUSCR, WGSEL, v)
2550b559df5SStephen Boyd #define SET_TBLSEL(b, v)	 SET_GLOBAL_FIELD(b, TESTBUSCR, TBLSEL, v)
2560b559df5SStephen Boyd #define SET_TBHSEL(b, v)	 SET_GLOBAL_FIELD(b, TESTBUSCR, TBHSEL, v)
2570b559df5SStephen Boyd #define SET_SPDM0SEL(b, v)       SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM0SEL, v)
2580b559df5SStephen Boyd #define SET_SPDM1SEL(b, v)       SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM1SEL, v)
2590b559df5SStephen Boyd #define SET_SPDM2SEL(b, v)       SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM2SEL, v)
2600b559df5SStephen Boyd #define SET_SPDM3SEL(b, v)       SET_GLOBAL_FIELD(b, TESTBUSCR, SPDM3SEL, v)
2610b559df5SStephen Boyd 
2620b559df5SStephen Boyd 
2630b559df5SStephen Boyd /* TLBIVMID */
2640b559df5SStephen Boyd #define SET_TLBIVMID_VMID(b, v)  SET_GLOBAL_FIELD(b, TLBIVMID, TLBIVMID_VMID, v)
2650b559df5SStephen Boyd 
2660b559df5SStephen Boyd 
2670b559df5SStephen Boyd /* TLBRSW */
2680b559df5SStephen Boyd #define SET_TLBRSW_INDEX(b, v)   SET_GLOBAL_FIELD(b, TLBRSW, TLBRSW_INDEX, v)
2690b559df5SStephen Boyd #define SET_TLBBFBS(b, v)	 SET_GLOBAL_FIELD(b, TLBRSW, TLBBFBS, v)
2700b559df5SStephen Boyd 
2710b559df5SStephen Boyd 
2720b559df5SStephen Boyd /* TLBTR0 */
2730b559df5SStephen Boyd #define SET_PR(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, PR, v)
2740b559df5SStephen Boyd #define SET_PW(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, PW, v)
2750b559df5SStephen Boyd #define SET_UR(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, UR, v)
2760b559df5SStephen Boyd #define SET_UW(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, UW, v)
2770b559df5SStephen Boyd #define SET_XN(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, XN, v)
2780b559df5SStephen Boyd #define SET_NSDESC(b, v)	 SET_GLOBAL_FIELD(b, TLBTR0, NSDESC, v)
2790b559df5SStephen Boyd #define SET_ISH(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, ISH, v)
2800b559df5SStephen Boyd #define SET_SH(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, SH, v)
2810b559df5SStephen Boyd #define SET_MT(b, v)		 SET_GLOBAL_FIELD(b, TLBTR0, MT, v)
2820b559df5SStephen Boyd #define SET_DPSIZR(b, v)	 SET_GLOBAL_FIELD(b, TLBTR0, DPSIZR, v)
2830b559df5SStephen Boyd #define SET_DPSIZC(b, v)	 SET_GLOBAL_FIELD(b, TLBTR0, DPSIZC, v)
2840b559df5SStephen Boyd 
2850b559df5SStephen Boyd 
2860b559df5SStephen Boyd /* TLBTR1 */
2870b559df5SStephen Boyd #define SET_TLBTR1_VMID(b, v)    SET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_VMID, v)
2880b559df5SStephen Boyd #define SET_TLBTR1_PA(b, v)      SET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_PA, v)
2890b559df5SStephen Boyd 
2900b559df5SStephen Boyd 
2910b559df5SStephen Boyd /* TLBTR2 */
2920b559df5SStephen Boyd #define SET_TLBTR2_ASID(b, v)    SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_ASID, v)
2930b559df5SStephen Boyd #define SET_TLBTR2_V(b, v)       SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_V, v)
2940b559df5SStephen Boyd #define SET_TLBTR2_NSTID(b, v)   SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NSTID, v)
2950b559df5SStephen Boyd #define SET_TLBTR2_NV(b, v)      SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NV, v)
2960b559df5SStephen Boyd #define SET_TLBTR2_VA(b, v)      SET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_VA, v)
2970b559df5SStephen Boyd 
2980b559df5SStephen Boyd 
2990b559df5SStephen Boyd /* Global Field Getters */
3000b559df5SStephen Boyd /* CBACR_N */
3010b559df5SStephen Boyd #define GET_RWVMID(b, n)	 GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWVMID)
3020b559df5SStephen Boyd #define GET_RWE(b, n)		 GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWE)
3030b559df5SStephen Boyd #define GET_RWGE(b, n)		 GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), RWGE)
3040b559df5SStephen Boyd #define GET_CBVMID(b, n)	 GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), CBVMID)
3050b559df5SStephen Boyd #define GET_IRPTNDX(b, n)	 GET_GLOBAL_FIELD(b, (n<<2)|(CBACR_N), IRPTNDX)
3060b559df5SStephen Boyd 
3070b559df5SStephen Boyd 
3080b559df5SStephen Boyd /* M2VCBR_N */
3090b559df5SStephen Boyd #define GET_VMID(b, n)       GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), VMID)
3100b559df5SStephen Boyd #define GET_CBNDX(b, n)      GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), CBNDX)
3110b559df5SStephen Boyd #define GET_BYPASSD(b, n)    GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BYPASSD)
3120b559df5SStephen Boyd #define GET_BPRCOSH(b, n)    GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCOSH)
3130b559df5SStephen Boyd #define GET_BPRCISH(b, n)    GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCISH)
3140b559df5SStephen Boyd #define GET_BPRCNSH(b, n)    GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPRCNSH)
3150b559df5SStephen Boyd #define GET_BPSHCFG(b, n)    GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPSHCFG)
3160b559df5SStephen Boyd #define GET_NSCFG(b, n)      GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), NSCFG)
3170b559df5SStephen Boyd #define GET_BPMTCFG(b, n)    GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMTCFG)
3180b559df5SStephen Boyd #define GET_BPMEMTYPE(b, n)  GET_GLOBAL_FIELD(b, (n<<2)|(M2VCBR_N), BPMEMTYPE)
3190b559df5SStephen Boyd 
3200b559df5SStephen Boyd 
3210b559df5SStephen Boyd /* CR */
3220b559df5SStephen Boyd #define GET_RPUE(b)		 GET_GLOBAL_FIELD(b, CR, RPUE)
3230b559df5SStephen Boyd #define GET_RPUERE(b)		 GET_GLOBAL_FIELD(b, CR, RPUERE)
3240b559df5SStephen Boyd #define GET_RPUEIE(b)		 GET_GLOBAL_FIELD(b, CR, RPUEIE)
3250b559df5SStephen Boyd #define GET_DCDEE(b)		 GET_GLOBAL_FIELD(b, CR, DCDEE)
3260b559df5SStephen Boyd #define GET_CLIENTPD(b)		 GET_GLOBAL_FIELD(b, CR, CLIENTPD)
3270b559df5SStephen Boyd #define GET_STALLD(b)		 GET_GLOBAL_FIELD(b, CR, STALLD)
3280b559df5SStephen Boyd #define GET_TLBLKCRWE(b)	 GET_GLOBAL_FIELD(b, CR, TLBLKCRWE)
3290b559df5SStephen Boyd #define GET_CR_TLBIALLCFG(b)	 GET_GLOBAL_FIELD(b, CR, CR_TLBIALLCFG)
3300b559df5SStephen Boyd #define GET_TLBIVMIDCFG(b)	 GET_GLOBAL_FIELD(b, CR, TLBIVMIDCFG)
3310b559df5SStephen Boyd #define GET_CR_HUME(b)		 GET_GLOBAL_FIELD(b, CR, CR_HUME)
3320b559df5SStephen Boyd 
3330b559df5SStephen Boyd 
3340b559df5SStephen Boyd /* ESR */
3350b559df5SStephen Boyd #define GET_CFG(b)		 GET_GLOBAL_FIELD(b, ESR, CFG)
3360b559df5SStephen Boyd #define GET_BYPASS(b)		 GET_GLOBAL_FIELD(b, ESR, BYPASS)
3370b559df5SStephen Boyd #define GET_ESR_MULTI(b)	 GET_GLOBAL_FIELD(b, ESR, ESR_MULTI)
3380b559df5SStephen Boyd 
3390b559df5SStephen Boyd 
3400b559df5SStephen Boyd /* ESYNR0 */
3410b559df5SStephen Boyd #define GET_ESYNR0_AMID(b)	 GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AMID)
3420b559df5SStephen Boyd #define GET_ESYNR0_APID(b)	 GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_APID)
3430b559df5SStephen Boyd #define GET_ESYNR0_ABID(b)	 GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ABID)
3440b559df5SStephen Boyd #define GET_ESYNR0_AVMID(b)	 GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_AVMID)
3450b559df5SStephen Boyd #define GET_ESYNR0_ATID(b)	 GET_GLOBAL_FIELD(b, ESYNR0, ESYNR0_ATID)
3460b559df5SStephen Boyd 
3470b559df5SStephen Boyd 
3480b559df5SStephen Boyd /* ESYNR1 */
3490b559df5SStephen Boyd #define GET_ESYNR1_AMEMTYPE(b)   GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AMEMTYPE)
3500b559df5SStephen Boyd #define GET_ESYNR1_ASHARED(b)    GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASHARED)
3510b559df5SStephen Boyd #define GET_ESYNR1_AINNERSHARED(b) \
3520b559df5SStephen Boyd 			GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINNERSHARED)
3530b559df5SStephen Boyd #define GET_ESYNR1_APRIV(b)      GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APRIV)
3540b559df5SStephen Boyd #define GET_ESYNR1_APROTNS(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_APROTNS)
3550b559df5SStephen Boyd #define GET_ESYNR1_AINST(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AINST)
3560b559df5SStephen Boyd #define GET_ESYNR1_AWRITE(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AWRITE)
3570b559df5SStephen Boyd #define GET_ESYNR1_ABURST(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ABURST)
3580b559df5SStephen Boyd #define GET_ESYNR1_ALEN(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALEN)
3590b559df5SStephen Boyd #define GET_ESYNR1_ASIZE(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ASIZE)
3600b559df5SStephen Boyd #define GET_ESYNR1_ALOCK(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_ALOCK)
3610b559df5SStephen Boyd #define GET_ESYNR1_AOOO(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AOOO)
3620b559df5SStephen Boyd #define GET_ESYNR1_AFULL(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AFULL)
3630b559df5SStephen Boyd #define GET_ESYNR1_AC(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_AC)
3640b559df5SStephen Boyd #define GET_ESYNR1_DCD(b)	 GET_GLOBAL_FIELD(b, ESYNR1, ESYNR1_DCD)
3650b559df5SStephen Boyd 
3660b559df5SStephen Boyd 
3670b559df5SStephen Boyd /* IDR */
3680b559df5SStephen Boyd #define GET_NM2VCBMT(b)		 GET_GLOBAL_FIELD(b, IDR, NM2VCBMT)
3690b559df5SStephen Boyd #define GET_HTW(b)		 GET_GLOBAL_FIELD(b, IDR, HTW)
3700b559df5SStephen Boyd #define GET_HUM(b)		 GET_GLOBAL_FIELD(b, IDR, HUM)
3710b559df5SStephen Boyd #define GET_TLBSIZE(b)		 GET_GLOBAL_FIELD(b, IDR, TLBSIZE)
3720b559df5SStephen Boyd #define GET_NCB(b)		 GET_GLOBAL_FIELD(b, IDR, NCB)
3730b559df5SStephen Boyd #define GET_NIRPT(b)		 GET_GLOBAL_FIELD(b, IDR, NIRPT)
3740b559df5SStephen Boyd 
3750b559df5SStephen Boyd 
3760b559df5SStephen Boyd /* REV */
3770b559df5SStephen Boyd #define GET_MAJOR(b)		 GET_GLOBAL_FIELD(b, REV, MAJOR)
3780b559df5SStephen Boyd #define GET_MINOR(b)		 GET_GLOBAL_FIELD(b, REV, MINOR)
3790b559df5SStephen Boyd 
3800b559df5SStephen Boyd 
3810b559df5SStephen Boyd /* TESTBUSCR */
3820b559df5SStephen Boyd #define GET_TBE(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, TBE)
3830b559df5SStephen Boyd #define GET_SPDMBE(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, SPDMBE)
3840b559df5SStephen Boyd #define GET_WGSEL(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, WGSEL)
3850b559df5SStephen Boyd #define GET_TBLSEL(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, TBLSEL)
3860b559df5SStephen Boyd #define GET_TBHSEL(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, TBHSEL)
3870b559df5SStephen Boyd #define GET_SPDM0SEL(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM0SEL)
3880b559df5SStephen Boyd #define GET_SPDM1SEL(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM1SEL)
3890b559df5SStephen Boyd #define GET_SPDM2SEL(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM2SEL)
3900b559df5SStephen Boyd #define GET_SPDM3SEL(b)		 GET_GLOBAL_FIELD(b, TESTBUSCR, SPDM3SEL)
3910b559df5SStephen Boyd 
3920b559df5SStephen Boyd 
3930b559df5SStephen Boyd /* TLBIVMID */
3940b559df5SStephen Boyd #define GET_TLBIVMID_VMID(b)	 GET_GLOBAL_FIELD(b, TLBIVMID, TLBIVMID_VMID)
3950b559df5SStephen Boyd 
3960b559df5SStephen Boyd 
3970b559df5SStephen Boyd /* TLBTR0 */
3980b559df5SStephen Boyd #define GET_PR(b)		 GET_GLOBAL_FIELD(b, TLBTR0, PR)
3990b559df5SStephen Boyd #define GET_PW(b)		 GET_GLOBAL_FIELD(b, TLBTR0, PW)
4000b559df5SStephen Boyd #define GET_UR(b)		 GET_GLOBAL_FIELD(b, TLBTR0, UR)
4010b559df5SStephen Boyd #define GET_UW(b)		 GET_GLOBAL_FIELD(b, TLBTR0, UW)
4020b559df5SStephen Boyd #define GET_XN(b)		 GET_GLOBAL_FIELD(b, TLBTR0, XN)
4030b559df5SStephen Boyd #define GET_NSDESC(b)		 GET_GLOBAL_FIELD(b, TLBTR0, NSDESC)
4040b559df5SStephen Boyd #define GET_ISH(b)		 GET_GLOBAL_FIELD(b, TLBTR0, ISH)
4050b559df5SStephen Boyd #define GET_SH(b)		 GET_GLOBAL_FIELD(b, TLBTR0, SH)
4060b559df5SStephen Boyd #define GET_MT(b)		 GET_GLOBAL_FIELD(b, TLBTR0, MT)
4070b559df5SStephen Boyd #define GET_DPSIZR(b)		 GET_GLOBAL_FIELD(b, TLBTR0, DPSIZR)
4080b559df5SStephen Boyd #define GET_DPSIZC(b)		 GET_GLOBAL_FIELD(b, TLBTR0, DPSIZC)
4090b559df5SStephen Boyd 
4100b559df5SStephen Boyd 
4110b559df5SStephen Boyd /* TLBTR1 */
4120b559df5SStephen Boyd #define GET_TLBTR1_VMID(b)	 GET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_VMID)
4130b559df5SStephen Boyd #define GET_TLBTR1_PA(b)	 GET_GLOBAL_FIELD(b, TLBTR1, TLBTR1_PA)
4140b559df5SStephen Boyd 
4150b559df5SStephen Boyd 
4160b559df5SStephen Boyd /* TLBTR2 */
4170b559df5SStephen Boyd #define GET_TLBTR2_ASID(b)	 GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_ASID)
4180b559df5SStephen Boyd #define GET_TLBTR2_V(b)		 GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_V)
4190b559df5SStephen Boyd #define GET_TLBTR2_NSTID(b)	 GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NSTID)
4200b559df5SStephen Boyd #define GET_TLBTR2_NV(b)	 GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_NV)
4210b559df5SStephen Boyd #define GET_TLBTR2_VA(b)	 GET_GLOBAL_FIELD(b, TLBTR2, TLBTR2_VA)
4220b559df5SStephen Boyd 
4230b559df5SStephen Boyd 
4240b559df5SStephen Boyd /* Context Register setters / getters */
4250b559df5SStephen Boyd /* Context Register setters */
4260b559df5SStephen Boyd /* ACTLR */
4270b559df5SStephen Boyd #define SET_CFERE(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, CFERE, v)
4280b559df5SStephen Boyd #define SET_CFEIE(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, CFEIE, v)
4290b559df5SStephen Boyd #define SET_PTSHCFG(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, PTSHCFG, v)
4300b559df5SStephen Boyd #define SET_RCOSH(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, RCOSH, v)
4310b559df5SStephen Boyd #define SET_RCISH(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, RCISH, v)
4320b559df5SStephen Boyd #define SET_RCNSH(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, RCNSH, v)
4330b559df5SStephen Boyd #define SET_PRIVCFG(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, PRIVCFG, v)
4340b559df5SStephen Boyd #define SET_DNA(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, DNA, v)
4350b559df5SStephen Boyd #define SET_DNLV2PA(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, DNLV2PA, v)
4360b559df5SStephen Boyd #define SET_TLBMCFG(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, TLBMCFG, v)
4370b559df5SStephen Boyd #define SET_CFCFG(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, CFCFG, v)
4380b559df5SStephen Boyd #define SET_TIPCF(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, TIPCF, v)
4390b559df5SStephen Boyd #define SET_V2PCFG(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, V2PCFG, v)
4400b559df5SStephen Boyd #define SET_HUME(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, HUME, v)
4410b559df5SStephen Boyd #define SET_PTMTCFG(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, PTMTCFG, v)
4420b559df5SStephen Boyd #define SET_PTMEMTYPE(b, c, v)	 SET_CONTEXT_FIELD(b, c, ACTLR, PTMEMTYPE, v)
4430b559df5SStephen Boyd 
4440b559df5SStephen Boyd 
4450b559df5SStephen Boyd /* BFBCR */
4460b559df5SStephen Boyd #define SET_BFBDFE(b, c, v)	 SET_CONTEXT_FIELD(b, c, BFBCR, BFBDFE, v)
4470b559df5SStephen Boyd #define SET_BFBSFE(b, c, v)	 SET_CONTEXT_FIELD(b, c, BFBCR, BFBSFE, v)
4480b559df5SStephen Boyd #define SET_SFVS(b, c, v)	 SET_CONTEXT_FIELD(b, c, BFBCR, SFVS, v)
4490b559df5SStephen Boyd #define SET_FLVIC(b, c, v)	 SET_CONTEXT_FIELD(b, c, BFBCR, FLVIC, v)
4500b559df5SStephen Boyd #define SET_SLVIC(b, c, v)	 SET_CONTEXT_FIELD(b, c, BFBCR, SLVIC, v)
4510b559df5SStephen Boyd 
4520b559df5SStephen Boyd 
4530b559df5SStephen Boyd /* CONTEXTIDR */
4540b559df5SStephen Boyd #define SET_CONTEXTIDR_ASID(b, c, v)   \
4550b559df5SStephen Boyd 		SET_CONTEXT_FIELD(b, c, CONTEXTIDR, CONTEXTIDR_ASID, v)
4560b559df5SStephen Boyd #define SET_CONTEXTIDR_PROCID(b, c, v) \
4570b559df5SStephen Boyd 		SET_CONTEXT_FIELD(b, c, CONTEXTIDR, PROCID, v)
4580b559df5SStephen Boyd 
4590b559df5SStephen Boyd 
4600b559df5SStephen Boyd /* FSR */
4610b559df5SStephen Boyd #define SET_TF(b, c, v)		 SET_CONTEXT_FIELD(b, c, FSR, TF, v)
4620b559df5SStephen Boyd #define SET_AFF(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSR, AFF, v)
4630b559df5SStephen Boyd #define SET_APF(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSR, APF, v)
4640b559df5SStephen Boyd #define SET_TLBMF(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSR, TLBMF, v)
4650b559df5SStephen Boyd #define SET_HTWDEEF(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSR, HTWDEEF, v)
4660b559df5SStephen Boyd #define SET_HTWSEEF(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSR, HTWSEEF, v)
4670b559df5SStephen Boyd #define SET_MHF(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSR, MHF, v)
4680b559df5SStephen Boyd #define SET_SL(b, c, v)		 SET_CONTEXT_FIELD(b, c, FSR, SL, v)
4690b559df5SStephen Boyd #define SET_SS(b, c, v)		 SET_CONTEXT_FIELD(b, c, FSR, SS, v)
4700b559df5SStephen Boyd #define SET_MULTI(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSR, MULTI, v)
4710b559df5SStephen Boyd 
4720b559df5SStephen Boyd 
4730b559df5SStephen Boyd /* FSYNR0 */
4740b559df5SStephen Boyd #define SET_AMID(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR0, AMID, v)
4750b559df5SStephen Boyd #define SET_APID(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR0, APID, v)
4760b559df5SStephen Boyd #define SET_ABID(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR0, ABID, v)
4770b559df5SStephen Boyd #define SET_ATID(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR0, ATID, v)
4780b559df5SStephen Boyd 
4790b559df5SStephen Boyd 
4800b559df5SStephen Boyd /* FSYNR1 */
4810b559df5SStephen Boyd #define SET_AMEMTYPE(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, AMEMTYPE, v)
4820b559df5SStephen Boyd #define SET_ASHARED(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, ASHARED, v)
4830b559df5SStephen Boyd #define SET_AINNERSHARED(b, c, v)  \
4840b559df5SStephen Boyd 				SET_CONTEXT_FIELD(b, c, FSYNR1, AINNERSHARED, v)
4850b559df5SStephen Boyd #define SET_APRIV(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, APRIV, v)
4860b559df5SStephen Boyd #define SET_APROTNS(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, APROTNS, v)
4870b559df5SStephen Boyd #define SET_AINST(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, AINST, v)
4880b559df5SStephen Boyd #define SET_AWRITE(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, AWRITE, v)
4890b559df5SStephen Boyd #define SET_ABURST(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, ABURST, v)
4900b559df5SStephen Boyd #define SET_ALEN(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, ALEN, v)
4910b559df5SStephen Boyd #define SET_FSYNR1_ASIZE(b, c, v) \
4920b559df5SStephen Boyd 				SET_CONTEXT_FIELD(b, c, FSYNR1, FSYNR1_ASIZE, v)
4930b559df5SStephen Boyd #define SET_ALOCK(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, ALOCK, v)
4940b559df5SStephen Boyd #define SET_AFULL(b, c, v)	 SET_CONTEXT_FIELD(b, c, FSYNR1, AFULL, v)
4950b559df5SStephen Boyd 
4960b559df5SStephen Boyd 
4970b559df5SStephen Boyd /* NMRR */
4980b559df5SStephen Boyd #define SET_ICPC0(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC0, v)
4990b559df5SStephen Boyd #define SET_ICPC1(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC1, v)
5000b559df5SStephen Boyd #define SET_ICPC2(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC2, v)
5010b559df5SStephen Boyd #define SET_ICPC3(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC3, v)
5020b559df5SStephen Boyd #define SET_ICPC4(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC4, v)
5030b559df5SStephen Boyd #define SET_ICPC5(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC5, v)
5040b559df5SStephen Boyd #define SET_ICPC6(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC6, v)
5050b559df5SStephen Boyd #define SET_ICPC7(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, ICPC7, v)
5060b559df5SStephen Boyd #define SET_OCPC0(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC0, v)
5070b559df5SStephen Boyd #define SET_OCPC1(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC1, v)
5080b559df5SStephen Boyd #define SET_OCPC2(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC2, v)
5090b559df5SStephen Boyd #define SET_OCPC3(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC3, v)
5100b559df5SStephen Boyd #define SET_OCPC4(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC4, v)
5110b559df5SStephen Boyd #define SET_OCPC5(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC5, v)
5120b559df5SStephen Boyd #define SET_OCPC6(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC6, v)
5130b559df5SStephen Boyd #define SET_OCPC7(b, c, v)	 SET_CONTEXT_FIELD(b, c, NMRR, OCPC7, v)
5140b559df5SStephen Boyd 
5150b559df5SStephen Boyd 
5160b559df5SStephen Boyd /* PAR */
5170b559df5SStephen Boyd #define SET_FAULT(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, FAULT, v)
5180b559df5SStephen Boyd 
5190b559df5SStephen Boyd #define SET_FAULT_TF(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, FAULT_TF, v)
5200b559df5SStephen Boyd #define SET_FAULT_AFF(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, FAULT_AFF, v)
5210b559df5SStephen Boyd #define SET_FAULT_APF(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, FAULT_APF, v)
5220b559df5SStephen Boyd #define SET_FAULT_TLBMF(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, FAULT_TLBMF, v)
5230b559df5SStephen Boyd #define SET_FAULT_HTWDEEF(b, c, v) \
5240b559df5SStephen Boyd 				SET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWDEEF, v)
5250b559df5SStephen Boyd #define SET_FAULT_HTWSEEF(b, c, v) \
5260b559df5SStephen Boyd 				SET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWSEEF, v)
5270b559df5SStephen Boyd #define SET_FAULT_MHF(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, FAULT_MHF, v)
5280b559df5SStephen Boyd #define SET_FAULT_SL(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, FAULT_SL, v)
5290b559df5SStephen Boyd #define SET_FAULT_SS(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, FAULT_SS, v)
5300b559df5SStephen Boyd 
5310b559df5SStephen Boyd #define SET_NOFAULT_SS(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_SS, v)
5320b559df5SStephen Boyd #define SET_NOFAULT_MT(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_MT, v)
5330b559df5SStephen Boyd #define SET_NOFAULT_SH(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_SH, v)
5340b559df5SStephen Boyd #define SET_NOFAULT_NS(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_NS, v)
5350b559df5SStephen Boyd #define SET_NOFAULT_NOS(b, c, v) SET_CONTEXT_FIELD(b, c, PAR, NOFAULT_NOS, v)
5360b559df5SStephen Boyd #define SET_NPFAULT_PA(b, c, v)	 SET_CONTEXT_FIELD(b, c, PAR, NPFAULT_PA, v)
5370b559df5SStephen Boyd 
5380b559df5SStephen Boyd 
5390b559df5SStephen Boyd /* PRRR */
5400b559df5SStephen Boyd #define SET_MTC0(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC0, v)
5410b559df5SStephen Boyd #define SET_MTC1(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC1, v)
5420b559df5SStephen Boyd #define SET_MTC2(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC2, v)
5430b559df5SStephen Boyd #define SET_MTC3(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC3, v)
5440b559df5SStephen Boyd #define SET_MTC4(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC4, v)
5450b559df5SStephen Boyd #define SET_MTC5(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC5, v)
5460b559df5SStephen Boyd #define SET_MTC6(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC6, v)
5470b559df5SStephen Boyd #define SET_MTC7(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, MTC7, v)
5480b559df5SStephen Boyd #define SET_SHDSH0(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, SHDSH0, v)
5490b559df5SStephen Boyd #define SET_SHDSH1(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, SHDSH1, v)
5500b559df5SStephen Boyd #define SET_SHNMSH0(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, SHNMSH0, v)
5510b559df5SStephen Boyd #define SET_SHNMSH1(b, c, v)     SET_CONTEXT_FIELD(b, c, PRRR, SHNMSH1, v)
5520b559df5SStephen Boyd #define SET_NOS0(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS0, v)
5530b559df5SStephen Boyd #define SET_NOS1(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS1, v)
5540b559df5SStephen Boyd #define SET_NOS2(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS2, v)
5550b559df5SStephen Boyd #define SET_NOS3(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS3, v)
5560b559df5SStephen Boyd #define SET_NOS4(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS4, v)
5570b559df5SStephen Boyd #define SET_NOS5(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS5, v)
5580b559df5SStephen Boyd #define SET_NOS6(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS6, v)
5590b559df5SStephen Boyd #define SET_NOS7(b, c, v)	 SET_CONTEXT_FIELD(b, c, PRRR, NOS7, v)
5600b559df5SStephen Boyd 
5610b559df5SStephen Boyd 
5620b559df5SStephen Boyd /* RESUME */
5630b559df5SStephen Boyd #define SET_TNR(b, c, v)	 SET_CONTEXT_FIELD(b, c, RESUME, TNR, v)
5640b559df5SStephen Boyd 
5650b559df5SStephen Boyd 
5660b559df5SStephen Boyd /* SCTLR */
5670b559df5SStephen Boyd #define SET_M(b, c, v)		 SET_CONTEXT_FIELD(b, c, SCTLR, M, v)
5680b559df5SStephen Boyd #define SET_TRE(b, c, v)	 SET_CONTEXT_FIELD(b, c, SCTLR, TRE, v)
5690b559df5SStephen Boyd #define SET_AFE(b, c, v)	 SET_CONTEXT_FIELD(b, c, SCTLR, AFE, v)
5700b559df5SStephen Boyd #define SET_HAF(b, c, v)	 SET_CONTEXT_FIELD(b, c, SCTLR, HAF, v)
5710b559df5SStephen Boyd #define SET_BE(b, c, v)		 SET_CONTEXT_FIELD(b, c, SCTLR, BE, v)
5720b559df5SStephen Boyd #define SET_AFFD(b, c, v)	 SET_CONTEXT_FIELD(b, c, SCTLR, AFFD, v)
5730b559df5SStephen Boyd 
5740b559df5SStephen Boyd 
5750b559df5SStephen Boyd /* TLBLKCR */
5760b559df5SStephen Boyd #define SET_LKE(b, c, v)	   SET_CONTEXT_FIELD(b, c, TLBLKCR, LKE, v)
5770b559df5SStephen Boyd #define SET_TLBLKCR_TLBIALLCFG(b, c, v) \
5780b559df5SStephen Boyd 			SET_CONTEXT_FIELD(b, c, TLBLKCR, TLBLCKR_TLBIALLCFG, v)
5790b559df5SStephen Boyd #define SET_TLBIASIDCFG(b, c, v) \
5800b559df5SStephen Boyd 			SET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIASIDCFG, v)
5810b559df5SStephen Boyd #define SET_TLBIVAACFG(b, c, v)	SET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIVAACFG, v)
5820b559df5SStephen Boyd #define SET_FLOOR(b, c, v)	SET_CONTEXT_FIELD(b, c, TLBLKCR, FLOOR, v)
5830b559df5SStephen Boyd #define SET_VICTIM(b, c, v)	SET_CONTEXT_FIELD(b, c, TLBLKCR, VICTIM, v)
5840b559df5SStephen Boyd 
5850b559df5SStephen Boyd 
5860b559df5SStephen Boyd /* TTBCR */
5870b559df5SStephen Boyd #define SET_N(b, c, v)	         SET_CONTEXT_FIELD(b, c, TTBCR, N, v)
5880b559df5SStephen Boyd #define SET_PD0(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBCR, PD0, v)
5890b559df5SStephen Boyd #define SET_PD1(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBCR, PD1, v)
5900b559df5SStephen Boyd 
5910b559df5SStephen Boyd 
5920b559df5SStephen Boyd /* TTBR0 */
5930b559df5SStephen Boyd #define SET_TTBR0_IRGNH(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNH, v)
5940b559df5SStephen Boyd #define SET_TTBR0_SH(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_SH, v)
5950b559df5SStephen Boyd #define SET_TTBR0_ORGN(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_ORGN, v)
5960b559df5SStephen Boyd #define SET_TTBR0_NOS(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_NOS, v)
5970b559df5SStephen Boyd #define SET_TTBR0_IRGNL(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNL, v)
5980b559df5SStephen Boyd #define SET_TTBR0_PA(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_PA, v)
5990b559df5SStephen Boyd 
6000b559df5SStephen Boyd 
6010b559df5SStephen Boyd /* TTBR1 */
6020b559df5SStephen Boyd #define SET_TTBR1_IRGNH(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNH, v)
6030b559df5SStephen Boyd #define SET_TTBR1_SH(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_SH, v)
6040b559df5SStephen Boyd #define SET_TTBR1_ORGN(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_ORGN, v)
6050b559df5SStephen Boyd #define SET_TTBR1_NOS(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_NOS, v)
6060b559df5SStephen Boyd #define SET_TTBR1_IRGNL(b, c, v) SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNL, v)
6070b559df5SStephen Boyd #define SET_TTBR1_PA(b, c, v)	 SET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_PA, v)
6080b559df5SStephen Boyd 
6090b559df5SStephen Boyd 
6100b559df5SStephen Boyd /* V2PSR */
6110b559df5SStephen Boyd #define SET_HIT(b, c, v)	 SET_CONTEXT_FIELD(b, c, V2PSR, HIT, v)
6120b559df5SStephen Boyd #define SET_INDEX(b, c, v)	 SET_CONTEXT_FIELD(b, c, V2PSR, INDEX, v)
6130b559df5SStephen Boyd 
6140b559df5SStephen Boyd 
6150b559df5SStephen Boyd /* Context Register getters */
6160b559df5SStephen Boyd /* ACTLR */
6170b559df5SStephen Boyd #define GET_CFERE(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, CFERE)
6180b559df5SStephen Boyd #define GET_CFEIE(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, CFEIE)
6190b559df5SStephen Boyd #define GET_PTSHCFG(b, c)       GET_CONTEXT_FIELD(b, c, ACTLR, PTSHCFG)
6200b559df5SStephen Boyd #define GET_RCOSH(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, RCOSH)
6210b559df5SStephen Boyd #define GET_RCISH(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, RCISH)
6220b559df5SStephen Boyd #define GET_RCNSH(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, RCNSH)
6230b559df5SStephen Boyd #define GET_PRIVCFG(b, c)       GET_CONTEXT_FIELD(b, c, ACTLR, PRIVCFG)
6240b559df5SStephen Boyd #define GET_DNA(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, DNA)
6250b559df5SStephen Boyd #define GET_DNLV2PA(b, c)       GET_CONTEXT_FIELD(b, c, ACTLR, DNLV2PA)
6260b559df5SStephen Boyd #define GET_TLBMCFG(b, c)       GET_CONTEXT_FIELD(b, c, ACTLR, TLBMCFG)
6270b559df5SStephen Boyd #define GET_CFCFG(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, CFCFG)
6280b559df5SStephen Boyd #define GET_TIPCF(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, TIPCF)
6290b559df5SStephen Boyd #define GET_V2PCFG(b, c)        GET_CONTEXT_FIELD(b, c, ACTLR, V2PCFG)
6300b559df5SStephen Boyd #define GET_HUME(b, c)	        GET_CONTEXT_FIELD(b, c, ACTLR, HUME)
6310b559df5SStephen Boyd #define GET_PTMTCFG(b, c)       GET_CONTEXT_FIELD(b, c, ACTLR, PTMTCFG)
6320b559df5SStephen Boyd #define GET_PTMEMTYPE(b, c)     GET_CONTEXT_FIELD(b, c, ACTLR, PTMEMTYPE)
6330b559df5SStephen Boyd 
6340b559df5SStephen Boyd /* BFBCR */
6350b559df5SStephen Boyd #define GET_BFBDFE(b, c)	GET_CONTEXT_FIELD(b, c, BFBCR, BFBDFE)
6360b559df5SStephen Boyd #define GET_BFBSFE(b, c)	GET_CONTEXT_FIELD(b, c, BFBCR, BFBSFE)
6370b559df5SStephen Boyd #define GET_SFVS(b, c)		GET_CONTEXT_FIELD(b, c, BFBCR, SFVS)
6380b559df5SStephen Boyd #define GET_FLVIC(b, c)		GET_CONTEXT_FIELD(b, c, BFBCR, FLVIC)
6390b559df5SStephen Boyd #define GET_SLVIC(b, c)		GET_CONTEXT_FIELD(b, c, BFBCR, SLVIC)
6400b559df5SStephen Boyd 
6410b559df5SStephen Boyd 
6420b559df5SStephen Boyd /* CONTEXTIDR */
6430b559df5SStephen Boyd #define GET_CONTEXTIDR_ASID(b, c) \
6440b559df5SStephen Boyd 			GET_CONTEXT_FIELD(b, c, CONTEXTIDR, CONTEXTIDR_ASID)
6450b559df5SStephen Boyd #define GET_CONTEXTIDR_PROCID(b, c) GET_CONTEXT_FIELD(b, c, CONTEXTIDR, PROCID)
6460b559df5SStephen Boyd 
6470b559df5SStephen Boyd 
6480b559df5SStephen Boyd /* FSR */
6490b559df5SStephen Boyd #define GET_TF(b, c)		GET_CONTEXT_FIELD(b, c, FSR, TF)
6500b559df5SStephen Boyd #define GET_AFF(b, c)		GET_CONTEXT_FIELD(b, c, FSR, AFF)
6510b559df5SStephen Boyd #define GET_APF(b, c)		GET_CONTEXT_FIELD(b, c, FSR, APF)
6520b559df5SStephen Boyd #define GET_TLBMF(b, c)		GET_CONTEXT_FIELD(b, c, FSR, TLBMF)
6530b559df5SStephen Boyd #define GET_HTWDEEF(b, c)	GET_CONTEXT_FIELD(b, c, FSR, HTWDEEF)
6540b559df5SStephen Boyd #define GET_HTWSEEF(b, c)	GET_CONTEXT_FIELD(b, c, FSR, HTWSEEF)
6550b559df5SStephen Boyd #define GET_MHF(b, c)		GET_CONTEXT_FIELD(b, c, FSR, MHF)
6560b559df5SStephen Boyd #define GET_SL(b, c)		GET_CONTEXT_FIELD(b, c, FSR, SL)
6570b559df5SStephen Boyd #define GET_SS(b, c)		GET_CONTEXT_FIELD(b, c, FSR, SS)
6580b559df5SStephen Boyd #define GET_MULTI(b, c)		GET_CONTEXT_FIELD(b, c, FSR, MULTI)
6590b559df5SStephen Boyd 
6600b559df5SStephen Boyd 
6610b559df5SStephen Boyd /* FSYNR0 */
6620b559df5SStephen Boyd #define GET_AMID(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR0, AMID)
6630b559df5SStephen Boyd #define GET_APID(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR0, APID)
6640b559df5SStephen Boyd #define GET_ABID(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR0, ABID)
6650b559df5SStephen Boyd #define GET_ATID(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR0, ATID)
6660b559df5SStephen Boyd 
6670b559df5SStephen Boyd 
6680b559df5SStephen Boyd /* FSYNR1 */
6690b559df5SStephen Boyd #define GET_AMEMTYPE(b, c)	GET_CONTEXT_FIELD(b, c, FSYNR1, AMEMTYPE)
6700b559df5SStephen Boyd #define GET_ASHARED(b, c)	GET_CONTEXT_FIELD(b, c, FSYNR1, ASHARED)
6710b559df5SStephen Boyd #define GET_AINNERSHARED(b, c)  GET_CONTEXT_FIELD(b, c, FSYNR1, AINNERSHARED)
6720b559df5SStephen Boyd #define GET_APRIV(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR1, APRIV)
6730b559df5SStephen Boyd #define GET_APROTNS(b, c)	GET_CONTEXT_FIELD(b, c, FSYNR1, APROTNS)
6740b559df5SStephen Boyd #define GET_AINST(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR1, AINST)
6750b559df5SStephen Boyd #define GET_AWRITE(b, c)	GET_CONTEXT_FIELD(b, c, FSYNR1, AWRITE)
6760b559df5SStephen Boyd #define GET_ABURST(b, c)	GET_CONTEXT_FIELD(b, c, FSYNR1, ABURST)
6770b559df5SStephen Boyd #define GET_ALEN(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR1, ALEN)
6780b559df5SStephen Boyd #define GET_FSYNR1_ASIZE(b, c)	GET_CONTEXT_FIELD(b, c, FSYNR1, FSYNR1_ASIZE)
6790b559df5SStephen Boyd #define GET_ALOCK(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR1, ALOCK)
6800b559df5SStephen Boyd #define GET_AFULL(b, c)		GET_CONTEXT_FIELD(b, c, FSYNR1, AFULL)
6810b559df5SStephen Boyd 
6820b559df5SStephen Boyd 
6830b559df5SStephen Boyd /* NMRR */
6840b559df5SStephen Boyd #define GET_ICPC0(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC0)
6850b559df5SStephen Boyd #define GET_ICPC1(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC1)
6860b559df5SStephen Boyd #define GET_ICPC2(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC2)
6870b559df5SStephen Boyd #define GET_ICPC3(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC3)
6880b559df5SStephen Boyd #define GET_ICPC4(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC4)
6890b559df5SStephen Boyd #define GET_ICPC5(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC5)
6900b559df5SStephen Boyd #define GET_ICPC6(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC6)
6910b559df5SStephen Boyd #define GET_ICPC7(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, ICPC7)
6920b559df5SStephen Boyd #define GET_OCPC0(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC0)
6930b559df5SStephen Boyd #define GET_OCPC1(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC1)
6940b559df5SStephen Boyd #define GET_OCPC2(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC2)
6950b559df5SStephen Boyd #define GET_OCPC3(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC3)
6960b559df5SStephen Boyd #define GET_OCPC4(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC4)
6970b559df5SStephen Boyd #define GET_OCPC5(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC5)
6980b559df5SStephen Boyd #define GET_OCPC6(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC6)
6990b559df5SStephen Boyd #define GET_OCPC7(b, c)		GET_CONTEXT_FIELD(b, c, NMRR, OCPC7)
7000b559df5SStephen Boyd #define NMRR_ICP(nmrr, n)	(((nmrr) & (3 << ((n) * 2))) >> ((n) * 2))
7010b559df5SStephen Boyd #define NMRR_OCP(nmrr, n)	(((nmrr) & (3 << ((n) * 2 + 16))) >> \
7020b559df5SStephen Boyd 								((n) * 2 + 16))
7030b559df5SStephen Boyd 
7040b559df5SStephen Boyd /* PAR */
7050b559df5SStephen Boyd #define GET_FAULT(b, c)		GET_CONTEXT_FIELD(b, c, PAR, FAULT)
7060b559df5SStephen Boyd 
7070b559df5SStephen Boyd #define GET_FAULT_TF(b, c)	GET_CONTEXT_FIELD(b, c, PAR, FAULT_TF)
7080b559df5SStephen Boyd #define GET_FAULT_AFF(b, c)	GET_CONTEXT_FIELD(b, c, PAR, FAULT_AFF)
7090b559df5SStephen Boyd #define GET_FAULT_APF(b, c)	GET_CONTEXT_FIELD(b, c, PAR, FAULT_APF)
7100b559df5SStephen Boyd #define GET_FAULT_TLBMF(b, c)   GET_CONTEXT_FIELD(b, c, PAR, FAULT_TLBMF)
7110b559df5SStephen Boyd #define GET_FAULT_HTWDEEF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWDEEF)
7120b559df5SStephen Boyd #define GET_FAULT_HTWSEEF(b, c) GET_CONTEXT_FIELD(b, c, PAR, FAULT_HTWSEEF)
7130b559df5SStephen Boyd #define GET_FAULT_MHF(b, c)	GET_CONTEXT_FIELD(b, c, PAR, FAULT_MHF)
7140b559df5SStephen Boyd #define GET_FAULT_SL(b, c)	GET_CONTEXT_FIELD(b, c, PAR, FAULT_SL)
7150b559df5SStephen Boyd #define GET_FAULT_SS(b, c)	GET_CONTEXT_FIELD(b, c, PAR, FAULT_SS)
7160b559df5SStephen Boyd 
7170b559df5SStephen Boyd #define GET_NOFAULT_SS(b, c)	GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_SS)
7180b559df5SStephen Boyd #define GET_NOFAULT_MT(b, c)	GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_MT)
7190b559df5SStephen Boyd #define GET_NOFAULT_SH(b, c)	GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_SH)
7200b559df5SStephen Boyd #define GET_NOFAULT_NS(b, c)	GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_NS)
7210b559df5SStephen Boyd #define GET_NOFAULT_NOS(b, c)   GET_CONTEXT_FIELD(b, c, PAR, PAR_NOFAULT_NOS)
7220b559df5SStephen Boyd #define GET_NPFAULT_PA(b, c)	GET_CONTEXT_FIELD(b, c, PAR, PAR_NPFAULT_PA)
7230b559df5SStephen Boyd 
7240b559df5SStephen Boyd 
7250b559df5SStephen Boyd /* PRRR */
7260b559df5SStephen Boyd #define GET_MTC0(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC0)
7270b559df5SStephen Boyd #define GET_MTC1(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC1)
7280b559df5SStephen Boyd #define GET_MTC2(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC2)
7290b559df5SStephen Boyd #define GET_MTC3(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC3)
7300b559df5SStephen Boyd #define GET_MTC4(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC4)
7310b559df5SStephen Boyd #define GET_MTC5(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC5)
7320b559df5SStephen Boyd #define GET_MTC6(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC6)
7330b559df5SStephen Boyd #define GET_MTC7(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, MTC7)
7340b559df5SStephen Boyd #define GET_SHDSH0(b, c)	GET_CONTEXT_FIELD(b, c, PRRR, SHDSH0)
7350b559df5SStephen Boyd #define GET_SHDSH1(b, c)	GET_CONTEXT_FIELD(b, c, PRRR, SHDSH1)
7360b559df5SStephen Boyd #define GET_SHNMSH0(b, c)	GET_CONTEXT_FIELD(b, c, PRRR, SHNMSH0)
7370b559df5SStephen Boyd #define GET_SHNMSH1(b, c)	GET_CONTEXT_FIELD(b, c, PRRR, SHNMSH1)
7380b559df5SStephen Boyd #define GET_NOS0(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS0)
7390b559df5SStephen Boyd #define GET_NOS1(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS1)
7400b559df5SStephen Boyd #define GET_NOS2(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS2)
7410b559df5SStephen Boyd #define GET_NOS3(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS3)
7420b559df5SStephen Boyd #define GET_NOS4(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS4)
7430b559df5SStephen Boyd #define GET_NOS5(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS5)
7440b559df5SStephen Boyd #define GET_NOS6(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS6)
7450b559df5SStephen Boyd #define GET_NOS7(b, c)		GET_CONTEXT_FIELD(b, c, PRRR, NOS7)
7460b559df5SStephen Boyd #define PRRR_NOS(prrr, n)	 ((prrr) & (1 << ((n) + 24)) ? 1 : 0)
7470b559df5SStephen Boyd #define PRRR_MT(prrr, n)	 ((((prrr) & (3 << ((n) * 2))) >> ((n) * 2)))
7480b559df5SStephen Boyd 
7490b559df5SStephen Boyd 
7500b559df5SStephen Boyd /* RESUME */
7510b559df5SStephen Boyd #define GET_TNR(b, c)		GET_CONTEXT_FIELD(b, c, RESUME, TNR)
7520b559df5SStephen Boyd 
7530b559df5SStephen Boyd 
7540b559df5SStephen Boyd /* SCTLR */
7550b559df5SStephen Boyd #define GET_M(b, c)		GET_CONTEXT_FIELD(b, c, SCTLR, M)
7560b559df5SStephen Boyd #define GET_TRE(b, c)		GET_CONTEXT_FIELD(b, c, SCTLR, TRE)
7570b559df5SStephen Boyd #define GET_AFE(b, c)		GET_CONTEXT_FIELD(b, c, SCTLR, AFE)
7580b559df5SStephen Boyd #define GET_HAF(b, c)		GET_CONTEXT_FIELD(b, c, SCTLR, HAF)
7590b559df5SStephen Boyd #define GET_BE(b, c)		GET_CONTEXT_FIELD(b, c, SCTLR, BE)
7600b559df5SStephen Boyd #define GET_AFFD(b, c)		GET_CONTEXT_FIELD(b, c, SCTLR, AFFD)
7610b559df5SStephen Boyd 
7620b559df5SStephen Boyd 
7630b559df5SStephen Boyd /* TLBLKCR */
7640b559df5SStephen Boyd #define GET_LKE(b, c)		GET_CONTEXT_FIELD(b, c, TLBLKCR, LKE)
7650b559df5SStephen Boyd #define GET_TLBLCKR_TLBIALLCFG(b, c) \
7660b559df5SStephen Boyd 			GET_CONTEXT_FIELD(b, c, TLBLKCR, TLBLCKR_TLBIALLCFG)
7670b559df5SStephen Boyd #define GET_TLBIASIDCFG(b, c)   GET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIASIDCFG)
7680b559df5SStephen Boyd #define GET_TLBIVAACFG(b, c)	GET_CONTEXT_FIELD(b, c, TLBLKCR, TLBIVAACFG)
7690b559df5SStephen Boyd #define GET_FLOOR(b, c)		GET_CONTEXT_FIELD(b, c, TLBLKCR, FLOOR)
7700b559df5SStephen Boyd #define GET_VICTIM(b, c)	GET_CONTEXT_FIELD(b, c, TLBLKCR, VICTIM)
7710b559df5SStephen Boyd 
7720b559df5SStephen Boyd 
7730b559df5SStephen Boyd /* TTBCR */
7740b559df5SStephen Boyd #define GET_N(b, c)		GET_CONTEXT_FIELD(b, c, TTBCR, N)
7750b559df5SStephen Boyd #define GET_PD0(b, c)		GET_CONTEXT_FIELD(b, c, TTBCR, PD0)
7760b559df5SStephen Boyd #define GET_PD1(b, c)		GET_CONTEXT_FIELD(b, c, TTBCR, PD1)
7770b559df5SStephen Boyd 
7780b559df5SStephen Boyd 
7790b559df5SStephen Boyd /* TTBR0 */
7800b559df5SStephen Boyd #define GET_TTBR0_IRGNH(b, c)	GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNH)
7810b559df5SStephen Boyd #define GET_TTBR0_SH(b, c)	GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_SH)
7820b559df5SStephen Boyd #define GET_TTBR0_ORGN(b, c)	GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_ORGN)
7830b559df5SStephen Boyd #define GET_TTBR0_NOS(b, c)	GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_NOS)
7840b559df5SStephen Boyd #define GET_TTBR0_IRGNL(b, c)	GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_IRGNL)
7850b559df5SStephen Boyd #define GET_TTBR0_PA(b, c)	GET_CONTEXT_FIELD(b, c, TTBR0, TTBR0_PA)
7860b559df5SStephen Boyd 
7870b559df5SStephen Boyd 
7880b559df5SStephen Boyd /* TTBR1 */
7890b559df5SStephen Boyd #define GET_TTBR1_IRGNH(b, c)	GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNH)
7900b559df5SStephen Boyd #define GET_TTBR1_SH(b, c)	GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_SH)
7910b559df5SStephen Boyd #define GET_TTBR1_ORGN(b, c)	GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_ORGN)
7920b559df5SStephen Boyd #define GET_TTBR1_NOS(b, c)	GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_NOS)
7930b559df5SStephen Boyd #define GET_TTBR1_IRGNL(b, c)	GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_IRGNL)
7940b559df5SStephen Boyd #define GET_TTBR1_PA(b, c)	GET_CONTEXT_FIELD(b, c, TTBR1, TTBR1_PA)
7950b559df5SStephen Boyd 
7960b559df5SStephen Boyd 
7970b559df5SStephen Boyd /* V2PSR */
7980b559df5SStephen Boyd #define GET_HIT(b, c)		GET_CONTEXT_FIELD(b, c, V2PSR, HIT)
7990b559df5SStephen Boyd #define GET_INDEX(b, c)		GET_CONTEXT_FIELD(b, c, V2PSR, INDEX)
8000b559df5SStephen Boyd 
8010b559df5SStephen Boyd 
8020b559df5SStephen Boyd /* Global Registers */
8030b559df5SStephen Boyd #define M2VCBR_N	(0xFF000)
8040b559df5SStephen Boyd #define CBACR_N		(0xFF800)
8050b559df5SStephen Boyd #define TLBRSW		(0xFFE00)
8060b559df5SStephen Boyd #define TLBTR0		(0xFFE80)
8070b559df5SStephen Boyd #define TLBTR1		(0xFFE84)
8080b559df5SStephen Boyd #define TLBTR2		(0xFFE88)
8090b559df5SStephen Boyd #define TESTBUSCR	(0xFFE8C)
8100b559df5SStephen Boyd #define GLOBAL_TLBIALL	(0xFFF00)
8110b559df5SStephen Boyd #define TLBIVMID	(0xFFF04)
8120b559df5SStephen Boyd #define CR		(0xFFF80)
8130b559df5SStephen Boyd #define EAR		(0xFFF84)
8140b559df5SStephen Boyd #define ESR		(0xFFF88)
8150b559df5SStephen Boyd #define ESRRESTORE	(0xFFF8C)
8160b559df5SStephen Boyd #define ESYNR0		(0xFFF90)
8170b559df5SStephen Boyd #define ESYNR1		(0xFFF94)
8180b559df5SStephen Boyd #define REV		(0xFFFF4)
8190b559df5SStephen Boyd #define IDR		(0xFFFF8)
8200b559df5SStephen Boyd #define RPU_ACR		(0xFFFFC)
8210b559df5SStephen Boyd 
8220b559df5SStephen Boyd 
8230b559df5SStephen Boyd /* Context Bank Registers */
8240b559df5SStephen Boyd #define SCTLR		(0x000)
8250b559df5SStephen Boyd #define ACTLR		(0x004)
8260b559df5SStephen Boyd #define CONTEXTIDR	(0x008)
8270b559df5SStephen Boyd #define TTBR0		(0x010)
8280b559df5SStephen Boyd #define TTBR1		(0x014)
8290b559df5SStephen Boyd #define TTBCR		(0x018)
8300b559df5SStephen Boyd #define PAR		(0x01C)
8310b559df5SStephen Boyd #define FSR		(0x020)
8320b559df5SStephen Boyd #define FSRRESTORE	(0x024)
8330b559df5SStephen Boyd #define FAR		(0x028)
8340b559df5SStephen Boyd #define FSYNR0		(0x02C)
8350b559df5SStephen Boyd #define FSYNR1		(0x030)
8360b559df5SStephen Boyd #define PRRR		(0x034)
8370b559df5SStephen Boyd #define NMRR		(0x038)
8380b559df5SStephen Boyd #define TLBLCKR		(0x03C)
8390b559df5SStephen Boyd #define V2PSR		(0x040)
8400b559df5SStephen Boyd #define TLBFLPTER	(0x044)
8410b559df5SStephen Boyd #define TLBSLPTER	(0x048)
8420b559df5SStephen Boyd #define BFBCR		(0x04C)
8430b559df5SStephen Boyd #define CTX_TLBIALL	(0x800)
8440b559df5SStephen Boyd #define TLBIASID	(0x804)
8450b559df5SStephen Boyd #define TLBIVA		(0x808)
8460b559df5SStephen Boyd #define TLBIVAA		(0x80C)
8470b559df5SStephen Boyd #define V2PPR		(0x810)
8480b559df5SStephen Boyd #define V2PPW		(0x814)
8490b559df5SStephen Boyd #define V2PUR		(0x818)
8500b559df5SStephen Boyd #define V2PUW		(0x81C)
8510b559df5SStephen Boyd #define RESUME		(0x820)
8520b559df5SStephen Boyd 
8530b559df5SStephen Boyd 
8540b559df5SStephen Boyd /* Global Register Fields */
8550b559df5SStephen Boyd /* CBACRn */
8560b559df5SStephen Boyd #define RWVMID        (RWVMID_MASK       << RWVMID_SHIFT)
8570b559df5SStephen Boyd #define RWE           (RWE_MASK          << RWE_SHIFT)
8580b559df5SStephen Boyd #define RWGE          (RWGE_MASK         << RWGE_SHIFT)
8590b559df5SStephen Boyd #define CBVMID        (CBVMID_MASK       << CBVMID_SHIFT)
8600b559df5SStephen Boyd #define IRPTNDX       (IRPTNDX_MASK      << IRPTNDX_SHIFT)
8610b559df5SStephen Boyd 
8620b559df5SStephen Boyd 
8630b559df5SStephen Boyd /* CR */
8640b559df5SStephen Boyd #define RPUE          (RPUE_MASK          << RPUE_SHIFT)
8650b559df5SStephen Boyd #define RPUERE        (RPUERE_MASK        << RPUERE_SHIFT)
8660b559df5SStephen Boyd #define RPUEIE        (RPUEIE_MASK        << RPUEIE_SHIFT)
8670b559df5SStephen Boyd #define DCDEE         (DCDEE_MASK         << DCDEE_SHIFT)
8680b559df5SStephen Boyd #define CLIENTPD      (CLIENTPD_MASK      << CLIENTPD_SHIFT)
8690b559df5SStephen Boyd #define STALLD        (STALLD_MASK        << STALLD_SHIFT)
8700b559df5SStephen Boyd #define TLBLKCRWE     (TLBLKCRWE_MASK     << TLBLKCRWE_SHIFT)
8710b559df5SStephen Boyd #define CR_TLBIALLCFG (CR_TLBIALLCFG_MASK << CR_TLBIALLCFG_SHIFT)
8720b559df5SStephen Boyd #define TLBIVMIDCFG   (TLBIVMIDCFG_MASK   << TLBIVMIDCFG_SHIFT)
8730b559df5SStephen Boyd #define CR_HUME       (CR_HUME_MASK       << CR_HUME_SHIFT)
8740b559df5SStephen Boyd 
8750b559df5SStephen Boyd 
8760b559df5SStephen Boyd /* ESR */
8770b559df5SStephen Boyd #define CFG           (CFG_MASK          << CFG_SHIFT)
8780b559df5SStephen Boyd #define BYPASS        (BYPASS_MASK       << BYPASS_SHIFT)
8790b559df5SStephen Boyd #define ESR_MULTI     (ESR_MULTI_MASK    << ESR_MULTI_SHIFT)
8800b559df5SStephen Boyd 
8810b559df5SStephen Boyd 
8820b559df5SStephen Boyd /* ESYNR0 */
8830b559df5SStephen Boyd #define ESYNR0_AMID   (ESYNR0_AMID_MASK  << ESYNR0_AMID_SHIFT)
8840b559df5SStephen Boyd #define ESYNR0_APID   (ESYNR0_APID_MASK  << ESYNR0_APID_SHIFT)
8850b559df5SStephen Boyd #define ESYNR0_ABID   (ESYNR0_ABID_MASK  << ESYNR0_ABID_SHIFT)
8860b559df5SStephen Boyd #define ESYNR0_AVMID  (ESYNR0_AVMID_MASK << ESYNR0_AVMID_SHIFT)
8870b559df5SStephen Boyd #define ESYNR0_ATID   (ESYNR0_ATID_MASK  << ESYNR0_ATID_SHIFT)
8880b559df5SStephen Boyd 
8890b559df5SStephen Boyd 
8900b559df5SStephen Boyd /* ESYNR1 */
8910b559df5SStephen Boyd #define ESYNR1_AMEMTYPE      (ESYNR1_AMEMTYPE_MASK    << ESYNR1_AMEMTYPE_SHIFT)
8920b559df5SStephen Boyd #define ESYNR1_ASHARED       (ESYNR1_ASHARED_MASK     << ESYNR1_ASHARED_SHIFT)
8930b559df5SStephen Boyd #define ESYNR1_AINNERSHARED  (ESYNR1_AINNERSHARED_MASK<< \
8940b559df5SStephen Boyd 						ESYNR1_AINNERSHARED_SHIFT)
8950b559df5SStephen Boyd #define ESYNR1_APRIV         (ESYNR1_APRIV_MASK       << ESYNR1_APRIV_SHIFT)
8960b559df5SStephen Boyd #define ESYNR1_APROTNS       (ESYNR1_APROTNS_MASK     << ESYNR1_APROTNS_SHIFT)
8970b559df5SStephen Boyd #define ESYNR1_AINST         (ESYNR1_AINST_MASK       << ESYNR1_AINST_SHIFT)
8980b559df5SStephen Boyd #define ESYNR1_AWRITE        (ESYNR1_AWRITE_MASK      << ESYNR1_AWRITE_SHIFT)
8990b559df5SStephen Boyd #define ESYNR1_ABURST        (ESYNR1_ABURST_MASK      << ESYNR1_ABURST_SHIFT)
9000b559df5SStephen Boyd #define ESYNR1_ALEN          (ESYNR1_ALEN_MASK        << ESYNR1_ALEN_SHIFT)
9010b559df5SStephen Boyd #define ESYNR1_ASIZE         (ESYNR1_ASIZE_MASK       << ESYNR1_ASIZE_SHIFT)
9020b559df5SStephen Boyd #define ESYNR1_ALOCK         (ESYNR1_ALOCK_MASK       << ESYNR1_ALOCK_SHIFT)
9030b559df5SStephen Boyd #define ESYNR1_AOOO          (ESYNR1_AOOO_MASK        << ESYNR1_AOOO_SHIFT)
9040b559df5SStephen Boyd #define ESYNR1_AFULL         (ESYNR1_AFULL_MASK       << ESYNR1_AFULL_SHIFT)
9050b559df5SStephen Boyd #define ESYNR1_AC            (ESYNR1_AC_MASK          << ESYNR1_AC_SHIFT)
9060b559df5SStephen Boyd #define ESYNR1_DCD           (ESYNR1_DCD_MASK         << ESYNR1_DCD_SHIFT)
9070b559df5SStephen Boyd 
9080b559df5SStephen Boyd 
9090b559df5SStephen Boyd /* IDR */
9100b559df5SStephen Boyd #define NM2VCBMT      (NM2VCBMT_MASK     << NM2VCBMT_SHIFT)
9110b559df5SStephen Boyd #define HTW           (HTW_MASK          << HTW_SHIFT)
9120b559df5SStephen Boyd #define HUM           (HUM_MASK          << HUM_SHIFT)
9130b559df5SStephen Boyd #define TLBSIZE       (TLBSIZE_MASK      << TLBSIZE_SHIFT)
9140b559df5SStephen Boyd #define NCB           (NCB_MASK          << NCB_SHIFT)
9150b559df5SStephen Boyd #define NIRPT         (NIRPT_MASK        << NIRPT_SHIFT)
9160b559df5SStephen Boyd 
9170b559df5SStephen Boyd 
9180b559df5SStephen Boyd /* M2VCBRn */
9190b559df5SStephen Boyd #define VMID          (VMID_MASK         << VMID_SHIFT)
9200b559df5SStephen Boyd #define CBNDX         (CBNDX_MASK        << CBNDX_SHIFT)
9210b559df5SStephen Boyd #define BYPASSD       (BYPASSD_MASK      << BYPASSD_SHIFT)
9220b559df5SStephen Boyd #define BPRCOSH       (BPRCOSH_MASK      << BPRCOSH_SHIFT)
9230b559df5SStephen Boyd #define BPRCISH       (BPRCISH_MASK      << BPRCISH_SHIFT)
9240b559df5SStephen Boyd #define BPRCNSH       (BPRCNSH_MASK      << BPRCNSH_SHIFT)
9250b559df5SStephen Boyd #define BPSHCFG       (BPSHCFG_MASK      << BPSHCFG_SHIFT)
9260b559df5SStephen Boyd #define NSCFG         (NSCFG_MASK        << NSCFG_SHIFT)
9270b559df5SStephen Boyd #define BPMTCFG       (BPMTCFG_MASK      << BPMTCFG_SHIFT)
9280b559df5SStephen Boyd #define BPMEMTYPE     (BPMEMTYPE_MASK    << BPMEMTYPE_SHIFT)
9290b559df5SStephen Boyd 
9300b559df5SStephen Boyd 
9310b559df5SStephen Boyd /* REV */
9320b559df5SStephen Boyd #define IDR_MINOR     (MINOR_MASK        << MINOR_SHIFT)
9330b559df5SStephen Boyd #define IDR_MAJOR     (MAJOR_MASK        << MAJOR_SHIFT)
9340b559df5SStephen Boyd 
9350b559df5SStephen Boyd 
9360b559df5SStephen Boyd /* TESTBUSCR */
9370b559df5SStephen Boyd #define TBE           (TBE_MASK          << TBE_SHIFT)
9380b559df5SStephen Boyd #define SPDMBE        (SPDMBE_MASK       << SPDMBE_SHIFT)
9390b559df5SStephen Boyd #define WGSEL         (WGSEL_MASK        << WGSEL_SHIFT)
9400b559df5SStephen Boyd #define TBLSEL        (TBLSEL_MASK       << TBLSEL_SHIFT)
9410b559df5SStephen Boyd #define TBHSEL        (TBHSEL_MASK       << TBHSEL_SHIFT)
9420b559df5SStephen Boyd #define SPDM0SEL      (SPDM0SEL_MASK     << SPDM0SEL_SHIFT)
9430b559df5SStephen Boyd #define SPDM1SEL      (SPDM1SEL_MASK     << SPDM1SEL_SHIFT)
9440b559df5SStephen Boyd #define SPDM2SEL      (SPDM2SEL_MASK     << SPDM2SEL_SHIFT)
9450b559df5SStephen Boyd #define SPDM3SEL      (SPDM3SEL_MASK     << SPDM3SEL_SHIFT)
9460b559df5SStephen Boyd 
9470b559df5SStephen Boyd 
9480b559df5SStephen Boyd /* TLBIVMID */
9490b559df5SStephen Boyd #define TLBIVMID_VMID (TLBIVMID_VMID_MASK << TLBIVMID_VMID_SHIFT)
9500b559df5SStephen Boyd 
9510b559df5SStephen Boyd 
9520b559df5SStephen Boyd /* TLBRSW */
9530b559df5SStephen Boyd #define TLBRSW_INDEX  (TLBRSW_INDEX_MASK << TLBRSW_INDEX_SHIFT)
9540b559df5SStephen Boyd #define TLBBFBS       (TLBBFBS_MASK      << TLBBFBS_SHIFT)
9550b559df5SStephen Boyd 
9560b559df5SStephen Boyd 
9570b559df5SStephen Boyd /* TLBTR0 */
9580b559df5SStephen Boyd #define PR            (PR_MASK           << PR_SHIFT)
9590b559df5SStephen Boyd #define PW            (PW_MASK           << PW_SHIFT)
9600b559df5SStephen Boyd #define UR            (UR_MASK           << UR_SHIFT)
9610b559df5SStephen Boyd #define UW            (UW_MASK           << UW_SHIFT)
9620b559df5SStephen Boyd #define XN            (XN_MASK           << XN_SHIFT)
9630b559df5SStephen Boyd #define NSDESC        (NSDESC_MASK       << NSDESC_SHIFT)
9640b559df5SStephen Boyd #define ISH           (ISH_MASK          << ISH_SHIFT)
9650b559df5SStephen Boyd #define SH            (SH_MASK           << SH_SHIFT)
9660b559df5SStephen Boyd #define MT            (MT_MASK           << MT_SHIFT)
9670b559df5SStephen Boyd #define DPSIZR        (DPSIZR_MASK       << DPSIZR_SHIFT)
9680b559df5SStephen Boyd #define DPSIZC        (DPSIZC_MASK       << DPSIZC_SHIFT)
9690b559df5SStephen Boyd 
9700b559df5SStephen Boyd 
9710b559df5SStephen Boyd /* TLBTR1 */
9720b559df5SStephen Boyd #define TLBTR1_VMID   (TLBTR1_VMID_MASK  << TLBTR1_VMID_SHIFT)
9730b559df5SStephen Boyd #define TLBTR1_PA     (TLBTR1_PA_MASK    << TLBTR1_PA_SHIFT)
9740b559df5SStephen Boyd 
9750b559df5SStephen Boyd 
9760b559df5SStephen Boyd /* TLBTR2 */
9770b559df5SStephen Boyd #define TLBTR2_ASID   (TLBTR2_ASID_MASK  << TLBTR2_ASID_SHIFT)
9780b559df5SStephen Boyd #define TLBTR2_V      (TLBTR2_V_MASK     << TLBTR2_V_SHIFT)
9790b559df5SStephen Boyd #define TLBTR2_NSTID  (TLBTR2_NSTID_MASK << TLBTR2_NSTID_SHIFT)
9800b559df5SStephen Boyd #define TLBTR2_NV     (TLBTR2_NV_MASK    << TLBTR2_NV_SHIFT)
9810b559df5SStephen Boyd #define TLBTR2_VA     (TLBTR2_VA_MASK    << TLBTR2_VA_SHIFT)
9820b559df5SStephen Boyd 
9830b559df5SStephen Boyd 
9840b559df5SStephen Boyd /* Context Register Fields */
9850b559df5SStephen Boyd /* ACTLR */
9860b559df5SStephen Boyd #define CFERE              (CFERE_MASK              << CFERE_SHIFT)
9870b559df5SStephen Boyd #define CFEIE              (CFEIE_MASK              << CFEIE_SHIFT)
9880b559df5SStephen Boyd #define PTSHCFG            (PTSHCFG_MASK            << PTSHCFG_SHIFT)
9890b559df5SStephen Boyd #define RCOSH              (RCOSH_MASK              << RCOSH_SHIFT)
9900b559df5SStephen Boyd #define RCISH              (RCISH_MASK              << RCISH_SHIFT)
9910b559df5SStephen Boyd #define RCNSH              (RCNSH_MASK              << RCNSH_SHIFT)
9920b559df5SStephen Boyd #define PRIVCFG            (PRIVCFG_MASK            << PRIVCFG_SHIFT)
9930b559df5SStephen Boyd #define DNA                (DNA_MASK                << DNA_SHIFT)
9940b559df5SStephen Boyd #define DNLV2PA            (DNLV2PA_MASK            << DNLV2PA_SHIFT)
9950b559df5SStephen Boyd #define TLBMCFG            (TLBMCFG_MASK            << TLBMCFG_SHIFT)
9960b559df5SStephen Boyd #define CFCFG              (CFCFG_MASK              << CFCFG_SHIFT)
9970b559df5SStephen Boyd #define TIPCF              (TIPCF_MASK              << TIPCF_SHIFT)
9980b559df5SStephen Boyd #define V2PCFG             (V2PCFG_MASK             << V2PCFG_SHIFT)
9990b559df5SStephen Boyd #define HUME               (HUME_MASK               << HUME_SHIFT)
10000b559df5SStephen Boyd #define PTMTCFG            (PTMTCFG_MASK            << PTMTCFG_SHIFT)
10010b559df5SStephen Boyd #define PTMEMTYPE          (PTMEMTYPE_MASK          << PTMEMTYPE_SHIFT)
10020b559df5SStephen Boyd 
10030b559df5SStephen Boyd 
10040b559df5SStephen Boyd /* BFBCR */
10050b559df5SStephen Boyd #define BFBDFE             (BFBDFE_MASK             << BFBDFE_SHIFT)
10060b559df5SStephen Boyd #define BFBSFE             (BFBSFE_MASK             << BFBSFE_SHIFT)
10070b559df5SStephen Boyd #define SFVS               (SFVS_MASK               << SFVS_SHIFT)
10080b559df5SStephen Boyd #define FLVIC              (FLVIC_MASK              << FLVIC_SHIFT)
10090b559df5SStephen Boyd #define SLVIC              (SLVIC_MASK              << SLVIC_SHIFT)
10100b559df5SStephen Boyd 
10110b559df5SStephen Boyd 
10120b559df5SStephen Boyd /* CONTEXTIDR */
10130b559df5SStephen Boyd #define CONTEXTIDR_ASID    (CONTEXTIDR_ASID_MASK    << CONTEXTIDR_ASID_SHIFT)
10140b559df5SStephen Boyd #define PROCID             (PROCID_MASK             << PROCID_SHIFT)
10150b559df5SStephen Boyd 
10160b559df5SStephen Boyd 
10170b559df5SStephen Boyd /* FSR */
10180b559df5SStephen Boyd #define TF                 (TF_MASK                 << TF_SHIFT)
10190b559df5SStephen Boyd #define AFF                (AFF_MASK                << AFF_SHIFT)
10200b559df5SStephen Boyd #define APF                (APF_MASK                << APF_SHIFT)
10210b559df5SStephen Boyd #define TLBMF              (TLBMF_MASK              << TLBMF_SHIFT)
10220b559df5SStephen Boyd #define HTWDEEF            (HTWDEEF_MASK            << HTWDEEF_SHIFT)
10230b559df5SStephen Boyd #define HTWSEEF            (HTWSEEF_MASK            << HTWSEEF_SHIFT)
10240b559df5SStephen Boyd #define MHF                (MHF_MASK                << MHF_SHIFT)
10250b559df5SStephen Boyd #define SL                 (SL_MASK                 << SL_SHIFT)
10260b559df5SStephen Boyd #define SS                 (SS_MASK                 << SS_SHIFT)
10270b559df5SStephen Boyd #define MULTI              (MULTI_MASK              << MULTI_SHIFT)
10280b559df5SStephen Boyd 
10290b559df5SStephen Boyd 
10300b559df5SStephen Boyd /* FSYNR0 */
10310b559df5SStephen Boyd #define AMID               (AMID_MASK               << AMID_SHIFT)
10320b559df5SStephen Boyd #define APID               (APID_MASK               << APID_SHIFT)
10330b559df5SStephen Boyd #define ABID               (ABID_MASK               << ABID_SHIFT)
10340b559df5SStephen Boyd #define ATID               (ATID_MASK               << ATID_SHIFT)
10350b559df5SStephen Boyd 
10360b559df5SStephen Boyd 
10370b559df5SStephen Boyd /* FSYNR1 */
10380b559df5SStephen Boyd #define AMEMTYPE           (AMEMTYPE_MASK           << AMEMTYPE_SHIFT)
10390b559df5SStephen Boyd #define ASHARED            (ASHARED_MASK            << ASHARED_SHIFT)
10400b559df5SStephen Boyd #define AINNERSHARED       (AINNERSHARED_MASK       << AINNERSHARED_SHIFT)
10410b559df5SStephen Boyd #define APRIV              (APRIV_MASK              << APRIV_SHIFT)
10420b559df5SStephen Boyd #define APROTNS            (APROTNS_MASK            << APROTNS_SHIFT)
10430b559df5SStephen Boyd #define AINST              (AINST_MASK              << AINST_SHIFT)
10440b559df5SStephen Boyd #define AWRITE             (AWRITE_MASK             << AWRITE_SHIFT)
10450b559df5SStephen Boyd #define ABURST             (ABURST_MASK             << ABURST_SHIFT)
10460b559df5SStephen Boyd #define ALEN               (ALEN_MASK               << ALEN_SHIFT)
10470b559df5SStephen Boyd #define FSYNR1_ASIZE       (FSYNR1_ASIZE_MASK       << FSYNR1_ASIZE_SHIFT)
10480b559df5SStephen Boyd #define ALOCK              (ALOCK_MASK              << ALOCK_SHIFT)
10490b559df5SStephen Boyd #define AFULL              (AFULL_MASK              << AFULL_SHIFT)
10500b559df5SStephen Boyd 
10510b559df5SStephen Boyd 
10520b559df5SStephen Boyd /* NMRR */
10530b559df5SStephen Boyd #define ICPC0              (ICPC0_MASK              << ICPC0_SHIFT)
10540b559df5SStephen Boyd #define ICPC1              (ICPC1_MASK              << ICPC1_SHIFT)
10550b559df5SStephen Boyd #define ICPC2              (ICPC2_MASK              << ICPC2_SHIFT)
10560b559df5SStephen Boyd #define ICPC3              (ICPC3_MASK              << ICPC3_SHIFT)
10570b559df5SStephen Boyd #define ICPC4              (ICPC4_MASK              << ICPC4_SHIFT)
10580b559df5SStephen Boyd #define ICPC5              (ICPC5_MASK              << ICPC5_SHIFT)
10590b559df5SStephen Boyd #define ICPC6              (ICPC6_MASK              << ICPC6_SHIFT)
10600b559df5SStephen Boyd #define ICPC7              (ICPC7_MASK              << ICPC7_SHIFT)
10610b559df5SStephen Boyd #define OCPC0              (OCPC0_MASK              << OCPC0_SHIFT)
10620b559df5SStephen Boyd #define OCPC1              (OCPC1_MASK              << OCPC1_SHIFT)
10630b559df5SStephen Boyd #define OCPC2              (OCPC2_MASK              << OCPC2_SHIFT)
10640b559df5SStephen Boyd #define OCPC3              (OCPC3_MASK              << OCPC3_SHIFT)
10650b559df5SStephen Boyd #define OCPC4              (OCPC4_MASK              << OCPC4_SHIFT)
10660b559df5SStephen Boyd #define OCPC5              (OCPC5_MASK              << OCPC5_SHIFT)
10670b559df5SStephen Boyd #define OCPC6              (OCPC6_MASK              << OCPC6_SHIFT)
10680b559df5SStephen Boyd #define OCPC7              (OCPC7_MASK              << OCPC7_SHIFT)
10690b559df5SStephen Boyd 
10700b559df5SStephen Boyd 
10710b559df5SStephen Boyd /* PAR */
10720b559df5SStephen Boyd #define FAULT              (FAULT_MASK              << FAULT_SHIFT)
10730b559df5SStephen Boyd /* If a fault is present, these are the
10740b559df5SStephen Boyd same as the fault fields in the FAR */
10750b559df5SStephen Boyd #define FAULT_TF           (FAULT_TF_MASK           << FAULT_TF_SHIFT)
10760b559df5SStephen Boyd #define FAULT_AFF          (FAULT_AFF_MASK          << FAULT_AFF_SHIFT)
10770b559df5SStephen Boyd #define FAULT_APF          (FAULT_APF_MASK          << FAULT_APF_SHIFT)
10780b559df5SStephen Boyd #define FAULT_TLBMF        (FAULT_TLBMF_MASK        << FAULT_TLBMF_SHIFT)
10790b559df5SStephen Boyd #define FAULT_HTWDEEF      (FAULT_HTWDEEF_MASK      << FAULT_HTWDEEF_SHIFT)
10800b559df5SStephen Boyd #define FAULT_HTWSEEF      (FAULT_HTWSEEF_MASK      << FAULT_HTWSEEF_SHIFT)
10810b559df5SStephen Boyd #define FAULT_MHF          (FAULT_MHF_MASK          << FAULT_MHF_SHIFT)
10820b559df5SStephen Boyd #define FAULT_SL           (FAULT_SL_MASK           << FAULT_SL_SHIFT)
10830b559df5SStephen Boyd #define FAULT_SS           (FAULT_SS_MASK           << FAULT_SS_SHIFT)
10840b559df5SStephen Boyd 
10850b559df5SStephen Boyd /* If NO fault is present, the following fields are in effect */
10860b559df5SStephen Boyd /* (FAULT remains as before) */
10870b559df5SStephen Boyd #define PAR_NOFAULT_SS     (PAR_NOFAULT_SS_MASK     << PAR_NOFAULT_SS_SHIFT)
10880b559df5SStephen Boyd #define PAR_NOFAULT_MT     (PAR_NOFAULT_MT_MASK     << PAR_NOFAULT_MT_SHIFT)
10890b559df5SStephen Boyd #define PAR_NOFAULT_SH     (PAR_NOFAULT_SH_MASK     << PAR_NOFAULT_SH_SHIFT)
10900b559df5SStephen Boyd #define PAR_NOFAULT_NS     (PAR_NOFAULT_NS_MASK     << PAR_NOFAULT_NS_SHIFT)
10910b559df5SStephen Boyd #define PAR_NOFAULT_NOS    (PAR_NOFAULT_NOS_MASK    << PAR_NOFAULT_NOS_SHIFT)
10920b559df5SStephen Boyd #define PAR_NPFAULT_PA     (PAR_NPFAULT_PA_MASK     << PAR_NPFAULT_PA_SHIFT)
10930b559df5SStephen Boyd 
10940b559df5SStephen Boyd 
10950b559df5SStephen Boyd /* PRRR */
10960b559df5SStephen Boyd #define MTC0               (MTC0_MASK               << MTC0_SHIFT)
10970b559df5SStephen Boyd #define MTC1               (MTC1_MASK               << MTC1_SHIFT)
10980b559df5SStephen Boyd #define MTC2               (MTC2_MASK               << MTC2_SHIFT)
10990b559df5SStephen Boyd #define MTC3               (MTC3_MASK               << MTC3_SHIFT)
11000b559df5SStephen Boyd #define MTC4               (MTC4_MASK               << MTC4_SHIFT)
11010b559df5SStephen Boyd #define MTC5               (MTC5_MASK               << MTC5_SHIFT)
11020b559df5SStephen Boyd #define MTC6               (MTC6_MASK               << MTC6_SHIFT)
11030b559df5SStephen Boyd #define MTC7               (MTC7_MASK               << MTC7_SHIFT)
11040b559df5SStephen Boyd #define SHDSH0             (SHDSH0_MASK             << SHDSH0_SHIFT)
11050b559df5SStephen Boyd #define SHDSH1             (SHDSH1_MASK             << SHDSH1_SHIFT)
11060b559df5SStephen Boyd #define SHNMSH0            (SHNMSH0_MASK            << SHNMSH0_SHIFT)
11070b559df5SStephen Boyd #define SHNMSH1            (SHNMSH1_MASK            << SHNMSH1_SHIFT)
11080b559df5SStephen Boyd #define NOS0               (NOS0_MASK               << NOS0_SHIFT)
11090b559df5SStephen Boyd #define NOS1               (NOS1_MASK               << NOS1_SHIFT)
11100b559df5SStephen Boyd #define NOS2               (NOS2_MASK               << NOS2_SHIFT)
11110b559df5SStephen Boyd #define NOS3               (NOS3_MASK               << NOS3_SHIFT)
11120b559df5SStephen Boyd #define NOS4               (NOS4_MASK               << NOS4_SHIFT)
11130b559df5SStephen Boyd #define NOS5               (NOS5_MASK               << NOS5_SHIFT)
11140b559df5SStephen Boyd #define NOS6               (NOS6_MASK               << NOS6_SHIFT)
11150b559df5SStephen Boyd #define NOS7               (NOS7_MASK               << NOS7_SHIFT)
11160b559df5SStephen Boyd 
11170b559df5SStephen Boyd 
11180b559df5SStephen Boyd /* RESUME */
11190b559df5SStephen Boyd #define TNR                (TNR_MASK                << TNR_SHIFT)
11200b559df5SStephen Boyd 
11210b559df5SStephen Boyd 
11220b559df5SStephen Boyd /* SCTLR */
11230b559df5SStephen Boyd #define M                  (M_MASK                  << M_SHIFT)
11240b559df5SStephen Boyd #define TRE                (TRE_MASK                << TRE_SHIFT)
11250b559df5SStephen Boyd #define AFE                (AFE_MASK                << AFE_SHIFT)
11260b559df5SStephen Boyd #define HAF                (HAF_MASK                << HAF_SHIFT)
11270b559df5SStephen Boyd #define BE                 (BE_MASK                 << BE_SHIFT)
11280b559df5SStephen Boyd #define AFFD               (AFFD_MASK               << AFFD_SHIFT)
11290b559df5SStephen Boyd 
11300b559df5SStephen Boyd 
11310b559df5SStephen Boyd /* TLBIASID */
11320b559df5SStephen Boyd #define TLBIASID_ASID      (TLBIASID_ASID_MASK      << TLBIASID_ASID_SHIFT)
11330b559df5SStephen Boyd 
11340b559df5SStephen Boyd 
11350b559df5SStephen Boyd /* TLBIVA */
11360b559df5SStephen Boyd #define TLBIVA_ASID        (TLBIVA_ASID_MASK        << TLBIVA_ASID_SHIFT)
11370b559df5SStephen Boyd #define TLBIVA_VA          (TLBIVA_VA_MASK          << TLBIVA_VA_SHIFT)
11380b559df5SStephen Boyd 
11390b559df5SStephen Boyd 
11400b559df5SStephen Boyd /* TLBIVAA */
11410b559df5SStephen Boyd #define TLBIVAA_VA         (TLBIVAA_VA_MASK         << TLBIVAA_VA_SHIFT)
11420b559df5SStephen Boyd 
11430b559df5SStephen Boyd 
11440b559df5SStephen Boyd /* TLBLCKR */
11450b559df5SStephen Boyd #define LKE                (LKE_MASK                << LKE_SHIFT)
11460b559df5SStephen Boyd #define TLBLCKR_TLBIALLCFG (TLBLCKR_TLBIALLCFG_MASK<<TLBLCKR_TLBIALLCFG_SHIFT)
11470b559df5SStephen Boyd #define TLBIASIDCFG        (TLBIASIDCFG_MASK        << TLBIASIDCFG_SHIFT)
11480b559df5SStephen Boyd #define TLBIVAACFG         (TLBIVAACFG_MASK         << TLBIVAACFG_SHIFT)
11490b559df5SStephen Boyd #define FLOOR              (FLOOR_MASK              << FLOOR_SHIFT)
11500b559df5SStephen Boyd #define VICTIM             (VICTIM_MASK             << VICTIM_SHIFT)
11510b559df5SStephen Boyd 
11520b559df5SStephen Boyd 
11530b559df5SStephen Boyd /* TTBCR */
11540b559df5SStephen Boyd #define N                  (N_MASK                  << N_SHIFT)
11550b559df5SStephen Boyd #define PD0                (PD0_MASK                << PD0_SHIFT)
11560b559df5SStephen Boyd #define PD1                (PD1_MASK                << PD1_SHIFT)
11570b559df5SStephen Boyd 
11580b559df5SStephen Boyd 
11590b559df5SStephen Boyd /* TTBR0 */
11600b559df5SStephen Boyd #define TTBR0_IRGNH        (TTBR0_IRGNH_MASK        << TTBR0_IRGNH_SHIFT)
11610b559df5SStephen Boyd #define TTBR0_SH           (TTBR0_SH_MASK           << TTBR0_SH_SHIFT)
11620b559df5SStephen Boyd #define TTBR0_ORGN         (TTBR0_ORGN_MASK         << TTBR0_ORGN_SHIFT)
11630b559df5SStephen Boyd #define TTBR0_NOS          (TTBR0_NOS_MASK          << TTBR0_NOS_SHIFT)
11640b559df5SStephen Boyd #define TTBR0_IRGNL        (TTBR0_IRGNL_MASK        << TTBR0_IRGNL_SHIFT)
11650b559df5SStephen Boyd #define TTBR0_PA           (TTBR0_PA_MASK           << TTBR0_PA_SHIFT)
11660b559df5SStephen Boyd 
11670b559df5SStephen Boyd 
11680b559df5SStephen Boyd /* TTBR1 */
11690b559df5SStephen Boyd #define TTBR1_IRGNH        (TTBR1_IRGNH_MASK        << TTBR1_IRGNH_SHIFT)
11700b559df5SStephen Boyd #define TTBR1_SH           (TTBR1_SH_MASK           << TTBR1_SH_SHIFT)
11710b559df5SStephen Boyd #define TTBR1_ORGN         (TTBR1_ORGN_MASK         << TTBR1_ORGN_SHIFT)
11720b559df5SStephen Boyd #define TTBR1_NOS          (TTBR1_NOS_MASK          << TTBR1_NOS_SHIFT)
11730b559df5SStephen Boyd #define TTBR1_IRGNL        (TTBR1_IRGNL_MASK        << TTBR1_IRGNL_SHIFT)
11740b559df5SStephen Boyd #define TTBR1_PA           (TTBR1_PA_MASK           << TTBR1_PA_SHIFT)
11750b559df5SStephen Boyd 
11760b559df5SStephen Boyd 
11770b559df5SStephen Boyd /* V2PSR */
11780b559df5SStephen Boyd #define HIT                (HIT_MASK                << HIT_SHIFT)
11790b559df5SStephen Boyd #define INDEX              (INDEX_MASK              << INDEX_SHIFT)
11800b559df5SStephen Boyd 
11810b559df5SStephen Boyd 
11820b559df5SStephen Boyd /* V2Pxx */
11830b559df5SStephen Boyd #define V2Pxx_INDEX        (V2Pxx_INDEX_MASK        << V2Pxx_INDEX_SHIFT)
11840b559df5SStephen Boyd #define V2Pxx_VA           (V2Pxx_VA_MASK           << V2Pxx_VA_SHIFT)
11850b559df5SStephen Boyd 
11860b559df5SStephen Boyd 
11870b559df5SStephen Boyd /* Global Register Masks */
11880b559df5SStephen Boyd /* CBACRn */
11890b559df5SStephen Boyd #define RWVMID_MASK               0x1F
11900b559df5SStephen Boyd #define RWE_MASK                  0x01
11910b559df5SStephen Boyd #define RWGE_MASK                 0x01
11920b559df5SStephen Boyd #define CBVMID_MASK               0x1F
11930b559df5SStephen Boyd #define IRPTNDX_MASK              0xFF
11940b559df5SStephen Boyd 
11950b559df5SStephen Boyd 
11960b559df5SStephen Boyd /* CR */
11970b559df5SStephen Boyd #define RPUE_MASK                 0x01
11980b559df5SStephen Boyd #define RPUERE_MASK               0x01
11990b559df5SStephen Boyd #define RPUEIE_MASK               0x01
12000b559df5SStephen Boyd #define DCDEE_MASK                0x01
12010b559df5SStephen Boyd #define CLIENTPD_MASK             0x01
12020b559df5SStephen Boyd #define STALLD_MASK               0x01
12030b559df5SStephen Boyd #define TLBLKCRWE_MASK            0x01
12040b559df5SStephen Boyd #define CR_TLBIALLCFG_MASK        0x01
12050b559df5SStephen Boyd #define TLBIVMIDCFG_MASK          0x01
12060b559df5SStephen Boyd #define CR_HUME_MASK              0x01
12070b559df5SStephen Boyd 
12080b559df5SStephen Boyd 
12090b559df5SStephen Boyd /* ESR */
12100b559df5SStephen Boyd #define CFG_MASK                  0x01
12110b559df5SStephen Boyd #define BYPASS_MASK               0x01
12120b559df5SStephen Boyd #define ESR_MULTI_MASK            0x01
12130b559df5SStephen Boyd 
12140b559df5SStephen Boyd 
12150b559df5SStephen Boyd /* ESYNR0 */
12160b559df5SStephen Boyd #define ESYNR0_AMID_MASK          0xFF
12170b559df5SStephen Boyd #define ESYNR0_APID_MASK          0x1F
12180b559df5SStephen Boyd #define ESYNR0_ABID_MASK          0x07
12190b559df5SStephen Boyd #define ESYNR0_AVMID_MASK         0x1F
12200b559df5SStephen Boyd #define ESYNR0_ATID_MASK          0xFF
12210b559df5SStephen Boyd 
12220b559df5SStephen Boyd 
12230b559df5SStephen Boyd /* ESYNR1 */
12240b559df5SStephen Boyd #define ESYNR1_AMEMTYPE_MASK             0x07
12250b559df5SStephen Boyd #define ESYNR1_ASHARED_MASK              0x01
12260b559df5SStephen Boyd #define ESYNR1_AINNERSHARED_MASK         0x01
12270b559df5SStephen Boyd #define ESYNR1_APRIV_MASK                0x01
12280b559df5SStephen Boyd #define ESYNR1_APROTNS_MASK              0x01
12290b559df5SStephen Boyd #define ESYNR1_AINST_MASK                0x01
12300b559df5SStephen Boyd #define ESYNR1_AWRITE_MASK               0x01
12310b559df5SStephen Boyd #define ESYNR1_ABURST_MASK               0x01
12320b559df5SStephen Boyd #define ESYNR1_ALEN_MASK                 0x0F
12330b559df5SStephen Boyd #define ESYNR1_ASIZE_MASK                0x01
12340b559df5SStephen Boyd #define ESYNR1_ALOCK_MASK                0x03
12350b559df5SStephen Boyd #define ESYNR1_AOOO_MASK                 0x01
12360b559df5SStephen Boyd #define ESYNR1_AFULL_MASK                0x01
12370b559df5SStephen Boyd #define ESYNR1_AC_MASK                   0x01
12380b559df5SStephen Boyd #define ESYNR1_DCD_MASK                  0x01
12390b559df5SStephen Boyd 
12400b559df5SStephen Boyd 
12410b559df5SStephen Boyd /* IDR */
12420b559df5SStephen Boyd #define NM2VCBMT_MASK             0x1FF
12430b559df5SStephen Boyd #define HTW_MASK                  0x01
12440b559df5SStephen Boyd #define HUM_MASK                  0x01
12450b559df5SStephen Boyd #define TLBSIZE_MASK              0x0F
12460b559df5SStephen Boyd #define NCB_MASK                  0xFF
12470b559df5SStephen Boyd #define NIRPT_MASK                0xFF
12480b559df5SStephen Boyd 
12490b559df5SStephen Boyd 
12500b559df5SStephen Boyd /* M2VCBRn */
12510b559df5SStephen Boyd #define VMID_MASK                 0x1F
12520b559df5SStephen Boyd #define CBNDX_MASK                0xFF
12530b559df5SStephen Boyd #define BYPASSD_MASK              0x01
12540b559df5SStephen Boyd #define BPRCOSH_MASK              0x01
12550b559df5SStephen Boyd #define BPRCISH_MASK              0x01
12560b559df5SStephen Boyd #define BPRCNSH_MASK              0x01
12570b559df5SStephen Boyd #define BPSHCFG_MASK              0x03
12580b559df5SStephen Boyd #define NSCFG_MASK                0x03
12590b559df5SStephen Boyd #define BPMTCFG_MASK              0x01
12600b559df5SStephen Boyd #define BPMEMTYPE_MASK            0x07
12610b559df5SStephen Boyd 
12620b559df5SStephen Boyd 
12630b559df5SStephen Boyd /* REV */
12640b559df5SStephen Boyd #define MINOR_MASK                0x0F
12650b559df5SStephen Boyd #define MAJOR_MASK                0x0F
12660b559df5SStephen Boyd 
12670b559df5SStephen Boyd 
12680b559df5SStephen Boyd /* TESTBUSCR */
12690b559df5SStephen Boyd #define TBE_MASK                  0x01
12700b559df5SStephen Boyd #define SPDMBE_MASK               0x01
12710b559df5SStephen Boyd #define WGSEL_MASK                0x03
12720b559df5SStephen Boyd #define TBLSEL_MASK               0x03
12730b559df5SStephen Boyd #define TBHSEL_MASK               0x03
12740b559df5SStephen Boyd #define SPDM0SEL_MASK             0x0F
12750b559df5SStephen Boyd #define SPDM1SEL_MASK             0x0F
12760b559df5SStephen Boyd #define SPDM2SEL_MASK             0x0F
12770b559df5SStephen Boyd #define SPDM3SEL_MASK             0x0F
12780b559df5SStephen Boyd 
12790b559df5SStephen Boyd 
12800b559df5SStephen Boyd /* TLBIMID */
12810b559df5SStephen Boyd #define TLBIVMID_VMID_MASK        0x1F
12820b559df5SStephen Boyd 
12830b559df5SStephen Boyd 
12840b559df5SStephen Boyd /* TLBRSW */
12850b559df5SStephen Boyd #define TLBRSW_INDEX_MASK         0xFF
12860b559df5SStephen Boyd #define TLBBFBS_MASK              0x03
12870b559df5SStephen Boyd 
12880b559df5SStephen Boyd 
12890b559df5SStephen Boyd /* TLBTR0 */
12900b559df5SStephen Boyd #define PR_MASK                   0x01
12910b559df5SStephen Boyd #define PW_MASK                   0x01
12920b559df5SStephen Boyd #define UR_MASK                   0x01
12930b559df5SStephen Boyd #define UW_MASK                   0x01
12940b559df5SStephen Boyd #define XN_MASK                   0x01
12950b559df5SStephen Boyd #define NSDESC_MASK               0x01
12960b559df5SStephen Boyd #define ISH_MASK                  0x01
12970b559df5SStephen Boyd #define SH_MASK                   0x01
12980b559df5SStephen Boyd #define MT_MASK                   0x07
12990b559df5SStephen Boyd #define DPSIZR_MASK               0x07
13000b559df5SStephen Boyd #define DPSIZC_MASK               0x07
13010b559df5SStephen Boyd 
13020b559df5SStephen Boyd 
13030b559df5SStephen Boyd /* TLBTR1 */
13040b559df5SStephen Boyd #define TLBTR1_VMID_MASK          0x1F
13050b559df5SStephen Boyd #define TLBTR1_PA_MASK            0x000FFFFF
13060b559df5SStephen Boyd 
13070b559df5SStephen Boyd 
13080b559df5SStephen Boyd /* TLBTR2 */
13090b559df5SStephen Boyd #define TLBTR2_ASID_MASK          0xFF
13100b559df5SStephen Boyd #define TLBTR2_V_MASK             0x01
13110b559df5SStephen Boyd #define TLBTR2_NSTID_MASK         0x01
13120b559df5SStephen Boyd #define TLBTR2_NV_MASK            0x01
13130b559df5SStephen Boyd #define TLBTR2_VA_MASK            0x000FFFFF
13140b559df5SStephen Boyd 
13150b559df5SStephen Boyd 
13160b559df5SStephen Boyd /* Global Register Shifts */
13170b559df5SStephen Boyd /* CBACRn */
13180b559df5SStephen Boyd #define RWVMID_SHIFT             0
13190b559df5SStephen Boyd #define RWE_SHIFT                8
13200b559df5SStephen Boyd #define RWGE_SHIFT               9
13210b559df5SStephen Boyd #define CBVMID_SHIFT             16
13220b559df5SStephen Boyd #define IRPTNDX_SHIFT            24
13230b559df5SStephen Boyd 
13240b559df5SStephen Boyd 
13250b559df5SStephen Boyd /* CR */
13260b559df5SStephen Boyd #define RPUE_SHIFT               0
13270b559df5SStephen Boyd #define RPUERE_SHIFT             1
13280b559df5SStephen Boyd #define RPUEIE_SHIFT             2
13290b559df5SStephen Boyd #define DCDEE_SHIFT              3
13300b559df5SStephen Boyd #define CLIENTPD_SHIFT           4
13310b559df5SStephen Boyd #define STALLD_SHIFT             5
13320b559df5SStephen Boyd #define TLBLKCRWE_SHIFT          6
13330b559df5SStephen Boyd #define CR_TLBIALLCFG_SHIFT      7
13340b559df5SStephen Boyd #define TLBIVMIDCFG_SHIFT        8
13350b559df5SStephen Boyd #define CR_HUME_SHIFT            9
13360b559df5SStephen Boyd 
13370b559df5SStephen Boyd 
13380b559df5SStephen Boyd /* ESR */
13390b559df5SStephen Boyd #define CFG_SHIFT                0
13400b559df5SStephen Boyd #define BYPASS_SHIFT             1
13410b559df5SStephen Boyd #define ESR_MULTI_SHIFT          31
13420b559df5SStephen Boyd 
13430b559df5SStephen Boyd 
13440b559df5SStephen Boyd /* ESYNR0 */
13450b559df5SStephen Boyd #define ESYNR0_AMID_SHIFT        0
13460b559df5SStephen Boyd #define ESYNR0_APID_SHIFT        8
13470b559df5SStephen Boyd #define ESYNR0_ABID_SHIFT        13
13480b559df5SStephen Boyd #define ESYNR0_AVMID_SHIFT       16
13490b559df5SStephen Boyd #define ESYNR0_ATID_SHIFT        24
13500b559df5SStephen Boyd 
13510b559df5SStephen Boyd 
13520b559df5SStephen Boyd /* ESYNR1 */
13530b559df5SStephen Boyd #define ESYNR1_AMEMTYPE_SHIFT           0
13540b559df5SStephen Boyd #define ESYNR1_ASHARED_SHIFT            3
13550b559df5SStephen Boyd #define ESYNR1_AINNERSHARED_SHIFT       4
13560b559df5SStephen Boyd #define ESYNR1_APRIV_SHIFT              5
13570b559df5SStephen Boyd #define ESYNR1_APROTNS_SHIFT            6
13580b559df5SStephen Boyd #define ESYNR1_AINST_SHIFT              7
13590b559df5SStephen Boyd #define ESYNR1_AWRITE_SHIFT             8
13600b559df5SStephen Boyd #define ESYNR1_ABURST_SHIFT             10
13610b559df5SStephen Boyd #define ESYNR1_ALEN_SHIFT               12
13620b559df5SStephen Boyd #define ESYNR1_ASIZE_SHIFT              16
13630b559df5SStephen Boyd #define ESYNR1_ALOCK_SHIFT              20
13640b559df5SStephen Boyd #define ESYNR1_AOOO_SHIFT               22
13650b559df5SStephen Boyd #define ESYNR1_AFULL_SHIFT              24
13660b559df5SStephen Boyd #define ESYNR1_AC_SHIFT                 30
13670b559df5SStephen Boyd #define ESYNR1_DCD_SHIFT                31
13680b559df5SStephen Boyd 
13690b559df5SStephen Boyd 
13700b559df5SStephen Boyd /* IDR */
13710b559df5SStephen Boyd #define NM2VCBMT_SHIFT           0
13720b559df5SStephen Boyd #define HTW_SHIFT                9
13730b559df5SStephen Boyd #define HUM_SHIFT                10
13740b559df5SStephen Boyd #define TLBSIZE_SHIFT            12
13750b559df5SStephen Boyd #define NCB_SHIFT                16
13760b559df5SStephen Boyd #define NIRPT_SHIFT              24
13770b559df5SStephen Boyd 
13780b559df5SStephen Boyd 
13790b559df5SStephen Boyd /* M2VCBRn */
13800b559df5SStephen Boyd #define VMID_SHIFT               0
13810b559df5SStephen Boyd #define CBNDX_SHIFT              8
13820b559df5SStephen Boyd #define BYPASSD_SHIFT            16
13830b559df5SStephen Boyd #define BPRCOSH_SHIFT            17
13840b559df5SStephen Boyd #define BPRCISH_SHIFT            18
13850b559df5SStephen Boyd #define BPRCNSH_SHIFT            19
13860b559df5SStephen Boyd #define BPSHCFG_SHIFT            20
13870b559df5SStephen Boyd #define NSCFG_SHIFT              22
13880b559df5SStephen Boyd #define BPMTCFG_SHIFT            24
13890b559df5SStephen Boyd #define BPMEMTYPE_SHIFT          25
13900b559df5SStephen Boyd 
13910b559df5SStephen Boyd 
13920b559df5SStephen Boyd /* REV */
13930b559df5SStephen Boyd #define MINOR_SHIFT              0
13940b559df5SStephen Boyd #define MAJOR_SHIFT              4
13950b559df5SStephen Boyd 
13960b559df5SStephen Boyd 
13970b559df5SStephen Boyd /* TESTBUSCR */
13980b559df5SStephen Boyd #define TBE_SHIFT                0
13990b559df5SStephen Boyd #define SPDMBE_SHIFT             1
14000b559df5SStephen Boyd #define WGSEL_SHIFT              8
14010b559df5SStephen Boyd #define TBLSEL_SHIFT             12
14020b559df5SStephen Boyd #define TBHSEL_SHIFT             14
14030b559df5SStephen Boyd #define SPDM0SEL_SHIFT           16
14040b559df5SStephen Boyd #define SPDM1SEL_SHIFT           20
14050b559df5SStephen Boyd #define SPDM2SEL_SHIFT           24
14060b559df5SStephen Boyd #define SPDM3SEL_SHIFT           28
14070b559df5SStephen Boyd 
14080b559df5SStephen Boyd 
14090b559df5SStephen Boyd /* TLBIMID */
14100b559df5SStephen Boyd #define TLBIVMID_VMID_SHIFT      0
14110b559df5SStephen Boyd 
14120b559df5SStephen Boyd 
14130b559df5SStephen Boyd /* TLBRSW */
14140b559df5SStephen Boyd #define TLBRSW_INDEX_SHIFT       0
14150b559df5SStephen Boyd #define TLBBFBS_SHIFT            8
14160b559df5SStephen Boyd 
14170b559df5SStephen Boyd 
14180b559df5SStephen Boyd /* TLBTR0 */
14190b559df5SStephen Boyd #define PR_SHIFT                 0
14200b559df5SStephen Boyd #define PW_SHIFT                 1
14210b559df5SStephen Boyd #define UR_SHIFT                 2
14220b559df5SStephen Boyd #define UW_SHIFT                 3
14230b559df5SStephen Boyd #define XN_SHIFT                 4
14240b559df5SStephen Boyd #define NSDESC_SHIFT             6
14250b559df5SStephen Boyd #define ISH_SHIFT                7
14260b559df5SStephen Boyd #define SH_SHIFT                 8
14270b559df5SStephen Boyd #define MT_SHIFT                 9
14280b559df5SStephen Boyd #define DPSIZR_SHIFT             16
14290b559df5SStephen Boyd #define DPSIZC_SHIFT             20
14300b559df5SStephen Boyd 
14310b559df5SStephen Boyd 
14320b559df5SStephen Boyd /* TLBTR1 */
14330b559df5SStephen Boyd #define TLBTR1_VMID_SHIFT        0
14340b559df5SStephen Boyd #define TLBTR1_PA_SHIFT          12
14350b559df5SStephen Boyd 
14360b559df5SStephen Boyd 
14370b559df5SStephen Boyd /* TLBTR2 */
14380b559df5SStephen Boyd #define TLBTR2_ASID_SHIFT        0
14390b559df5SStephen Boyd #define TLBTR2_V_SHIFT           8
14400b559df5SStephen Boyd #define TLBTR2_NSTID_SHIFT       9
14410b559df5SStephen Boyd #define TLBTR2_NV_SHIFT          10
14420b559df5SStephen Boyd #define TLBTR2_VA_SHIFT          12
14430b559df5SStephen Boyd 
14440b559df5SStephen Boyd 
14450b559df5SStephen Boyd /* Context Register Masks */
14460b559df5SStephen Boyd /* ACTLR */
14470b559df5SStephen Boyd #define CFERE_MASK                       0x01
14480b559df5SStephen Boyd #define CFEIE_MASK                       0x01
14490b559df5SStephen Boyd #define PTSHCFG_MASK                     0x03
14500b559df5SStephen Boyd #define RCOSH_MASK                       0x01
14510b559df5SStephen Boyd #define RCISH_MASK                       0x01
14520b559df5SStephen Boyd #define RCNSH_MASK                       0x01
14530b559df5SStephen Boyd #define PRIVCFG_MASK                     0x03
14540b559df5SStephen Boyd #define DNA_MASK                         0x01
14550b559df5SStephen Boyd #define DNLV2PA_MASK                     0x01
14560b559df5SStephen Boyd #define TLBMCFG_MASK                     0x03
14570b559df5SStephen Boyd #define CFCFG_MASK                       0x01
14580b559df5SStephen Boyd #define TIPCF_MASK                       0x01
14590b559df5SStephen Boyd #define V2PCFG_MASK                      0x03
14600b559df5SStephen Boyd #define HUME_MASK                        0x01
14610b559df5SStephen Boyd #define PTMTCFG_MASK                     0x01
14620b559df5SStephen Boyd #define PTMEMTYPE_MASK                   0x07
14630b559df5SStephen Boyd 
14640b559df5SStephen Boyd 
14650b559df5SStephen Boyd /* BFBCR */
14660b559df5SStephen Boyd #define BFBDFE_MASK                      0x01
14670b559df5SStephen Boyd #define BFBSFE_MASK                      0x01
14680b559df5SStephen Boyd #define SFVS_MASK                        0x01
14690b559df5SStephen Boyd #define FLVIC_MASK                       0x0F
14700b559df5SStephen Boyd #define SLVIC_MASK                       0x0F
14710b559df5SStephen Boyd 
14720b559df5SStephen Boyd 
14730b559df5SStephen Boyd /* CONTEXTIDR */
14740b559df5SStephen Boyd #define CONTEXTIDR_ASID_MASK             0xFF
14750b559df5SStephen Boyd #define PROCID_MASK                      0x00FFFFFF
14760b559df5SStephen Boyd 
14770b559df5SStephen Boyd 
14780b559df5SStephen Boyd /* FSR */
14790b559df5SStephen Boyd #define TF_MASK                          0x01
14800b559df5SStephen Boyd #define AFF_MASK                         0x01
14810b559df5SStephen Boyd #define APF_MASK                         0x01
14820b559df5SStephen Boyd #define TLBMF_MASK                       0x01
14830b559df5SStephen Boyd #define HTWDEEF_MASK                     0x01
14840b559df5SStephen Boyd #define HTWSEEF_MASK                     0x01
14850b559df5SStephen Boyd #define MHF_MASK                         0x01
14860b559df5SStephen Boyd #define SL_MASK                          0x01
14870b559df5SStephen Boyd #define SS_MASK                          0x01
14880b559df5SStephen Boyd #define MULTI_MASK                       0x01
14890b559df5SStephen Boyd 
14900b559df5SStephen Boyd 
14910b559df5SStephen Boyd /* FSYNR0 */
14920b559df5SStephen Boyd #define AMID_MASK                        0xFF
14930b559df5SStephen Boyd #define APID_MASK                        0x1F
14940b559df5SStephen Boyd #define ABID_MASK                        0x07
14950b559df5SStephen Boyd #define ATID_MASK                        0xFF
14960b559df5SStephen Boyd 
14970b559df5SStephen Boyd 
14980b559df5SStephen Boyd /* FSYNR1 */
14990b559df5SStephen Boyd #define AMEMTYPE_MASK                    0x07
15000b559df5SStephen Boyd #define ASHARED_MASK                     0x01
15010b559df5SStephen Boyd #define AINNERSHARED_MASK                0x01
15020b559df5SStephen Boyd #define APRIV_MASK                       0x01
15030b559df5SStephen Boyd #define APROTNS_MASK                     0x01
15040b559df5SStephen Boyd #define AINST_MASK                       0x01
15050b559df5SStephen Boyd #define AWRITE_MASK                      0x01
15060b559df5SStephen Boyd #define ABURST_MASK                      0x01
15070b559df5SStephen Boyd #define ALEN_MASK                        0x0F
15080b559df5SStephen Boyd #define FSYNR1_ASIZE_MASK                0x07
15090b559df5SStephen Boyd #define ALOCK_MASK                       0x03
15100b559df5SStephen Boyd #define AFULL_MASK                       0x01
15110b559df5SStephen Boyd 
15120b559df5SStephen Boyd 
15130b559df5SStephen Boyd /* NMRR */
15140b559df5SStephen Boyd #define ICPC0_MASK                       0x03
15150b559df5SStephen Boyd #define ICPC1_MASK                       0x03
15160b559df5SStephen Boyd #define ICPC2_MASK                       0x03
15170b559df5SStephen Boyd #define ICPC3_MASK                       0x03
15180b559df5SStephen Boyd #define ICPC4_MASK                       0x03
15190b559df5SStephen Boyd #define ICPC5_MASK                       0x03
15200b559df5SStephen Boyd #define ICPC6_MASK                       0x03
15210b559df5SStephen Boyd #define ICPC7_MASK                       0x03
15220b559df5SStephen Boyd #define OCPC0_MASK                       0x03
15230b559df5SStephen Boyd #define OCPC1_MASK                       0x03
15240b559df5SStephen Boyd #define OCPC2_MASK                       0x03
15250b559df5SStephen Boyd #define OCPC3_MASK                       0x03
15260b559df5SStephen Boyd #define OCPC4_MASK                       0x03
15270b559df5SStephen Boyd #define OCPC5_MASK                       0x03
15280b559df5SStephen Boyd #define OCPC6_MASK                       0x03
15290b559df5SStephen Boyd #define OCPC7_MASK                       0x03
15300b559df5SStephen Boyd 
15310b559df5SStephen Boyd 
15320b559df5SStephen Boyd /* PAR */
15330b559df5SStephen Boyd #define FAULT_MASK                       0x01
15340b559df5SStephen Boyd /* If a fault is present, these are the
15350b559df5SStephen Boyd same as the fault fields in the FAR */
15360b559df5SStephen Boyd #define FAULT_TF_MASK                    0x01
15370b559df5SStephen Boyd #define FAULT_AFF_MASK                   0x01
15380b559df5SStephen Boyd #define FAULT_APF_MASK                   0x01
15390b559df5SStephen Boyd #define FAULT_TLBMF_MASK                 0x01
15400b559df5SStephen Boyd #define FAULT_HTWDEEF_MASK               0x01
15410b559df5SStephen Boyd #define FAULT_HTWSEEF_MASK               0x01
15420b559df5SStephen Boyd #define FAULT_MHF_MASK                   0x01
15430b559df5SStephen Boyd #define FAULT_SL_MASK                    0x01
15440b559df5SStephen Boyd #define FAULT_SS_MASK                    0x01
15450b559df5SStephen Boyd 
15460b559df5SStephen Boyd /* If NO fault is present, the following
15470b559df5SStephen Boyd  * fields are in effect
15480b559df5SStephen Boyd  * (FAULT remains as before) */
15490b559df5SStephen Boyd #define PAR_NOFAULT_SS_MASK              0x01
15500b559df5SStephen Boyd #define PAR_NOFAULT_MT_MASK              0x07
15510b559df5SStephen Boyd #define PAR_NOFAULT_SH_MASK              0x01
15520b559df5SStephen Boyd #define PAR_NOFAULT_NS_MASK              0x01
15530b559df5SStephen Boyd #define PAR_NOFAULT_NOS_MASK             0x01
15540b559df5SStephen Boyd #define PAR_NPFAULT_PA_MASK              0x000FFFFF
15550b559df5SStephen Boyd 
15560b559df5SStephen Boyd 
15570b559df5SStephen Boyd /* PRRR */
15580b559df5SStephen Boyd #define MTC0_MASK                        0x03
15590b559df5SStephen Boyd #define MTC1_MASK                        0x03
15600b559df5SStephen Boyd #define MTC2_MASK                        0x03
15610b559df5SStephen Boyd #define MTC3_MASK                        0x03
15620b559df5SStephen Boyd #define MTC4_MASK                        0x03
15630b559df5SStephen Boyd #define MTC5_MASK                        0x03
15640b559df5SStephen Boyd #define MTC6_MASK                        0x03
15650b559df5SStephen Boyd #define MTC7_MASK                        0x03
15660b559df5SStephen Boyd #define SHDSH0_MASK                      0x01
15670b559df5SStephen Boyd #define SHDSH1_MASK                      0x01
15680b559df5SStephen Boyd #define SHNMSH0_MASK                     0x01
15690b559df5SStephen Boyd #define SHNMSH1_MASK                     0x01
15700b559df5SStephen Boyd #define NOS0_MASK                        0x01
15710b559df5SStephen Boyd #define NOS1_MASK                        0x01
15720b559df5SStephen Boyd #define NOS2_MASK                        0x01
15730b559df5SStephen Boyd #define NOS3_MASK                        0x01
15740b559df5SStephen Boyd #define NOS4_MASK                        0x01
15750b559df5SStephen Boyd #define NOS5_MASK                        0x01
15760b559df5SStephen Boyd #define NOS6_MASK                        0x01
15770b559df5SStephen Boyd #define NOS7_MASK                        0x01
15780b559df5SStephen Boyd 
15790b559df5SStephen Boyd 
15800b559df5SStephen Boyd /* RESUME */
15810b559df5SStephen Boyd #define TNR_MASK                         0x01
15820b559df5SStephen Boyd 
15830b559df5SStephen Boyd 
15840b559df5SStephen Boyd /* SCTLR */
15850b559df5SStephen Boyd #define M_MASK                           0x01
15860b559df5SStephen Boyd #define TRE_MASK                         0x01
15870b559df5SStephen Boyd #define AFE_MASK                         0x01
15880b559df5SStephen Boyd #define HAF_MASK                         0x01
15890b559df5SStephen Boyd #define BE_MASK                          0x01
15900b559df5SStephen Boyd #define AFFD_MASK                        0x01
15910b559df5SStephen Boyd 
15920b559df5SStephen Boyd 
15930b559df5SStephen Boyd /* TLBIASID */
15940b559df5SStephen Boyd #define TLBIASID_ASID_MASK               0xFF
15950b559df5SStephen Boyd 
15960b559df5SStephen Boyd 
15970b559df5SStephen Boyd /* TLBIVA */
15980b559df5SStephen Boyd #define TLBIVA_ASID_MASK                 0xFF
15990b559df5SStephen Boyd #define TLBIVA_VA_MASK                   0x000FFFFF
16000b559df5SStephen Boyd 
16010b559df5SStephen Boyd 
16020b559df5SStephen Boyd /* TLBIVAA */
16030b559df5SStephen Boyd #define TLBIVAA_VA_MASK                  0x000FFFFF
16040b559df5SStephen Boyd 
16050b559df5SStephen Boyd 
16060b559df5SStephen Boyd /* TLBLCKR */
16070b559df5SStephen Boyd #define LKE_MASK                         0x01
16080b559df5SStephen Boyd #define TLBLCKR_TLBIALLCFG_MASK          0x01
16090b559df5SStephen Boyd #define TLBIASIDCFG_MASK                 0x01
16100b559df5SStephen Boyd #define TLBIVAACFG_MASK                  0x01
16110b559df5SStephen Boyd #define FLOOR_MASK                       0xFF
16120b559df5SStephen Boyd #define VICTIM_MASK                      0xFF
16130b559df5SStephen Boyd 
16140b559df5SStephen Boyd 
16150b559df5SStephen Boyd /* TTBCR */
16160b559df5SStephen Boyd #define N_MASK                           0x07
16170b559df5SStephen Boyd #define PD0_MASK                         0x01
16180b559df5SStephen Boyd #define PD1_MASK                         0x01
16190b559df5SStephen Boyd 
16200b559df5SStephen Boyd 
16210b559df5SStephen Boyd /* TTBR0 */
16220b559df5SStephen Boyd #define TTBR0_IRGNH_MASK                 0x01
16230b559df5SStephen Boyd #define TTBR0_SH_MASK                    0x01
16240b559df5SStephen Boyd #define TTBR0_ORGN_MASK                  0x03
16250b559df5SStephen Boyd #define TTBR0_NOS_MASK                   0x01
16260b559df5SStephen Boyd #define TTBR0_IRGNL_MASK                 0x01
16270b559df5SStephen Boyd #define TTBR0_PA_MASK                    0x0003FFFF
16280b559df5SStephen Boyd 
16290b559df5SStephen Boyd 
16300b559df5SStephen Boyd /* TTBR1 */
16310b559df5SStephen Boyd #define TTBR1_IRGNH_MASK                 0x01
16320b559df5SStephen Boyd #define TTBR1_SH_MASK                    0x01
16330b559df5SStephen Boyd #define TTBR1_ORGN_MASK                  0x03
16340b559df5SStephen Boyd #define TTBR1_NOS_MASK                   0x01
16350b559df5SStephen Boyd #define TTBR1_IRGNL_MASK                 0x01
16360b559df5SStephen Boyd #define TTBR1_PA_MASK                    0x0003FFFF
16370b559df5SStephen Boyd 
16380b559df5SStephen Boyd 
16390b559df5SStephen Boyd /* V2PSR */
16400b559df5SStephen Boyd #define HIT_MASK                         0x01
16410b559df5SStephen Boyd #define INDEX_MASK                       0xFF
16420b559df5SStephen Boyd 
16430b559df5SStephen Boyd 
16440b559df5SStephen Boyd /* V2Pxx */
16450b559df5SStephen Boyd #define V2Pxx_INDEX_MASK                 0xFF
16460b559df5SStephen Boyd #define V2Pxx_VA_MASK                    0x000FFFFF
16470b559df5SStephen Boyd 
16480b559df5SStephen Boyd 
16490b559df5SStephen Boyd /* Context Register Shifts */
16500b559df5SStephen Boyd /* ACTLR */
16510b559df5SStephen Boyd #define CFERE_SHIFT                    0
16520b559df5SStephen Boyd #define CFEIE_SHIFT                    1
16530b559df5SStephen Boyd #define PTSHCFG_SHIFT                  2
16540b559df5SStephen Boyd #define RCOSH_SHIFT                    4
16550b559df5SStephen Boyd #define RCISH_SHIFT                    5
16560b559df5SStephen Boyd #define RCNSH_SHIFT                    6
16570b559df5SStephen Boyd #define PRIVCFG_SHIFT                  8
16580b559df5SStephen Boyd #define DNA_SHIFT                      10
16590b559df5SStephen Boyd #define DNLV2PA_SHIFT                  11
16600b559df5SStephen Boyd #define TLBMCFG_SHIFT                  12
16610b559df5SStephen Boyd #define CFCFG_SHIFT                    14
16620b559df5SStephen Boyd #define TIPCF_SHIFT                    15
16630b559df5SStephen Boyd #define V2PCFG_SHIFT                   16
16640b559df5SStephen Boyd #define HUME_SHIFT                     18
16650b559df5SStephen Boyd #define PTMTCFG_SHIFT                  20
16660b559df5SStephen Boyd #define PTMEMTYPE_SHIFT                21
16670b559df5SStephen Boyd 
16680b559df5SStephen Boyd 
16690b559df5SStephen Boyd /* BFBCR */
16700b559df5SStephen Boyd #define BFBDFE_SHIFT                   0
16710b559df5SStephen Boyd #define BFBSFE_SHIFT                   1
16720b559df5SStephen Boyd #define SFVS_SHIFT                     2
16730b559df5SStephen Boyd #define FLVIC_SHIFT                    4
16740b559df5SStephen Boyd #define SLVIC_SHIFT                    8
16750b559df5SStephen Boyd 
16760b559df5SStephen Boyd 
16770b559df5SStephen Boyd /* CONTEXTIDR */
16780b559df5SStephen Boyd #define CONTEXTIDR_ASID_SHIFT          0
16790b559df5SStephen Boyd #define PROCID_SHIFT                   8
16800b559df5SStephen Boyd 
16810b559df5SStephen Boyd 
16820b559df5SStephen Boyd /* FSR */
16830b559df5SStephen Boyd #define TF_SHIFT                       1
16840b559df5SStephen Boyd #define AFF_SHIFT                      2
16850b559df5SStephen Boyd #define APF_SHIFT                      3
16860b559df5SStephen Boyd #define TLBMF_SHIFT                    4
16870b559df5SStephen Boyd #define HTWDEEF_SHIFT                  5
16880b559df5SStephen Boyd #define HTWSEEF_SHIFT                  6
16890b559df5SStephen Boyd #define MHF_SHIFT                      7
16900b559df5SStephen Boyd #define SL_SHIFT                       16
16910b559df5SStephen Boyd #define SS_SHIFT                       30
16920b559df5SStephen Boyd #define MULTI_SHIFT                    31
16930b559df5SStephen Boyd 
16940b559df5SStephen Boyd 
16950b559df5SStephen Boyd /* FSYNR0 */
16960b559df5SStephen Boyd #define AMID_SHIFT                     0
16970b559df5SStephen Boyd #define APID_SHIFT                     8
16980b559df5SStephen Boyd #define ABID_SHIFT                     13
16990b559df5SStephen Boyd #define ATID_SHIFT                     24
17000b559df5SStephen Boyd 
17010b559df5SStephen Boyd 
17020b559df5SStephen Boyd /* FSYNR1 */
17030b559df5SStephen Boyd #define AMEMTYPE_SHIFT                 0
17040b559df5SStephen Boyd #define ASHARED_SHIFT                  3
17050b559df5SStephen Boyd #define AINNERSHARED_SHIFT             4
17060b559df5SStephen Boyd #define APRIV_SHIFT                    5
17070b559df5SStephen Boyd #define APROTNS_SHIFT                  6
17080b559df5SStephen Boyd #define AINST_SHIFT                    7
17090b559df5SStephen Boyd #define AWRITE_SHIFT                   8
17100b559df5SStephen Boyd #define ABURST_SHIFT                   10
17110b559df5SStephen Boyd #define ALEN_SHIFT                     12
17120b559df5SStephen Boyd #define FSYNR1_ASIZE_SHIFT             16
17130b559df5SStephen Boyd #define ALOCK_SHIFT                    20
17140b559df5SStephen Boyd #define AFULL_SHIFT                    24
17150b559df5SStephen Boyd 
17160b559df5SStephen Boyd 
17170b559df5SStephen Boyd /* NMRR */
17180b559df5SStephen Boyd #define ICPC0_SHIFT                    0
17190b559df5SStephen Boyd #define ICPC1_SHIFT                    2
17200b559df5SStephen Boyd #define ICPC2_SHIFT                    4
17210b559df5SStephen Boyd #define ICPC3_SHIFT                    6
17220b559df5SStephen Boyd #define ICPC4_SHIFT                    8
17230b559df5SStephen Boyd #define ICPC5_SHIFT                    10
17240b559df5SStephen Boyd #define ICPC6_SHIFT                    12
17250b559df5SStephen Boyd #define ICPC7_SHIFT                    14
17260b559df5SStephen Boyd #define OCPC0_SHIFT                    16
17270b559df5SStephen Boyd #define OCPC1_SHIFT                    18
17280b559df5SStephen Boyd #define OCPC2_SHIFT                    20
17290b559df5SStephen Boyd #define OCPC3_SHIFT                    22
17300b559df5SStephen Boyd #define OCPC4_SHIFT                    24
17310b559df5SStephen Boyd #define OCPC5_SHIFT                    26
17320b559df5SStephen Boyd #define OCPC6_SHIFT                    28
17330b559df5SStephen Boyd #define OCPC7_SHIFT                    30
17340b559df5SStephen Boyd 
17350b559df5SStephen Boyd 
17360b559df5SStephen Boyd /* PAR */
17370b559df5SStephen Boyd #define FAULT_SHIFT                    0
17380b559df5SStephen Boyd /* If a fault is present, these are the
17390b559df5SStephen Boyd same as the fault fields in the FAR */
17400b559df5SStephen Boyd #define FAULT_TF_SHIFT                 1
17410b559df5SStephen Boyd #define FAULT_AFF_SHIFT                2
17420b559df5SStephen Boyd #define FAULT_APF_SHIFT                3
17430b559df5SStephen Boyd #define FAULT_TLBMF_SHIFT              4
17440b559df5SStephen Boyd #define FAULT_HTWDEEF_SHIFT            5
17450b559df5SStephen Boyd #define FAULT_HTWSEEF_SHIFT            6
17460b559df5SStephen Boyd #define FAULT_MHF_SHIFT                7
17470b559df5SStephen Boyd #define FAULT_SL_SHIFT                 16
17480b559df5SStephen Boyd #define FAULT_SS_SHIFT                 30
17490b559df5SStephen Boyd 
17500b559df5SStephen Boyd /* If NO fault is present, the following
17510b559df5SStephen Boyd  * fields are in effect
17520b559df5SStephen Boyd  * (FAULT remains as before) */
17530b559df5SStephen Boyd #define PAR_NOFAULT_SS_SHIFT           1
17540b559df5SStephen Boyd #define PAR_NOFAULT_MT_SHIFT           4
17550b559df5SStephen Boyd #define PAR_NOFAULT_SH_SHIFT           7
17560b559df5SStephen Boyd #define PAR_NOFAULT_NS_SHIFT           9
17570b559df5SStephen Boyd #define PAR_NOFAULT_NOS_SHIFT          10
17580b559df5SStephen Boyd #define PAR_NPFAULT_PA_SHIFT           12
17590b559df5SStephen Boyd 
17600b559df5SStephen Boyd 
17610b559df5SStephen Boyd /* PRRR */
17620b559df5SStephen Boyd #define MTC0_SHIFT                     0
17630b559df5SStephen Boyd #define MTC1_SHIFT                     2
17640b559df5SStephen Boyd #define MTC2_SHIFT                     4
17650b559df5SStephen Boyd #define MTC3_SHIFT                     6
17660b559df5SStephen Boyd #define MTC4_SHIFT                     8
17670b559df5SStephen Boyd #define MTC5_SHIFT                     10
17680b559df5SStephen Boyd #define MTC6_SHIFT                     12
17690b559df5SStephen Boyd #define MTC7_SHIFT                     14
17700b559df5SStephen Boyd #define SHDSH0_SHIFT                   16
17710b559df5SStephen Boyd #define SHDSH1_SHIFT                   17
17720b559df5SStephen Boyd #define SHNMSH0_SHIFT                  18
17730b559df5SStephen Boyd #define SHNMSH1_SHIFT                  19
17740b559df5SStephen Boyd #define NOS0_SHIFT                     24
17750b559df5SStephen Boyd #define NOS1_SHIFT                     25
17760b559df5SStephen Boyd #define NOS2_SHIFT                     26
17770b559df5SStephen Boyd #define NOS3_SHIFT                     27
17780b559df5SStephen Boyd #define NOS4_SHIFT                     28
17790b559df5SStephen Boyd #define NOS5_SHIFT                     29
17800b559df5SStephen Boyd #define NOS6_SHIFT                     30
17810b559df5SStephen Boyd #define NOS7_SHIFT                     31
17820b559df5SStephen Boyd 
17830b559df5SStephen Boyd 
17840b559df5SStephen Boyd /* RESUME */
17850b559df5SStephen Boyd #define TNR_SHIFT                      0
17860b559df5SStephen Boyd 
17870b559df5SStephen Boyd 
17880b559df5SStephen Boyd /* SCTLR */
17890b559df5SStephen Boyd #define M_SHIFT                        0
17900b559df5SStephen Boyd #define TRE_SHIFT                      1
17910b559df5SStephen Boyd #define AFE_SHIFT                      2
17920b559df5SStephen Boyd #define HAF_SHIFT                      3
17930b559df5SStephen Boyd #define BE_SHIFT                       4
17940b559df5SStephen Boyd #define AFFD_SHIFT                     5
17950b559df5SStephen Boyd 
17960b559df5SStephen Boyd 
17970b559df5SStephen Boyd /* TLBIASID */
17980b559df5SStephen Boyd #define TLBIASID_ASID_SHIFT            0
17990b559df5SStephen Boyd 
18000b559df5SStephen Boyd 
18010b559df5SStephen Boyd /* TLBIVA */
18020b559df5SStephen Boyd #define TLBIVA_ASID_SHIFT              0
18030b559df5SStephen Boyd #define TLBIVA_VA_SHIFT                12
18040b559df5SStephen Boyd 
18050b559df5SStephen Boyd 
18060b559df5SStephen Boyd /* TLBIVAA */
18070b559df5SStephen Boyd #define TLBIVAA_VA_SHIFT               12
18080b559df5SStephen Boyd 
18090b559df5SStephen Boyd 
18100b559df5SStephen Boyd /* TLBLCKR */
18110b559df5SStephen Boyd #define LKE_SHIFT                      0
18120b559df5SStephen Boyd #define TLBLCKR_TLBIALLCFG_SHIFT       1
18130b559df5SStephen Boyd #define TLBIASIDCFG_SHIFT              2
18140b559df5SStephen Boyd #define TLBIVAACFG_SHIFT               3
18150b559df5SStephen Boyd #define FLOOR_SHIFT                    8
18160b559df5SStephen Boyd #define VICTIM_SHIFT                   8
18170b559df5SStephen Boyd 
18180b559df5SStephen Boyd 
18190b559df5SStephen Boyd /* TTBCR */
18200b559df5SStephen Boyd #define N_SHIFT                        3
18210b559df5SStephen Boyd #define PD0_SHIFT                      4
18220b559df5SStephen Boyd #define PD1_SHIFT                      5
18230b559df5SStephen Boyd 
18240b559df5SStephen Boyd 
18250b559df5SStephen Boyd /* TTBR0 */
18260b559df5SStephen Boyd #define TTBR0_IRGNH_SHIFT              0
18270b559df5SStephen Boyd #define TTBR0_SH_SHIFT                 1
18280b559df5SStephen Boyd #define TTBR0_ORGN_SHIFT               3
18290b559df5SStephen Boyd #define TTBR0_NOS_SHIFT                5
18300b559df5SStephen Boyd #define TTBR0_IRGNL_SHIFT              6
18310b559df5SStephen Boyd #define TTBR0_PA_SHIFT                 14
18320b559df5SStephen Boyd 
18330b559df5SStephen Boyd 
18340b559df5SStephen Boyd /* TTBR1 */
18350b559df5SStephen Boyd #define TTBR1_IRGNH_SHIFT              0
18360b559df5SStephen Boyd #define TTBR1_SH_SHIFT                 1
18370b559df5SStephen Boyd #define TTBR1_ORGN_SHIFT               3
18380b559df5SStephen Boyd #define TTBR1_NOS_SHIFT                5
18390b559df5SStephen Boyd #define TTBR1_IRGNL_SHIFT              6
18400b559df5SStephen Boyd #define TTBR1_PA_SHIFT                 14
18410b559df5SStephen Boyd 
18420b559df5SStephen Boyd 
18430b559df5SStephen Boyd /* V2PSR */
18440b559df5SStephen Boyd #define HIT_SHIFT                      0
18450b559df5SStephen Boyd #define INDEX_SHIFT                    8
18460b559df5SStephen Boyd 
18470b559df5SStephen Boyd 
18480b559df5SStephen Boyd /* V2Pxx */
18490b559df5SStephen Boyd #define V2Pxx_INDEX_SHIFT              0
18500b559df5SStephen Boyd #define V2Pxx_VA_SHIFT                 12
18510b559df5SStephen Boyd 
18520b559df5SStephen Boyd #endif
1853