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