AArch64SystemOperands.td 98 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911
  1. //===- AArch64SystemOperands.td ----------------------------*- tablegen -*-===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. //
  9. // This file defines the symbolic operands permitted for various kinds of
  10. // AArch64 system instruction.
  11. //
  12. //===----------------------------------------------------------------------===//
  13. include "llvm/TableGen/SearchableTable.td"
  14. //===----------------------------------------------------------------------===//
  15. // Features that, for the compiler, only enable system operands and PStates
  16. //===----------------------------------------------------------------------===//
  17. def HasCCPP : Predicate<"Subtarget->hasCCPP()">,
  18. AssemblerPredicateWithAll<(all_of FeatureCCPP), "ccpp">;
  19. def HasPAN : Predicate<"Subtarget->hasPAN()">,
  20. AssemblerPredicateWithAll<(all_of FeaturePAN),
  21. "ARM v8.1 Privileged Access-Never extension">;
  22. def HasPsUAO : Predicate<"Subtarget->hasPsUAO()">,
  23. AssemblerPredicateWithAll<(all_of FeaturePsUAO),
  24. "ARM v8.2 UAO PState extension (psuao)">;
  25. def HasPAN_RWV : Predicate<"Subtarget->hasPAN_RWV()">,
  26. AssemblerPredicateWithAll<(all_of FeaturePAN_RWV),
  27. "ARM v8.2 PAN AT S1E1R and AT S1E1W Variation">;
  28. def HasCONTEXTIDREL2
  29. : Predicate<"Subtarget->hasCONTEXTIDREL2()">,
  30. AssemblerPredicateWithAll<(all_of FeatureCONTEXTIDREL2),
  31. "Target contains CONTEXTIDR_EL2 RW operand">;
  32. //===----------------------------------------------------------------------===//
  33. // AT (address translate) instruction options.
  34. //===----------------------------------------------------------------------===//
  35. class AT<string name, bits<3> op1, bits<4> crn, bits<4> crm,
  36. bits<3> op2> : SearchableTable {
  37. let SearchableFields = ["Name", "Encoding"];
  38. let EnumValueField = "Encoding";
  39. string Name = name;
  40. bits<14> Encoding;
  41. let Encoding{13-11} = op1;
  42. let Encoding{10-7} = crn;
  43. let Encoding{6-3} = crm;
  44. let Encoding{2-0} = op2;
  45. code Requires = [{ {} }];
  46. }
  47. def : AT<"S1E1R", 0b000, 0b0111, 0b1000, 0b000>;
  48. def : AT<"S1E2R", 0b100, 0b0111, 0b1000, 0b000>;
  49. def : AT<"S1E3R", 0b110, 0b0111, 0b1000, 0b000>;
  50. def : AT<"S1E1W", 0b000, 0b0111, 0b1000, 0b001>;
  51. def : AT<"S1E2W", 0b100, 0b0111, 0b1000, 0b001>;
  52. def : AT<"S1E3W", 0b110, 0b0111, 0b1000, 0b001>;
  53. def : AT<"S1E0R", 0b000, 0b0111, 0b1000, 0b010>;
  54. def : AT<"S1E0W", 0b000, 0b0111, 0b1000, 0b011>;
  55. def : AT<"S12E1R", 0b100, 0b0111, 0b1000, 0b100>;
  56. def : AT<"S12E1W", 0b100, 0b0111, 0b1000, 0b101>;
  57. def : AT<"S12E0R", 0b100, 0b0111, 0b1000, 0b110>;
  58. def : AT<"S12E0W", 0b100, 0b0111, 0b1000, 0b111>;
  59. let Requires = [{ {AArch64::FeaturePAN_RWV} }] in {
  60. def : AT<"S1E1RP", 0b000, 0b0111, 0b1001, 0b000>;
  61. def : AT<"S1E1WP", 0b000, 0b0111, 0b1001, 0b001>;
  62. }
  63. //===----------------------------------------------------------------------===//
  64. // DMB/DSB (data barrier) instruction options.
  65. //===----------------------------------------------------------------------===//
  66. class DB<string name, bits<4> encoding> : SearchableTable {
  67. let SearchableFields = ["Name", "Encoding"];
  68. let EnumValueField = "Encoding";
  69. string Name = name;
  70. bits<4> Encoding = encoding;
  71. }
  72. def : DB<"oshld", 0x1>;
  73. def : DB<"oshst", 0x2>;
  74. def : DB<"osh", 0x3>;
  75. def : DB<"nshld", 0x5>;
  76. def : DB<"nshst", 0x6>;
  77. def : DB<"nsh", 0x7>;
  78. def : DB<"ishld", 0x9>;
  79. def : DB<"ishst", 0xa>;
  80. def : DB<"ish", 0xb>;
  81. def : DB<"ld", 0xd>;
  82. def : DB<"st", 0xe>;
  83. def : DB<"sy", 0xf>;
  84. class DBnXS<string name, bits<4> encoding, bits<5> immValue> : SearchableTable {
  85. let SearchableFields = ["Name", "Encoding", "ImmValue"];
  86. let EnumValueField = "Encoding";
  87. string Name = name;
  88. bits<4> Encoding = encoding;
  89. bits<5> ImmValue = immValue;
  90. code Requires = [{ {AArch64::FeatureXS} }];
  91. }
  92. def : DBnXS<"oshnxs", 0x3, 0x10>;
  93. def : DBnXS<"nshnxs", 0x7, 0x14>;
  94. def : DBnXS<"ishnxs", 0xb, 0x18>;
  95. def : DBnXS<"synxs", 0xf, 0x1c>;
  96. //===----------------------------------------------------------------------===//
  97. // DC (data cache maintenance) instruction options.
  98. //===----------------------------------------------------------------------===//
  99. class DC<string name, bits<3> op1, bits<4> crn, bits<4> crm,
  100. bits<3> op2> : SearchableTable {
  101. let SearchableFields = ["Name", "Encoding"];
  102. let EnumValueField = "Encoding";
  103. string Name = name;
  104. bits<14> Encoding;
  105. let Encoding{13-11} = op1;
  106. let Encoding{10-7} = crn;
  107. let Encoding{6-3} = crm;
  108. let Encoding{2-0} = op2;
  109. code Requires = [{ {} }];
  110. }
  111. def : DC<"ZVA", 0b011, 0b0111, 0b0100, 0b001>;
  112. def : DC<"IVAC", 0b000, 0b0111, 0b0110, 0b001>;
  113. def : DC<"ISW", 0b000, 0b0111, 0b0110, 0b010>;
  114. def : DC<"CVAC", 0b011, 0b0111, 0b1010, 0b001>;
  115. def : DC<"CSW", 0b000, 0b0111, 0b1010, 0b010>;
  116. def : DC<"CVAU", 0b011, 0b0111, 0b1011, 0b001>;
  117. def : DC<"CIVAC", 0b011, 0b0111, 0b1110, 0b001>;
  118. def : DC<"CISW", 0b000, 0b0111, 0b1110, 0b010>;
  119. let Requires = [{ {AArch64::FeatureCCPP} }] in
  120. def : DC<"CVAP", 0b011, 0b0111, 0b1100, 0b001>;
  121. let Requires = [{ {AArch64::FeatureCacheDeepPersist} }] in
  122. def : DC<"CVADP", 0b011, 0b0111, 0b1101, 0b001>;
  123. let Requires = [{ {AArch64::FeatureMTE} }] in {
  124. def : DC<"IGVAC", 0b000, 0b0111, 0b0110, 0b011>;
  125. def : DC<"IGSW", 0b000, 0b0111, 0b0110, 0b100>;
  126. def : DC<"CGSW", 0b000, 0b0111, 0b1010, 0b100>;
  127. def : DC<"CIGSW", 0b000, 0b0111, 0b1110, 0b100>;
  128. def : DC<"CGVAC", 0b011, 0b0111, 0b1010, 0b011>;
  129. def : DC<"CGVAP", 0b011, 0b0111, 0b1100, 0b011>;
  130. def : DC<"CGVADP", 0b011, 0b0111, 0b1101, 0b011>;
  131. def : DC<"CIGVAC", 0b011, 0b0111, 0b1110, 0b011>;
  132. def : DC<"GVA", 0b011, 0b0111, 0b0100, 0b011>;
  133. def : DC<"IGDVAC", 0b000, 0b0111, 0b0110, 0b101>;
  134. def : DC<"IGDSW", 0b000, 0b0111, 0b0110, 0b110>;
  135. def : DC<"CGDSW", 0b000, 0b0111, 0b1010, 0b110>;
  136. def : DC<"CIGDSW", 0b000, 0b0111, 0b1110, 0b110>;
  137. def : DC<"CGDVAC", 0b011, 0b0111, 0b1010, 0b101>;
  138. def : DC<"CGDVAP", 0b011, 0b0111, 0b1100, 0b101>;
  139. def : DC<"CGDVADP", 0b011, 0b0111, 0b1101, 0b101>;
  140. def : DC<"CIGDVAC", 0b011, 0b0111, 0b1110, 0b101>;
  141. def : DC<"GZVA", 0b011, 0b0111, 0b0100, 0b100>;
  142. }
  143. let Requires = [{ {AArch64::FeatureMEC} }] in {
  144. def : DC<"CIPAE", 0b100, 0b0111, 0b1110, 0b000>;
  145. def : DC<"CIGDPAE", 0b100, 0b0111, 0b1110, 0b111>;
  146. }
  147. //===----------------------------------------------------------------------===//
  148. // IC (instruction cache maintenance) instruction options.
  149. //===----------------------------------------------------------------------===//
  150. class IC<string name, bits<3> op1, bits<4> crn, bits<4> crm, bits<3> op2,
  151. bit needsreg> : SearchableTable {
  152. let SearchableFields = ["Name", "Encoding"];
  153. let EnumValueField = "Encoding";
  154. string Name = name;
  155. bits<14> Encoding;
  156. let Encoding{13-11} = op1;
  157. let Encoding{10-7} = crn;
  158. let Encoding{6-3} = crm;
  159. let Encoding{2-0} = op2;
  160. bit NeedsReg = needsreg;
  161. }
  162. def : IC<"IALLUIS", 0b000, 0b0111, 0b0001, 0b000, 0>;
  163. def : IC<"IALLU", 0b000, 0b0111, 0b0101, 0b000, 0>;
  164. def : IC<"IVAU", 0b011, 0b0111, 0b0101, 0b001, 1>;
  165. //===----------------------------------------------------------------------===//
  166. // ISB (instruction-fetch barrier) instruction options.
  167. //===----------------------------------------------------------------------===//
  168. class ISB<string name, bits<4> encoding> : SearchableTable{
  169. let SearchableFields = ["Name", "Encoding"];
  170. let EnumValueField = "Encoding";
  171. string Name = name;
  172. bits<4> Encoding;
  173. let Encoding = encoding;
  174. }
  175. def : ISB<"sy", 0xf>;
  176. //===----------------------------------------------------------------------===//
  177. // TSB (Trace synchronization barrier) instruction options.
  178. //===----------------------------------------------------------------------===//
  179. class TSB<string name, bits<4> encoding> : SearchableTable{
  180. let SearchableFields = ["Name", "Encoding"];
  181. let EnumValueField = "Encoding";
  182. string Name = name;
  183. bits<4> Encoding;
  184. let Encoding = encoding;
  185. code Requires = [{ {AArch64::FeatureTRACEV8_4} }];
  186. }
  187. def : TSB<"csync", 0>;
  188. //===----------------------------------------------------------------------===//
  189. // PRFM (prefetch) instruction options.
  190. //===----------------------------------------------------------------------===//
  191. class PRFM<string type, bits<2> type_encoding,
  192. string target, bits<2> target_encoding,
  193. string policy, bits<1> policy_encoding> : SearchableTable {
  194. let SearchableFields = ["Name", "Encoding"];
  195. let EnumValueField = "Encoding";
  196. string Name = type # target # policy;
  197. bits<5> Encoding;
  198. let Encoding{4-3} = type_encoding;
  199. let Encoding{2-1} = target_encoding;
  200. let Encoding{0} = policy_encoding;
  201. code Requires = [{ {} }];
  202. }
  203. def : PRFM<"pld", 0b00, "l1", 0b00, "keep", 0b0>;
  204. def : PRFM<"pld", 0b00, "l1", 0b00, "strm", 0b1>;
  205. def : PRFM<"pld", 0b00, "l2", 0b01, "keep", 0b0>;
  206. def : PRFM<"pld", 0b00, "l2", 0b01, "strm", 0b1>;
  207. def : PRFM<"pld", 0b00, "l3", 0b10, "keep", 0b0>;
  208. def : PRFM<"pld", 0b00, "l3", 0b10, "strm", 0b1>;
  209. let Requires = [{ {AArch64::FeaturePRFM_SLC} }] in {
  210. def : PRFM<"pld", 0b00, "slc", 0b11, "keep", 0b0>;
  211. def : PRFM<"pld", 0b00, "slc", 0b11, "strm", 0b1>;
  212. }
  213. def : PRFM<"pli", 0b01, "l1", 0b00, "keep", 0b0>;
  214. def : PRFM<"pli", 0b01, "l1", 0b00, "strm", 0b1>;
  215. def : PRFM<"pli", 0b01, "l2", 0b01, "keep", 0b0>;
  216. def : PRFM<"pli", 0b01, "l2", 0b01, "strm", 0b1>;
  217. def : PRFM<"pli", 0b01, "l3", 0b10, "keep", 0b0>;
  218. def : PRFM<"pli", 0b01, "l3", 0b10, "strm", 0b1>;
  219. let Requires = [{ {AArch64::FeaturePRFM_SLC} }] in {
  220. def : PRFM<"pli", 0b01, "slc", 0b11, "keep", 0b0>;
  221. def : PRFM<"pli", 0b01, "slc", 0b11, "strm", 0b1>;
  222. }
  223. def : PRFM<"pst", 0b10, "l1", 0b00, "keep", 0b0>;
  224. def : PRFM<"pst", 0b10, "l1", 0b00, "strm", 0b1>;
  225. def : PRFM<"pst", 0b10, "l2", 0b01, "keep", 0b0>;
  226. def : PRFM<"pst", 0b10, "l2", 0b01, "strm", 0b1>;
  227. def : PRFM<"pst", 0b10, "l3", 0b10, "keep", 0b0>;
  228. def : PRFM<"pst", 0b10, "l3", 0b10, "strm", 0b1>;
  229. let Requires = [{ {AArch64::FeaturePRFM_SLC} }] in {
  230. def : PRFM<"pst", 0b10, "slc", 0b11, "keep", 0b0>;
  231. def : PRFM<"pst", 0b10, "slc", 0b11, "strm", 0b1>;
  232. }
  233. //===----------------------------------------------------------------------===//
  234. // SVE Prefetch instruction options.
  235. //===----------------------------------------------------------------------===//
  236. class SVEPRFM<string name, bits<4> encoding> : SearchableTable {
  237. let SearchableFields = ["Name", "Encoding"];
  238. let EnumValueField = "Encoding";
  239. string Name = name;
  240. bits<4> Encoding;
  241. let Encoding = encoding;
  242. code Requires = [{ {} }];
  243. }
  244. let Requires = [{ {AArch64::FeatureSVE} }] in {
  245. def : SVEPRFM<"pldl1keep", 0x00>;
  246. def : SVEPRFM<"pldl1strm", 0x01>;
  247. def : SVEPRFM<"pldl2keep", 0x02>;
  248. def : SVEPRFM<"pldl2strm", 0x03>;
  249. def : SVEPRFM<"pldl3keep", 0x04>;
  250. def : SVEPRFM<"pldl3strm", 0x05>;
  251. def : SVEPRFM<"pstl1keep", 0x08>;
  252. def : SVEPRFM<"pstl1strm", 0x09>;
  253. def : SVEPRFM<"pstl2keep", 0x0a>;
  254. def : SVEPRFM<"pstl2strm", 0x0b>;
  255. def : SVEPRFM<"pstl3keep", 0x0c>;
  256. def : SVEPRFM<"pstl3strm", 0x0d>;
  257. }
  258. //===----------------------------------------------------------------------===//
  259. // RPRFM (prefetch) instruction options.
  260. //===----------------------------------------------------------------------===//
  261. class RPRFM<string name, bits<1> type_encoding, bits<5> policy_encoding> : SearchableTable {
  262. let SearchableFields = ["Name", "Encoding"];
  263. let EnumValueField = "Encoding";
  264. string Name = name;
  265. bits<6> Encoding;
  266. let Encoding{0} = type_encoding;
  267. let Encoding{5-1} = policy_encoding;
  268. code Requires = [{ {} }];
  269. }
  270. def : RPRFM<"pldkeep", 0b0, 0b00000>;
  271. def : RPRFM<"pstkeep", 0b1, 0b00000>;
  272. def : RPRFM<"pldstrm", 0b0, 0b00010>;
  273. def : RPRFM<"pststrm", 0b1, 0b00010>;
  274. //===----------------------------------------------------------------------===//
  275. // SVE Predicate patterns
  276. //===----------------------------------------------------------------------===//
  277. class SVEPREDPAT<string name, bits<5> encoding> : SearchableTable {
  278. let SearchableFields = ["Name", "Encoding"];
  279. let EnumValueField = "Encoding";
  280. string Name = name;
  281. bits<5> Encoding;
  282. let Encoding = encoding;
  283. }
  284. def : SVEPREDPAT<"pow2", 0x00>;
  285. def : SVEPREDPAT<"vl1", 0x01>;
  286. def : SVEPREDPAT<"vl2", 0x02>;
  287. def : SVEPREDPAT<"vl3", 0x03>;
  288. def : SVEPREDPAT<"vl4", 0x04>;
  289. def : SVEPREDPAT<"vl5", 0x05>;
  290. def : SVEPREDPAT<"vl6", 0x06>;
  291. def : SVEPREDPAT<"vl7", 0x07>;
  292. def : SVEPREDPAT<"vl8", 0x08>;
  293. def : SVEPREDPAT<"vl16", 0x09>;
  294. def : SVEPREDPAT<"vl32", 0x0a>;
  295. def : SVEPREDPAT<"vl64", 0x0b>;
  296. def : SVEPREDPAT<"vl128", 0x0c>;
  297. def : SVEPREDPAT<"vl256", 0x0d>;
  298. def : SVEPREDPAT<"mul4", 0x1d>;
  299. def : SVEPREDPAT<"mul3", 0x1e>;
  300. def : SVEPREDPAT<"all", 0x1f>;
  301. //===----------------------------------------------------------------------===//
  302. // SVE Predicate-as-counter patterns
  303. //===----------------------------------------------------------------------===//
  304. class SVEVECLENSPECIFIER<string name, bits<1> encoding> : SearchableTable {
  305. let SearchableFields = ["Name", "Encoding"];
  306. let EnumValueField = "Encoding";
  307. string Name = name;
  308. bits<1> Encoding;
  309. let Encoding = encoding;
  310. }
  311. def : SVEVECLENSPECIFIER<"vlx2", 0x0>;
  312. def : SVEVECLENSPECIFIER<"vlx4", 0x1>;
  313. //===----------------------------------------------------------------------===//
  314. // Exact FP Immediates.
  315. //
  316. // These definitions are used to create a lookup table with FP Immediates that
  317. // is used for a few instructions that only accept a limited set of exact FP
  318. // immediates values.
  319. //===----------------------------------------------------------------------===//
  320. class ExactFPImm<string name, string repr, bits<4> enum > : SearchableTable {
  321. let SearchableFields = ["Enum", "Repr"];
  322. let EnumValueField = "Enum";
  323. string Name = name;
  324. bits<4> Enum = enum;
  325. string Repr = repr;
  326. }
  327. def : ExactFPImm<"zero", "0.0", 0x0>;
  328. def : ExactFPImm<"half", "0.5", 0x1>;
  329. def : ExactFPImm<"one", "1.0", 0x2>;
  330. def : ExactFPImm<"two", "2.0", 0x3>;
  331. //===----------------------------------------------------------------------===//
  332. // PState instruction options.
  333. //===----------------------------------------------------------------------===//
  334. class PStateImm0_15<string name, bits<3> op1, bits<3> op2> : SearchableTable {
  335. let SearchableFields = ["Name", "Encoding"];
  336. let EnumValueField = "Encoding";
  337. string Name = name;
  338. bits<6> Encoding;
  339. let Encoding{5-3} = op1;
  340. let Encoding{2-0} = op2;
  341. code Requires = [{ {} }];
  342. }
  343. class PStateImm0_1<string name, bits<3> op1, bits<3> op2, bits<3> crm_high> : SearchableTable {
  344. let SearchableFields = ["Name", "Encoding"];
  345. let EnumValueField = "Encoding";
  346. string Name = name;
  347. bits<9> Encoding;
  348. let Encoding{8-6} = crm_high;
  349. let Encoding{5-3} = op1;
  350. let Encoding{2-0} = op2;
  351. code Requires = [{ {} }];
  352. }
  353. // Name, Op1, Op2
  354. def : PStateImm0_15<"SPSel", 0b000, 0b101>;
  355. def : PStateImm0_15<"DAIFSet", 0b011, 0b110>;
  356. def : PStateImm0_15<"DAIFClr", 0b011, 0b111>;
  357. // v8.1a "Privileged Access Never" extension-specific PStates
  358. let Requires = [{ {AArch64::FeaturePAN} }] in
  359. def : PStateImm0_15<"PAN", 0b000, 0b100>;
  360. // v8.2a "User Access Override" extension-specific PStates
  361. let Requires = [{ {AArch64::FeaturePsUAO} }] in
  362. def : PStateImm0_15<"UAO", 0b000, 0b011>;
  363. // v8.4a timing insensitivity of data processing instructions
  364. let Requires = [{ {AArch64::FeatureDIT} }] in
  365. def : PStateImm0_15<"DIT", 0b011, 0b010>;
  366. // v8.5a Spectre Mitigation
  367. let Requires = [{ {AArch64::FeatureSSBS} }] in
  368. def : PStateImm0_15<"SSBS", 0b011, 0b001>;
  369. // v8.5a Memory Tagging Extension
  370. let Requires = [{ {AArch64::FeatureMTE} }] in
  371. def : PStateImm0_15<"TCO", 0b011, 0b100>;
  372. // v8.8a Non-Maskable Interrupts
  373. let Requires = [{ {AArch64::FeatureNMI} }] in
  374. def : PStateImm0_1<"ALLINT", 0b001, 0b000, 0b000>;
  375. // v9.4a Exception-based event profiling
  376. // Name, Op1, Op2, Crm_high
  377. def : PStateImm0_1<"PM", 0b001, 0b000, 0b001>;
  378. //===----------------------------------------------------------------------===//
  379. // SVCR instruction options.
  380. //===----------------------------------------------------------------------===//
  381. class SVCR<string name, bits<3> encoding> : SearchableTable {
  382. let SearchableFields = ["Name", "Encoding"];
  383. let EnumValueField = "Encoding";
  384. string Name = name;
  385. bits<3> Encoding;
  386. let Encoding = encoding;
  387. code Requires = [{ {} }];
  388. }
  389. let Requires = [{ {AArch64::FeatureSME} }] in {
  390. def : SVCR<"SVCRSM", 0b001>;
  391. def : SVCR<"SVCRZA", 0b010>;
  392. def : SVCR<"SVCRSMZA", 0b011>;
  393. }
  394. //===----------------------------------------------------------------------===//
  395. // PSB instruction options.
  396. //===----------------------------------------------------------------------===//
  397. class PSB<string name, bits<5> encoding> : SearchableTable {
  398. let SearchableFields = ["Name", "Encoding"];
  399. let EnumValueField = "Encoding";
  400. string Name = name;
  401. bits<5> Encoding;
  402. let Encoding = encoding;
  403. }
  404. def : PSB<"csync", 0x11>;
  405. //===----------------------------------------------------------------------===//
  406. // BTI instruction options.
  407. //===----------------------------------------------------------------------===//
  408. class BTI<string name, bits<3> encoding> : SearchableTable {
  409. let SearchableFields = ["Name", "Encoding"];
  410. let EnumValueField = "Encoding";
  411. string Name = name;
  412. bits<3> Encoding;
  413. let Encoding = encoding;
  414. }
  415. def : BTI<"c", 0b010>;
  416. def : BTI<"j", 0b100>;
  417. def : BTI<"jc", 0b110>;
  418. //===----------------------------------------------------------------------===//
  419. // TLBI (translation lookaside buffer invalidate) instruction options.
  420. //===----------------------------------------------------------------------===//
  421. class TLBIEntry<string name, bits<3> op1, bits<4> crn, bits<4> crm,
  422. bits<3> op2, bit needsreg> {
  423. string Name = name;
  424. bits<14> Encoding;
  425. let Encoding{13-11} = op1;
  426. let Encoding{10-7} = crn;
  427. let Encoding{6-3} = crm;
  428. let Encoding{2-0} = op2;
  429. bit NeedsReg = needsreg;
  430. list<string> Requires = [];
  431. list<string> ExtraRequires = [];
  432. code RequiresStr = [{ { }] # !interleave(Requires # ExtraRequires, [{, }]) # [{ } }];
  433. }
  434. def TLBITable : GenericTable {
  435. let FilterClass = "TLBIEntry";
  436. let CppTypeName = "TLBI";
  437. let Fields = ["Name", "Encoding", "NeedsReg", "RequiresStr"];
  438. }
  439. def lookupTLBIByName : SearchIndex {
  440. let Table = TLBITable;
  441. let Key = ["Name"];
  442. }
  443. def lookupTLBIByEncoding : SearchIndex {
  444. let Table = TLBITable;
  445. let Key = ["Encoding"];
  446. }
  447. multiclass TLBI<string name, bits<3> op1, bits<4> crn, bits<4> crm,
  448. bits<3> op2, bit needsreg = 1> {
  449. def : TLBIEntry<name, op1, crn, crm, op2, needsreg>;
  450. def : TLBIEntry<!strconcat(name, "nXS"), op1, crn, crm, op2, needsreg> {
  451. let Encoding{7} = 1;
  452. let ExtraRequires = ["AArch64::FeatureXS"];
  453. }
  454. }
  455. defm : TLBI<"IPAS2E1IS", 0b100, 0b1000, 0b0000, 0b001>;
  456. defm : TLBI<"IPAS2LE1IS", 0b100, 0b1000, 0b0000, 0b101>;
  457. defm : TLBI<"VMALLE1IS", 0b000, 0b1000, 0b0011, 0b000, 0>;
  458. defm : TLBI<"ALLE2IS", 0b100, 0b1000, 0b0011, 0b000, 0>;
  459. defm : TLBI<"ALLE3IS", 0b110, 0b1000, 0b0011, 0b000, 0>;
  460. defm : TLBI<"VAE1IS", 0b000, 0b1000, 0b0011, 0b001>;
  461. defm : TLBI<"VAE2IS", 0b100, 0b1000, 0b0011, 0b001>;
  462. defm : TLBI<"VAE3IS", 0b110, 0b1000, 0b0011, 0b001>;
  463. defm : TLBI<"ASIDE1IS", 0b000, 0b1000, 0b0011, 0b010>;
  464. defm : TLBI<"VAAE1IS", 0b000, 0b1000, 0b0011, 0b011>;
  465. defm : TLBI<"ALLE1IS", 0b100, 0b1000, 0b0011, 0b100, 0>;
  466. defm : TLBI<"VALE1IS", 0b000, 0b1000, 0b0011, 0b101>;
  467. defm : TLBI<"VALE2IS", 0b100, 0b1000, 0b0011, 0b101>;
  468. defm : TLBI<"VALE3IS", 0b110, 0b1000, 0b0011, 0b101>;
  469. defm : TLBI<"VMALLS12E1IS", 0b100, 0b1000, 0b0011, 0b110, 0>;
  470. defm : TLBI<"VAALE1IS", 0b000, 0b1000, 0b0011, 0b111>;
  471. defm : TLBI<"IPAS2E1", 0b100, 0b1000, 0b0100, 0b001>;
  472. defm : TLBI<"IPAS2LE1", 0b100, 0b1000, 0b0100, 0b101>;
  473. defm : TLBI<"VMALLE1", 0b000, 0b1000, 0b0111, 0b000, 0>;
  474. defm : TLBI<"ALLE2", 0b100, 0b1000, 0b0111, 0b000, 0>;
  475. defm : TLBI<"ALLE3", 0b110, 0b1000, 0b0111, 0b000, 0>;
  476. defm : TLBI<"VAE1", 0b000, 0b1000, 0b0111, 0b001>;
  477. defm : TLBI<"VAE2", 0b100, 0b1000, 0b0111, 0b001>;
  478. defm : TLBI<"VAE3", 0b110, 0b1000, 0b0111, 0b001>;
  479. defm : TLBI<"ASIDE1", 0b000, 0b1000, 0b0111, 0b010>;
  480. defm : TLBI<"VAAE1", 0b000, 0b1000, 0b0111, 0b011>;
  481. defm : TLBI<"ALLE1", 0b100, 0b1000, 0b0111, 0b100, 0>;
  482. defm : TLBI<"VALE1", 0b000, 0b1000, 0b0111, 0b101>;
  483. defm : TLBI<"VALE2", 0b100, 0b1000, 0b0111, 0b101>;
  484. defm : TLBI<"VALE3", 0b110, 0b1000, 0b0111, 0b101>;
  485. defm : TLBI<"VMALLS12E1", 0b100, 0b1000, 0b0111, 0b110, 0>;
  486. defm : TLBI<"VAALE1", 0b000, 0b1000, 0b0111, 0b111>;
  487. // Armv8.4-A Translation Lookaside Buffer Instructions (TLBI)
  488. let Requires = ["AArch64::FeatureTLB_RMI"] in {
  489. // Armv8.4-A Outer Sharable TLB Maintenance instructions:
  490. // op1 CRn CRm op2
  491. defm : TLBI<"VMALLE1OS", 0b000, 0b1000, 0b0001, 0b000, 0>;
  492. defm : TLBI<"VAE1OS", 0b000, 0b1000, 0b0001, 0b001>;
  493. defm : TLBI<"ASIDE1OS", 0b000, 0b1000, 0b0001, 0b010>;
  494. defm : TLBI<"VAAE1OS", 0b000, 0b1000, 0b0001, 0b011>;
  495. defm : TLBI<"VALE1OS", 0b000, 0b1000, 0b0001, 0b101>;
  496. defm : TLBI<"VAALE1OS", 0b000, 0b1000, 0b0001, 0b111>;
  497. defm : TLBI<"IPAS2E1OS", 0b100, 0b1000, 0b0100, 0b000>;
  498. defm : TLBI<"IPAS2LE1OS", 0b100, 0b1000, 0b0100, 0b100>;
  499. defm : TLBI<"VAE2OS", 0b100, 0b1000, 0b0001, 0b001>;
  500. defm : TLBI<"VALE2OS", 0b100, 0b1000, 0b0001, 0b101>;
  501. defm : TLBI<"VMALLS12E1OS", 0b100, 0b1000, 0b0001, 0b110, 0>;
  502. defm : TLBI<"VAE3OS", 0b110, 0b1000, 0b0001, 0b001>;
  503. defm : TLBI<"VALE3OS", 0b110, 0b1000, 0b0001, 0b101>;
  504. defm : TLBI<"ALLE2OS", 0b100, 0b1000, 0b0001, 0b000, 0>;
  505. defm : TLBI<"ALLE1OS", 0b100, 0b1000, 0b0001, 0b100, 0>;
  506. defm : TLBI<"ALLE3OS", 0b110, 0b1000, 0b0001, 0b000, 0>;
  507. // Armv8.4-A TLB Range Maintenance instructions:
  508. // op1 CRn CRm op2
  509. defm : TLBI<"RVAE1", 0b000, 0b1000, 0b0110, 0b001>;
  510. defm : TLBI<"RVAAE1", 0b000, 0b1000, 0b0110, 0b011>;
  511. defm : TLBI<"RVALE1", 0b000, 0b1000, 0b0110, 0b101>;
  512. defm : TLBI<"RVAALE1", 0b000, 0b1000, 0b0110, 0b111>;
  513. defm : TLBI<"RVAE1IS", 0b000, 0b1000, 0b0010, 0b001>;
  514. defm : TLBI<"RVAAE1IS", 0b000, 0b1000, 0b0010, 0b011>;
  515. defm : TLBI<"RVALE1IS", 0b000, 0b1000, 0b0010, 0b101>;
  516. defm : TLBI<"RVAALE1IS", 0b000, 0b1000, 0b0010, 0b111>;
  517. defm : TLBI<"RVAE1OS", 0b000, 0b1000, 0b0101, 0b001>;
  518. defm : TLBI<"RVAAE1OS", 0b000, 0b1000, 0b0101, 0b011>;
  519. defm : TLBI<"RVALE1OS", 0b000, 0b1000, 0b0101, 0b101>;
  520. defm : TLBI<"RVAALE1OS", 0b000, 0b1000, 0b0101, 0b111>;
  521. defm : TLBI<"RIPAS2E1IS", 0b100, 0b1000, 0b0000, 0b010>;
  522. defm : TLBI<"RIPAS2LE1IS", 0b100, 0b1000, 0b0000, 0b110>;
  523. defm : TLBI<"RIPAS2E1", 0b100, 0b1000, 0b0100, 0b010>;
  524. defm : TLBI<"RIPAS2LE1", 0b100, 0b1000, 0b0100, 0b110>;
  525. defm : TLBI<"RIPAS2E1OS", 0b100, 0b1000, 0b0100, 0b011>;
  526. defm : TLBI<"RIPAS2LE1OS", 0b100, 0b1000, 0b0100, 0b111>;
  527. defm : TLBI<"RVAE2", 0b100, 0b1000, 0b0110, 0b001>;
  528. defm : TLBI<"RVALE2", 0b100, 0b1000, 0b0110, 0b101>;
  529. defm : TLBI<"RVAE2IS", 0b100, 0b1000, 0b0010, 0b001>;
  530. defm : TLBI<"RVALE2IS", 0b100, 0b1000, 0b0010, 0b101>;
  531. defm : TLBI<"RVAE2OS", 0b100, 0b1000, 0b0101, 0b001>;
  532. defm : TLBI<"RVALE2OS", 0b100, 0b1000, 0b0101, 0b101>;
  533. defm : TLBI<"RVAE3", 0b110, 0b1000, 0b0110, 0b001>;
  534. defm : TLBI<"RVALE3", 0b110, 0b1000, 0b0110, 0b101>;
  535. defm : TLBI<"RVAE3IS", 0b110, 0b1000, 0b0010, 0b001>;
  536. defm : TLBI<"RVALE3IS", 0b110, 0b1000, 0b0010, 0b101>;
  537. defm : TLBI<"RVAE3OS", 0b110, 0b1000, 0b0101, 0b001>;
  538. defm : TLBI<"RVALE3OS", 0b110, 0b1000, 0b0101, 0b101>;
  539. } //FeatureTLB_RMI
  540. // Armv9-A Realm Management Extention TLBI Instructions
  541. let Requires = ["AArch64::FeatureRME"] in {
  542. defm : TLBI<"RPAOS", 0b110, 0b1000, 0b0100, 0b011>;
  543. defm : TLBI<"RPALOS", 0b110, 0b1000, 0b0100, 0b111>;
  544. defm : TLBI<"PAALLOS", 0b110, 0b1000, 0b0001, 0b100, 0>;
  545. defm : TLBI<"PAALL", 0b110, 0b1000, 0b0111, 0b100, 0>;
  546. }
  547. //===----------------------------------------------------------------------===//
  548. // MRS/MSR (system register read/write) instruction options.
  549. //===----------------------------------------------------------------------===//
  550. class SysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
  551. bits<3> op2> : SearchableTable {
  552. let SearchableFields = ["Name", "Encoding"];
  553. let EnumValueField = "Encoding";
  554. string Name = name;
  555. string AltName = name;
  556. bits<16> Encoding;
  557. let Encoding{15-14} = op0;
  558. let Encoding{13-11} = op1;
  559. let Encoding{10-7} = crn;
  560. let Encoding{6-3} = crm;
  561. let Encoding{2-0} = op2;
  562. bit Readable = ?;
  563. bit Writeable = ?;
  564. code Requires = [{ {} }];
  565. }
  566. class RWSysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
  567. bits<3> op2>
  568. : SysReg<name, op0, op1, crn, crm, op2> {
  569. let Readable = 1;
  570. let Writeable = 1;
  571. }
  572. class ROSysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
  573. bits<3> op2>
  574. : SysReg<name, op0, op1, crn, crm, op2> {
  575. let Readable = 1;
  576. let Writeable = 0;
  577. }
  578. class WOSysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
  579. bits<3> op2>
  580. : SysReg<name, op0, op1, crn, crm, op2> {
  581. let Readable = 0;
  582. let Writeable = 1;
  583. }
  584. //===----------------------
  585. // Read-only regs
  586. //===----------------------
  587. // Op0 Op1 CRn CRm Op2
  588. def : ROSysReg<"MDCCSR_EL0", 0b10, 0b011, 0b0000, 0b0001, 0b000>;
  589. def : ROSysReg<"DBGDTRRX_EL0", 0b10, 0b011, 0b0000, 0b0101, 0b000>;
  590. def : ROSysReg<"MDRAR_EL1", 0b10, 0b000, 0b0001, 0b0000, 0b000>;
  591. def : ROSysReg<"OSLSR_EL1", 0b10, 0b000, 0b0001, 0b0001, 0b100>;
  592. def : ROSysReg<"DBGAUTHSTATUS_EL1", 0b10, 0b000, 0b0111, 0b1110, 0b110>;
  593. def : ROSysReg<"PMCEID0_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b110>;
  594. def : ROSysReg<"PMCEID1_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b111>;
  595. def : ROSysReg<"PMMIR_EL1", 0b11, 0b000, 0b1001, 0b1110, 0b110>;
  596. def : ROSysReg<"MIDR_EL1", 0b11, 0b000, 0b0000, 0b0000, 0b000>;
  597. def : ROSysReg<"CCSIDR_EL1", 0b11, 0b001, 0b0000, 0b0000, 0b000>;
  598. //v8.3 CCIDX - extending the CCsIDr number of sets
  599. def : ROSysReg<"CCSIDR2_EL1", 0b11, 0b001, 0b0000, 0b0000, 0b010> {
  600. let Requires = [{ {AArch64::FeatureCCIDX} }];
  601. }
  602. def : ROSysReg<"CLIDR_EL1", 0b11, 0b001, 0b0000, 0b0000, 0b001>;
  603. def : ROSysReg<"CTR_EL0", 0b11, 0b011, 0b0000, 0b0000, 0b001>;
  604. def : ROSysReg<"MPIDR_EL1", 0b11, 0b000, 0b0000, 0b0000, 0b101>;
  605. def : ROSysReg<"REVIDR_EL1", 0b11, 0b000, 0b0000, 0b0000, 0b110>;
  606. def : ROSysReg<"AIDR_EL1", 0b11, 0b001, 0b0000, 0b0000, 0b111>;
  607. def : ROSysReg<"DCZID_EL0", 0b11, 0b011, 0b0000, 0b0000, 0b111>;
  608. def : ROSysReg<"ID_PFR0_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b000>;
  609. def : ROSysReg<"ID_PFR1_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b001>;
  610. def : ROSysReg<"ID_PFR2_EL1", 0b11, 0b000, 0b0000, 0b0011, 0b100> {
  611. let Requires = [{ {AArch64::FeatureSpecRestrict} }];
  612. }
  613. def : ROSysReg<"ID_DFR0_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b010>;
  614. def : ROSysReg<"ID_DFR1_EL1", 0b11, 0b000, 0b0000, 0b0011, 0b101>;
  615. def : ROSysReg<"ID_AFR0_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b011>;
  616. def : ROSysReg<"ID_MMFR0_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b100>;
  617. def : ROSysReg<"ID_MMFR1_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b101>;
  618. def : ROSysReg<"ID_MMFR2_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b110>;
  619. def : ROSysReg<"ID_MMFR3_EL1", 0b11, 0b000, 0b0000, 0b0001, 0b111>;
  620. def : ROSysReg<"ID_ISAR0_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b000>;
  621. def : ROSysReg<"ID_ISAR1_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b001>;
  622. def : ROSysReg<"ID_ISAR2_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b010>;
  623. def : ROSysReg<"ID_ISAR3_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b011>;
  624. def : ROSysReg<"ID_ISAR4_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b100>;
  625. def : ROSysReg<"ID_ISAR5_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b101>;
  626. def : ROSysReg<"ID_ISAR6_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b111> {
  627. let Requires = [{ {AArch64::HasV8_2aOps} }];
  628. }
  629. def : ROSysReg<"ID_AA64PFR0_EL1", 0b11, 0b000, 0b0000, 0b0100, 0b000>;
  630. def : ROSysReg<"ID_AA64PFR1_EL1", 0b11, 0b000, 0b0000, 0b0100, 0b001>;
  631. def : ROSysReg<"ID_AA64PFR2_EL1", 0b11, 0b000, 0b0000, 0b0100, 0b010>;
  632. def : ROSysReg<"ID_AA64DFR0_EL1", 0b11, 0b000, 0b0000, 0b0101, 0b000>;
  633. def : ROSysReg<"ID_AA64DFR1_EL1", 0b11, 0b000, 0b0000, 0b0101, 0b001>;
  634. def : ROSysReg<"ID_AA64AFR0_EL1", 0b11, 0b000, 0b0000, 0b0101, 0b100>;
  635. def : ROSysReg<"ID_AA64AFR1_EL1", 0b11, 0b000, 0b0000, 0b0101, 0b101>;
  636. def : ROSysReg<"ID_AA64ISAR0_EL1", 0b11, 0b000, 0b0000, 0b0110, 0b000>;
  637. def : ROSysReg<"ID_AA64ISAR1_EL1", 0b11, 0b000, 0b0000, 0b0110, 0b001>;
  638. def : ROSysReg<"ID_AA64ISAR2_EL1", 0b11, 0b000, 0b0000, 0b0110, 0b010>;
  639. def : ROSysReg<"ID_AA64MMFR0_EL1", 0b11, 0b000, 0b0000, 0b0111, 0b000>;
  640. def : ROSysReg<"ID_AA64MMFR1_EL1", 0b11, 0b000, 0b0000, 0b0111, 0b001>;
  641. def : ROSysReg<"ID_AA64MMFR2_EL1", 0b11, 0b000, 0b0000, 0b0111, 0b010>;
  642. def : ROSysReg<"ID_AA64MMFR3_EL1", 0b11, 0b000, 0b0000, 0b0111, 0b011>;
  643. def : ROSysReg<"ID_AA64MMFR4_EL1", 0b11, 0b000, 0b0000, 0b0111, 0b100>;
  644. def : ROSysReg<"MVFR0_EL1", 0b11, 0b000, 0b0000, 0b0011, 0b000>;
  645. def : ROSysReg<"MVFR1_EL1", 0b11, 0b000, 0b0000, 0b0011, 0b001>;
  646. def : ROSysReg<"MVFR2_EL1", 0b11, 0b000, 0b0000, 0b0011, 0b010>;
  647. def : ROSysReg<"RVBAR_EL1", 0b11, 0b000, 0b1100, 0b0000, 0b001>;
  648. def : ROSysReg<"RVBAR_EL2", 0b11, 0b100, 0b1100, 0b0000, 0b001>;
  649. def : ROSysReg<"RVBAR_EL3", 0b11, 0b110, 0b1100, 0b0000, 0b001>;
  650. def : ROSysReg<"ISR_EL1", 0b11, 0b000, 0b1100, 0b0001, 0b000>;
  651. def : ROSysReg<"CNTPCT_EL0", 0b11, 0b011, 0b1110, 0b0000, 0b001>;
  652. def : ROSysReg<"CNTVCT_EL0", 0b11, 0b011, 0b1110, 0b0000, 0b010>;
  653. def : ROSysReg<"ID_MMFR4_EL1", 0b11, 0b000, 0b0000, 0b0010, 0b110>;
  654. def : ROSysReg<"ID_MMFR5_EL1", 0b11, 0b000, 0b0000, 0b0011, 0b110>;
  655. // Trace registers
  656. // Op0 Op1 CRn CRm Op2
  657. def : ROSysReg<"TRCSTATR", 0b10, 0b001, 0b0000, 0b0011, 0b000>;
  658. def : ROSysReg<"TRCIDR8", 0b10, 0b001, 0b0000, 0b0000, 0b110>;
  659. def : ROSysReg<"TRCIDR9", 0b10, 0b001, 0b0000, 0b0001, 0b110>;
  660. def : ROSysReg<"TRCIDR10", 0b10, 0b001, 0b0000, 0b0010, 0b110>;
  661. def : ROSysReg<"TRCIDR11", 0b10, 0b001, 0b0000, 0b0011, 0b110>;
  662. def : ROSysReg<"TRCIDR12", 0b10, 0b001, 0b0000, 0b0100, 0b110>;
  663. def : ROSysReg<"TRCIDR13", 0b10, 0b001, 0b0000, 0b0101, 0b110>;
  664. def : ROSysReg<"TRCIDR0", 0b10, 0b001, 0b0000, 0b1000, 0b111>;
  665. def : ROSysReg<"TRCIDR1", 0b10, 0b001, 0b0000, 0b1001, 0b111>;
  666. def : ROSysReg<"TRCIDR2", 0b10, 0b001, 0b0000, 0b1010, 0b111>;
  667. def : ROSysReg<"TRCIDR3", 0b10, 0b001, 0b0000, 0b1011, 0b111>;
  668. def : ROSysReg<"TRCIDR4", 0b10, 0b001, 0b0000, 0b1100, 0b111>;
  669. def : ROSysReg<"TRCIDR5", 0b10, 0b001, 0b0000, 0b1101, 0b111>;
  670. def : ROSysReg<"TRCIDR6", 0b10, 0b001, 0b0000, 0b1110, 0b111>;
  671. def : ROSysReg<"TRCIDR7", 0b10, 0b001, 0b0000, 0b1111, 0b111>;
  672. def : ROSysReg<"TRCOSLSR", 0b10, 0b001, 0b0001, 0b0001, 0b100>;
  673. def : ROSysReg<"TRCPDSR", 0b10, 0b001, 0b0001, 0b0101, 0b100>;
  674. def : ROSysReg<"TRCDEVAFF0", 0b10, 0b001, 0b0111, 0b1010, 0b110>;
  675. def : ROSysReg<"TRCDEVAFF1", 0b10, 0b001, 0b0111, 0b1011, 0b110>;
  676. def : ROSysReg<"TRCLSR", 0b10, 0b001, 0b0111, 0b1101, 0b110>;
  677. def : ROSysReg<"TRCAUTHSTATUS", 0b10, 0b001, 0b0111, 0b1110, 0b110>;
  678. def : ROSysReg<"TRCDEVARCH", 0b10, 0b001, 0b0111, 0b1111, 0b110>;
  679. def : ROSysReg<"TRCDEVID", 0b10, 0b001, 0b0111, 0b0010, 0b111>;
  680. def : ROSysReg<"TRCDEVTYPE", 0b10, 0b001, 0b0111, 0b0011, 0b111>;
  681. def : ROSysReg<"TRCPIDR4", 0b10, 0b001, 0b0111, 0b0100, 0b111>;
  682. def : ROSysReg<"TRCPIDR5", 0b10, 0b001, 0b0111, 0b0101, 0b111>;
  683. def : ROSysReg<"TRCPIDR6", 0b10, 0b001, 0b0111, 0b0110, 0b111>;
  684. def : ROSysReg<"TRCPIDR7", 0b10, 0b001, 0b0111, 0b0111, 0b111>;
  685. def : ROSysReg<"TRCPIDR0", 0b10, 0b001, 0b0111, 0b1000, 0b111>;
  686. def : ROSysReg<"TRCPIDR1", 0b10, 0b001, 0b0111, 0b1001, 0b111>;
  687. def : ROSysReg<"TRCPIDR2", 0b10, 0b001, 0b0111, 0b1010, 0b111>;
  688. def : ROSysReg<"TRCPIDR3", 0b10, 0b001, 0b0111, 0b1011, 0b111>;
  689. def : ROSysReg<"TRCCIDR0", 0b10, 0b001, 0b0111, 0b1100, 0b111>;
  690. def : ROSysReg<"TRCCIDR1", 0b10, 0b001, 0b0111, 0b1101, 0b111>;
  691. def : ROSysReg<"TRCCIDR2", 0b10, 0b001, 0b0111, 0b1110, 0b111>;
  692. def : ROSysReg<"TRCCIDR3", 0b10, 0b001, 0b0111, 0b1111, 0b111>;
  693. // GICv3 registers
  694. // Op0 Op1 CRn CRm Op2
  695. def : ROSysReg<"ICC_IAR1_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b000>;
  696. def : ROSysReg<"ICC_IAR0_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b000>;
  697. def : ROSysReg<"ICC_HPPIR1_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b010>;
  698. def : ROSysReg<"ICC_HPPIR0_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b010>;
  699. def : ROSysReg<"ICC_RPR_EL1", 0b11, 0b000, 0b1100, 0b1011, 0b011>;
  700. def : ROSysReg<"ICH_VTR_EL2", 0b11, 0b100, 0b1100, 0b1011, 0b001>;
  701. def : ROSysReg<"ICH_EISR_EL2", 0b11, 0b100, 0b1100, 0b1011, 0b011>;
  702. def : ROSysReg<"ICH_ELRSR_EL2", 0b11, 0b100, 0b1100, 0b1011, 0b101>;
  703. // SVE control registers
  704. // Op0 Op1 CRn CRm Op2
  705. let Requires = [{ {AArch64::FeatureSVE} }] in {
  706. def : ROSysReg<"ID_AA64ZFR0_EL1", 0b11, 0b000, 0b0000, 0b0100, 0b100>;
  707. }
  708. // v8.1a "Limited Ordering Regions" extension-specific system register
  709. // Op0 Op1 CRn CRm Op2
  710. let Requires = [{ {AArch64::FeatureLOR} }] in
  711. def : ROSysReg<"LORID_EL1", 0b11, 0b000, 0b1010, 0b0100, 0b111>;
  712. // v8.2a "RAS extension" registers
  713. // Op0 Op1 CRn CRm Op2
  714. let Requires = [{ {AArch64::FeatureRAS} }] in {
  715. def : ROSysReg<"ERRIDR_EL1", 0b11, 0b000, 0b0101, 0b0011, 0b000>;
  716. def : ROSysReg<"ERXFR_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b000>;
  717. }
  718. // v8.5a "random number" registers
  719. // Op0 Op1 CRn CRm Op2
  720. let Requires = [{ {AArch64::FeatureRandGen} }] in {
  721. def : ROSysReg<"RNDR", 0b11, 0b011, 0b0010, 0b0100, 0b000>;
  722. def : ROSysReg<"RNDRRS", 0b11, 0b011, 0b0010, 0b0100, 0b001>;
  723. }
  724. // v8.5a Software Context Number registers
  725. let Requires = [{ {AArch64::FeatureSpecRestrict} }] in {
  726. def : RWSysReg<"SCXTNUM_EL0", 0b11, 0b011, 0b1101, 0b0000, 0b111>;
  727. def : RWSysReg<"SCXTNUM_EL1", 0b11, 0b000, 0b1101, 0b0000, 0b111>;
  728. def : RWSysReg<"SCXTNUM_EL2", 0b11, 0b100, 0b1101, 0b0000, 0b111>;
  729. def : RWSysReg<"SCXTNUM_EL3", 0b11, 0b110, 0b1101, 0b0000, 0b111>;
  730. def : RWSysReg<"SCXTNUM_EL12", 0b11, 0b101, 0b1101, 0b0000, 0b111>;
  731. }
  732. // v9a Realm Management Extension registers
  733. let Requires = [{ {AArch64::FeatureRME} }] in {
  734. def : RWSysReg<"GPCCR_EL3", 0b11, 0b110, 0b0010, 0b0001, 0b110>;
  735. def : RWSysReg<"GPTBR_EL3", 0b11, 0b110, 0b0010, 0b0001, 0b100>;
  736. }
  737. // MFAR_EL3 is part of both FEAT_RME and FEAT_PFAR (further below). The latter
  738. // is unconditional so this register has to be too.
  739. def : RWSysReg<"MFAR_EL3", 0b11, 0b110, 0b0110, 0b0000, 0b101>;
  740. // v9a Memory Encryption Contexts Extension registers
  741. let Requires = [{ {AArch64::FeatureMEC} }] in {
  742. def : ROSysReg<"MECIDR_EL2", 0b11, 0b100, 0b1010, 0b1000, 0b111>;
  743. def : RWSysReg<"MECID_P0_EL2", 0b11, 0b100, 0b1010, 0b1000, 0b000>;
  744. def : RWSysReg<"MECID_A0_EL2", 0b11, 0b100, 0b1010, 0b1000, 0b001>;
  745. def : RWSysReg<"MECID_P1_EL2", 0b11, 0b100, 0b1010, 0b1000, 0b010>;
  746. def : RWSysReg<"MECID_A1_EL2", 0b11, 0b100, 0b1010, 0b1000, 0b011>;
  747. def : RWSysReg<"VMECID_P_EL2", 0b11, 0b100, 0b1010, 0b1001, 0b000>;
  748. def : RWSysReg<"VMECID_A_EL2", 0b11, 0b100, 0b1010, 0b1001, 0b001>;
  749. def : RWSysReg<"MECID_RL_A_EL3", 0b11, 0b110, 0b1010, 0b1010, 0b001>;
  750. }
  751. // v9-a Scalable Matrix Extension (SME) registers
  752. // Op0 Op1 CRn CRm Op2
  753. let Requires = [{ {AArch64::FeatureSME} }] in {
  754. def : ROSysReg<"ID_AA64SMFR0_EL1", 0b11, 0b000, 0b0000, 0b0100, 0b101>;
  755. }
  756. //===----------------------
  757. // Write-only regs
  758. //===----------------------
  759. // Op0 Op1 CRn CRm Op2
  760. def : WOSysReg<"DBGDTRTX_EL0", 0b10, 0b011, 0b0000, 0b0101, 0b000>;
  761. def : WOSysReg<"OSLAR_EL1", 0b10, 0b000, 0b0001, 0b0000, 0b100>;
  762. def : WOSysReg<"PMSWINC_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b100>;
  763. // Trace Registers
  764. // Op0 Op1 CRn CRm Op2
  765. def : WOSysReg<"TRCOSLAR", 0b10, 0b001, 0b0001, 0b0000, 0b100>;
  766. def : WOSysReg<"TRCLAR", 0b10, 0b001, 0b0111, 0b1100, 0b110>;
  767. // GICv3 registers
  768. // Op0 Op1 CRn CRm Op2
  769. def : WOSysReg<"ICC_EOIR1_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b001>;
  770. def : WOSysReg<"ICC_EOIR0_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b001>;
  771. def : WOSysReg<"ICC_DIR_EL1", 0b11, 0b000, 0b1100, 0b1011, 0b001>;
  772. def : WOSysReg<"ICC_SGI1R_EL1", 0b11, 0b000, 0b1100, 0b1011, 0b101>;
  773. def : WOSysReg<"ICC_ASGI1R_EL1", 0b11, 0b000, 0b1100, 0b1011, 0b110>;
  774. def : WOSysReg<"ICC_SGI0R_EL1", 0b11, 0b000, 0b1100, 0b1011, 0b111>;
  775. //===----------------------
  776. // Read-write regs
  777. //===----------------------
  778. // Op0 Op1 CRn CRm Op2
  779. def : RWSysReg<"OSDTRRX_EL1", 0b10, 0b000, 0b0000, 0b0000, 0b010>;
  780. def : RWSysReg<"OSDTRTX_EL1", 0b10, 0b000, 0b0000, 0b0011, 0b010>;
  781. def : RWSysReg<"TEECR32_EL1", 0b10, 0b010, 0b0000, 0b0000, 0b000>;
  782. def : RWSysReg<"MDCCINT_EL1", 0b10, 0b000, 0b0000, 0b0010, 0b000>;
  783. def : RWSysReg<"MDSCR_EL1", 0b10, 0b000, 0b0000, 0b0010, 0b010>;
  784. def : RWSysReg<"DBGDTR_EL0", 0b10, 0b011, 0b0000, 0b0100, 0b000>;
  785. def : RWSysReg<"OSECCR_EL1", 0b10, 0b000, 0b0000, 0b0110, 0b010>;
  786. def : RWSysReg<"DBGVCR32_EL2", 0b10, 0b100, 0b0000, 0b0111, 0b000>;
  787. foreach n = 0-15 in {
  788. defvar nb = !cast<bits<4>>(n);
  789. // Op0 Op1 CRn CRm Op2
  790. def : RWSysReg<"DBGBVR"#n#"_EL1", 0b10, 0b000, 0b0000, nb, 0b100>;
  791. def : RWSysReg<"DBGBCR"#n#"_EL1", 0b10, 0b000, 0b0000, nb, 0b101>;
  792. def : RWSysReg<"DBGWVR"#n#"_EL1", 0b10, 0b000, 0b0000, nb, 0b110>;
  793. def : RWSysReg<"DBGWCR"#n#"_EL1", 0b10, 0b000, 0b0000, nb, 0b111>;
  794. }
  795. // Op0 Op1 CRn CRm Op2
  796. def : RWSysReg<"TEEHBR32_EL1", 0b10, 0b010, 0b0001, 0b0000, 0b000>;
  797. def : RWSysReg<"OSDLR_EL1", 0b10, 0b000, 0b0001, 0b0011, 0b100>;
  798. def : RWSysReg<"DBGPRCR_EL1", 0b10, 0b000, 0b0001, 0b0100, 0b100>;
  799. def : RWSysReg<"DBGCLAIMSET_EL1", 0b10, 0b000, 0b0111, 0b1000, 0b110>;
  800. def : RWSysReg<"DBGCLAIMCLR_EL1", 0b10, 0b000, 0b0111, 0b1001, 0b110>;
  801. def : RWSysReg<"CSSELR_EL1", 0b11, 0b010, 0b0000, 0b0000, 0b000>;
  802. def : RWSysReg<"VPIDR_EL2", 0b11, 0b100, 0b0000, 0b0000, 0b000>;
  803. def : RWSysReg<"VMPIDR_EL2", 0b11, 0b100, 0b0000, 0b0000, 0b101>;
  804. def : RWSysReg<"CPACR_EL1", 0b11, 0b000, 0b0001, 0b0000, 0b010>;
  805. def : RWSysReg<"SCTLR_EL1", 0b11, 0b000, 0b0001, 0b0000, 0b000>;
  806. def : RWSysReg<"SCTLR_EL2", 0b11, 0b100, 0b0001, 0b0000, 0b000>;
  807. def : RWSysReg<"SCTLR_EL3", 0b11, 0b110, 0b0001, 0b0000, 0b000>;
  808. def : RWSysReg<"ACTLR_EL1", 0b11, 0b000, 0b0001, 0b0000, 0b001>;
  809. def : RWSysReg<"ACTLR_EL2", 0b11, 0b100, 0b0001, 0b0000, 0b001>;
  810. def : RWSysReg<"ACTLR_EL3", 0b11, 0b110, 0b0001, 0b0000, 0b001>;
  811. def : RWSysReg<"HCR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b000>;
  812. def : RWSysReg<"HCRX_EL2", 0b11, 0b100, 0b0001, 0b0010, 0b010> {
  813. let Requires = [{ {AArch64::FeatureHCX} }];
  814. }
  815. def : RWSysReg<"SCR_EL3", 0b11, 0b110, 0b0001, 0b0001, 0b000>;
  816. def : RWSysReg<"MDCR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b001>;
  817. def : RWSysReg<"SDER32_EL3", 0b11, 0b110, 0b0001, 0b0001, 0b001>;
  818. def : RWSysReg<"CPTR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b010>;
  819. def : RWSysReg<"CPTR_EL3", 0b11, 0b110, 0b0001, 0b0001, 0b010>;
  820. def : RWSysReg<"HSTR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b011>;
  821. def : RWSysReg<"HACR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b111>;
  822. def : RWSysReg<"MDCR_EL3", 0b11, 0b110, 0b0001, 0b0011, 0b001>;
  823. def : RWSysReg<"TTBR0_EL1", 0b11, 0b000, 0b0010, 0b0000, 0b000>;
  824. def : RWSysReg<"TTBR0_EL3", 0b11, 0b110, 0b0010, 0b0000, 0b000>;
  825. let Requires = [{ {AArch64::FeatureEL2VMSA} }] in {
  826. def : RWSysReg<"TTBR0_EL2", 0b11, 0b100, 0b0010, 0b0000, 0b000> {
  827. let AltName = "VSCTLR_EL2";
  828. }
  829. def : RWSysReg<"VTTBR_EL2", 0b11, 0b100, 0b0010, 0b0001, 0b000>;
  830. }
  831. def : RWSysReg<"TTBR1_EL1", 0b11, 0b000, 0b0010, 0b0000, 0b001>;
  832. def : RWSysReg<"TCR_EL1", 0b11, 0b000, 0b0010, 0b0000, 0b010>;
  833. def : RWSysReg<"TCR_EL2", 0b11, 0b100, 0b0010, 0b0000, 0b010>;
  834. def : RWSysReg<"TCR_EL3", 0b11, 0b110, 0b0010, 0b0000, 0b010>;
  835. def : RWSysReg<"VTCR_EL2", 0b11, 0b100, 0b0010, 0b0001, 0b010>;
  836. def : RWSysReg<"DACR32_EL2", 0b11, 0b100, 0b0011, 0b0000, 0b000>;
  837. def : RWSysReg<"SPSR_EL1", 0b11, 0b000, 0b0100, 0b0000, 0b000>;
  838. def : RWSysReg<"SPSR_EL2", 0b11, 0b100, 0b0100, 0b0000, 0b000>;
  839. def : RWSysReg<"SPSR_EL3", 0b11, 0b110, 0b0100, 0b0000, 0b000>;
  840. def : RWSysReg<"ELR_EL1", 0b11, 0b000, 0b0100, 0b0000, 0b001>;
  841. def : RWSysReg<"ELR_EL2", 0b11, 0b100, 0b0100, 0b0000, 0b001>;
  842. def : RWSysReg<"ELR_EL3", 0b11, 0b110, 0b0100, 0b0000, 0b001>;
  843. def : RWSysReg<"SP_EL0", 0b11, 0b000, 0b0100, 0b0001, 0b000>;
  844. def : RWSysReg<"SP_EL1", 0b11, 0b100, 0b0100, 0b0001, 0b000>;
  845. def : RWSysReg<"SP_EL2", 0b11, 0b110, 0b0100, 0b0001, 0b000>;
  846. def : RWSysReg<"SPSel", 0b11, 0b000, 0b0100, 0b0010, 0b000>;
  847. def : RWSysReg<"NZCV", 0b11, 0b011, 0b0100, 0b0010, 0b000>;
  848. def : RWSysReg<"DAIF", 0b11, 0b011, 0b0100, 0b0010, 0b001>;
  849. def : ROSysReg<"CurrentEL", 0b11, 0b000, 0b0100, 0b0010, 0b010>;
  850. def : RWSysReg<"SPSR_irq", 0b11, 0b100, 0b0100, 0b0011, 0b000>;
  851. def : RWSysReg<"SPSR_abt", 0b11, 0b100, 0b0100, 0b0011, 0b001>;
  852. def : RWSysReg<"SPSR_und", 0b11, 0b100, 0b0100, 0b0011, 0b010>;
  853. def : RWSysReg<"SPSR_fiq", 0b11, 0b100, 0b0100, 0b0011, 0b011>;
  854. def : RWSysReg<"FPCR", 0b11, 0b011, 0b0100, 0b0100, 0b000>;
  855. def : RWSysReg<"FPSR", 0b11, 0b011, 0b0100, 0b0100, 0b001>;
  856. def : RWSysReg<"DSPSR_EL0", 0b11, 0b011, 0b0100, 0b0101, 0b000>;
  857. def : RWSysReg<"DLR_EL0", 0b11, 0b011, 0b0100, 0b0101, 0b001>;
  858. def : RWSysReg<"IFSR32_EL2", 0b11, 0b100, 0b0101, 0b0000, 0b001>;
  859. def : RWSysReg<"AFSR0_EL1", 0b11, 0b000, 0b0101, 0b0001, 0b000>;
  860. def : RWSysReg<"AFSR0_EL2", 0b11, 0b100, 0b0101, 0b0001, 0b000>;
  861. def : RWSysReg<"AFSR0_EL3", 0b11, 0b110, 0b0101, 0b0001, 0b000>;
  862. def : RWSysReg<"AFSR1_EL1", 0b11, 0b000, 0b0101, 0b0001, 0b001>;
  863. def : RWSysReg<"AFSR1_EL2", 0b11, 0b100, 0b0101, 0b0001, 0b001>;
  864. def : RWSysReg<"AFSR1_EL3", 0b11, 0b110, 0b0101, 0b0001, 0b001>;
  865. def : RWSysReg<"ESR_EL1", 0b11, 0b000, 0b0101, 0b0010, 0b000>;
  866. def : RWSysReg<"ESR_EL2", 0b11, 0b100, 0b0101, 0b0010, 0b000>;
  867. def : RWSysReg<"ESR_EL3", 0b11, 0b110, 0b0101, 0b0010, 0b000>;
  868. def : RWSysReg<"FPEXC32_EL2", 0b11, 0b100, 0b0101, 0b0011, 0b000>;
  869. def : RWSysReg<"FAR_EL1", 0b11, 0b000, 0b0110, 0b0000, 0b000>;
  870. def : RWSysReg<"FAR_EL2", 0b11, 0b100, 0b0110, 0b0000, 0b000>;
  871. def : RWSysReg<"FAR_EL3", 0b11, 0b110, 0b0110, 0b0000, 0b000>;
  872. def : RWSysReg<"HPFAR_EL2", 0b11, 0b100, 0b0110, 0b0000, 0b100>;
  873. def : RWSysReg<"PAR_EL1", 0b11, 0b000, 0b0111, 0b0100, 0b000>;
  874. def : RWSysReg<"PMCR_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b000>;
  875. def : RWSysReg<"PMCNTENSET_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b001>;
  876. def : RWSysReg<"PMCNTENCLR_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b010>;
  877. def : RWSysReg<"PMOVSCLR_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b011>;
  878. def : RWSysReg<"PMSELR_EL0", 0b11, 0b011, 0b1001, 0b1100, 0b101>;
  879. def : RWSysReg<"PMCCNTR_EL0", 0b11, 0b011, 0b1001, 0b1101, 0b000>;
  880. def : RWSysReg<"PMXEVTYPER_EL0", 0b11, 0b011, 0b1001, 0b1101, 0b001>;
  881. def : RWSysReg<"PMXEVCNTR_EL0", 0b11, 0b011, 0b1001, 0b1101, 0b010>;
  882. def : RWSysReg<"PMUSERENR_EL0", 0b11, 0b011, 0b1001, 0b1110, 0b000>;
  883. def : RWSysReg<"PMINTENSET_EL1", 0b11, 0b000, 0b1001, 0b1110, 0b001>;
  884. def : RWSysReg<"PMINTENCLR_EL1", 0b11, 0b000, 0b1001, 0b1110, 0b010>;
  885. def : RWSysReg<"PMOVSSET_EL0", 0b11, 0b011, 0b1001, 0b1110, 0b011>;
  886. def : RWSysReg<"MAIR_EL1", 0b11, 0b000, 0b1010, 0b0010, 0b000>;
  887. def : RWSysReg<"MAIR_EL2", 0b11, 0b100, 0b1010, 0b0010, 0b000>;
  888. def : RWSysReg<"MAIR_EL3", 0b11, 0b110, 0b1010, 0b0010, 0b000>;
  889. def : RWSysReg<"AMAIR_EL1", 0b11, 0b000, 0b1010, 0b0011, 0b000>;
  890. def : RWSysReg<"AMAIR_EL2", 0b11, 0b100, 0b1010, 0b0011, 0b000>;
  891. def : RWSysReg<"AMAIR_EL3", 0b11, 0b110, 0b1010, 0b0011, 0b000>;
  892. def : RWSysReg<"VBAR_EL1", 0b11, 0b000, 0b1100, 0b0000, 0b000>;
  893. def : RWSysReg<"VBAR_EL2", 0b11, 0b100, 0b1100, 0b0000, 0b000>;
  894. def : RWSysReg<"VBAR_EL3", 0b11, 0b110, 0b1100, 0b0000, 0b000>;
  895. def : RWSysReg<"RMR_EL1", 0b11, 0b000, 0b1100, 0b0000, 0b010>;
  896. def : RWSysReg<"RMR_EL2", 0b11, 0b100, 0b1100, 0b0000, 0b010>;
  897. def : RWSysReg<"RMR_EL3", 0b11, 0b110, 0b1100, 0b0000, 0b010>;
  898. def : RWSysReg<"CONTEXTIDR_EL1", 0b11, 0b000, 0b1101, 0b0000, 0b001>;
  899. def : RWSysReg<"TPIDR_EL0", 0b11, 0b011, 0b1101, 0b0000, 0b010>;
  900. def : RWSysReg<"TPIDR_EL2", 0b11, 0b100, 0b1101, 0b0000, 0b010>;
  901. def : RWSysReg<"TPIDR_EL3", 0b11, 0b110, 0b1101, 0b0000, 0b010>;
  902. def : RWSysReg<"TPIDRRO_EL0", 0b11, 0b011, 0b1101, 0b0000, 0b011>;
  903. def : RWSysReg<"TPIDR_EL1", 0b11, 0b000, 0b1101, 0b0000, 0b100>;
  904. def : RWSysReg<"CNTFRQ_EL0", 0b11, 0b011, 0b1110, 0b0000, 0b000>;
  905. def : RWSysReg<"CNTVOFF_EL2", 0b11, 0b100, 0b1110, 0b0000, 0b011>;
  906. def : RWSysReg<"CNTKCTL_EL1", 0b11, 0b000, 0b1110, 0b0001, 0b000>;
  907. def : RWSysReg<"CNTHCTL_EL2", 0b11, 0b100, 0b1110, 0b0001, 0b000>;
  908. def : RWSysReg<"CNTP_TVAL_EL0", 0b11, 0b011, 0b1110, 0b0010, 0b000>;
  909. def : RWSysReg<"CNTHP_TVAL_EL2", 0b11, 0b100, 0b1110, 0b0010, 0b000>;
  910. def : RWSysReg<"CNTPS_TVAL_EL1", 0b11, 0b111, 0b1110, 0b0010, 0b000>;
  911. def : RWSysReg<"CNTP_CTL_EL0", 0b11, 0b011, 0b1110, 0b0010, 0b001>;
  912. def : RWSysReg<"CNTHP_CTL_EL2", 0b11, 0b100, 0b1110, 0b0010, 0b001>;
  913. def : RWSysReg<"CNTPS_CTL_EL1", 0b11, 0b111, 0b1110, 0b0010, 0b001>;
  914. def : RWSysReg<"CNTP_CVAL_EL0", 0b11, 0b011, 0b1110, 0b0010, 0b010>;
  915. def : RWSysReg<"CNTHP_CVAL_EL2", 0b11, 0b100, 0b1110, 0b0010, 0b010>;
  916. def : RWSysReg<"CNTPS_CVAL_EL1", 0b11, 0b111, 0b1110, 0b0010, 0b010>;
  917. def : RWSysReg<"CNTV_TVAL_EL0", 0b11, 0b011, 0b1110, 0b0011, 0b000>;
  918. def : RWSysReg<"CNTV_CTL_EL0", 0b11, 0b011, 0b1110, 0b0011, 0b001>;
  919. def : RWSysReg<"CNTV_CVAL_EL0", 0b11, 0b011, 0b1110, 0b0011, 0b010>;
  920. def : RWSysReg<"PMEVCNTR0_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b000>;
  921. def : RWSysReg<"PMEVCNTR1_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b001>;
  922. def : RWSysReg<"PMEVCNTR2_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b010>;
  923. def : RWSysReg<"PMEVCNTR3_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b011>;
  924. def : RWSysReg<"PMEVCNTR4_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b100>;
  925. def : RWSysReg<"PMEVCNTR5_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b101>;
  926. def : RWSysReg<"PMEVCNTR6_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b110>;
  927. def : RWSysReg<"PMEVCNTR7_EL0", 0b11, 0b011, 0b1110, 0b1000, 0b111>;
  928. def : RWSysReg<"PMEVCNTR8_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b000>;
  929. def : RWSysReg<"PMEVCNTR9_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b001>;
  930. def : RWSysReg<"PMEVCNTR10_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b010>;
  931. def : RWSysReg<"PMEVCNTR11_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b011>;
  932. def : RWSysReg<"PMEVCNTR12_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b100>;
  933. def : RWSysReg<"PMEVCNTR13_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b101>;
  934. def : RWSysReg<"PMEVCNTR14_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b110>;
  935. def : RWSysReg<"PMEVCNTR15_EL0", 0b11, 0b011, 0b1110, 0b1001, 0b111>;
  936. def : RWSysReg<"PMEVCNTR16_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b000>;
  937. def : RWSysReg<"PMEVCNTR17_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b001>;
  938. def : RWSysReg<"PMEVCNTR18_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b010>;
  939. def : RWSysReg<"PMEVCNTR19_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b011>;
  940. def : RWSysReg<"PMEVCNTR20_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b100>;
  941. def : RWSysReg<"PMEVCNTR21_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b101>;
  942. def : RWSysReg<"PMEVCNTR22_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b110>;
  943. def : RWSysReg<"PMEVCNTR23_EL0", 0b11, 0b011, 0b1110, 0b1010, 0b111>;
  944. def : RWSysReg<"PMEVCNTR24_EL0", 0b11, 0b011, 0b1110, 0b1011, 0b000>;
  945. def : RWSysReg<"PMEVCNTR25_EL0", 0b11, 0b011, 0b1110, 0b1011, 0b001>;
  946. def : RWSysReg<"PMEVCNTR26_EL0", 0b11, 0b011, 0b1110, 0b1011, 0b010>;
  947. def : RWSysReg<"PMEVCNTR27_EL0", 0b11, 0b011, 0b1110, 0b1011, 0b011>;
  948. def : RWSysReg<"PMEVCNTR28_EL0", 0b11, 0b011, 0b1110, 0b1011, 0b100>;
  949. def : RWSysReg<"PMEVCNTR29_EL0", 0b11, 0b011, 0b1110, 0b1011, 0b101>;
  950. def : RWSysReg<"PMEVCNTR30_EL0", 0b11, 0b011, 0b1110, 0b1011, 0b110>;
  951. def : RWSysReg<"PMCCFILTR_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b111>;
  952. def : RWSysReg<"PMEVTYPER0_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b000>;
  953. def : RWSysReg<"PMEVTYPER1_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b001>;
  954. def : RWSysReg<"PMEVTYPER2_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b010>;
  955. def : RWSysReg<"PMEVTYPER3_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b011>;
  956. def : RWSysReg<"PMEVTYPER4_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b100>;
  957. def : RWSysReg<"PMEVTYPER5_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b101>;
  958. def : RWSysReg<"PMEVTYPER6_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b110>;
  959. def : RWSysReg<"PMEVTYPER7_EL0", 0b11, 0b011, 0b1110, 0b1100, 0b111>;
  960. def : RWSysReg<"PMEVTYPER8_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b000>;
  961. def : RWSysReg<"PMEVTYPER9_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b001>;
  962. def : RWSysReg<"PMEVTYPER10_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b010>;
  963. def : RWSysReg<"PMEVTYPER11_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b011>;
  964. def : RWSysReg<"PMEVTYPER12_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b100>;
  965. def : RWSysReg<"PMEVTYPER13_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b101>;
  966. def : RWSysReg<"PMEVTYPER14_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b110>;
  967. def : RWSysReg<"PMEVTYPER15_EL0", 0b11, 0b011, 0b1110, 0b1101, 0b111>;
  968. def : RWSysReg<"PMEVTYPER16_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b000>;
  969. def : RWSysReg<"PMEVTYPER17_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b001>;
  970. def : RWSysReg<"PMEVTYPER18_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b010>;
  971. def : RWSysReg<"PMEVTYPER19_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b011>;
  972. def : RWSysReg<"PMEVTYPER20_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b100>;
  973. def : RWSysReg<"PMEVTYPER21_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b101>;
  974. def : RWSysReg<"PMEVTYPER22_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b110>;
  975. def : RWSysReg<"PMEVTYPER23_EL0", 0b11, 0b011, 0b1110, 0b1110, 0b111>;
  976. def : RWSysReg<"PMEVTYPER24_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b000>;
  977. def : RWSysReg<"PMEVTYPER25_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b001>;
  978. def : RWSysReg<"PMEVTYPER26_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b010>;
  979. def : RWSysReg<"PMEVTYPER27_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b011>;
  980. def : RWSysReg<"PMEVTYPER28_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b100>;
  981. def : RWSysReg<"PMEVTYPER29_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b101>;
  982. def : RWSysReg<"PMEVTYPER30_EL0", 0b11, 0b011, 0b1110, 0b1111, 0b110>;
  983. // Trace registers
  984. // Op0 Op1 CRn CRm Op2
  985. def : RWSysReg<"TRCPRGCTLR", 0b10, 0b001, 0b0000, 0b0001, 0b000>;
  986. def : RWSysReg<"TRCPROCSELR", 0b10, 0b001, 0b0000, 0b0010, 0b000>;
  987. def : RWSysReg<"TRCCONFIGR", 0b10, 0b001, 0b0000, 0b0100, 0b000>;
  988. def : RWSysReg<"TRCAUXCTLR", 0b10, 0b001, 0b0000, 0b0110, 0b000>;
  989. def : RWSysReg<"TRCEVENTCTL0R", 0b10, 0b001, 0b0000, 0b1000, 0b000>;
  990. def : RWSysReg<"TRCEVENTCTL1R", 0b10, 0b001, 0b0000, 0b1001, 0b000>;
  991. def : RWSysReg<"TRCSTALLCTLR", 0b10, 0b001, 0b0000, 0b1011, 0b000>;
  992. def : RWSysReg<"TRCTSCTLR", 0b10, 0b001, 0b0000, 0b1100, 0b000>;
  993. def : RWSysReg<"TRCSYNCPR", 0b10, 0b001, 0b0000, 0b1101, 0b000>;
  994. def : RWSysReg<"TRCCCCTLR", 0b10, 0b001, 0b0000, 0b1110, 0b000>;
  995. def : RWSysReg<"TRCBBCTLR", 0b10, 0b001, 0b0000, 0b1111, 0b000>;
  996. def : RWSysReg<"TRCTRACEIDR", 0b10, 0b001, 0b0000, 0b0000, 0b001>;
  997. def : RWSysReg<"TRCQCTLR", 0b10, 0b001, 0b0000, 0b0001, 0b001>;
  998. def : RWSysReg<"TRCVICTLR", 0b10, 0b001, 0b0000, 0b0000, 0b010>;
  999. def : RWSysReg<"TRCVIIECTLR", 0b10, 0b001, 0b0000, 0b0001, 0b010>;
  1000. def : RWSysReg<"TRCVISSCTLR", 0b10, 0b001, 0b0000, 0b0010, 0b010>;
  1001. def : RWSysReg<"TRCVIPCSSCTLR", 0b10, 0b001, 0b0000, 0b0011, 0b010>;
  1002. def : RWSysReg<"TRCVDCTLR", 0b10, 0b001, 0b0000, 0b1000, 0b010>;
  1003. def : RWSysReg<"TRCVDSACCTLR", 0b10, 0b001, 0b0000, 0b1001, 0b010>;
  1004. def : RWSysReg<"TRCVDARCCTLR", 0b10, 0b001, 0b0000, 0b1010, 0b010>;
  1005. def : RWSysReg<"TRCSEQEVR0", 0b10, 0b001, 0b0000, 0b0000, 0b100>;
  1006. def : RWSysReg<"TRCSEQEVR1", 0b10, 0b001, 0b0000, 0b0001, 0b100>;
  1007. def : RWSysReg<"TRCSEQEVR2", 0b10, 0b001, 0b0000, 0b0010, 0b100>;
  1008. def : RWSysReg<"TRCSEQRSTEVR", 0b10, 0b001, 0b0000, 0b0110, 0b100>;
  1009. def : RWSysReg<"TRCSEQSTR", 0b10, 0b001, 0b0000, 0b0111, 0b100>;
  1010. def : RWSysReg<"TRCEXTINSELR", 0b10, 0b001, 0b0000, 0b1000, 0b100>;
  1011. def : RWSysReg<"TRCCNTRLDVR0", 0b10, 0b001, 0b0000, 0b0000, 0b101>;
  1012. def : RWSysReg<"TRCCNTRLDVR1", 0b10, 0b001, 0b0000, 0b0001, 0b101>;
  1013. def : RWSysReg<"TRCCNTRLDVR2", 0b10, 0b001, 0b0000, 0b0010, 0b101>;
  1014. def : RWSysReg<"TRCCNTRLDVR3", 0b10, 0b001, 0b0000, 0b0011, 0b101>;
  1015. def : RWSysReg<"TRCCNTCTLR0", 0b10, 0b001, 0b0000, 0b0100, 0b101>;
  1016. def : RWSysReg<"TRCCNTCTLR1", 0b10, 0b001, 0b0000, 0b0101, 0b101>;
  1017. def : RWSysReg<"TRCCNTCTLR2", 0b10, 0b001, 0b0000, 0b0110, 0b101>;
  1018. def : RWSysReg<"TRCCNTCTLR3", 0b10, 0b001, 0b0000, 0b0111, 0b101>;
  1019. def : RWSysReg<"TRCCNTVR0", 0b10, 0b001, 0b0000, 0b1000, 0b101>;
  1020. def : RWSysReg<"TRCCNTVR1", 0b10, 0b001, 0b0000, 0b1001, 0b101>;
  1021. def : RWSysReg<"TRCCNTVR2", 0b10, 0b001, 0b0000, 0b1010, 0b101>;
  1022. def : RWSysReg<"TRCCNTVR3", 0b10, 0b001, 0b0000, 0b1011, 0b101>;
  1023. def : RWSysReg<"TRCIMSPEC0", 0b10, 0b001, 0b0000, 0b0000, 0b111>;
  1024. def : RWSysReg<"TRCIMSPEC1", 0b10, 0b001, 0b0000, 0b0001, 0b111>;
  1025. def : RWSysReg<"TRCIMSPEC2", 0b10, 0b001, 0b0000, 0b0010, 0b111>;
  1026. def : RWSysReg<"TRCIMSPEC3", 0b10, 0b001, 0b0000, 0b0011, 0b111>;
  1027. def : RWSysReg<"TRCIMSPEC4", 0b10, 0b001, 0b0000, 0b0100, 0b111>;
  1028. def : RWSysReg<"TRCIMSPEC5", 0b10, 0b001, 0b0000, 0b0101, 0b111>;
  1029. def : RWSysReg<"TRCIMSPEC6", 0b10, 0b001, 0b0000, 0b0110, 0b111>;
  1030. def : RWSysReg<"TRCIMSPEC7", 0b10, 0b001, 0b0000, 0b0111, 0b111>;
  1031. def : RWSysReg<"TRCRSCTLR2", 0b10, 0b001, 0b0001, 0b0010, 0b000>;
  1032. def : RWSysReg<"TRCRSCTLR3", 0b10, 0b001, 0b0001, 0b0011, 0b000>;
  1033. def : RWSysReg<"TRCRSCTLR4", 0b10, 0b001, 0b0001, 0b0100, 0b000>;
  1034. def : RWSysReg<"TRCRSCTLR5", 0b10, 0b001, 0b0001, 0b0101, 0b000>;
  1035. def : RWSysReg<"TRCRSCTLR6", 0b10, 0b001, 0b0001, 0b0110, 0b000>;
  1036. def : RWSysReg<"TRCRSCTLR7", 0b10, 0b001, 0b0001, 0b0111, 0b000>;
  1037. def : RWSysReg<"TRCRSCTLR8", 0b10, 0b001, 0b0001, 0b1000, 0b000>;
  1038. def : RWSysReg<"TRCRSCTLR9", 0b10, 0b001, 0b0001, 0b1001, 0b000>;
  1039. def : RWSysReg<"TRCRSCTLR10", 0b10, 0b001, 0b0001, 0b1010, 0b000>;
  1040. def : RWSysReg<"TRCRSCTLR11", 0b10, 0b001, 0b0001, 0b1011, 0b000>;
  1041. def : RWSysReg<"TRCRSCTLR12", 0b10, 0b001, 0b0001, 0b1100, 0b000>;
  1042. def : RWSysReg<"TRCRSCTLR13", 0b10, 0b001, 0b0001, 0b1101, 0b000>;
  1043. def : RWSysReg<"TRCRSCTLR14", 0b10, 0b001, 0b0001, 0b1110, 0b000>;
  1044. def : RWSysReg<"TRCRSCTLR15", 0b10, 0b001, 0b0001, 0b1111, 0b000>;
  1045. def : RWSysReg<"TRCRSCTLR16", 0b10, 0b001, 0b0001, 0b0000, 0b001>;
  1046. def : RWSysReg<"TRCRSCTLR17", 0b10, 0b001, 0b0001, 0b0001, 0b001>;
  1047. def : RWSysReg<"TRCRSCTLR18", 0b10, 0b001, 0b0001, 0b0010, 0b001>;
  1048. def : RWSysReg<"TRCRSCTLR19", 0b10, 0b001, 0b0001, 0b0011, 0b001>;
  1049. def : RWSysReg<"TRCRSCTLR20", 0b10, 0b001, 0b0001, 0b0100, 0b001>;
  1050. def : RWSysReg<"TRCRSCTLR21", 0b10, 0b001, 0b0001, 0b0101, 0b001>;
  1051. def : RWSysReg<"TRCRSCTLR22", 0b10, 0b001, 0b0001, 0b0110, 0b001>;
  1052. def : RWSysReg<"TRCRSCTLR23", 0b10, 0b001, 0b0001, 0b0111, 0b001>;
  1053. def : RWSysReg<"TRCRSCTLR24", 0b10, 0b001, 0b0001, 0b1000, 0b001>;
  1054. def : RWSysReg<"TRCRSCTLR25", 0b10, 0b001, 0b0001, 0b1001, 0b001>;
  1055. def : RWSysReg<"TRCRSCTLR26", 0b10, 0b001, 0b0001, 0b1010, 0b001>;
  1056. def : RWSysReg<"TRCRSCTLR27", 0b10, 0b001, 0b0001, 0b1011, 0b001>;
  1057. def : RWSysReg<"TRCRSCTLR28", 0b10, 0b001, 0b0001, 0b1100, 0b001>;
  1058. def : RWSysReg<"TRCRSCTLR29", 0b10, 0b001, 0b0001, 0b1101, 0b001>;
  1059. def : RWSysReg<"TRCRSCTLR30", 0b10, 0b001, 0b0001, 0b1110, 0b001>;
  1060. def : RWSysReg<"TRCRSCTLR31", 0b10, 0b001, 0b0001, 0b1111, 0b001>;
  1061. def : RWSysReg<"TRCSSCCR0", 0b10, 0b001, 0b0001, 0b0000, 0b010>;
  1062. def : RWSysReg<"TRCSSCCR1", 0b10, 0b001, 0b0001, 0b0001, 0b010>;
  1063. def : RWSysReg<"TRCSSCCR2", 0b10, 0b001, 0b0001, 0b0010, 0b010>;
  1064. def : RWSysReg<"TRCSSCCR3", 0b10, 0b001, 0b0001, 0b0011, 0b010>;
  1065. def : RWSysReg<"TRCSSCCR4", 0b10, 0b001, 0b0001, 0b0100, 0b010>;
  1066. def : RWSysReg<"TRCSSCCR5", 0b10, 0b001, 0b0001, 0b0101, 0b010>;
  1067. def : RWSysReg<"TRCSSCCR6", 0b10, 0b001, 0b0001, 0b0110, 0b010>;
  1068. def : RWSysReg<"TRCSSCCR7", 0b10, 0b001, 0b0001, 0b0111, 0b010>;
  1069. def : RWSysReg<"TRCSSCSR0", 0b10, 0b001, 0b0001, 0b1000, 0b010>;
  1070. def : RWSysReg<"TRCSSCSR1", 0b10, 0b001, 0b0001, 0b1001, 0b010>;
  1071. def : RWSysReg<"TRCSSCSR2", 0b10, 0b001, 0b0001, 0b1010, 0b010>;
  1072. def : RWSysReg<"TRCSSCSR3", 0b10, 0b001, 0b0001, 0b1011, 0b010>;
  1073. def : RWSysReg<"TRCSSCSR4", 0b10, 0b001, 0b0001, 0b1100, 0b010>;
  1074. def : RWSysReg<"TRCSSCSR5", 0b10, 0b001, 0b0001, 0b1101, 0b010>;
  1075. def : RWSysReg<"TRCSSCSR6", 0b10, 0b001, 0b0001, 0b1110, 0b010>;
  1076. def : RWSysReg<"TRCSSCSR7", 0b10, 0b001, 0b0001, 0b1111, 0b010>;
  1077. def : RWSysReg<"TRCSSPCICR0", 0b10, 0b001, 0b0001, 0b0000, 0b011>;
  1078. def : RWSysReg<"TRCSSPCICR1", 0b10, 0b001, 0b0001, 0b0001, 0b011>;
  1079. def : RWSysReg<"TRCSSPCICR2", 0b10, 0b001, 0b0001, 0b0010, 0b011>;
  1080. def : RWSysReg<"TRCSSPCICR3", 0b10, 0b001, 0b0001, 0b0011, 0b011>;
  1081. def : RWSysReg<"TRCSSPCICR4", 0b10, 0b001, 0b0001, 0b0100, 0b011>;
  1082. def : RWSysReg<"TRCSSPCICR5", 0b10, 0b001, 0b0001, 0b0101, 0b011>;
  1083. def : RWSysReg<"TRCSSPCICR6", 0b10, 0b001, 0b0001, 0b0110, 0b011>;
  1084. def : RWSysReg<"TRCSSPCICR7", 0b10, 0b001, 0b0001, 0b0111, 0b011>;
  1085. def : RWSysReg<"TRCPDCR", 0b10, 0b001, 0b0001, 0b0100, 0b100>;
  1086. def : RWSysReg<"TRCACVR0", 0b10, 0b001, 0b0010, 0b0000, 0b000>;
  1087. def : RWSysReg<"TRCACVR1", 0b10, 0b001, 0b0010, 0b0010, 0b000>;
  1088. def : RWSysReg<"TRCACVR2", 0b10, 0b001, 0b0010, 0b0100, 0b000>;
  1089. def : RWSysReg<"TRCACVR3", 0b10, 0b001, 0b0010, 0b0110, 0b000>;
  1090. def : RWSysReg<"TRCACVR4", 0b10, 0b001, 0b0010, 0b1000, 0b000>;
  1091. def : RWSysReg<"TRCACVR5", 0b10, 0b001, 0b0010, 0b1010, 0b000>;
  1092. def : RWSysReg<"TRCACVR6", 0b10, 0b001, 0b0010, 0b1100, 0b000>;
  1093. def : RWSysReg<"TRCACVR7", 0b10, 0b001, 0b0010, 0b1110, 0b000>;
  1094. def : RWSysReg<"TRCACVR8", 0b10, 0b001, 0b0010, 0b0000, 0b001>;
  1095. def : RWSysReg<"TRCACVR9", 0b10, 0b001, 0b0010, 0b0010, 0b001>;
  1096. def : RWSysReg<"TRCACVR10", 0b10, 0b001, 0b0010, 0b0100, 0b001>;
  1097. def : RWSysReg<"TRCACVR11", 0b10, 0b001, 0b0010, 0b0110, 0b001>;
  1098. def : RWSysReg<"TRCACVR12", 0b10, 0b001, 0b0010, 0b1000, 0b001>;
  1099. def : RWSysReg<"TRCACVR13", 0b10, 0b001, 0b0010, 0b1010, 0b001>;
  1100. def : RWSysReg<"TRCACVR14", 0b10, 0b001, 0b0010, 0b1100, 0b001>;
  1101. def : RWSysReg<"TRCACVR15", 0b10, 0b001, 0b0010, 0b1110, 0b001>;
  1102. def : RWSysReg<"TRCACATR0", 0b10, 0b001, 0b0010, 0b0000, 0b010>;
  1103. def : RWSysReg<"TRCACATR1", 0b10, 0b001, 0b0010, 0b0010, 0b010>;
  1104. def : RWSysReg<"TRCACATR2", 0b10, 0b001, 0b0010, 0b0100, 0b010>;
  1105. def : RWSysReg<"TRCACATR3", 0b10, 0b001, 0b0010, 0b0110, 0b010>;
  1106. def : RWSysReg<"TRCACATR4", 0b10, 0b001, 0b0010, 0b1000, 0b010>;
  1107. def : RWSysReg<"TRCACATR5", 0b10, 0b001, 0b0010, 0b1010, 0b010>;
  1108. def : RWSysReg<"TRCACATR6", 0b10, 0b001, 0b0010, 0b1100, 0b010>;
  1109. def : RWSysReg<"TRCACATR7", 0b10, 0b001, 0b0010, 0b1110, 0b010>;
  1110. def : RWSysReg<"TRCACATR8", 0b10, 0b001, 0b0010, 0b0000, 0b011>;
  1111. def : RWSysReg<"TRCACATR9", 0b10, 0b001, 0b0010, 0b0010, 0b011>;
  1112. def : RWSysReg<"TRCACATR10", 0b10, 0b001, 0b0010, 0b0100, 0b011>;
  1113. def : RWSysReg<"TRCACATR11", 0b10, 0b001, 0b0010, 0b0110, 0b011>;
  1114. def : RWSysReg<"TRCACATR12", 0b10, 0b001, 0b0010, 0b1000, 0b011>;
  1115. def : RWSysReg<"TRCACATR13", 0b10, 0b001, 0b0010, 0b1010, 0b011>;
  1116. def : RWSysReg<"TRCACATR14", 0b10, 0b001, 0b0010, 0b1100, 0b011>;
  1117. def : RWSysReg<"TRCACATR15", 0b10, 0b001, 0b0010, 0b1110, 0b011>;
  1118. def : RWSysReg<"TRCDVCVR0", 0b10, 0b001, 0b0010, 0b0000, 0b100>;
  1119. def : RWSysReg<"TRCDVCVR1", 0b10, 0b001, 0b0010, 0b0100, 0b100>;
  1120. def : RWSysReg<"TRCDVCVR2", 0b10, 0b001, 0b0010, 0b1000, 0b100>;
  1121. def : RWSysReg<"TRCDVCVR3", 0b10, 0b001, 0b0010, 0b1100, 0b100>;
  1122. def : RWSysReg<"TRCDVCVR4", 0b10, 0b001, 0b0010, 0b0000, 0b101>;
  1123. def : RWSysReg<"TRCDVCVR5", 0b10, 0b001, 0b0010, 0b0100, 0b101>;
  1124. def : RWSysReg<"TRCDVCVR6", 0b10, 0b001, 0b0010, 0b1000, 0b101>;
  1125. def : RWSysReg<"TRCDVCVR7", 0b10, 0b001, 0b0010, 0b1100, 0b101>;
  1126. def : RWSysReg<"TRCDVCMR0", 0b10, 0b001, 0b0010, 0b0000, 0b110>;
  1127. def : RWSysReg<"TRCDVCMR1", 0b10, 0b001, 0b0010, 0b0100, 0b110>;
  1128. def : RWSysReg<"TRCDVCMR2", 0b10, 0b001, 0b0010, 0b1000, 0b110>;
  1129. def : RWSysReg<"TRCDVCMR3", 0b10, 0b001, 0b0010, 0b1100, 0b110>;
  1130. def : RWSysReg<"TRCDVCMR4", 0b10, 0b001, 0b0010, 0b0000, 0b111>;
  1131. def : RWSysReg<"TRCDVCMR5", 0b10, 0b001, 0b0010, 0b0100, 0b111>;
  1132. def : RWSysReg<"TRCDVCMR6", 0b10, 0b001, 0b0010, 0b1000, 0b111>;
  1133. def : RWSysReg<"TRCDVCMR7", 0b10, 0b001, 0b0010, 0b1100, 0b111>;
  1134. def : RWSysReg<"TRCCIDCVR0", 0b10, 0b001, 0b0011, 0b0000, 0b000>;
  1135. def : RWSysReg<"TRCCIDCVR1", 0b10, 0b001, 0b0011, 0b0010, 0b000>;
  1136. def : RWSysReg<"TRCCIDCVR2", 0b10, 0b001, 0b0011, 0b0100, 0b000>;
  1137. def : RWSysReg<"TRCCIDCVR3", 0b10, 0b001, 0b0011, 0b0110, 0b000>;
  1138. def : RWSysReg<"TRCCIDCVR4", 0b10, 0b001, 0b0011, 0b1000, 0b000>;
  1139. def : RWSysReg<"TRCCIDCVR5", 0b10, 0b001, 0b0011, 0b1010, 0b000>;
  1140. def : RWSysReg<"TRCCIDCVR6", 0b10, 0b001, 0b0011, 0b1100, 0b000>;
  1141. def : RWSysReg<"TRCCIDCVR7", 0b10, 0b001, 0b0011, 0b1110, 0b000>;
  1142. def : RWSysReg<"TRCVMIDCVR0", 0b10, 0b001, 0b0011, 0b0000, 0b001>;
  1143. def : RWSysReg<"TRCVMIDCVR1", 0b10, 0b001, 0b0011, 0b0010, 0b001>;
  1144. def : RWSysReg<"TRCVMIDCVR2", 0b10, 0b001, 0b0011, 0b0100, 0b001>;
  1145. def : RWSysReg<"TRCVMIDCVR3", 0b10, 0b001, 0b0011, 0b0110, 0b001>;
  1146. def : RWSysReg<"TRCVMIDCVR4", 0b10, 0b001, 0b0011, 0b1000, 0b001>;
  1147. def : RWSysReg<"TRCVMIDCVR5", 0b10, 0b001, 0b0011, 0b1010, 0b001>;
  1148. def : RWSysReg<"TRCVMIDCVR6", 0b10, 0b001, 0b0011, 0b1100, 0b001>;
  1149. def : RWSysReg<"TRCVMIDCVR7", 0b10, 0b001, 0b0011, 0b1110, 0b001>;
  1150. def : RWSysReg<"TRCCIDCCTLR0", 0b10, 0b001, 0b0011, 0b0000, 0b010>;
  1151. def : RWSysReg<"TRCCIDCCTLR1", 0b10, 0b001, 0b0011, 0b0001, 0b010>;
  1152. def : RWSysReg<"TRCVMIDCCTLR0", 0b10, 0b001, 0b0011, 0b0010, 0b010>;
  1153. def : RWSysReg<"TRCVMIDCCTLR1", 0b10, 0b001, 0b0011, 0b0011, 0b010>;
  1154. def : RWSysReg<"TRCITCTRL", 0b10, 0b001, 0b0111, 0b0000, 0b100>;
  1155. def : RWSysReg<"TRCCLAIMSET", 0b10, 0b001, 0b0111, 0b1000, 0b110>;
  1156. def : RWSysReg<"TRCCLAIMCLR", 0b10, 0b001, 0b0111, 0b1001, 0b110>;
  1157. // GICv3 registers
  1158. // Op0 Op1 CRn CRm Op2
  1159. def : RWSysReg<"ICC_BPR1_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b011>;
  1160. def : RWSysReg<"ICC_BPR0_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b011>;
  1161. def : RWSysReg<"ICC_PMR_EL1", 0b11, 0b000, 0b0100, 0b0110, 0b000>;
  1162. def : RWSysReg<"ICC_CTLR_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b100>;
  1163. def : RWSysReg<"ICC_CTLR_EL3", 0b11, 0b110, 0b1100, 0b1100, 0b100>;
  1164. def : RWSysReg<"ICC_SRE_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b101>;
  1165. def : RWSysReg<"ICC_SRE_EL2", 0b11, 0b100, 0b1100, 0b1001, 0b101>;
  1166. def : RWSysReg<"ICC_SRE_EL3", 0b11, 0b110, 0b1100, 0b1100, 0b101>;
  1167. def : RWSysReg<"ICC_IGRPEN0_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b110>;
  1168. def : RWSysReg<"ICC_IGRPEN1_EL1", 0b11, 0b000, 0b1100, 0b1100, 0b111>;
  1169. def : RWSysReg<"ICC_IGRPEN1_EL3", 0b11, 0b110, 0b1100, 0b1100, 0b111>;
  1170. def : RWSysReg<"ICC_AP0R0_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b100>;
  1171. def : RWSysReg<"ICC_AP0R1_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b101>;
  1172. def : RWSysReg<"ICC_AP0R2_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b110>;
  1173. def : RWSysReg<"ICC_AP0R3_EL1", 0b11, 0b000, 0b1100, 0b1000, 0b111>;
  1174. def : RWSysReg<"ICC_AP1R0_EL1", 0b11, 0b000, 0b1100, 0b1001, 0b000>;
  1175. def : RWSysReg<"ICC_AP1R1_EL1", 0b11, 0b000, 0b1100, 0b1001, 0b001>;
  1176. def : RWSysReg<"ICC_AP1R2_EL1", 0b11, 0b000, 0b1100, 0b1001, 0b010>;
  1177. def : RWSysReg<"ICC_AP1R3_EL1", 0b11, 0b000, 0b1100, 0b1001, 0b011>;
  1178. def : RWSysReg<"ICH_AP0R0_EL2", 0b11, 0b100, 0b1100, 0b1000, 0b000>;
  1179. def : RWSysReg<"ICH_AP0R1_EL2", 0b11, 0b100, 0b1100, 0b1000, 0b001>;
  1180. def : RWSysReg<"ICH_AP0R2_EL2", 0b11, 0b100, 0b1100, 0b1000, 0b010>;
  1181. def : RWSysReg<"ICH_AP0R3_EL2", 0b11, 0b100, 0b1100, 0b1000, 0b011>;
  1182. def : RWSysReg<"ICH_AP1R0_EL2", 0b11, 0b100, 0b1100, 0b1001, 0b000>;
  1183. def : RWSysReg<"ICH_AP1R1_EL2", 0b11, 0b100, 0b1100, 0b1001, 0b001>;
  1184. def : RWSysReg<"ICH_AP1R2_EL2", 0b11, 0b100, 0b1100, 0b1001, 0b010>;
  1185. def : RWSysReg<"ICH_AP1R3_EL2", 0b11, 0b100, 0b1100, 0b1001, 0b011>;
  1186. def : RWSysReg<"ICH_HCR_EL2", 0b11, 0b100, 0b1100, 0b1011, 0b000>;
  1187. def : ROSysReg<"ICH_MISR_EL2", 0b11, 0b100, 0b1100, 0b1011, 0b010>;
  1188. def : RWSysReg<"ICH_VMCR_EL2", 0b11, 0b100, 0b1100, 0b1011, 0b111>;
  1189. def : RWSysReg<"ICH_LR0_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b000>;
  1190. def : RWSysReg<"ICH_LR1_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b001>;
  1191. def : RWSysReg<"ICH_LR2_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b010>;
  1192. def : RWSysReg<"ICH_LR3_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b011>;
  1193. def : RWSysReg<"ICH_LR4_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b100>;
  1194. def : RWSysReg<"ICH_LR5_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b101>;
  1195. def : RWSysReg<"ICH_LR6_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b110>;
  1196. def : RWSysReg<"ICH_LR7_EL2", 0b11, 0b100, 0b1100, 0b1100, 0b111>;
  1197. def : RWSysReg<"ICH_LR8_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b000>;
  1198. def : RWSysReg<"ICH_LR9_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b001>;
  1199. def : RWSysReg<"ICH_LR10_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b010>;
  1200. def : RWSysReg<"ICH_LR11_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b011>;
  1201. def : RWSysReg<"ICH_LR12_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b100>;
  1202. def : RWSysReg<"ICH_LR13_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b101>;
  1203. def : RWSysReg<"ICH_LR14_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b110>;
  1204. def : RWSysReg<"ICH_LR15_EL2", 0b11, 0b100, 0b1100, 0b1101, 0b111>;
  1205. // v8r system registers
  1206. let Requires = [{ {AArch64::HasV8_0rOps} }] in {
  1207. //Virtualization System Control Register
  1208. // Op0 Op1 CRn CRm Op2
  1209. def : RWSysReg<"VSCTLR_EL2", 0b11, 0b100, 0b0010, 0b0000, 0b000> {
  1210. let AltName = "TTBR0_EL2";
  1211. }
  1212. //MPU Type Register
  1213. // Op0 Op1 CRn CRm Op2
  1214. def : RWSysReg<"MPUIR_EL1", 0b11, 0b000, 0b0000, 0b0000, 0b100>;
  1215. def : RWSysReg<"MPUIR_EL2", 0b11, 0b100, 0b0000, 0b0000, 0b100>;
  1216. //Protection Region Enable Register
  1217. // Op0 Op1 CRn CRm Op2
  1218. def : RWSysReg<"PRENR_EL1", 0b11, 0b000, 0b0110, 0b0001, 0b001>;
  1219. def : RWSysReg<"PRENR_EL2", 0b11, 0b100, 0b0110, 0b0001, 0b001>;
  1220. //Protection Region Selection Register
  1221. // Op0 Op1 CRn CRm Op2
  1222. def : RWSysReg<"PRSELR_EL1", 0b11, 0b000, 0b0110, 0b0010, 0b001>;
  1223. def : RWSysReg<"PRSELR_EL2", 0b11, 0b100, 0b0110, 0b0010, 0b001>;
  1224. //Protection Region Base Address Register
  1225. // Op0 Op1 CRn CRm Op2
  1226. def : RWSysReg<"PRBAR_EL1", 0b11, 0b000, 0b0110, 0b1000, 0b000>;
  1227. def : RWSysReg<"PRBAR_EL2", 0b11, 0b100, 0b0110, 0b1000, 0b000>;
  1228. //Protection Region Limit Address Register
  1229. // Op0 Op1 CRn CRm Op2
  1230. def : RWSysReg<"PRLAR_EL1", 0b11, 0b000, 0b0110, 0b1000, 0b001>;
  1231. def : RWSysReg<"PRLAR_EL2", 0b11, 0b100, 0b0110, 0b1000, 0b001>;
  1232. foreach n = 1-15 in {
  1233. foreach x = 1-2 in {
  1234. //Direct acces to Protection Region Base Address Register for n th MPU region
  1235. def : RWSysReg<!strconcat("PRBAR"#n, "_EL"#x),
  1236. 0b11, 0b000, 0b0110, 0b1000, 0b000>{
  1237. let Encoding{5-2} = n;
  1238. let Encoding{13} = !add(x,-1);
  1239. }
  1240. def : RWSysReg<!strconcat("PRLAR"#n, "_EL"#x),
  1241. 0b11, 0b000, 0b0110, 0b1000, 0b001>{
  1242. let Encoding{5-2} = n;
  1243. let Encoding{13} = !add(x,-1);
  1244. }
  1245. } //foreach x = 1-2 in
  1246. } //foreach n = 1-15 in
  1247. } //let Requires = [{ {AArch64::HasV8_0rOps} }] in
  1248. // v8.1a "Privileged Access Never" extension-specific system registers
  1249. let Requires = [{ {AArch64::FeaturePAN} }] in
  1250. def : RWSysReg<"PAN", 0b11, 0b000, 0b0100, 0b0010, 0b011>;
  1251. // v8.1a "Limited Ordering Regions" extension-specific system registers
  1252. // Op0 Op1 CRn CRm Op2
  1253. let Requires = [{ {AArch64::FeatureLOR} }] in {
  1254. def : RWSysReg<"LORSA_EL1", 0b11, 0b000, 0b1010, 0b0100, 0b000>;
  1255. def : RWSysReg<"LOREA_EL1", 0b11, 0b000, 0b1010, 0b0100, 0b001>;
  1256. def : RWSysReg<"LORN_EL1", 0b11, 0b000, 0b1010, 0b0100, 0b010>;
  1257. def : RWSysReg<"LORC_EL1", 0b11, 0b000, 0b1010, 0b0100, 0b011>;
  1258. }
  1259. // v8.1a "Virtualization Host extensions" system registers
  1260. // Op0 Op1 CRn CRm Op2
  1261. let Requires = [{ {AArch64::FeatureVH} }] in {
  1262. def : RWSysReg<"TTBR1_EL2", 0b11, 0b100, 0b0010, 0b0000, 0b001>;
  1263. def : RWSysReg<"CNTHV_TVAL_EL2", 0b11, 0b100, 0b1110, 0b0011, 0b000>;
  1264. def : RWSysReg<"CNTHV_CVAL_EL2", 0b11, 0b100, 0b1110, 0b0011, 0b010>;
  1265. def : RWSysReg<"CNTHV_CTL_EL2", 0b11, 0b100, 0b1110, 0b0011, 0b001>;
  1266. def : RWSysReg<"SCTLR_EL12", 0b11, 0b101, 0b0001, 0b0000, 0b000>;
  1267. def : RWSysReg<"CPACR_EL12", 0b11, 0b101, 0b0001, 0b0000, 0b010>;
  1268. def : RWSysReg<"TTBR0_EL12", 0b11, 0b101, 0b0010, 0b0000, 0b000>;
  1269. def : RWSysReg<"TTBR1_EL12", 0b11, 0b101, 0b0010, 0b0000, 0b001>;
  1270. def : RWSysReg<"TCR_EL12", 0b11, 0b101, 0b0010, 0b0000, 0b010>;
  1271. def : RWSysReg<"AFSR0_EL12", 0b11, 0b101, 0b0101, 0b0001, 0b000>;
  1272. def : RWSysReg<"AFSR1_EL12", 0b11, 0b101, 0b0101, 0b0001, 0b001>;
  1273. def : RWSysReg<"ESR_EL12", 0b11, 0b101, 0b0101, 0b0010, 0b000>;
  1274. def : RWSysReg<"FAR_EL12", 0b11, 0b101, 0b0110, 0b0000, 0b000>;
  1275. def : RWSysReg<"MAIR_EL12", 0b11, 0b101, 0b1010, 0b0010, 0b000>;
  1276. def : RWSysReg<"AMAIR_EL12", 0b11, 0b101, 0b1010, 0b0011, 0b000>;
  1277. def : RWSysReg<"VBAR_EL12", 0b11, 0b101, 0b1100, 0b0000, 0b000>;
  1278. def : RWSysReg<"CONTEXTIDR_EL12", 0b11, 0b101, 0b1101, 0b0000, 0b001>;
  1279. def : RWSysReg<"CNTKCTL_EL12", 0b11, 0b101, 0b1110, 0b0001, 0b000>;
  1280. def : RWSysReg<"CNTP_TVAL_EL02", 0b11, 0b101, 0b1110, 0b0010, 0b000>;
  1281. def : RWSysReg<"CNTP_CTL_EL02", 0b11, 0b101, 0b1110, 0b0010, 0b001>;
  1282. def : RWSysReg<"CNTP_CVAL_EL02", 0b11, 0b101, 0b1110, 0b0010, 0b010>;
  1283. def : RWSysReg<"CNTV_TVAL_EL02", 0b11, 0b101, 0b1110, 0b0011, 0b000>;
  1284. def : RWSysReg<"CNTV_CTL_EL02", 0b11, 0b101, 0b1110, 0b0011, 0b001>;
  1285. def : RWSysReg<"CNTV_CVAL_EL02", 0b11, 0b101, 0b1110, 0b0011, 0b010>;
  1286. def : RWSysReg<"SPSR_EL12", 0b11, 0b101, 0b0100, 0b0000, 0b000>;
  1287. def : RWSysReg<"ELR_EL12", 0b11, 0b101, 0b0100, 0b0000, 0b001>;
  1288. let Requires = [{ {AArch64::FeatureCONTEXTIDREL2} }] in {
  1289. def : RWSysReg<"CONTEXTIDR_EL2", 0b11, 0b100, 0b1101, 0b0000, 0b001>;
  1290. }
  1291. }
  1292. // v8.2a registers
  1293. // Op0 Op1 CRn CRm Op2
  1294. let Requires = [{ {AArch64::FeaturePsUAO} }] in
  1295. def : RWSysReg<"UAO", 0b11, 0b000, 0b0100, 0b0010, 0b100>;
  1296. // v8.2a "Statistical Profiling extension" registers
  1297. // Op0 Op1 CRn CRm Op2
  1298. let Requires = [{ {AArch64::FeatureSPE} }] in {
  1299. def : RWSysReg<"PMBLIMITR_EL1", 0b11, 0b000, 0b1001, 0b1010, 0b000>;
  1300. def : RWSysReg<"PMBPTR_EL1", 0b11, 0b000, 0b1001, 0b1010, 0b001>;
  1301. def : RWSysReg<"PMBSR_EL1", 0b11, 0b000, 0b1001, 0b1010, 0b011>;
  1302. def : ROSysReg<"PMBIDR_EL1", 0b11, 0b000, 0b1001, 0b1010, 0b111>;
  1303. def : RWSysReg<"PMSCR_EL2", 0b11, 0b100, 0b1001, 0b1001, 0b000>;
  1304. def : RWSysReg<"PMSCR_EL12", 0b11, 0b101, 0b1001, 0b1001, 0b000>;
  1305. def : RWSysReg<"PMSCR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b000>;
  1306. def : RWSysReg<"PMSICR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b010>;
  1307. def : RWSysReg<"PMSIRR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b011>;
  1308. def : RWSysReg<"PMSFCR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b100>;
  1309. def : RWSysReg<"PMSEVFR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b101>;
  1310. def : RWSysReg<"PMSLATFR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b110>;
  1311. def : ROSysReg<"PMSIDR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b111>;
  1312. }
  1313. // v8.2a "RAS extension" registers
  1314. // Op0 Op1 CRn CRm Op2
  1315. let Requires = [{ {AArch64::FeatureRAS} }] in {
  1316. def : RWSysReg<"ERRSELR_EL1", 0b11, 0b000, 0b0101, 0b0011, 0b001>;
  1317. def : RWSysReg<"ERXCTLR_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b001>;
  1318. def : RWSysReg<"ERXSTATUS_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b010>;
  1319. def : RWSysReg<"ERXADDR_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b011>;
  1320. def : RWSysReg<"ERXMISC0_EL1", 0b11, 0b000, 0b0101, 0b0101, 0b000>;
  1321. def : RWSysReg<"ERXMISC1_EL1", 0b11, 0b000, 0b0101, 0b0101, 0b001>;
  1322. def : RWSysReg<"DISR_EL1", 0b11, 0b000, 0b1100, 0b0001, 0b001>;
  1323. def : RWSysReg<"VDISR_EL2", 0b11, 0b100, 0b1100, 0b0001, 0b001>;
  1324. def : RWSysReg<"VSESR_EL2", 0b11, 0b100, 0b0101, 0b0010, 0b011>;
  1325. }
  1326. // v8.3a "Pointer authentication extension" registers
  1327. // Op0 Op1 CRn CRm Op2
  1328. let Requires = [{ {AArch64::FeaturePAuth} }] in {
  1329. def : RWSysReg<"APIAKeyLo_EL1", 0b11, 0b000, 0b0010, 0b0001, 0b000>;
  1330. def : RWSysReg<"APIAKeyHi_EL1", 0b11, 0b000, 0b0010, 0b0001, 0b001>;
  1331. def : RWSysReg<"APIBKeyLo_EL1", 0b11, 0b000, 0b0010, 0b0001, 0b010>;
  1332. def : RWSysReg<"APIBKeyHi_EL1", 0b11, 0b000, 0b0010, 0b0001, 0b011>;
  1333. def : RWSysReg<"APDAKeyLo_EL1", 0b11, 0b000, 0b0010, 0b0010, 0b000>;
  1334. def : RWSysReg<"APDAKeyHi_EL1", 0b11, 0b000, 0b0010, 0b0010, 0b001>;
  1335. def : RWSysReg<"APDBKeyLo_EL1", 0b11, 0b000, 0b0010, 0b0010, 0b010>;
  1336. def : RWSysReg<"APDBKeyHi_EL1", 0b11, 0b000, 0b0010, 0b0010, 0b011>;
  1337. def : RWSysReg<"APGAKeyLo_EL1", 0b11, 0b000, 0b0010, 0b0011, 0b000>;
  1338. def : RWSysReg<"APGAKeyHi_EL1", 0b11, 0b000, 0b0010, 0b0011, 0b001>;
  1339. }
  1340. // v8.4 "Secure Exception Level 2 extension"
  1341. let Requires = [{ {AArch64::FeatureSEL2} }] in {
  1342. // v8.4a "Virtualization secure second stage translation" registers
  1343. // Op0 Op1 CRn CRm Op2
  1344. def : RWSysReg<"VSTCR_EL2" , 0b11, 0b100, 0b0010, 0b0110, 0b010>;
  1345. def : RWSysReg<"VSTTBR_EL2", 0b11, 0b100, 0b0010, 0b0110, 0b000> {
  1346. let Requires = [{ {AArch64::HasV8_0aOps} }];
  1347. }
  1348. // v8.4a "Virtualization timer" registers
  1349. // Op0 Op1 CRn CRm Op2
  1350. def : RWSysReg<"CNTHVS_TVAL_EL2", 0b11, 0b100, 0b1110, 0b0100, 0b000>;
  1351. def : RWSysReg<"CNTHVS_CVAL_EL2", 0b11, 0b100, 0b1110, 0b0100, 0b010>;
  1352. def : RWSysReg<"CNTHVS_CTL_EL2", 0b11, 0b100, 0b1110, 0b0100, 0b001>;
  1353. def : RWSysReg<"CNTHPS_TVAL_EL2", 0b11, 0b100, 0b1110, 0b0101, 0b000>;
  1354. def : RWSysReg<"CNTHPS_CVAL_EL2", 0b11, 0b100, 0b1110, 0b0101, 0b010>;
  1355. def : RWSysReg<"CNTHPS_CTL_EL2", 0b11, 0b100, 0b1110, 0b0101, 0b001>;
  1356. // v8.4a "Virtualization debug state" registers
  1357. // Op0 Op1 CRn CRm Op2
  1358. def : RWSysReg<"SDER32_EL2", 0b11, 0b100, 0b0001, 0b0011, 0b001>;
  1359. } // FeatureSEL2
  1360. // v8.4a RAS registers
  1361. // Op0 Op1 CRn CRm Op2
  1362. def : RWSysReg<"ERXPFGCTL_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b101>;
  1363. def : RWSysReg<"ERXPFGCDN_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b110>;
  1364. def : RWSysReg<"ERXMISC2_EL1", 0b11, 0b000, 0b0101, 0b0101, 0b010>;
  1365. def : RWSysReg<"ERXMISC3_EL1", 0b11, 0b000, 0b0101, 0b0101, 0b011>;
  1366. def : ROSysReg<"ERXPFGF_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b100>;
  1367. // v8.4a MPAM registers
  1368. // Op0 Op1 CRn CRm Op2
  1369. let Requires = [{ {AArch64::FeatureMPAM} }] in {
  1370. def : RWSysReg<"MPAM0_EL1", 0b11, 0b000, 0b1010, 0b0101, 0b001>;
  1371. def : RWSysReg<"MPAM1_EL1", 0b11, 0b000, 0b1010, 0b0101, 0b000>;
  1372. def : RWSysReg<"MPAM2_EL2", 0b11, 0b100, 0b1010, 0b0101, 0b000>;
  1373. def : RWSysReg<"MPAM3_EL3", 0b11, 0b110, 0b1010, 0b0101, 0b000>;
  1374. def : RWSysReg<"MPAM1_EL12", 0b11, 0b101, 0b1010, 0b0101, 0b000>;
  1375. def : RWSysReg<"MPAMHCR_EL2", 0b11, 0b100, 0b1010, 0b0100, 0b000>;
  1376. def : RWSysReg<"MPAMVPMV_EL2", 0b11, 0b100, 0b1010, 0b0100, 0b001>;
  1377. def : RWSysReg<"MPAMVPM0_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b000>;
  1378. def : RWSysReg<"MPAMVPM1_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b001>;
  1379. def : RWSysReg<"MPAMVPM2_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b010>;
  1380. def : RWSysReg<"MPAMVPM3_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b011>;
  1381. def : RWSysReg<"MPAMVPM4_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b100>;
  1382. def : RWSysReg<"MPAMVPM5_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b101>;
  1383. def : RWSysReg<"MPAMVPM6_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b110>;
  1384. def : RWSysReg<"MPAMVPM7_EL2", 0b11, 0b100, 0b1010, 0b0110, 0b111>;
  1385. def : ROSysReg<"MPAMIDR_EL1", 0b11, 0b000, 0b1010, 0b0100, 0b100>;
  1386. } //FeatureMPAM
  1387. // v8.4a Activity Monitor registers
  1388. // Op0 Op1 CRn CRm Op2
  1389. let Requires = [{ {AArch64::FeatureAM} }] in {
  1390. def : RWSysReg<"AMCR_EL0", 0b11, 0b011, 0b1101, 0b0010, 0b000>;
  1391. def : ROSysReg<"AMCFGR_EL0", 0b11, 0b011, 0b1101, 0b0010, 0b001>;
  1392. def : ROSysReg<"AMCGCR_EL0", 0b11, 0b011, 0b1101, 0b0010, 0b010>;
  1393. def : RWSysReg<"AMUSERENR_EL0", 0b11, 0b011, 0b1101, 0b0010, 0b011>;
  1394. def : RWSysReg<"AMCNTENCLR0_EL0", 0b11, 0b011, 0b1101, 0b0010, 0b100>;
  1395. def : RWSysReg<"AMCNTENSET0_EL0", 0b11, 0b011, 0b1101, 0b0010, 0b101>;
  1396. def : RWSysReg<"AMEVCNTR00_EL0", 0b11, 0b011, 0b1101, 0b0100, 0b000>;
  1397. def : RWSysReg<"AMEVCNTR01_EL0", 0b11, 0b011, 0b1101, 0b0100, 0b001>;
  1398. def : RWSysReg<"AMEVCNTR02_EL0", 0b11, 0b011, 0b1101, 0b0100, 0b010>;
  1399. def : RWSysReg<"AMEVCNTR03_EL0", 0b11, 0b011, 0b1101, 0b0100, 0b011>;
  1400. def : ROSysReg<"AMEVTYPER00_EL0", 0b11, 0b011, 0b1101, 0b0110, 0b000>;
  1401. def : ROSysReg<"AMEVTYPER01_EL0", 0b11, 0b011, 0b1101, 0b0110, 0b001>;
  1402. def : ROSysReg<"AMEVTYPER02_EL0", 0b11, 0b011, 0b1101, 0b0110, 0b010>;
  1403. def : ROSysReg<"AMEVTYPER03_EL0", 0b11, 0b011, 0b1101, 0b0110, 0b011>;
  1404. def : RWSysReg<"AMCNTENCLR1_EL0", 0b11, 0b011, 0b1101, 0b0011, 0b000>;
  1405. def : RWSysReg<"AMCNTENSET1_EL0", 0b11, 0b011, 0b1101, 0b0011, 0b001>;
  1406. def : RWSysReg<"AMEVCNTR10_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b000>;
  1407. def : RWSysReg<"AMEVCNTR11_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b001>;
  1408. def : RWSysReg<"AMEVCNTR12_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b010>;
  1409. def : RWSysReg<"AMEVCNTR13_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b011>;
  1410. def : RWSysReg<"AMEVCNTR14_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b100>;
  1411. def : RWSysReg<"AMEVCNTR15_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b101>;
  1412. def : RWSysReg<"AMEVCNTR16_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b110>;
  1413. def : RWSysReg<"AMEVCNTR17_EL0", 0b11, 0b011, 0b1101, 0b1100, 0b111>;
  1414. def : RWSysReg<"AMEVCNTR18_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b000>;
  1415. def : RWSysReg<"AMEVCNTR19_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b001>;
  1416. def : RWSysReg<"AMEVCNTR110_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b010>;
  1417. def : RWSysReg<"AMEVCNTR111_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b011>;
  1418. def : RWSysReg<"AMEVCNTR112_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b100>;
  1419. def : RWSysReg<"AMEVCNTR113_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b101>;
  1420. def : RWSysReg<"AMEVCNTR114_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b110>;
  1421. def : RWSysReg<"AMEVCNTR115_EL0", 0b11, 0b011, 0b1101, 0b1101, 0b111>;
  1422. def : RWSysReg<"AMEVTYPER10_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b000>;
  1423. def : RWSysReg<"AMEVTYPER11_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b001>;
  1424. def : RWSysReg<"AMEVTYPER12_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b010>;
  1425. def : RWSysReg<"AMEVTYPER13_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b011>;
  1426. def : RWSysReg<"AMEVTYPER14_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b100>;
  1427. def : RWSysReg<"AMEVTYPER15_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b101>;
  1428. def : RWSysReg<"AMEVTYPER16_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b110>;
  1429. def : RWSysReg<"AMEVTYPER17_EL0", 0b11, 0b011, 0b1101, 0b1110, 0b111>;
  1430. def : RWSysReg<"AMEVTYPER18_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b000>;
  1431. def : RWSysReg<"AMEVTYPER19_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b001>;
  1432. def : RWSysReg<"AMEVTYPER110_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b010>;
  1433. def : RWSysReg<"AMEVTYPER111_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b011>;
  1434. def : RWSysReg<"AMEVTYPER112_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b100>;
  1435. def : RWSysReg<"AMEVTYPER113_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b101>;
  1436. def : RWSysReg<"AMEVTYPER114_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b110>;
  1437. def : RWSysReg<"AMEVTYPER115_EL0", 0b11, 0b011, 0b1101, 0b1111, 0b111>;
  1438. } //FeatureAM
  1439. // v8.4a Trace Extension registers
  1440. //
  1441. // Please note that the 8.4 spec also defines these registers:
  1442. // TRCIDR1, ID_DFR0_EL1, ID_AA64DFR0_EL1, MDSCR_EL1, MDCR_EL2, and MDCR_EL3,
  1443. // but they are already defined above.
  1444. //
  1445. // Op0 Op1 CRn CRm Op2
  1446. let Requires = [{ {AArch64::FeatureTRACEV8_4} }] in {
  1447. def : RWSysReg<"TRFCR_EL1", 0b11, 0b000, 0b0001, 0b0010, 0b001>;
  1448. def : RWSysReg<"TRFCR_EL2", 0b11, 0b100, 0b0001, 0b0010, 0b001>;
  1449. def : RWSysReg<"TRFCR_EL12", 0b11, 0b101, 0b0001, 0b0010, 0b001>;
  1450. } //FeatureTRACEV8_4
  1451. // v8.4a Timing insensitivity of data processing instructions
  1452. // DIT: Data Independent Timing instructions
  1453. // Op0 Op1 CRn CRm Op2
  1454. let Requires = [{ {AArch64::FeatureDIT} }] in {
  1455. def : RWSysReg<"DIT", 0b11, 0b011, 0b0100, 0b0010, 0b101>;
  1456. } //FeatureDIT
  1457. // v8.4a Enhanced Support for Nested Virtualization
  1458. // Op0 Op1 CRn CRm Op2
  1459. let Requires = [{ {AArch64::FeatureNV} }] in {
  1460. def : RWSysReg<"VNCR_EL2", 0b11, 0b100, 0b0010, 0b0010, 0b000>;
  1461. } //FeatureNV
  1462. // SVE control registers
  1463. // Op0 Op1 CRn CRm Op2
  1464. let Requires = [{ {AArch64::FeatureSVE} }] in {
  1465. def : RWSysReg<"ZCR_EL1", 0b11, 0b000, 0b0001, 0b0010, 0b000>;
  1466. def : RWSysReg<"ZCR_EL2", 0b11, 0b100, 0b0001, 0b0010, 0b000>;
  1467. def : RWSysReg<"ZCR_EL3", 0b11, 0b110, 0b0001, 0b0010, 0b000>;
  1468. def : RWSysReg<"ZCR_EL12", 0b11, 0b101, 0b0001, 0b0010, 0b000>;
  1469. }
  1470. // V8.5a Spectre mitigation SSBS register
  1471. // Op0 Op1 CRn CRm Op2
  1472. let Requires = [{ {AArch64::FeatureSSBS} }] in
  1473. def : RWSysReg<"SSBS", 0b11, 0b011, 0b0100, 0b0010, 0b110>;
  1474. // v8.5a Memory Tagging Extension
  1475. // Op0 Op1 CRn CRm Op2
  1476. let Requires = [{ {AArch64::FeatureMTE} }] in {
  1477. def : RWSysReg<"TCO", 0b11, 0b011, 0b0100, 0b0010, 0b111>;
  1478. def : RWSysReg<"GCR_EL1", 0b11, 0b000, 0b0001, 0b0000, 0b110>;
  1479. def : RWSysReg<"RGSR_EL1", 0b11, 0b000, 0b0001, 0b0000, 0b101>;
  1480. def : RWSysReg<"TFSR_EL1", 0b11, 0b000, 0b0101, 0b0110, 0b000>;
  1481. def : RWSysReg<"TFSR_EL2", 0b11, 0b100, 0b0101, 0b0110, 0b000>;
  1482. def : RWSysReg<"TFSR_EL3", 0b11, 0b110, 0b0101, 0b0110, 0b000>;
  1483. def : RWSysReg<"TFSR_EL12", 0b11, 0b101, 0b0101, 0b0110, 0b000>;
  1484. def : RWSysReg<"TFSRE0_EL1", 0b11, 0b000, 0b0101, 0b0110, 0b001>;
  1485. def : ROSysReg<"GMID_EL1", 0b11, 0b001, 0b0000, 0b0000, 0b100>;
  1486. } // HasMTE
  1487. // Embedded Trace Extension R/W System registers
  1488. let Requires = [{ {AArch64::FeatureETE} }] in {
  1489. // Name Op0 Op1 CRn CRm Op2
  1490. def : RWSysReg<"TRCRSR", 0b10, 0b001, 0b0000, 0b1010, 0b000>;
  1491. // TRCEXTINSELR0 has the same encoding as ETM TRCEXTINSELR
  1492. def : RWSysReg<"TRCEXTINSELR0", 0b10, 0b001, 0b0000, 0b1000, 0b100>;
  1493. def : RWSysReg<"TRCEXTINSELR1", 0b10, 0b001, 0b0000, 0b1001, 0b100>;
  1494. def : RWSysReg<"TRCEXTINSELR2", 0b10, 0b001, 0b0000, 0b1010, 0b100>;
  1495. def : RWSysReg<"TRCEXTINSELR3", 0b10, 0b001, 0b0000, 0b1011, 0b100>;
  1496. } // FeatureETE
  1497. // Trace Buffer Extension System registers
  1498. let Requires = [{ {AArch64::FeatureTRBE} }] in {
  1499. // Name Op0 Op1 CRn CRm Op2
  1500. def : RWSysReg<"TRBLIMITR_EL1", 0b11, 0b000, 0b1001, 0b1011, 0b000>;
  1501. def : RWSysReg<"TRBPTR_EL1", 0b11, 0b000, 0b1001, 0b1011, 0b001>;
  1502. def : RWSysReg<"TRBBASER_EL1", 0b11, 0b000, 0b1001, 0b1011, 0b010>;
  1503. def : RWSysReg<"TRBSR_EL1", 0b11, 0b000, 0b1001, 0b1011, 0b011>;
  1504. def : RWSysReg<"TRBMAR_EL1", 0b11, 0b000, 0b1001, 0b1011, 0b100>;
  1505. def : RWSysReg<"TRBTRG_EL1", 0b11, 0b000, 0b1001, 0b1011, 0b110>;
  1506. def : ROSysReg<"TRBIDR_EL1", 0b11, 0b000, 0b1001, 0b1011, 0b111>;
  1507. } // FeatureTRBE
  1508. // v8.6a Activity Monitors Virtualization Support
  1509. let Requires = [{ {AArch64::FeatureAMVS} }] in {
  1510. // Name Op0 Op1 CRn CRm Op2
  1511. def : ROSysReg<"AMCG1IDR_EL0", 0b11, 0b011, 0b1101, 0b0010, 0b110>;
  1512. foreach n = 0-15 in {
  1513. foreach x = 0-1 in {
  1514. def : RWSysReg<"AMEVCNTVOFF"#x#n#"_EL2",
  1515. 0b11, 0b100, 0b1101, 0b1000, 0b000>{
  1516. let Encoding{4} = x;
  1517. let Encoding{3-0} = n;
  1518. }
  1519. }
  1520. }
  1521. }
  1522. // v8.6a Fine Grained Virtualization Traps
  1523. // Op0 Op1 CRn CRm Op2
  1524. let Requires = [{ {AArch64::FeatureFineGrainedTraps} }] in {
  1525. def : RWSysReg<"HFGRTR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b100>;
  1526. def : RWSysReg<"HFGWTR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b101>;
  1527. def : RWSysReg<"HFGITR_EL2", 0b11, 0b100, 0b0001, 0b0001, 0b110>;
  1528. def : RWSysReg<"HDFGRTR_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b100>;
  1529. def : RWSysReg<"HDFGWTR_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b101>;
  1530. def : RWSysReg<"HAFGRTR_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b110>;
  1531. // v8.9a/v9.4a additions to Fine Grained Traps (FEAT_FGT2)
  1532. // Op0 Op1 CRn CRm Op2
  1533. def : RWSysReg<"HDFGRTR2_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b000>;
  1534. def : RWSysReg<"HDFGWTR2_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b001>;
  1535. def : RWSysReg<"HFGRTR2_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b010>;
  1536. def : RWSysReg<"HFGWTR2_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b011>;
  1537. def : RWSysReg<"HFGITR2_EL2", 0b11, 0b100, 0b0011, 0b0001, 0b111>;
  1538. }
  1539. // v8.6a Enhanced Counter Virtualization
  1540. // Op0 Op1 CRn CRm Op2
  1541. let Requires = [{ {AArch64::FeatureEnhancedCounterVirtualization} }] in {
  1542. def : RWSysReg<"CNTSCALE_EL2", 0b11, 0b100, 0b1110, 0b0000, 0b100>;
  1543. def : RWSysReg<"CNTISCALE_EL2", 0b11, 0b100, 0b1110, 0b0000, 0b101>;
  1544. def : RWSysReg<"CNTPOFF_EL2", 0b11, 0b100, 0b1110, 0b0000, 0b110>;
  1545. def : RWSysReg<"CNTVFRQ_EL2", 0b11, 0b100, 0b1110, 0b0000, 0b111>;
  1546. def : ROSysReg<"CNTPCTSS_EL0", 0b11, 0b011, 0b1110, 0b0000, 0b101>;
  1547. def : ROSysReg<"CNTVCTSS_EL0", 0b11, 0b011, 0b1110, 0b0000, 0b110>;
  1548. }
  1549. // v8.7a LD64B/ST64B Accelerator Extension system register
  1550. let Requires = [{ {AArch64::FeatureLS64} }] in
  1551. def : RWSysReg<"ACCDATA_EL1", 0b11, 0b000, 0b1101, 0b0000, 0b101>;
  1552. // Branch Record Buffer system registers
  1553. let Requires = [{ {AArch64::FeatureBRBE} }] in {
  1554. def : RWSysReg<"BRBCR_EL1", 0b10, 0b001, 0b1001, 0b0000, 0b000>;
  1555. def : RWSysReg<"BRBCR_EL12", 0b10, 0b101, 0b1001, 0b0000, 0b000>;
  1556. def : RWSysReg<"BRBCR_EL2", 0b10, 0b100, 0b1001, 0b0000, 0b000>;
  1557. def : RWSysReg<"BRBFCR_EL1", 0b10, 0b001, 0b1001, 0b0000, 0b001>;
  1558. def : ROSysReg<"BRBIDR0_EL1", 0b10, 0b001, 0b1001, 0b0010, 0b000>;
  1559. def : RWSysReg<"BRBINFINJ_EL1", 0b10, 0b001, 0b1001, 0b0001, 0b000>;
  1560. def : RWSysReg<"BRBSRCINJ_EL1", 0b10, 0b001, 0b1001, 0b0001, 0b001>;
  1561. def : RWSysReg<"BRBTGTINJ_EL1", 0b10, 0b001, 0b1001, 0b0001, 0b010>;
  1562. def : RWSysReg<"BRBTS_EL1", 0b10, 0b001, 0b1001, 0b0000, 0b010>;
  1563. foreach n = 0-31 in {
  1564. defvar nb = !cast<bits<5>>(n);
  1565. def : ROSysReg<"BRBINF"#n#"_EL1", 0b10, 0b001, 0b1000, nb{3-0}, {nb{4},0b00}>;
  1566. def : ROSysReg<"BRBSRC"#n#"_EL1", 0b10, 0b001, 0b1000, nb{3-0}, {nb{4},0b01}>;
  1567. def : ROSysReg<"BRBTGT"#n#"_EL1", 0b10, 0b001, 0b1000, nb{3-0}, {nb{4},0b10}>;
  1568. }
  1569. }
  1570. // Statistical Profiling Extension system register
  1571. let Requires = [{ {AArch64::FeatureSPE_EEF} }] in
  1572. def : RWSysReg<"PMSNEVFR_EL1", 0b11, 0b000, 0b1001, 0b1001, 0b001>;
  1573. // Cyclone specific system registers
  1574. // Op0 Op1 CRn CRm Op2
  1575. let Requires = [{ {AArch64::FeatureAppleA7SysReg} }] in
  1576. def : RWSysReg<"CPM_IOACC_CTL_EL3", 0b11, 0b111, 0b1111, 0b0010, 0b000>;
  1577. // Scalable Matrix Extension (SME)
  1578. // Op0 Op1 CRn CRm Op2
  1579. let Requires = [{ {AArch64::FeatureSME} }] in {
  1580. def : RWSysReg<"SMCR_EL1", 0b11, 0b000, 0b0001, 0b0010, 0b110>;
  1581. def : RWSysReg<"SMCR_EL2", 0b11, 0b100, 0b0001, 0b0010, 0b110>;
  1582. def : RWSysReg<"SMCR_EL3", 0b11, 0b110, 0b0001, 0b0010, 0b110>;
  1583. def : RWSysReg<"SMCR_EL12", 0b11, 0b101, 0b0001, 0b0010, 0b110>;
  1584. def : RWSysReg<"SVCR", 0b11, 0b011, 0b0100, 0b0010, 0b010>;
  1585. def : RWSysReg<"SMPRI_EL1", 0b11, 0b000, 0b0001, 0b0010, 0b100>;
  1586. def : RWSysReg<"SMPRIMAP_EL2", 0b11, 0b100, 0b0001, 0b0010, 0b101>;
  1587. def : ROSysReg<"SMIDR_EL1", 0b11, 0b001, 0b0000, 0b0000, 0b110>;
  1588. def : RWSysReg<"TPIDR2_EL0", 0b11, 0b011, 0b1101, 0b0000, 0b101>;
  1589. } // HasSME
  1590. // v8.4a MPAM and SME registers
  1591. // Op0 Op1 CRn CRm Op2
  1592. let Requires = [{ {AArch64::FeatureMPAM, AArch64::FeatureSME} }] in {
  1593. def : RWSysReg<"MPAMSM_EL1", 0b11, 0b000, 0b1010, 0b0101, 0b011>;
  1594. } // HasMPAM, HasSME
  1595. // v8.8a Non-Maskable Interrupts
  1596. let Requires = [{ {AArch64::FeatureNMI} }] in {
  1597. // Op0 Op1 CRn CRm Op2
  1598. def : RWSysReg<"ALLINT", 0b11, 0b000, 0b0100, 0b0011, 0b000>;
  1599. def : ROSysReg<"ICC_NMIAR1_EL1", 0b11, 0b000, 0b1100, 0b1001, 0b101>; // FEAT_GICv3_NMI
  1600. }
  1601. // v8.9a/v9.4a Memory Attribute Index Enhancement (FEAT_AIE)
  1602. // Op0 Op1 CRn CRm Op2
  1603. def : RWSysReg<"AMAIR2_EL1", 0b11, 0b000, 0b1010, 0b0011, 0b001>;
  1604. def : RWSysReg<"AMAIR2_EL12", 0b11, 0b101, 0b1010, 0b0011, 0b001>;
  1605. def : RWSysReg<"AMAIR2_EL2", 0b11, 0b100, 0b1010, 0b0011, 0b001>;
  1606. def : RWSysReg<"AMAIR2_EL3", 0b11, 0b110, 0b1010, 0b0011, 0b001>;
  1607. def : RWSysReg<"MAIR2_EL1", 0b11, 0b000, 0b1010, 0b0010, 0b001>;
  1608. def : RWSysReg<"MAIR2_EL12", 0b11, 0b101, 0b1010, 0b0010, 0b001>;
  1609. def : RWSysReg<"MAIR2_EL2", 0b11, 0b100, 0b1010, 0b0001, 0b001>;
  1610. def : RWSysReg<"MAIR2_EL3", 0b11, 0b110, 0b1010, 0b0001, 0b001>;
  1611. // v8.9a/9.4a Stage 1 Permission Indirection Extension (FEAT_S1PIE)
  1612. // Op0 Op1 CRn CRm Op2
  1613. def : RWSysReg<"PIRE0_EL1", 0b11, 0b000, 0b1010, 0b0010, 0b010>;
  1614. def : RWSysReg<"PIRE0_EL12", 0b11, 0b101, 0b1010, 0b0010, 0b010>;
  1615. def : RWSysReg<"PIRE0_EL2", 0b11, 0b100, 0b1010, 0b0010, 0b010>;
  1616. def : RWSysReg<"PIR_EL1", 0b11, 0b000, 0b1010, 0b0010, 0b011>;
  1617. def : RWSysReg<"PIR_EL12", 0b11, 0b101, 0b1010, 0b0010, 0b011>;
  1618. def : RWSysReg<"PIR_EL2", 0b11, 0b100, 0b1010, 0b0010, 0b011>;
  1619. def : RWSysReg<"PIR_EL3", 0b11, 0b110, 0b1010, 0b0010, 0b011>;
  1620. // v8.9a/v9.4a Stage 2 Permission Indirection Extension (FEAT_S2PIE)
  1621. // Op0 Op1 CRn CRm Op2
  1622. def : RWSysReg<"S2PIR_EL2", 0b11, 0b100, 0b1010, 0b0010, 0b101>;
  1623. // v8.9a/v9.4a Stage 1 Permission Overlay Extension (FEAT_S1POE)
  1624. // Op0 Op1 CRn CRm Op2
  1625. def : RWSysReg<"POR_EL0", 0b11, 0b011, 0b1010, 0b0010, 0b100>;
  1626. def : RWSysReg<"POR_EL1", 0b11, 0b000, 0b1010, 0b0010, 0b100>;
  1627. def : RWSysReg<"POR_EL12", 0b11, 0b101, 0b1010, 0b0010, 0b100>;
  1628. def : RWSysReg<"POR_EL2", 0b11, 0b100, 0b1010, 0b0010, 0b100>;
  1629. def : RWSysReg<"POR_EL3", 0b11, 0b110, 0b1010, 0b0010, 0b100>;
  1630. // v8.9a/v9.4a Stage 2 Permission Overlay Extension (FEAT_S2POE)
  1631. // Op0 Op1 CRn CRm Op2
  1632. def : RWSysReg<"S2POR_EL1", 0b11, 0b000, 0b1010, 0b0010, 0b101>;
  1633. // v8.9a/v9.4a Extension to System Control Registers (FEAT_SCTLR2)
  1634. // Op0 Op1 CRn CRm Op2
  1635. def : RWSysReg<"SCTLR2_EL1", 0b11, 0b000, 0b0001, 0b0000, 0b011>;
  1636. def : RWSysReg<"SCTLR2_EL12", 0b11, 0b101, 0b0001, 0b0000, 0b011>;
  1637. def : RWSysReg<"SCTLR2_EL2", 0b11, 0b100, 0b0001, 0b0000, 0b011>;
  1638. def : RWSysReg<"SCTLR2_EL3", 0b11, 0b110, 0b0001, 0b0000, 0b011>;
  1639. // v8.9a/v9.4a Extension to Translation Control Registers (FEAT_TCR2)
  1640. // Op0 Op1 CRn CRm Op2
  1641. def : RWSysReg<"TCR2_EL1", 0b11, 0b000, 0b0010, 0b0000, 0b011>;
  1642. def : RWSysReg<"TCR2_EL12", 0b11, 0b101, 0b0010, 0b0000, 0b011>;
  1643. def : RWSysReg<"TCR2_EL2", 0b11, 0b100, 0b0010, 0b0000, 0b011>;
  1644. // v8.9a/9.4a Translation Hardening Extension (FEAT_THE)
  1645. // Op0 Op1 CRn CRm Op2
  1646. let Requires = [{ {AArch64::FeatureTHE} }] in {
  1647. def : RWSysReg<"RCWMASK_EL1", 0b11, 0b000, 0b1101, 0b0000, 0b110>;
  1648. def : RWSysReg<"RCWSMASK_EL1", 0b11, 0b000, 0b1101, 0b0000, 0b011>;
  1649. }
  1650. // v8.9a/9.4a new Debug feature (FEAT_DEBUGv8p9)
  1651. // Op0 Op1 CRn CRm Op2
  1652. def : RWSysReg<"MDSELR_EL1", 0b10, 0b000, 0b0000, 0b0100, 0b010>;
  1653. // v8.9a/9.4a new Performance Monitors Extension (FEAT_PMUv3p9)
  1654. // Op0 Op1 CRn CRm Op2
  1655. def : RWSysReg<"PMUACR_EL1", 0b11, 0b000, 0b1001, 0b1110, 0b100>;
  1656. // v8.9a/9.4a PMU Snapshot Extension (FEAT_PMUv3_SS)
  1657. // Op0 Op1 CRn CRm Op2
  1658. def : ROSysReg<"PMCCNTSVR_EL1", 0b10, 0b000, 0b1110, 0b1011, 0b111>;
  1659. def : ROSysReg<"PMICNTSVR_EL1", 0b10, 0b000, 0b1110, 0b1100, 0b000>;
  1660. def : RWSysReg<"PMSSCR_EL1", 0b11, 0b000, 0b1001, 0b1101, 0b011>;
  1661. foreach n = 0-30 in {
  1662. defvar nb = !cast<bits<5>>(n);
  1663. def : ROSysReg<"PMEVCNTSVR"#n#"_EL1", 0b10, 0b000, 0b1110, {0b10,nb{4-3}}, nb{2-0}>;
  1664. }
  1665. // v8.9a/v9.4a PMUv3 Fixed-function instruction counter (FEAT_PMUv3_ICNTR)
  1666. // Op0 Op1 CRn CRm Op2
  1667. def : RWSysReg<"PMICNTR_EL0", 0b11, 0b011, 0b1001, 0b0100, 0b000>;
  1668. def : RWSysReg<"PMICFILTR_EL0", 0b11, 0b011, 0b1001, 0b0110, 0b000>;
  1669. // v8.9a/v9.4a PMUv3 Performance Monitors Zero with Mask (FEAT_PMUv3p9/FEAT_PMUv3_ICNTR)
  1670. // Op0 Op1 CRn CRm Op2
  1671. def : WOSysReg<"PMZR_EL0", 0b11, 0b011, 0b1001, 0b1101, 0b100>;
  1672. // v8.9a/9.4a Synchronous-Exception-Based Event Profiling extension (FEAT_SEBEP)
  1673. // Op0 Op1 CRn CRm Op2
  1674. def : RWSysReg<"PMECR_EL1", 0b11, 0b000, 0b1001, 0b1110, 0b101>;
  1675. def : RWSysReg<"PMIAR_EL1", 0b11, 0b000, 0b1001, 0b1110, 0b111>;
  1676. // v8.9a/9.4a System Performance Monitors Extension (FEAT_SPMU)
  1677. // Op0 Op1 CRn CRm Op2
  1678. def : RWSysReg<"SPMACCESSR_EL1", 0b10, 0b000, 0b1001, 0b1101, 0b011>;
  1679. def : RWSysReg<"SPMACCESSR_EL12", 0b10, 0b101, 0b1001, 0b1101, 0b011>;
  1680. def : RWSysReg<"SPMACCESSR_EL2", 0b10, 0b100, 0b1001, 0b1101, 0b011>;
  1681. def : RWSysReg<"SPMACCESSR_EL3", 0b10, 0b110, 0b1001, 0b1101, 0b011>;
  1682. def : RWSysReg<"SPMCNTENCLR_EL0", 0b10, 0b011, 0b1001, 0b1100, 0b010>;
  1683. def : RWSysReg<"SPMCNTENSET_EL0", 0b10, 0b011, 0b1001, 0b1100, 0b001>;
  1684. def : RWSysReg<"SPMCR_EL0", 0b10, 0b011, 0b1001, 0b1100, 0b000>;
  1685. def : ROSysReg<"SPMDEVAFF_EL1", 0b10, 0b000, 0b1001, 0b1101, 0b110>;
  1686. def : ROSysReg<"SPMDEVARCH_EL1", 0b10, 0b000, 0b1001, 0b1101, 0b101>;
  1687. foreach n = 0-15 in {
  1688. defvar nb = !cast<bits<4>>(n);
  1689. // Op0 Op1 CRn CRm Op2
  1690. def : RWSysReg<"SPMEVCNTR"#n#"_EL0", 0b10, 0b011, 0b1110, {0b000,nb{3}}, nb{2-0}>;
  1691. def : RWSysReg<"SPMEVFILT2R"#n#"_EL0", 0b10, 0b011, 0b1110, {0b011,nb{3}}, nb{2-0}>;
  1692. def : RWSysReg<"SPMEVFILTR"#n#"_EL0", 0b10, 0b011, 0b1110, {0b010,nb{3}}, nb{2-0}>;
  1693. def : RWSysReg<"SPMEVTYPER"#n#"_EL0", 0b10, 0b011, 0b1110, {0b001,nb{3}}, nb{2-0}>;
  1694. }
  1695. // Op0 Op1 CRn CRm Op2
  1696. def : ROSysReg<"SPMIIDR_EL1", 0b10, 0b000, 0b1001, 0b1101, 0b100>;
  1697. def : RWSysReg<"SPMINTENCLR_EL1", 0b10, 0b000, 0b1001, 0b1110, 0b010>;
  1698. def : RWSysReg<"SPMINTENSET_EL1", 0b10, 0b000, 0b1001, 0b1110, 0b001>;
  1699. def : RWSysReg<"SPMOVSCLR_EL0", 0b10, 0b011, 0b1001, 0b1100, 0b011>;
  1700. def : RWSysReg<"SPMOVSSET_EL0", 0b10, 0b011, 0b1001, 0b1110, 0b011>;
  1701. def : RWSysReg<"SPMSELR_EL0", 0b10, 0b011, 0b1001, 0b1100, 0b101>;
  1702. def : ROSysReg<"SPMCGCR0_EL1", 0b10, 0b000, 0b1001, 0b1101, 0b000>;
  1703. def : ROSysReg<"SPMCGCR1_EL1", 0b10, 0b000, 0b1001, 0b1101, 0b001>;
  1704. def : ROSysReg<"SPMCFGR_EL1", 0b10, 0b000, 0b1001, 0b1101, 0b111>;
  1705. def : RWSysReg<"SPMROOTCR_EL3", 0b10, 0b110, 0b1001, 0b1110, 0b111>;
  1706. def : RWSysReg<"SPMSCR_EL1", 0b10, 0b111, 0b1001, 0b1110, 0b111>;
  1707. // v8.9a/9.4a Instrumentation Extension (FEAT_ITE)
  1708. // Op0 Op1 CRn CRm Op2
  1709. let Requires = [{ {AArch64::FeatureITE} }] in {
  1710. def : RWSysReg<"TRCITEEDCR", 0b10, 0b001, 0b0000, 0b0010, 0b001>;
  1711. def : RWSysReg<"TRCITECR_EL1", 0b11, 0b000, 0b0001, 0b0010, 0b011>;
  1712. def : RWSysReg<"TRCITECR_EL12", 0b11, 0b101, 0b0001, 0b0010, 0b011>;
  1713. def : RWSysReg<"TRCITECR_EL2", 0b11, 0b100, 0b0001, 0b0010, 0b011>;
  1714. }
  1715. // v8.9a/9.4a SPE Data Source Filtering (FEAT_SPE_FDS)
  1716. // Op0 Op1 CRn CRm Op2
  1717. def : RWSysReg<"PMSDSFR_EL1", 0b11, 0b000, 0b1001, 0b1010, 0b100>;
  1718. // v8.9a/9.4a RASv2 (FEAT_RASv2)
  1719. // Op0 Op1 CRn CRm Op2
  1720. let Requires = [{ {AArch64::FeatureRASv2} }] in
  1721. def : ROSysReg<"ERXGSR_EL1", 0b11, 0b000, 0b0101, 0b0011, 0b010>;
  1722. // v8.9a/9.4a Physical Fault Address (FEAT_PFAR)
  1723. // Op0 Op1 CRn CRm Op2
  1724. def : RWSysReg<"PFAR_EL1", 0b11, 0b000, 0b0110, 0b0000, 0b101>;
  1725. def : RWSysReg<"PFAR_EL12", 0b11, 0b101, 0b0110, 0b0000, 0b101>;
  1726. def : RWSysReg<"PFAR_EL2", 0b11, 0b100, 0b0110, 0b0000, 0b101>;
  1727. // v9.4a Exception-based event profiling (FEAT_EBEP)
  1728. // Op0 Op1 CRn CRm Op2
  1729. def : RWSysReg<"PM", 0b11, 0b000, 0b0100, 0b0011, 0b001>;