1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Copyright (C) 2012 ARM Ltd. 4*4882a593Smuzhiyun */ 5*4882a593Smuzhiyun #ifndef __ASM_PGTABLE_HWDEF_H 6*4882a593Smuzhiyun #define __ASM_PGTABLE_HWDEF_H 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #include <asm/memory.h> 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun /* 11*4882a593Smuzhiyun * Number of page-table levels required to address 'va_bits' wide 12*4882a593Smuzhiyun * address, without section mapping. We resolve the top (va_bits - PAGE_SHIFT) 13*4882a593Smuzhiyun * bits with (PAGE_SHIFT - 3) bits at each page table level. Hence: 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * levels = DIV_ROUND_UP((va_bits - PAGE_SHIFT), (PAGE_SHIFT - 3)) 16*4882a593Smuzhiyun * 17*4882a593Smuzhiyun * where DIV_ROUND_UP(n, d) => (((n) + (d) - 1) / (d)) 18*4882a593Smuzhiyun * 19*4882a593Smuzhiyun * We cannot include linux/kernel.h which defines DIV_ROUND_UP here 20*4882a593Smuzhiyun * due to build issues. So we open code DIV_ROUND_UP here: 21*4882a593Smuzhiyun * 22*4882a593Smuzhiyun * ((((va_bits) - PAGE_SHIFT) + (PAGE_SHIFT - 3) - 1) / (PAGE_SHIFT - 3)) 23*4882a593Smuzhiyun * 24*4882a593Smuzhiyun * which gets simplified as : 25*4882a593Smuzhiyun */ 26*4882a593Smuzhiyun #define ARM64_HW_PGTABLE_LEVELS(va_bits) (((va_bits) - 4) / (PAGE_SHIFT - 3)) 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun /* 29*4882a593Smuzhiyun * Size mapped by an entry at level n ( 0 <= n <= 3) 30*4882a593Smuzhiyun * We map (PAGE_SHIFT - 3) at all translation levels and PAGE_SHIFT bits 31*4882a593Smuzhiyun * in the final page. The maximum number of translation levels supported by 32*4882a593Smuzhiyun * the architecture is 4. Hence, starting at level n, we have further 33*4882a593Smuzhiyun * ((4 - n) - 1) levels of translation excluding the offset within the page. 34*4882a593Smuzhiyun * So, the total number of bits mapped by an entry at level n is : 35*4882a593Smuzhiyun * 36*4882a593Smuzhiyun * ((4 - n) - 1) * (PAGE_SHIFT - 3) + PAGE_SHIFT 37*4882a593Smuzhiyun * 38*4882a593Smuzhiyun * Rearranging it a bit we get : 39*4882a593Smuzhiyun * (4 - n) * (PAGE_SHIFT - 3) + 3 40*4882a593Smuzhiyun */ 41*4882a593Smuzhiyun #define ARM64_HW_PGTABLE_LEVEL_SHIFT(n) ((PAGE_SHIFT - 3) * (4 - (n)) + 3) 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun #define PTRS_PER_PTE (1 << (PAGE_SHIFT - 3)) 44*4882a593Smuzhiyun 45*4882a593Smuzhiyun /* 46*4882a593Smuzhiyun * PMD_SHIFT determines the size a level 2 page table entry can map. 47*4882a593Smuzhiyun */ 48*4882a593Smuzhiyun #if CONFIG_PGTABLE_LEVELS > 2 49*4882a593Smuzhiyun #define PMD_SHIFT ARM64_HW_PGTABLE_LEVEL_SHIFT(2) 50*4882a593Smuzhiyun #define PMD_SIZE (_AC(1, UL) << PMD_SHIFT) 51*4882a593Smuzhiyun #define PMD_MASK (~(PMD_SIZE-1)) 52*4882a593Smuzhiyun #define PTRS_PER_PMD PTRS_PER_PTE 53*4882a593Smuzhiyun #endif 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun /* 56*4882a593Smuzhiyun * PUD_SHIFT determines the size a level 1 page table entry can map. 57*4882a593Smuzhiyun */ 58*4882a593Smuzhiyun #if CONFIG_PGTABLE_LEVELS > 3 59*4882a593Smuzhiyun #define PUD_SHIFT ARM64_HW_PGTABLE_LEVEL_SHIFT(1) 60*4882a593Smuzhiyun #define PUD_SIZE (_AC(1, UL) << PUD_SHIFT) 61*4882a593Smuzhiyun #define PUD_MASK (~(PUD_SIZE-1)) 62*4882a593Smuzhiyun #define PTRS_PER_PUD PTRS_PER_PTE 63*4882a593Smuzhiyun #endif 64*4882a593Smuzhiyun 65*4882a593Smuzhiyun /* 66*4882a593Smuzhiyun * PGDIR_SHIFT determines the size a top-level page table entry can map 67*4882a593Smuzhiyun * (depending on the configuration, this level can be 0, 1 or 2). 68*4882a593Smuzhiyun */ 69*4882a593Smuzhiyun #define PGDIR_SHIFT ARM64_HW_PGTABLE_LEVEL_SHIFT(4 - CONFIG_PGTABLE_LEVELS) 70*4882a593Smuzhiyun #define PGDIR_SIZE (_AC(1, UL) << PGDIR_SHIFT) 71*4882a593Smuzhiyun #define PGDIR_MASK (~(PGDIR_SIZE-1)) 72*4882a593Smuzhiyun #define PTRS_PER_PGD (1 << (VA_BITS - PGDIR_SHIFT)) 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun /* 75*4882a593Smuzhiyun * Section address mask and size definitions. 76*4882a593Smuzhiyun */ 77*4882a593Smuzhiyun #define SECTION_SHIFT PMD_SHIFT 78*4882a593Smuzhiyun #define SECTION_SIZE (_AC(1, UL) << SECTION_SHIFT) 79*4882a593Smuzhiyun #define SECTION_MASK (~(SECTION_SIZE-1)) 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun /* 82*4882a593Smuzhiyun * Contiguous page definitions. 83*4882a593Smuzhiyun */ 84*4882a593Smuzhiyun #define CONT_PTE_SHIFT (CONFIG_ARM64_CONT_PTE_SHIFT + PAGE_SHIFT) 85*4882a593Smuzhiyun #define CONT_PTES (1 << (CONT_PTE_SHIFT - PAGE_SHIFT)) 86*4882a593Smuzhiyun #define CONT_PTE_SIZE (CONT_PTES * PAGE_SIZE) 87*4882a593Smuzhiyun #define CONT_PTE_MASK (~(CONT_PTE_SIZE - 1)) 88*4882a593Smuzhiyun 89*4882a593Smuzhiyun #define CONT_PMD_SHIFT (CONFIG_ARM64_CONT_PMD_SHIFT + PMD_SHIFT) 90*4882a593Smuzhiyun #define CONT_PMDS (1 << (CONT_PMD_SHIFT - PMD_SHIFT)) 91*4882a593Smuzhiyun #define CONT_PMD_SIZE (CONT_PMDS * PMD_SIZE) 92*4882a593Smuzhiyun #define CONT_PMD_MASK (~(CONT_PMD_SIZE - 1)) 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun /* 95*4882a593Smuzhiyun * Hardware page table definitions. 96*4882a593Smuzhiyun * 97*4882a593Smuzhiyun * Level 1 descriptor (PUD). 98*4882a593Smuzhiyun */ 99*4882a593Smuzhiyun #define PUD_TYPE_TABLE (_AT(pudval_t, 3) << 0) 100*4882a593Smuzhiyun #define PUD_TABLE_BIT (_AT(pudval_t, 1) << 1) 101*4882a593Smuzhiyun #define PUD_TYPE_MASK (_AT(pudval_t, 3) << 0) 102*4882a593Smuzhiyun #define PUD_TYPE_SECT (_AT(pudval_t, 1) << 0) 103*4882a593Smuzhiyun #define PUD_SECT_RDONLY (_AT(pudval_t, 1) << 7) /* AP[2] */ 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun /* 106*4882a593Smuzhiyun * Level 2 descriptor (PMD). 107*4882a593Smuzhiyun */ 108*4882a593Smuzhiyun #define PMD_TYPE_MASK (_AT(pmdval_t, 3) << 0) 109*4882a593Smuzhiyun #define PMD_TYPE_TABLE (_AT(pmdval_t, 3) << 0) 110*4882a593Smuzhiyun #define PMD_TYPE_SECT (_AT(pmdval_t, 1) << 0) 111*4882a593Smuzhiyun #define PMD_TABLE_BIT (_AT(pmdval_t, 1) << 1) 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun /* 114*4882a593Smuzhiyun * Section 115*4882a593Smuzhiyun */ 116*4882a593Smuzhiyun #define PMD_SECT_VALID (_AT(pmdval_t, 1) << 0) 117*4882a593Smuzhiyun #define PMD_SECT_USER (_AT(pmdval_t, 1) << 6) /* AP[1] */ 118*4882a593Smuzhiyun #define PMD_SECT_RDONLY (_AT(pmdval_t, 1) << 7) /* AP[2] */ 119*4882a593Smuzhiyun #define PMD_SECT_S (_AT(pmdval_t, 3) << 8) 120*4882a593Smuzhiyun #define PMD_SECT_AF (_AT(pmdval_t, 1) << 10) 121*4882a593Smuzhiyun #define PMD_SECT_NG (_AT(pmdval_t, 1) << 11) 122*4882a593Smuzhiyun #define PMD_SECT_CONT (_AT(pmdval_t, 1) << 52) 123*4882a593Smuzhiyun #define PMD_SECT_PXN (_AT(pmdval_t, 1) << 53) 124*4882a593Smuzhiyun #define PMD_SECT_UXN (_AT(pmdval_t, 1) << 54) 125*4882a593Smuzhiyun 126*4882a593Smuzhiyun /* 127*4882a593Smuzhiyun * AttrIndx[2:0] encoding (mapping attributes defined in the MAIR* registers). 128*4882a593Smuzhiyun */ 129*4882a593Smuzhiyun #define PMD_ATTRINDX(t) (_AT(pmdval_t, (t)) << 2) 130*4882a593Smuzhiyun #define PMD_ATTRINDX_MASK (_AT(pmdval_t, 7) << 2) 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun /* 133*4882a593Smuzhiyun * Level 3 descriptor (PTE). 134*4882a593Smuzhiyun */ 135*4882a593Smuzhiyun #define PTE_VALID (_AT(pteval_t, 1) << 0) 136*4882a593Smuzhiyun #define PTE_TYPE_MASK (_AT(pteval_t, 3) << 0) 137*4882a593Smuzhiyun #define PTE_TYPE_PAGE (_AT(pteval_t, 3) << 0) 138*4882a593Smuzhiyun #define PTE_TABLE_BIT (_AT(pteval_t, 1) << 1) 139*4882a593Smuzhiyun #define PTE_USER (_AT(pteval_t, 1) << 6) /* AP[1] */ 140*4882a593Smuzhiyun #define PTE_RDONLY (_AT(pteval_t, 1) << 7) /* AP[2] */ 141*4882a593Smuzhiyun #define PTE_SHARED (_AT(pteval_t, 3) << 8) /* SH[1:0], inner shareable */ 142*4882a593Smuzhiyun #define PTE_AF (_AT(pteval_t, 1) << 10) /* Access Flag */ 143*4882a593Smuzhiyun #define PTE_NG (_AT(pteval_t, 1) << 11) /* nG */ 144*4882a593Smuzhiyun #define PTE_GP (_AT(pteval_t, 1) << 50) /* BTI guarded */ 145*4882a593Smuzhiyun #define PTE_DBM (_AT(pteval_t, 1) << 51) /* Dirty Bit Management */ 146*4882a593Smuzhiyun #define PTE_CONT (_AT(pteval_t, 1) << 52) /* Contiguous range */ 147*4882a593Smuzhiyun #define PTE_PXN (_AT(pteval_t, 1) << 53) /* Privileged XN */ 148*4882a593Smuzhiyun #define PTE_UXN (_AT(pteval_t, 1) << 54) /* User XN */ 149*4882a593Smuzhiyun 150*4882a593Smuzhiyun #define PTE_ADDR_LOW (((_AT(pteval_t, 1) << (48 - PAGE_SHIFT)) - 1) << PAGE_SHIFT) 151*4882a593Smuzhiyun #ifdef CONFIG_ARM64_PA_BITS_52 152*4882a593Smuzhiyun #define PTE_ADDR_HIGH (_AT(pteval_t, 0xf) << 12) 153*4882a593Smuzhiyun #define PTE_ADDR_MASK (PTE_ADDR_LOW | PTE_ADDR_HIGH) 154*4882a593Smuzhiyun #else 155*4882a593Smuzhiyun #define PTE_ADDR_MASK PTE_ADDR_LOW 156*4882a593Smuzhiyun #endif 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun /* 159*4882a593Smuzhiyun * AttrIndx[2:0] encoding (mapping attributes defined in the MAIR* registers). 160*4882a593Smuzhiyun */ 161*4882a593Smuzhiyun #define PTE_ATTRINDX(t) (_AT(pteval_t, (t)) << 2) 162*4882a593Smuzhiyun #define PTE_ATTRINDX_MASK (_AT(pteval_t, 7) << 2) 163*4882a593Smuzhiyun 164*4882a593Smuzhiyun /* 165*4882a593Smuzhiyun * Memory Attribute override for Stage-2 (MemAttr[3:0]) 166*4882a593Smuzhiyun */ 167*4882a593Smuzhiyun #define PTE_S2_MEMATTR(t) (_AT(pteval_t, (t)) << 2) 168*4882a593Smuzhiyun 169*4882a593Smuzhiyun /* 170*4882a593Smuzhiyun * Highest possible physical address supported. 171*4882a593Smuzhiyun */ 172*4882a593Smuzhiyun #define PHYS_MASK_SHIFT (CONFIG_ARM64_PA_BITS) 173*4882a593Smuzhiyun #define PHYS_MASK ((UL(1) << PHYS_MASK_SHIFT) - 1) 174*4882a593Smuzhiyun 175*4882a593Smuzhiyun #define TTBR_CNP_BIT (UL(1) << 0) 176*4882a593Smuzhiyun 177*4882a593Smuzhiyun /* 178*4882a593Smuzhiyun * TCR flags. 179*4882a593Smuzhiyun */ 180*4882a593Smuzhiyun #define TCR_T0SZ_OFFSET 0 181*4882a593Smuzhiyun #define TCR_T1SZ_OFFSET 16 182*4882a593Smuzhiyun #define TCR_T0SZ(x) ((UL(64) - (x)) << TCR_T0SZ_OFFSET) 183*4882a593Smuzhiyun #define TCR_T1SZ(x) ((UL(64) - (x)) << TCR_T1SZ_OFFSET) 184*4882a593Smuzhiyun #define TCR_TxSZ(x) (TCR_T0SZ(x) | TCR_T1SZ(x)) 185*4882a593Smuzhiyun #define TCR_TxSZ_WIDTH 6 186*4882a593Smuzhiyun #define TCR_T0SZ_MASK (((UL(1) << TCR_TxSZ_WIDTH) - 1) << TCR_T0SZ_OFFSET) 187*4882a593Smuzhiyun #define TCR_T1SZ_MASK (((UL(1) << TCR_TxSZ_WIDTH) - 1) << TCR_T1SZ_OFFSET) 188*4882a593Smuzhiyun 189*4882a593Smuzhiyun #define TCR_EPD0_SHIFT 7 190*4882a593Smuzhiyun #define TCR_EPD0_MASK (UL(1) << TCR_EPD0_SHIFT) 191*4882a593Smuzhiyun #define TCR_IRGN0_SHIFT 8 192*4882a593Smuzhiyun #define TCR_IRGN0_MASK (UL(3) << TCR_IRGN0_SHIFT) 193*4882a593Smuzhiyun #define TCR_IRGN0_NC (UL(0) << TCR_IRGN0_SHIFT) 194*4882a593Smuzhiyun #define TCR_IRGN0_WBWA (UL(1) << TCR_IRGN0_SHIFT) 195*4882a593Smuzhiyun #define TCR_IRGN0_WT (UL(2) << TCR_IRGN0_SHIFT) 196*4882a593Smuzhiyun #define TCR_IRGN0_WBnWA (UL(3) << TCR_IRGN0_SHIFT) 197*4882a593Smuzhiyun 198*4882a593Smuzhiyun #define TCR_EPD1_SHIFT 23 199*4882a593Smuzhiyun #define TCR_EPD1_MASK (UL(1) << TCR_EPD1_SHIFT) 200*4882a593Smuzhiyun #define TCR_IRGN1_SHIFT 24 201*4882a593Smuzhiyun #define TCR_IRGN1_MASK (UL(3) << TCR_IRGN1_SHIFT) 202*4882a593Smuzhiyun #define TCR_IRGN1_NC (UL(0) << TCR_IRGN1_SHIFT) 203*4882a593Smuzhiyun #define TCR_IRGN1_WBWA (UL(1) << TCR_IRGN1_SHIFT) 204*4882a593Smuzhiyun #define TCR_IRGN1_WT (UL(2) << TCR_IRGN1_SHIFT) 205*4882a593Smuzhiyun #define TCR_IRGN1_WBnWA (UL(3) << TCR_IRGN1_SHIFT) 206*4882a593Smuzhiyun 207*4882a593Smuzhiyun #define TCR_IRGN_NC (TCR_IRGN0_NC | TCR_IRGN1_NC) 208*4882a593Smuzhiyun #define TCR_IRGN_WBWA (TCR_IRGN0_WBWA | TCR_IRGN1_WBWA) 209*4882a593Smuzhiyun #define TCR_IRGN_WT (TCR_IRGN0_WT | TCR_IRGN1_WT) 210*4882a593Smuzhiyun #define TCR_IRGN_WBnWA (TCR_IRGN0_WBnWA | TCR_IRGN1_WBnWA) 211*4882a593Smuzhiyun #define TCR_IRGN_MASK (TCR_IRGN0_MASK | TCR_IRGN1_MASK) 212*4882a593Smuzhiyun 213*4882a593Smuzhiyun 214*4882a593Smuzhiyun #define TCR_ORGN0_SHIFT 10 215*4882a593Smuzhiyun #define TCR_ORGN0_MASK (UL(3) << TCR_ORGN0_SHIFT) 216*4882a593Smuzhiyun #define TCR_ORGN0_NC (UL(0) << TCR_ORGN0_SHIFT) 217*4882a593Smuzhiyun #define TCR_ORGN0_WBWA (UL(1) << TCR_ORGN0_SHIFT) 218*4882a593Smuzhiyun #define TCR_ORGN0_WT (UL(2) << TCR_ORGN0_SHIFT) 219*4882a593Smuzhiyun #define TCR_ORGN0_WBnWA (UL(3) << TCR_ORGN0_SHIFT) 220*4882a593Smuzhiyun 221*4882a593Smuzhiyun #define TCR_ORGN1_SHIFT 26 222*4882a593Smuzhiyun #define TCR_ORGN1_MASK (UL(3) << TCR_ORGN1_SHIFT) 223*4882a593Smuzhiyun #define TCR_ORGN1_NC (UL(0) << TCR_ORGN1_SHIFT) 224*4882a593Smuzhiyun #define TCR_ORGN1_WBWA (UL(1) << TCR_ORGN1_SHIFT) 225*4882a593Smuzhiyun #define TCR_ORGN1_WT (UL(2) << TCR_ORGN1_SHIFT) 226*4882a593Smuzhiyun #define TCR_ORGN1_WBnWA (UL(3) << TCR_ORGN1_SHIFT) 227*4882a593Smuzhiyun 228*4882a593Smuzhiyun #define TCR_ORGN_NC (TCR_ORGN0_NC | TCR_ORGN1_NC) 229*4882a593Smuzhiyun #define TCR_ORGN_WBWA (TCR_ORGN0_WBWA | TCR_ORGN1_WBWA) 230*4882a593Smuzhiyun #define TCR_ORGN_WT (TCR_ORGN0_WT | TCR_ORGN1_WT) 231*4882a593Smuzhiyun #define TCR_ORGN_WBnWA (TCR_ORGN0_WBnWA | TCR_ORGN1_WBnWA) 232*4882a593Smuzhiyun #define TCR_ORGN_MASK (TCR_ORGN0_MASK | TCR_ORGN1_MASK) 233*4882a593Smuzhiyun 234*4882a593Smuzhiyun #define TCR_SH0_SHIFT 12 235*4882a593Smuzhiyun #define TCR_SH0_MASK (UL(3) << TCR_SH0_SHIFT) 236*4882a593Smuzhiyun #define TCR_SH0_INNER (UL(3) << TCR_SH0_SHIFT) 237*4882a593Smuzhiyun 238*4882a593Smuzhiyun #define TCR_SH1_SHIFT 28 239*4882a593Smuzhiyun #define TCR_SH1_MASK (UL(3) << TCR_SH1_SHIFT) 240*4882a593Smuzhiyun #define TCR_SH1_INNER (UL(3) << TCR_SH1_SHIFT) 241*4882a593Smuzhiyun #define TCR_SHARED (TCR_SH0_INNER | TCR_SH1_INNER) 242*4882a593Smuzhiyun 243*4882a593Smuzhiyun #define TCR_TG0_SHIFT 14 244*4882a593Smuzhiyun #define TCR_TG0_MASK (UL(3) << TCR_TG0_SHIFT) 245*4882a593Smuzhiyun #define TCR_TG0_4K (UL(0) << TCR_TG0_SHIFT) 246*4882a593Smuzhiyun #define TCR_TG0_64K (UL(1) << TCR_TG0_SHIFT) 247*4882a593Smuzhiyun #define TCR_TG0_16K (UL(2) << TCR_TG0_SHIFT) 248*4882a593Smuzhiyun 249*4882a593Smuzhiyun #define TCR_TG1_SHIFT 30 250*4882a593Smuzhiyun #define TCR_TG1_MASK (UL(3) << TCR_TG1_SHIFT) 251*4882a593Smuzhiyun #define TCR_TG1_16K (UL(1) << TCR_TG1_SHIFT) 252*4882a593Smuzhiyun #define TCR_TG1_4K (UL(2) << TCR_TG1_SHIFT) 253*4882a593Smuzhiyun #define TCR_TG1_64K (UL(3) << TCR_TG1_SHIFT) 254*4882a593Smuzhiyun 255*4882a593Smuzhiyun #define TCR_IPS_SHIFT 32 256*4882a593Smuzhiyun #define TCR_IPS_MASK (UL(7) << TCR_IPS_SHIFT) 257*4882a593Smuzhiyun #define TCR_A1 (UL(1) << 22) 258*4882a593Smuzhiyun #define TCR_ASID16 (UL(1) << 36) 259*4882a593Smuzhiyun #define TCR_TBI0 (UL(1) << 37) 260*4882a593Smuzhiyun #define TCR_TBI1 (UL(1) << 38) 261*4882a593Smuzhiyun #define TCR_HA (UL(1) << 39) 262*4882a593Smuzhiyun #define TCR_HD (UL(1) << 40) 263*4882a593Smuzhiyun #define TCR_TBID1 (UL(1) << 52) 264*4882a593Smuzhiyun #define TCR_NFD0 (UL(1) << 53) 265*4882a593Smuzhiyun #define TCR_NFD1 (UL(1) << 54) 266*4882a593Smuzhiyun #define TCR_E0PD0 (UL(1) << 55) 267*4882a593Smuzhiyun #define TCR_E0PD1 (UL(1) << 56) 268*4882a593Smuzhiyun 269*4882a593Smuzhiyun /* 270*4882a593Smuzhiyun * TTBR. 271*4882a593Smuzhiyun */ 272*4882a593Smuzhiyun #ifdef CONFIG_ARM64_PA_BITS_52 273*4882a593Smuzhiyun /* 274*4882a593Smuzhiyun * This should be GENMASK_ULL(47, 2). 275*4882a593Smuzhiyun * TTBR_ELx[1] is RES0 in this configuration. 276*4882a593Smuzhiyun */ 277*4882a593Smuzhiyun #define TTBR_BADDR_MASK_52 (((UL(1) << 46) - 1) << 2) 278*4882a593Smuzhiyun #endif 279*4882a593Smuzhiyun 280*4882a593Smuzhiyun #ifdef CONFIG_ARM64_VA_BITS_52 281*4882a593Smuzhiyun /* Must be at least 64-byte aligned to prevent corruption of the TTBR */ 282*4882a593Smuzhiyun #define TTBR1_BADDR_4852_OFFSET (((UL(1) << (52 - PGDIR_SHIFT)) - \ 283*4882a593Smuzhiyun (UL(1) << (48 - PGDIR_SHIFT))) * 8) 284*4882a593Smuzhiyun #endif 285*4882a593Smuzhiyun 286*4882a593Smuzhiyun #endif 287