cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

msm_iommu_hw-8xxx.h (75136B)


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