pgtable-hwdef.h 9.9 KB

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