sysreg.h 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Macros for accessing system registers with older binutils.
  4. *
  5. * Copyright (C) 2014 ARM Ltd.
  6. * Author: Catalin Marinas <catalin.marinas@arm.com>
  7. */
  8. #ifndef __ASM_SYSREG_H
  9. #define __ASM_SYSREG_H
  10. #include <linux/bits.h>
  11. #include <linux/stringify.h>
  12. #include <linux/kasan-tags.h>
  13. #include <linux/kconfig.h>
  14. #include <asm/gpr-num.h>
  15. /*
  16. * ARMv8 ARM reserves the following encoding for system registers:
  17. * (Ref: ARMv8 ARM, Section: "System instruction class encoding overview",
  18. * C5.2, version:ARM DDI 0487A.f)
  19. * [20-19] : Op0
  20. * [18-16] : Op1
  21. * [15-12] : CRn
  22. * [11-8] : CRm
  23. * [7-5] : Op2
  24. */
  25. #define Op0_shift 19
  26. #define Op0_mask 0x3
  27. #define Op1_shift 16
  28. #define Op1_mask 0x7
  29. #define CRn_shift 12
  30. #define CRn_mask 0xf
  31. #define CRm_shift 8
  32. #define CRm_mask 0xf
  33. #define Op2_shift 5
  34. #define Op2_mask 0x7
  35. #define sys_reg(op0, op1, crn, crm, op2) \
  36. (((op0) << Op0_shift) | ((op1) << Op1_shift) | \
  37. ((crn) << CRn_shift) | ((crm) << CRm_shift) | \
  38. ((op2) << Op2_shift))
  39. #define sys_insn sys_reg
  40. #define sys_reg_Op0(id) (((id) >> Op0_shift) & Op0_mask)
  41. #define sys_reg_Op1(id) (((id) >> Op1_shift) & Op1_mask)
  42. #define sys_reg_CRn(id) (((id) >> CRn_shift) & CRn_mask)
  43. #define sys_reg_CRm(id) (((id) >> CRm_shift) & CRm_mask)
  44. #define sys_reg_Op2(id) (((id) >> Op2_shift) & Op2_mask)
  45. #ifndef CONFIG_BROKEN_GAS_INST
  46. #ifdef __ASSEMBLER__
  47. // The space separator is omitted so that __emit_inst(x) can be parsed as
  48. // either an assembler directive or an assembler macro argument.
  49. #define __emit_inst(x) .inst(x)
  50. #else
  51. #define __emit_inst(x) ".inst " __stringify((x)) "\n\t"
  52. #endif
  53. #else /* CONFIG_BROKEN_GAS_INST */
  54. #ifndef CONFIG_CPU_BIG_ENDIAN
  55. #define __INSTR_BSWAP(x) (x)
  56. #else /* CONFIG_CPU_BIG_ENDIAN */
  57. #define __INSTR_BSWAP(x) ((((x) << 24) & 0xff000000) | \
  58. (((x) << 8) & 0x00ff0000) | \
  59. (((x) >> 8) & 0x0000ff00) | \
  60. (((x) >> 24) & 0x000000ff))
  61. #endif /* CONFIG_CPU_BIG_ENDIAN */
  62. #ifdef __ASSEMBLER__
  63. #define __emit_inst(x) .long __INSTR_BSWAP(x)
  64. #else /* __ASSEMBLER__ */
  65. #define __emit_inst(x) ".long " __stringify(__INSTR_BSWAP(x)) "\n\t"
  66. #endif /* __ASSEMBLER__ */
  67. #endif /* CONFIG_BROKEN_GAS_INST */
  68. /*
  69. * Instructions for modifying PSTATE fields.
  70. * As per Arm ARM for v8-A, Section "C.5.1.3 op0 == 0b00, architectural hints,
  71. * barriers and CLREX, and PSTATE access", ARM DDI 0487 C.a, system instructions
  72. * for accessing PSTATE fields have the following encoding:
  73. * Op0 = 0, CRn = 4
  74. * Op1, Op2 encodes the PSTATE field modified and defines the constraints.
  75. * CRm = Imm4 for the instruction.
  76. * Rt = 0x1f
  77. */
  78. #define pstate_field(op1, op2) ((op1) << Op1_shift | (op2) << Op2_shift)
  79. #define PSTATE_Imm_shift CRm_shift
  80. #define ENCODE_PSTATE(x, r) (0xd500401f | PSTATE_ ## r | ((!!x) << PSTATE_Imm_shift))
  81. #define SET_PSTATE(x, r) __emit_inst(ENCODE_PSTATE(x, r))
  82. #define PSTATE_PAN pstate_field(0, 4)
  83. #define PSTATE_UAO pstate_field(0, 3)
  84. #define PSTATE_SSBS pstate_field(3, 1)
  85. #define PSTATE_DIT pstate_field(3, 2)
  86. #define PSTATE_TCO pstate_field(3, 4)
  87. #define SET_PSTATE_PAN(x) SET_PSTATE((x), PAN)
  88. #define SET_PSTATE_UAO(x) SET_PSTATE((x), UAO)
  89. #define SET_PSTATE_SSBS(x) SET_PSTATE((x), SSBS)
  90. #define SET_PSTATE_DIT(x) SET_PSTATE((x), DIT)
  91. #define SET_PSTATE_TCO(x) SET_PSTATE((x), TCO)
  92. #define set_pstate_pan(x) asm volatile(SET_PSTATE_PAN(x))
  93. #define set_pstate_uao(x) asm volatile(SET_PSTATE_UAO(x))
  94. #define set_pstate_ssbs(x) asm volatile(SET_PSTATE_SSBS(x))
  95. #define set_pstate_dit(x) asm volatile(SET_PSTATE_DIT(x))
  96. /* Register-based PAN access, for save/restore purposes */
  97. #define SYS_PSTATE_PAN sys_reg(3, 0, 4, 2, 3)
  98. #define __SYS_BARRIER_INSN(op0, op1, CRn, CRm, op2, Rt) \
  99. __emit_inst(0xd5000000 | \
  100. sys_insn((op0), (op1), (CRn), (CRm), (op2)) | \
  101. ((Rt) & 0x1f))
  102. #define SB_BARRIER_INSN __SYS_BARRIER_INSN(0, 3, 3, 0, 7, 31)
  103. #define GSB_SYS_BARRIER_INSN __SYS_BARRIER_INSN(1, 0, 12, 0, 0, 31)
  104. #define GSB_ACK_BARRIER_INSN __SYS_BARRIER_INSN(1, 0, 12, 0, 1, 31)
  105. /* Data cache zero operations */
  106. #define SYS_DC_ISW sys_insn(1, 0, 7, 6, 2)
  107. #define SYS_DC_IGSW sys_insn(1, 0, 7, 6, 4)
  108. #define SYS_DC_IGDSW sys_insn(1, 0, 7, 6, 6)
  109. #define SYS_DC_CSW sys_insn(1, 0, 7, 10, 2)
  110. #define SYS_DC_CGSW sys_insn(1, 0, 7, 10, 4)
  111. #define SYS_DC_CGDSW sys_insn(1, 0, 7, 10, 6)
  112. #define SYS_DC_CISW sys_insn(1, 0, 7, 14, 2)
  113. #define SYS_DC_CIGSW sys_insn(1, 0, 7, 14, 4)
  114. #define SYS_DC_CIGDSW sys_insn(1, 0, 7, 14, 6)
  115. #define SYS_IC_IALLUIS sys_insn(1, 0, 7, 1, 0)
  116. #define SYS_IC_IALLU sys_insn(1, 0, 7, 5, 0)
  117. #define SYS_IC_IVAU sys_insn(1, 3, 7, 5, 1)
  118. #define SYS_DC_IVAC sys_insn(1, 0, 7, 6, 1)
  119. #define SYS_DC_IGVAC sys_insn(1, 0, 7, 6, 3)
  120. #define SYS_DC_IGDVAC sys_insn(1, 0, 7, 6, 5)
  121. #define SYS_DC_CVAC sys_insn(1, 3, 7, 10, 1)
  122. #define SYS_DC_CGVAC sys_insn(1, 3, 7, 10, 3)
  123. #define SYS_DC_CGDVAC sys_insn(1, 3, 7, 10, 5)
  124. #define SYS_DC_CVAU sys_insn(1, 3, 7, 11, 1)
  125. #define SYS_DC_CVAP sys_insn(1, 3, 7, 12, 1)
  126. #define SYS_DC_CGVAP sys_insn(1, 3, 7, 12, 3)
  127. #define SYS_DC_CGDVAP sys_insn(1, 3, 7, 12, 5)
  128. #define SYS_DC_CVADP sys_insn(1, 3, 7, 13, 1)
  129. #define SYS_DC_CGVADP sys_insn(1, 3, 7, 13, 3)
  130. #define SYS_DC_CGDVADP sys_insn(1, 3, 7, 13, 5)
  131. #define SYS_DC_CIVAC sys_insn(1, 3, 7, 14, 1)
  132. #define SYS_DC_CIGVAC sys_insn(1, 3, 7, 14, 3)
  133. #define SYS_DC_CIGDVAC sys_insn(1, 3, 7, 14, 5)
  134. #define SYS_DC_ZVA sys_insn(1, 3, 7, 4, 1)
  135. #define SYS_DC_GVA sys_insn(1, 3, 7, 4, 3)
  136. #define SYS_DC_GZVA sys_insn(1, 3, 7, 4, 4)
  137. #define SYS_DC_CIVAPS sys_insn(1, 0, 7, 15, 1)
  138. #define SYS_DC_CIGDVAPS sys_insn(1, 0, 7, 15, 5)
  139. /*
  140. * Automatically generated definitions for system registers, the
  141. * manual encodings below are in the process of being converted to
  142. * come from here. The header relies on the definition of sys_reg()
  143. * earlier in this file.
  144. */
  145. #include "asm/sysreg-defs.h"
  146. /*
  147. * System registers, organised loosely by encoding but grouped together
  148. * where the architected name contains an index. e.g. ID_MMFR<n>_EL1.
  149. */
  150. #define SYS_SVCR_SMSTOP_SM_EL0 sys_reg(0, 3, 4, 2, 3)
  151. #define SYS_SVCR_SMSTART_SM_EL0 sys_reg(0, 3, 4, 3, 3)
  152. #define SYS_SVCR_SMSTOP_SMZA_EL0 sys_reg(0, 3, 4, 6, 3)
  153. #define SYS_DBGBVRn_EL1(n) sys_reg(2, 0, 0, n, 4)
  154. #define SYS_DBGBCRn_EL1(n) sys_reg(2, 0, 0, n, 5)
  155. #define SYS_DBGWVRn_EL1(n) sys_reg(2, 0, 0, n, 6)
  156. #define SYS_DBGWCRn_EL1(n) sys_reg(2, 0, 0, n, 7)
  157. #define SYS_MDRAR_EL1 sys_reg(2, 0, 1, 0, 0)
  158. #define SYS_OSLSR_EL1 sys_reg(2, 0, 1, 1, 4)
  159. #define OSLSR_EL1_OSLM_MASK (BIT(3) | BIT(0))
  160. #define OSLSR_EL1_OSLM_NI 0
  161. #define OSLSR_EL1_OSLM_IMPLEMENTED BIT(3)
  162. #define OSLSR_EL1_OSLK BIT(1)
  163. #define SYS_OSDLR_EL1 sys_reg(2, 0, 1, 3, 4)
  164. #define SYS_DBGPRCR_EL1 sys_reg(2, 0, 1, 4, 4)
  165. #define SYS_DBGCLAIMSET_EL1 sys_reg(2, 0, 7, 8, 6)
  166. #define SYS_DBGCLAIMCLR_EL1 sys_reg(2, 0, 7, 9, 6)
  167. #define SYS_DBGAUTHSTATUS_EL1 sys_reg(2, 0, 7, 14, 6)
  168. #define SYS_MDCCSR_EL0 sys_reg(2, 3, 0, 1, 0)
  169. #define SYS_DBGDTR_EL0 sys_reg(2, 3, 0, 4, 0)
  170. #define SYS_DBGDTRRX_EL0 sys_reg(2, 3, 0, 5, 0)
  171. #define SYS_DBGDTRTX_EL0 sys_reg(2, 3, 0, 5, 0)
  172. #define SYS_DBGVCR32_EL2 sys_reg(2, 4, 0, 7, 0)
  173. #define SYS_BRBINF_EL1(n) sys_reg(2, 1, 8, (n & 15), (((n & 16) >> 2) | 0))
  174. #define SYS_BRBSRC_EL1(n) sys_reg(2, 1, 8, (n & 15), (((n & 16) >> 2) | 1))
  175. #define SYS_BRBTGT_EL1(n) sys_reg(2, 1, 8, (n & 15), (((n & 16) >> 2) | 2))
  176. #define SYS_TRCITECR_EL1 sys_reg(3, 0, 1, 2, 3)
  177. #define SYS_TRCACATR(m) sys_reg(2, 1, 2, ((m & 7) << 1), (2 | (m >> 3)))
  178. #define SYS_TRCACVR(m) sys_reg(2, 1, 2, ((m & 7) << 1), (0 | (m >> 3)))
  179. #define SYS_TRCAUTHSTATUS sys_reg(2, 1, 7, 14, 6)
  180. #define SYS_TRCAUXCTLR sys_reg(2, 1, 0, 6, 0)
  181. #define SYS_TRCBBCTLR sys_reg(2, 1, 0, 15, 0)
  182. #define SYS_TRCCCCTLR sys_reg(2, 1, 0, 14, 0)
  183. #define SYS_TRCCIDCCTLR0 sys_reg(2, 1, 3, 0, 2)
  184. #define SYS_TRCCIDCCTLR1 sys_reg(2, 1, 3, 1, 2)
  185. #define SYS_TRCCIDCVR(m) sys_reg(2, 1, 3, ((m & 7) << 1), 0)
  186. #define SYS_TRCCLAIMCLR sys_reg(2, 1, 7, 9, 6)
  187. #define SYS_TRCCLAIMSET sys_reg(2, 1, 7, 8, 6)
  188. #define SYS_TRCCNTCTLR(m) sys_reg(2, 1, 0, (4 | (m & 3)), 5)
  189. #define SYS_TRCCNTRLDVR(m) sys_reg(2, 1, 0, (0 | (m & 3)), 5)
  190. #define SYS_TRCCNTVR(m) sys_reg(2, 1, 0, (8 | (m & 3)), 5)
  191. #define SYS_TRCCONFIGR sys_reg(2, 1, 0, 4, 0)
  192. #define SYS_TRCDEVARCH sys_reg(2, 1, 7, 15, 6)
  193. #define SYS_TRCDEVID sys_reg(2, 1, 7, 2, 7)
  194. #define SYS_TRCEVENTCTL0R sys_reg(2, 1, 0, 8, 0)
  195. #define SYS_TRCEVENTCTL1R sys_reg(2, 1, 0, 9, 0)
  196. #define SYS_TRCEXTINSELR(m) sys_reg(2, 1, 0, (8 | (m & 3)), 4)
  197. #define SYS_TRCIDR0 sys_reg(2, 1, 0, 8, 7)
  198. #define SYS_TRCIDR10 sys_reg(2, 1, 0, 2, 6)
  199. #define SYS_TRCIDR11 sys_reg(2, 1, 0, 3, 6)
  200. #define SYS_TRCIDR12 sys_reg(2, 1, 0, 4, 6)
  201. #define SYS_TRCIDR13 sys_reg(2, 1, 0, 5, 6)
  202. #define SYS_TRCIDR1 sys_reg(2, 1, 0, 9, 7)
  203. #define SYS_TRCIDR2 sys_reg(2, 1, 0, 10, 7)
  204. #define SYS_TRCIDR3 sys_reg(2, 1, 0, 11, 7)
  205. #define SYS_TRCIDR4 sys_reg(2, 1, 0, 12, 7)
  206. #define SYS_TRCIDR5 sys_reg(2, 1, 0, 13, 7)
  207. #define SYS_TRCIDR6 sys_reg(2, 1, 0, 14, 7)
  208. #define SYS_TRCIDR7 sys_reg(2, 1, 0, 15, 7)
  209. #define SYS_TRCIDR8 sys_reg(2, 1, 0, 0, 6)
  210. #define SYS_TRCIDR9 sys_reg(2, 1, 0, 1, 6)
  211. #define SYS_TRCIMSPEC(m) sys_reg(2, 1, 0, (m & 7), 7)
  212. #define SYS_TRCITEEDCR sys_reg(2, 1, 0, 2, 1)
  213. #define SYS_TRCOSLSR sys_reg(2, 1, 1, 1, 4)
  214. #define SYS_TRCPRGCTLR sys_reg(2, 1, 0, 1, 0)
  215. #define SYS_TRCQCTLR sys_reg(2, 1, 0, 1, 1)
  216. #define SYS_TRCRSCTLR(m) sys_reg(2, 1, 1, (m & 15), (0 | (m >> 4)))
  217. #define SYS_TRCRSR sys_reg(2, 1, 0, 10, 0)
  218. #define SYS_TRCSEQEVR(m) sys_reg(2, 1, 0, (m & 3), 4)
  219. #define SYS_TRCSEQRSTEVR sys_reg(2, 1, 0, 6, 4)
  220. #define SYS_TRCSEQSTR sys_reg(2, 1, 0, 7, 4)
  221. #define SYS_TRCSSCCR(m) sys_reg(2, 1, 1, (m & 7), 2)
  222. #define SYS_TRCSSCSR(m) sys_reg(2, 1, 1, (8 | (m & 7)), 2)
  223. #define SYS_TRCSSPCICR(m) sys_reg(2, 1, 1, (m & 7), 3)
  224. #define SYS_TRCSTALLCTLR sys_reg(2, 1, 0, 11, 0)
  225. #define SYS_TRCSTATR sys_reg(2, 1, 0, 3, 0)
  226. #define SYS_TRCSYNCPR sys_reg(2, 1, 0, 13, 0)
  227. #define SYS_TRCTRACEIDR sys_reg(2, 1, 0, 0, 1)
  228. #define SYS_TRCTSCTLR sys_reg(2, 1, 0, 12, 0)
  229. #define SYS_TRCVICTLR sys_reg(2, 1, 0, 0, 2)
  230. #define SYS_TRCVIIECTLR sys_reg(2, 1, 0, 1, 2)
  231. #define SYS_TRCVIPCSSCTLR sys_reg(2, 1, 0, 3, 2)
  232. #define SYS_TRCVISSCTLR sys_reg(2, 1, 0, 2, 2)
  233. #define SYS_TRCVMIDCCTLR0 sys_reg(2, 1, 3, 2, 2)
  234. #define SYS_TRCVMIDCCTLR1 sys_reg(2, 1, 3, 3, 2)
  235. #define SYS_TRCVMIDCVR(m) sys_reg(2, 1, 3, ((m & 7) << 1), 1)
  236. /* ETM */
  237. #define SYS_TRCOSLAR sys_reg(2, 1, 1, 0, 4)
  238. #define SYS_MIDR_EL1 sys_reg(3, 0, 0, 0, 0)
  239. #define SYS_MPIDR_EL1 sys_reg(3, 0, 0, 0, 5)
  240. #define SYS_REVIDR_EL1 sys_reg(3, 0, 0, 0, 6)
  241. #define SYS_ACTLR_EL1 sys_reg(3, 0, 1, 0, 1)
  242. #define SYS_RGSR_EL1 sys_reg(3, 0, 1, 0, 5)
  243. #define SYS_GCR_EL1 sys_reg(3, 0, 1, 0, 6)
  244. #define SYS_APIAKEYLO_EL1 sys_reg(3, 0, 2, 1, 0)
  245. #define SYS_APIAKEYHI_EL1 sys_reg(3, 0, 2, 1, 1)
  246. #define SYS_APIBKEYLO_EL1 sys_reg(3, 0, 2, 1, 2)
  247. #define SYS_APIBKEYHI_EL1 sys_reg(3, 0, 2, 1, 3)
  248. #define SYS_APDAKEYLO_EL1 sys_reg(3, 0, 2, 2, 0)
  249. #define SYS_APDAKEYHI_EL1 sys_reg(3, 0, 2, 2, 1)
  250. #define SYS_APDBKEYLO_EL1 sys_reg(3, 0, 2, 2, 2)
  251. #define SYS_APDBKEYHI_EL1 sys_reg(3, 0, 2, 2, 3)
  252. #define SYS_APGAKEYLO_EL1 sys_reg(3, 0, 2, 3, 0)
  253. #define SYS_APGAKEYHI_EL1 sys_reg(3, 0, 2, 3, 1)
  254. #define SYS_SPSR_EL1 sys_reg(3, 0, 4, 0, 0)
  255. #define SYS_ELR_EL1 sys_reg(3, 0, 4, 0, 1)
  256. #define SYS_ICC_PMR_EL1 sys_reg(3, 0, 4, 6, 0)
  257. #define SYS_AFSR0_EL1 sys_reg(3, 0, 5, 1, 0)
  258. #define SYS_AFSR1_EL1 sys_reg(3, 0, 5, 1, 1)
  259. #define SYS_ESR_EL1 sys_reg(3, 0, 5, 2, 0)
  260. #define SYS_ERRIDR_EL1 sys_reg(3, 0, 5, 3, 0)
  261. #define SYS_ERRSELR_EL1 sys_reg(3, 0, 5, 3, 1)
  262. #define SYS_ERXFR_EL1 sys_reg(3, 0, 5, 4, 0)
  263. #define SYS_ERXCTLR_EL1 sys_reg(3, 0, 5, 4, 1)
  264. #define SYS_ERXSTATUS_EL1 sys_reg(3, 0, 5, 4, 2)
  265. #define SYS_ERXADDR_EL1 sys_reg(3, 0, 5, 4, 3)
  266. #define SYS_ERXPFGF_EL1 sys_reg(3, 0, 5, 4, 4)
  267. #define SYS_ERXPFGCTL_EL1 sys_reg(3, 0, 5, 4, 5)
  268. #define SYS_ERXPFGCDN_EL1 sys_reg(3, 0, 5, 4, 6)
  269. #define SYS_ERXMISC0_EL1 sys_reg(3, 0, 5, 5, 0)
  270. #define SYS_ERXMISC1_EL1 sys_reg(3, 0, 5, 5, 1)
  271. #define SYS_ERXMISC2_EL1 sys_reg(3, 0, 5, 5, 2)
  272. #define SYS_ERXMISC3_EL1 sys_reg(3, 0, 5, 5, 3)
  273. #define SYS_TFSR_EL1 sys_reg(3, 0, 5, 6, 0)
  274. #define SYS_TFSRE0_EL1 sys_reg(3, 0, 5, 6, 1)
  275. #define SYS_PAR_EL1 sys_reg(3, 0, 7, 4, 0)
  276. #define SYS_PAR_EL1_F BIT(0)
  277. /* When PAR_EL1.F == 1 */
  278. #define SYS_PAR_EL1_FST GENMASK(6, 1)
  279. #define SYS_PAR_EL1_PTW BIT(8)
  280. #define SYS_PAR_EL1_S BIT(9)
  281. #define SYS_PAR_EL1_AssuredOnly BIT(12)
  282. #define SYS_PAR_EL1_TopLevel BIT(13)
  283. #define SYS_PAR_EL1_Overlay BIT(14)
  284. #define SYS_PAR_EL1_DirtyBit BIT(15)
  285. #define SYS_PAR_EL1_F1_IMPDEF GENMASK_ULL(63, 48)
  286. #define SYS_PAR_EL1_F1_RES0 (BIT(7) | BIT(10) | GENMASK_ULL(47, 16))
  287. #define SYS_PAR_EL1_RES1 BIT(11)
  288. /* When PAR_EL1.F == 0 */
  289. #define SYS_PAR_EL1_SH GENMASK_ULL(8, 7)
  290. #define SYS_PAR_EL1_NS BIT(9)
  291. #define SYS_PAR_EL1_F0_IMPDEF BIT(10)
  292. #define SYS_PAR_EL1_NSE BIT(11)
  293. #define SYS_PAR_EL1_PA GENMASK_ULL(51, 12)
  294. #define SYS_PAR_EL1_ATTR GENMASK_ULL(63, 56)
  295. #define SYS_PAR_EL1_F0_RES0 (GENMASK_ULL(6, 1) | GENMASK_ULL(55, 52))
  296. /* Buffer error reporting */
  297. #define PMBSR_EL1_FAULT_FSC_SHIFT PMBSR_EL1_MSS_SHIFT
  298. #define PMBSR_EL1_FAULT_FSC_MASK PMBSR_EL1_MSS_MASK
  299. #define PMBSR_EL1_BUF_BSC_SHIFT PMBSR_EL1_MSS_SHIFT
  300. #define PMBSR_EL1_BUF_BSC_MASK PMBSR_EL1_MSS_MASK
  301. #define PMBSR_EL1_BUF_BSC_FULL 0x1UL
  302. /*** End of Statistical Profiling Extension ***/
  303. #define TRBSR_EL1_BSC_MASK GENMASK(5, 0)
  304. #define TRBSR_EL1_BSC_SHIFT 0
  305. #define SYS_PMINTENSET_EL1 sys_reg(3, 0, 9, 14, 1)
  306. #define SYS_PMINTENCLR_EL1 sys_reg(3, 0, 9, 14, 2)
  307. #define SYS_PMMIR_EL1 sys_reg(3, 0, 9, 14, 6)
  308. #define SYS_MAIR_EL1 sys_reg(3, 0, 10, 2, 0)
  309. #define SYS_AMAIR_EL1 sys_reg(3, 0, 10, 3, 0)
  310. #define SYS_VBAR_EL1 sys_reg(3, 0, 12, 0, 0)
  311. #define SYS_DISR_EL1 sys_reg(3, 0, 12, 1, 1)
  312. #define SYS_ICC_IAR0_EL1 sys_reg(3, 0, 12, 8, 0)
  313. #define SYS_ICC_EOIR0_EL1 sys_reg(3, 0, 12, 8, 1)
  314. #define SYS_ICC_HPPIR0_EL1 sys_reg(3, 0, 12, 8, 2)
  315. #define SYS_ICC_BPR0_EL1 sys_reg(3, 0, 12, 8, 3)
  316. #define SYS_ICC_AP0Rn_EL1(n) sys_reg(3, 0, 12, 8, 4 | n)
  317. #define SYS_ICC_AP0R0_EL1 SYS_ICC_AP0Rn_EL1(0)
  318. #define SYS_ICC_AP0R1_EL1 SYS_ICC_AP0Rn_EL1(1)
  319. #define SYS_ICC_AP0R2_EL1 SYS_ICC_AP0Rn_EL1(2)
  320. #define SYS_ICC_AP0R3_EL1 SYS_ICC_AP0Rn_EL1(3)
  321. #define SYS_ICC_AP1Rn_EL1(n) sys_reg(3, 0, 12, 9, n)
  322. #define SYS_ICC_AP1R0_EL1 SYS_ICC_AP1Rn_EL1(0)
  323. #define SYS_ICC_AP1R1_EL1 SYS_ICC_AP1Rn_EL1(1)
  324. #define SYS_ICC_AP1R2_EL1 SYS_ICC_AP1Rn_EL1(2)
  325. #define SYS_ICC_AP1R3_EL1 SYS_ICC_AP1Rn_EL1(3)
  326. #define SYS_ICC_DIR_EL1 sys_reg(3, 0, 12, 11, 1)
  327. #define SYS_ICC_RPR_EL1 sys_reg(3, 0, 12, 11, 3)
  328. #define SYS_ICC_SGI1R_EL1 sys_reg(3, 0, 12, 11, 5)
  329. #define SYS_ICC_ASGI1R_EL1 sys_reg(3, 0, 12, 11, 6)
  330. #define SYS_ICC_SGI0R_EL1 sys_reg(3, 0, 12, 11, 7)
  331. #define SYS_ICC_IAR1_EL1 sys_reg(3, 0, 12, 12, 0)
  332. #define SYS_ICC_EOIR1_EL1 sys_reg(3, 0, 12, 12, 1)
  333. #define SYS_ICC_HPPIR1_EL1 sys_reg(3, 0, 12, 12, 2)
  334. #define SYS_ICC_BPR1_EL1 sys_reg(3, 0, 12, 12, 3)
  335. #define SYS_ICC_CTLR_EL1 sys_reg(3, 0, 12, 12, 4)
  336. #define SYS_ICC_SRE_EL1 sys_reg(3, 0, 12, 12, 5)
  337. #define SYS_ICC_IGRPEN0_EL1 sys_reg(3, 0, 12, 12, 6)
  338. #define SYS_ICC_IGRPEN1_EL1 sys_reg(3, 0, 12, 12, 7)
  339. #define SYS_ACCDATA_EL1 sys_reg(3, 0, 13, 0, 5)
  340. #define SYS_CNTKCTL_EL1 sys_reg(3, 0, 14, 1, 0)
  341. #define SYS_AIDR_EL1 sys_reg(3, 1, 0, 0, 7)
  342. #define SYS_RNDR_EL0 sys_reg(3, 3, 2, 4, 0)
  343. #define SYS_RNDRRS_EL0 sys_reg(3, 3, 2, 4, 1)
  344. #define SYS_PMCR_EL0 sys_reg(3, 3, 9, 12, 0)
  345. #define SYS_PMCNTENSET_EL0 sys_reg(3, 3, 9, 12, 1)
  346. #define SYS_PMCNTENCLR_EL0 sys_reg(3, 3, 9, 12, 2)
  347. #define SYS_PMOVSCLR_EL0 sys_reg(3, 3, 9, 12, 3)
  348. #define SYS_PMSWINC_EL0 sys_reg(3, 3, 9, 12, 4)
  349. #define SYS_PMCEID0_EL0 sys_reg(3, 3, 9, 12, 6)
  350. #define SYS_PMCEID1_EL0 sys_reg(3, 3, 9, 12, 7)
  351. #define SYS_PMCCNTR_EL0 sys_reg(3, 3, 9, 13, 0)
  352. #define SYS_PMXEVTYPER_EL0 sys_reg(3, 3, 9, 13, 1)
  353. #define SYS_PMXEVCNTR_EL0 sys_reg(3, 3, 9, 13, 2)
  354. #define SYS_PMUSERENR_EL0 sys_reg(3, 3, 9, 14, 0)
  355. #define SYS_PMOVSSET_EL0 sys_reg(3, 3, 9, 14, 3)
  356. #define SYS_TPIDR_EL0 sys_reg(3, 3, 13, 0, 2)
  357. #define SYS_TPIDRRO_EL0 sys_reg(3, 3, 13, 0, 3)
  358. #define SYS_TPIDR2_EL0 sys_reg(3, 3, 13, 0, 5)
  359. #define SYS_SCXTNUM_EL0 sys_reg(3, 3, 13, 0, 7)
  360. /* Definitions for system register interface to AMU for ARMv8.4 onwards */
  361. #define SYS_AM_EL0(crm, op2) sys_reg(3, 3, 13, (crm), (op2))
  362. #define SYS_AMCR_EL0 SYS_AM_EL0(2, 0)
  363. #define SYS_AMCFGR_EL0 SYS_AM_EL0(2, 1)
  364. #define SYS_AMCGCR_EL0 SYS_AM_EL0(2, 2)
  365. #define SYS_AMUSERENR_EL0 SYS_AM_EL0(2, 3)
  366. #define SYS_AMCNTENCLR0_EL0 SYS_AM_EL0(2, 4)
  367. #define SYS_AMCNTENSET0_EL0 SYS_AM_EL0(2, 5)
  368. #define SYS_AMCNTENCLR1_EL0 SYS_AM_EL0(3, 0)
  369. #define SYS_AMCNTENSET1_EL0 SYS_AM_EL0(3, 1)
  370. /*
  371. * Group 0 of activity monitors (architected):
  372. * op0 op1 CRn CRm op2
  373. * Counter: 11 011 1101 010:n<3> n<2:0>
  374. * Type: 11 011 1101 011:n<3> n<2:0>
  375. * n: 0-15
  376. *
  377. * Group 1 of activity monitors (auxiliary):
  378. * op0 op1 CRn CRm op2
  379. * Counter: 11 011 1101 110:n<3> n<2:0>
  380. * Type: 11 011 1101 111:n<3> n<2:0>
  381. * n: 0-15
  382. */
  383. #define SYS_AMEVCNTR0_EL0(n) SYS_AM_EL0(4 + ((n) >> 3), (n) & 7)
  384. #define SYS_AMEVTYPER0_EL0(n) SYS_AM_EL0(6 + ((n) >> 3), (n) & 7)
  385. #define SYS_AMEVCNTR1_EL0(n) SYS_AM_EL0(12 + ((n) >> 3), (n) & 7)
  386. #define SYS_AMEVTYPER1_EL0(n) SYS_AM_EL0(14 + ((n) >> 3), (n) & 7)
  387. /* AMU v1: Fixed (architecturally defined) activity monitors */
  388. #define SYS_AMEVCNTR0_CORE_EL0 SYS_AMEVCNTR0_EL0(0)
  389. #define SYS_AMEVCNTR0_CONST_EL0 SYS_AMEVCNTR0_EL0(1)
  390. #define SYS_AMEVCNTR0_INST_RET_EL0 SYS_AMEVCNTR0_EL0(2)
  391. #define SYS_AMEVCNTR0_MEM_STALL SYS_AMEVCNTR0_EL0(3)
  392. #define SYS_CNTFRQ_EL0 sys_reg(3, 3, 14, 0, 0)
  393. #define SYS_CNTPCT_EL0 sys_reg(3, 3, 14, 0, 1)
  394. #define SYS_CNTVCT_EL0 sys_reg(3, 3, 14, 0, 2)
  395. #define SYS_CNTPCTSS_EL0 sys_reg(3, 3, 14, 0, 5)
  396. #define SYS_CNTVCTSS_EL0 sys_reg(3, 3, 14, 0, 6)
  397. #define SYS_CNTP_TVAL_EL0 sys_reg(3, 3, 14, 2, 0)
  398. #define SYS_CNTP_CTL_EL0 sys_reg(3, 3, 14, 2, 1)
  399. #define SYS_CNTP_CVAL_EL0 sys_reg(3, 3, 14, 2, 2)
  400. #define SYS_CNTV_TVAL_EL0 sys_reg(3, 3, 14, 3, 0)
  401. #define SYS_CNTV_CTL_EL0 sys_reg(3, 3, 14, 3, 1)
  402. #define SYS_CNTV_CVAL_EL0 sys_reg(3, 3, 14, 3, 2)
  403. #define SYS_AARCH32_CNTP_TVAL sys_reg(0, 0, 14, 2, 0)
  404. #define SYS_AARCH32_CNTP_CTL sys_reg(0, 0, 14, 2, 1)
  405. #define SYS_AARCH32_CNTPCT sys_reg(0, 0, 0, 14, 0)
  406. #define SYS_AARCH32_CNTVCT sys_reg(0, 1, 0, 14, 0)
  407. #define SYS_AARCH32_CNTP_CVAL sys_reg(0, 2, 0, 14, 0)
  408. #define SYS_AARCH32_CNTPCTSS sys_reg(0, 8, 0, 14, 0)
  409. #define SYS_AARCH32_CNTVCTSS sys_reg(0, 9, 0, 14, 0)
  410. #define __PMEV_op2(n) ((n) & 0x7)
  411. #define __CNTR_CRm(n) (0x8 | (((n) >> 3) & 0x3))
  412. #define SYS_PMEVCNTSVRn_EL1(n) sys_reg(2, 0, 14, __CNTR_CRm(n), __PMEV_op2(n))
  413. #define SYS_PMEVCNTRn_EL0(n) sys_reg(3, 3, 14, __CNTR_CRm(n), __PMEV_op2(n))
  414. #define __TYPER_CRm(n) (0xc | (((n) >> 3) & 0x3))
  415. #define SYS_PMEVTYPERn_EL0(n) sys_reg(3, 3, 14, __TYPER_CRm(n), __PMEV_op2(n))
  416. #define SYS_PMCCFILTR_EL0 sys_reg(3, 3, 14, 15, 7)
  417. #define SYS_SPMCGCRn_EL1(n) sys_reg(2, 0, 9, 13, ((n) & 1))
  418. #define __SPMEV_op2(n) ((n) & 0x7)
  419. #define __SPMEV_crm(p, n) ((((p) & 7) << 1) | (((n) >> 3) & 1))
  420. #define SYS_SPMEVCNTRn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b000, n), __SPMEV_op2(n))
  421. #define SYS_SPMEVFILT2Rn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b011, n), __SPMEV_op2(n))
  422. #define SYS_SPMEVFILTRn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b010, n), __SPMEV_op2(n))
  423. #define SYS_SPMEVTYPERn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b001, n), __SPMEV_op2(n))
  424. #define SYS_VPIDR_EL2 sys_reg(3, 4, 0, 0, 0)
  425. #define SYS_VMPIDR_EL2 sys_reg(3, 4, 0, 0, 5)
  426. #define SYS_ACTLR_EL2 sys_reg(3, 4, 1, 0, 1)
  427. #define SYS_SCTLR2_EL2 sys_reg(3, 4, 1, 0, 3)
  428. #define SYS_HCR_EL2 sys_reg(3, 4, 1, 1, 0)
  429. #define SYS_MDCR_EL2 sys_reg(3, 4, 1, 1, 1)
  430. #define SYS_CPTR_EL2 sys_reg(3, 4, 1, 1, 2)
  431. #define SYS_HSTR_EL2 sys_reg(3, 4, 1, 1, 3)
  432. #define SYS_HACR_EL2 sys_reg(3, 4, 1, 1, 7)
  433. #define SYS_TTBR0_EL2 sys_reg(3, 4, 2, 0, 0)
  434. #define SYS_TTBR1_EL2 sys_reg(3, 4, 2, 0, 1)
  435. #define SYS_TCR_EL2 sys_reg(3, 4, 2, 0, 2)
  436. #define SYS_VTTBR_EL2 sys_reg(3, 4, 2, 1, 0)
  437. #define SYS_HAFGRTR_EL2 sys_reg(3, 4, 3, 1, 6)
  438. #define SYS_SPSR_EL2 sys_reg(3, 4, 4, 0, 0)
  439. #define SYS_ELR_EL2 sys_reg(3, 4, 4, 0, 1)
  440. #define SYS_SP_EL1 sys_reg(3, 4, 4, 1, 0)
  441. #define SYS_SPSR_irq sys_reg(3, 4, 4, 3, 0)
  442. #define SYS_SPSR_abt sys_reg(3, 4, 4, 3, 1)
  443. #define SYS_SPSR_und sys_reg(3, 4, 4, 3, 2)
  444. #define SYS_SPSR_fiq sys_reg(3, 4, 4, 3, 3)
  445. #define SYS_IFSR32_EL2 sys_reg(3, 4, 5, 0, 1)
  446. #define SYS_AFSR0_EL2 sys_reg(3, 4, 5, 1, 0)
  447. #define SYS_AFSR1_EL2 sys_reg(3, 4, 5, 1, 1)
  448. #define SYS_ESR_EL2 sys_reg(3, 4, 5, 2, 0)
  449. #define SYS_VSESR_EL2 sys_reg(3, 4, 5, 2, 3)
  450. #define SYS_FPEXC32_EL2 sys_reg(3, 4, 5, 3, 0)
  451. #define SYS_TFSR_EL2 sys_reg(3, 4, 5, 6, 0)
  452. #define SYS_FAR_EL2 sys_reg(3, 4, 6, 0, 0)
  453. #define SYS_HPFAR_EL2 sys_reg(3, 4, 6, 0, 4)
  454. #define SYS_MAIR_EL2 sys_reg(3, 4, 10, 2, 0)
  455. #define SYS_AMAIR_EL2 sys_reg(3, 4, 10, 3, 0)
  456. #define SYS_VBAR_EL2 sys_reg(3, 4, 12, 0, 0)
  457. #define SYS_RVBAR_EL2 sys_reg(3, 4, 12, 0, 1)
  458. #define SYS_RMR_EL2 sys_reg(3, 4, 12, 0, 2)
  459. #define SYS_VDISR_EL2 sys_reg(3, 4, 12, 1, 1)
  460. #define __SYS__AP0Rx_EL2(x) sys_reg(3, 4, 12, 8, x)
  461. #define SYS_ICH_AP0R0_EL2 __SYS__AP0Rx_EL2(0)
  462. #define SYS_ICH_AP0R1_EL2 __SYS__AP0Rx_EL2(1)
  463. #define SYS_ICH_AP0R2_EL2 __SYS__AP0Rx_EL2(2)
  464. #define SYS_ICH_AP0R3_EL2 __SYS__AP0Rx_EL2(3)
  465. #define __SYS__AP1Rx_EL2(x) sys_reg(3, 4, 12, 9, x)
  466. #define SYS_ICH_AP1R0_EL2 __SYS__AP1Rx_EL2(0)
  467. #define SYS_ICH_AP1R1_EL2 __SYS__AP1Rx_EL2(1)
  468. #define SYS_ICH_AP1R2_EL2 __SYS__AP1Rx_EL2(2)
  469. #define SYS_ICH_AP1R3_EL2 __SYS__AP1Rx_EL2(3)
  470. #define SYS_ICH_VSEIR_EL2 sys_reg(3, 4, 12, 9, 4)
  471. #define SYS_ICC_SRE_EL2 sys_reg(3, 4, 12, 9, 5)
  472. #define SYS_ICH_EISR_EL2 sys_reg(3, 4, 12, 11, 3)
  473. #define SYS_ICH_ELRSR_EL2 sys_reg(3, 4, 12, 11, 5)
  474. #define __SYS__LR0_EL2(x) sys_reg(3, 4, 12, 12, x)
  475. #define SYS_ICH_LR0_EL2 __SYS__LR0_EL2(0)
  476. #define SYS_ICH_LR1_EL2 __SYS__LR0_EL2(1)
  477. #define SYS_ICH_LR2_EL2 __SYS__LR0_EL2(2)
  478. #define SYS_ICH_LR3_EL2 __SYS__LR0_EL2(3)
  479. #define SYS_ICH_LR4_EL2 __SYS__LR0_EL2(4)
  480. #define SYS_ICH_LR5_EL2 __SYS__LR0_EL2(5)
  481. #define SYS_ICH_LR6_EL2 __SYS__LR0_EL2(6)
  482. #define SYS_ICH_LR7_EL2 __SYS__LR0_EL2(7)
  483. #define __SYS__LR8_EL2(x) sys_reg(3, 4, 12, 13, x)
  484. #define SYS_ICH_LR8_EL2 __SYS__LR8_EL2(0)
  485. #define SYS_ICH_LR9_EL2 __SYS__LR8_EL2(1)
  486. #define SYS_ICH_LR10_EL2 __SYS__LR8_EL2(2)
  487. #define SYS_ICH_LR11_EL2 __SYS__LR8_EL2(3)
  488. #define SYS_ICH_LR12_EL2 __SYS__LR8_EL2(4)
  489. #define SYS_ICH_LR13_EL2 __SYS__LR8_EL2(5)
  490. #define SYS_ICH_LR14_EL2 __SYS__LR8_EL2(6)
  491. #define SYS_ICH_LR15_EL2 __SYS__LR8_EL2(7)
  492. #define SYS_CONTEXTIDR_EL2 sys_reg(3, 4, 13, 0, 1)
  493. #define SYS_TPIDR_EL2 sys_reg(3, 4, 13, 0, 2)
  494. #define SYS_SCXTNUM_EL2 sys_reg(3, 4, 13, 0, 7)
  495. #define __AMEV_op2(m) (m & 0x7)
  496. #define __AMEV_CRm(n, m) (n | ((m & 0x8) >> 3))
  497. #define __SYS__AMEVCNTVOFF0n_EL2(m) sys_reg(3, 4, 13, __AMEV_CRm(0x8, m), __AMEV_op2(m))
  498. #define SYS_AMEVCNTVOFF0n_EL2(m) __SYS__AMEVCNTVOFF0n_EL2(m)
  499. #define __SYS__AMEVCNTVOFF1n_EL2(m) sys_reg(3, 4, 13, __AMEV_CRm(0xA, m), __AMEV_op2(m))
  500. #define SYS_AMEVCNTVOFF1n_EL2(m) __SYS__AMEVCNTVOFF1n_EL2(m)
  501. #define SYS_CNTVOFF_EL2 sys_reg(3, 4, 14, 0, 3)
  502. #define SYS_CNTHCTL_EL2 sys_reg(3, 4, 14, 1, 0)
  503. #define SYS_CNTHP_TVAL_EL2 sys_reg(3, 4, 14, 2, 0)
  504. #define SYS_CNTHP_CTL_EL2 sys_reg(3, 4, 14, 2, 1)
  505. #define SYS_CNTHP_CVAL_EL2 sys_reg(3, 4, 14, 2, 2)
  506. #define SYS_CNTHV_TVAL_EL2 sys_reg(3, 4, 14, 3, 0)
  507. #define SYS_CNTHV_CTL_EL2 sys_reg(3, 4, 14, 3, 1)
  508. #define SYS_CNTHV_CVAL_EL2 sys_reg(3, 4, 14, 3, 2)
  509. /* VHE encodings for architectural EL0/1 system registers */
  510. #define SYS_BRBCR_EL12 sys_reg(2, 5, 9, 0, 0)
  511. #define SYS_TTBR0_EL12 sys_reg(3, 5, 2, 0, 0)
  512. #define SYS_TTBR1_EL12 sys_reg(3, 5, 2, 0, 1)
  513. #define SYS_SPSR_EL12 sys_reg(3, 5, 4, 0, 0)
  514. #define SYS_ELR_EL12 sys_reg(3, 5, 4, 0, 1)
  515. #define SYS_AFSR0_EL12 sys_reg(3, 5, 5, 1, 0)
  516. #define SYS_AFSR1_EL12 sys_reg(3, 5, 5, 1, 1)
  517. #define SYS_ESR_EL12 sys_reg(3, 5, 5, 2, 0)
  518. #define SYS_TFSR_EL12 sys_reg(3, 5, 5, 6, 0)
  519. #define SYS_PMSCR_EL12 sys_reg(3, 5, 9, 9, 0)
  520. #define SYS_MAIR_EL12 sys_reg(3, 5, 10, 2, 0)
  521. #define SYS_AMAIR_EL12 sys_reg(3, 5, 10, 3, 0)
  522. #define SYS_VBAR_EL12 sys_reg(3, 5, 12, 0, 0)
  523. #define SYS_SCXTNUM_EL12 sys_reg(3, 5, 13, 0, 7)
  524. #define SYS_CNTKCTL_EL12 sys_reg(3, 5, 14, 1, 0)
  525. #define SYS_CNTP_TVAL_EL02 sys_reg(3, 5, 14, 2, 0)
  526. #define SYS_CNTP_CTL_EL02 sys_reg(3, 5, 14, 2, 1)
  527. #define SYS_CNTP_CVAL_EL02 sys_reg(3, 5, 14, 2, 2)
  528. #define SYS_CNTV_TVAL_EL02 sys_reg(3, 5, 14, 3, 0)
  529. #define SYS_CNTV_CTL_EL02 sys_reg(3, 5, 14, 3, 1)
  530. #define SYS_CNTV_CVAL_EL02 sys_reg(3, 5, 14, 3, 2)
  531. #define SYS_SP_EL2 sys_reg(3, 6, 4, 1, 0)
  532. /* AT instructions */
  533. #define AT_Op0 1
  534. #define AT_CRn 7
  535. #define OP_AT_S1E1R sys_insn(AT_Op0, 0, AT_CRn, 8, 0)
  536. #define OP_AT_S1E1W sys_insn(AT_Op0, 0, AT_CRn, 8, 1)
  537. #define OP_AT_S1E0R sys_insn(AT_Op0, 0, AT_CRn, 8, 2)
  538. #define OP_AT_S1E0W sys_insn(AT_Op0, 0, AT_CRn, 8, 3)
  539. #define OP_AT_S1E1RP sys_insn(AT_Op0, 0, AT_CRn, 9, 0)
  540. #define OP_AT_S1E1WP sys_insn(AT_Op0, 0, AT_CRn, 9, 1)
  541. #define OP_AT_S1E1A sys_insn(AT_Op0, 0, AT_CRn, 9, 2)
  542. #define OP_AT_S1E2R sys_insn(AT_Op0, 4, AT_CRn, 8, 0)
  543. #define OP_AT_S1E2W sys_insn(AT_Op0, 4, AT_CRn, 8, 1)
  544. #define OP_AT_S12E1R sys_insn(AT_Op0, 4, AT_CRn, 8, 4)
  545. #define OP_AT_S12E1W sys_insn(AT_Op0, 4, AT_CRn, 8, 5)
  546. #define OP_AT_S12E0R sys_insn(AT_Op0, 4, AT_CRn, 8, 6)
  547. #define OP_AT_S12E0W sys_insn(AT_Op0, 4, AT_CRn, 8, 7)
  548. #define OP_AT_S1E2A sys_insn(AT_Op0, 4, AT_CRn, 9, 2)
  549. /* TLBI instructions */
  550. #define TLBI_Op0 1
  551. #define TLBI_Op1_EL1 0 /* Accessible from EL1 or higher */
  552. #define TLBI_Op1_EL2 4 /* Accessible from EL2 or higher */
  553. #define TLBI_CRn_XS 8 /* Extra Slow (the common one) */
  554. #define TLBI_CRn_nXS 9 /* not Extra Slow (which nobody uses)*/
  555. #define TLBI_CRm_IPAIS 0 /* S2 Inner-Shareable */
  556. #define TLBI_CRm_nROS 1 /* non-Range, Outer-Sharable */
  557. #define TLBI_CRm_RIS 2 /* Range, Inner-Sharable */
  558. #define TLBI_CRm_nRIS 3 /* non-Range, Inner-Sharable */
  559. #define TLBI_CRm_IPAONS 4 /* S2 Outer and Non-Shareable */
  560. #define TLBI_CRm_ROS 5 /* Range, Outer-Sharable */
  561. #define TLBI_CRm_RNS 6 /* Range, Non-Sharable */
  562. #define TLBI_CRm_nRNS 7 /* non-Range, Non-Sharable */
  563. #define OP_TLBI_VMALLE1OS sys_insn(1, 0, 8, 1, 0)
  564. #define OP_TLBI_VAE1OS sys_insn(1, 0, 8, 1, 1)
  565. #define OP_TLBI_ASIDE1OS sys_insn(1, 0, 8, 1, 2)
  566. #define OP_TLBI_VAAE1OS sys_insn(1, 0, 8, 1, 3)
  567. #define OP_TLBI_VALE1OS sys_insn(1, 0, 8, 1, 5)
  568. #define OP_TLBI_VAALE1OS sys_insn(1, 0, 8, 1, 7)
  569. #define OP_TLBI_RVAE1IS sys_insn(1, 0, 8, 2, 1)
  570. #define OP_TLBI_RVAAE1IS sys_insn(1, 0, 8, 2, 3)
  571. #define OP_TLBI_RVALE1IS sys_insn(1, 0, 8, 2, 5)
  572. #define OP_TLBI_RVAALE1IS sys_insn(1, 0, 8, 2, 7)
  573. #define OP_TLBI_VMALLE1IS sys_insn(1, 0, 8, 3, 0)
  574. #define OP_TLBI_VAE1IS sys_insn(1, 0, 8, 3, 1)
  575. #define OP_TLBI_ASIDE1IS sys_insn(1, 0, 8, 3, 2)
  576. #define OP_TLBI_VAAE1IS sys_insn(1, 0, 8, 3, 3)
  577. #define OP_TLBI_VALE1IS sys_insn(1, 0, 8, 3, 5)
  578. #define OP_TLBI_VAALE1IS sys_insn(1, 0, 8, 3, 7)
  579. #define OP_TLBI_RVAE1OS sys_insn(1, 0, 8, 5, 1)
  580. #define OP_TLBI_RVAAE1OS sys_insn(1, 0, 8, 5, 3)
  581. #define OP_TLBI_RVALE1OS sys_insn(1, 0, 8, 5, 5)
  582. #define OP_TLBI_RVAALE1OS sys_insn(1, 0, 8, 5, 7)
  583. #define OP_TLBI_RVAE1 sys_insn(1, 0, 8, 6, 1)
  584. #define OP_TLBI_RVAAE1 sys_insn(1, 0, 8, 6, 3)
  585. #define OP_TLBI_RVALE1 sys_insn(1, 0, 8, 6, 5)
  586. #define OP_TLBI_RVAALE1 sys_insn(1, 0, 8, 6, 7)
  587. #define OP_TLBI_VMALLE1 sys_insn(1, 0, 8, 7, 0)
  588. #define OP_TLBI_VAE1 sys_insn(1, 0, 8, 7, 1)
  589. #define OP_TLBI_ASIDE1 sys_insn(1, 0, 8, 7, 2)
  590. #define OP_TLBI_VAAE1 sys_insn(1, 0, 8, 7, 3)
  591. #define OP_TLBI_VALE1 sys_insn(1, 0, 8, 7, 5)
  592. #define OP_TLBI_VAALE1 sys_insn(1, 0, 8, 7, 7)
  593. #define OP_TLBI_VMALLE1OSNXS sys_insn(1, 0, 9, 1, 0)
  594. #define OP_TLBI_VAE1OSNXS sys_insn(1, 0, 9, 1, 1)
  595. #define OP_TLBI_ASIDE1OSNXS sys_insn(1, 0, 9, 1, 2)
  596. #define OP_TLBI_VAAE1OSNXS sys_insn(1, 0, 9, 1, 3)
  597. #define OP_TLBI_VALE1OSNXS sys_insn(1, 0, 9, 1, 5)
  598. #define OP_TLBI_VAALE1OSNXS sys_insn(1, 0, 9, 1, 7)
  599. #define OP_TLBI_RVAE1ISNXS sys_insn(1, 0, 9, 2, 1)
  600. #define OP_TLBI_RVAAE1ISNXS sys_insn(1, 0, 9, 2, 3)
  601. #define OP_TLBI_RVALE1ISNXS sys_insn(1, 0, 9, 2, 5)
  602. #define OP_TLBI_RVAALE1ISNXS sys_insn(1, 0, 9, 2, 7)
  603. #define OP_TLBI_VMALLE1ISNXS sys_insn(1, 0, 9, 3, 0)
  604. #define OP_TLBI_VAE1ISNXS sys_insn(1, 0, 9, 3, 1)
  605. #define OP_TLBI_ASIDE1ISNXS sys_insn(1, 0, 9, 3, 2)
  606. #define OP_TLBI_VAAE1ISNXS sys_insn(1, 0, 9, 3, 3)
  607. #define OP_TLBI_VALE1ISNXS sys_insn(1, 0, 9, 3, 5)
  608. #define OP_TLBI_VAALE1ISNXS sys_insn(1, 0, 9, 3, 7)
  609. #define OP_TLBI_RVAE1OSNXS sys_insn(1, 0, 9, 5, 1)
  610. #define OP_TLBI_RVAAE1OSNXS sys_insn(1, 0, 9, 5, 3)
  611. #define OP_TLBI_RVALE1OSNXS sys_insn(1, 0, 9, 5, 5)
  612. #define OP_TLBI_RVAALE1OSNXS sys_insn(1, 0, 9, 5, 7)
  613. #define OP_TLBI_RVAE1NXS sys_insn(1, 0, 9, 6, 1)
  614. #define OP_TLBI_RVAAE1NXS sys_insn(1, 0, 9, 6, 3)
  615. #define OP_TLBI_RVALE1NXS sys_insn(1, 0, 9, 6, 5)
  616. #define OP_TLBI_RVAALE1NXS sys_insn(1, 0, 9, 6, 7)
  617. #define OP_TLBI_VMALLE1NXS sys_insn(1, 0, 9, 7, 0)
  618. #define OP_TLBI_VAE1NXS sys_insn(1, 0, 9, 7, 1)
  619. #define OP_TLBI_ASIDE1NXS sys_insn(1, 0, 9, 7, 2)
  620. #define OP_TLBI_VAAE1NXS sys_insn(1, 0, 9, 7, 3)
  621. #define OP_TLBI_VALE1NXS sys_insn(1, 0, 9, 7, 5)
  622. #define OP_TLBI_VAALE1NXS sys_insn(1, 0, 9, 7, 7)
  623. #define OP_TLBI_IPAS2E1IS sys_insn(1, 4, 8, 0, 1)
  624. #define OP_TLBI_RIPAS2E1IS sys_insn(1, 4, 8, 0, 2)
  625. #define OP_TLBI_IPAS2LE1IS sys_insn(1, 4, 8, 0, 5)
  626. #define OP_TLBI_RIPAS2LE1IS sys_insn(1, 4, 8, 0, 6)
  627. #define OP_TLBI_ALLE2OS sys_insn(1, 4, 8, 1, 0)
  628. #define OP_TLBI_VAE2OS sys_insn(1, 4, 8, 1, 1)
  629. #define OP_TLBI_ALLE1OS sys_insn(1, 4, 8, 1, 4)
  630. #define OP_TLBI_VALE2OS sys_insn(1, 4, 8, 1, 5)
  631. #define OP_TLBI_VMALLS12E1OS sys_insn(1, 4, 8, 1, 6)
  632. #define OP_TLBI_RVAE2IS sys_insn(1, 4, 8, 2, 1)
  633. #define OP_TLBI_RVALE2IS sys_insn(1, 4, 8, 2, 5)
  634. #define OP_TLBI_ALLE2IS sys_insn(1, 4, 8, 3, 0)
  635. #define OP_TLBI_VAE2IS sys_insn(1, 4, 8, 3, 1)
  636. #define OP_TLBI_ALLE1IS sys_insn(1, 4, 8, 3, 4)
  637. #define OP_TLBI_VALE2IS sys_insn(1, 4, 8, 3, 5)
  638. #define OP_TLBI_VMALLS12E1IS sys_insn(1, 4, 8, 3, 6)
  639. #define OP_TLBI_IPAS2E1OS sys_insn(1, 4, 8, 4, 0)
  640. #define OP_TLBI_IPAS2E1 sys_insn(1, 4, 8, 4, 1)
  641. #define OP_TLBI_RIPAS2E1 sys_insn(1, 4, 8, 4, 2)
  642. #define OP_TLBI_RIPAS2E1OS sys_insn(1, 4, 8, 4, 3)
  643. #define OP_TLBI_IPAS2LE1OS sys_insn(1, 4, 8, 4, 4)
  644. #define OP_TLBI_IPAS2LE1 sys_insn(1, 4, 8, 4, 5)
  645. #define OP_TLBI_RIPAS2LE1 sys_insn(1, 4, 8, 4, 6)
  646. #define OP_TLBI_RIPAS2LE1OS sys_insn(1, 4, 8, 4, 7)
  647. #define OP_TLBI_RVAE2OS sys_insn(1, 4, 8, 5, 1)
  648. #define OP_TLBI_RVALE2OS sys_insn(1, 4, 8, 5, 5)
  649. #define OP_TLBI_RVAE2 sys_insn(1, 4, 8, 6, 1)
  650. #define OP_TLBI_RVALE2 sys_insn(1, 4, 8, 6, 5)
  651. #define OP_TLBI_ALLE2 sys_insn(1, 4, 8, 7, 0)
  652. #define OP_TLBI_VAE2 sys_insn(1, 4, 8, 7, 1)
  653. #define OP_TLBI_ALLE1 sys_insn(1, 4, 8, 7, 4)
  654. #define OP_TLBI_VALE2 sys_insn(1, 4, 8, 7, 5)
  655. #define OP_TLBI_VMALLS12E1 sys_insn(1, 4, 8, 7, 6)
  656. #define OP_TLBI_IPAS2E1ISNXS sys_insn(1, 4, 9, 0, 1)
  657. #define OP_TLBI_RIPAS2E1ISNXS sys_insn(1, 4, 9, 0, 2)
  658. #define OP_TLBI_IPAS2LE1ISNXS sys_insn(1, 4, 9, 0, 5)
  659. #define OP_TLBI_RIPAS2LE1ISNXS sys_insn(1, 4, 9, 0, 6)
  660. #define OP_TLBI_ALLE2OSNXS sys_insn(1, 4, 9, 1, 0)
  661. #define OP_TLBI_VAE2OSNXS sys_insn(1, 4, 9, 1, 1)
  662. #define OP_TLBI_ALLE1OSNXS sys_insn(1, 4, 9, 1, 4)
  663. #define OP_TLBI_VALE2OSNXS sys_insn(1, 4, 9, 1, 5)
  664. #define OP_TLBI_VMALLS12E1OSNXS sys_insn(1, 4, 9, 1, 6)
  665. #define OP_TLBI_RVAE2ISNXS sys_insn(1, 4, 9, 2, 1)
  666. #define OP_TLBI_RVALE2ISNXS sys_insn(1, 4, 9, 2, 5)
  667. #define OP_TLBI_ALLE2ISNXS sys_insn(1, 4, 9, 3, 0)
  668. #define OP_TLBI_VAE2ISNXS sys_insn(1, 4, 9, 3, 1)
  669. #define OP_TLBI_ALLE1ISNXS sys_insn(1, 4, 9, 3, 4)
  670. #define OP_TLBI_VALE2ISNXS sys_insn(1, 4, 9, 3, 5)
  671. #define OP_TLBI_VMALLS12E1ISNXS sys_insn(1, 4, 9, 3, 6)
  672. #define OP_TLBI_IPAS2E1OSNXS sys_insn(1, 4, 9, 4, 0)
  673. #define OP_TLBI_IPAS2E1NXS sys_insn(1, 4, 9, 4, 1)
  674. #define OP_TLBI_RIPAS2E1NXS sys_insn(1, 4, 9, 4, 2)
  675. #define OP_TLBI_RIPAS2E1OSNXS sys_insn(1, 4, 9, 4, 3)
  676. #define OP_TLBI_IPAS2LE1OSNXS sys_insn(1, 4, 9, 4, 4)
  677. #define OP_TLBI_IPAS2LE1NXS sys_insn(1, 4, 9, 4, 5)
  678. #define OP_TLBI_RIPAS2LE1NXS sys_insn(1, 4, 9, 4, 6)
  679. #define OP_TLBI_RIPAS2LE1OSNXS sys_insn(1, 4, 9, 4, 7)
  680. #define OP_TLBI_RVAE2OSNXS sys_insn(1, 4, 9, 5, 1)
  681. #define OP_TLBI_RVALE2OSNXS sys_insn(1, 4, 9, 5, 5)
  682. #define OP_TLBI_RVAE2NXS sys_insn(1, 4, 9, 6, 1)
  683. #define OP_TLBI_RVALE2NXS sys_insn(1, 4, 9, 6, 5)
  684. #define OP_TLBI_ALLE2NXS sys_insn(1, 4, 9, 7, 0)
  685. #define OP_TLBI_VAE2NXS sys_insn(1, 4, 9, 7, 1)
  686. #define OP_TLBI_ALLE1NXS sys_insn(1, 4, 9, 7, 4)
  687. #define OP_TLBI_VALE2NXS sys_insn(1, 4, 9, 7, 5)
  688. #define OP_TLBI_VMALLS12E1NXS sys_insn(1, 4, 9, 7, 6)
  689. /* Misc instructions */
  690. #define OP_GCSPUSHX sys_insn(1, 0, 7, 7, 4)
  691. #define OP_GCSPOPCX sys_insn(1, 0, 7, 7, 5)
  692. #define OP_GCSPOPX sys_insn(1, 0, 7, 7, 6)
  693. #define OP_GCSPUSHM sys_insn(1, 3, 7, 7, 0)
  694. #define OP_BRB_IALL sys_insn(1, 1, 7, 2, 4)
  695. #define OP_BRB_INJ sys_insn(1, 1, 7, 2, 5)
  696. #define OP_CFP_RCTX sys_insn(1, 3, 7, 3, 4)
  697. #define OP_DVP_RCTX sys_insn(1, 3, 7, 3, 5)
  698. #define OP_COSP_RCTX sys_insn(1, 3, 7, 3, 6)
  699. #define OP_CPP_RCTX sys_insn(1, 3, 7, 3, 7)
  700. /*
  701. * BRBE Instructions
  702. */
  703. #define BRB_IALL_INSN __emit_inst(0xd5000000 | OP_BRB_IALL | (0x1f))
  704. #define BRB_INJ_INSN __emit_inst(0xd5000000 | OP_BRB_INJ | (0x1f))
  705. /* Common SCTLR_ELx flags. */
  706. #define SCTLR_ELx_ENTP2 (BIT(60))
  707. #define SCTLR_ELx_DSSBS (BIT(44))
  708. #define SCTLR_ELx_ATA (BIT(43))
  709. #define SCTLR_ELx_EE_SHIFT 25
  710. #define SCTLR_ELx_ENIA_SHIFT 31
  711. #define SCTLR_ELx_ITFSB (BIT(37))
  712. #define SCTLR_ELx_ENIA (BIT(SCTLR_ELx_ENIA_SHIFT))
  713. #define SCTLR_ELx_ENIB (BIT(30))
  714. #define SCTLR_ELx_LSMAOE (BIT(29))
  715. #define SCTLR_ELx_nTLSMD (BIT(28))
  716. #define SCTLR_ELx_ENDA (BIT(27))
  717. #define SCTLR_ELx_EE (BIT(SCTLR_ELx_EE_SHIFT))
  718. #define SCTLR_ELx_EIS (BIT(22))
  719. #define SCTLR_ELx_IESB (BIT(21))
  720. #define SCTLR_ELx_TSCXT (BIT(20))
  721. #define SCTLR_ELx_WXN (BIT(19))
  722. #define SCTLR_ELx_ENDB (BIT(13))
  723. #define SCTLR_ELx_I (BIT(12))
  724. #define SCTLR_ELx_EOS (BIT(11))
  725. #define SCTLR_ELx_SA (BIT(3))
  726. #define SCTLR_ELx_C (BIT(2))
  727. #define SCTLR_ELx_A (BIT(1))
  728. #define SCTLR_ELx_M (BIT(0))
  729. #ifdef CONFIG_CPU_BIG_ENDIAN
  730. #define ENDIAN_SET_EL2 SCTLR_ELx_EE
  731. #else
  732. #define ENDIAN_SET_EL2 0
  733. #endif
  734. #define INIT_SCTLR_EL2_MMU_ON \
  735. (SCTLR_ELx_M | SCTLR_ELx_C | SCTLR_ELx_SA | SCTLR_ELx_I | \
  736. SCTLR_ELx_IESB | SCTLR_ELx_WXN | ENDIAN_SET_EL2 | \
  737. SCTLR_ELx_ITFSB | SCTLR_EL2_RES1)
  738. #define INIT_SCTLR_EL2_MMU_OFF \
  739. (SCTLR_EL2_RES1 | ENDIAN_SET_EL2)
  740. /* SCTLR_EL1 specific flags. */
  741. #ifdef CONFIG_CPU_BIG_ENDIAN
  742. #define ENDIAN_SET_EL1 (SCTLR_EL1_E0E | SCTLR_ELx_EE)
  743. #else
  744. #define ENDIAN_SET_EL1 0
  745. #endif
  746. #define INIT_SCTLR_EL1_MMU_OFF \
  747. (ENDIAN_SET_EL1 | SCTLR_EL1_LSMAOE | SCTLR_EL1_nTLSMD | \
  748. SCTLR_EL1_EIS | SCTLR_EL1_TSCXT | SCTLR_EL1_EOS)
  749. #define INIT_SCTLR_EL1_MMU_ON \
  750. (SCTLR_ELx_M | SCTLR_ELx_C | SCTLR_ELx_SA | \
  751. SCTLR_EL1_SA0 | SCTLR_EL1_SED | SCTLR_ELx_I | \
  752. SCTLR_EL1_DZE | SCTLR_EL1_UCT | SCTLR_EL1_nTWE | \
  753. SCTLR_ELx_IESB | SCTLR_EL1_SPAN | SCTLR_ELx_ITFSB | \
  754. ENDIAN_SET_EL1 | SCTLR_EL1_UCI | SCTLR_EL1_EPAN | \
  755. SCTLR_EL1_LSMAOE | SCTLR_EL1_nTLSMD | SCTLR_EL1_EIS | \
  756. SCTLR_EL1_TSCXT | SCTLR_EL1_EOS)
  757. /* MAIR_ELx memory attributes (used by Linux) */
  758. #define MAIR_ATTR_DEVICE_nGnRnE UL(0x00)
  759. #define MAIR_ATTR_DEVICE_nGnRE UL(0x04)
  760. #define MAIR_ATTR_NORMAL_NC UL(0x44)
  761. #define MAIR_ATTR_NORMAL_TAGGED UL(0xf0)
  762. #define MAIR_ATTR_NORMAL UL(0xff)
  763. #define MAIR_ATTR_MASK UL(0xff)
  764. /* Position the attr at the correct index */
  765. #define MAIR_ATTRIDX(attr, idx) ((attr) << ((idx) * 8))
  766. /* id_aa64mmfr0 */
  767. #define ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MIN 0x0
  768. #define ID_AA64MMFR0_EL1_TGRAN4_LPA2 ID_AA64MMFR0_EL1_TGRAN4_52_BIT
  769. #define ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MAX 0x7
  770. #define ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MIN 0x0
  771. #define ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MAX 0x7
  772. #define ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MIN 0x1
  773. #define ID_AA64MMFR0_EL1_TGRAN16_LPA2 ID_AA64MMFR0_EL1_TGRAN16_52_BIT
  774. #define ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MAX 0xf
  775. #define ARM64_MIN_PARANGE_BITS 32
  776. #define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_DEFAULT 0x0
  777. #define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_NONE 0x1
  778. #define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_MIN 0x2
  779. #define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_LPA2 0x3
  780. #define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_MAX 0x7
  781. #ifdef CONFIG_ARM64_PA_BITS_52
  782. #define ID_AA64MMFR0_EL1_PARANGE_MAX ID_AA64MMFR0_EL1_PARANGE_52
  783. #else
  784. #define ID_AA64MMFR0_EL1_PARANGE_MAX ID_AA64MMFR0_EL1_PARANGE_48
  785. #endif
  786. #if defined(CONFIG_ARM64_4K_PAGES)
  787. #define ID_AA64MMFR0_EL1_TGRAN_SHIFT ID_AA64MMFR0_EL1_TGRAN4_SHIFT
  788. #define ID_AA64MMFR0_EL1_TGRAN_LPA2 ID_AA64MMFR0_EL1_TGRAN4_52_BIT
  789. #define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MIN ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MIN
  790. #define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MAX ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MAX
  791. #define ID_AA64MMFR0_EL1_TGRAN_2_SHIFT ID_AA64MMFR0_EL1_TGRAN4_2_SHIFT
  792. #elif defined(CONFIG_ARM64_16K_PAGES)
  793. #define ID_AA64MMFR0_EL1_TGRAN_SHIFT ID_AA64MMFR0_EL1_TGRAN16_SHIFT
  794. #define ID_AA64MMFR0_EL1_TGRAN_LPA2 ID_AA64MMFR0_EL1_TGRAN16_52_BIT
  795. #define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MIN ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MIN
  796. #define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MAX ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MAX
  797. #define ID_AA64MMFR0_EL1_TGRAN_2_SHIFT ID_AA64MMFR0_EL1_TGRAN16_2_SHIFT
  798. #elif defined(CONFIG_ARM64_64K_PAGES)
  799. #define ID_AA64MMFR0_EL1_TGRAN_SHIFT ID_AA64MMFR0_EL1_TGRAN64_SHIFT
  800. #define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MIN ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MIN
  801. #define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MAX ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MAX
  802. #define ID_AA64MMFR0_EL1_TGRAN_2_SHIFT ID_AA64MMFR0_EL1_TGRAN64_2_SHIFT
  803. #endif
  804. #define CPACR_EL1_FPEN_EL1EN (BIT(20)) /* enable EL1 access */
  805. #define CPACR_EL1_FPEN_EL0EN (BIT(21)) /* enable EL0 access, if EL1EN set */
  806. #define CPACR_EL1_SMEN_EL1EN (BIT(24)) /* enable EL1 access */
  807. #define CPACR_EL1_SMEN_EL0EN (BIT(25)) /* enable EL0 access, if EL1EN set */
  808. #define CPACR_EL1_ZEN_EL1EN (BIT(16)) /* enable EL1 access */
  809. #define CPACR_EL1_ZEN_EL0EN (BIT(17)) /* enable EL0 access, if EL1EN set */
  810. /* GCR_EL1 Definitions */
  811. #define SYS_GCR_EL1_RRND (BIT(16))
  812. #define SYS_GCR_EL1_EXCL_MASK 0xffffUL
  813. #ifdef CONFIG_KASAN_HW_TAGS
  814. /*
  815. * KASAN always uses a whole byte for its tags. With CONFIG_KASAN_HW_TAGS it
  816. * only uses tags in the range 0xF0-0xFF, which we map to MTE tags 0x0-0xF.
  817. */
  818. #define __MTE_TAG_MIN (KASAN_TAG_MIN & 0xf)
  819. #define __MTE_TAG_MAX (KASAN_TAG_MAX & 0xf)
  820. #define __MTE_TAG_INCL GENMASK(__MTE_TAG_MAX, __MTE_TAG_MIN)
  821. #define KERNEL_GCR_EL1_EXCL (SYS_GCR_EL1_EXCL_MASK & ~__MTE_TAG_INCL)
  822. #else
  823. #define KERNEL_GCR_EL1_EXCL SYS_GCR_EL1_EXCL_MASK
  824. #endif
  825. #define KERNEL_GCR_EL1 (SYS_GCR_EL1_RRND | KERNEL_GCR_EL1_EXCL)
  826. /* RGSR_EL1 Definitions */
  827. #define SYS_RGSR_EL1_TAG_MASK 0xfUL
  828. #define SYS_RGSR_EL1_SEED_SHIFT 8
  829. #define SYS_RGSR_EL1_SEED_MASK 0xffffUL
  830. /* TFSR{,E0}_EL1 bit definitions */
  831. #define SYS_TFSR_EL1_TF0_SHIFT 0
  832. #define SYS_TFSR_EL1_TF1_SHIFT 1
  833. #define SYS_TFSR_EL1_TF0 (UL(1) << SYS_TFSR_EL1_TF0_SHIFT)
  834. #define SYS_TFSR_EL1_TF1 (UL(1) << SYS_TFSR_EL1_TF1_SHIFT)
  835. /* Safe value for MPIDR_EL1: Bit31:RES1, Bit30:U:0, Bit24:MT:0 */
  836. #define SYS_MPIDR_SAFE_VAL (BIT(31))
  837. /* GIC Hypervisor interface registers */
  838. /* ICH_LR*_EL2 bit definitions */
  839. #define ICH_LR_VIRTUAL_ID_MASK ((1ULL << 32) - 1)
  840. #define ICH_LR_EOI (1ULL << 41)
  841. #define ICH_LR_GROUP (1ULL << 60)
  842. #define ICH_LR_HW (1ULL << 61)
  843. #define ICH_LR_STATE (3ULL << 62)
  844. #define ICH_LR_PENDING_BIT (1ULL << 62)
  845. #define ICH_LR_ACTIVE_BIT (1ULL << 63)
  846. #define ICH_LR_PHYS_ID_SHIFT 32
  847. #define ICH_LR_PHYS_ID_MASK (0x3ffULL << ICH_LR_PHYS_ID_SHIFT)
  848. #define ICH_LR_PRIORITY_SHIFT 48
  849. #define ICH_LR_PRIORITY_MASK (0xffULL << ICH_LR_PRIORITY_SHIFT)
  850. /*
  851. * Permission Indirection Extension (PIE) permission encodings.
  852. * Encodings with the _O suffix, have overlays applied (Permission Overlay Extension).
  853. */
  854. #define PIE_NONE_O UL(0x0)
  855. #define PIE_R_O UL(0x1)
  856. #define PIE_X_O UL(0x2)
  857. #define PIE_RX_O UL(0x3)
  858. #define PIE_RW_O UL(0x5)
  859. #define PIE_RWnX_O UL(0x6)
  860. #define PIE_RWX_O UL(0x7)
  861. #define PIE_R UL(0x8)
  862. #define PIE_GCS UL(0x9)
  863. #define PIE_RX UL(0xa)
  864. #define PIE_RW UL(0xc)
  865. #define PIE_RWX UL(0xe)
  866. #define PIE_MASK UL(0xf)
  867. #define PIRx_ELx_BITS_PER_IDX 4
  868. #define PIRx_ELx_PERM_SHIFT(idx) ((idx) * PIRx_ELx_BITS_PER_IDX)
  869. #define PIRx_ELx_PERM_PREP(idx, perm) (((perm) & PIE_MASK) << PIRx_ELx_PERM_SHIFT(idx))
  870. /*
  871. * Permission Overlay Extension (POE) permission encodings.
  872. */
  873. #define POE_NONE UL(0x0)
  874. #define POE_R UL(0x1)
  875. #define POE_X UL(0x2)
  876. #define POE_RX UL(0x3)
  877. #define POE_W UL(0x4)
  878. #define POE_RW UL(0x5)
  879. #define POE_WX UL(0x6)
  880. #define POE_RWX UL(0x7)
  881. #define POE_MASK UL(0xf)
  882. #define POR_ELx_BITS_PER_IDX 4
  883. #define POR_ELx_PERM_SHIFT(idx) ((idx) * POR_ELx_BITS_PER_IDX)
  884. #define POR_ELx_PERM_GET(idx, reg) (((reg) >> POR_ELx_PERM_SHIFT(idx)) & POE_MASK)
  885. #define POR_ELx_PERM_PREP(idx, perm) (((perm) & POE_MASK) << POR_ELx_PERM_SHIFT(idx))
  886. /*
  887. * Definitions for Guarded Control Stack
  888. */
  889. #define GCS_CAP_ADDR_MASK GENMASK(63, 12)
  890. #define GCS_CAP_ADDR_SHIFT 12
  891. #define GCS_CAP_ADDR_WIDTH 52
  892. #define GCS_CAP_ADDR(x) FIELD_GET(GCS_CAP_ADDR_MASK, x)
  893. #define GCS_CAP_TOKEN_MASK GENMASK(11, 0)
  894. #define GCS_CAP_TOKEN_SHIFT 0
  895. #define GCS_CAP_TOKEN_WIDTH 12
  896. #define GCS_CAP_TOKEN(x) FIELD_GET(GCS_CAP_TOKEN_MASK, x)
  897. #define GCS_CAP_VALID_TOKEN 0x1
  898. #define GCS_CAP_IN_PROGRESS_TOKEN 0x5
  899. #define GCS_CAP(x) ((((unsigned long)x) & GCS_CAP_ADDR_MASK) | \
  900. GCS_CAP_VALID_TOKEN)
  901. /*
  902. * Definitions for GICv5 instructions
  903. */
  904. #define GICV5_OP_GIC_CDAFF sys_insn(1, 0, 12, 1, 3)
  905. #define GICV5_OP_GIC_CDDI sys_insn(1, 0, 12, 2, 0)
  906. #define GICV5_OP_GIC_CDDIS sys_insn(1, 0, 12, 1, 0)
  907. #define GICV5_OP_GIC_CDHM sys_insn(1, 0, 12, 2, 1)
  908. #define GICV5_OP_GIC_CDEN sys_insn(1, 0, 12, 1, 1)
  909. #define GICV5_OP_GIC_CDEOI sys_insn(1, 0, 12, 1, 7)
  910. #define GICV5_OP_GIC_CDPEND sys_insn(1, 0, 12, 1, 4)
  911. #define GICV5_OP_GIC_CDPRI sys_insn(1, 0, 12, 1, 2)
  912. #define GICV5_OP_GIC_CDRCFG sys_insn(1, 0, 12, 1, 5)
  913. #define GICV5_OP_GICR_CDIA sys_insn(1, 0, 12, 3, 0)
  914. /* Definitions for GIC CDAFF */
  915. #define GICV5_GIC_CDAFF_IAFFID_MASK GENMASK_ULL(47, 32)
  916. #define GICV5_GIC_CDAFF_TYPE_MASK GENMASK_ULL(31, 29)
  917. #define GICV5_GIC_CDAFF_IRM_MASK BIT_ULL(28)
  918. #define GICV5_GIC_CDAFF_ID_MASK GENMASK_ULL(23, 0)
  919. /* Definitions for GIC CDDI */
  920. #define GICV5_GIC_CDDI_TYPE_MASK GENMASK_ULL(31, 29)
  921. #define GICV5_GIC_CDDI_ID_MASK GENMASK_ULL(23, 0)
  922. /* Definitions for GIC CDDIS */
  923. #define GICV5_GIC_CDDIS_TYPE_MASK GENMASK_ULL(31, 29)
  924. #define GICV5_GIC_CDDIS_TYPE(r) FIELD_GET(GICV5_GIC_CDDIS_TYPE_MASK, r)
  925. #define GICV5_GIC_CDDIS_ID_MASK GENMASK_ULL(23, 0)
  926. #define GICV5_GIC_CDDIS_ID(r) FIELD_GET(GICV5_GIC_CDDIS_ID_MASK, r)
  927. /* Definitions for GIC CDEN */
  928. #define GICV5_GIC_CDEN_TYPE_MASK GENMASK_ULL(31, 29)
  929. #define GICV5_GIC_CDEN_ID_MASK GENMASK_ULL(23, 0)
  930. /* Definitions for GIC CDHM */
  931. #define GICV5_GIC_CDHM_HM_MASK BIT_ULL(32)
  932. #define GICV5_GIC_CDHM_TYPE_MASK GENMASK_ULL(31, 29)
  933. #define GICV5_GIC_CDHM_ID_MASK GENMASK_ULL(23, 0)
  934. /* Definitions for GIC CDPEND */
  935. #define GICV5_GIC_CDPEND_PENDING_MASK BIT_ULL(32)
  936. #define GICV5_GIC_CDPEND_TYPE_MASK GENMASK_ULL(31, 29)
  937. #define GICV5_GIC_CDPEND_ID_MASK GENMASK_ULL(23, 0)
  938. /* Definitions for GIC CDPRI */
  939. #define GICV5_GIC_CDPRI_PRIORITY_MASK GENMASK_ULL(39, 35)
  940. #define GICV5_GIC_CDPRI_TYPE_MASK GENMASK_ULL(31, 29)
  941. #define GICV5_GIC_CDPRI_ID_MASK GENMASK_ULL(23, 0)
  942. /* Definitions for GIC CDRCFG */
  943. #define GICV5_GIC_CDRCFG_TYPE_MASK GENMASK_ULL(31, 29)
  944. #define GICV5_GIC_CDRCFG_ID_MASK GENMASK_ULL(23, 0)
  945. /* Definitions for GICR CDIA */
  946. #define GICV5_GIC_CDIA_VALID_MASK BIT_ULL(32)
  947. #define GICV5_GICR_CDIA_VALID(r) FIELD_GET(GICV5_GIC_CDIA_VALID_MASK, r)
  948. #define GICV5_GIC_CDIA_TYPE_MASK GENMASK_ULL(31, 29)
  949. #define GICV5_GIC_CDIA_ID_MASK GENMASK_ULL(23, 0)
  950. #define gicr_insn(insn) read_sysreg_s(GICV5_OP_GICR_##insn)
  951. #define gic_insn(v, insn) write_sysreg_s(v, GICV5_OP_GIC_##insn)
  952. #ifdef __ASSEMBLER__
  953. .macro mrs_s, rt, sreg
  954. __emit_inst(0xd5200000|(\sreg)|(.L__gpr_num_\rt))
  955. .endm
  956. .macro msr_s, sreg, rt
  957. __emit_inst(0xd5000000|(\sreg)|(.L__gpr_num_\rt))
  958. .endm
  959. .macro msr_hcr_el2, reg
  960. #if IS_ENABLED(CONFIG_AMPERE_ERRATUM_AC04_CPU_23)
  961. dsb nsh
  962. msr hcr_el2, \reg
  963. isb
  964. #else
  965. msr hcr_el2, \reg
  966. #endif
  967. .endm
  968. #else
  969. #include <linux/bitfield.h>
  970. #include <linux/build_bug.h>
  971. #include <linux/types.h>
  972. #include <asm/alternative.h>
  973. #define DEFINE_MRS_S \
  974. __DEFINE_ASM_GPR_NUMS \
  975. " .macro mrs_s, rt, sreg\n" \
  976. __emit_inst(0xd5200000|(\\sreg)|(.L__gpr_num_\\rt)) \
  977. " .endm\n"
  978. #define DEFINE_MSR_S \
  979. __DEFINE_ASM_GPR_NUMS \
  980. " .macro msr_s, sreg, rt\n" \
  981. __emit_inst(0xd5000000|(\\sreg)|(.L__gpr_num_\\rt)) \
  982. " .endm\n"
  983. #define UNDEFINE_MRS_S \
  984. " .purgem mrs_s\n"
  985. #define UNDEFINE_MSR_S \
  986. " .purgem msr_s\n"
  987. #define __mrs_s(v, r) \
  988. DEFINE_MRS_S \
  989. " mrs_s " v ", " __stringify(r) "\n" \
  990. UNDEFINE_MRS_S
  991. #define __msr_s(r, v) \
  992. DEFINE_MSR_S \
  993. " msr_s " __stringify(r) ", " v "\n" \
  994. UNDEFINE_MSR_S
  995. /*
  996. * Unlike read_cpuid, calls to read_sysreg are never expected to be
  997. * optimized away or replaced with synthetic values.
  998. */
  999. #define read_sysreg(r) ({ \
  1000. u64 __val; \
  1001. asm volatile("mrs %0, " __stringify(r) : "=r" (__val)); \
  1002. __val; \
  1003. })
  1004. /*
  1005. * The "Z" constraint normally means a zero immediate, but when combined with
  1006. * the "%x0" template means XZR.
  1007. */
  1008. #define write_sysreg(v, r) do { \
  1009. u64 __val = (u64)(v); \
  1010. asm volatile("msr " __stringify(r) ", %x0" \
  1011. : : "rZ" (__val)); \
  1012. } while (0)
  1013. /*
  1014. * For registers without architectural names, or simply unsupported by
  1015. * GAS.
  1016. *
  1017. * __check_r forces warnings to be generated by the compiler when
  1018. * evaluating r which wouldn't normally happen due to being passed to
  1019. * the assembler via __stringify(r).
  1020. */
  1021. #define read_sysreg_s(r) ({ \
  1022. u64 __val; \
  1023. u32 __maybe_unused __check_r = (u32)(r); \
  1024. asm volatile(__mrs_s("%0", r) : "=r" (__val)); \
  1025. __val; \
  1026. })
  1027. /*
  1028. * The "Z" constraint combined with the "%x0" template should be enough
  1029. * to force XZR generation if (v) is a constant 0 value but LLVM does not
  1030. * yet understand that modifier/constraint combo so a conditional is required
  1031. * to nudge the compiler into using XZR as a source for a 0 constant value.
  1032. */
  1033. #define write_sysreg_s(v, r) do { \
  1034. u64 __val = (u64)(v); \
  1035. u32 __maybe_unused __check_r = (u32)(r); \
  1036. if (__builtin_constant_p(__val) && __val == 0) \
  1037. asm volatile(__msr_s(r, "xzr")); \
  1038. else \
  1039. asm volatile(__msr_s(r, "%x0") : : "r" (__val)); \
  1040. } while (0)
  1041. /*
  1042. * Modify bits in a sysreg. Bits in the clear mask are zeroed, then bits in the
  1043. * set mask are set. Other bits are left as-is.
  1044. */
  1045. #define sysreg_clear_set(sysreg, clear, set) do { \
  1046. u64 __scs_val = read_sysreg(sysreg); \
  1047. u64 __scs_new = (__scs_val & ~(u64)(clear)) | (set); \
  1048. if (__scs_new != __scs_val) \
  1049. write_sysreg(__scs_new, sysreg); \
  1050. } while (0)
  1051. #define sysreg_clear_set_hcr(clear, set) do { \
  1052. u64 __scs_val = read_sysreg(hcr_el2); \
  1053. u64 __scs_new = (__scs_val & ~(u64)(clear)) | (set); \
  1054. if (__scs_new != __scs_val) \
  1055. write_sysreg_hcr(__scs_new); \
  1056. } while (0)
  1057. #define sysreg_clear_set_s(sysreg, clear, set) do { \
  1058. u64 __scs_val = read_sysreg_s(sysreg); \
  1059. u64 __scs_new = (__scs_val & ~(u64)(clear)) | (set); \
  1060. if (__scs_new != __scs_val) \
  1061. write_sysreg_s(__scs_new, sysreg); \
  1062. } while (0)
  1063. #define write_sysreg_hcr(__val) do { \
  1064. if (IS_ENABLED(CONFIG_AMPERE_ERRATUM_AC04_CPU_23) && \
  1065. (!system_capabilities_finalized() || \
  1066. alternative_has_cap_unlikely(ARM64_WORKAROUND_AMPERE_AC04_CPU_23))) \
  1067. asm volatile("dsb nsh; msr hcr_el2, %x0; isb" \
  1068. : : "rZ" (__val)); \
  1069. else \
  1070. asm volatile("msr hcr_el2, %x0" \
  1071. : : "rZ" (__val)); \
  1072. } while (0)
  1073. #define read_sysreg_par() ({ \
  1074. u64 par; \
  1075. asm(ALTERNATIVE("nop", "dmb sy", ARM64_WORKAROUND_1508412)); \
  1076. par = read_sysreg(par_el1); \
  1077. asm(ALTERNATIVE("nop", "dmb sy", ARM64_WORKAROUND_1508412)); \
  1078. par; \
  1079. })
  1080. #define SYS_FIELD_VALUE(reg, field, val) reg##_##field##_##val
  1081. #define SYS_FIELD_GET(reg, field, val) \
  1082. FIELD_GET(reg##_##field##_MASK, val)
  1083. #define SYS_FIELD_PREP(reg, field, val) \
  1084. FIELD_PREP(reg##_##field##_MASK, val)
  1085. #define SYS_FIELD_PREP_ENUM(reg, field, val) \
  1086. FIELD_PREP(reg##_##field##_MASK, \
  1087. SYS_FIELD_VALUE(reg, field, val))
  1088. #endif
  1089. #endif /* __ASM_SYSREG_H */