udb 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2654) hide show
  1. checksums.yaml +7 -0
  2. data/.data/cfgs/MC100-32.yaml +23 -0
  3. data/.data/cfgs/_.yaml +8 -0
  4. data/.data/cfgs/example_rv64_with_overlay.yaml +618 -0
  5. data/.data/cfgs/mc100-32-full-example.yaml +91 -0
  6. data/.data/cfgs/memmap.json +76 -0
  7. data/.data/cfgs/prm_demo_rv32.yaml +28 -0
  8. data/.data/cfgs/profile/RVA20S64.yaml +73 -0
  9. data/.data/cfgs/profile/RVA20U64.yaml +53 -0
  10. data/.data/cfgs/profile/RVA22S64.yaml +123 -0
  11. data/.data/cfgs/profile/RVA22U64.yaml +85 -0
  12. data/.data/cfgs/profile/RVA23M64.yaml +161 -0
  13. data/.data/cfgs/profile/RVA23S64.yaml +151 -0
  14. data/.data/cfgs/profile/RVA23U64.yaml +131 -0
  15. data/.data/cfgs/profile/RVB23M64.yaml +151 -0
  16. data/.data/cfgs/profile/RVB23S64.yaml +147 -0
  17. data/.data/cfgs/profile/RVB23U64.yaml +141 -0
  18. data/.data/cfgs/profile/RVI20U32.yaml +41 -0
  19. data/.data/cfgs/profile/RVI20U64.yaml +41 -0
  20. data/.data/cfgs/qc_iu.yaml +153 -0
  21. data/.data/cfgs/regress.yaml +9 -0
  22. data/.data/cfgs/rv32-riscv-tests.yaml +208 -0
  23. data/.data/cfgs/rv32-vector.yaml +246 -0
  24. data/.data/cfgs/rv32.yaml +15 -0
  25. data/.data/cfgs/rv64-riscv-tests.yaml +202 -0
  26. data/.data/cfgs/rv64-vector.yaml +245 -0
  27. data/.data/cfgs/rv64.yaml +14 -0
  28. data/.data/spec/custom/isa/example/csr/marchid.yaml +8 -0
  29. data/.data/spec/custom/isa/example/csr/mcustom0.yaml +18 -0
  30. data/.data/spec/custom/isa/example/ext/Xcustom.yaml +15 -0
  31. data/.data/spec/custom/isa/qc_iu/csr/Xqci/gen_mcliciX.rb +188 -0
  32. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mcause.yaml +85 -0
  33. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie0.yaml +181 -0
  34. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie1.yaml +181 -0
  35. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie2.yaml +181 -0
  36. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie3.yaml +181 -0
  37. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie4.yaml +181 -0
  38. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie5.yaml +181 -0
  39. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie6.yaml +181 -0
  40. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicie7.yaml +181 -0
  41. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl00.yaml +62 -0
  42. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl01.yaml +62 -0
  43. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl02.yaml +62 -0
  44. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl03.yaml +62 -0
  45. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl04.yaml +62 -0
  46. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl05.yaml +62 -0
  47. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl06.yaml +62 -0
  48. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl07.yaml +62 -0
  49. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl08.yaml +62 -0
  50. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl09.yaml +62 -0
  51. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl10.yaml +62 -0
  52. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl11.yaml +62 -0
  53. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl12.yaml +62 -0
  54. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl13.yaml +62 -0
  55. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl14.yaml +62 -0
  56. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl15.yaml +62 -0
  57. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl16.yaml +62 -0
  58. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl17.yaml +62 -0
  59. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl18.yaml +62 -0
  60. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl19.yaml +62 -0
  61. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl20.yaml +62 -0
  62. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl21.yaml +62 -0
  63. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl22.yaml +62 -0
  64. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl23.yaml +62 -0
  65. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl24.yaml +62 -0
  66. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl25.yaml +62 -0
  67. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl26.yaml +62 -0
  68. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl27.yaml +62 -0
  69. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl28.yaml +62 -0
  70. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl29.yaml +62 -0
  71. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl30.yaml +62 -0
  72. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicilvl31.yaml +62 -0
  73. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip0.yaml +181 -0
  74. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip1.yaml +181 -0
  75. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip2.yaml +181 -0
  76. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip3.yaml +181 -0
  77. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip4.yaml +181 -0
  78. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip5.yaml +181 -0
  79. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip6.yaml +181 -0
  80. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mclicip7.yaml +181 -0
  81. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mmcr.yaml +42 -0
  82. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mntvec.yaml +28 -0
  83. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mstkbottomaddr.yaml +33 -0
  84. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mstktopaddr.yaml +33 -0
  85. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mthreadptr.yaml +27 -0
  86. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpendaddr0.yaml +27 -0
  87. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpendaddr1.yaml +27 -0
  88. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpendaddr2.yaml +27 -0
  89. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpendaddr3.yaml +27 -0
  90. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpstartaddr0.yaml +27 -0
  91. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpstartaddr1.yaml +27 -0
  92. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpstartaddr2.yaml +27 -0
  93. data/.data/spec/custom/isa/qc_iu/csr/Xqci/qc.mwpstartaddr3.yaml +27 -0
  94. data/.data/spec/custom/isa/qc_iu/exception_code/ExecWatchpoint.yaml +13 -0
  95. data/.data/spec/custom/isa/qc_iu/exception_code/IllegalStackPointer.yaml +13 -0
  96. data/.data/spec/custom/isa/qc_iu/exception_code/ReadWatchpoint.yaml +13 -0
  97. data/.data/spec/custom/isa/qc_iu/exception_code/SpOutOfRange.yaml +13 -0
  98. data/.data/spec/custom/isa/qc_iu/exception_code/WriteWatchpoint.yaml +13 -0
  99. data/.data/spec/custom/isa/qc_iu/ext/Xqccmp.yaml +160 -0
  100. data/.data/spec/custom/isa/qc_iu/ext/Xqci.yaml +778 -0
  101. data/.data/spec/custom/isa/qc_iu/ext/Xqcia.yaml +111 -0
  102. data/.data/spec/custom/isa/qc_iu/ext/Xqciac.yaml +66 -0
  103. data/.data/spec/custom/isa/qc_iu/ext/Xqcibi.yaml +50 -0
  104. data/.data/spec/custom/isa/qc_iu/ext/Xqcibm.yaml +146 -0
  105. data/.data/spec/custom/isa/qc_iu/ext/Xqcicli.yaml +57 -0
  106. data/.data/spec/custom/isa/qc_iu/ext/Xqcicm.yaml +50 -0
  107. data/.data/spec/custom/isa/qc_iu/ext/Xqcics.yaml +44 -0
  108. data/.data/spec/custom/isa/qc_iu/ext/Xqcicsr.yaml +68 -0
  109. data/.data/spec/custom/isa/qc_iu/ext/Xqciint.yaml +173 -0
  110. data/.data/spec/custom/isa/qc_iu/ext/Xqciio.yaml +32 -0
  111. data/.data/spec/custom/isa/qc_iu/ext/Xqcilb.yaml +46 -0
  112. data/.data/spec/custom/isa/qc_iu/ext/Xqcili.yaml +49 -0
  113. data/.data/spec/custom/isa/qc_iu/ext/Xqcilia.yaml +47 -0
  114. data/.data/spec/custom/isa/qc_iu/ext/Xqcilo.yaml +59 -0
  115. data/.data/spec/custom/isa/qc_iu/ext/Xqcilsm.yaml +94 -0
  116. data/.data/spec/custom/isa/qc_iu/ext/Xqcisim.yaml +48 -0
  117. data/.data/spec/custom/isa/qc_iu/ext/Xqcisls.yaml +44 -0
  118. data/.data/spec/custom/isa/qc_iu/ext/Xqcisync.yaml +62 -0
  119. data/.data/spec/custom/isa/qc_iu/inst/C/c.slli.yaml +6 -0
  120. data/.data/spec/custom/isa/qc_iu/inst/C/c.srai.yaml +5 -0
  121. data/.data/spec/custom/isa/qc_iu/inst/C/c.srli.yaml +5 -0
  122. data/.data/spec/custom/isa/qc_iu/inst/I/slti.yaml +15 -0
  123. data/.data/spec/custom/isa/qc_iu/inst/I/sltiu.yaml +8 -0
  124. data/.data/spec/custom/isa/qc_iu/inst/Xqccmp/qc.cm.mva01s.yaml +36 -0
  125. data/.data/spec/custom/isa/qc_iu/inst/Xqccmp/qc.cm.mvsa01.yaml +38 -0
  126. data/.data/spec/custom/isa/qc_iu/inst/Xqccmp/qc.cm.pop.yaml +87 -0
  127. data/.data/spec/custom/isa/qc_iu/inst/Xqccmp/qc.cm.popret.yaml +88 -0
  128. data/.data/spec/custom/isa/qc_iu/inst/Xqccmp/qc.cm.popretz.yaml +88 -0
  129. data/.data/spec/custom/isa/qc_iu/inst/Xqccmp/qc.cm.push.yaml +87 -0
  130. data/.data/spec/custom/isa/qc_iu/inst/Xqccmp/qc.cm.pushfp.yaml +89 -0
  131. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.addsat.yaml +51 -0
  132. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.addusat.yaml +44 -0
  133. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.beqi.yaml +40 -0
  134. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.bgei.yaml +40 -0
  135. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.bgeui.yaml +40 -0
  136. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.blti.yaml +40 -0
  137. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.bltui.yaml +40 -0
  138. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.bnei.yaml +40 -0
  139. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.brev32.yaml +41 -0
  140. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.bexti.yaml +36 -0
  141. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.bseti.yaml +36 -0
  142. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.clrint.yaml +36 -0
  143. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.delay.yaml +31 -0
  144. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.di.yaml +30 -0
  145. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.dir.yaml +36 -0
  146. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.ei.yaml +30 -0
  147. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.eir.yaml +35 -0
  148. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.extu.yaml +36 -0
  149. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.mienter.nest.yaml +61 -0
  150. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.mienter.yaml +59 -0
  151. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.mileaveret.yaml +106 -0
  152. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.mnret.yaml +50 -0
  153. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.mret.yaml +53 -0
  154. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.muliadd.yaml +37 -0
  155. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.mveqz.yaml +35 -0
  156. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.ptrace.yaml +31 -0
  157. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.setint.yaml +36 -0
  158. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.sync.yaml +46 -0
  159. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.syncr.yaml +46 -0
  160. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.syncwf.yaml +46 -0
  161. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.c.syncwl.yaml +46 -0
  162. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.clo.yaml +38 -0
  163. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.clrinti.yaml +35 -0
  164. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.compress2.yaml +37 -0
  165. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.compress3.yaml +37 -0
  166. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.csrrwr.yaml +52 -0
  167. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.csrrwri.yaml +48 -0
  168. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.cto.yaml +38 -0
  169. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.addai.yaml +33 -0
  170. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.addi.yaml +37 -0
  171. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.andai.yaml +33 -0
  172. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.andi.yaml +37 -0
  173. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.beqi.yaml +40 -0
  174. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.bgei.yaml +40 -0
  175. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.bgeui.yaml +40 -0
  176. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.blti.yaml +40 -0
  177. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.bltui.yaml +40 -0
  178. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.bnei.yaml +40 -0
  179. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.j.yaml +32 -0
  180. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.jal.yaml +35 -0
  181. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.lb.yaml +37 -0
  182. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.lbu.yaml +37 -0
  183. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.lh.yaml +37 -0
  184. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.lhu.yaml +37 -0
  185. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.li.yaml +33 -0
  186. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.lw.yaml +37 -0
  187. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.orai.yaml +33 -0
  188. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.ori.yaml +37 -0
  189. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.sb.yaml +36 -0
  190. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.sh.yaml +36 -0
  191. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.sw.yaml +36 -0
  192. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.xorai.yaml +33 -0
  193. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.e.xori.yaml +37 -0
  194. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.expand2.yaml +39 -0
  195. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.expand3.yaml +39 -0
  196. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.ext.yaml +42 -0
  197. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extd.yaml +42 -0
  198. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extdpr.yaml +49 -0
  199. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extdprh.yaml +49 -0
  200. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extdr.yaml +49 -0
  201. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extdu.yaml +42 -0
  202. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extdupr.yaml +49 -0
  203. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extduprh.yaml +49 -0
  204. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extdur.yaml +49 -0
  205. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.extu.yaml +41 -0
  206. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insb.yaml +42 -0
  207. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insbh.yaml +51 -0
  208. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insbhr.yaml +53 -0
  209. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insbi.yaml +43 -0
  210. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insbpr.yaml +47 -0
  211. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insbprh.yaml +47 -0
  212. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insbr.yaml +47 -0
  213. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.insbri.yaml +48 -0
  214. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.inw.yaml +38 -0
  215. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.li.yaml +33 -0
  216. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lieq.yaml +41 -0
  217. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lieqi.yaml +40 -0
  218. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lige.yaml +41 -0
  219. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.ligei.yaml +40 -0
  220. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.ligeu.yaml +41 -0
  221. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.ligeui.yaml +40 -0
  222. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lilt.yaml +41 -0
  223. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lilti.yaml +40 -0
  224. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.liltu.yaml +41 -0
  225. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.liltui.yaml +40 -0
  226. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.line.yaml +41 -0
  227. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.linei.yaml +40 -0
  228. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lrb.yaml +40 -0
  229. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lrbu.yaml +39 -0
  230. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lrh.yaml +40 -0
  231. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lrhu.yaml +39 -0
  232. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lrw.yaml +39 -0
  233. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lwm.yaml +46 -0
  234. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.lwmi.yaml +45 -0
  235. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.muliadd.yaml +37 -0
  236. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mveq.yaml +42 -0
  237. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mveqi.yaml +41 -0
  238. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvge.yaml +42 -0
  239. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvgei.yaml +41 -0
  240. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvgeu.yaml +42 -0
  241. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvgeui.yaml +41 -0
  242. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvlt.yaml +42 -0
  243. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvlti.yaml +41 -0
  244. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvltu.yaml +42 -0
  245. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvltui.yaml +41 -0
  246. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvne.yaml +42 -0
  247. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.mvnei.yaml +41 -0
  248. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.norm.yaml +41 -0
  249. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.normeu.yaml +40 -0
  250. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.normu.yaml +40 -0
  251. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.outw.yaml +38 -0
  252. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.pcoredump.yaml +32 -0
  253. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.pexit.yaml +33 -0
  254. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.ppreg.yaml +33 -0
  255. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.ppregs.yaml +31 -0
  256. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.pputc.yaml +33 -0
  257. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.pputci.yaml +33 -0
  258. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.pputs.yaml +34 -0
  259. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.psyscall.yaml +34 -0
  260. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.psyscalli.yaml +34 -0
  261. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selecteqi.yaml +44 -0
  262. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selectieq.yaml +44 -0
  263. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selectieqi.yaml +43 -0
  264. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selectiieq.yaml +43 -0
  265. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selectiine.yaml +43 -0
  266. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selectine.yaml +44 -0
  267. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selectinei.yaml +43 -0
  268. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.selectnei.yaml +44 -0
  269. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.setinti.yaml +35 -0
  270. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.setwm.yaml +45 -0
  271. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.setwmi.yaml +44 -0
  272. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.shladd.yaml +43 -0
  273. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.shlsat.yaml +48 -0
  274. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.shlusat.yaml +45 -0
  275. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.srb.yaml +39 -0
  276. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.srh.yaml +39 -0
  277. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.srw.yaml +39 -0
  278. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.subsat.yaml +53 -0
  279. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.subusat.yaml +37 -0
  280. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.swm.yaml +46 -0
  281. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.swmi.yaml +45 -0
  282. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.sync.yaml +34 -0
  283. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.syncr.yaml +34 -0
  284. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.syncwf.yaml +34 -0
  285. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.syncwl.yaml +34 -0
  286. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.wrap.yaml +43 -0
  287. data/.data/spec/custom/isa/qc_iu/inst/Xqci/qc.wrapi.yaml +47 -0
  288. data/.data/spec/custom/isa/qc_iu/isa/globals.isa +83 -0
  289. data/.data/spec/custom/isa/regress/manual_version/isa/regress/isa_regress.yaml +222 -0
  290. data/.data/spec/schemas/README.adoc +87 -0
  291. data/.data/spec/schemas/config_schema.json +198 -0
  292. data/.data/spec/schemas/csr_schema.json +319 -0
  293. data/.data/spec/schemas/exception_code_schema.json +33 -0
  294. data/.data/spec/schemas/ext_schema.json +168 -0
  295. data/.data/spec/schemas/inst_opcode_schema.json +37 -0
  296. data/.data/spec/schemas/inst_schema.json +503 -0
  297. data/.data/spec/schemas/inst_subtype_schema.json +190 -0
  298. data/.data/spec/schemas/inst_type_schema.json +69 -0
  299. data/.data/spec/schemas/inst_var_schema.json +93 -0
  300. data/.data/spec/schemas/inst_var_type_schema.json +45 -0
  301. data/.data/spec/schemas/inst_variable_metadatas.json +10 -0
  302. data/.data/spec/schemas/interrupt_code_schema.json +33 -0
  303. data/.data/spec/schemas/json-schema-draft-07.json +242 -0
  304. data/.data/spec/schemas/manual_schema.json +44 -0
  305. data/.data/spec/schemas/manual_version_schema.json +129 -0
  306. data/.data/spec/schemas/mmr_schema.json +74 -0
  307. data/.data/spec/schemas/non_isa_schema.json +102 -0
  308. data/.data/spec/schemas/param_schema.json +48 -0
  309. data/.data/spec/schemas/prm_schema.json +203 -0
  310. data/.data/spec/schemas/proc_cert_class_schema.json +35 -0
  311. data/.data/spec/schemas/proc_cert_model_schema.json +336 -0
  312. data/.data/spec/schemas/profile_family_schema.json +54 -0
  313. data/.data/spec/schemas/profile_release_schema.json +22 -0
  314. data/.data/spec/schemas/profile_schema.json +139 -0
  315. data/.data/spec/schemas/register_file_schema.json +123 -0
  316. data/.data/spec/schemas/schema_defs.json +905 -0
  317. data/.data/spec/std/isa/README.adoc +295 -0
  318. data/.data/spec/std/isa/csr/F/fcsr.yaml +190 -0
  319. data/.data/spec/std/isa/csr/F/fflags.yaml +95 -0
  320. data/.data/spec/std/isa/csr/F/frm.yaml +57 -0
  321. data/.data/spec/std/isa/csr/H/hcounteren.layout +178 -0
  322. data/.data/spec/std/isa/csr/H/hcounteren.yaml +1215 -0
  323. data/.data/spec/std/isa/csr/H/henvcfg.yaml +307 -0
  324. data/.data/spec/std/isa/csr/H/henvcfgh.yaml +120 -0
  325. data/.data/spec/std/isa/csr/H/hgatp.yaml +242 -0
  326. data/.data/spec/std/isa/csr/H/htimedelta.yaml +32 -0
  327. data/.data/spec/std/isa/csr/H/htimedeltah.yaml +32 -0
  328. data/.data/spec/std/isa/csr/H/htinst.yaml +50 -0
  329. data/.data/spec/std/isa/csr/H/htval.yaml +42 -0
  330. data/.data/spec/std/isa/csr/H/mtinst.yaml +50 -0
  331. data/.data/spec/std/isa/csr/H/mtval2.yaml +43 -0
  332. data/.data/spec/std/isa/csr/H/vsatp.yaml +149 -0
  333. data/.data/spec/std/isa/csr/I/mcounteren.layout +192 -0
  334. data/.data/spec/std/isa/csr/I/mcounteren.yaml +1061 -0
  335. data/.data/spec/std/isa/csr/I/pmpaddr0.yaml +79 -0
  336. data/.data/spec/std/isa/csr/I/pmpaddr1.yaml +79 -0
  337. data/.data/spec/std/isa/csr/I/pmpaddr10.yaml +79 -0
  338. data/.data/spec/std/isa/csr/I/pmpaddr11.yaml +79 -0
  339. data/.data/spec/std/isa/csr/I/pmpaddr12.yaml +79 -0
  340. data/.data/spec/std/isa/csr/I/pmpaddr13.yaml +79 -0
  341. data/.data/spec/std/isa/csr/I/pmpaddr14.yaml +79 -0
  342. data/.data/spec/std/isa/csr/I/pmpaddr15.yaml +79 -0
  343. data/.data/spec/std/isa/csr/I/pmpaddr16.yaml +79 -0
  344. data/.data/spec/std/isa/csr/I/pmpaddr17.yaml +79 -0
  345. data/.data/spec/std/isa/csr/I/pmpaddr18.yaml +79 -0
  346. data/.data/spec/std/isa/csr/I/pmpaddr19.yaml +79 -0
  347. data/.data/spec/std/isa/csr/I/pmpaddr2.yaml +79 -0
  348. data/.data/spec/std/isa/csr/I/pmpaddr20.yaml +79 -0
  349. data/.data/spec/std/isa/csr/I/pmpaddr21.yaml +79 -0
  350. data/.data/spec/std/isa/csr/I/pmpaddr22.yaml +79 -0
  351. data/.data/spec/std/isa/csr/I/pmpaddr23.yaml +79 -0
  352. data/.data/spec/std/isa/csr/I/pmpaddr24.yaml +79 -0
  353. data/.data/spec/std/isa/csr/I/pmpaddr25.yaml +79 -0
  354. data/.data/spec/std/isa/csr/I/pmpaddr26.yaml +79 -0
  355. data/.data/spec/std/isa/csr/I/pmpaddr27.yaml +79 -0
  356. data/.data/spec/std/isa/csr/I/pmpaddr28.yaml +79 -0
  357. data/.data/spec/std/isa/csr/I/pmpaddr29.yaml +79 -0
  358. data/.data/spec/std/isa/csr/I/pmpaddr3.yaml +79 -0
  359. data/.data/spec/std/isa/csr/I/pmpaddr30.yaml +79 -0
  360. data/.data/spec/std/isa/csr/I/pmpaddr31.yaml +79 -0
  361. data/.data/spec/std/isa/csr/I/pmpaddr32.yaml +79 -0
  362. data/.data/spec/std/isa/csr/I/pmpaddr33.yaml +79 -0
  363. data/.data/spec/std/isa/csr/I/pmpaddr34.yaml +79 -0
  364. data/.data/spec/std/isa/csr/I/pmpaddr35.yaml +79 -0
  365. data/.data/spec/std/isa/csr/I/pmpaddr36.yaml +79 -0
  366. data/.data/spec/std/isa/csr/I/pmpaddr37.yaml +79 -0
  367. data/.data/spec/std/isa/csr/I/pmpaddr38.yaml +79 -0
  368. data/.data/spec/std/isa/csr/I/pmpaddr39.yaml +79 -0
  369. data/.data/spec/std/isa/csr/I/pmpaddr4.yaml +79 -0
  370. data/.data/spec/std/isa/csr/I/pmpaddr40.yaml +79 -0
  371. data/.data/spec/std/isa/csr/I/pmpaddr41.yaml +79 -0
  372. data/.data/spec/std/isa/csr/I/pmpaddr42.yaml +79 -0
  373. data/.data/spec/std/isa/csr/I/pmpaddr43.yaml +79 -0
  374. data/.data/spec/std/isa/csr/I/pmpaddr44.yaml +79 -0
  375. data/.data/spec/std/isa/csr/I/pmpaddr45.yaml +79 -0
  376. data/.data/spec/std/isa/csr/I/pmpaddr46.yaml +79 -0
  377. data/.data/spec/std/isa/csr/I/pmpaddr47.yaml +79 -0
  378. data/.data/spec/std/isa/csr/I/pmpaddr48.yaml +79 -0
  379. data/.data/spec/std/isa/csr/I/pmpaddr49.yaml +79 -0
  380. data/.data/spec/std/isa/csr/I/pmpaddr5.yaml +79 -0
  381. data/.data/spec/std/isa/csr/I/pmpaddr50.yaml +79 -0
  382. data/.data/spec/std/isa/csr/I/pmpaddr51.yaml +79 -0
  383. data/.data/spec/std/isa/csr/I/pmpaddr52.yaml +79 -0
  384. data/.data/spec/std/isa/csr/I/pmpaddr53.yaml +79 -0
  385. data/.data/spec/std/isa/csr/I/pmpaddr54.yaml +79 -0
  386. data/.data/spec/std/isa/csr/I/pmpaddr55.yaml +79 -0
  387. data/.data/spec/std/isa/csr/I/pmpaddr56.yaml +79 -0
  388. data/.data/spec/std/isa/csr/I/pmpaddr57.yaml +79 -0
  389. data/.data/spec/std/isa/csr/I/pmpaddr58.yaml +79 -0
  390. data/.data/spec/std/isa/csr/I/pmpaddr59.yaml +79 -0
  391. data/.data/spec/std/isa/csr/I/pmpaddr6.yaml +79 -0
  392. data/.data/spec/std/isa/csr/I/pmpaddr60.yaml +79 -0
  393. data/.data/spec/std/isa/csr/I/pmpaddr61.yaml +79 -0
  394. data/.data/spec/std/isa/csr/I/pmpaddr62.yaml +79 -0
  395. data/.data/spec/std/isa/csr/I/pmpaddr63.yaml +79 -0
  396. data/.data/spec/std/isa/csr/I/pmpaddr7.yaml +79 -0
  397. data/.data/spec/std/isa/csr/I/pmpaddr8.yaml +79 -0
  398. data/.data/spec/std/isa/csr/I/pmpaddr9.yaml +79 -0
  399. data/.data/spec/std/isa/csr/I/pmpaddrN.layout +81 -0
  400. data/.data/spec/std/isa/csr/I/pmpcfg0.yaml +493 -0
  401. data/.data/spec/std/isa/csr/I/pmpcfg1.yaml +255 -0
  402. data/.data/spec/std/isa/csr/I/pmpcfg10.yaml +493 -0
  403. data/.data/spec/std/isa/csr/I/pmpcfg11.yaml +255 -0
  404. data/.data/spec/std/isa/csr/I/pmpcfg12.yaml +493 -0
  405. data/.data/spec/std/isa/csr/I/pmpcfg13.yaml +255 -0
  406. data/.data/spec/std/isa/csr/I/pmpcfg14.yaml +493 -0
  407. data/.data/spec/std/isa/csr/I/pmpcfg15.yaml +255 -0
  408. data/.data/spec/std/isa/csr/I/pmpcfg2.yaml +493 -0
  409. data/.data/spec/std/isa/csr/I/pmpcfg3.yaml +255 -0
  410. data/.data/spec/std/isa/csr/I/pmpcfg4.yaml +493 -0
  411. data/.data/spec/std/isa/csr/I/pmpcfg5.yaml +255 -0
  412. data/.data/spec/std/isa/csr/I/pmpcfg6.yaml +493 -0
  413. data/.data/spec/std/isa/csr/I/pmpcfg7.yaml +255 -0
  414. data/.data/spec/std/isa/csr/I/pmpcfg8.yaml +493 -0
  415. data/.data/spec/std/isa/csr/I/pmpcfg9.yaml +255 -0
  416. data/.data/spec/std/isa/csr/I/pmpcfgN.layout +90 -0
  417. data/.data/spec/std/isa/csr/S/scounteren.layout +103 -0
  418. data/.data/spec/std/isa/csr/S/scounteren.yaml +692 -0
  419. data/.data/spec/std/isa/csr/Smcntrpmf/mcyclecfg.yaml +97 -0
  420. data/.data/spec/std/isa/csr/Smcntrpmf/mcyclecfgh.yaml +69 -0
  421. data/.data/spec/std/isa/csr/Smcntrpmf/minstretcfg.yaml +94 -0
  422. data/.data/spec/std/isa/csr/Smcntrpmf/minstretcfgh.yaml +69 -0
  423. data/.data/spec/std/isa/csr/Smcsrind/mireg.yaml +63 -0
  424. data/.data/spec/std/isa/csr/Smcsrind/mireg2.yaml +63 -0
  425. data/.data/spec/std/isa/csr/Smcsrind/mireg3.yaml +63 -0
  426. data/.data/spec/std/isa/csr/Smcsrind/mireg4.yaml +63 -0
  427. data/.data/spec/std/isa/csr/Smcsrind/mireg5.yaml +63 -0
  428. data/.data/spec/std/isa/csr/Smcsrind/mireg6.yaml +63 -0
  429. data/.data/spec/std/isa/csr/Smcsrind/miselect.yaml +47 -0
  430. data/.data/spec/std/isa/csr/Smcsrind/sireg.yaml +63 -0
  431. data/.data/spec/std/isa/csr/Smcsrind/sireg2.yaml +63 -0
  432. data/.data/spec/std/isa/csr/Smcsrind/sireg3.yaml +63 -0
  433. data/.data/spec/std/isa/csr/Smcsrind/sireg4.yaml +63 -0
  434. data/.data/spec/std/isa/csr/Smcsrind/sireg5.yaml +63 -0
  435. data/.data/spec/std/isa/csr/Smcsrind/sireg6.yaml +63 -0
  436. data/.data/spec/std/isa/csr/Smcsrind/siselect.yaml +41 -0
  437. data/.data/spec/std/isa/csr/Smcsrind/vsireg.yaml +63 -0
  438. data/.data/spec/std/isa/csr/Smcsrind/vsireg2.yaml +62 -0
  439. data/.data/spec/std/isa/csr/Smcsrind/vsireg3.yaml +61 -0
  440. data/.data/spec/std/isa/csr/Smcsrind/vsireg4.yaml +61 -0
  441. data/.data/spec/std/isa/csr/Smcsrind/vsireg5.yaml +62 -0
  442. data/.data/spec/std/isa/csr/Smcsrind/vsireg6.yaml +62 -0
  443. data/.data/spec/std/isa/csr/Smcsrind/vsiselect.yaml +47 -0
  444. data/.data/spec/std/isa/csr/Smctr/mctrctl.yaml +223 -0
  445. data/.data/spec/std/isa/csr/Smctr/sctrctl.yaml +224 -0
  446. data/.data/spec/std/isa/csr/Smctr/vsctrctl.yaml +228 -0
  447. data/.data/spec/std/isa/csr/Smrnmi/mncause.yaml +49 -0
  448. data/.data/spec/std/isa/csr/Smrnmi/mnepc.yaml +54 -0
  449. data/.data/spec/std/isa/csr/Smrnmi/mnscratch.yaml +26 -0
  450. data/.data/spec/std/isa/csr/Smrnmi/mnstatus.yaml +109 -0
  451. data/.data/spec/std/isa/csr/Sscofpmf/scountovf.layout +64 -0
  452. data/.data/spec/std/isa/csr/Sscofpmf/scountovf.yaml +455 -0
  453. data/.data/spec/std/isa/csr/Ssqosid/srmcfg.yaml +116 -0
  454. data/.data/spec/std/isa/csr/V/vcsr.yaml +36 -0
  455. data/.data/spec/std/isa/csr/V/vl.yaml +33 -0
  456. data/.data/spec/std/isa/csr/V/vlenb.yaml +27 -0
  457. data/.data/spec/std/isa/csr/V/vstart.yaml +81 -0
  458. data/.data/spec/std/isa/csr/V/vtype.yaml +125 -0
  459. data/.data/spec/std/isa/csr/V/vxrm.yaml +48 -0
  460. data/.data/spec/std/isa/csr/V/vxsat.yaml +33 -0
  461. data/.data/spec/std/isa/csr/Zicntr/mcountinhibit.layout +86 -0
  462. data/.data/spec/std/isa/csr/Zicntr/mcountinhibit.yaml +507 -0
  463. data/.data/spec/std/isa/csr/Zihpm/hpmcounter10.yaml +67 -0
  464. data/.data/spec/std/isa/csr/Zihpm/hpmcounter10h.yaml +69 -0
  465. data/.data/spec/std/isa/csr/Zihpm/hpmcounter11.yaml +67 -0
  466. data/.data/spec/std/isa/csr/Zihpm/hpmcounter11h.yaml +69 -0
  467. data/.data/spec/std/isa/csr/Zihpm/hpmcounter12.yaml +67 -0
  468. data/.data/spec/std/isa/csr/Zihpm/hpmcounter12h.yaml +69 -0
  469. data/.data/spec/std/isa/csr/Zihpm/hpmcounter13.yaml +67 -0
  470. data/.data/spec/std/isa/csr/Zihpm/hpmcounter13h.yaml +69 -0
  471. data/.data/spec/std/isa/csr/Zihpm/hpmcounter14.yaml +67 -0
  472. data/.data/spec/std/isa/csr/Zihpm/hpmcounter14h.yaml +69 -0
  473. data/.data/spec/std/isa/csr/Zihpm/hpmcounter15.yaml +67 -0
  474. data/.data/spec/std/isa/csr/Zihpm/hpmcounter15h.yaml +69 -0
  475. data/.data/spec/std/isa/csr/Zihpm/hpmcounter16.yaml +67 -0
  476. data/.data/spec/std/isa/csr/Zihpm/hpmcounter16h.yaml +69 -0
  477. data/.data/spec/std/isa/csr/Zihpm/hpmcounter17.yaml +67 -0
  478. data/.data/spec/std/isa/csr/Zihpm/hpmcounter17h.yaml +69 -0
  479. data/.data/spec/std/isa/csr/Zihpm/hpmcounter18.yaml +67 -0
  480. data/.data/spec/std/isa/csr/Zihpm/hpmcounter18h.yaml +69 -0
  481. data/.data/spec/std/isa/csr/Zihpm/hpmcounter19.yaml +67 -0
  482. data/.data/spec/std/isa/csr/Zihpm/hpmcounter19h.yaml +69 -0
  483. data/.data/spec/std/isa/csr/Zihpm/hpmcounter20.yaml +67 -0
  484. data/.data/spec/std/isa/csr/Zihpm/hpmcounter20h.yaml +69 -0
  485. data/.data/spec/std/isa/csr/Zihpm/hpmcounter21.yaml +67 -0
  486. data/.data/spec/std/isa/csr/Zihpm/hpmcounter21h.yaml +69 -0
  487. data/.data/spec/std/isa/csr/Zihpm/hpmcounter22.yaml +67 -0
  488. data/.data/spec/std/isa/csr/Zihpm/hpmcounter22h.yaml +69 -0
  489. data/.data/spec/std/isa/csr/Zihpm/hpmcounter23.yaml +67 -0
  490. data/.data/spec/std/isa/csr/Zihpm/hpmcounter23h.yaml +69 -0
  491. data/.data/spec/std/isa/csr/Zihpm/hpmcounter24.yaml +67 -0
  492. data/.data/spec/std/isa/csr/Zihpm/hpmcounter24h.yaml +69 -0
  493. data/.data/spec/std/isa/csr/Zihpm/hpmcounter25.yaml +67 -0
  494. data/.data/spec/std/isa/csr/Zihpm/hpmcounter25h.yaml +69 -0
  495. data/.data/spec/std/isa/csr/Zihpm/hpmcounter26.yaml +67 -0
  496. data/.data/spec/std/isa/csr/Zihpm/hpmcounter26h.yaml +69 -0
  497. data/.data/spec/std/isa/csr/Zihpm/hpmcounter27.yaml +67 -0
  498. data/.data/spec/std/isa/csr/Zihpm/hpmcounter27h.yaml +69 -0
  499. data/.data/spec/std/isa/csr/Zihpm/hpmcounter28.yaml +67 -0
  500. data/.data/spec/std/isa/csr/Zihpm/hpmcounter28h.yaml +69 -0
  501. data/.data/spec/std/isa/csr/Zihpm/hpmcounter29.yaml +67 -0
  502. data/.data/spec/std/isa/csr/Zihpm/hpmcounter29h.yaml +69 -0
  503. data/.data/spec/std/isa/csr/Zihpm/hpmcounter3.yaml +67 -0
  504. data/.data/spec/std/isa/csr/Zihpm/hpmcounter30.yaml +67 -0
  505. data/.data/spec/std/isa/csr/Zihpm/hpmcounter30h.yaml +69 -0
  506. data/.data/spec/std/isa/csr/Zihpm/hpmcounter31.yaml +67 -0
  507. data/.data/spec/std/isa/csr/Zihpm/hpmcounter31h.yaml +69 -0
  508. data/.data/spec/std/isa/csr/Zihpm/hpmcounter3h.yaml +69 -0
  509. data/.data/spec/std/isa/csr/Zihpm/hpmcounter4.yaml +67 -0
  510. data/.data/spec/std/isa/csr/Zihpm/hpmcounter4h.yaml +69 -0
  511. data/.data/spec/std/isa/csr/Zihpm/hpmcounter5.yaml +67 -0
  512. data/.data/spec/std/isa/csr/Zihpm/hpmcounter5h.yaml +69 -0
  513. data/.data/spec/std/isa/csr/Zihpm/hpmcounter6.yaml +67 -0
  514. data/.data/spec/std/isa/csr/Zihpm/hpmcounter6h.yaml +69 -0
  515. data/.data/spec/std/isa/csr/Zihpm/hpmcounter7.yaml +67 -0
  516. data/.data/spec/std/isa/csr/Zihpm/hpmcounter7h.yaml +69 -0
  517. data/.data/spec/std/isa/csr/Zihpm/hpmcounter8.yaml +67 -0
  518. data/.data/spec/std/isa/csr/Zihpm/hpmcounter8h.yaml +69 -0
  519. data/.data/spec/std/isa/csr/Zihpm/hpmcounter9.yaml +67 -0
  520. data/.data/spec/std/isa/csr/Zihpm/hpmcounter9h.yaml +69 -0
  521. data/.data/spec/std/isa/csr/Zihpm/hpmcounterN.layout +65 -0
  522. data/.data/spec/std/isa/csr/Zihpm/hpmcounterNh.layout +67 -0
  523. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter10.yaml +106 -0
  524. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter10h.yaml +85 -0
  525. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter11.yaml +106 -0
  526. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter11h.yaml +85 -0
  527. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter12.yaml +106 -0
  528. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter12h.yaml +85 -0
  529. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter13.yaml +106 -0
  530. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter13h.yaml +85 -0
  531. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter14.yaml +106 -0
  532. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter14h.yaml +85 -0
  533. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter15.yaml +106 -0
  534. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter15h.yaml +85 -0
  535. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter16.yaml +106 -0
  536. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter16h.yaml +85 -0
  537. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter17.yaml +106 -0
  538. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter17h.yaml +85 -0
  539. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter18.yaml +106 -0
  540. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter18h.yaml +85 -0
  541. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter19.yaml +106 -0
  542. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter19h.yaml +85 -0
  543. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter20.yaml +106 -0
  544. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter20h.yaml +85 -0
  545. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter21.yaml +106 -0
  546. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter21h.yaml +85 -0
  547. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter22.yaml +106 -0
  548. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter22h.yaml +85 -0
  549. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter23.yaml +106 -0
  550. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter23h.yaml +85 -0
  551. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter24.yaml +106 -0
  552. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter24h.yaml +85 -0
  553. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter25.yaml +106 -0
  554. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter25h.yaml +85 -0
  555. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter26.yaml +106 -0
  556. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter26h.yaml +85 -0
  557. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter27.yaml +106 -0
  558. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter27h.yaml +85 -0
  559. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter28.yaml +106 -0
  560. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter28h.yaml +85 -0
  561. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter29.yaml +106 -0
  562. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter29h.yaml +85 -0
  563. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter3.yaml +106 -0
  564. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter30.yaml +106 -0
  565. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter30h.yaml +85 -0
  566. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter31.yaml +106 -0
  567. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter31h.yaml +85 -0
  568. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter3h.yaml +85 -0
  569. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter4.yaml +106 -0
  570. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter4h.yaml +85 -0
  571. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter5.yaml +106 -0
  572. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter5h.yaml +85 -0
  573. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter6.yaml +106 -0
  574. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter6h.yaml +85 -0
  575. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter7.yaml +106 -0
  576. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter7h.yaml +85 -0
  577. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter8.yaml +106 -0
  578. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter8h.yaml +85 -0
  579. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter9.yaml +106 -0
  580. data/.data/spec/std/isa/csr/Zihpm/mhpmcounter9h.yaml +85 -0
  581. data/.data/spec/std/isa/csr/Zihpm/mhpmcounterN.layout +104 -0
  582. data/.data/spec/std/isa/csr/Zihpm/mhpmcounterNh.layout +83 -0
  583. data/.data/spec/std/isa/csr/Zihpm/mhpmevent10.yaml +170 -0
  584. data/.data/spec/std/isa/csr/Zihpm/mhpmevent10h.yaml +163 -0
  585. data/.data/spec/std/isa/csr/Zihpm/mhpmevent11.yaml +170 -0
  586. data/.data/spec/std/isa/csr/Zihpm/mhpmevent11h.yaml +163 -0
  587. data/.data/spec/std/isa/csr/Zihpm/mhpmevent12.yaml +170 -0
  588. data/.data/spec/std/isa/csr/Zihpm/mhpmevent12h.yaml +163 -0
  589. data/.data/spec/std/isa/csr/Zihpm/mhpmevent13.yaml +170 -0
  590. data/.data/spec/std/isa/csr/Zihpm/mhpmevent13h.yaml +163 -0
  591. data/.data/spec/std/isa/csr/Zihpm/mhpmevent14.yaml +170 -0
  592. data/.data/spec/std/isa/csr/Zihpm/mhpmevent14h.yaml +163 -0
  593. data/.data/spec/std/isa/csr/Zihpm/mhpmevent15.yaml +170 -0
  594. data/.data/spec/std/isa/csr/Zihpm/mhpmevent15h.yaml +163 -0
  595. data/.data/spec/std/isa/csr/Zihpm/mhpmevent16.yaml +170 -0
  596. data/.data/spec/std/isa/csr/Zihpm/mhpmevent16h.yaml +163 -0
  597. data/.data/spec/std/isa/csr/Zihpm/mhpmevent17.yaml +170 -0
  598. data/.data/spec/std/isa/csr/Zihpm/mhpmevent17h.yaml +163 -0
  599. data/.data/spec/std/isa/csr/Zihpm/mhpmevent18.yaml +170 -0
  600. data/.data/spec/std/isa/csr/Zihpm/mhpmevent18h.yaml +163 -0
  601. data/.data/spec/std/isa/csr/Zihpm/mhpmevent19.yaml +170 -0
  602. data/.data/spec/std/isa/csr/Zihpm/mhpmevent19h.yaml +163 -0
  603. data/.data/spec/std/isa/csr/Zihpm/mhpmevent20.yaml +170 -0
  604. data/.data/spec/std/isa/csr/Zihpm/mhpmevent20h.yaml +163 -0
  605. data/.data/spec/std/isa/csr/Zihpm/mhpmevent21.yaml +170 -0
  606. data/.data/spec/std/isa/csr/Zihpm/mhpmevent21h.yaml +163 -0
  607. data/.data/spec/std/isa/csr/Zihpm/mhpmevent22.yaml +170 -0
  608. data/.data/spec/std/isa/csr/Zihpm/mhpmevent22h.yaml +163 -0
  609. data/.data/spec/std/isa/csr/Zihpm/mhpmevent23.yaml +170 -0
  610. data/.data/spec/std/isa/csr/Zihpm/mhpmevent23h.yaml +163 -0
  611. data/.data/spec/std/isa/csr/Zihpm/mhpmevent24.yaml +170 -0
  612. data/.data/spec/std/isa/csr/Zihpm/mhpmevent24h.yaml +163 -0
  613. data/.data/spec/std/isa/csr/Zihpm/mhpmevent25.yaml +170 -0
  614. data/.data/spec/std/isa/csr/Zihpm/mhpmevent25h.yaml +163 -0
  615. data/.data/spec/std/isa/csr/Zihpm/mhpmevent26.yaml +170 -0
  616. data/.data/spec/std/isa/csr/Zihpm/mhpmevent26h.yaml +163 -0
  617. data/.data/spec/std/isa/csr/Zihpm/mhpmevent27.yaml +170 -0
  618. data/.data/spec/std/isa/csr/Zihpm/mhpmevent27h.yaml +163 -0
  619. data/.data/spec/std/isa/csr/Zihpm/mhpmevent28.yaml +170 -0
  620. data/.data/spec/std/isa/csr/Zihpm/mhpmevent28h.yaml +163 -0
  621. data/.data/spec/std/isa/csr/Zihpm/mhpmevent29.yaml +170 -0
  622. data/.data/spec/std/isa/csr/Zihpm/mhpmevent29h.yaml +163 -0
  623. data/.data/spec/std/isa/csr/Zihpm/mhpmevent3.yaml +170 -0
  624. data/.data/spec/std/isa/csr/Zihpm/mhpmevent30.yaml +170 -0
  625. data/.data/spec/std/isa/csr/Zihpm/mhpmevent30h.yaml +163 -0
  626. data/.data/spec/std/isa/csr/Zihpm/mhpmevent31.yaml +170 -0
  627. data/.data/spec/std/isa/csr/Zihpm/mhpmevent31h.yaml +163 -0
  628. data/.data/spec/std/isa/csr/Zihpm/mhpmevent3h.yaml +163 -0
  629. data/.data/spec/std/isa/csr/Zihpm/mhpmevent4.yaml +170 -0
  630. data/.data/spec/std/isa/csr/Zihpm/mhpmevent4h.yaml +163 -0
  631. data/.data/spec/std/isa/csr/Zihpm/mhpmevent5.yaml +170 -0
  632. data/.data/spec/std/isa/csr/Zihpm/mhpmevent5h.yaml +163 -0
  633. data/.data/spec/std/isa/csr/Zihpm/mhpmevent6.yaml +170 -0
  634. data/.data/spec/std/isa/csr/Zihpm/mhpmevent6h.yaml +163 -0
  635. data/.data/spec/std/isa/csr/Zihpm/mhpmevent7.yaml +170 -0
  636. data/.data/spec/std/isa/csr/Zihpm/mhpmevent7h.yaml +163 -0
  637. data/.data/spec/std/isa/csr/Zihpm/mhpmevent8.yaml +170 -0
  638. data/.data/spec/std/isa/csr/Zihpm/mhpmevent8h.yaml +163 -0
  639. data/.data/spec/std/isa/csr/Zihpm/mhpmevent9.yaml +170 -0
  640. data/.data/spec/std/isa/csr/Zihpm/mhpmevent9h.yaml +163 -0
  641. data/.data/spec/std/isa/csr/Zihpm/mhpmeventN.layout +168 -0
  642. data/.data/spec/std/isa/csr/Zihpm/mhpmeventNh.layout +161 -0
  643. data/.data/spec/std/isa/csr/cycle.yaml +79 -0
  644. data/.data/spec/std/isa/csr/cycleh.yaml +86 -0
  645. data/.data/spec/std/isa/csr/dcsr.yaml +293 -0
  646. data/.data/spec/std/isa/csr/dpc.yaml +45 -0
  647. data/.data/spec/std/isa/csr/dscratch0.yaml +28 -0
  648. data/.data/spec/std/isa/csr/dscratch1.yaml +28 -0
  649. data/.data/spec/std/isa/csr/hcontext.yaml +64 -0
  650. data/.data/spec/std/isa/csr/hedeleg.yaml +243 -0
  651. data/.data/spec/std/isa/csr/hedelegh.yaml +23 -0
  652. data/.data/spec/std/isa/csr/hstateen0.yaml +220 -0
  653. data/.data/spec/std/isa/csr/hstateen0h.yaml +159 -0
  654. data/.data/spec/std/isa/csr/hstateen1.yaml +70 -0
  655. data/.data/spec/std/isa/csr/hstateen1h.yaml +47 -0
  656. data/.data/spec/std/isa/csr/hstateen2.yaml +70 -0
  657. data/.data/spec/std/isa/csr/hstateen2h.yaml +47 -0
  658. data/.data/spec/std/isa/csr/hstateen3.yaml +70 -0
  659. data/.data/spec/std/isa/csr/hstateen3h.yaml +47 -0
  660. data/.data/spec/std/isa/csr/hstatus.yaml +246 -0
  661. data/.data/spec/std/isa/csr/instret.yaml +77 -0
  662. data/.data/spec/std/isa/csr/instreth.yaml +81 -0
  663. data/.data/spec/std/isa/csr/jvt.yaml +89 -0
  664. data/.data/spec/std/isa/csr/marchid.yaml +58 -0
  665. data/.data/spec/std/isa/csr/mcause.yaml +94 -0
  666. data/.data/spec/std/isa/csr/mconfigptr.yaml +61 -0
  667. data/.data/spec/std/isa/csr/mcontext.yaml +55 -0
  668. data/.data/spec/std/isa/csr/mcycle.yaml +67 -0
  669. data/.data/spec/std/isa/csr/mcycleh.yaml +40 -0
  670. data/.data/spec/std/isa/csr/medeleg.yaml +672 -0
  671. data/.data/spec/std/isa/csr/medelegh.yaml +22 -0
  672. data/.data/spec/std/isa/csr/menvcfg.yaml +305 -0
  673. data/.data/spec/std/isa/csr/menvcfgh.yaml +59 -0
  674. data/.data/spec/std/isa/csr/mepc.yaml +54 -0
  675. data/.data/spec/std/isa/csr/mhartid.yaml +26 -0
  676. data/.data/spec/std/isa/csr/mideleg.yaml +204 -0
  677. data/.data/spec/std/isa/csr/mie.yaml +105 -0
  678. data/.data/spec/std/isa/csr/mimpid.yaml +41 -0
  679. data/.data/spec/std/isa/csr/minstret.yaml +54 -0
  680. data/.data/spec/std/isa/csr/minstreth.yaml +39 -0
  681. data/.data/spec/std/isa/csr/mip.yaml +434 -0
  682. data/.data/spec/std/isa/csr/misa.yaml +263 -0
  683. data/.data/spec/std/isa/csr/mscontext.yaml +42 -0
  684. data/.data/spec/std/isa/csr/mscratch.yaml +24 -0
  685. data/.data/spec/std/isa/csr/mseccfg.yaml +25 -0
  686. data/.data/spec/std/isa/csr/mseccfgh.yaml +28 -0
  687. data/.data/spec/std/isa/csr/mstateen0.yaml +182 -0
  688. data/.data/spec/std/isa/csr/mstateen0h.yaml +151 -0
  689. data/.data/spec/std/isa/csr/mstateen1.yaml +65 -0
  690. data/.data/spec/std/isa/csr/mstateen1h.yaml +37 -0
  691. data/.data/spec/std/isa/csr/mstateen2.yaml +65 -0
  692. data/.data/spec/std/isa/csr/mstateen2h.yaml +37 -0
  693. data/.data/spec/std/isa/csr/mstateen3.yaml +65 -0
  694. data/.data/spec/std/isa/csr/mstateen3h.yaml +37 -0
  695. data/.data/spec/std/isa/csr/mstatus.yaml +626 -0
  696. data/.data/spec/std/isa/csr/mstatush.yaml +88 -0
  697. data/.data/spec/std/isa/csr/mtval.yaml +105 -0
  698. data/.data/spec/std/isa/csr/mtvec.yaml +111 -0
  699. data/.data/spec/std/isa/csr/mvendorid.yaml +28 -0
  700. data/.data/spec/std/isa/csr/satp.yaml +184 -0
  701. data/.data/spec/std/isa/csr/scause.yaml +96 -0
  702. data/.data/spec/std/isa/csr/schema.adoc +223 -0
  703. data/.data/spec/std/isa/csr/scontext.yaml +52 -0
  704. data/.data/spec/std/isa/csr/senvcfg.yaml +157 -0
  705. data/.data/spec/std/isa/csr/sepc.yaml +51 -0
  706. data/.data/spec/std/isa/csr/sie.yaml +49 -0
  707. data/.data/spec/std/isa/csr/sip.yaml +160 -0
  708. data/.data/spec/std/isa/csr/sscratch.yaml +23 -0
  709. data/.data/spec/std/isa/csr/sstateen0.yaml +134 -0
  710. data/.data/spec/std/isa/csr/sstateen1.yaml +96 -0
  711. data/.data/spec/std/isa/csr/sstateen2.yaml +96 -0
  712. data/.data/spec/std/isa/csr/sstateen3.yaml +96 -0
  713. data/.data/spec/std/isa/csr/sstatus.yaml +149 -0
  714. data/.data/spec/std/isa/csr/stval.yaml +103 -0
  715. data/.data/spec/std/isa/csr/stvec.yaml +54 -0
  716. data/.data/spec/std/isa/csr/tdata1.yaml +68 -0
  717. data/.data/spec/std/isa/csr/tdata2.yaml +32 -0
  718. data/.data/spec/std/isa/csr/tdata3.yaml +32 -0
  719. data/.data/spec/std/isa/csr/time.yaml +89 -0
  720. data/.data/spec/std/isa/csr/timeh.yaml +90 -0
  721. data/.data/spec/std/isa/csr/tselect.yaml +36 -0
  722. data/.data/spec/std/isa/csr/vscause.yaml +97 -0
  723. data/.data/spec/std/isa/csr/vsepc.yaml +52 -0
  724. data/.data/spec/std/isa/csr/vsstatus.yaml +232 -0
  725. data/.data/spec/std/isa/csr/vstval.yaml +105 -0
  726. data/.data/spec/std/isa/csr/vstvec.yaml +55 -0
  727. data/.data/spec/std/isa/exception_code/Breakpoint.yaml +13 -0
  728. data/.data/spec/std/isa/exception_code/DoubleTrap.yaml +13 -0
  729. data/.data/spec/std/isa/exception_code/HardwareError.yaml +14 -0
  730. data/.data/spec/std/isa/exception_code/IllegalInstruction.yaml +13 -0
  731. data/.data/spec/std/isa/exception_code/InstructionAccessFault.yaml +13 -0
  732. data/.data/spec/std/isa/exception_code/InstructionAddressMisaligned.yaml +13 -0
  733. data/.data/spec/std/isa/exception_code/InstructionGuestPageFault.yaml +13 -0
  734. data/.data/spec/std/isa/exception_code/InstructionPageFault.yaml +13 -0
  735. data/.data/spec/std/isa/exception_code/LoadAccessFault.yaml +13 -0
  736. data/.data/spec/std/isa/exception_code/LoadAddressMisaligned.yaml +13 -0
  737. data/.data/spec/std/isa/exception_code/LoadGuestPageFault.yaml +13 -0
  738. data/.data/spec/std/isa/exception_code/LoadPageFault.yaml +13 -0
  739. data/.data/spec/std/isa/exception_code/Mcall.yaml +13 -0
  740. data/.data/spec/std/isa/exception_code/Scall.yaml +13 -0
  741. data/.data/spec/std/isa/exception_code/SoftwareCheck.yaml +14 -0
  742. data/.data/spec/std/isa/exception_code/StoreAmoAccessFault.yaml +13 -0
  743. data/.data/spec/std/isa/exception_code/StoreAmoAddressMisaligned.yaml +13 -0
  744. data/.data/spec/std/isa/exception_code/StoreAmoGuestPageFault.yaml +13 -0
  745. data/.data/spec/std/isa/exception_code/StoreAmoPageFault.yaml +13 -0
  746. data/.data/spec/std/isa/exception_code/Ucall.yaml +13 -0
  747. data/.data/spec/std/isa/exception_code/VScall.yaml +13 -0
  748. data/.data/spec/std/isa/exception_code/VirtualInstruction.yaml +13 -0
  749. data/.data/spec/std/isa/ext/A.yaml +79 -0
  750. data/.data/spec/std/isa/ext/B.yaml +41 -0
  751. data/.data/spec/std/isa/ext/C.yaml +318 -0
  752. data/.data/spec/std/isa/ext/D.yaml +109 -0
  753. data/.data/spec/std/isa/ext/F.yaml +243 -0
  754. data/.data/spec/std/isa/ext/H.yaml +126 -0
  755. data/.data/spec/std/isa/ext/I.yaml +18 -0
  756. data/.data/spec/std/isa/ext/M.yaml +26 -0
  757. data/.data/spec/std/isa/ext/Q.yaml +26 -0
  758. data/.data/spec/std/isa/ext/S.yaml +41 -0
  759. data/.data/spec/std/isa/ext/Sdext.yaml +16 -0
  760. data/.data/spec/std/isa/ext/Sdtrig.yaml +33 -0
  761. data/.data/spec/std/isa/ext/Sha.yaml +69 -0
  762. data/.data/spec/std/isa/ext/Shcounterenw.yaml +29 -0
  763. data/.data/spec/std/isa/ext/Shgatpa.yaml +42 -0
  764. data/.data/spec/std/isa/ext/Shtvala.yaml +29 -0
  765. data/.data/spec/std/isa/ext/Shvsatpa.yaml +19 -0
  766. data/.data/spec/std/isa/ext/Shvstvala.yaml +61 -0
  767. data/.data/spec/std/isa/ext/Shvstvecd.yaml +26 -0
  768. data/.data/spec/std/isa/ext/Sm.yaml +104 -0
  769. data/.data/spec/std/isa/ext/Smaia.yaml +16 -0
  770. data/.data/spec/std/isa/ext/Smcdeleg.yaml +40 -0
  771. data/.data/spec/std/isa/ext/Smcntrpmf.yaml +16 -0
  772. data/.data/spec/std/isa/ext/Smcsrind.yaml +45 -0
  773. data/.data/spec/std/isa/ext/Smctr.yaml +58 -0
  774. data/.data/spec/std/isa/ext/Smdbltrp.yaml +25 -0
  775. data/.data/spec/std/isa/ext/Smepmp.yaml +36 -0
  776. data/.data/spec/std/isa/ext/Smhpm.yaml +29 -0
  777. data/.data/spec/std/isa/ext/Smmpm.yaml +16 -0
  778. data/.data/spec/std/isa/ext/Smnpm.yaml +17 -0
  779. data/.data/spec/std/isa/ext/Smpmp.yaml +42 -0
  780. data/.data/spec/std/isa/ext/Smrnmi.yaml +24 -0
  781. data/.data/spec/std/isa/ext/Smstateen.yaml +28 -0
  782. data/.data/spec/std/isa/ext/Ssaia.yaml +20 -0
  783. data/.data/spec/std/isa/ext/Ssccfg.yaml +16 -0
  784. data/.data/spec/std/isa/ext/Ssccptr.yaml +26 -0
  785. data/.data/spec/std/isa/ext/Sscofpmf.yaml +19 -0
  786. data/.data/spec/std/isa/ext/Sscounterenw.yaml +30 -0
  787. data/.data/spec/std/isa/ext/Sscsrind.yaml +48 -0
  788. data/.data/spec/std/isa/ext/Ssctr.yaml +23 -0
  789. data/.data/spec/std/isa/ext/Ssdbltrp.yaml +25 -0
  790. data/.data/spec/std/isa/ext/Ssnpm.yaml +17 -0
  791. data/.data/spec/std/isa/ext/Sspm.yaml +23 -0
  792. data/.data/spec/std/isa/ext/Ssqosid.yaml +40 -0
  793. data/.data/spec/std/isa/ext/Ssstateen.yaml +31 -0
  794. data/.data/spec/std/isa/ext/Ssstrict.yaml +52 -0
  795. data/.data/spec/std/isa/ext/Sstc.yaml +16 -0
  796. data/.data/spec/std/isa/ext/Sstvala.yaml +57 -0
  797. data/.data/spec/std/isa/ext/Sstvecd.yaml +29 -0
  798. data/.data/spec/std/isa/ext/Sstvecv.yaml +30 -0
  799. data/.data/spec/std/isa/ext/Ssu32xl.yaml +22 -0
  800. data/.data/spec/std/isa/ext/Ssu64xl.yaml +23 -0
  801. data/.data/spec/std/isa/ext/Ssube.yaml +25 -0
  802. data/.data/spec/std/isa/ext/Supm.yaml +23 -0
  803. data/.data/spec/std/isa/ext/Sv32.yaml +34 -0
  804. data/.data/spec/std/isa/ext/Sv39.yaml +34 -0
  805. data/.data/spec/std/isa/ext/Sv48.yaml +34 -0
  806. data/.data/spec/std/isa/ext/Sv57.yaml +34 -0
  807. data/.data/spec/std/isa/ext/Svade.yaml +53 -0
  808. data/.data/spec/std/isa/ext/Svadu.yaml +136 -0
  809. data/.data/spec/std/isa/ext/Svbare.yaml +28 -0
  810. data/.data/spec/std/isa/ext/Svinval.yaml +86 -0
  811. data/.data/spec/std/isa/ext/Svnapot.yaml +183 -0
  812. data/.data/spec/std/isa/ext/Svpbmt.yaml +29 -0
  813. data/.data/spec/std/isa/ext/Svrsw60t59b.yaml +39 -0
  814. data/.data/spec/std/isa/ext/Svvptc.yaml +37 -0
  815. data/.data/spec/std/isa/ext/U.yaml +17 -0
  816. data/.data/spec/std/isa/ext/V.yaml +21 -0
  817. data/.data/spec/std/isa/ext/Xmock.yaml +30 -0
  818. data/.data/spec/std/isa/ext/Za128rs.yaml +30 -0
  819. data/.data/spec/std/isa/ext/Za64rs.yaml +32 -0
  820. data/.data/spec/std/isa/ext/Zaamo.yaml +136 -0
  821. data/.data/spec/std/isa/ext/Zabha.yaml +19 -0
  822. data/.data/spec/std/isa/ext/Zacas.yaml +19 -0
  823. data/.data/spec/std/isa/ext/Zalasr.yaml +16 -0
  824. data/.data/spec/std/isa/ext/Zalrsc.yaml +316 -0
  825. data/.data/spec/std/isa/ext/Zama16b.yaml +24 -0
  826. data/.data/spec/std/isa/ext/Zawrs.yaml +25 -0
  827. data/.data/spec/std/isa/ext/Zba.yaml +66 -0
  828. data/.data/spec/std/isa/ext/Zbb.yaml +54 -0
  829. data/.data/spec/std/isa/ext/Zbc.yaml +54 -0
  830. data/.data/spec/std/isa/ext/Zbkb.yaml +18 -0
  831. data/.data/spec/std/isa/ext/Zbkc.yaml +23 -0
  832. data/.data/spec/std/isa/ext/Zbkx.yaml +24 -0
  833. data/.data/spec/std/isa/ext/Zbs.yaml +59 -0
  834. data/.data/spec/std/isa/ext/Zca.yaml +46 -0
  835. data/.data/spec/std/isa/ext/Zcb.yaml +45 -0
  836. data/.data/spec/std/isa/ext/Zcd.yaml +47 -0
  837. data/.data/spec/std/isa/ext/Zce.yaml +99 -0
  838. data/.data/spec/std/isa/ext/Zcf.yaml +46 -0
  839. data/.data/spec/std/isa/ext/Zclsd.yaml +28 -0
  840. data/.data/spec/std/isa/ext/Zcmop.yaml +58 -0
  841. data/.data/spec/std/isa/ext/Zcmp.yaml +100 -0
  842. data/.data/spec/std/isa/ext/Zcmt.yaml +75 -0
  843. data/.data/spec/std/isa/ext/Zdinx.yaml +49 -0
  844. data/.data/spec/std/isa/ext/Zfa.yaml +24 -0
  845. data/.data/spec/std/isa/ext/Zfbfmin.yaml +27 -0
  846. data/.data/spec/std/isa/ext/Zfh.yaml +24 -0
  847. data/.data/spec/std/isa/ext/Zfhmin.yaml +55 -0
  848. data/.data/spec/std/isa/ext/Zfinx.yaml +56 -0
  849. data/.data/spec/std/isa/ext/Zhinx.yaml +26 -0
  850. data/.data/spec/std/isa/ext/Zhinxmin.yaml +29 -0
  851. data/.data/spec/std/isa/ext/Zic64b.yaml +31 -0
  852. data/.data/spec/std/isa/ext/Zicbom.yaml +15 -0
  853. data/.data/spec/std/isa/ext/Zicbop.yaml +15 -0
  854. data/.data/spec/std/isa/ext/Zicboz.yaml +15 -0
  855. data/.data/spec/std/isa/ext/Ziccamoa.yaml +19 -0
  856. data/.data/spec/std/isa/ext/Ziccamoc.yaml +23 -0
  857. data/.data/spec/std/isa/ext/Ziccif.yaml +21 -0
  858. data/.data/spec/std/isa/ext/Zicclsm.yaml +31 -0
  859. data/.data/spec/std/isa/ext/Ziccrse.yaml +19 -0
  860. data/.data/spec/std/isa/ext/Zicfilp.yaml +16 -0
  861. data/.data/spec/std/isa/ext/Zicfiss.yaml +16 -0
  862. data/.data/spec/std/isa/ext/Zicntr.yaml +20 -0
  863. data/.data/spec/std/isa/ext/Zicond.yaml +24 -0
  864. data/.data/spec/std/isa/ext/Zicsr.yaml +15 -0
  865. data/.data/spec/std/isa/ext/Zifencei.yaml +75 -0
  866. data/.data/spec/std/isa/ext/Zihintntl.yaml +201 -0
  867. data/.data/spec/std/isa/ext/Zihintpause.yaml +76 -0
  868. data/.data/spec/std/isa/ext/Zihpm.yaml +18 -0
  869. data/.data/spec/std/isa/ext/Zilsd.yaml +20 -0
  870. data/.data/spec/std/isa/ext/Zimop.yaml +70 -0
  871. data/.data/spec/std/isa/ext/Zk.yaml +42 -0
  872. data/.data/spec/std/isa/ext/Zkn.yaml +57 -0
  873. data/.data/spec/std/isa/ext/Zknd.yaml +19 -0
  874. data/.data/spec/std/isa/ext/Zkne.yaml +19 -0
  875. data/.data/spec/std/isa/ext/Zknh.yaml +19 -0
  876. data/.data/spec/std/isa/ext/Zkr.yaml +20 -0
  877. data/.data/spec/std/isa/ext/Zks.yaml +53 -0
  878. data/.data/spec/std/isa/ext/Zksed.yaml +20 -0
  879. data/.data/spec/std/isa/ext/Zksh.yaml +19 -0
  880. data/.data/spec/std/isa/ext/Zkt.yaml +365 -0
  881. data/.data/spec/std/isa/ext/Zmmul.yaml +28 -0
  882. data/.data/spec/std/isa/ext/Ztso.yaml +23 -0
  883. data/.data/spec/std/isa/ext/Zvbb.yaml +20 -0
  884. data/.data/spec/std/isa/ext/Zvbc.yaml +19 -0
  885. data/.data/spec/std/isa/ext/Zve32f.yaml +34 -0
  886. data/.data/spec/std/isa/ext/Zve32x.yaml +38 -0
  887. data/.data/spec/std/isa/ext/Zve64d.yaml +35 -0
  888. data/.data/spec/std/isa/ext/Zve64f.yaml +33 -0
  889. data/.data/spec/std/isa/ext/Zve64x.yaml +35 -0
  890. data/.data/spec/std/isa/ext/Zvfbfmin.yaml +23 -0
  891. data/.data/spec/std/isa/ext/Zvfbfwma.yaml +23 -0
  892. data/.data/spec/std/isa/ext/Zvfh.yaml +43 -0
  893. data/.data/spec/std/isa/ext/Zvfhmin.yaml +26 -0
  894. data/.data/spec/std/isa/ext/Zvkb.yaml +16 -0
  895. data/.data/spec/std/isa/ext/Zvkg.yaml +26 -0
  896. data/.data/spec/std/isa/ext/Zvkn.yaml +32 -0
  897. data/.data/spec/std/isa/ext/Zvknc.yaml +27 -0
  898. data/.data/spec/std/isa/ext/Zvkned.yaml +22 -0
  899. data/.data/spec/std/isa/ext/Zvkng.yaml +27 -0
  900. data/.data/spec/std/isa/ext/Zvknha.yaml +17 -0
  901. data/.data/spec/std/isa/ext/Zvknhb.yaml +21 -0
  902. data/.data/spec/std/isa/ext/Zvks.yaml +32 -0
  903. data/.data/spec/std/isa/ext/Zvksc.yaml +27 -0
  904. data/.data/spec/std/isa/ext/Zvksed.yaml +24 -0
  905. data/.data/spec/std/isa/ext/Zvksg.yaml +27 -0
  906. data/.data/spec/std/isa/ext/Zvksh.yaml +20 -0
  907. data/.data/spec/std/isa/ext/Zvkt.yaml +28 -0
  908. data/.data/spec/std/isa/ext/Zvl1024b.yaml +30 -0
  909. data/.data/spec/std/isa/ext/Zvl128b.yaml +31 -0
  910. data/.data/spec/std/isa/ext/Zvl256b.yaml +30 -0
  911. data/.data/spec/std/isa/ext/Zvl32b.yaml +28 -0
  912. data/.data/spec/std/isa/ext/Zvl512b.yaml +30 -0
  913. data/.data/spec/std/isa/ext/Zvl64b.yaml +31 -0
  914. data/.data/spec/std/isa/inst/B/andn.yaml +69 -0
  915. data/.data/spec/std/isa/inst/B/clmul.yaml +66 -0
  916. data/.data/spec/std/isa/inst/B/clmulh.yaml +66 -0
  917. data/.data/spec/std/isa/inst/B/orn.yaml +68 -0
  918. data/.data/spec/std/isa/inst/B/rev8.yaml +77 -0
  919. data/.data/spec/std/isa/inst/B/rol.yaml +70 -0
  920. data/.data/spec/std/isa/inst/B/rolw.yaml +65 -0
  921. data/.data/spec/std/isa/inst/B/ror.yaml +70 -0
  922. data/.data/spec/std/isa/inst/B/rori.yaml +66 -0
  923. data/.data/spec/std/isa/inst/B/roriw.yaml +58 -0
  924. data/.data/spec/std/isa/inst/B/rorw.yaml +65 -0
  925. data/.data/spec/std/isa/inst/B/xnor.yaml +68 -0
  926. data/.data/spec/std/isa/inst/C/c.add.yaml +52 -0
  927. data/.data/spec/std/isa/inst/C/c.addi.yaml +38 -0
  928. data/.data/spec/std/isa/inst/C/c.addi16sp.yaml +36 -0
  929. data/.data/spec/std/isa/inst/C/c.addi4spn.yaml +38 -0
  930. data/.data/spec/std/isa/inst/C/c.addiw.yaml +39 -0
  931. data/.data/spec/std/isa/inst/C/c.addw.yaml +55 -0
  932. data/.data/spec/std/isa/inst/C/c.and.yaml +64 -0
  933. data/.data/spec/std/isa/inst/C/c.andi.yaml +53 -0
  934. data/.data/spec/std/isa/inst/C/c.beqz.yaml +75 -0
  935. data/.data/spec/std/isa/inst/C/c.bnez.yaml +75 -0
  936. data/.data/spec/std/isa/inst/C/c.ebreak.yaml +53 -0
  937. data/.data/spec/std/isa/inst/C/c.j.yaml +34 -0
  938. data/.data/spec/std/isa/inst/C/c.jal.yaml +39 -0
  939. data/.data/spec/std/isa/inst/C/c.jalr.yaml +37 -0
  940. data/.data/spec/std/isa/inst/C/c.jr.yaml +33 -0
  941. data/.data/spec/std/isa/inst/C/c.ld.yaml +101 -0
  942. data/.data/spec/std/isa/inst/C/c.ldsp.yaml +64 -0
  943. data/.data/spec/std/isa/inst/C/c.li.yaml +36 -0
  944. data/.data/spec/std/isa/inst/C/c.lui.yaml +38 -0
  945. data/.data/spec/std/isa/inst/C/c.lw.yaml +74 -0
  946. data/.data/spec/std/isa/inst/C/c.lwsp.yaml +41 -0
  947. data/.data/spec/std/isa/inst/C/c.mv.yaml +48 -0
  948. data/.data/spec/std/isa/inst/C/c.nop.yaml +26 -0
  949. data/.data/spec/std/isa/inst/C/c.or.yaml +64 -0
  950. data/.data/spec/std/isa/inst/C/c.sd.yaml +67 -0
  951. data/.data/spec/std/isa/inst/C/c.sdsp.yaml +63 -0
  952. data/.data/spec/std/isa/inst/C/c.slli.yaml +65 -0
  953. data/.data/spec/std/isa/inst/C/c.srai.yaml +66 -0
  954. data/.data/spec/std/isa/inst/C/c.srli.yaml +66 -0
  955. data/.data/spec/std/isa/inst/C/c.sub.yaml +64 -0
  956. data/.data/spec/std/isa/inst/C/c.subw.yaml +55 -0
  957. data/.data/spec/std/isa/inst/C/c.sw.yaml +41 -0
  958. data/.data/spec/std/isa/inst/C/c.swsp.yaml +39 -0
  959. data/.data/spec/std/isa/inst/C/c.xor.yaml +64 -0
  960. data/.data/spec/std/isa/inst/D/fadd.d.yaml +36 -0
  961. data/.data/spec/std/isa/inst/D/fclass.d.yaml +53 -0
  962. data/.data/spec/std/isa/inst/D/fcvt.d.l.yaml +36 -0
  963. data/.data/spec/std/isa/inst/D/fcvt.d.lu.yaml +36 -0
  964. data/.data/spec/std/isa/inst/D/fcvt.d.s.yaml +36 -0
  965. data/.data/spec/std/isa/inst/D/fcvt.d.w.yaml +35 -0
  966. data/.data/spec/std/isa/inst/D/fcvt.d.wu.yaml +35 -0
  967. data/.data/spec/std/isa/inst/D/fcvt.l.d.yaml +36 -0
  968. data/.data/spec/std/isa/inst/D/fcvt.lu.d.yaml +36 -0
  969. data/.data/spec/std/isa/inst/D/fcvt.s.d.yaml +36 -0
  970. data/.data/spec/std/isa/inst/D/fcvt.w.d.yaml +34 -0
  971. data/.data/spec/std/isa/inst/D/fcvt.wu.d.yaml +34 -0
  972. data/.data/spec/std/isa/inst/D/fcvtmod.w.d.yaml +42 -0
  973. data/.data/spec/std/isa/inst/D/fdiv.d.yaml +36 -0
  974. data/.data/spec/std/isa/inst/D/feq.d.yaml +34 -0
  975. data/.data/spec/std/isa/inst/D/fld.yaml +34 -0
  976. data/.data/spec/std/isa/inst/D/fle.d.yaml +34 -0
  977. data/.data/spec/std/isa/inst/D/fleq.d.yaml +34 -0
  978. data/.data/spec/std/isa/inst/D/fli.d.yaml +32 -0
  979. data/.data/spec/std/isa/inst/D/flt.d.yaml +34 -0
  980. data/.data/spec/std/isa/inst/D/fltq.d.yaml +34 -0
  981. data/.data/spec/std/isa/inst/D/fmadd.d.yaml +37 -0
  982. data/.data/spec/std/isa/inst/D/fmax.d.yaml +36 -0
  983. data/.data/spec/std/isa/inst/D/fmaxm.d.yaml +34 -0
  984. data/.data/spec/std/isa/inst/D/fmin.d.yaml +36 -0
  985. data/.data/spec/std/isa/inst/D/fminm.d.yaml +34 -0
  986. data/.data/spec/std/isa/inst/D/fmsub.d.yaml +37 -0
  987. data/.data/spec/std/isa/inst/D/fmul.d.yaml +37 -0
  988. data/.data/spec/std/isa/inst/D/fmv.d.x.yaml +32 -0
  989. data/.data/spec/std/isa/inst/D/fmv.x.d.yaml +32 -0
  990. data/.data/spec/std/isa/inst/D/fmvh.x.d.yaml +35 -0
  991. data/.data/spec/std/isa/inst/D/fmvp.d.x.yaml +37 -0
  992. data/.data/spec/std/isa/inst/D/fnmadd.d.yaml +38 -0
  993. data/.data/spec/std/isa/inst/D/fnmsub.d.yaml +38 -0
  994. data/.data/spec/std/isa/inst/D/fround.d.yaml +38 -0
  995. data/.data/spec/std/isa/inst/D/froundnx.d.yaml +34 -0
  996. data/.data/spec/std/isa/inst/D/fsd.yaml +33 -0
  997. data/.data/spec/std/isa/inst/D/fsgnj.d.yaml +36 -0
  998. data/.data/spec/std/isa/inst/D/fsgnjn.d.yaml +36 -0
  999. data/.data/spec/std/isa/inst/D/fsgnjx.d.yaml +36 -0
  1000. data/.data/spec/std/isa/inst/D/fsqrt.d.yaml +35 -0
  1001. data/.data/spec/std/isa/inst/D/fsub.d.yaml +36 -0
  1002. data/.data/spec/std/isa/inst/F/fadd.s.yaml +63 -0
  1003. data/.data/spec/std/isa/inst/F/fclass.s.yaml +90 -0
  1004. data/.data/spec/std/isa/inst/F/fcvt.l.s.yaml +56 -0
  1005. data/.data/spec/std/isa/inst/F/fcvt.lu.s.yaml +56 -0
  1006. data/.data/spec/std/isa/inst/F/fcvt.s.l.yaml +56 -0
  1007. data/.data/spec/std/isa/inst/F/fcvt.s.lu.yaml +55 -0
  1008. data/.data/spec/std/isa/inst/F/fcvt.s.w.yaml +67 -0
  1009. data/.data/spec/std/isa/inst/F/fcvt.s.wu.yaml +66 -0
  1010. data/.data/spec/std/isa/inst/F/fcvt.w.s.yaml +85 -0
  1011. data/.data/spec/std/isa/inst/F/fcvt.wu.s.yaml +83 -0
  1012. data/.data/spec/std/isa/inst/F/fdiv.s.yaml +60 -0
  1013. data/.data/spec/std/isa/inst/F/feq.s.yaml +68 -0
  1014. data/.data/spec/std/isa/inst/F/fle.s.yaml +68 -0
  1015. data/.data/spec/std/isa/inst/F/fleq.s.yaml +50 -0
  1016. data/.data/spec/std/isa/inst/F/flt.s.yaml +70 -0
  1017. data/.data/spec/std/isa/inst/F/fltq.s.yaml +50 -0
  1018. data/.data/spec/std/isa/inst/F/flw.yaml +80 -0
  1019. data/.data/spec/std/isa/inst/F/fmadd.s.yaml +63 -0
  1020. data/.data/spec/std/isa/inst/F/fmax.s.yaml +59 -0
  1021. data/.data/spec/std/isa/inst/F/fmin.s.yaml +59 -0
  1022. data/.data/spec/std/isa/inst/F/fmsub.s.yaml +63 -0
  1023. data/.data/spec/std/isa/inst/F/fmul.s.yaml +60 -0
  1024. data/.data/spec/std/isa/inst/F/fmv.w.x.yaml +55 -0
  1025. data/.data/spec/std/isa/inst/F/fmv.x.w.yaml +48 -0
  1026. data/.data/spec/std/isa/inst/F/fnmadd.s.yaml +64 -0
  1027. data/.data/spec/std/isa/inst/F/fnmsub.s.yaml +64 -0
  1028. data/.data/spec/std/isa/inst/F/fsgnj.s.yaml +68 -0
  1029. data/.data/spec/std/isa/inst/F/fsgnjn.s.yaml +67 -0
  1030. data/.data/spec/std/isa/inst/F/fsgnjx.s.yaml +66 -0
  1031. data/.data/spec/std/isa/inst/F/fsqrt.s.yaml +53 -0
  1032. data/.data/spec/std/isa/inst/F/fsub.s.yaml +61 -0
  1033. data/.data/spec/std/isa/inst/F/fsw.yaml +82 -0
  1034. data/.data/spec/std/isa/inst/H/hfence.gvma.yaml +33 -0
  1035. data/.data/spec/std/isa/inst/H/hfence.vvma.yaml +34 -0
  1036. data/.data/spec/std/isa/inst/H/hlv.b.yaml +30 -0
  1037. data/.data/spec/std/isa/inst/H/hlv.bu.yaml +30 -0
  1038. data/.data/spec/std/isa/inst/H/hlv.d.yaml +32 -0
  1039. data/.data/spec/std/isa/inst/H/hlv.h.yaml +30 -0
  1040. data/.data/spec/std/isa/inst/H/hlv.hu.yaml +30 -0
  1041. data/.data/spec/std/isa/inst/H/hlv.w.yaml +30 -0
  1042. data/.data/spec/std/isa/inst/H/hlv.wu.yaml +32 -0
  1043. data/.data/spec/std/isa/inst/H/hlvx.hu.yaml +32 -0
  1044. data/.data/spec/std/isa/inst/H/hlvx.wu.yaml +32 -0
  1045. data/.data/spec/std/isa/inst/H/hsv.b.yaml +30 -0
  1046. data/.data/spec/std/isa/inst/H/hsv.d.yaml +32 -0
  1047. data/.data/spec/std/isa/inst/H/hsv.h.yaml +30 -0
  1048. data/.data/spec/std/isa/inst/H/hsv.w.yaml +30 -0
  1049. data/.data/spec/std/isa/inst/I/add.yaml +68 -0
  1050. data/.data/spec/std/isa/inst/I/addi.yaml +58 -0
  1051. data/.data/spec/std/isa/inst/I/addiw.yaml +50 -0
  1052. data/.data/spec/std/isa/inst/I/addw.yaml +57 -0
  1053. data/.data/spec/std/isa/inst/I/and.yaml +61 -0
  1054. data/.data/spec/std/isa/inst/I/andi.yaml +54 -0
  1055. data/.data/spec/std/isa/inst/I/auipc.yaml +47 -0
  1056. data/.data/spec/std/isa/inst/I/beq.yaml +82 -0
  1057. data/.data/spec/std/isa/inst/I/bge.yaml +84 -0
  1058. data/.data/spec/std/isa/inst/I/bgeu.yaml +79 -0
  1059. data/.data/spec/std/isa/inst/I/blt.yaml +84 -0
  1060. data/.data/spec/std/isa/inst/I/bltu.yaml +79 -0
  1061. data/.data/spec/std/isa/inst/I/bne.yaml +82 -0
  1062. data/.data/spec/std/isa/inst/I/ebreak.yaml +50 -0
  1063. data/.data/spec/std/isa/inst/I/ecall.yaml +81 -0
  1064. data/.data/spec/std/isa/inst/I/fence.tso.yaml +52 -0
  1065. data/.data/spec/std/isa/inst/I/fence.yaml +224 -0
  1066. data/.data/spec/std/isa/inst/I/jal.yaml +69 -0
  1067. data/.data/spec/std/isa/inst/I/jalr.yaml +79 -0
  1068. data/.data/spec/std/isa/inst/I/lb.yaml +68 -0
  1069. data/.data/spec/std/isa/inst/I/lbu.yaml +68 -0
  1070. data/.data/spec/std/isa/inst/I/ld.yaml +98 -0
  1071. data/.data/spec/std/isa/inst/I/lh.yaml +68 -0
  1072. data/.data/spec/std/isa/inst/I/lhu.yaml +68 -0
  1073. data/.data/spec/std/isa/inst/I/lui.yaml +45 -0
  1074. data/.data/spec/std/isa/inst/I/lw.yaml +68 -0
  1075. data/.data/spec/std/isa/inst/I/lwu.yaml +70 -0
  1076. data/.data/spec/std/isa/inst/I/mret.yaml +61 -0
  1077. data/.data/spec/std/isa/inst/I/or.yaml +61 -0
  1078. data/.data/spec/std/isa/inst/I/ori.yaml +56 -0
  1079. data/.data/spec/std/isa/inst/I/sb.yaml +82 -0
  1080. data/.data/spec/std/isa/inst/I/sd.yaml +110 -0
  1081. data/.data/spec/std/isa/inst/I/sh.yaml +82 -0
  1082. data/.data/spec/std/isa/inst/I/sll.yaml +67 -0
  1083. data/.data/spec/std/isa/inst/I/slli.yaml +66 -0
  1084. data/.data/spec/std/isa/inst/I/slliw.yaml +53 -0
  1085. data/.data/spec/std/isa/inst/I/sllw.yaml +53 -0
  1086. data/.data/spec/std/isa/inst/I/slt.yaml +72 -0
  1087. data/.data/spec/std/isa/inst/I/slti.yaml +54 -0
  1088. data/.data/spec/std/isa/inst/I/sltiu.yaml +62 -0
  1089. data/.data/spec/std/isa/inst/I/sltu.yaml +67 -0
  1090. data/.data/spec/std/isa/inst/I/sra.yaml +67 -0
  1091. data/.data/spec/std/isa/inst/I/srai.yaml +68 -0
  1092. data/.data/spec/std/isa/inst/I/sraiw.yaml +54 -0
  1093. data/.data/spec/std/isa/inst/I/sraw.yaml +56 -0
  1094. data/.data/spec/std/isa/inst/I/srl.yaml +67 -0
  1095. data/.data/spec/std/isa/inst/I/srli.yaml +65 -0
  1096. data/.data/spec/std/isa/inst/I/srliw.yaml +55 -0
  1097. data/.data/spec/std/isa/inst/I/srlw.yaml +53 -0
  1098. data/.data/spec/std/isa/inst/I/sub.yaml +67 -0
  1099. data/.data/spec/std/isa/inst/I/subw.yaml +60 -0
  1100. data/.data/spec/std/isa/inst/I/sw.yaml +82 -0
  1101. data/.data/spec/std/isa/inst/I/wfi.yaml +131 -0
  1102. data/.data/spec/std/isa/inst/I/xor.yaml +61 -0
  1103. data/.data/spec/std/isa/inst/I/xori.yaml +56 -0
  1104. data/.data/spec/std/isa/inst/M/div.yaml +82 -0
  1105. data/.data/spec/std/isa/inst/M/divu.yaml +71 -0
  1106. data/.data/spec/std/isa/inst/M/divuw.yaml +78 -0
  1107. data/.data/spec/std/isa/inst/M/divw.yaml +85 -0
  1108. data/.data/spec/std/isa/inst/M/mul.yaml +95 -0
  1109. data/.data/spec/std/isa/inst/M/mulh.yaml +80 -0
  1110. data/.data/spec/std/isa/inst/M/mulhsu.yaml +77 -0
  1111. data/.data/spec/std/isa/inst/M/mulhu.yaml +76 -0
  1112. data/.data/spec/std/isa/inst/M/mulw.yaml +79 -0
  1113. data/.data/spec/std/isa/inst/M/rem.yaml +76 -0
  1114. data/.data/spec/std/isa/inst/M/remu.yaml +66 -0
  1115. data/.data/spec/std/isa/inst/M/remuw.yaml +79 -0
  1116. data/.data/spec/std/isa/inst/M/remw.yaml +84 -0
  1117. data/.data/spec/std/isa/inst/Q/fadd.q.yaml +34 -0
  1118. data/.data/spec/std/isa/inst/Q/fclass.q.yaml +53 -0
  1119. data/.data/spec/std/isa/inst/Q/fcvt.d.q.yaml +31 -0
  1120. data/.data/spec/std/isa/inst/Q/fcvt.h.q.yaml +33 -0
  1121. data/.data/spec/std/isa/inst/Q/fcvt.l.q.yaml +33 -0
  1122. data/.data/spec/std/isa/inst/Q/fcvt.lu.q.yaml +33 -0
  1123. data/.data/spec/std/isa/inst/Q/fcvt.q.d.yaml +31 -0
  1124. data/.data/spec/std/isa/inst/Q/fcvt.q.h.yaml +33 -0
  1125. data/.data/spec/std/isa/inst/Q/fcvt.q.l.yaml +33 -0
  1126. data/.data/spec/std/isa/inst/Q/fcvt.q.lu.yaml +33 -0
  1127. data/.data/spec/std/isa/inst/Q/fcvt.q.s.yaml +31 -0
  1128. data/.data/spec/std/isa/inst/Q/fcvt.q.w.yaml +31 -0
  1129. data/.data/spec/std/isa/inst/Q/fcvt.q.wu.yaml +31 -0
  1130. data/.data/spec/std/isa/inst/Q/fcvt.s.q.yaml +31 -0
  1131. data/.data/spec/std/isa/inst/Q/fcvt.w.q.yaml +31 -0
  1132. data/.data/spec/std/isa/inst/Q/fcvt.wu.q.yaml +31 -0
  1133. data/.data/spec/std/isa/inst/Q/fdiv.q.yaml +40 -0
  1134. data/.data/spec/std/isa/inst/Q/feq.q.yaml +37 -0
  1135. data/.data/spec/std/isa/inst/Q/fle.q.yaml +37 -0
  1136. data/.data/spec/std/isa/inst/Q/fleq.q.yaml +38 -0
  1137. data/.data/spec/std/isa/inst/Q/fli.q.yaml +33 -0
  1138. data/.data/spec/std/isa/inst/Q/flq.yaml +37 -0
  1139. data/.data/spec/std/isa/inst/Q/flt.q.yaml +38 -0
  1140. data/.data/spec/std/isa/inst/Q/fltq.q.yaml +38 -0
  1141. data/.data/spec/std/isa/inst/Q/fmadd.q.yaml +40 -0
  1142. data/.data/spec/std/isa/inst/Q/fmax.q.yaml +35 -0
  1143. data/.data/spec/std/isa/inst/Q/fmaxm.q.yaml +38 -0
  1144. data/.data/spec/std/isa/inst/Q/fmin.q.yaml +35 -0
  1145. data/.data/spec/std/isa/inst/Q/fminm.q.yaml +38 -0
  1146. data/.data/spec/std/isa/inst/Q/fmsub.q.yaml +36 -0
  1147. data/.data/spec/std/isa/inst/Q/fmul.q.yaml +33 -0
  1148. data/.data/spec/std/isa/inst/Q/fmvh.x.q.yaml +37 -0
  1149. data/.data/spec/std/isa/inst/Q/fmvp.q.x.yaml +39 -0
  1150. data/.data/spec/std/isa/inst/Q/fnmadd.q.yaml +37 -0
  1151. data/.data/spec/std/isa/inst/Q/fnmsub.q.yaml +37 -0
  1152. data/.data/spec/std/isa/inst/Q/fround.q.yaml +38 -0
  1153. data/.data/spec/std/isa/inst/Q/froundnx.q.yaml +34 -0
  1154. data/.data/spec/std/isa/inst/Q/fsgnj.q.yaml +36 -0
  1155. data/.data/spec/std/isa/inst/Q/fsgnjn.q.yaml +36 -0
  1156. data/.data/spec/std/isa/inst/Q/fsgnjx.q.yaml +36 -0
  1157. data/.data/spec/std/isa/inst/Q/fsq.yaml +36 -0
  1158. data/.data/spec/std/isa/inst/Q/fsqrt.q.yaml +31 -0
  1159. data/.data/spec/std/isa/inst/Q/fsub.q.yaml +34 -0
  1160. data/.data/spec/std/isa/inst/README.md +78 -0
  1161. data/.data/spec/std/isa/inst/S/sfence.vma.yaml +331 -0
  1162. data/.data/spec/std/isa/inst/S/sret.yaml +166 -0
  1163. data/.data/spec/std/isa/inst/Sdext/dret.yaml +25 -0
  1164. data/.data/spec/std/isa/inst/Smdbltrp/sctrclr.yaml +47 -0
  1165. data/.data/spec/std/isa/inst/Smrnmi/mnret.yaml +51 -0
  1166. data/.data/spec/std/isa/inst/Svinval/hinval.gvma.yaml +91 -0
  1167. data/.data/spec/std/isa/inst/Svinval/hinval.vvma.yaml +91 -0
  1168. data/.data/spec/std/isa/inst/Svinval/sfence.inval.ir.yaml +44 -0
  1169. data/.data/spec/std/isa/inst/Svinval/sfence.w.inval.yaml +45 -0
  1170. data/.data/spec/std/isa/inst/Svinval/sinval.vma.yaml +102 -0
  1171. data/.data/spec/std/isa/inst/V/vaadd.vv.yaml +116 -0
  1172. data/.data/spec/std/isa/inst/V/vaadd.vx.yaml +125 -0
  1173. data/.data/spec/std/isa/inst/V/vaaddu.vv.yaml +116 -0
  1174. data/.data/spec/std/isa/inst/V/vaaddu.vx.yaml +125 -0
  1175. data/.data/spec/std/isa/inst/V/vadc.vim.yaml +75 -0
  1176. data/.data/spec/std/isa/inst/V/vadc.vvm.yaml +76 -0
  1177. data/.data/spec/std/isa/inst/V/vadc.vxm.yaml +76 -0
  1178. data/.data/spec/std/isa/inst/V/vadd.vi.yaml +101 -0
  1179. data/.data/spec/std/isa/inst/V/vadd.vv.yaml +158 -0
  1180. data/.data/spec/std/isa/inst/V/vadd.vx.yaml +117 -0
  1181. data/.data/spec/std/isa/inst/V/vand.vi.yaml +101 -0
  1182. data/.data/spec/std/isa/inst/V/vand.vv.yaml +134 -0
  1183. data/.data/spec/std/isa/inst/V/vand.vx.yaml +117 -0
  1184. data/.data/spec/std/isa/inst/V/vasub.vv.yaml +116 -0
  1185. data/.data/spec/std/isa/inst/V/vasub.vx.yaml +125 -0
  1186. data/.data/spec/std/isa/inst/V/vasubu.vv.yaml +116 -0
  1187. data/.data/spec/std/isa/inst/V/vasubu.vx.yaml +125 -0
  1188. data/.data/spec/std/isa/inst/V/vcompress.vm.yaml +85 -0
  1189. data/.data/spec/std/isa/inst/V/vcpop.m.yaml +31 -0
  1190. data/.data/spec/std/isa/inst/V/vdiv.vv.yaml +116 -0
  1191. data/.data/spec/std/isa/inst/V/vdiv.vx.yaml +125 -0
  1192. data/.data/spec/std/isa/inst/V/vdivu.vv.yaml +116 -0
  1193. data/.data/spec/std/isa/inst/V/vdivu.vx.yaml +125 -0
  1194. data/.data/spec/std/isa/inst/V/vfadd.vf.yaml +92 -0
  1195. data/.data/spec/std/isa/inst/V/vfadd.vv.yaml +81 -0
  1196. data/.data/spec/std/isa/inst/V/vfclass.v.yaml +97 -0
  1197. data/.data/spec/std/isa/inst/V/vfcvt.f.x.v.yaml +122 -0
  1198. data/.data/spec/std/isa/inst/V/vfcvt.f.xu.v.yaml +122 -0
  1199. data/.data/spec/std/isa/inst/V/vfcvt.rtz.x.f.v.yaml +122 -0
  1200. data/.data/spec/std/isa/inst/V/vfcvt.rtz.xu.f.v.yaml +122 -0
  1201. data/.data/spec/std/isa/inst/V/vfcvt.x.f.v.yaml +122 -0
  1202. data/.data/spec/std/isa/inst/V/vfcvt.xu.f.v.yaml +122 -0
  1203. data/.data/spec/std/isa/inst/V/vfdiv.vf.yaml +92 -0
  1204. data/.data/spec/std/isa/inst/V/vfdiv.vv.yaml +81 -0
  1205. data/.data/spec/std/isa/inst/V/vfirst.m.yaml +66 -0
  1206. data/.data/spec/std/isa/inst/V/vfmacc.vf.yaml +80 -0
  1207. data/.data/spec/std/isa/inst/V/vfmacc.vv.yaml +80 -0
  1208. data/.data/spec/std/isa/inst/V/vfmadd.vf.yaml +80 -0
  1209. data/.data/spec/std/isa/inst/V/vfmadd.vv.yaml +80 -0
  1210. data/.data/spec/std/isa/inst/V/vfmax.vf.yaml +92 -0
  1211. data/.data/spec/std/isa/inst/V/vfmax.vv.yaml +81 -0
  1212. data/.data/spec/std/isa/inst/V/vfmerge.vfm.yaml +78 -0
  1213. data/.data/spec/std/isa/inst/V/vfmin.vf.yaml +92 -0
  1214. data/.data/spec/std/isa/inst/V/vfmin.vv.yaml +81 -0
  1215. data/.data/spec/std/isa/inst/V/vfmsac.vf.yaml +80 -0
  1216. data/.data/spec/std/isa/inst/V/vfmsac.vv.yaml +80 -0
  1217. data/.data/spec/std/isa/inst/V/vfmsub.vf.yaml +80 -0
  1218. data/.data/spec/std/isa/inst/V/vfmsub.vv.yaml +80 -0
  1219. data/.data/spec/std/isa/inst/V/vfmul.vf.yaml +92 -0
  1220. data/.data/spec/std/isa/inst/V/vfmul.vv.yaml +81 -0
  1221. data/.data/spec/std/isa/inst/V/vfmv.f.s.yaml +58 -0
  1222. data/.data/spec/std/isa/inst/V/vfmv.s.f.yaml +71 -0
  1223. data/.data/spec/std/isa/inst/V/vfmv.v.f.yaml +64 -0
  1224. data/.data/spec/std/isa/inst/V/vfncvt.f.f.w.yaml +145 -0
  1225. data/.data/spec/std/isa/inst/V/vfncvt.f.x.w.yaml +145 -0
  1226. data/.data/spec/std/isa/inst/V/vfncvt.f.xu.w.yaml +145 -0
  1227. data/.data/spec/std/isa/inst/V/vfncvt.rod.f.f.w.yaml +145 -0
  1228. data/.data/spec/std/isa/inst/V/vfncvt.rtz.x.f.w.yaml +145 -0
  1229. data/.data/spec/std/isa/inst/V/vfncvt.rtz.xu.f.w.yaml +145 -0
  1230. data/.data/spec/std/isa/inst/V/vfncvt.x.f.w.yaml +145 -0
  1231. data/.data/spec/std/isa/inst/V/vfncvt.xu.f.w.yaml +145 -0
  1232. data/.data/spec/std/isa/inst/V/vfnmacc.vf.yaml +80 -0
  1233. data/.data/spec/std/isa/inst/V/vfnmacc.vv.yaml +80 -0
  1234. data/.data/spec/std/isa/inst/V/vfnmadd.vf.yaml +80 -0
  1235. data/.data/spec/std/isa/inst/V/vfnmadd.vv.yaml +80 -0
  1236. data/.data/spec/std/isa/inst/V/vfnmsac.vf.yaml +80 -0
  1237. data/.data/spec/std/isa/inst/V/vfnmsac.vv.yaml +80 -0
  1238. data/.data/spec/std/isa/inst/V/vfnmsub.vf.yaml +80 -0
  1239. data/.data/spec/std/isa/inst/V/vfnmsub.vv.yaml +80 -0
  1240. data/.data/spec/std/isa/inst/V/vfrdiv.vf.yaml +92 -0
  1241. data/.data/spec/std/isa/inst/V/vfrec7.v.yaml +97 -0
  1242. data/.data/spec/std/isa/inst/V/vfredmax.vs.yaml +50 -0
  1243. data/.data/spec/std/isa/inst/V/vfredmin.vs.yaml +50 -0
  1244. data/.data/spec/std/isa/inst/V/vfredosum.vs.yaml +50 -0
  1245. data/.data/spec/std/isa/inst/V/vfredusum.vs.yaml +50 -0
  1246. data/.data/spec/std/isa/inst/V/vfrsqrt7.v.yaml +97 -0
  1247. data/.data/spec/std/isa/inst/V/vfrsub.vf.yaml +92 -0
  1248. data/.data/spec/std/isa/inst/V/vfsgnj.vf.yaml +92 -0
  1249. data/.data/spec/std/isa/inst/V/vfsgnj.vv.yaml +81 -0
  1250. data/.data/spec/std/isa/inst/V/vfsgnjn.vf.yaml +92 -0
  1251. data/.data/spec/std/isa/inst/V/vfsgnjn.vv.yaml +81 -0
  1252. data/.data/spec/std/isa/inst/V/vfsgnjx.vf.yaml +92 -0
  1253. data/.data/spec/std/isa/inst/V/vfsgnjx.vv.yaml +81 -0
  1254. data/.data/spec/std/isa/inst/V/vfslide1down.vf.yaml +92 -0
  1255. data/.data/spec/std/isa/inst/V/vfslide1up.vf.yaml +92 -0
  1256. data/.data/spec/std/isa/inst/V/vfsqrt.v.yaml +97 -0
  1257. data/.data/spec/std/isa/inst/V/vfsub.vf.yaml +92 -0
  1258. data/.data/spec/std/isa/inst/V/vfsub.vv.yaml +81 -0
  1259. data/.data/spec/std/isa/inst/V/vfwadd.vf.yaml +80 -0
  1260. data/.data/spec/std/isa/inst/V/vfwadd.vv.yaml +81 -0
  1261. data/.data/spec/std/isa/inst/V/vfwadd.wf.yaml +78 -0
  1262. data/.data/spec/std/isa/inst/V/vfwadd.wv.yaml +79 -0
  1263. data/.data/spec/std/isa/inst/V/vfwcvt.f.f.v.yaml +137 -0
  1264. data/.data/spec/std/isa/inst/V/vfwcvt.f.x.v.yaml +137 -0
  1265. data/.data/spec/std/isa/inst/V/vfwcvt.f.xu.v.yaml +137 -0
  1266. data/.data/spec/std/isa/inst/V/vfwcvt.rtz.x.f.v.yaml +137 -0
  1267. data/.data/spec/std/isa/inst/V/vfwcvt.rtz.xu.f.v.yaml +137 -0
  1268. data/.data/spec/std/isa/inst/V/vfwcvt.x.f.v.yaml +137 -0
  1269. data/.data/spec/std/isa/inst/V/vfwcvt.xu.f.v.yaml +137 -0
  1270. data/.data/spec/std/isa/inst/V/vfwmacc.vf.yaml +81 -0
  1271. data/.data/spec/std/isa/inst/V/vfwmacc.vv.yaml +82 -0
  1272. data/.data/spec/std/isa/inst/V/vfwmsac.vf.yaml +81 -0
  1273. data/.data/spec/std/isa/inst/V/vfwmsac.vv.yaml +82 -0
  1274. data/.data/spec/std/isa/inst/V/vfwmul.vf.yaml +80 -0
  1275. data/.data/spec/std/isa/inst/V/vfwmul.vv.yaml +81 -0
  1276. data/.data/spec/std/isa/inst/V/vfwnmacc.vf.yaml +81 -0
  1277. data/.data/spec/std/isa/inst/V/vfwnmacc.vv.yaml +82 -0
  1278. data/.data/spec/std/isa/inst/V/vfwnmsac.vf.yaml +81 -0
  1279. data/.data/spec/std/isa/inst/V/vfwnmsac.vv.yaml +82 -0
  1280. data/.data/spec/std/isa/inst/V/vfwredosum.vs.yaml +50 -0
  1281. data/.data/spec/std/isa/inst/V/vfwredusum.vs.yaml +50 -0
  1282. data/.data/spec/std/isa/inst/V/vfwsub.vf.yaml +80 -0
  1283. data/.data/spec/std/isa/inst/V/vfwsub.vv.yaml +81 -0
  1284. data/.data/spec/std/isa/inst/V/vfwsub.wf.yaml +78 -0
  1285. data/.data/spec/std/isa/inst/V/vfwsub.wv.yaml +79 -0
  1286. data/.data/spec/std/isa/inst/V/vid.v.yaml +61 -0
  1287. data/.data/spec/std/isa/inst/V/viota.m.yaml +69 -0
  1288. data/.data/spec/std/isa/inst/V/vl1re16.v.yaml +29 -0
  1289. data/.data/spec/std/isa/inst/V/vl1re32.v.yaml +29 -0
  1290. data/.data/spec/std/isa/inst/V/vl1re64.v.yaml +29 -0
  1291. data/.data/spec/std/isa/inst/V/vl1re8.v.yaml +29 -0
  1292. data/.data/spec/std/isa/inst/V/vl2re16.v.yaml +29 -0
  1293. data/.data/spec/std/isa/inst/V/vl2re32.v.yaml +29 -0
  1294. data/.data/spec/std/isa/inst/V/vl2re64.v.yaml +29 -0
  1295. data/.data/spec/std/isa/inst/V/vl2re8.v.yaml +29 -0
  1296. data/.data/spec/std/isa/inst/V/vl4re16.v.yaml +29 -0
  1297. data/.data/spec/std/isa/inst/V/vl4re32.v.yaml +29 -0
  1298. data/.data/spec/std/isa/inst/V/vl4re64.v.yaml +29 -0
  1299. data/.data/spec/std/isa/inst/V/vl4re8.v.yaml +29 -0
  1300. data/.data/spec/std/isa/inst/V/vl8re16.v.yaml +29 -0
  1301. data/.data/spec/std/isa/inst/V/vl8re32.v.yaml +29 -0
  1302. data/.data/spec/std/isa/inst/V/vl8re64.v.yaml +29 -0
  1303. data/.data/spec/std/isa/inst/V/vl8re8.v.yaml +29 -0
  1304. data/.data/spec/std/isa/inst/V/vle16.v.yaml +52 -0
  1305. data/.data/spec/std/isa/inst/V/vle16ff.v.yaml +52 -0
  1306. data/.data/spec/std/isa/inst/V/vle32.v.yaml +52 -0
  1307. data/.data/spec/std/isa/inst/V/vle32ff.v.yaml +52 -0
  1308. data/.data/spec/std/isa/inst/V/vle64.v.yaml +52 -0
  1309. data/.data/spec/std/isa/inst/V/vle64ff.v.yaml +52 -0
  1310. data/.data/spec/std/isa/inst/V/vle8.v.yaml +64 -0
  1311. data/.data/spec/std/isa/inst/V/vle8ff.v.yaml +52 -0
  1312. data/.data/spec/std/isa/inst/V/vlm.v.yaml +48 -0
  1313. data/.data/spec/std/isa/inst/V/vloxei16.v.yaml +54 -0
  1314. data/.data/spec/std/isa/inst/V/vloxei32.v.yaml +54 -0
  1315. data/.data/spec/std/isa/inst/V/vloxei64.v.yaml +54 -0
  1316. data/.data/spec/std/isa/inst/V/vloxei8.v.yaml +54 -0
  1317. data/.data/spec/std/isa/inst/V/vloxseg2ei16.v.yaml +33 -0
  1318. data/.data/spec/std/isa/inst/V/vloxseg2ei32.v.yaml +33 -0
  1319. data/.data/spec/std/isa/inst/V/vloxseg2ei64.v.yaml +33 -0
  1320. data/.data/spec/std/isa/inst/V/vloxseg2ei8.v.yaml +33 -0
  1321. data/.data/spec/std/isa/inst/V/vloxseg3ei16.v.yaml +33 -0
  1322. data/.data/spec/std/isa/inst/V/vloxseg3ei32.v.yaml +33 -0
  1323. data/.data/spec/std/isa/inst/V/vloxseg3ei64.v.yaml +33 -0
  1324. data/.data/spec/std/isa/inst/V/vloxseg3ei8.v.yaml +33 -0
  1325. data/.data/spec/std/isa/inst/V/vloxseg4ei16.v.yaml +33 -0
  1326. data/.data/spec/std/isa/inst/V/vloxseg4ei32.v.yaml +33 -0
  1327. data/.data/spec/std/isa/inst/V/vloxseg4ei64.v.yaml +33 -0
  1328. data/.data/spec/std/isa/inst/V/vloxseg4ei8.v.yaml +33 -0
  1329. data/.data/spec/std/isa/inst/V/vloxseg5ei16.v.yaml +33 -0
  1330. data/.data/spec/std/isa/inst/V/vloxseg5ei32.v.yaml +33 -0
  1331. data/.data/spec/std/isa/inst/V/vloxseg5ei64.v.yaml +33 -0
  1332. data/.data/spec/std/isa/inst/V/vloxseg5ei8.v.yaml +33 -0
  1333. data/.data/spec/std/isa/inst/V/vloxseg6ei16.v.yaml +33 -0
  1334. data/.data/spec/std/isa/inst/V/vloxseg6ei32.v.yaml +33 -0
  1335. data/.data/spec/std/isa/inst/V/vloxseg6ei64.v.yaml +33 -0
  1336. data/.data/spec/std/isa/inst/V/vloxseg6ei8.v.yaml +33 -0
  1337. data/.data/spec/std/isa/inst/V/vloxseg7ei16.v.yaml +33 -0
  1338. data/.data/spec/std/isa/inst/V/vloxseg7ei32.v.yaml +33 -0
  1339. data/.data/spec/std/isa/inst/V/vloxseg7ei64.v.yaml +33 -0
  1340. data/.data/spec/std/isa/inst/V/vloxseg7ei8.v.yaml +33 -0
  1341. data/.data/spec/std/isa/inst/V/vloxseg8ei16.v.yaml +33 -0
  1342. data/.data/spec/std/isa/inst/V/vloxseg8ei32.v.yaml +33 -0
  1343. data/.data/spec/std/isa/inst/V/vloxseg8ei64.v.yaml +33 -0
  1344. data/.data/spec/std/isa/inst/V/vloxseg8ei8.v.yaml +33 -0
  1345. data/.data/spec/std/isa/inst/V/vlse16.v.yaml +54 -0
  1346. data/.data/spec/std/isa/inst/V/vlse32.v.yaml +54 -0
  1347. data/.data/spec/std/isa/inst/V/vlse64.v.yaml +54 -0
  1348. data/.data/spec/std/isa/inst/V/vlse8.v.yaml +54 -0
  1349. data/.data/spec/std/isa/inst/V/vlseg2e16.v.yaml +31 -0
  1350. data/.data/spec/std/isa/inst/V/vlseg2e16ff.v.yaml +31 -0
  1351. data/.data/spec/std/isa/inst/V/vlseg2e32.v.yaml +31 -0
  1352. data/.data/spec/std/isa/inst/V/vlseg2e32ff.v.yaml +31 -0
  1353. data/.data/spec/std/isa/inst/V/vlseg2e64.v.yaml +31 -0
  1354. data/.data/spec/std/isa/inst/V/vlseg2e64ff.v.yaml +31 -0
  1355. data/.data/spec/std/isa/inst/V/vlseg2e8.v.yaml +31 -0
  1356. data/.data/spec/std/isa/inst/V/vlseg2e8ff.v.yaml +31 -0
  1357. data/.data/spec/std/isa/inst/V/vlseg3e16.v.yaml +31 -0
  1358. data/.data/spec/std/isa/inst/V/vlseg3e16ff.v.yaml +31 -0
  1359. data/.data/spec/std/isa/inst/V/vlseg3e32.v.yaml +31 -0
  1360. data/.data/spec/std/isa/inst/V/vlseg3e32ff.v.yaml +31 -0
  1361. data/.data/spec/std/isa/inst/V/vlseg3e64.v.yaml +31 -0
  1362. data/.data/spec/std/isa/inst/V/vlseg3e64ff.v.yaml +31 -0
  1363. data/.data/spec/std/isa/inst/V/vlseg3e8.v.yaml +31 -0
  1364. data/.data/spec/std/isa/inst/V/vlseg3e8ff.v.yaml +31 -0
  1365. data/.data/spec/std/isa/inst/V/vlseg4e16.v.yaml +31 -0
  1366. data/.data/spec/std/isa/inst/V/vlseg4e16ff.v.yaml +31 -0
  1367. data/.data/spec/std/isa/inst/V/vlseg4e32.v.yaml +31 -0
  1368. data/.data/spec/std/isa/inst/V/vlseg4e32ff.v.yaml +31 -0
  1369. data/.data/spec/std/isa/inst/V/vlseg4e64.v.yaml +31 -0
  1370. data/.data/spec/std/isa/inst/V/vlseg4e64ff.v.yaml +31 -0
  1371. data/.data/spec/std/isa/inst/V/vlseg4e8.v.yaml +31 -0
  1372. data/.data/spec/std/isa/inst/V/vlseg4e8ff.v.yaml +31 -0
  1373. data/.data/spec/std/isa/inst/V/vlseg5e16.v.yaml +31 -0
  1374. data/.data/spec/std/isa/inst/V/vlseg5e16ff.v.yaml +31 -0
  1375. data/.data/spec/std/isa/inst/V/vlseg5e32.v.yaml +31 -0
  1376. data/.data/spec/std/isa/inst/V/vlseg5e32ff.v.yaml +31 -0
  1377. data/.data/spec/std/isa/inst/V/vlseg5e64.v.yaml +31 -0
  1378. data/.data/spec/std/isa/inst/V/vlseg5e64ff.v.yaml +31 -0
  1379. data/.data/spec/std/isa/inst/V/vlseg5e8.v.yaml +31 -0
  1380. data/.data/spec/std/isa/inst/V/vlseg5e8ff.v.yaml +31 -0
  1381. data/.data/spec/std/isa/inst/V/vlseg6e16.v.yaml +31 -0
  1382. data/.data/spec/std/isa/inst/V/vlseg6e16ff.v.yaml +31 -0
  1383. data/.data/spec/std/isa/inst/V/vlseg6e32.v.yaml +31 -0
  1384. data/.data/spec/std/isa/inst/V/vlseg6e32ff.v.yaml +31 -0
  1385. data/.data/spec/std/isa/inst/V/vlseg6e64.v.yaml +31 -0
  1386. data/.data/spec/std/isa/inst/V/vlseg6e64ff.v.yaml +31 -0
  1387. data/.data/spec/std/isa/inst/V/vlseg6e8.v.yaml +31 -0
  1388. data/.data/spec/std/isa/inst/V/vlseg6e8ff.v.yaml +31 -0
  1389. data/.data/spec/std/isa/inst/V/vlseg7e16.v.yaml +31 -0
  1390. data/.data/spec/std/isa/inst/V/vlseg7e16ff.v.yaml +31 -0
  1391. data/.data/spec/std/isa/inst/V/vlseg7e32.v.yaml +31 -0
  1392. data/.data/spec/std/isa/inst/V/vlseg7e32ff.v.yaml +31 -0
  1393. data/.data/spec/std/isa/inst/V/vlseg7e64.v.yaml +31 -0
  1394. data/.data/spec/std/isa/inst/V/vlseg7e64ff.v.yaml +31 -0
  1395. data/.data/spec/std/isa/inst/V/vlseg7e8.v.yaml +31 -0
  1396. data/.data/spec/std/isa/inst/V/vlseg7e8ff.v.yaml +31 -0
  1397. data/.data/spec/std/isa/inst/V/vlseg8e16.v.yaml +31 -0
  1398. data/.data/spec/std/isa/inst/V/vlseg8e16ff.v.yaml +31 -0
  1399. data/.data/spec/std/isa/inst/V/vlseg8e32.v.yaml +31 -0
  1400. data/.data/spec/std/isa/inst/V/vlseg8e32ff.v.yaml +31 -0
  1401. data/.data/spec/std/isa/inst/V/vlseg8e64.v.yaml +31 -0
  1402. data/.data/spec/std/isa/inst/V/vlseg8e64ff.v.yaml +31 -0
  1403. data/.data/spec/std/isa/inst/V/vlseg8e8.v.yaml +31 -0
  1404. data/.data/spec/std/isa/inst/V/vlseg8e8ff.v.yaml +31 -0
  1405. data/.data/spec/std/isa/inst/V/vlsseg2e16.v.yaml +33 -0
  1406. data/.data/spec/std/isa/inst/V/vlsseg2e32.v.yaml +33 -0
  1407. data/.data/spec/std/isa/inst/V/vlsseg2e64.v.yaml +33 -0
  1408. data/.data/spec/std/isa/inst/V/vlsseg2e8.v.yaml +33 -0
  1409. data/.data/spec/std/isa/inst/V/vlsseg3e16.v.yaml +33 -0
  1410. data/.data/spec/std/isa/inst/V/vlsseg3e32.v.yaml +33 -0
  1411. data/.data/spec/std/isa/inst/V/vlsseg3e64.v.yaml +33 -0
  1412. data/.data/spec/std/isa/inst/V/vlsseg3e8.v.yaml +33 -0
  1413. data/.data/spec/std/isa/inst/V/vlsseg4e16.v.yaml +33 -0
  1414. data/.data/spec/std/isa/inst/V/vlsseg4e32.v.yaml +33 -0
  1415. data/.data/spec/std/isa/inst/V/vlsseg4e64.v.yaml +33 -0
  1416. data/.data/spec/std/isa/inst/V/vlsseg4e8.v.yaml +33 -0
  1417. data/.data/spec/std/isa/inst/V/vlsseg5e16.v.yaml +33 -0
  1418. data/.data/spec/std/isa/inst/V/vlsseg5e32.v.yaml +33 -0
  1419. data/.data/spec/std/isa/inst/V/vlsseg5e64.v.yaml +33 -0
  1420. data/.data/spec/std/isa/inst/V/vlsseg5e8.v.yaml +33 -0
  1421. data/.data/spec/std/isa/inst/V/vlsseg6e16.v.yaml +33 -0
  1422. data/.data/spec/std/isa/inst/V/vlsseg6e32.v.yaml +33 -0
  1423. data/.data/spec/std/isa/inst/V/vlsseg6e64.v.yaml +33 -0
  1424. data/.data/spec/std/isa/inst/V/vlsseg6e8.v.yaml +33 -0
  1425. data/.data/spec/std/isa/inst/V/vlsseg7e16.v.yaml +33 -0
  1426. data/.data/spec/std/isa/inst/V/vlsseg7e32.v.yaml +33 -0
  1427. data/.data/spec/std/isa/inst/V/vlsseg7e64.v.yaml +33 -0
  1428. data/.data/spec/std/isa/inst/V/vlsseg7e8.v.yaml +33 -0
  1429. data/.data/spec/std/isa/inst/V/vlsseg8e16.v.yaml +33 -0
  1430. data/.data/spec/std/isa/inst/V/vlsseg8e32.v.yaml +33 -0
  1431. data/.data/spec/std/isa/inst/V/vlsseg8e64.v.yaml +33 -0
  1432. data/.data/spec/std/isa/inst/V/vlsseg8e8.v.yaml +33 -0
  1433. data/.data/spec/std/isa/inst/V/vluxei16.v.yaml +54 -0
  1434. data/.data/spec/std/isa/inst/V/vluxei32.v.yaml +54 -0
  1435. data/.data/spec/std/isa/inst/V/vluxei64.v.yaml +54 -0
  1436. data/.data/spec/std/isa/inst/V/vluxei8.v.yaml +54 -0
  1437. data/.data/spec/std/isa/inst/V/vluxseg2ei16.v.yaml +33 -0
  1438. data/.data/spec/std/isa/inst/V/vluxseg2ei32.v.yaml +33 -0
  1439. data/.data/spec/std/isa/inst/V/vluxseg2ei64.v.yaml +33 -0
  1440. data/.data/spec/std/isa/inst/V/vluxseg2ei8.v.yaml +33 -0
  1441. data/.data/spec/std/isa/inst/V/vluxseg3ei16.v.yaml +33 -0
  1442. data/.data/spec/std/isa/inst/V/vluxseg3ei32.v.yaml +33 -0
  1443. data/.data/spec/std/isa/inst/V/vluxseg3ei64.v.yaml +33 -0
  1444. data/.data/spec/std/isa/inst/V/vluxseg3ei8.v.yaml +33 -0
  1445. data/.data/spec/std/isa/inst/V/vluxseg4ei16.v.yaml +33 -0
  1446. data/.data/spec/std/isa/inst/V/vluxseg4ei32.v.yaml +33 -0
  1447. data/.data/spec/std/isa/inst/V/vluxseg4ei64.v.yaml +33 -0
  1448. data/.data/spec/std/isa/inst/V/vluxseg4ei8.v.yaml +33 -0
  1449. data/.data/spec/std/isa/inst/V/vluxseg5ei16.v.yaml +33 -0
  1450. data/.data/spec/std/isa/inst/V/vluxseg5ei32.v.yaml +33 -0
  1451. data/.data/spec/std/isa/inst/V/vluxseg5ei64.v.yaml +33 -0
  1452. data/.data/spec/std/isa/inst/V/vluxseg5ei8.v.yaml +33 -0
  1453. data/.data/spec/std/isa/inst/V/vluxseg6ei16.v.yaml +33 -0
  1454. data/.data/spec/std/isa/inst/V/vluxseg6ei32.v.yaml +33 -0
  1455. data/.data/spec/std/isa/inst/V/vluxseg6ei64.v.yaml +33 -0
  1456. data/.data/spec/std/isa/inst/V/vluxseg6ei8.v.yaml +33 -0
  1457. data/.data/spec/std/isa/inst/V/vluxseg7ei16.v.yaml +33 -0
  1458. data/.data/spec/std/isa/inst/V/vluxseg7ei32.v.yaml +33 -0
  1459. data/.data/spec/std/isa/inst/V/vluxseg7ei64.v.yaml +33 -0
  1460. data/.data/spec/std/isa/inst/V/vluxseg7ei8.v.yaml +33 -0
  1461. data/.data/spec/std/isa/inst/V/vluxseg8ei16.v.yaml +33 -0
  1462. data/.data/spec/std/isa/inst/V/vluxseg8ei32.v.yaml +33 -0
  1463. data/.data/spec/std/isa/inst/V/vluxseg8ei64.v.yaml +33 -0
  1464. data/.data/spec/std/isa/inst/V/vluxseg8ei8.v.yaml +33 -0
  1465. data/.data/spec/std/isa/inst/V/vmacc.vv.yaml +74 -0
  1466. data/.data/spec/std/isa/inst/V/vmacc.vx.yaml +74 -0
  1467. data/.data/spec/std/isa/inst/V/vmadc.vi.yaml +69 -0
  1468. data/.data/spec/std/isa/inst/V/vmadc.vim.yaml +70 -0
  1469. data/.data/spec/std/isa/inst/V/vmadc.vv.yaml +70 -0
  1470. data/.data/spec/std/isa/inst/V/vmadc.vvm.yaml +71 -0
  1471. data/.data/spec/std/isa/inst/V/vmadc.vx.yaml +70 -0
  1472. data/.data/spec/std/isa/inst/V/vmadc.vxm.yaml +71 -0
  1473. data/.data/spec/std/isa/inst/V/vmadd.vv.yaml +74 -0
  1474. data/.data/spec/std/isa/inst/V/vmadd.vx.yaml +74 -0
  1475. data/.data/spec/std/isa/inst/V/vmand.mm.yaml +75 -0
  1476. data/.data/spec/std/isa/inst/V/vmandn.mm.yaml +31 -0
  1477. data/.data/spec/std/isa/inst/V/vmax.vv.yaml +134 -0
  1478. data/.data/spec/std/isa/inst/V/vmax.vx.yaml +117 -0
  1479. data/.data/spec/std/isa/inst/V/vmaxu.vv.yaml +134 -0
  1480. data/.data/spec/std/isa/inst/V/vmaxu.vx.yaml +117 -0
  1481. data/.data/spec/std/isa/inst/V/vmerge.vim.yaml +76 -0
  1482. data/.data/spec/std/isa/inst/V/vmerge.vvm.yaml +76 -0
  1483. data/.data/spec/std/isa/inst/V/vmerge.vxm.yaml +76 -0
  1484. data/.data/spec/std/isa/inst/V/vmfeq.vf.yaml +79 -0
  1485. data/.data/spec/std/isa/inst/V/vmfeq.vv.yaml +77 -0
  1486. data/.data/spec/std/isa/inst/V/vmfge.vf.yaml +79 -0
  1487. data/.data/spec/std/isa/inst/V/vmfgt.vf.yaml +79 -0
  1488. data/.data/spec/std/isa/inst/V/vmfle.vf.yaml +79 -0
  1489. data/.data/spec/std/isa/inst/V/vmfle.vv.yaml +77 -0
  1490. data/.data/spec/std/isa/inst/V/vmflt.vf.yaml +79 -0
  1491. data/.data/spec/std/isa/inst/V/vmflt.vv.yaml +77 -0
  1492. data/.data/spec/std/isa/inst/V/vmfne.vf.yaml +79 -0
  1493. data/.data/spec/std/isa/inst/V/vmfne.vv.yaml +77 -0
  1494. data/.data/spec/std/isa/inst/V/vmin.vv.yaml +134 -0
  1495. data/.data/spec/std/isa/inst/V/vmin.vx.yaml +117 -0
  1496. data/.data/spec/std/isa/inst/V/vminu.vv.yaml +134 -0
  1497. data/.data/spec/std/isa/inst/V/vminu.vx.yaml +117 -0
  1498. data/.data/spec/std/isa/inst/V/vmnand.mm.yaml +75 -0
  1499. data/.data/spec/std/isa/inst/V/vmnor.mm.yaml +75 -0
  1500. data/.data/spec/std/isa/inst/V/vmor.mm.yaml +75 -0
  1501. data/.data/spec/std/isa/inst/V/vmorn.mm.yaml +31 -0
  1502. data/.data/spec/std/isa/inst/V/vmsbc.vv.yaml +70 -0
  1503. data/.data/spec/std/isa/inst/V/vmsbc.vvm.yaml +71 -0
  1504. data/.data/spec/std/isa/inst/V/vmsbc.vx.yaml +70 -0
  1505. data/.data/spec/std/isa/inst/V/vmsbc.vxm.yaml +71 -0
  1506. data/.data/spec/std/isa/inst/V/vmsbf.m.yaml +69 -0
  1507. data/.data/spec/std/isa/inst/V/vmseq.vi.yaml +77 -0
  1508. data/.data/spec/std/isa/inst/V/vmseq.vv.yaml +77 -0
  1509. data/.data/spec/std/isa/inst/V/vmseq.vx.yaml +79 -0
  1510. data/.data/spec/std/isa/inst/V/vmsgt.vi.yaml +77 -0
  1511. data/.data/spec/std/isa/inst/V/vmsgt.vx.yaml +79 -0
  1512. data/.data/spec/std/isa/inst/V/vmsgtu.vi.yaml +77 -0
  1513. data/.data/spec/std/isa/inst/V/vmsgtu.vx.yaml +79 -0
  1514. data/.data/spec/std/isa/inst/V/vmsif.m.yaml +69 -0
  1515. data/.data/spec/std/isa/inst/V/vmsle.vi.yaml +77 -0
  1516. data/.data/spec/std/isa/inst/V/vmsle.vv.yaml +77 -0
  1517. data/.data/spec/std/isa/inst/V/vmsle.vx.yaml +79 -0
  1518. data/.data/spec/std/isa/inst/V/vmsleu.vi.yaml +77 -0
  1519. data/.data/spec/std/isa/inst/V/vmsleu.vv.yaml +77 -0
  1520. data/.data/spec/std/isa/inst/V/vmsleu.vx.yaml +79 -0
  1521. data/.data/spec/std/isa/inst/V/vmslt.vv.yaml +77 -0
  1522. data/.data/spec/std/isa/inst/V/vmslt.vx.yaml +79 -0
  1523. data/.data/spec/std/isa/inst/V/vmsltu.vv.yaml +77 -0
  1524. data/.data/spec/std/isa/inst/V/vmsltu.vx.yaml +79 -0
  1525. data/.data/spec/std/isa/inst/V/vmsne.vi.yaml +77 -0
  1526. data/.data/spec/std/isa/inst/V/vmsne.vv.yaml +77 -0
  1527. data/.data/spec/std/isa/inst/V/vmsne.vx.yaml +79 -0
  1528. data/.data/spec/std/isa/inst/V/vmsof.m.yaml +73 -0
  1529. data/.data/spec/std/isa/inst/V/vmul.vv.yaml +116 -0
  1530. data/.data/spec/std/isa/inst/V/vmul.vx.yaml +125 -0
  1531. data/.data/spec/std/isa/inst/V/vmulh.vv.yaml +116 -0
  1532. data/.data/spec/std/isa/inst/V/vmulh.vx.yaml +125 -0
  1533. data/.data/spec/std/isa/inst/V/vmulhsu.vv.yaml +116 -0
  1534. data/.data/spec/std/isa/inst/V/vmulhsu.vx.yaml +125 -0
  1535. data/.data/spec/std/isa/inst/V/vmulhu.vv.yaml +116 -0
  1536. data/.data/spec/std/isa/inst/V/vmulhu.vx.yaml +125 -0
  1537. data/.data/spec/std/isa/inst/V/vmv.s.x.yaml +70 -0
  1538. data/.data/spec/std/isa/inst/V/vmv.v.i.yaml +105 -0
  1539. data/.data/spec/std/isa/inst/V/vmv.v.v.yaml +62 -0
  1540. data/.data/spec/std/isa/inst/V/vmv.v.x.yaml +62 -0
  1541. data/.data/spec/std/isa/inst/V/vmv.x.s.yaml +64 -0
  1542. data/.data/spec/std/isa/inst/V/vmv1r.v.yaml +62 -0
  1543. data/.data/spec/std/isa/inst/V/vmv2r.v.yaml +62 -0
  1544. data/.data/spec/std/isa/inst/V/vmv4r.v.yaml +62 -0
  1545. data/.data/spec/std/isa/inst/V/vmv8r.v.yaml +62 -0
  1546. data/.data/spec/std/isa/inst/V/vmxnor.mm.yaml +75 -0
  1547. data/.data/spec/std/isa/inst/V/vmxor.mm.yaml +75 -0
  1548. data/.data/spec/std/isa/inst/V/vnclip.wi.yaml +87 -0
  1549. data/.data/spec/std/isa/inst/V/vnclip.wv.yaml +87 -0
  1550. data/.data/spec/std/isa/inst/V/vnclip.wx.yaml +87 -0
  1551. data/.data/spec/std/isa/inst/V/vnclipu.wi.yaml +87 -0
  1552. data/.data/spec/std/isa/inst/V/vnclipu.wv.yaml +87 -0
  1553. data/.data/spec/std/isa/inst/V/vnclipu.wx.yaml +87 -0
  1554. data/.data/spec/std/isa/inst/V/vnmsac.vv.yaml +74 -0
  1555. data/.data/spec/std/isa/inst/V/vnmsac.vx.yaml +74 -0
  1556. data/.data/spec/std/isa/inst/V/vnmsub.vv.yaml +74 -0
  1557. data/.data/spec/std/isa/inst/V/vnmsub.vx.yaml +74 -0
  1558. data/.data/spec/std/isa/inst/V/vnsra.wi.yaml +86 -0
  1559. data/.data/spec/std/isa/inst/V/vnsra.wv.yaml +86 -0
  1560. data/.data/spec/std/isa/inst/V/vnsra.wx.yaml +86 -0
  1561. data/.data/spec/std/isa/inst/V/vnsrl.wi.yaml +86 -0
  1562. data/.data/spec/std/isa/inst/V/vnsrl.wv.yaml +86 -0
  1563. data/.data/spec/std/isa/inst/V/vnsrl.wx.yaml +86 -0
  1564. data/.data/spec/std/isa/inst/V/vor.vi.yaml +101 -0
  1565. data/.data/spec/std/isa/inst/V/vor.vv.yaml +134 -0
  1566. data/.data/spec/std/isa/inst/V/vor.vx.yaml +117 -0
  1567. data/.data/spec/std/isa/inst/V/vredand.vs.yaml +81 -0
  1568. data/.data/spec/std/isa/inst/V/vredmax.vs.yaml +81 -0
  1569. data/.data/spec/std/isa/inst/V/vredmaxu.vs.yaml +81 -0
  1570. data/.data/spec/std/isa/inst/V/vredmin.vs.yaml +81 -0
  1571. data/.data/spec/std/isa/inst/V/vredminu.vs.yaml +81 -0
  1572. data/.data/spec/std/isa/inst/V/vredor.vs.yaml +81 -0
  1573. data/.data/spec/std/isa/inst/V/vredsum.vs.yaml +81 -0
  1574. data/.data/spec/std/isa/inst/V/vredxor.vs.yaml +81 -0
  1575. data/.data/spec/std/isa/inst/V/vrem.vv.yaml +116 -0
  1576. data/.data/spec/std/isa/inst/V/vrem.vx.yaml +125 -0
  1577. data/.data/spec/std/isa/inst/V/vremu.vv.yaml +116 -0
  1578. data/.data/spec/std/isa/inst/V/vremu.vx.yaml +125 -0
  1579. data/.data/spec/std/isa/inst/V/vrgather.vi.yaml +87 -0
  1580. data/.data/spec/std/isa/inst/V/vrgather.vv.yaml +134 -0
  1581. data/.data/spec/std/isa/inst/V/vrgather.vx.yaml +87 -0
  1582. data/.data/spec/std/isa/inst/V/vrgatherei16.vv.yaml +134 -0
  1583. data/.data/spec/std/isa/inst/V/vrsub.vi.yaml +101 -0
  1584. data/.data/spec/std/isa/inst/V/vrsub.vx.yaml +117 -0
  1585. data/.data/spec/std/isa/inst/V/vs1r.v.yaml +29 -0
  1586. data/.data/spec/std/isa/inst/V/vs2r.v.yaml +29 -0
  1587. data/.data/spec/std/isa/inst/V/vs4r.v.yaml +29 -0
  1588. data/.data/spec/std/isa/inst/V/vs8r.v.yaml +29 -0
  1589. data/.data/spec/std/isa/inst/V/vsadd.vi.yaml +101 -0
  1590. data/.data/spec/std/isa/inst/V/vsadd.vv.yaml +134 -0
  1591. data/.data/spec/std/isa/inst/V/vsadd.vx.yaml +117 -0
  1592. data/.data/spec/std/isa/inst/V/vsaddu.vi.yaml +101 -0
  1593. data/.data/spec/std/isa/inst/V/vsaddu.vv.yaml +134 -0
  1594. data/.data/spec/std/isa/inst/V/vsaddu.vx.yaml +117 -0
  1595. data/.data/spec/std/isa/inst/V/vsbc.vvm.yaml +76 -0
  1596. data/.data/spec/std/isa/inst/V/vsbc.vxm.yaml +76 -0
  1597. data/.data/spec/std/isa/inst/V/vse16.v.yaml +52 -0
  1598. data/.data/spec/std/isa/inst/V/vse32.v.yaml +52 -0
  1599. data/.data/spec/std/isa/inst/V/vse64.v.yaml +52 -0
  1600. data/.data/spec/std/isa/inst/V/vse8.v.yaml +60 -0
  1601. data/.data/spec/std/isa/inst/V/vsetivli.yaml +122 -0
  1602. data/.data/spec/std/isa/inst/V/vsetvl.yaml +147 -0
  1603. data/.data/spec/std/isa/inst/V/vsetvli.yaml +174 -0
  1604. data/.data/spec/std/isa/inst/V/vsext.vf2.yaml +75 -0
  1605. data/.data/spec/std/isa/inst/V/vsext.vf4.yaml +75 -0
  1606. data/.data/spec/std/isa/inst/V/vsext.vf8.yaml +75 -0
  1607. data/.data/spec/std/isa/inst/V/vslide1down.vx.yaml +125 -0
  1608. data/.data/spec/std/isa/inst/V/vslide1up.vx.yaml +125 -0
  1609. data/.data/spec/std/isa/inst/V/vslidedown.vi.yaml +87 -0
  1610. data/.data/spec/std/isa/inst/V/vslidedown.vx.yaml +87 -0
  1611. data/.data/spec/std/isa/inst/V/vslideup.vi.yaml +87 -0
  1612. data/.data/spec/std/isa/inst/V/vslideup.vx.yaml +87 -0
  1613. data/.data/spec/std/isa/inst/V/vsll.vi.yaml +101 -0
  1614. data/.data/spec/std/isa/inst/V/vsll.vv.yaml +134 -0
  1615. data/.data/spec/std/isa/inst/V/vsll.vx.yaml +117 -0
  1616. data/.data/spec/std/isa/inst/V/vsm.v.yaml +48 -0
  1617. data/.data/spec/std/isa/inst/V/vsmul.vv.yaml +134 -0
  1618. data/.data/spec/std/isa/inst/V/vsmul.vx.yaml +117 -0
  1619. data/.data/spec/std/isa/inst/V/vsoxei16.v.yaml +54 -0
  1620. data/.data/spec/std/isa/inst/V/vsoxei32.v.yaml +54 -0
  1621. data/.data/spec/std/isa/inst/V/vsoxei64.v.yaml +54 -0
  1622. data/.data/spec/std/isa/inst/V/vsoxei8.v.yaml +54 -0
  1623. data/.data/spec/std/isa/inst/V/vsoxseg2ei16.v.yaml +33 -0
  1624. data/.data/spec/std/isa/inst/V/vsoxseg2ei32.v.yaml +33 -0
  1625. data/.data/spec/std/isa/inst/V/vsoxseg2ei64.v.yaml +33 -0
  1626. data/.data/spec/std/isa/inst/V/vsoxseg2ei8.v.yaml +33 -0
  1627. data/.data/spec/std/isa/inst/V/vsoxseg3ei16.v.yaml +33 -0
  1628. data/.data/spec/std/isa/inst/V/vsoxseg3ei32.v.yaml +33 -0
  1629. data/.data/spec/std/isa/inst/V/vsoxseg3ei64.v.yaml +33 -0
  1630. data/.data/spec/std/isa/inst/V/vsoxseg3ei8.v.yaml +33 -0
  1631. data/.data/spec/std/isa/inst/V/vsoxseg4ei16.v.yaml +33 -0
  1632. data/.data/spec/std/isa/inst/V/vsoxseg4ei32.v.yaml +33 -0
  1633. data/.data/spec/std/isa/inst/V/vsoxseg4ei64.v.yaml +33 -0
  1634. data/.data/spec/std/isa/inst/V/vsoxseg4ei8.v.yaml +33 -0
  1635. data/.data/spec/std/isa/inst/V/vsoxseg5ei16.v.yaml +33 -0
  1636. data/.data/spec/std/isa/inst/V/vsoxseg5ei32.v.yaml +33 -0
  1637. data/.data/spec/std/isa/inst/V/vsoxseg5ei64.v.yaml +33 -0
  1638. data/.data/spec/std/isa/inst/V/vsoxseg5ei8.v.yaml +33 -0
  1639. data/.data/spec/std/isa/inst/V/vsoxseg6ei16.v.yaml +33 -0
  1640. data/.data/spec/std/isa/inst/V/vsoxseg6ei32.v.yaml +33 -0
  1641. data/.data/spec/std/isa/inst/V/vsoxseg6ei64.v.yaml +33 -0
  1642. data/.data/spec/std/isa/inst/V/vsoxseg6ei8.v.yaml +33 -0
  1643. data/.data/spec/std/isa/inst/V/vsoxseg7ei16.v.yaml +33 -0
  1644. data/.data/spec/std/isa/inst/V/vsoxseg7ei32.v.yaml +33 -0
  1645. data/.data/spec/std/isa/inst/V/vsoxseg7ei64.v.yaml +33 -0
  1646. data/.data/spec/std/isa/inst/V/vsoxseg7ei8.v.yaml +33 -0
  1647. data/.data/spec/std/isa/inst/V/vsoxseg8ei16.v.yaml +33 -0
  1648. data/.data/spec/std/isa/inst/V/vsoxseg8ei32.v.yaml +33 -0
  1649. data/.data/spec/std/isa/inst/V/vsoxseg8ei64.v.yaml +33 -0
  1650. data/.data/spec/std/isa/inst/V/vsoxseg8ei8.v.yaml +33 -0
  1651. data/.data/spec/std/isa/inst/V/vsra.vi.yaml +101 -0
  1652. data/.data/spec/std/isa/inst/V/vsra.vv.yaml +134 -0
  1653. data/.data/spec/std/isa/inst/V/vsra.vx.yaml +117 -0
  1654. data/.data/spec/std/isa/inst/V/vsrl.vi.yaml +101 -0
  1655. data/.data/spec/std/isa/inst/V/vsrl.vv.yaml +134 -0
  1656. data/.data/spec/std/isa/inst/V/vsrl.vx.yaml +117 -0
  1657. data/.data/spec/std/isa/inst/V/vsse16.v.yaml +54 -0
  1658. data/.data/spec/std/isa/inst/V/vsse32.v.yaml +54 -0
  1659. data/.data/spec/std/isa/inst/V/vsse64.v.yaml +54 -0
  1660. data/.data/spec/std/isa/inst/V/vsse8.v.yaml +54 -0
  1661. data/.data/spec/std/isa/inst/V/vsseg2e16.v.yaml +31 -0
  1662. data/.data/spec/std/isa/inst/V/vsseg2e32.v.yaml +31 -0
  1663. data/.data/spec/std/isa/inst/V/vsseg2e64.v.yaml +31 -0
  1664. data/.data/spec/std/isa/inst/V/vsseg2e8.v.yaml +31 -0
  1665. data/.data/spec/std/isa/inst/V/vsseg3e16.v.yaml +31 -0
  1666. data/.data/spec/std/isa/inst/V/vsseg3e32.v.yaml +31 -0
  1667. data/.data/spec/std/isa/inst/V/vsseg3e64.v.yaml +31 -0
  1668. data/.data/spec/std/isa/inst/V/vsseg3e8.v.yaml +31 -0
  1669. data/.data/spec/std/isa/inst/V/vsseg4e16.v.yaml +31 -0
  1670. data/.data/spec/std/isa/inst/V/vsseg4e32.v.yaml +31 -0
  1671. data/.data/spec/std/isa/inst/V/vsseg4e64.v.yaml +31 -0
  1672. data/.data/spec/std/isa/inst/V/vsseg4e8.v.yaml +31 -0
  1673. data/.data/spec/std/isa/inst/V/vsseg5e16.v.yaml +31 -0
  1674. data/.data/spec/std/isa/inst/V/vsseg5e32.v.yaml +31 -0
  1675. data/.data/spec/std/isa/inst/V/vsseg5e64.v.yaml +31 -0
  1676. data/.data/spec/std/isa/inst/V/vsseg5e8.v.yaml +31 -0
  1677. data/.data/spec/std/isa/inst/V/vsseg6e16.v.yaml +31 -0
  1678. data/.data/spec/std/isa/inst/V/vsseg6e32.v.yaml +31 -0
  1679. data/.data/spec/std/isa/inst/V/vsseg6e64.v.yaml +31 -0
  1680. data/.data/spec/std/isa/inst/V/vsseg6e8.v.yaml +31 -0
  1681. data/.data/spec/std/isa/inst/V/vsseg7e16.v.yaml +31 -0
  1682. data/.data/spec/std/isa/inst/V/vsseg7e32.v.yaml +31 -0
  1683. data/.data/spec/std/isa/inst/V/vsseg7e64.v.yaml +31 -0
  1684. data/.data/spec/std/isa/inst/V/vsseg7e8.v.yaml +31 -0
  1685. data/.data/spec/std/isa/inst/V/vsseg8e16.v.yaml +31 -0
  1686. data/.data/spec/std/isa/inst/V/vsseg8e32.v.yaml +31 -0
  1687. data/.data/spec/std/isa/inst/V/vsseg8e64.v.yaml +31 -0
  1688. data/.data/spec/std/isa/inst/V/vsseg8e8.v.yaml +31 -0
  1689. data/.data/spec/std/isa/inst/V/vssra.vi.yaml +101 -0
  1690. data/.data/spec/std/isa/inst/V/vssra.vv.yaml +134 -0
  1691. data/.data/spec/std/isa/inst/V/vssra.vx.yaml +117 -0
  1692. data/.data/spec/std/isa/inst/V/vssrl.vi.yaml +101 -0
  1693. data/.data/spec/std/isa/inst/V/vssrl.vv.yaml +134 -0
  1694. data/.data/spec/std/isa/inst/V/vssrl.vx.yaml +117 -0
  1695. data/.data/spec/std/isa/inst/V/vssseg2e16.v.yaml +33 -0
  1696. data/.data/spec/std/isa/inst/V/vssseg2e32.v.yaml +33 -0
  1697. data/.data/spec/std/isa/inst/V/vssseg2e64.v.yaml +33 -0
  1698. data/.data/spec/std/isa/inst/V/vssseg2e8.v.yaml +33 -0
  1699. data/.data/spec/std/isa/inst/V/vssseg3e16.v.yaml +33 -0
  1700. data/.data/spec/std/isa/inst/V/vssseg3e32.v.yaml +33 -0
  1701. data/.data/spec/std/isa/inst/V/vssseg3e64.v.yaml +33 -0
  1702. data/.data/spec/std/isa/inst/V/vssseg3e8.v.yaml +33 -0
  1703. data/.data/spec/std/isa/inst/V/vssseg4e16.v.yaml +33 -0
  1704. data/.data/spec/std/isa/inst/V/vssseg4e32.v.yaml +33 -0
  1705. data/.data/spec/std/isa/inst/V/vssseg4e64.v.yaml +33 -0
  1706. data/.data/spec/std/isa/inst/V/vssseg4e8.v.yaml +33 -0
  1707. data/.data/spec/std/isa/inst/V/vssseg5e16.v.yaml +33 -0
  1708. data/.data/spec/std/isa/inst/V/vssseg5e32.v.yaml +33 -0
  1709. data/.data/spec/std/isa/inst/V/vssseg5e64.v.yaml +33 -0
  1710. data/.data/spec/std/isa/inst/V/vssseg5e8.v.yaml +33 -0
  1711. data/.data/spec/std/isa/inst/V/vssseg6e16.v.yaml +33 -0
  1712. data/.data/spec/std/isa/inst/V/vssseg6e32.v.yaml +33 -0
  1713. data/.data/spec/std/isa/inst/V/vssseg6e64.v.yaml +33 -0
  1714. data/.data/spec/std/isa/inst/V/vssseg6e8.v.yaml +33 -0
  1715. data/.data/spec/std/isa/inst/V/vssseg7e16.v.yaml +33 -0
  1716. data/.data/spec/std/isa/inst/V/vssseg7e32.v.yaml +33 -0
  1717. data/.data/spec/std/isa/inst/V/vssseg7e64.v.yaml +33 -0
  1718. data/.data/spec/std/isa/inst/V/vssseg7e8.v.yaml +33 -0
  1719. data/.data/spec/std/isa/inst/V/vssseg8e16.v.yaml +33 -0
  1720. data/.data/spec/std/isa/inst/V/vssseg8e32.v.yaml +33 -0
  1721. data/.data/spec/std/isa/inst/V/vssseg8e64.v.yaml +33 -0
  1722. data/.data/spec/std/isa/inst/V/vssseg8e8.v.yaml +33 -0
  1723. data/.data/spec/std/isa/inst/V/vssub.vv.yaml +134 -0
  1724. data/.data/spec/std/isa/inst/V/vssub.vx.yaml +117 -0
  1725. data/.data/spec/std/isa/inst/V/vssubu.vv.yaml +134 -0
  1726. data/.data/spec/std/isa/inst/V/vssubu.vx.yaml +117 -0
  1727. data/.data/spec/std/isa/inst/V/vsub.vv.yaml +134 -0
  1728. data/.data/spec/std/isa/inst/V/vsub.vx.yaml +117 -0
  1729. data/.data/spec/std/isa/inst/V/vsuxei16.v.yaml +54 -0
  1730. data/.data/spec/std/isa/inst/V/vsuxei32.v.yaml +54 -0
  1731. data/.data/spec/std/isa/inst/V/vsuxei64.v.yaml +54 -0
  1732. data/.data/spec/std/isa/inst/V/vsuxei8.v.yaml +54 -0
  1733. data/.data/spec/std/isa/inst/V/vsuxseg2ei16.v.yaml +33 -0
  1734. data/.data/spec/std/isa/inst/V/vsuxseg2ei32.v.yaml +33 -0
  1735. data/.data/spec/std/isa/inst/V/vsuxseg2ei64.v.yaml +33 -0
  1736. data/.data/spec/std/isa/inst/V/vsuxseg2ei8.v.yaml +33 -0
  1737. data/.data/spec/std/isa/inst/V/vsuxseg3ei16.v.yaml +33 -0
  1738. data/.data/spec/std/isa/inst/V/vsuxseg3ei32.v.yaml +33 -0
  1739. data/.data/spec/std/isa/inst/V/vsuxseg3ei64.v.yaml +33 -0
  1740. data/.data/spec/std/isa/inst/V/vsuxseg3ei8.v.yaml +33 -0
  1741. data/.data/spec/std/isa/inst/V/vsuxseg4ei16.v.yaml +33 -0
  1742. data/.data/spec/std/isa/inst/V/vsuxseg4ei32.v.yaml +33 -0
  1743. data/.data/spec/std/isa/inst/V/vsuxseg4ei64.v.yaml +33 -0
  1744. data/.data/spec/std/isa/inst/V/vsuxseg4ei8.v.yaml +33 -0
  1745. data/.data/spec/std/isa/inst/V/vsuxseg5ei16.v.yaml +33 -0
  1746. data/.data/spec/std/isa/inst/V/vsuxseg5ei32.v.yaml +33 -0
  1747. data/.data/spec/std/isa/inst/V/vsuxseg5ei64.v.yaml +33 -0
  1748. data/.data/spec/std/isa/inst/V/vsuxseg5ei8.v.yaml +33 -0
  1749. data/.data/spec/std/isa/inst/V/vsuxseg6ei16.v.yaml +33 -0
  1750. data/.data/spec/std/isa/inst/V/vsuxseg6ei32.v.yaml +33 -0
  1751. data/.data/spec/std/isa/inst/V/vsuxseg6ei64.v.yaml +33 -0
  1752. data/.data/spec/std/isa/inst/V/vsuxseg6ei8.v.yaml +33 -0
  1753. data/.data/spec/std/isa/inst/V/vsuxseg7ei16.v.yaml +33 -0
  1754. data/.data/spec/std/isa/inst/V/vsuxseg7ei32.v.yaml +33 -0
  1755. data/.data/spec/std/isa/inst/V/vsuxseg7ei64.v.yaml +33 -0
  1756. data/.data/spec/std/isa/inst/V/vsuxseg7ei8.v.yaml +33 -0
  1757. data/.data/spec/std/isa/inst/V/vsuxseg8ei16.v.yaml +33 -0
  1758. data/.data/spec/std/isa/inst/V/vsuxseg8ei32.v.yaml +33 -0
  1759. data/.data/spec/std/isa/inst/V/vsuxseg8ei64.v.yaml +33 -0
  1760. data/.data/spec/std/isa/inst/V/vsuxseg8ei8.v.yaml +33 -0
  1761. data/.data/spec/std/isa/inst/V/vwadd.vv.yaml +83 -0
  1762. data/.data/spec/std/isa/inst/V/vwadd.vx.yaml +82 -0
  1763. data/.data/spec/std/isa/inst/V/vwadd.wv.yaml +79 -0
  1764. data/.data/spec/std/isa/inst/V/vwadd.wx.yaml +78 -0
  1765. data/.data/spec/std/isa/inst/V/vwaddu.vv.yaml +83 -0
  1766. data/.data/spec/std/isa/inst/V/vwaddu.vx.yaml +82 -0
  1767. data/.data/spec/std/isa/inst/V/vwaddu.wv.yaml +79 -0
  1768. data/.data/spec/std/isa/inst/V/vwaddu.wx.yaml +78 -0
  1769. data/.data/spec/std/isa/inst/V/vwmacc.vv.yaml +79 -0
  1770. data/.data/spec/std/isa/inst/V/vwmacc.vx.yaml +79 -0
  1771. data/.data/spec/std/isa/inst/V/vwmaccsu.vv.yaml +79 -0
  1772. data/.data/spec/std/isa/inst/V/vwmaccsu.vx.yaml +79 -0
  1773. data/.data/spec/std/isa/inst/V/vwmaccu.vv.yaml +79 -0
  1774. data/.data/spec/std/isa/inst/V/vwmaccu.vx.yaml +79 -0
  1775. data/.data/spec/std/isa/inst/V/vwmaccus.vx.yaml +79 -0
  1776. data/.data/spec/std/isa/inst/V/vwmul.vv.yaml +83 -0
  1777. data/.data/spec/std/isa/inst/V/vwmul.vx.yaml +82 -0
  1778. data/.data/spec/std/isa/inst/V/vwmulsu.vv.yaml +83 -0
  1779. data/.data/spec/std/isa/inst/V/vwmulsu.vx.yaml +82 -0
  1780. data/.data/spec/std/isa/inst/V/vwmulu.vv.yaml +83 -0
  1781. data/.data/spec/std/isa/inst/V/vwmulu.vx.yaml +82 -0
  1782. data/.data/spec/std/isa/inst/V/vwredsum.vs.yaml +79 -0
  1783. data/.data/spec/std/isa/inst/V/vwredsumu.vs.yaml +79 -0
  1784. data/.data/spec/std/isa/inst/V/vwsub.vv.yaml +83 -0
  1785. data/.data/spec/std/isa/inst/V/vwsub.vx.yaml +82 -0
  1786. data/.data/spec/std/isa/inst/V/vwsub.wv.yaml +79 -0
  1787. data/.data/spec/std/isa/inst/V/vwsub.wx.yaml +78 -0
  1788. data/.data/spec/std/isa/inst/V/vwsubu.vv.yaml +83 -0
  1789. data/.data/spec/std/isa/inst/V/vwsubu.vx.yaml +82 -0
  1790. data/.data/spec/std/isa/inst/V/vwsubu.wv.yaml +79 -0
  1791. data/.data/spec/std/isa/inst/V/vwsubu.wx.yaml +78 -0
  1792. data/.data/spec/std/isa/inst/V/vxor.vi.yaml +101 -0
  1793. data/.data/spec/std/isa/inst/V/vxor.vv.yaml +134 -0
  1794. data/.data/spec/std/isa/inst/V/vxor.vx.yaml +117 -0
  1795. data/.data/spec/std/isa/inst/V/vzext.vf2.yaml +75 -0
  1796. data/.data/spec/std/isa/inst/V/vzext.vf4.yaml +75 -0
  1797. data/.data/spec/std/isa/inst/V/vzext.vf8.yaml +75 -0
  1798. data/.data/spec/std/isa/inst/Zaamo/amoadd.SIZE.AQRL.layout +181 -0
  1799. data/.data/spec/std/isa/inst/Zaamo/amoadd.d.aq.yaml +145 -0
  1800. data/.data/spec/std/isa/inst/Zaamo/amoadd.d.aqrl.yaml +147 -0
  1801. data/.data/spec/std/isa/inst/Zaamo/amoadd.d.rl.yaml +145 -0
  1802. data/.data/spec/std/isa/inst/Zaamo/amoadd.d.yaml +143 -0
  1803. data/.data/spec/std/isa/inst/Zaamo/amoadd.w.aq.yaml +143 -0
  1804. data/.data/spec/std/isa/inst/Zaamo/amoadd.w.aqrl.yaml +145 -0
  1805. data/.data/spec/std/isa/inst/Zaamo/amoadd.w.rl.yaml +143 -0
  1806. data/.data/spec/std/isa/inst/Zaamo/amoadd.w.yaml +141 -0
  1807. data/.data/spec/std/isa/inst/Zaamo/amoand.SIZE.AQRL.layout +181 -0
  1808. data/.data/spec/std/isa/inst/Zaamo/amoand.d.aq.yaml +145 -0
  1809. data/.data/spec/std/isa/inst/Zaamo/amoand.d.aqrl.yaml +147 -0
  1810. data/.data/spec/std/isa/inst/Zaamo/amoand.d.rl.yaml +145 -0
  1811. data/.data/spec/std/isa/inst/Zaamo/amoand.d.yaml +143 -0
  1812. data/.data/spec/std/isa/inst/Zaamo/amoand.w.aq.yaml +143 -0
  1813. data/.data/spec/std/isa/inst/Zaamo/amoand.w.aqrl.yaml +145 -0
  1814. data/.data/spec/std/isa/inst/Zaamo/amoand.w.rl.yaml +143 -0
  1815. data/.data/spec/std/isa/inst/Zaamo/amoand.w.yaml +141 -0
  1816. data/.data/spec/std/isa/inst/Zaamo/amomax.SIZE.AQRL.layout +181 -0
  1817. data/.data/spec/std/isa/inst/Zaamo/amomax.d.aq.yaml +145 -0
  1818. data/.data/spec/std/isa/inst/Zaamo/amomax.d.aqrl.yaml +147 -0
  1819. data/.data/spec/std/isa/inst/Zaamo/amomax.d.rl.yaml +145 -0
  1820. data/.data/spec/std/isa/inst/Zaamo/amomax.d.yaml +143 -0
  1821. data/.data/spec/std/isa/inst/Zaamo/amomax.w.aq.yaml +143 -0
  1822. data/.data/spec/std/isa/inst/Zaamo/amomax.w.aqrl.yaml +145 -0
  1823. data/.data/spec/std/isa/inst/Zaamo/amomax.w.rl.yaml +143 -0
  1824. data/.data/spec/std/isa/inst/Zaamo/amomax.w.yaml +141 -0
  1825. data/.data/spec/std/isa/inst/Zaamo/amomaxu.SIZE.AQRL.layout +181 -0
  1826. data/.data/spec/std/isa/inst/Zaamo/amomaxu.d.aq.yaml +145 -0
  1827. data/.data/spec/std/isa/inst/Zaamo/amomaxu.d.aqrl.yaml +147 -0
  1828. data/.data/spec/std/isa/inst/Zaamo/amomaxu.d.rl.yaml +145 -0
  1829. data/.data/spec/std/isa/inst/Zaamo/amomaxu.d.yaml +143 -0
  1830. data/.data/spec/std/isa/inst/Zaamo/amomaxu.w.aq.yaml +143 -0
  1831. data/.data/spec/std/isa/inst/Zaamo/amomaxu.w.aqrl.yaml +145 -0
  1832. data/.data/spec/std/isa/inst/Zaamo/amomaxu.w.rl.yaml +143 -0
  1833. data/.data/spec/std/isa/inst/Zaamo/amomaxu.w.yaml +141 -0
  1834. data/.data/spec/std/isa/inst/Zaamo/amomin.SIZE.AQRL.layout +181 -0
  1835. data/.data/spec/std/isa/inst/Zaamo/amomin.d.aq.yaml +145 -0
  1836. data/.data/spec/std/isa/inst/Zaamo/amomin.d.aqrl.yaml +147 -0
  1837. data/.data/spec/std/isa/inst/Zaamo/amomin.d.rl.yaml +145 -0
  1838. data/.data/spec/std/isa/inst/Zaamo/amomin.d.yaml +143 -0
  1839. data/.data/spec/std/isa/inst/Zaamo/amomin.w.aq.yaml +143 -0
  1840. data/.data/spec/std/isa/inst/Zaamo/amomin.w.aqrl.yaml +145 -0
  1841. data/.data/spec/std/isa/inst/Zaamo/amomin.w.rl.yaml +143 -0
  1842. data/.data/spec/std/isa/inst/Zaamo/amomin.w.yaml +141 -0
  1843. data/.data/spec/std/isa/inst/Zaamo/amominu.SIZE.AQRL.layout +181 -0
  1844. data/.data/spec/std/isa/inst/Zaamo/amominu.d.aq.yaml +145 -0
  1845. data/.data/spec/std/isa/inst/Zaamo/amominu.d.aqrl.yaml +147 -0
  1846. data/.data/spec/std/isa/inst/Zaamo/amominu.d.rl.yaml +145 -0
  1847. data/.data/spec/std/isa/inst/Zaamo/amominu.d.yaml +143 -0
  1848. data/.data/spec/std/isa/inst/Zaamo/amominu.w.aq.yaml +143 -0
  1849. data/.data/spec/std/isa/inst/Zaamo/amominu.w.aqrl.yaml +145 -0
  1850. data/.data/spec/std/isa/inst/Zaamo/amominu.w.rl.yaml +143 -0
  1851. data/.data/spec/std/isa/inst/Zaamo/amominu.w.yaml +141 -0
  1852. data/.data/spec/std/isa/inst/Zaamo/amoor.SIZE.AQRL.layout +181 -0
  1853. data/.data/spec/std/isa/inst/Zaamo/amoor.d.aq.yaml +145 -0
  1854. data/.data/spec/std/isa/inst/Zaamo/amoor.d.aqrl.yaml +147 -0
  1855. data/.data/spec/std/isa/inst/Zaamo/amoor.d.rl.yaml +145 -0
  1856. data/.data/spec/std/isa/inst/Zaamo/amoor.d.yaml +143 -0
  1857. data/.data/spec/std/isa/inst/Zaamo/amoor.w.aq.yaml +143 -0
  1858. data/.data/spec/std/isa/inst/Zaamo/amoor.w.aqrl.yaml +145 -0
  1859. data/.data/spec/std/isa/inst/Zaamo/amoor.w.rl.yaml +143 -0
  1860. data/.data/spec/std/isa/inst/Zaamo/amoor.w.yaml +141 -0
  1861. data/.data/spec/std/isa/inst/Zaamo/amoswap.SIZE.AQRL.layout +180 -0
  1862. data/.data/spec/std/isa/inst/Zaamo/amoswap.d.aq.yaml +144 -0
  1863. data/.data/spec/std/isa/inst/Zaamo/amoswap.d.aqrl.yaml +146 -0
  1864. data/.data/spec/std/isa/inst/Zaamo/amoswap.d.rl.yaml +144 -0
  1865. data/.data/spec/std/isa/inst/Zaamo/amoswap.d.yaml +142 -0
  1866. data/.data/spec/std/isa/inst/Zaamo/amoswap.w.aq.yaml +142 -0
  1867. data/.data/spec/std/isa/inst/Zaamo/amoswap.w.aqrl.yaml +144 -0
  1868. data/.data/spec/std/isa/inst/Zaamo/amoswap.w.rl.yaml +142 -0
  1869. data/.data/spec/std/isa/inst/Zaamo/amoswap.w.yaml +140 -0
  1870. data/.data/spec/std/isa/inst/Zaamo/amoxor.SIZE.AQRL.layout +181 -0
  1871. data/.data/spec/std/isa/inst/Zaamo/amoxor.d.aq.yaml +145 -0
  1872. data/.data/spec/std/isa/inst/Zaamo/amoxor.d.aqrl.yaml +147 -0
  1873. data/.data/spec/std/isa/inst/Zaamo/amoxor.d.rl.yaml +145 -0
  1874. data/.data/spec/std/isa/inst/Zaamo/amoxor.d.yaml +143 -0
  1875. data/.data/spec/std/isa/inst/Zaamo/amoxor.w.aq.yaml +143 -0
  1876. data/.data/spec/std/isa/inst/Zaamo/amoxor.w.aqrl.yaml +145 -0
  1877. data/.data/spec/std/isa/inst/Zaamo/amoxor.w.rl.yaml +143 -0
  1878. data/.data/spec/std/isa/inst/Zaamo/amoxor.w.yaml +141 -0
  1879. data/.data/spec/std/isa/inst/Zabha/amoadd.b.aq.yaml +143 -0
  1880. data/.data/spec/std/isa/inst/Zabha/amoadd.b.aqrl.yaml +145 -0
  1881. data/.data/spec/std/isa/inst/Zabha/amoadd.b.rl.yaml +143 -0
  1882. data/.data/spec/std/isa/inst/Zabha/amoadd.b.yaml +141 -0
  1883. data/.data/spec/std/isa/inst/Zabha/amoadd.h.aq.yaml +143 -0
  1884. data/.data/spec/std/isa/inst/Zabha/amoadd.h.aqrl.yaml +145 -0
  1885. data/.data/spec/std/isa/inst/Zabha/amoadd.h.rl.yaml +143 -0
  1886. data/.data/spec/std/isa/inst/Zabha/amoadd.h.yaml +141 -0
  1887. data/.data/spec/std/isa/inst/Zabha/amoand.b.aq.yaml +143 -0
  1888. data/.data/spec/std/isa/inst/Zabha/amoand.b.aqrl.yaml +145 -0
  1889. data/.data/spec/std/isa/inst/Zabha/amoand.b.rl.yaml +143 -0
  1890. data/.data/spec/std/isa/inst/Zabha/amoand.b.yaml +141 -0
  1891. data/.data/spec/std/isa/inst/Zabha/amoand.h.aq.yaml +143 -0
  1892. data/.data/spec/std/isa/inst/Zabha/amoand.h.aqrl.yaml +145 -0
  1893. data/.data/spec/std/isa/inst/Zabha/amoand.h.rl.yaml +143 -0
  1894. data/.data/spec/std/isa/inst/Zabha/amoand.h.yaml +141 -0
  1895. data/.data/spec/std/isa/inst/Zabha/amocas.b.aq.yaml +135 -0
  1896. data/.data/spec/std/isa/inst/Zabha/amocas.b.aqrl.yaml +137 -0
  1897. data/.data/spec/std/isa/inst/Zabha/amocas.b.rl.yaml +135 -0
  1898. data/.data/spec/std/isa/inst/Zabha/amocas.b.yaml +133 -0
  1899. data/.data/spec/std/isa/inst/Zabha/amocas.h.aq.yaml +135 -0
  1900. data/.data/spec/std/isa/inst/Zabha/amocas.h.aqrl.yaml +137 -0
  1901. data/.data/spec/std/isa/inst/Zabha/amocas.h.rl.yaml +135 -0
  1902. data/.data/spec/std/isa/inst/Zabha/amocas.h.yaml +133 -0
  1903. data/.data/spec/std/isa/inst/Zabha/amomax.b.aq.yaml +143 -0
  1904. data/.data/spec/std/isa/inst/Zabha/amomax.b.aqrl.yaml +145 -0
  1905. data/.data/spec/std/isa/inst/Zabha/amomax.b.rl.yaml +143 -0
  1906. data/.data/spec/std/isa/inst/Zabha/amomax.b.yaml +141 -0
  1907. data/.data/spec/std/isa/inst/Zabha/amomax.h.aq.yaml +143 -0
  1908. data/.data/spec/std/isa/inst/Zabha/amomax.h.aqrl.yaml +145 -0
  1909. data/.data/spec/std/isa/inst/Zabha/amomax.h.rl.yaml +143 -0
  1910. data/.data/spec/std/isa/inst/Zabha/amomax.h.yaml +141 -0
  1911. data/.data/spec/std/isa/inst/Zabha/amomaxu.b.aq.yaml +143 -0
  1912. data/.data/spec/std/isa/inst/Zabha/amomaxu.b.aqrl.yaml +145 -0
  1913. data/.data/spec/std/isa/inst/Zabha/amomaxu.b.rl.yaml +143 -0
  1914. data/.data/spec/std/isa/inst/Zabha/amomaxu.b.yaml +141 -0
  1915. data/.data/spec/std/isa/inst/Zabha/amomaxu.h.aq.yaml +143 -0
  1916. data/.data/spec/std/isa/inst/Zabha/amomaxu.h.aqrl.yaml +145 -0
  1917. data/.data/spec/std/isa/inst/Zabha/amomaxu.h.rl.yaml +143 -0
  1918. data/.data/spec/std/isa/inst/Zabha/amomaxu.h.yaml +141 -0
  1919. data/.data/spec/std/isa/inst/Zabha/amomin.b.aq.yaml +143 -0
  1920. data/.data/spec/std/isa/inst/Zabha/amomin.b.aqrl.yaml +145 -0
  1921. data/.data/spec/std/isa/inst/Zabha/amomin.b.rl.yaml +143 -0
  1922. data/.data/spec/std/isa/inst/Zabha/amomin.b.yaml +141 -0
  1923. data/.data/spec/std/isa/inst/Zabha/amomin.h.aq.yaml +143 -0
  1924. data/.data/spec/std/isa/inst/Zabha/amomin.h.aqrl.yaml +145 -0
  1925. data/.data/spec/std/isa/inst/Zabha/amomin.h.rl.yaml +143 -0
  1926. data/.data/spec/std/isa/inst/Zabha/amomin.h.yaml +141 -0
  1927. data/.data/spec/std/isa/inst/Zabha/amominu.b.aq.yaml +143 -0
  1928. data/.data/spec/std/isa/inst/Zabha/amominu.b.aqrl.yaml +145 -0
  1929. data/.data/spec/std/isa/inst/Zabha/amominu.b.rl.yaml +143 -0
  1930. data/.data/spec/std/isa/inst/Zabha/amominu.b.yaml +141 -0
  1931. data/.data/spec/std/isa/inst/Zabha/amominu.h.aq.yaml +143 -0
  1932. data/.data/spec/std/isa/inst/Zabha/amominu.h.aqrl.yaml +145 -0
  1933. data/.data/spec/std/isa/inst/Zabha/amominu.h.rl.yaml +143 -0
  1934. data/.data/spec/std/isa/inst/Zabha/amominu.h.yaml +141 -0
  1935. data/.data/spec/std/isa/inst/Zabha/amoor.b.aq.yaml +143 -0
  1936. data/.data/spec/std/isa/inst/Zabha/amoor.b.aqrl.yaml +145 -0
  1937. data/.data/spec/std/isa/inst/Zabha/amoor.b.rl.yaml +143 -0
  1938. data/.data/spec/std/isa/inst/Zabha/amoor.b.yaml +141 -0
  1939. data/.data/spec/std/isa/inst/Zabha/amoor.h.aq.yaml +143 -0
  1940. data/.data/spec/std/isa/inst/Zabha/amoor.h.aqrl.yaml +145 -0
  1941. data/.data/spec/std/isa/inst/Zabha/amoor.h.rl.yaml +143 -0
  1942. data/.data/spec/std/isa/inst/Zabha/amoor.h.yaml +141 -0
  1943. data/.data/spec/std/isa/inst/Zabha/amoswap.b.aq.yaml +142 -0
  1944. data/.data/spec/std/isa/inst/Zabha/amoswap.b.aqrl.yaml +144 -0
  1945. data/.data/spec/std/isa/inst/Zabha/amoswap.b.rl.yaml +142 -0
  1946. data/.data/spec/std/isa/inst/Zabha/amoswap.b.yaml +140 -0
  1947. data/.data/spec/std/isa/inst/Zabha/amoswap.h.aq.yaml +142 -0
  1948. data/.data/spec/std/isa/inst/Zabha/amoswap.h.aqrl.yaml +144 -0
  1949. data/.data/spec/std/isa/inst/Zabha/amoswap.h.rl.yaml +142 -0
  1950. data/.data/spec/std/isa/inst/Zabha/amoswap.h.yaml +140 -0
  1951. data/.data/spec/std/isa/inst/Zabha/amoxor.b.aq.yaml +143 -0
  1952. data/.data/spec/std/isa/inst/Zabha/amoxor.b.aqrl.yaml +145 -0
  1953. data/.data/spec/std/isa/inst/Zabha/amoxor.b.rl.yaml +143 -0
  1954. data/.data/spec/std/isa/inst/Zabha/amoxor.b.yaml +141 -0
  1955. data/.data/spec/std/isa/inst/Zabha/amoxor.h.aq.yaml +143 -0
  1956. data/.data/spec/std/isa/inst/Zabha/amoxor.h.aqrl.yaml +145 -0
  1957. data/.data/spec/std/isa/inst/Zabha/amoxor.h.rl.yaml +143 -0
  1958. data/.data/spec/std/isa/inst/Zabha/amoxor.h.yaml +141 -0
  1959. data/.data/spec/std/isa/inst/Zacas/amocas.SIZE.AQRL.layout +174 -0
  1960. data/.data/spec/std/isa/inst/Zacas/amocas.d.aq.yaml +135 -0
  1961. data/.data/spec/std/isa/inst/Zacas/amocas.d.aqrl.yaml +137 -0
  1962. data/.data/spec/std/isa/inst/Zacas/amocas.d.rl.yaml +135 -0
  1963. data/.data/spec/std/isa/inst/Zacas/amocas.d.yaml +133 -0
  1964. data/.data/spec/std/isa/inst/Zacas/amocas.q.aq.yaml +137 -0
  1965. data/.data/spec/std/isa/inst/Zacas/amocas.q.aqrl.yaml +139 -0
  1966. data/.data/spec/std/isa/inst/Zacas/amocas.q.rl.yaml +137 -0
  1967. data/.data/spec/std/isa/inst/Zacas/amocas.q.yaml +135 -0
  1968. data/.data/spec/std/isa/inst/Zacas/amocas.w.aq.yaml +135 -0
  1969. data/.data/spec/std/isa/inst/Zacas/amocas.w.aqrl.yaml +137 -0
  1970. data/.data/spec/std/isa/inst/Zacas/amocas.w.rl.yaml +135 -0
  1971. data/.data/spec/std/isa/inst/Zacas/amocas.w.yaml +133 -0
  1972. data/.data/spec/std/isa/inst/Zalasr/lSIZE.AQRL.layout +80 -0
  1973. data/.data/spec/std/isa/inst/Zalasr/lb.aq.yaml +65 -0
  1974. data/.data/spec/std/isa/inst/Zalasr/lb.aqrl.yaml +65 -0
  1975. data/.data/spec/std/isa/inst/Zalasr/ld.aq.yaml +65 -0
  1976. data/.data/spec/std/isa/inst/Zalasr/ld.aqrl.yaml +65 -0
  1977. data/.data/spec/std/isa/inst/Zalasr/lh.aq.yaml +65 -0
  1978. data/.data/spec/std/isa/inst/Zalasr/lh.aqrl.yaml +65 -0
  1979. data/.data/spec/std/isa/inst/Zalasr/lw.aq.yaml +65 -0
  1980. data/.data/spec/std/isa/inst/Zalasr/lw.aqrl.yaml +65 -0
  1981. data/.data/spec/std/isa/inst/Zalasr/sSIZE.AQRL.layout +95 -0
  1982. data/.data/spec/std/isa/inst/Zalasr/sb.aqrl.yaml +80 -0
  1983. data/.data/spec/std/isa/inst/Zalasr/sb.rl.yaml +80 -0
  1984. data/.data/spec/std/isa/inst/Zalasr/sd.aqrl.yaml +80 -0
  1985. data/.data/spec/std/isa/inst/Zalasr/sd.rl.yaml +80 -0
  1986. data/.data/spec/std/isa/inst/Zalasr/sh.aqrl.yaml +80 -0
  1987. data/.data/spec/std/isa/inst/Zalasr/sh.rl.yaml +80 -0
  1988. data/.data/spec/std/isa/inst/Zalasr/sw.aqrl.yaml +80 -0
  1989. data/.data/spec/std/isa/inst/Zalasr/sw.rl.yaml +80 -0
  1990. data/.data/spec/std/isa/inst/Zalrsc/lr.SIZE.AQRL.layout +205 -0
  1991. data/.data/spec/std/isa/inst/Zalrsc/lr.d.aq.yaml +151 -0
  1992. data/.data/spec/std/isa/inst/Zalrsc/lr.d.aqrl.yaml +151 -0
  1993. data/.data/spec/std/isa/inst/Zalrsc/lr.d.rl.yaml +151 -0
  1994. data/.data/spec/std/isa/inst/Zalrsc/lr.d.yaml +151 -0
  1995. data/.data/spec/std/isa/inst/Zalrsc/lr.w.aq.yaml +158 -0
  1996. data/.data/spec/std/isa/inst/Zalrsc/lr.w.aqrl.yaml +158 -0
  1997. data/.data/spec/std/isa/inst/Zalrsc/lr.w.rl.yaml +158 -0
  1998. data/.data/spec/std/isa/inst/Zalrsc/lr.w.yaml +158 -0
  1999. data/.data/spec/std/isa/inst/Zalrsc/sc.SIZE.AQRL.layout +288 -0
  2000. data/.data/spec/std/isa/inst/Zalrsc/sc.d.aq.yaml +245 -0
  2001. data/.data/spec/std/isa/inst/Zalrsc/sc.d.aqrl.yaml +245 -0
  2002. data/.data/spec/std/isa/inst/Zalrsc/sc.d.rl.yaml +245 -0
  2003. data/.data/spec/std/isa/inst/Zalrsc/sc.d.yaml +245 -0
  2004. data/.data/spec/std/isa/inst/Zalrsc/sc.w.aq.yaml +247 -0
  2005. data/.data/spec/std/isa/inst/Zalrsc/sc.w.aqrl.yaml +247 -0
  2006. data/.data/spec/std/isa/inst/Zalrsc/sc.w.rl.yaml +247 -0
  2007. data/.data/spec/std/isa/inst/Zalrsc/sc.w.yaml +247 -0
  2008. data/.data/spec/std/isa/inst/Zawrs/wrs.nto.yaml +77 -0
  2009. data/.data/spec/std/isa/inst/Zawrs/wrs.sto.yaml +57 -0
  2010. data/.data/spec/std/isa/inst/Zba/add.uw.yaml +63 -0
  2011. data/.data/spec/std/isa/inst/Zba/sh1add.uw.yaml +59 -0
  2012. data/.data/spec/std/isa/inst/Zba/sh1add.yaml +54 -0
  2013. data/.data/spec/std/isa/inst/Zba/sh2add.uw.yaml +59 -0
  2014. data/.data/spec/std/isa/inst/Zba/sh2add.yaml +54 -0
  2015. data/.data/spec/std/isa/inst/Zba/sh3add.uw.yaml +59 -0
  2016. data/.data/spec/std/isa/inst/Zba/sh3add.yaml +54 -0
  2017. data/.data/spec/std/isa/inst/Zba/slli.uw.yaml +54 -0
  2018. data/.data/spec/std/isa/inst/Zbb/clz.yaml +54 -0
  2019. data/.data/spec/std/isa/inst/Zbb/clzw.yaml +55 -0
  2020. data/.data/spec/std/isa/inst/Zbb/cpop.yaml +69 -0
  2021. data/.data/spec/std/isa/inst/Zbb/cpopw.yaml +71 -0
  2022. data/.data/spec/std/isa/inst/Zbb/ctz.yaml +59 -0
  2023. data/.data/spec/std/isa/inst/Zbb/ctzw.yaml +57 -0
  2024. data/.data/spec/std/isa/inst/Zbb/max.yaml +71 -0
  2025. data/.data/spec/std/isa/inst/Zbb/maxu.yaml +63 -0
  2026. data/.data/spec/std/isa/inst/Zbb/min.yaml +63 -0
  2027. data/.data/spec/std/isa/inst/Zbb/minu.yaml +63 -0
  2028. data/.data/spec/std/isa/inst/Zbb/orc.b.yaml +59 -0
  2029. data/.data/spec/std/isa/inst/Zbb/sext.b.yaml +55 -0
  2030. data/.data/spec/std/isa/inst/Zbb/sext.h.yaml +55 -0
  2031. data/.data/spec/std/isa/inst/Zbb/zext.h.yaml +69 -0
  2032. data/.data/spec/std/isa/inst/Zbc/clmulr.yaml +61 -0
  2033. data/.data/spec/std/isa/inst/Zbkb/brev8.yaml +51 -0
  2034. data/.data/spec/std/isa/inst/Zbkb/pack.yaml +34 -0
  2035. data/.data/spec/std/isa/inst/Zbkb/packh.yaml +31 -0
  2036. data/.data/spec/std/isa/inst/Zbkb/packw.yaml +36 -0
  2037. data/.data/spec/std/isa/inst/Zbkb/unzip.yaml +53 -0
  2038. data/.data/spec/std/isa/inst/Zbkb/zip.yaml +53 -0
  2039. data/.data/spec/std/isa/inst/Zbkx/xperm4.yaml +64 -0
  2040. data/.data/spec/std/isa/inst/Zbkx/xperm8.yaml +64 -0
  2041. data/.data/spec/std/isa/inst/Zbs/bclr.yaml +59 -0
  2042. data/.data/spec/std/isa/inst/Zbs/bclri.yaml +69 -0
  2043. data/.data/spec/std/isa/inst/Zbs/bext.yaml +59 -0
  2044. data/.data/spec/std/isa/inst/Zbs/bexti.yaml +69 -0
  2045. data/.data/spec/std/isa/inst/Zbs/binv.yaml +59 -0
  2046. data/.data/spec/std/isa/inst/Zbs/binvi.yaml +69 -0
  2047. data/.data/spec/std/isa/inst/Zbs/bset.yaml +59 -0
  2048. data/.data/spec/std/isa/inst/Zbs/bseti.yaml +69 -0
  2049. data/.data/spec/std/isa/inst/Zcb/c.lbu.yaml +72 -0
  2050. data/.data/spec/std/isa/inst/Zcb/c.lh.yaml +73 -0
  2051. data/.data/spec/std/isa/inst/Zcb/c.lhu.yaml +73 -0
  2052. data/.data/spec/std/isa/inst/Zcb/c.mul.yaml +53 -0
  2053. data/.data/spec/std/isa/inst/Zcb/c.not.yaml +45 -0
  2054. data/.data/spec/std/isa/inst/Zcb/c.sb.yaml +39 -0
  2055. data/.data/spec/std/isa/inst/Zcb/c.sext.b.yaml +60 -0
  2056. data/.data/spec/std/isa/inst/Zcb/c.sext.h.yaml +60 -0
  2057. data/.data/spec/std/isa/inst/Zcb/c.sh.yaml +40 -0
  2058. data/.data/spec/std/isa/inst/Zcb/c.zext.b.yaml +60 -0
  2059. data/.data/spec/std/isa/inst/Zcb/c.zext.h.yaml +60 -0
  2060. data/.data/spec/std/isa/inst/Zcb/c.zext.w.yaml +61 -0
  2061. data/.data/spec/std/isa/inst/Zcd/c.fld.yaml +41 -0
  2062. data/.data/spec/std/isa/inst/Zcd/c.fldsp.yaml +42 -0
  2063. data/.data/spec/std/isa/inst/Zcd/c.fsd.yaml +41 -0
  2064. data/.data/spec/std/isa/inst/Zcd/c.fsdsp.yaml +42 -0
  2065. data/.data/spec/std/isa/inst/Zcf/c.flw.yaml +41 -0
  2066. data/.data/spec/std/isa/inst/Zcf/c.flwsp.yaml +42 -0
  2067. data/.data/spec/std/isa/inst/Zcf/c.fsw.yaml +41 -0
  2068. data/.data/spec/std/isa/inst/Zcf/c.fswsp.yaml +42 -0
  2069. data/.data/spec/std/isa/inst/Zcmop/c.mop.1.yaml +31 -0
  2070. data/.data/spec/std/isa/inst/Zcmop/c.mop.11.yaml +31 -0
  2071. data/.data/spec/std/isa/inst/Zcmop/c.mop.13.yaml +31 -0
  2072. data/.data/spec/std/isa/inst/Zcmop/c.mop.15.yaml +31 -0
  2073. data/.data/spec/std/isa/inst/Zcmop/c.mop.3.yaml +31 -0
  2074. data/.data/spec/std/isa/inst/Zcmop/c.mop.5.yaml +31 -0
  2075. data/.data/spec/std/isa/inst/Zcmop/c.mop.7.yaml +31 -0
  2076. data/.data/spec/std/isa/inst/Zcmop/c.mop.9.yaml +31 -0
  2077. data/.data/spec/std/isa/inst/Zcmop/c.mop.N.layout +45 -0
  2078. data/.data/spec/std/isa/inst/Zcmp/cm.mva01s.yaml +36 -0
  2079. data/.data/spec/std/isa/inst/Zcmp/cm.mvsa01.yaml +38 -0
  2080. data/.data/spec/std/isa/inst/Zcmp/cm.pop.yaml +86 -0
  2081. data/.data/spec/std/isa/inst/Zcmp/cm.popret.yaml +87 -0
  2082. data/.data/spec/std/isa/inst/Zcmp/cm.popretz.yaml +88 -0
  2083. data/.data/spec/std/isa/inst/Zcmp/cm.push.yaml +87 -0
  2084. data/.data/spec/std/isa/inst/Zcmt/cm.jalt.yaml +65 -0
  2085. data/.data/spec/std/isa/inst/Zcmt/cm.jt.yaml +60 -0
  2086. data/.data/spec/std/isa/inst/Zfa/fli.s.yaml +74 -0
  2087. data/.data/spec/std/isa/inst/Zfa/fmaxm.s.yaml +55 -0
  2088. data/.data/spec/std/isa/inst/Zfa/fminm.s.yaml +55 -0
  2089. data/.data/spec/std/isa/inst/Zfa/fround.s.yaml +63 -0
  2090. data/.data/spec/std/isa/inst/Zfa/froundnx.s.yaml +53 -0
  2091. data/.data/spec/std/isa/inst/Zfbfmin/fcvt.bf16.s.yaml +31 -0
  2092. data/.data/spec/std/isa/inst/Zfbfmin/fcvt.s.bf16.yaml +31 -0
  2093. data/.data/spec/std/isa/inst/Zfh/fadd.h.yaml +35 -0
  2094. data/.data/spec/std/isa/inst/Zfh/fclass.h.yaml +31 -0
  2095. data/.data/spec/std/isa/inst/Zfh/fcvt.d.h.yaml +37 -0
  2096. data/.data/spec/std/isa/inst/Zfh/fcvt.h.d.yaml +37 -0
  2097. data/.data/spec/std/isa/inst/Zfh/fcvt.h.l.yaml +35 -0
  2098. data/.data/spec/std/isa/inst/Zfh/fcvt.h.lu.yaml +35 -0
  2099. data/.data/spec/std/isa/inst/Zfh/fcvt.h.s.yaml +94 -0
  2100. data/.data/spec/std/isa/inst/Zfh/fcvt.h.w.yaml +33 -0
  2101. data/.data/spec/std/isa/inst/Zfh/fcvt.h.wu.yaml +33 -0
  2102. data/.data/spec/std/isa/inst/Zfh/fcvt.l.h.yaml +35 -0
  2103. data/.data/spec/std/isa/inst/Zfh/fcvt.lu.h.yaml +35 -0
  2104. data/.data/spec/std/isa/inst/Zfh/fcvt.s.h.yaml +91 -0
  2105. data/.data/spec/std/isa/inst/Zfh/fcvt.w.h.yaml +33 -0
  2106. data/.data/spec/std/isa/inst/Zfh/fcvt.wu.h.yaml +33 -0
  2107. data/.data/spec/std/isa/inst/Zfh/fdiv.h.yaml +35 -0
  2108. data/.data/spec/std/isa/inst/Zfh/feq.h.yaml +33 -0
  2109. data/.data/spec/std/isa/inst/Zfh/fle.h.yaml +33 -0
  2110. data/.data/spec/std/isa/inst/Zfh/fleq.h.yaml +33 -0
  2111. data/.data/spec/std/isa/inst/Zfh/flh.yaml +78 -0
  2112. data/.data/spec/std/isa/inst/Zfh/fli.h.yaml +31 -0
  2113. data/.data/spec/std/isa/inst/Zfh/flt.h.yaml +33 -0
  2114. data/.data/spec/std/isa/inst/Zfh/fltq.h.yaml +33 -0
  2115. data/.data/spec/std/isa/inst/Zfh/fmadd.h.yaml +37 -0
  2116. data/.data/spec/std/isa/inst/Zfh/fmax.h.yaml +33 -0
  2117. data/.data/spec/std/isa/inst/Zfh/fmaxm.h.yaml +33 -0
  2118. data/.data/spec/std/isa/inst/Zfh/fmin.h.yaml +33 -0
  2119. data/.data/spec/std/isa/inst/Zfh/fminm.h.yaml +33 -0
  2120. data/.data/spec/std/isa/inst/Zfh/fmsub.h.yaml +37 -0
  2121. data/.data/spec/std/isa/inst/Zfh/fmul.h.yaml +35 -0
  2122. data/.data/spec/std/isa/inst/Zfh/fmv.h.x.yaml +51 -0
  2123. data/.data/spec/std/isa/inst/Zfh/fmv.x.h.yaml +51 -0
  2124. data/.data/spec/std/isa/inst/Zfh/fnmadd.h.yaml +37 -0
  2125. data/.data/spec/std/isa/inst/Zfh/fnmsub.h.yaml +37 -0
  2126. data/.data/spec/std/isa/inst/Zfh/fround.h.yaml +33 -0
  2127. data/.data/spec/std/isa/inst/Zfh/froundnx.h.yaml +33 -0
  2128. data/.data/spec/std/isa/inst/Zfh/fsgnj.h.yaml +33 -0
  2129. data/.data/spec/std/isa/inst/Zfh/fsgnjn.h.yaml +33 -0
  2130. data/.data/spec/std/isa/inst/Zfh/fsgnjx.h.yaml +33 -0
  2131. data/.data/spec/std/isa/inst/Zfh/fsh.yaml +89 -0
  2132. data/.data/spec/std/isa/inst/Zfh/fsqrt.h.yaml +33 -0
  2133. data/.data/spec/std/isa/inst/Zfh/fsub.h.yaml +35 -0
  2134. data/.data/spec/std/isa/inst/Zicbom/cbo.clean.yaml +77 -0
  2135. data/.data/spec/std/isa/inst/Zicbom/cbo.flush.yaml +75 -0
  2136. data/.data/spec/std/isa/inst/Zicbom/cbo.inval.yaml +116 -0
  2137. data/.data/spec/std/isa/inst/Zicbop/prefetch.i.yaml +34 -0
  2138. data/.data/spec/std/isa/inst/Zicbop/prefetch.r.yaml +34 -0
  2139. data/.data/spec/std/isa/inst/Zicbop/prefetch.w.yaml +34 -0
  2140. data/.data/spec/std/isa/inst/Zicboz/cbo.zero.yaml +107 -0
  2141. data/.data/spec/std/isa/inst/Zicfilp/lpad.yaml +28 -0
  2142. data/.data/spec/std/isa/inst/Zicfiss/ssamoswap.d.yaml +35 -0
  2143. data/.data/spec/std/isa/inst/Zicfiss/ssamoswap.w.yaml +35 -0
  2144. data/.data/spec/std/isa/inst/Zicfiss/sspopchk.x1.yaml +25 -0
  2145. data/.data/spec/std/isa/inst/Zicfiss/sspopchk.x5.yaml +25 -0
  2146. data/.data/spec/std/isa/inst/Zicfiss/sspush.x1.yaml +25 -0
  2147. data/.data/spec/std/isa/inst/Zicfiss/sspush.x5.yaml +25 -0
  2148. data/.data/spec/std/isa/inst/Zicfiss/ssrdp.yaml +28 -0
  2149. data/.data/spec/std/isa/inst/Zicond/czero.eqz.yaml +50 -0
  2150. data/.data/spec/std/isa/inst/Zicond/czero.nez.yaml +50 -0
  2151. data/.data/spec/std/isa/inst/Zicsr/csrrc.yaml +68 -0
  2152. data/.data/spec/std/isa/inst/Zicsr/csrrci.yaml +62 -0
  2153. data/.data/spec/std/isa/inst/Zicsr/csrrs.yaml +114 -0
  2154. data/.data/spec/std/isa/inst/Zicsr/csrrsi.yaml +62 -0
  2155. data/.data/spec/std/isa/inst/Zicsr/csrrw.yaml +90 -0
  2156. data/.data/spec/std/isa/inst/Zicsr/csrrwi.yaml +88 -0
  2157. data/.data/spec/std/isa/inst/Zifencei/fence.i.yaml +65 -0
  2158. data/.data/spec/std/isa/inst/Zihintntl/c.ntl.all.yaml +27 -0
  2159. data/.data/spec/std/isa/inst/Zihintntl/c.ntl.p1.yaml +27 -0
  2160. data/.data/spec/std/isa/inst/Zihintntl/c.ntl.pall.yaml +27 -0
  2161. data/.data/spec/std/isa/inst/Zihintntl/c.ntl.s1.yaml +27 -0
  2162. data/.data/spec/std/isa/inst/Zihintntl/ntl.all.yaml +25 -0
  2163. data/.data/spec/std/isa/inst/Zihintntl/ntl.p1.yaml +25 -0
  2164. data/.data/spec/std/isa/inst/Zihintntl/ntl.pall.yaml +25 -0
  2165. data/.data/spec/std/isa/inst/Zihintntl/ntl.s1.yaml +25 -0
  2166. data/.data/spec/std/isa/inst/Zihintpause/pause.yaml +76 -0
  2167. data/.data/spec/std/isa/inst/Zimop/mop.r.0.yaml +36 -0
  2168. data/.data/spec/std/isa/inst/Zimop/mop.r.1.yaml +36 -0
  2169. data/.data/spec/std/isa/inst/Zimop/mop.r.10.yaml +36 -0
  2170. data/.data/spec/std/isa/inst/Zimop/mop.r.11.yaml +36 -0
  2171. data/.data/spec/std/isa/inst/Zimop/mop.r.12.yaml +36 -0
  2172. data/.data/spec/std/isa/inst/Zimop/mop.r.13.yaml +36 -0
  2173. data/.data/spec/std/isa/inst/Zimop/mop.r.14.yaml +36 -0
  2174. data/.data/spec/std/isa/inst/Zimop/mop.r.15.yaml +36 -0
  2175. data/.data/spec/std/isa/inst/Zimop/mop.r.16.yaml +36 -0
  2176. data/.data/spec/std/isa/inst/Zimop/mop.r.17.yaml +36 -0
  2177. data/.data/spec/std/isa/inst/Zimop/mop.r.18.yaml +36 -0
  2178. data/.data/spec/std/isa/inst/Zimop/mop.r.19.yaml +36 -0
  2179. data/.data/spec/std/isa/inst/Zimop/mop.r.2.yaml +36 -0
  2180. data/.data/spec/std/isa/inst/Zimop/mop.r.20.yaml +36 -0
  2181. data/.data/spec/std/isa/inst/Zimop/mop.r.21.yaml +36 -0
  2182. data/.data/spec/std/isa/inst/Zimop/mop.r.22.yaml +36 -0
  2183. data/.data/spec/std/isa/inst/Zimop/mop.r.23.yaml +36 -0
  2184. data/.data/spec/std/isa/inst/Zimop/mop.r.24.yaml +36 -0
  2185. data/.data/spec/std/isa/inst/Zimop/mop.r.25.yaml +36 -0
  2186. data/.data/spec/std/isa/inst/Zimop/mop.r.26.yaml +36 -0
  2187. data/.data/spec/std/isa/inst/Zimop/mop.r.27.yaml +36 -0
  2188. data/.data/spec/std/isa/inst/Zimop/mop.r.28.yaml +40 -0
  2189. data/.data/spec/std/isa/inst/Zimop/mop.r.29.yaml +36 -0
  2190. data/.data/spec/std/isa/inst/Zimop/mop.r.3.yaml +36 -0
  2191. data/.data/spec/std/isa/inst/Zimop/mop.r.30.yaml +36 -0
  2192. data/.data/spec/std/isa/inst/Zimop/mop.r.31.yaml +36 -0
  2193. data/.data/spec/std/isa/inst/Zimop/mop.r.4.yaml +36 -0
  2194. data/.data/spec/std/isa/inst/Zimop/mop.r.5.yaml +36 -0
  2195. data/.data/spec/std/isa/inst/Zimop/mop.r.6.yaml +36 -0
  2196. data/.data/spec/std/isa/inst/Zimop/mop.r.7.yaml +36 -0
  2197. data/.data/spec/std/isa/inst/Zimop/mop.r.8.yaml +36 -0
  2198. data/.data/spec/std/isa/inst/Zimop/mop.r.9.yaml +36 -0
  2199. data/.data/spec/std/isa/inst/Zimop/mop.r.N.layout +58 -0
  2200. data/.data/spec/std/isa/inst/Zimop/mop.rr.0.yaml +39 -0
  2201. data/.data/spec/std/isa/inst/Zimop/mop.rr.1.yaml +39 -0
  2202. data/.data/spec/std/isa/inst/Zimop/mop.rr.2.yaml +39 -0
  2203. data/.data/spec/std/isa/inst/Zimop/mop.rr.3.yaml +39 -0
  2204. data/.data/spec/std/isa/inst/Zimop/mop.rr.4.yaml +39 -0
  2205. data/.data/spec/std/isa/inst/Zimop/mop.rr.5.yaml +39 -0
  2206. data/.data/spec/std/isa/inst/Zimop/mop.rr.6.yaml +39 -0
  2207. data/.data/spec/std/isa/inst/Zimop/mop.rr.7.yaml +42 -0
  2208. data/.data/spec/std/isa/inst/Zimop/mop.rr.N.layout +58 -0
  2209. data/.data/spec/std/isa/inst/Zkn/aes64ks1i.yaml +37 -0
  2210. data/.data/spec/std/isa/inst/Zkn/aes64ks2.yaml +36 -0
  2211. data/.data/spec/std/isa/inst/Zknd/aes32dsi.yaml +37 -0
  2212. data/.data/spec/std/isa/inst/Zknd/aes32dsmi.yaml +38 -0
  2213. data/.data/spec/std/isa/inst/Zknd/aes64ds.yaml +34 -0
  2214. data/.data/spec/std/isa/inst/Zknd/aes64dsm.yaml +34 -0
  2215. data/.data/spec/std/isa/inst/Zknd/aes64im.yaml +33 -0
  2216. data/.data/spec/std/isa/inst/Zkne/aes32esi.yaml +35 -0
  2217. data/.data/spec/std/isa/inst/Zkne/aes32esmi.yaml +35 -0
  2218. data/.data/spec/std/isa/inst/Zkne/aes64es.yaml +34 -0
  2219. data/.data/spec/std/isa/inst/Zkne/aes64esm.yaml +34 -0
  2220. data/.data/spec/std/isa/inst/Zknh/sha256sig0.yaml +29 -0
  2221. data/.data/spec/std/isa/inst/Zknh/sha256sig1.yaml +29 -0
  2222. data/.data/spec/std/isa/inst/Zknh/sha256sum0.yaml +29 -0
  2223. data/.data/spec/std/isa/inst/Zknh/sha256sum1.yaml +29 -0
  2224. data/.data/spec/std/isa/inst/Zknh/sha512sig0.yaml +31 -0
  2225. data/.data/spec/std/isa/inst/Zknh/sha512sig0h.yaml +33 -0
  2226. data/.data/spec/std/isa/inst/Zknh/sha512sig0l.yaml +33 -0
  2227. data/.data/spec/std/isa/inst/Zknh/sha512sig1.yaml +31 -0
  2228. data/.data/spec/std/isa/inst/Zknh/sha512sig1h.yaml +33 -0
  2229. data/.data/spec/std/isa/inst/Zknh/sha512sig1l.yaml +33 -0
  2230. data/.data/spec/std/isa/inst/Zknh/sha512sum0.yaml +31 -0
  2231. data/.data/spec/std/isa/inst/Zknh/sha512sum0r.yaml +33 -0
  2232. data/.data/spec/std/isa/inst/Zknh/sha512sum1.yaml +31 -0
  2233. data/.data/spec/std/isa/inst/Zknh/sha512sum1r.yaml +33 -0
  2234. data/.data/spec/std/isa/inst/Zks/sm3p0.yaml +29 -0
  2235. data/.data/spec/std/isa/inst/Zks/sm3p1.yaml +29 -0
  2236. data/.data/spec/std/isa/inst/Zks/sm4ed.yaml +33 -0
  2237. data/.data/spec/std/isa/inst/Zks/sm4ks.yaml +33 -0
  2238. data/.data/spec/std/isa/inst/Zvbb/vandn.vv.yaml +33 -0
  2239. data/.data/spec/std/isa/inst/Zvbb/vandn.vx.yaml +33 -0
  2240. data/.data/spec/std/isa/inst/Zvbb/vbrev.v.yaml +31 -0
  2241. data/.data/spec/std/isa/inst/Zvbb/vbrev8.v.yaml +31 -0
  2242. data/.data/spec/std/isa/inst/Zvbb/vclz.v.yaml +31 -0
  2243. data/.data/spec/std/isa/inst/Zvbb/vcpop.v.yaml +31 -0
  2244. data/.data/spec/std/isa/inst/Zvbb/vctz.v.yaml +31 -0
  2245. data/.data/spec/std/isa/inst/Zvbb/vrev8.v.yaml +31 -0
  2246. data/.data/spec/std/isa/inst/Zvbb/vrol.vv.yaml +33 -0
  2247. data/.data/spec/std/isa/inst/Zvbb/vrol.vx.yaml +33 -0
  2248. data/.data/spec/std/isa/inst/Zvbb/vror.vi.yaml +33 -0
  2249. data/.data/spec/std/isa/inst/Zvbb/vror.vv.yaml +33 -0
  2250. data/.data/spec/std/isa/inst/Zvbb/vror.vx.yaml +33 -0
  2251. data/.data/spec/std/isa/inst/Zvbb/vwsll.vi.yaml +33 -0
  2252. data/.data/spec/std/isa/inst/Zvbb/vwsll.vv.yaml +33 -0
  2253. data/.data/spec/std/isa/inst/Zvbb/vwsll.vx.yaml +33 -0
  2254. data/.data/spec/std/isa/inst/Zvbc/vclmul.vv.yaml +33 -0
  2255. data/.data/spec/std/isa/inst/Zvbc/vclmul.vx.yaml +33 -0
  2256. data/.data/spec/std/isa/inst/Zvbc/vclmulh.vv.yaml +33 -0
  2257. data/.data/spec/std/isa/inst/Zvbc/vclmulh.vx.yaml +33 -0
  2258. data/.data/spec/std/isa/inst/Zvfbfmin/vfncvtbf16.f.f.w.yaml +31 -0
  2259. data/.data/spec/std/isa/inst/Zvfbfmin/vfwcvtbf16.f.f.v.yaml +31 -0
  2260. data/.data/spec/std/isa/inst/Zvfbfwma/vfwmaccbf16.vf.yaml +33 -0
  2261. data/.data/spec/std/isa/inst/Zvfbfwma/vfwmaccbf16.vv.yaml +33 -0
  2262. data/.data/spec/std/isa/inst/Zvkg/vghsh.vv.yaml +31 -0
  2263. data/.data/spec/std/isa/inst/Zvkg/vgmul.vv.yaml +29 -0
  2264. data/.data/spec/std/isa/inst/Zvkned/vaesdf.vs.yaml +29 -0
  2265. data/.data/spec/std/isa/inst/Zvkned/vaesdf.vv.yaml +29 -0
  2266. data/.data/spec/std/isa/inst/Zvkned/vaesdm.vs.yaml +29 -0
  2267. data/.data/spec/std/isa/inst/Zvkned/vaesdm.vv.yaml +29 -0
  2268. data/.data/spec/std/isa/inst/Zvkned/vaesef.vs.yaml +29 -0
  2269. data/.data/spec/std/isa/inst/Zvkned/vaesef.vv.yaml +29 -0
  2270. data/.data/spec/std/isa/inst/Zvkned/vaesem.vs.yaml +29 -0
  2271. data/.data/spec/std/isa/inst/Zvkned/vaesem.vv.yaml +29 -0
  2272. data/.data/spec/std/isa/inst/Zvkned/vaeskf1.vi.yaml +31 -0
  2273. data/.data/spec/std/isa/inst/Zvkned/vaeskf2.vi.yaml +31 -0
  2274. data/.data/spec/std/isa/inst/Zvkned/vaesz.vs.yaml +29 -0
  2275. data/.data/spec/std/isa/inst/Zvknha/vsha2ch.vv.yaml +31 -0
  2276. data/.data/spec/std/isa/inst/Zvknha/vsha2cl.vv.yaml +31 -0
  2277. data/.data/spec/std/isa/inst/Zvknha/vsha2ms.vv.yaml +31 -0
  2278. data/.data/spec/std/isa/inst/Zvks/vsm3c.vi.yaml +31 -0
  2279. data/.data/spec/std/isa/inst/Zvks/vsm3me.vv.yaml +31 -0
  2280. data/.data/spec/std/isa/inst/Zvks/vsm4k.vi.yaml +31 -0
  2281. data/.data/spec/std/isa/inst/Zvks/vsm4r.vs.yaml +29 -0
  2282. data/.data/spec/std/isa/inst/Zvks/vsm4r.vv.yaml +31 -0
  2283. data/.data/spec/std/isa/inst_opcode/OP-32.yaml +12 -0
  2284. data/.data/spec/std/isa/inst_opcode/OP.yaml +12 -0
  2285. data/.data/spec/std/isa/inst_subtype/I/I-x-x.yaml +21 -0
  2286. data/.data/spec/std/isa/inst_subtype/R/R-x.yaml +21 -0
  2287. data/.data/spec/std/isa/inst_type/I.yaml +22 -0
  2288. data/.data/spec/std/isa/inst_type/R.yaml +24 -0
  2289. data/.data/spec/std/isa/inst_var/I-imm.yaml +12 -0
  2290. data/.data/spec/std/isa/inst_var/xd.yaml +12 -0
  2291. data/.data/spec/std/isa/inst_var/xs1.yaml +12 -0
  2292. data/.data/spec/std/isa/inst_var/xs2.yaml +12 -0
  2293. data/.data/spec/std/isa/inst_var_type/imm.yaml +9 -0
  2294. data/.data/spec/std/isa/inst_var_type/x_dst_reg.yaml +11 -0
  2295. data/.data/spec/std/isa/inst_var_type/x_src_reg.yaml +11 -0
  2296. data/.data/spec/std/isa/interrupt_code/LocalCounterOverflow.yaml +14 -0
  2297. data/.data/spec/std/isa/interrupt_code/MachineExternal.yaml +13 -0
  2298. data/.data/spec/std/isa/interrupt_code/MachineSoftware.yaml +13 -0
  2299. data/.data/spec/std/isa/interrupt_code/MachineTimer.yaml +13 -0
  2300. data/.data/spec/std/isa/interrupt_code/SupervisorExternal.yaml +13 -0
  2301. data/.data/spec/std/isa/interrupt_code/SupervisorGuestExternal.yaml +13 -0
  2302. data/.data/spec/std/isa/interrupt_code/SupervisorSoftware.yaml +13 -0
  2303. data/.data/spec/std/isa/interrupt_code/SupervisorTimer.yaml +13 -0
  2304. data/.data/spec/std/isa/interrupt_code/VirtualSupervisorExternal.yaml +13 -0
  2305. data/.data/spec/std/isa/interrupt_code/VirtualSupervisorSoftware.yaml +13 -0
  2306. data/.data/spec/std/isa/interrupt_code/VirtualSupervisorTimer.yaml +13 -0
  2307. data/.data/spec/std/isa/isa/builtin_functions.idl +671 -0
  2308. data/.data/spec/std/isa/isa/fetch.idl +74 -0
  2309. data/.data/spec/std/isa/isa/fp.idl +1238 -0
  2310. data/.data/spec/std/isa/isa/globals.isa +3124 -0
  2311. data/.data/spec/std/isa/isa/interrupts.idl +391 -0
  2312. data/.data/spec/std/isa/isa/util.idl +224 -0
  2313. data/.data/spec/std/isa/isa/vec.idl +55 -0
  2314. data/.data/spec/std/isa/manual/isa.yaml +16 -0
  2315. data/.data/spec/std/isa/manual_version/isa/20240411/isa_20240411.yaml +222 -0
  2316. data/.data/spec/std/isa/param/ARCH_ID_VALUE.yaml +32 -0
  2317. data/.data/spec/std/isa/param/ASID_WIDTH.yaml +23 -0
  2318. data/.data/spec/std/isa/param/CACHE_BLOCK_SIZE.yaml +22 -0
  2319. data/.data/spec/std/isa/param/CONFIG_PTR_ADDRESS.yaml +28 -0
  2320. data/.data/spec/std/isa/param/COUNTINHIBIT_EN.yaml +30 -0
  2321. data/.data/spec/std/isa/param/DBG_HCONTEXT_WIDTH.yaml +18 -0
  2322. data/.data/spec/std/isa/param/DBG_SCONTEXT_WIDTH.yaml +18 -0
  2323. data/.data/spec/std/isa/param/DCSR_MPRVEN_TYPE.yaml +23 -0
  2324. data/.data/spec/std/isa/param/DCSR_STEPIE_TYPE.yaml +23 -0
  2325. data/.data/spec/std/isa/param/DCSR_STOPCOUNT_TYPE.yaml +23 -0
  2326. data/.data/spec/std/isa/param/DCSR_STOPTIME_TYPE.yaml +23 -0
  2327. data/.data/spec/std/isa/param/ELEN.yaml +20 -0
  2328. data/.data/spec/std/isa/param/FOLLOW_VTYPE_RESET_RECOMMENDATION.yaml +18 -0
  2329. data/.data/spec/std/isa/param/FORCE_UPGRADE_CBO_INVAL_TO_FLUSH.yaml +20 -0
  2330. data/.data/spec/std/isa/param/GSTAGE_MODE_BARE.yaml +24 -0
  2331. data/.data/spec/std/isa/param/HCONTEXT_AVAILABLE.yaml +19 -0
  2332. data/.data/spec/std/isa/param/HCOUNTENABLE_EN.yaml +27 -0
  2333. data/.data/spec/std/isa/param/HPM_COUNTER_EN.yaml +29 -0
  2334. data/.data/spec/std/isa/param/HPM_EVENTS.yaml +23 -0
  2335. data/.data/spec/std/isa/param/HSTATEEN_AIA_TYPE.yaml +34 -0
  2336. data/.data/spec/std/isa/param/HSTATEEN_CONTEXT_TYPE.yaml +35 -0
  2337. data/.data/spec/std/isa/param/HSTATEEN_CSRIND_TYPE.yaml +34 -0
  2338. data/.data/spec/std/isa/param/HSTATEEN_ENVCFG_TYPE.yaml +36 -0
  2339. data/.data/spec/std/isa/param/HSTATEEN_IMSIC_TYPE.yaml +34 -0
  2340. data/.data/spec/std/isa/param/HSTATEEN_JVT_TYPE.yaml +33 -0
  2341. data/.data/spec/std/isa/param/HW_MSTATUS_FS_DIRTY_UPDATE.yaml +30 -0
  2342. data/.data/spec/std/isa/param/HW_MSTATUS_VS_DIRTY_UPDATE.yaml +30 -0
  2343. data/.data/spec/std/isa/param/IGNORE_INVALID_VSATP_MODE_WRITES_WHEN_V_EQ_ZERO.yaml +18 -0
  2344. data/.data/spec/std/isa/param/IMPRECISE_VECTOR_TRAP_SETTABLE.yaml +19 -0
  2345. data/.data/spec/std/isa/param/IMP_ID_VALUE.yaml +25 -0
  2346. data/.data/spec/std/isa/param/JVT_BASE_MASK.yaml +28 -0
  2347. data/.data/spec/std/isa/param/JVT_BASE_TYPE.yaml +20 -0
  2348. data/.data/spec/std/isa/param/JVT_READ_ONLY.yaml +16 -0
  2349. data/.data/spec/std/isa/param/LEGAL_VSTART.yaml +21 -0
  2350. data/.data/spec/std/isa/param/LRSC_FAIL_ON_NON_EXACT_LRSC.yaml +18 -0
  2351. data/.data/spec/std/isa/param/LRSC_FAIL_ON_VA_SYNONYM.yaml +17 -0
  2352. data/.data/spec/std/isa/param/LRSC_MISALIGNED_BEHAVIOR.yaml +24 -0
  2353. data/.data/spec/std/isa/param/LRSC_RESERVATION_STRATEGY.yaml +26 -0
  2354. data/.data/spec/std/isa/param/MARCHID_IMPLEMENTED.yaml +17 -0
  2355. data/.data/spec/std/isa/param/MCID_WIDTH.yaml +19 -0
  2356. data/.data/spec/std/isa/param/MCONTEXT_AVAILABLE.yaml +16 -0
  2357. data/.data/spec/std/isa/param/MCOUNTENABLE_EN.yaml +32 -0
  2358. data/.data/spec/std/isa/param/MCTRCTL_CORSWAPINH_IMPLEMENTED.yaml +18 -0
  2359. data/.data/spec/std/isa/param/MCTRCTL_CUSTOM_IMPLEMENTED.yaml +18 -0
  2360. data/.data/spec/std/isa/param/MCTRCTL_DIRCALLINH_IMPLEMENTED.yaml +18 -0
  2361. data/.data/spec/std/isa/param/MCTRCTL_DIRJMPINH_IMPLEMENTED.yaml +18 -0
  2362. data/.data/spec/std/isa/param/MCTRCTL_DIRLJMPINH_IMPLEMENTED.yaml +18 -0
  2363. data/.data/spec/std/isa/param/MCTRCTL_EXCINH_IMPLEMENTED.yaml +18 -0
  2364. data/.data/spec/std/isa/param/MCTRCTL_INDCALLINH_IMPLEMENTED.yaml +18 -0
  2365. data/.data/spec/std/isa/param/MCTRCTL_INDJMPINH_IMPLEMENTED.yaml +18 -0
  2366. data/.data/spec/std/isa/param/MCTRCTL_INDLJMPINH_IMPLEMENTED.yaml +18 -0
  2367. data/.data/spec/std/isa/param/MCTRCTL_INTRINH_IMPLEMENTED.yaml +18 -0
  2368. data/.data/spec/std/isa/param/MCTRCTL_MTE_IMPLEMENTED.yaml +18 -0
  2369. data/.data/spec/std/isa/param/MCTRCTL_NTBREN_IMPLEMENTED.yaml +18 -0
  2370. data/.data/spec/std/isa/param/MCTRCTL_RASEMU_IMPLEMENTED.yaml +18 -0
  2371. data/.data/spec/std/isa/param/MCTRCTL_RETINH_IMPLEMENTED.yaml +18 -0
  2372. data/.data/spec/std/isa/param/MCTRCTL_STE_IMPLEMENTED.yaml +18 -0
  2373. data/.data/spec/std/isa/param/MCTRCTL_TKBRINH_IMPLEMENTED.yaml +18 -0
  2374. data/.data/spec/std/isa/param/MCTRCTL_TRETINH_IMPLEMENTED.yaml +18 -0
  2375. data/.data/spec/std/isa/param/MIMPID_IMPLEMENTED.yaml +17 -0
  2376. data/.data/spec/std/isa/param/MISALIGNED_AMO.yaml +17 -0
  2377. data/.data/spec/std/isa/param/MISALIGNED_LDST.yaml +18 -0
  2378. data/.data/spec/std/isa/param/MISALIGNED_LDST_EXCEPTION_PRIORITY.yaml +39 -0
  2379. data/.data/spec/std/isa/param/MISALIGNED_MAX_ATOMICITY_GRANULE_SIZE.yaml +40 -0
  2380. data/.data/spec/std/isa/param/MISALIGNED_SPLIT_STRATEGY.yaml +29 -0
  2381. data/.data/spec/std/isa/param/MISA_CSR_IMPLEMENTED.yaml +23 -0
  2382. data/.data/spec/std/isa/param/MOCK_1_BIT_INT.yaml +17 -0
  2383. data/.data/spec/std/isa/param/MOCK_25_BIT_INT.yaml +17 -0
  2384. data/.data/spec/std/isa/param/MOCK_2_BIT_INT.yaml +17 -0
  2385. data/.data/spec/std/isa/param/MOCK_32_BIT_INT.yaml +17 -0
  2386. data/.data/spec/std/isa/param/MOCK_64_BIT_INT.yaml +17 -0
  2387. data/.data/spec/std/isa/param/MOCK_ARRAY_BOOL_ARRAY_OF_8_FIRST_2_FALSE.yaml +22 -0
  2388. data/.data/spec/std/isa/param/MOCK_ARRAY_INT_ENUM.yaml +23 -0
  2389. data/.data/spec/std/isa/param/MOCK_ARRAY_MAX_ONLY.yaml +21 -0
  2390. data/.data/spec/std/isa/param/MOCK_ARRAY_MIN_ONLY.yaml +21 -0
  2391. data/.data/spec/std/isa/param/MOCK_ARRAY_STRING_ENUM1.yaml +21 -0
  2392. data/.data/spec/std/isa/param/MOCK_ARRAY_STRING_ENUM2.yaml +21 -0
  2393. data/.data/spec/std/isa/param/MOCK_BOOL_1.yaml +15 -0
  2394. data/.data/spec/std/isa/param/MOCK_BOOL_2.yaml +15 -0
  2395. data/.data/spec/std/isa/param/MOCK_ENUM_2_INTS.yaml +18 -0
  2396. data/.data/spec/std/isa/param/MOCK_ENUM_2_STRINGS.yaml +18 -0
  2397. data/.data/spec/std/isa/param/MOCK_INT_RANGE_0_TO_1023.yaml +17 -0
  2398. data/.data/spec/std/isa/param/MOCK_INT_RANGE_0_TO_127.yaml +17 -0
  2399. data/.data/spec/std/isa/param/MOCK_INT_RANGE_0_TO_128.yaml +17 -0
  2400. data/.data/spec/std/isa/param/MOCK_INT_RANGE_0_TO_2.yaml +17 -0
  2401. data/.data/spec/std/isa/param/MOCK_INT_RANGE_0_TO_999.yaml +17 -0
  2402. data/.data/spec/std/isa/param/MOCK_INT_RANGE_1000_TO_2048.yaml +17 -0
  2403. data/.data/spec/std/isa/param/MOCK_INT_RANGE_1_TO_128.yaml +17 -0
  2404. data/.data/spec/std/isa/param/MSTATEEN_AIA_TYPE.yaml +27 -0
  2405. data/.data/spec/std/isa/param/MSTATEEN_CONTEXT_TYPE.yaml +26 -0
  2406. data/.data/spec/std/isa/param/MSTATEEN_CSRIND_TYPE.yaml +26 -0
  2407. data/.data/spec/std/isa/param/MSTATEEN_ENVCFG_TYPE.yaml +26 -0
  2408. data/.data/spec/std/isa/param/MSTATEEN_IMSIC_TYPE.yaml +27 -0
  2409. data/.data/spec/std/isa/param/MSTATEEN_JVT_TYPE.yaml +27 -0
  2410. data/.data/spec/std/isa/param/MSTATUS_FS_LEGAL_VALUES.yaml +41 -0
  2411. data/.data/spec/std/isa/param/MSTATUS_TVM_IMPLEMENTED.yaml +18 -0
  2412. data/.data/spec/std/isa/param/MSTATUS_VS_LEGAL_VALUES.yaml +45 -0
  2413. data/.data/spec/std/isa/param/MTVAL_WIDTH.yaml +88 -0
  2414. data/.data/spec/std/isa/param/MTVEC_ACCESS.yaml +24 -0
  2415. data/.data/spec/std/isa/param/MTVEC_BASE_ALIGNMENT_DIRECT.yaml +96 -0
  2416. data/.data/spec/std/isa/param/MTVEC_BASE_ALIGNMENT_VECTORED.yaml +96 -0
  2417. data/.data/spec/std/isa/param/MTVEC_ILLEGAL_WRITE_BEHAVIOR.yaml +25 -0
  2418. data/.data/spec/std/isa/param/MTVEC_MODES.yaml +35 -0
  2419. data/.data/spec/std/isa/param/MUTABLE_MISA_A.yaml +19 -0
  2420. data/.data/spec/std/isa/param/MUTABLE_MISA_B.yaml +18 -0
  2421. data/.data/spec/std/isa/param/MUTABLE_MISA_C.yaml +21 -0
  2422. data/.data/spec/std/isa/param/MUTABLE_MISA_D.yaml +21 -0
  2423. data/.data/spec/std/isa/param/MUTABLE_MISA_F.yaml +21 -0
  2424. data/.data/spec/std/isa/param/MUTABLE_MISA_H.yaml +26 -0
  2425. data/.data/spec/std/isa/param/MUTABLE_MISA_M.yaml +21 -0
  2426. data/.data/spec/std/isa/param/MUTABLE_MISA_Q.yaml +21 -0
  2427. data/.data/spec/std/isa/param/MUTABLE_MISA_S.yaml +26 -0
  2428. data/.data/spec/std/isa/param/MUTABLE_MISA_U.yaml +21 -0
  2429. data/.data/spec/std/isa/param/MUTABLE_MISA_V.yaml +17 -0
  2430. data/.data/spec/std/isa/param/MXLEN.yaml +54 -0
  2431. data/.data/spec/std/isa/param/M_MODE_ENDIANNESS.yaml +26 -0
  2432. data/.data/spec/std/isa/param/NUM_EXTERNAL_GUEST_INTERRUPTS.yaml +24 -0
  2433. data/.data/spec/std/isa/param/NUM_PMP_ENTRIES.yaml +42 -0
  2434. data/.data/spec/std/isa/param/PHYS_ADDR_WIDTH.yaml +24 -0
  2435. data/.data/spec/std/isa/param/PMA_GRANULARITY.yaml +21 -0
  2436. data/.data/spec/std/isa/param/PMLEN.yaml +20 -0
  2437. data/.data/spec/std/isa/param/PMP_GRANULARITY.yaml +25 -0
  2438. data/.data/spec/std/isa/param/PRECISE_SYNCHRONOUS_EXCEPTIONS.yaml +17 -0
  2439. data/.data/spec/std/isa/param/RCID_WIDTH.yaml +19 -0
  2440. data/.data/spec/std/isa/param/REPORT_CAUSE_IN_MTVAL_ON_LANDING_PAD_SOFTWARE_CHECK.yaml +18 -0
  2441. data/.data/spec/std/isa/param/REPORT_CAUSE_IN_MTVAL_ON_SHADOW_STACK_SOFTWARE_CHECK.yaml +18 -0
  2442. data/.data/spec/std/isa/param/REPORT_CAUSE_IN_STVAL_ON_LANDING_PAD_SOFTWARE_CHECK.yaml +18 -0
  2443. data/.data/spec/std/isa/param/REPORT_CAUSE_IN_STVAL_ON_SHADOW_STACK_SOFTWARE_CHECK.yaml +18 -0
  2444. data/.data/spec/std/isa/param/REPORT_CAUSE_IN_VSTVAL_ON_LANDING_PAD_SOFTWARE_CHECK.yaml +18 -0
  2445. data/.data/spec/std/isa/param/REPORT_CAUSE_IN_VSTVAL_ON_SHADOW_STACK_SOFTWARE_CHECK.yaml +18 -0
  2446. data/.data/spec/std/isa/param/REPORT_ENCODING_IN_MTVAL_ON_ILLEGAL_INSTRUCTION.yaml +21 -0
  2447. data/.data/spec/std/isa/param/REPORT_ENCODING_IN_STVAL_ON_ILLEGAL_INSTRUCTION.yaml +19 -0
  2448. data/.data/spec/std/isa/param/REPORT_ENCODING_IN_VSTVAL_ON_ILLEGAL_INSTRUCTION.yaml +19 -0
  2449. data/.data/spec/std/isa/param/REPORT_ENCODING_IN_VSTVAL_ON_VIRTUAL_INSTRUCTION.yaml +19 -0
  2450. data/.data/spec/std/isa/param/REPORT_GPA_IN_HTVAL_ON_GUEST_PAGE_FAULT.yaml +19 -0
  2451. data/.data/spec/std/isa/param/REPORT_GPA_IN_TVAL_ON_INSTRUCTION_GUEST_PAGE_FAULT.yaml +18 -0
  2452. data/.data/spec/std/isa/param/REPORT_GPA_IN_TVAL_ON_INTERMEDIATE_GUEST_PAGE_FAULT.yaml +19 -0
  2453. data/.data/spec/std/isa/param/REPORT_GPA_IN_TVAL_ON_LOAD_GUEST_PAGE_FAULT.yaml +18 -0
  2454. data/.data/spec/std/isa/param/REPORT_GPA_IN_TVAL_ON_STORE_AMO_GUEST_PAGE_FAULT.yaml +18 -0
  2455. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_BREAKPOINT.yaml +23 -0
  2456. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_INSTRUCTION_ACCESS_FAULT.yaml +21 -0
  2457. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_INSTRUCTION_MISALIGNED.yaml +21 -0
  2458. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_INSTRUCTION_PAGE_FAULT.yaml +20 -0
  2459. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_LOAD_ACCESS_FAULT.yaml +21 -0
  2460. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_LOAD_MISALIGNED.yaml +21 -0
  2461. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_LOAD_PAGE_FAULT.yaml +19 -0
  2462. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_STORE_AMO_ACCESS_FAULT.yaml +21 -0
  2463. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_STORE_AMO_MISALIGNED.yaml +21 -0
  2464. data/.data/spec/std/isa/param/REPORT_VA_IN_MTVAL_ON_STORE_AMO_PAGE_FAULT.yaml +19 -0
  2465. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_BREAKPOINT.yaml +20 -0
  2466. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_INSTRUCTION_ACCESS_FAULT.yaml +20 -0
  2467. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_INSTRUCTION_MISALIGNED.yaml +21 -0
  2468. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_INSTRUCTION_PAGE_FAULT.yaml +20 -0
  2469. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_LOAD_ACCESS_FAULT.yaml +19 -0
  2470. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_LOAD_MISALIGNED.yaml +20 -0
  2471. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_LOAD_PAGE_FAULT.yaml +19 -0
  2472. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_STORE_AMO_ACCESS_FAULT.yaml +19 -0
  2473. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_STORE_AMO_MISALIGNED.yaml +20 -0
  2474. data/.data/spec/std/isa/param/REPORT_VA_IN_STVAL_ON_STORE_AMO_PAGE_FAULT.yaml +19 -0
  2475. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_BREAKPOINT.yaml +20 -0
  2476. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_INSTRUCTION_ACCESS_FAULT.yaml +20 -0
  2477. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_INSTRUCTION_MISALIGNED.yaml +21 -0
  2478. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_INSTRUCTION_PAGE_FAULT.yaml +20 -0
  2479. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_LOAD_ACCESS_FAULT.yaml +19 -0
  2480. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_LOAD_MISALIGNED.yaml +20 -0
  2481. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_LOAD_PAGE_FAULT.yaml +19 -0
  2482. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_STORE_AMO_ACCESS_FAULT.yaml +19 -0
  2483. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_STORE_AMO_MISALIGNED.yaml +20 -0
  2484. data/.data/spec/std/isa/param/REPORT_VA_IN_VSTVAL_ON_STORE_AMO_PAGE_FAULT.yaml +19 -0
  2485. data/.data/spec/std/isa/param/RESERVED_VSET_X0X0_VILL_SET.yaml +21 -0
  2486. data/.data/spec/std/isa/param/RESERVED_VSET_X0X0_VLMAX_CHANGE.yaml +20 -0
  2487. data/.data/spec/std/isa/param/RVV_VL_WHEN_AVL_LT_DOUBLE_VLMAX.yaml +17 -0
  2488. data/.data/spec/std/isa/param/SATP_MODE_BARE.yaml +17 -0
  2489. data/.data/spec/std/isa/param/SCOUNTENABLE_EN.yaml +46 -0
  2490. data/.data/spec/std/isa/param/SEW_MIN.yaml +27 -0
  2491. data/.data/spec/std/isa/param/SSTATEEN_JVT_TYPE.yaml +37 -0
  2492. data/.data/spec/std/isa/param/STVAL_WIDTH.yaml +19 -0
  2493. data/.data/spec/std/isa/param/STVEC_MODE_DIRECT.yaml +21 -0
  2494. data/.data/spec/std/isa/param/STVEC_MODE_VECTORED.yaml +19 -0
  2495. data/.data/spec/std/isa/param/SUPPORT_FRACTIONAL_LMUL_BEYOND_REQUIRED.yaml +21 -0
  2496. data/.data/spec/std/isa/param/SV32X4_TRANSLATION.yaml +24 -0
  2497. data/.data/spec/std/isa/param/SV32_VSMODE_TRANSLATION.yaml +27 -0
  2498. data/.data/spec/std/isa/param/SV39X4_TRANSLATION.yaml +23 -0
  2499. data/.data/spec/std/isa/param/SV39_VSMODE_TRANSLATION.yaml +27 -0
  2500. data/.data/spec/std/isa/param/SV48X4_TRANSLATION.yaml +27 -0
  2501. data/.data/spec/std/isa/param/SV48_VSMODE_TRANSLATION.yaml +27 -0
  2502. data/.data/spec/std/isa/param/SV57X4_TRANSLATION.yaml +25 -0
  2503. data/.data/spec/std/isa/param/SV57_VSMODE_TRANSLATION.yaml +27 -0
  2504. data/.data/spec/std/isa/param/SXLEN.yaml +31 -0
  2505. data/.data/spec/std/isa/param/S_MODE_ENDIANNESS.yaml +25 -0
  2506. data/.data/spec/std/isa/param/TIME_CSR_IMPLEMENTED.yaml +28 -0
  2507. data/.data/spec/std/isa/param/TINST_VALUE_ON_BREAKPOINT.yaml +23 -0
  2508. data/.data/spec/std/isa/param/TINST_VALUE_ON_FINAL_INSTRUCTION_GUEST_PAGE_FAULT.yaml +23 -0
  2509. data/.data/spec/std/isa/param/TINST_VALUE_ON_FINAL_LOAD_GUEST_PAGE_FAULT.yaml +27 -0
  2510. data/.data/spec/std/isa/param/TINST_VALUE_ON_FINAL_STORE_AMO_GUEST_PAGE_FAULT.yaml +27 -0
  2511. data/.data/spec/std/isa/param/TINST_VALUE_ON_INSTRUCTION_ADDRESS_MISALIGNED.yaml +23 -0
  2512. data/.data/spec/std/isa/param/TINST_VALUE_ON_LOAD_ACCESS_FAULT.yaml +25 -0
  2513. data/.data/spec/std/isa/param/TINST_VALUE_ON_LOAD_ADDRESS_MISALIGNED.yaml +25 -0
  2514. data/.data/spec/std/isa/param/TINST_VALUE_ON_LOAD_PAGE_FAULT.yaml +25 -0
  2515. data/.data/spec/std/isa/param/TINST_VALUE_ON_MCALL.yaml +23 -0
  2516. data/.data/spec/std/isa/param/TINST_VALUE_ON_SCALL.yaml +23 -0
  2517. data/.data/spec/std/isa/param/TINST_VALUE_ON_STORE_AMO_ACCESS_FAULT.yaml +25 -0
  2518. data/.data/spec/std/isa/param/TINST_VALUE_ON_STORE_AMO_ADDRESS_MISALIGNED.yaml +25 -0
  2519. data/.data/spec/std/isa/param/TINST_VALUE_ON_STORE_AMO_PAGE_FAULT.yaml +25 -0
  2520. data/.data/spec/std/isa/param/TINST_VALUE_ON_UCALL.yaml +23 -0
  2521. data/.data/spec/std/isa/param/TINST_VALUE_ON_VIRTUAL_INSTRUCTION.yaml +23 -0
  2522. data/.data/spec/std/isa/param/TINST_VALUE_ON_VSCALL.yaml +23 -0
  2523. data/.data/spec/std/isa/param/TRAP_ON_EBREAK.yaml +17 -0
  2524. data/.data/spec/std/isa/param/TRAP_ON_ECALL_FROM_M.yaml +17 -0
  2525. data/.data/spec/std/isa/param/TRAP_ON_ECALL_FROM_S.yaml +20 -0
  2526. data/.data/spec/std/isa/param/TRAP_ON_ECALL_FROM_U.yaml +20 -0
  2527. data/.data/spec/std/isa/param/TRAP_ON_ECALL_FROM_VS.yaml +20 -0
  2528. data/.data/spec/std/isa/param/TRAP_ON_ILLEGAL_WLRL.yaml +21 -0
  2529. data/.data/spec/std/isa/param/TRAP_ON_RESERVED_INSTRUCTION.yaml +24 -0
  2530. data/.data/spec/std/isa/param/TRAP_ON_SFENCE_VMA_WHEN_SATP_MODE_IS_READ_ONLY.yaml +31 -0
  2531. data/.data/spec/std/isa/param/TRAP_ON_UNIMPLEMENTED_CSR.yaml +21 -0
  2532. data/.data/spec/std/isa/param/TRAP_ON_UNIMPLEMENTED_INSTRUCTION.yaml +23 -0
  2533. data/.data/spec/std/isa/param/UXLEN.yaml +31 -0
  2534. data/.data/spec/std/isa/param/U_MODE_ENDIANNESS.yaml +25 -0
  2535. data/.data/spec/std/isa/param/VECTOR_FF_NO_EXCEPTION_TRIM.yaml +19 -0
  2536. data/.data/spec/std/isa/param/VECTOR_FF_SEG_EXCEPTION_PARTIAL_LOAD.yaml +22 -0
  2537. data/.data/spec/std/isa/param/VECTOR_FF_UPDATE_PAST_TRIM.yaml +22 -0
  2538. data/.data/spec/std/isa/param/VECTOR_LOAD_PAST_TRAP.yaml +19 -0
  2539. data/.data/spec/std/isa/param/VECTOR_LOAD_SEG_FF_OVERWRITE_ELEMENTS_AFTER_FAULT.yaml +21 -0
  2540. data/.data/spec/std/isa/param/VECTOR_LS_INDEX_MAX_EEW.yaml +28 -0
  2541. data/.data/spec/std/isa/param/VECTOR_LS_MISALIGNED_LEGAL.yaml +19 -0
  2542. data/.data/spec/std/isa/param/VECTOR_LS_SEG_PARTIAL_ACCESS.yaml +19 -0
  2543. data/.data/spec/std/isa/param/VECTOR_LS_WHOLEREG_MISALIGNED_LEGAL.yaml +20 -0
  2544. data/.data/spec/std/isa/param/VENDOR_ID_BANK.yaml +20 -0
  2545. data/.data/spec/std/isa/param/VENDOR_ID_OFFSET.yaml +18 -0
  2546. data/.data/spec/std/isa/param/VFREDUSUM_FINAL_NODE_ELEMENT_BEHAVIOR.yaml +20 -0
  2547. data/.data/spec/std/isa/param/VFREDUSUM_INACTIVE_NODE_ELEMENT_BEHAVIOR.yaml +21 -0
  2548. data/.data/spec/std/isa/param/VFREDUSUM_NAN.yaml +22 -0
  2549. data/.data/spec/std/isa/param/VFREDUSUM_NODE_ROUNDING_BEHAVIOR.yaml +23 -0
  2550. data/.data/spec/std/isa/param/VILL_SET_ON_RESERVED_VTYPE.yaml +20 -0
  2551. data/.data/spec/std/isa/param/VLEN.yaml +20 -0
  2552. data/.data/spec/std/isa/param/VMID_WIDTH.yaml +25 -0
  2553. data/.data/spec/std/isa/param/VSSTAGE_MODE_BARE.yaml +24 -0
  2554. data/.data/spec/std/isa/param/VSSTATUS_VS_EXISTS.yaml +19 -0
  2555. data/.data/spec/std/isa/param/VSTVEC_MODE_DIRECT.yaml +21 -0
  2556. data/.data/spec/std/isa/param/VSTVEC_MODE_VECTORED.yaml +21 -0
  2557. data/.data/spec/std/isa/param/VSXLEN.yaml +33 -0
  2558. data/.data/spec/std/isa/param/VS_MODE_ENDIANNESS.yaml +25 -0
  2559. data/.data/spec/std/isa/param/VUXLEN.yaml +30 -0
  2560. data/.data/spec/std/isa/param/VU_MODE_ENDIANNESS.yaml +25 -0
  2561. data/.data/spec/std/isa/proc_cert_class/AC.yaml +13 -0
  2562. data/.data/spec/std/isa/proc_cert_class/MC.yaml +13 -0
  2563. data/.data/spec/std/isa/proc_cert_class/MockProcessor.yaml +13 -0
  2564. data/.data/spec/std/isa/proc_cert_class/RVI.yaml +16 -0
  2565. data/.data/spec/std/isa/proc_cert_model/AC100.yaml +72 -0
  2566. data/.data/spec/std/isa/proc_cert_model/AC200.yaml +58 -0
  2567. data/.data/spec/std/isa/proc_cert_model/MC100-32.yaml +155 -0
  2568. data/.data/spec/std/isa/proc_cert_model/MC100-64.yaml +21 -0
  2569. data/.data/spec/std/isa/proc_cert_model/MC200-32.yaml +60 -0
  2570. data/.data/spec/std/isa/proc_cert_model/MC200-64.yaml +21 -0
  2571. data/.data/spec/std/isa/proc_cert_model/MC300-32.yaml +40 -0
  2572. data/.data/spec/std/isa/proc_cert_model/MC300-64.yaml +21 -0
  2573. data/.data/spec/std/isa/proc_cert_model/RVI20-32.yaml +39 -0
  2574. data/.data/spec/std/isa/proc_cert_model/RVI20-64.yaml +19 -0
  2575. data/.data/spec/std/isa/profile/RVA20S64.yaml +76 -0
  2576. data/.data/spec/std/isa/profile/RVA20U64.yaml +108 -0
  2577. data/.data/spec/std/isa/profile/RVA22S64.yaml +80 -0
  2578. data/.data/spec/std/isa/profile/RVA22U64.yaml +140 -0
  2579. data/.data/spec/std/isa/profile/RVA23M64.yaml +24 -0
  2580. data/.data/spec/std/isa/profile/RVA23S64.yaml +55 -0
  2581. data/.data/spec/std/isa/profile/RVA23U64.yaml +70 -0
  2582. data/.data/spec/std/isa/profile/RVB23M64.yaml +89 -0
  2583. data/.data/spec/std/isa/profile/RVB23S64.yaml +299 -0
  2584. data/.data/spec/std/isa/profile/RVB23U64.yaml +273 -0
  2585. data/.data/spec/std/isa/profile/RVI20U32.yaml +83 -0
  2586. data/.data/spec/std/isa/profile/RVI20U64.yaml +12 -0
  2587. data/.data/spec/std/isa/profile_family/Mock.yaml +24 -0
  2588. data/.data/spec/std/isa/profile_family/RVA.yaml +154 -0
  2589. data/.data/spec/std/isa/profile_family/RVB.yaml +59 -0
  2590. data/.data/spec/std/isa/profile_family/RVI.yaml +37 -0
  2591. data/.data/spec/std/isa/profile_release/RVA20.yaml +44 -0
  2592. data/.data/spec/std/isa/profile_release/RVA22.yaml +44 -0
  2593. data/.data/spec/std/isa/profile_release/RVA23.yaml +40 -0
  2594. data/.data/spec/std/isa/profile_release/RVB23.yaml +40 -0
  2595. data/.data/spec/std/isa/profile_release/RVI20.yaml +31 -0
  2596. data/.data/spec/std/isa/prose/interrupts.adoc +185 -0
  2597. data/.data/spec/std/isa/register_file/F.yaml +165 -0
  2598. data/.data/spec/std/isa/register_file/V.yaml +146 -0
  2599. data/.data/spec/std/isa/register_file/X.yaml +201 -0
  2600. data/LICENSE +26 -0
  2601. data/bin/udb +11 -0
  2602. data/ext/udb_download/extconf.rb +238 -0
  2603. data/lib/tapioca/dsl/compilers/cfg_arch_compiler.rb +38 -0
  2604. data/lib/udb/EQNTOTT_VERSION +1 -0
  2605. data/lib/udb/ESPRESSO_VERSION +1 -0
  2606. data/lib/udb/MUST_VERSION +1 -0
  2607. data/lib/udb/Z3_VERSION +1 -0
  2608. data/lib/udb/architecture.rb +345 -0
  2609. data/lib/udb/cert_normative_rule.rb +41 -0
  2610. data/lib/udb/cfg_arch.rb +1679 -0
  2611. data/lib/udb/cli.rb +424 -0
  2612. data/lib/udb/condition.rb +2143 -0
  2613. data/lib/udb/config.rb +363 -0
  2614. data/lib/udb/dep_paths.rb +109 -0
  2615. data/lib/udb/dep_versions.rb +12 -0
  2616. data/lib/udb/doc_link.rb +49 -0
  2617. data/lib/udb/eqn.rb +204 -0
  2618. data/lib/udb/eqn_parser.rb +804 -0
  2619. data/lib/udb/external_documentation_renderer.rb +466 -0
  2620. data/lib/udb/idl/condition_to_udb.rb +386 -0
  2621. data/lib/udb/log.rb +147 -0
  2622. data/lib/udb/logic.rb +3636 -0
  2623. data/lib/udb/obj/certifiable_obj.rb +21 -0
  2624. data/lib/udb/obj/certificate.rb +230 -0
  2625. data/lib/udb/obj/csr.rb +603 -0
  2626. data/lib/udb/obj/csr_field.rb +877 -0
  2627. data/lib/udb/obj/database_obj.rb +556 -0
  2628. data/lib/udb/obj/exception_code.rb +98 -0
  2629. data/lib/udb/obj/extension.rb +1734 -0
  2630. data/lib/udb/obj/has_fields.rb +151 -0
  2631. data/lib/udb/obj/instruction.rb +1328 -0
  2632. data/lib/udb/obj/manual.rb +208 -0
  2633. data/lib/udb/obj/mmr.rb +104 -0
  2634. data/lib/udb/obj/non_isa_specification.rb +382 -0
  2635. data/lib/udb/obj/parameter.rb +148 -0
  2636. data/lib/udb/obj/portfolio.rb +972 -0
  2637. data/lib/udb/obj/prm.rb +52 -0
  2638. data/lib/udb/obj/profile.rb +284 -0
  2639. data/lib/udb/obj/register_file.rb +118 -0
  2640. data/lib/udb/portfolio_design.rb +256 -0
  2641. data/lib/udb/presence.rb +101 -0
  2642. data/lib/udb/prm_generator.rb +763 -0
  2643. data/lib/udb/proc_cert_design.rb +77 -0
  2644. data/lib/udb/resolver.rb +425 -0
  2645. data/lib/udb/schema.rb +305 -0
  2646. data/lib/udb/version.rb +8 -0
  2647. data/lib/udb/version_spec.rb +334 -0
  2648. data/lib/udb/yaml/comment_parser.rb +422 -0
  2649. data/lib/udb/yaml/preserving_emitter.rb +339 -0
  2650. data/lib/udb/yaml/yaml_resolver.rb +1039 -0
  2651. data/lib/udb/z3.rb +1218 -0
  2652. data/lib/udb/z3_loader.rb +97 -0
  2653. data/lib/udb.rb +25 -0
  2654. metadata +3125 -0
@@ -0,0 +1,1679 @@
1
+ # Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
2
+ # SPDX-License-Identifier: BSD-3-Clause-Clear
3
+
4
+ # typed: true
5
+ # frozen_string_literal: true
6
+
7
+ # Many classes include DatabaseObject have an "cfg_arch" member which is a ConfiguredArchitecture class.
8
+ # It combines knowledge of the RISC-V Architecture with a particular configuration.
9
+ # A configuration is an instance of the AbstractConfig object either located in the /cfg directory
10
+ # or created at runtime for things like profiles and certificate models.
11
+
12
+ require "concurrent"
13
+ require "tilt"
14
+ require "tty-progressbar"
15
+ require "yaml"
16
+ require "pathname"
17
+ require_relative "obj/non_isa_specification"
18
+ require_relative "config"
19
+ require_relative "architecture"
20
+ require_relative "log"
21
+
22
+ require "idlc"
23
+ require "idlc/symbol_table"
24
+ require "idlc/passes/find_return_values"
25
+ require "idlc/passes/gen_adoc"
26
+ require "idlc/passes/prune"
27
+ require "idlc/passes/reachable_exceptions"
28
+ require "idlc/passes/reachable_functions"
29
+
30
+ require "udb_helpers/backend_helpers"
31
+
32
+ include Udb::Helpers::TemplateHelpers
33
+
34
+ module Udb
35
+
36
+ class ConfiguredArchitecture < Architecture
37
+ extend T::Sig
38
+
39
+ # @return [Idl::Compiler] The IDL compiler
40
+ sig { returns(Idl::Compiler) }
41
+ attr_reader :idl_compiler
42
+
43
+ # @return [String] Name of this definition. Special names are:
44
+ # * '_' - The generic architecture, with no configuration settings.
45
+ # * 'rv32' - A generic RV32 architecture, with only one parameter set (XLEN == 32)
46
+ # * 'rv64' - A generic RV64 architecture, with only one parameter set (XLEN == 64)
47
+ sig { returns(String) }
48
+ attr_reader :name
49
+
50
+ sig { returns(AbstractConfig) }
51
+ attr_reader :config
52
+
53
+ sig { returns(T::Boolean) }
54
+ def fully_configured? = @config.fully_configured?
55
+
56
+ sig { returns(T::Boolean) }
57
+ def partially_configured? = @config.partially_configured?
58
+
59
+ sig { returns(T::Boolean) }
60
+ def unconfigured? = @config.unconfigured?
61
+
62
+ # MXLEN parameter value, or nil if it is not known
63
+ sig { returns(T.nilable(Integer)) }
64
+ def mxlen = @config.mxlen
65
+
66
+ # known parameter values as a hash of param_name => param_value
67
+ sig { returns(T::Hash[String, T.untyped]) }
68
+ def param_values = @config.param_values
69
+
70
+ # Returns whether or not it may be possible to switch XLEN given this definition.
71
+ #
72
+ # There are three cases when this will return true:
73
+ # 1. A mode (e.g., U) is known to be implemented, and the CSR bit that controls XLEN in that mode is known to be writable.
74
+ # 2. A mode is known to be implemented, but the writability of the CSR bit that controls XLEN in that mode is not known.
75
+ # 3. It is not known if the mode is implemented.
76
+ #
77
+ #
78
+ # @return true if this configuration might execute in multiple xlen environments
79
+ # (e.g., that in some mode the effective xlen can be either 32 or 64, depending on CSR values)
80
+ sig { returns(T::Boolean) }
81
+ def multi_xlen?
82
+ @memo.multi_xlen ||=
83
+ begin
84
+ return true if @mxlen.nil?
85
+
86
+ ["S", "U", "VS", "VU"].any? { |mode| multi_xlen_in_mode?(mode) }
87
+ end
88
+ end
89
+
90
+ # Returns whether or not it may be possible to switch XLEN in +mode+ given this definition.
91
+ #
92
+ # There are three cases when this will return true:
93
+ # 1. +mode+ (e.g., U) is known to be implemented, and the CSR bit that controls XLEN in +mode+ is known to be writable.
94
+ # 2. +mode+ is known to be implemented, but the writability of the CSR bit that controls XLEN in +mode+ is not known.
95
+ # 3. It is not known if +mode+ is implemented.
96
+ #
97
+ # Will return false if +mode+ is not possible (e.g., because U is a prohibited extension)
98
+ #
99
+ # @param mode mode to check. One of "M", "S", "U", "VS", "VU"
100
+ # @return true if this configuration might execute in multiple xlen environments in +mode+
101
+ # (e.g., that in some mode the effective xlen can be either 32 or 64, depending on CSR values)
102
+ sig { params(mode: String).returns(T::Boolean) }
103
+ def multi_xlen_in_mode?(mode)
104
+ @memo.multi_xlen_in_mode[mode] ||=
105
+ begin
106
+ return false if mxlen == 32
107
+
108
+ case mode
109
+ when "M", "D"
110
+ mxlen.nil?
111
+ when "S"
112
+ return true if unconfigured?
113
+
114
+ if fully_configured?
115
+ ext?(:S) && (param_values["SXLEN"].size > 1)
116
+ elsif partially_configured?
117
+ return false if prohibited_ext?(:S)
118
+
119
+ return true unless ext?(:S) # if S is not known to be implemented, we can't say anything about it
120
+
121
+ return true unless param_values.key?("SXLEN")
122
+
123
+ param_values["SXLEN"].size > 1
124
+ else
125
+ raise "Unexpected configuration state"
126
+ end
127
+ when "U"
128
+ return false if prohibited_ext?(:U)
129
+
130
+ return true if unconfigured?
131
+
132
+ if fully_configured?
133
+ ext?(:U) && (param_values["UXLEN"].size > 1)
134
+ elsif partially_configured?
135
+ return true unless ext?(:U) # if U is not known to be implemented, we can't say anything about it
136
+
137
+ return true unless param_values.key?("UXLEN")
138
+
139
+ param_values["UXLEN"].size > 1
140
+ else
141
+ raise "Unexpected configuration state"
142
+ end
143
+ when "VS"
144
+ return false if prohibited_ext?(:H)
145
+
146
+ return true if unconfigured?
147
+
148
+ if fully_configured?
149
+ ext?(:H) && (param_values["VSXLEN"].size > 1)
150
+ elsif partially_configured?
151
+ return true unless ext?(:H) # if H is not known to be implemented, we can't say anything about it
152
+
153
+ return true unless param_values.key?("VSXLEN")
154
+
155
+ param_values["VSXLEN"].size > 1
156
+ else
157
+ raise "Unexpected configuration state"
158
+ end
159
+ when "VU"
160
+ return false if prohibited_ext?(:H)
161
+
162
+ return true if unconfigured?
163
+
164
+ if fully_configured?
165
+ ext?(:H) && (param_values["VUXLEN"].size > 1)
166
+ elsif partially_configured?
167
+ return true unless ext?(:H) # if H is not known to be implemented, we can't say anything about it
168
+
169
+ return true unless param_values.key?("VUXLEN")
170
+
171
+ param_values["VUXLEN"].size > 1
172
+ else
173
+ raise "Unexpected configuration state"
174
+ end
175
+ else
176
+ raise ArgumentError, "Bad mode: #{mode}"
177
+ end
178
+ end
179
+ end
180
+
181
+ # @return [Array<Integer>] List of possible XLENs in any mode for this config
182
+ sig { returns(T::Array[Integer]) }
183
+ def possible_xlens = multi_xlen? ? [32, 64] : [mxlen]
184
+
185
+ # @api private
186
+ # hash for Hash lookup
187
+ sig { override.returns(Integer) }
188
+ def hash = @name_sym.hash
189
+
190
+ sig { override.params(other: BasicObject).returns(T::Boolean) }
191
+ def eql?(other)
192
+ return false unless other.__send__(:is_a?, ConfiguredArchitecture)
193
+
194
+ @name.eql?(other.__send__(:name))
195
+ end
196
+
197
+ # @return Symbol table with global scope included
198
+ sig { returns(Idl::SymbolTable) }
199
+ def symtab
200
+ @symtab ||=
201
+ begin
202
+ @symtab = create_symtab
203
+
204
+ global_ast.add_global_symbols(@symtab)
205
+
206
+ @symtab.deep_freeze
207
+ raise if @symtab.name.nil?
208
+ global_ast.freeze_tree(@symtab)
209
+ @symtab
210
+ end
211
+ end
212
+
213
+ sig { returns(Idl::IsaAst) }
214
+ def global_ast
215
+ @global_ast ||=
216
+ begin
217
+ # now add globals to the phase1 symtab
218
+ overlay_path = @config.info.overlay_path
219
+ custom_globals_path = overlay_path.nil? ? Pathname.new("/does/not/exist") : overlay_path / "isa" / "globals.isa"
220
+ idl_path = File.exist?(custom_globals_path) ? custom_globals_path : @config.info.spec_path / "isa" / "globals.isa"
221
+ Udb.logger.info "Compiling global IDL"
222
+ pb =
223
+ Udb.create_progressbar(
224
+ "Compiling IDL for #{name} [:bar]",
225
+ clear: true
226
+ )
227
+ @idl_compiler.pb = pb
228
+ ast = @idl_compiler.compile_file(
229
+ idl_path
230
+ )
231
+ pb.finish
232
+ @idl_compiler.unset_pb
233
+ ast
234
+ end
235
+ end
236
+
237
+ sig { returns(ConfigType) }
238
+ def config_type = @config_type
239
+
240
+ # return type for #valid?
241
+ class ValidationResult < T::Struct
242
+ const :valid, T::Boolean
243
+ const :reasons, T::Array[String] # filled with messages if valid is false
244
+ end
245
+
246
+ # whether or not the configuration is valid. if it's not, reasons are provided
247
+ sig { returns(ValidationResult) }
248
+ def valid?
249
+ if fully_configured?
250
+ full_config_valid?
251
+ elsif partially_configured?
252
+ partial_config_valid?
253
+ else
254
+ ValidationResult.new(valid: true, reasons: [])
255
+ end
256
+ end
257
+
258
+ # @api private
259
+ sig { returns(ValidationResult) }
260
+ def full_config_valid?
261
+ # check extension requirements
262
+ reasons = []
263
+
264
+ # check as much as we can before going into full SMT solving
265
+ config.param_values.each do |param_name, param_value|
266
+ reasons << "Parameter has no definition: '#{param_name}'" if param(param_name).nil?
267
+ if !param(param_name).nil? && !T.must(param(param_name)).schema.validate(param_value, udb_resolver: @config.info.resolver)
268
+ reasons << "Parameter value violates the schema: '#{param_name}' = '#{param_value}'"
269
+ end
270
+ end
271
+
272
+ T.cast(config, FullConfig).implemented_extensions.each do |h|
273
+ unless extensions.any? { |e| e.name == h["name"] }
274
+ reasons << "#{h.fetch("name")} is not a known extension"
275
+ end
276
+ if extensions.any? { |e| e.name == h.fetch("name") } && !T.must(extension(h.fetch("name"))).versions.any? { |v| v.version_spec == h.fetch("version") }
277
+ reasons << "#{h.fetch("version")} is not a known extension"
278
+ end
279
+ end
280
+
281
+ # shouldn't go any further if there is already a problem because constructing a
282
+ # cfg_arch condition will fail
283
+ return ValidationResult.new(valid: false, reasons:) unless reasons.empty?
284
+
285
+ explicitly_implemented_extension_versions.each do |ext_ver|
286
+ unless ext_ver.requirements_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::Yes
287
+ reasons << "Extension requirement is unmet: #{ext_ver}. Needs: #{ext_ver.requirements_condition.minimize(expand: true).to_s_with_value(self, expand: false)}"
288
+ end
289
+ end
290
+
291
+ # check parameter requirements
292
+ config.param_values.each do |param_name, param_value|
293
+ p = T.must(param(param_name))
294
+ unless p.defined_by_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::Yes
295
+ reasons << [
296
+ "Parameter is not defined by this config: '#{param_name}'.",
297
+ "Needs: #{p.defined_by_condition.minimize(expand: true).to_s_with_value(self, expand: false)}"
298
+ ].join("\n")
299
+ end
300
+ unless p.requirements_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::Yes
301
+ reasons << [
302
+ "Parameter requirements not met: '#{param_name}'.",
303
+ "Needs: #{p.requirements_condition.minimize(expand: true).to_s_with_value(self, expand: false)}"
304
+ ].join("\n")
305
+ end
306
+ end
307
+
308
+ # to know all of the parameters that must be listed, we have to expand the implemented extension versions
309
+ # and then collect all of the defined parameters
310
+ required_parameters = params.select do |param|
311
+ param.defined_by_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::Yes
312
+ end
313
+
314
+ missing_params = required_parameters.reject do |param|
315
+ config.param_values.key?(param.name)
316
+ end
317
+ unless missing_params.empty?
318
+ reasons += missing_params.map { |p| "Parameter is required but missing: '#{p.name}'" }
319
+ end
320
+
321
+ if reasons.empty?
322
+ raise "bad validity check" unless to_condition.satisfiable?
323
+ ValidationResult.new(valid: true, reasons:)
324
+ else
325
+ ValidationResult.new(valid: false, reasons:)
326
+ end
327
+ end
328
+ private :full_config_valid?
329
+
330
+ # returns whether or not the partial config transitively lists all requirements of
331
+ # mandatory extensions (as other mandatory extension and/or parameters)
332
+ #
333
+ # For example:
334
+ # ----
335
+ # mandatory_extensions:
336
+ # - name: A
337
+ # ----
338
+ # is not strictly specified
339
+ #
340
+ # but
341
+ # ----
342
+ # mandatory_extensions:
343
+ # - name: A
344
+ # - name: Zaamo
345
+ # - name: Zalrsc
346
+ # ---
347
+ # is
348
+ sig { returns(ValidationResult) }
349
+ def partial_config_strictly_specified?
350
+ raise "not a partial config" unless partially_configured?
351
+
352
+ v = partial_config_valid?
353
+
354
+ reasons = []
355
+ mandatory_extension_reqs.each do |ext_req|
356
+ if ext_req.requirements_condition.satisfied_by_cfg_arch?(self) != SatisfiedResult::Yes
357
+ reasons << "Requirement of #{ext_req} are not met: #{ext_req.requirements_condition.to_s_with_value(self, expand: false)}"
358
+ end
359
+ end
360
+
361
+ ValidationResult.new(valid: v.valid & reasons.empty?, reasons: v.reasons + reasons)
362
+ end
363
+
364
+ # @api private
365
+ sig { returns(ValidationResult) }
366
+ def partial_config_valid?
367
+ reasons = []
368
+
369
+ mandatory_extension_reqs.each do |ext_req|
370
+ unless ext_req.valid?
371
+ reasons << "Extension requirement can never be met (no match in the database): #{ext_req}"
372
+ end
373
+ end
374
+
375
+ # check that provided param values are defined and match the schema
376
+ config.param_values.each do |param_name, param_value|
377
+ p = param(param_name)
378
+ # pwv.name is not a defined parameter
379
+ if p.nil?
380
+ reasons << "Parameter has no definition: '#{param_name}'"
381
+ next
382
+ end
383
+
384
+ unless p.schema.validate(param_value, udb_resolver: @config.info.resolver)
385
+ reasons << "Parameter value violates the schema: '#{param_name}' = '#{param_value}'"
386
+ end
387
+ end
388
+
389
+ # shouldn't go any further if there is already a problem because constructing a
390
+ # cfg_arch condition will fail
391
+ return ValidationResult.new(valid: false, reasons:) unless reasons.empty?
392
+
393
+ # first check extension requirements
394
+ # need to make sure that it is possible to construct a config that
395
+ # meets the requirements without introducing a conflict
396
+ mandatory_cond =
397
+ Condition.conjunction(
398
+ mandatory_extension_reqs.select(&:valid?).map { |ext_req| ext_req.to_condition },
399
+ self
400
+ )
401
+ unless mandatory_cond.satisfiable?
402
+ mandatory_cond.to_logic_tree(expand: true).minimal_unsat_subsets.each do |min|
403
+ reasons << "Mandatory extension requirements conflict: This is not satisfiable: #{min.to_s(format: LogicNode::LogicSymbolFormat::C)}"
404
+ end
405
+ end
406
+
407
+ # check that provided param values are defined and match the schema
408
+ config.param_values.each do |param_name, param_value|
409
+ p = T.must(param(param_name))
410
+
411
+ # check that parameter is defined by the partial config (e.g., is defined by a mandatory
412
+ # extension and/or other param value).
413
+ unless p.defined_by_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::Yes
414
+ reasons << "Parameter is not defined by this config: '#{param_name}'. Needs #{p.defined_by_condition}"
415
+ end
416
+
417
+ if p.requirements_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::No
418
+ reasons << "Parameter requirements cannot be met: '#{param_name}'. Needs: #{p.requirements_condition}"
419
+ end
420
+ end
421
+
422
+ unless T.cast(config, PartialConfig).requirements.nil?
423
+ unless (to_condition).satisfiable?
424
+ to_condition.to_logic_tree(expand: true).minimal_unsat_subsets.each do |min|
425
+ reasons << "Requirements cannot be met. This is not satisfiable: #{min.to_s(format: LogicNode::LogicSymbolFormat::C)}"
426
+ end
427
+ end
428
+ end
429
+
430
+ if reasons.empty?
431
+ raise "Bad validation" unless to_condition.satisfiable?
432
+ return ValidationResult.new(valid: true, reasons: [])
433
+ else
434
+ return ValidationResult.new(valid: false, reasons:)
435
+ end
436
+ end
437
+ private :partial_config_valid?
438
+
439
+ # @api private
440
+ # Return callbacks needed by a SymbolTable to check properties of the configuration
441
+ sig { returns(Idl::SymbolTable::BuiltinFunctionCallbacks) }
442
+ def symtab_callbacks
443
+ Idl::SymbolTable::BuiltinFunctionCallbacks.new(
444
+ implemented: (
445
+ Idl::SymbolTable.make_implemented_callback do |ext_name|
446
+ if fully_configured?
447
+ ext?(ext_name)
448
+ else
449
+ # we can know if it is implemented, but not if it's not implemented for a partially configured
450
+ if ext?(ext_name)
451
+ true
452
+ elsif prohibited_ext?(ext_name)
453
+ false
454
+ else
455
+ nil
456
+ end
457
+ end
458
+ end
459
+ ),
460
+ implemented_version: (
461
+ Idl::SymbolTable.make_implemented_version_callback do |ext_name, version|
462
+ if fully_configured?
463
+ ext?(ext_name, [version])
464
+ else
465
+ # we can know if it is implemented, but not if it's not implemented for a partially configured
466
+ if ext?(ext_name, [version])
467
+ true
468
+ elsif prohibited_ext?(ext_name)
469
+ false
470
+ else
471
+ nil
472
+ end
473
+ end
474
+ end
475
+ ),
476
+ implemented_csr: (
477
+ Idl::SymbolTable.make_implemented_csr_callback do |csr_addr|
478
+ if fully_configured?
479
+ if implemented_csrs.any? { |c| c.address == csr_addr }
480
+ true
481
+ end
482
+ else
483
+ if not_prohibited_csrs.none? { |c| c.address == csr_addr }
484
+ false
485
+ end
486
+ end
487
+ end
488
+ )
489
+ )
490
+ end
491
+ private :symtab_callbacks
492
+
493
+ # @api private
494
+ # generated enum definitions for the symbol table
495
+ sig { returns(T::Array[Idl::SymbolTable::EnumDef]) }
496
+ def symtab_enums
497
+ [
498
+ Idl::SymbolTable::EnumDef.new(
499
+ name: "ExtensionName",
500
+ element_values: (1..extensions.size).to_a,
501
+ element_names: extensions.map(&:name)
502
+ ),
503
+ Idl::SymbolTable::EnumDef.new(
504
+ name: "ExceptionCode",
505
+ element_values: exception_codes.map(&:num),
506
+ element_names: exception_codes.map(&:var)
507
+ ),
508
+ Idl::SymbolTable::EnumDef.new(
509
+ name: "InterruptCode",
510
+ element_values: interrupt_codes.map(&:num),
511
+ element_names: interrupt_codes.map(&:var)
512
+ )
513
+ ]
514
+ end
515
+ private :symtab_enums
516
+
517
+ # @api private
518
+ sig { returns(Idl::SymbolTable) }
519
+ def create_symtab
520
+ Udb.logger.debug "Creating symbol table"
521
+ pb =
522
+ Udb.create_progressbar(
523
+ "Finding params for #{name} [:bar]",
524
+ clear: true
525
+ )
526
+ all_params = # including both those will value/without value, and those in scope/out of scope
527
+ @config.param_values.map do |pname, pvalue|
528
+ pb.advance
529
+ p = param(pname)
530
+ unless p.nil?
531
+ ParameterWithValue.new(p, pvalue)
532
+ end
533
+ end.compact \
534
+ + params.reject { |p| pb.advance; @config.param_values.key?(p.name) }
535
+ final_param_vars = all_params.map do |param|
536
+ pb.advance
537
+ idl_type = param.idl_type
538
+
539
+ if param.value_known?
540
+ Idl::Var.new(param.name, idl_type.make_const, param.value, param: true)
541
+ else
542
+ Idl::Var.new(param.name, idl_type.make_const, param: true)
543
+ end
544
+ end
545
+ pb.finish
546
+
547
+ Idl::SymbolTable.new(
548
+ mxlen:,
549
+ possible_xlens_cb: proc { possible_xlens },
550
+ builtin_global_vars: final_param_vars,
551
+ builtin_funcs: symtab_callbacks,
552
+ builtin_enums: symtab_enums,
553
+ name: @name,
554
+ csrs:,
555
+ params: all_params
556
+ )
557
+ end
558
+ private :create_symtab
559
+
560
+ class MemoizedState < T::Struct
561
+ prop :multi_xlen_in_mode, T::Hash[String, T::Boolean]
562
+ prop :multi_xlen, T.nilable(T::Boolean)
563
+ prop :params_with_value, T.nilable(T::Array[ParameterWithValue])
564
+ prop :params_without_value, T.nilable(T::Array[Parameter])
565
+ prop :out_of_scope_params, T.nilable(T::Array[Parameter])
566
+ prop :implemented_extension_versions, T.nilable(T::Array[ExtensionVersion])
567
+ prop :implemented_extension_version_hash, T.nilable(T::Hash[String, ExtensionVersion])
568
+ prop :extension_requirements_hash, T::Hash[String, ExtensionRequirement]
569
+ prop :extension_versions_hash, T::Hash[String, ExtensionVersion]
570
+ end
571
+
572
+ # Initialize a new configured architecture definition
573
+ #
574
+ # @param name [:to_s] The name associated with this ConfiguredArchitecture
575
+ # @param config [AbstractConfig] The configuration object
576
+ # @param arch_path [Pathnam] Path to the resolved architecture directory corresponding to the configuration
577
+ sig { params(name: String, config: AbstractConfig).void }
578
+ def initialize(name, config)
579
+ Udb.logger.info "Constructing ConfiguredArchiture for #{name}"
580
+ super(config.info.resolved_spec_path)
581
+
582
+ @name = name.to_s.freeze
583
+ @name_sym = @name.to_sym.freeze
584
+
585
+ @memo = MemoizedState.new(
586
+ multi_xlen_in_mode: {},
587
+ extension_requirements_hash: {},
588
+ extension_versions_hash: {}
589
+ )
590
+
591
+ @config = config
592
+ @config_type = T.let(@config.type, ConfigType)
593
+ @mxlen = config.mxlen
594
+ @mxlen.freeze
595
+
596
+ @idl_compiler = Idl::Compiler.new
597
+ end
598
+
599
+ def inspect
600
+ "CfgArch##{name}"
601
+ end
602
+
603
+ # @api private
604
+ # metaprogramming function to create accessor methods for top-level database objects
605
+ #
606
+ # This is defined in ConfiguredArchitecture, rather than Architecture because the object
607
+ # models all expect to work with a ConfiguredArchitecture
608
+ #
609
+ # For example, created the following functions:
610
+ # extensions # array of all extensions
611
+ # extension_hash # hash of all extensions, indexed by name
612
+ # extension(name) # getter for extension 'name'
613
+ # instructions # array of all extensions
614
+ # instruction_hash # hash of all extensions, indexed by name
615
+ # instruction(name) # getter for extension 'name'
616
+ # ...
617
+ #
618
+ # @!macro [attach] generate_obj_methods
619
+ # @method $1s
620
+ # @return [Array<$3>] List of all $1s defined in the standard
621
+ #
622
+ # @method $1_hash
623
+ # @return [Hash<String, $3>] Hash of all $1s
624
+ #
625
+ # @method $1
626
+ # @param name [String] The $1 name
627
+ # @return [$3] The $1
628
+ # @return [nil] if there is no $1 named +name+
629
+ sig { params(fn_name: String, arch_dir: String, obj_class: T.class_of(TopLevelDatabaseObject)).void }
630
+ def self.generate_obj_methods(fn_name, arch_dir, obj_class)
631
+
632
+ plural_fn = ActiveSupport::Inflector.pluralize(fn_name)
633
+
634
+ define_method(plural_fn) do
635
+ return @objects[arch_dir] unless @objects[arch_dir].nil?
636
+
637
+ @objects[arch_dir] = Concurrent::Array.new
638
+ @object_hashes[arch_dir] = Concurrent::Hash.new
639
+ Dir.glob(@arch_dir / arch_dir / "**" / "*.yaml") do |obj_path|
640
+ f = File.open(obj_path)
641
+ f.flock(File::LOCK_EX)
642
+ obj_yaml = YAML.load(f.read, filename: obj_path, permitted_classes: [Date])
643
+ f.flock(File::LOCK_UN)
644
+ @objects[arch_dir] << obj_class.new(obj_yaml, Pathname.new(obj_path).realpath, T.cast(self, ConfiguredArchitecture))
645
+ @object_hashes[arch_dir][@objects[arch_dir].last.name] = @objects[arch_dir].last
646
+ end
647
+ @objects[arch_dir]
648
+ end
649
+
650
+ define_method("#{fn_name}_hash") do
651
+ return @object_hashes[arch_dir] unless @object_hashes[arch_dir].nil?
652
+
653
+ send(plural_fn) # create the hash
654
+
655
+ @object_hashes[arch_dir]
656
+ end
657
+
658
+ define_method(fn_name) do |name|
659
+ return @object_hashes[arch_dir][name] unless @object_hashes[arch_dir].nil?
660
+
661
+ send(plural_fn) # create the hash
662
+
663
+ @object_hashes[arch_dir][name]
664
+ end
665
+ end
666
+
667
+ # call generate_obj_methods for each known top-level database object
668
+ OBJS.each do |obj_info|
669
+ generate_obj_methods(obj_info[:fn_name], obj_info[:arch_dir], obj_info[:klass])
670
+ end
671
+
672
+ # type check all IDL, including globals, instruction ops, and CSR functions
673
+ #
674
+ # @param show_progress whether to show progress bars
675
+ # @param io where to write progress bars
676
+ # @return [void]
677
+ sig { params(show_progress: T::Boolean, io: IO).void }
678
+ def type_check(show_progress: true, io: $stdout)
679
+ io.puts "Type checking IDL code for #{@config.name}..." if show_progress
680
+ insts = @config.unconfigured? ? instructions : possible_instructions(show_progress:)
681
+ xlens = @config.unconfigured? ? [32, 64] : possible_xlens
682
+
683
+ progressbar =
684
+ if show_progress
685
+ TTY::ProgressBar.new("type checking possible instructions [:bar] :current/:total", total: insts.size, output: $stdout)
686
+ end
687
+
688
+ insts.each do |inst|
689
+ progressbar.advance if show_progress
690
+ if @mxlen == 32
691
+ if inst.rv32?
692
+ op_ast = inst.operation_ast
693
+ unless op_ast.nil?
694
+ s = inst.fill_symtab(32, op_ast)
695
+ op_ast.prune(s).type_check(s, strict: true)
696
+ s.release
697
+ end
698
+ end
699
+ else
700
+ if inst.rv64?
701
+ op_ast = inst.operation_ast
702
+ unless op_ast.nil?
703
+ s = inst.fill_symtab(64, op_ast)
704
+ op_ast.prune(s).type_check(s, strict: true)
705
+ s.release
706
+ end
707
+ end
708
+ if xlens.include?(32) && inst.rv32?
709
+ op_ast = inst.operation_ast
710
+ unless op_ast.nil?
711
+ s = inst.fill_symtab(32, op_ast)
712
+ op_ast.prune(s).type_check(s, strict: true)
713
+ s.release
714
+ end
715
+ end
716
+ end
717
+ end
718
+
719
+ csr_list = @config.unconfigured? ? csrs : possible_csrs
720
+ progressbar =
721
+ if show_progress
722
+ TTY::ProgressBar.new("type checking CSRs [:bar]", total: csr_list.size, output: $stdout)
723
+ end
724
+
725
+ csr_list.each do |csr|
726
+ progressbar.advance if show_progress
727
+ # Cache CSR base checks to avoid repeated method calls
728
+ csr_in_base32 = csr.defined_in_base32?
729
+ csr_in_base64 = csr.defined_in_base64?
730
+
731
+ if csr.has_custom_sw_read?
732
+ if (xlens.include?(32) && csr_in_base32)
733
+ s = csr.fill_symtab(nil, 32)
734
+ csr.sw_read_ast(s).prune(s).type_check(s, strict: true)
735
+ s.release
736
+ end
737
+ if (xlens.include?(64) && csr_in_base64)
738
+ s = csr.fill_symtab(nil, 64)
739
+ csr.sw_read_ast(s).prune(s).type_check(s, strict: true)
740
+ s.release
741
+ end
742
+ end
743
+ csr.possible_fields.each do |field|
744
+ reset_ast = field.reset_value_ast
745
+ unless reset_ast.nil?
746
+ if xlens.include?(32) && csr_in_base32 && field.defined_in_base32?
747
+ s = field.fill_symtab_for_reset(nil)
748
+ reset_ast.prune(s).type_check(s, strict: true)
749
+ s.release
750
+ end
751
+ if xlens.include?(64) && csr_in_base64 && field.defined_in_base64?
752
+ s = field.fill_symtab_for_reset(nil)
753
+ reset_ast.prune(s).type_check(s, strict: true)
754
+ s.release
755
+ end
756
+ end
757
+ if field.has_custom_sw_write?
758
+ if xlens.include?(32) && csr_in_base32 && field.defined_in_base32?
759
+ s = field.fill_symtab_for_sw_write(32, nil)
760
+ field.sw_write_ast(s).prune(s).type_check(s, strict: true)
761
+ s.release
762
+ end
763
+ if xlens.include?(64) && csr_in_base64 && field.defined_in_base64?
764
+ s = field.fill_symtab_for_sw_write(64, nil)
765
+ field.sw_write_ast(s).prune(s).type_check(s, strict: true)
766
+ s.release
767
+ end
768
+ end
769
+ type_ast = field.type_ast
770
+ unless type_ast.nil?
771
+ if xlens.include?(32) && csr_in_base32 && field.defined_in_base32?
772
+ s = field.fill_symtab_for_type(32, nil)
773
+ type_ast.prune(s).type_check(s, strict: true)
774
+ s.release
775
+ end
776
+ if xlens.include?(64) && csr_in_base64 && field.defined_in_base64?
777
+ s = field.fill_symtab_for_type(64, nil)
778
+ type_ast.prune(s).type_check(s, strict: true)
779
+ s.release
780
+ end
781
+ end
782
+ end
783
+ end
784
+
785
+ func_list = @config.unconfigured? ? functions : reachable_functions(show_progress:)
786
+ progressbar =
787
+ if show_progress
788
+ TTY::ProgressBar.new("type checking functions [:bar]", total: func_list.size, output: $stdout)
789
+ end
790
+ func_list.each do |func|
791
+ progressbar.advance if show_progress
792
+ s = symtab.global_clone
793
+ s.push(func)
794
+ pruned = func.prune(s)
795
+ s.pop
796
+ pruned.type_check(s, strict: true)
797
+ s.release
798
+ end
799
+
800
+ puts "done" if show_progress
801
+ end
802
+
803
+ # @return List of all parameters with one known value in the config
804
+ sig { returns(T::Array[ParameterWithValue]) }
805
+ def params_with_value
806
+ @memo.params_with_value ||=
807
+ @config.param_values.map do |param_name, param_value|
808
+ p = param(param_name)
809
+ if p.nil?
810
+ Udb.logger.warn "#{param_name} is not a parameter"
811
+ nil
812
+ else
813
+ ParameterWithValue.new(p, param_value)
814
+ end
815
+ end.compact
816
+ end
817
+
818
+ # List of all available parameters without one known value in the config
819
+ sig { returns(T::Array[Parameter]) }
820
+ def params_without_value
821
+ @memo.params_without_value ||=
822
+ params.select do |p|
823
+ !@config.param_values.key?(p.name) \
824
+ && p.defined_by_condition.could_be_satisfied_by_cfg_arch?(self)
825
+ end
826
+ end
827
+
828
+ # Returns list of parameters that out of scope for the config
829
+ sig { returns(T::Array[Parameter]) }
830
+ def out_of_scope_params
831
+ @memo.out_of_scope_params ||=
832
+ begin
833
+ out_of_scope_params = []
834
+ params.each do |param|
835
+ next if params_with_value.any? { |p| p.name == param.name }
836
+ next if params_without_value.any? { |p| p.name == param.name }
837
+
838
+ out_of_scope_params << param
839
+ end
840
+ out_of_scope_params
841
+ end
842
+ end
843
+
844
+ # @return List of extension versions explicitly marked as implemented in the config.
845
+ sig { returns(T::Array[ExtensionVersion]) }
846
+ def implemented_extension_versions
847
+ @memo.implemented_extension_versions ||=
848
+ begin
849
+ unless fully_configured?
850
+ raise ArgumentError, "implemented_extension_versions only valid for fully configured systems"
851
+ end
852
+
853
+ T.cast(@config, FullConfig).implemented_extensions.map do |e|
854
+ extension_version(e.fetch("name"), e.fetch("version"))
855
+ end
856
+ end
857
+ end
858
+
859
+ # @deprecated in favor of implemented_extension_versions
860
+ def explicitly_implemented_extension_versions = implemented_extension_versions
861
+
862
+ # @deprecated in favor of implemented_extension_versions
863
+ def transitive_implemented_extension_versions = implemented_extension_versions
864
+
865
+ sig { params(name: String, requirements: T.any(String, T::Array[String], RequirementSpec, T::Array[RequirementSpec])).returns(ExtensionRequirement) }
866
+ def extension_requirement(name, requirements)
867
+ requirement_specs =
868
+ if requirements.is_a?(Array)
869
+ if requirements.fetch(0).is_a?(RequirementSpec)
870
+ requirements
871
+ else
872
+ requirements.map { |r| RequirementSpec.new(r) }
873
+ end
874
+ else
875
+ if requirements.is_a?(RequirementSpec)
876
+ requirements
877
+ else
878
+ RequirementSpec.new(requirements)
879
+ end
880
+ end
881
+ key =
882
+ if requirement_specs.is_a?(Array)
883
+ [name, *requirement_specs].hash
884
+ else
885
+ [name, requirement_specs].hash
886
+ end
887
+
888
+ cached_ext_req = @memo.extension_requirements_hash[key]
889
+ if cached_ext_req.nil?
890
+ ext_req = ExtensionRequirement.send(:new, name, requirement_specs, arch: self)
891
+ @memo.extension_requirements_hash[key] = ext_req
892
+ else
893
+ cached_ext_req
894
+ end
895
+ end
896
+
897
+ sig { params(name: String, version: T.any(String, VersionSpec)).returns(ExtensionVersion) }
898
+ def extension_version(name, version)
899
+ version_spec = version.is_a?(VersionSpec) ? version : VersionSpec.new(version)
900
+ key = [name, version_spec].hash
901
+
902
+ cached_ext_ver = @memo.extension_versions_hash[key]
903
+ if cached_ext_ver.nil?
904
+ ext_req = ExtensionVersion.send(:new, name, version_spec, self, fail_if_version_does_not_exist: true)
905
+ @memo.extension_versions_hash[key] = ext_req
906
+ else
907
+ cached_ext_ver
908
+ end
909
+ end
910
+
911
+ # given the current (invalid) config, try to come up with a list of extension versions that,
912
+ # if added, might make the config valid
913
+ #
914
+ # For example, if C, F, and D are implemented but not Zca, Zcf, Zcd, return [Zca, Zcf, Zcd]
915
+ sig { params(ext_vers: T::Array[ExtensionVersion]).returns(T::Array[ExtensionVersion]) }
916
+ def expand_implemented_extension_list(ext_vers)
917
+
918
+ # build up a condition requiring all ext_vers, have it expand, and then minimize it
919
+ # what's left is the full list
920
+ condition =
921
+ Condition.conjunction(ext_vers.map(&:to_condition), self)
922
+
923
+ res = condition.implied_extension_requirements
924
+ (ext_vers +
925
+ res.map do |cond_ext_req|
926
+ if cond_ext_req.cond.empty?
927
+ cond_ext_req.ext_req.satisfying_versions.fetch(0)
928
+ else
929
+ nil
930
+ end
931
+ end.compact).uniq
932
+ end
933
+
934
+
935
+ sig { params(ext_name: String).returns(T.nilable(ExtensionVersion)) }
936
+ def implemented_extension_version(ext_name)
937
+ @memo.implemented_extension_version_hash ||=
938
+ implemented_extension_versions.to_h { |ext_ver| [ext_ver.name, ext_ver] }
939
+
940
+ @memo.implemented_extension_version_hash[ext_name]
941
+ end
942
+
943
+ # @return List of all mandatory extension requirements (not transitive)
944
+ sig { returns(T::Array[ExtensionRequirement]) }
945
+ def mandatory_extension_reqs
946
+ @mandatory_extension_reqs ||=
947
+ begin
948
+ raise "Only partial configs have mandatory extension requirements" unless @config.is_a?(PartialConfig)
949
+
950
+ @config.mandatory_extensions.map do |e|
951
+ ename = T.cast(e["name"], String)
952
+
953
+ if e["version"].nil?
954
+ extension_requirement(ename, ">= 0")
955
+ else
956
+ extension_requirement(ename, e.fetch("version"))
957
+ end
958
+ end
959
+ end
960
+ end
961
+
962
+ # @return List of all mandatory extension requirements (not transitive)
963
+ sig { returns(T::Array[ExtensionRequirement]) }
964
+ def non_mandatory_extension_reqs
965
+ @non_mandatory_extension_reqs ||=
966
+ begin
967
+ raise "Only partial configs have non-mandatory extension requirements" unless @config.is_a?(PartialConfig)
968
+
969
+ @config.non_mandatory_extensions.map do |e|
970
+ ename = T.cast(e["name"], String)
971
+
972
+ if e["version"].nil?
973
+ extension_requirement(ename, ">= 0")
974
+ else
975
+ extension_requirement(ename, e.fetch("version"))
976
+ end
977
+ end
978
+ end
979
+ end
980
+
981
+ # list of all the extension versions that optional, i.e:
982
+ # lis of all the extension versions would not fufill a mandatory requirement and are not prhohibited
983
+ sig { returns(T::Array[ExtensionRequirement]) }
984
+ def optional_extension_versions
985
+ @optional_extension_versions ||=
986
+ begin
987
+ if fully_configured?
988
+ []
989
+ elsif partially_configured?
990
+ # optional is all extensions - mandatory - prohibited
991
+ extension_versions.reject do |ext_ver|
992
+ mandatory_extension_reqs.any? { |ext_req| ext_req.satisfied_by?(ext_ver) } ||
993
+ prohibited_extension_versions.any? { |prohibited_ext_ver| prohibited_ext_ver == ext_ver }
994
+ end
995
+ else
996
+ # unconfig; all extension versions are optional
997
+ extension_versions
998
+ end
999
+ end
1000
+ end
1001
+
1002
+ # @return [Array<Extension>] List of extensions that are possibly supported
1003
+ sig { returns(T::Array[Extension]) }
1004
+ def possible_extensions
1005
+ return @not_prohibited_extensions if defined?(@not_prohibited_extensions)
1006
+
1007
+ @not_prohibited_extensions ||=
1008
+ if @config.fully_configured?
1009
+ implemented_extension_versions.map { |ext_ver| ext_ver.ext }.uniq
1010
+ elsif @config.partially_configured?
1011
+ pb = Udb.create_progressbar("determining possible exts [:bar] :current/:total", total: extensions.size)
1012
+ extensions.select { |e| pb.advance; (e.to_condition).satisfiable_by_cfg_arch?(self) }
1013
+ else
1014
+ extensions
1015
+ end
1016
+ end
1017
+ alias not_prohibited_extensions possible_extensions
1018
+
1019
+ # @return List of all extension versions that are prohibited.
1020
+ # This includes extensions explicitly prohibited by the config file
1021
+ # and extensions that conflict with a mandatory extension.
1022
+ sig { returns(T::Array[ExtensionVersion]) }
1023
+ def prohibited_extension_versions
1024
+ @prohibited_extension_versions ||=
1025
+ extension_versions - possible_extension_versions
1026
+ end
1027
+
1028
+ # the complete set of extension versions that could be implemented in this config
1029
+ def possible_extension_versions
1030
+ @possible_extension_versions ||=
1031
+ begin
1032
+ if @config.partially_configured?
1033
+ extension_versions.select { |ext_ver| ext_ver.to_condition.satisfiable_by_cfg_arch?(self) }
1034
+ elsif @config.fully_configured?
1035
+ # full config: only the implemented versions are possible
1036
+ implemented_extension_versions
1037
+ else
1038
+ # unconfig; everything is possible
1039
+ extensions.map(&:versions).flatten
1040
+ end
1041
+ end
1042
+ end
1043
+
1044
+ # @overload prohibited_ext?(ext)
1045
+ # Returns true if the ExtensionVersion +ext+ is prohibited
1046
+ # @param ext [ExtensionVersion] An extension version
1047
+ # @return [Boolean]
1048
+ #
1049
+ # @overload prohibited_ext?(ext)
1050
+ # Returns true if any version of the extension named +ext+ is prohibited
1051
+ # @param ext [String] An extension name
1052
+ # @return [Boolean]
1053
+ sig { params(ext: T.any(ExtensionVersion, String, Symbol)).returns(T::Boolean) }
1054
+ def prohibited_ext?(ext)
1055
+ if ext.is_a?(ExtensionVersion)
1056
+ prohibited_extension_versions.include?(ext)
1057
+ elsif ext.is_a?(String) || ext.is_a?(Symbol)
1058
+ prohibited_extension_versions.any? { |ext_ver| ext_ver.name == ext.to_s }
1059
+ else
1060
+ raise ArgumentError, "Argument to prohibited_ext? should be an ExtensionVersion or a String"
1061
+ end
1062
+ end
1063
+
1064
+ # @overload ext?(ext_name)
1065
+ # @param ext_name [#to_s] Extension name (case sensitive)
1066
+ # @return [Boolean] True if the extension `name` is implemented
1067
+ # @overload ext?(ext_name, ext_version_requirements)
1068
+ # @param ext_name [#to_s] Extension name (case sensitive)
1069
+ # @param ext_version_requirements [Number,String,Array] Extension version requirements
1070
+ # @return [Boolean] True if the extension `name` meeting `ext_version_requirements` is implemented
1071
+ # @example Checking extension presence with a version requirement
1072
+ # ConfigurationArchitecture.ext?(:S, ">= 1.12")
1073
+ # @example Checking extension presence with multiple version requirements
1074
+ # ConfigurationArchitecture.ext?(:S, ">= 1.12", "< 1.15")
1075
+ # @example Checking extension precsence with a precise version requirement
1076
+ # ConfigurationArchitecture.ext?(:S, 1.12)
1077
+ # sig { params(ext_name: T.any(String, Symbol), ext_version_requirements: T::Array[String]).returns(T::Boolean) }
1078
+ def ext?(ext_name, ext_version_requirements = [])
1079
+ @ext_cache ||= {}
1080
+ cached_result = @ext_cache[[ext_name, ext_version_requirements]]
1081
+ return cached_result unless cached_result.nil?
1082
+
1083
+ result =
1084
+ if @config.fully_configured?
1085
+ implemented_extension_versions.any? do |e|
1086
+ if ext_version_requirements.empty?
1087
+ e.name == ext_name.to_s
1088
+ else
1089
+ requirement = extension_requirement(ext_name.to_s, ext_version_requirements)
1090
+ requirement.satisfied_by?(e)
1091
+ end
1092
+ end
1093
+ elsif @config.partially_configured?
1094
+ mandatory_extension_reqs.any? do |e|
1095
+ if ext_version_requirements.empty?
1096
+ e.name == ext_name.to_s
1097
+ else
1098
+ requirement = extension_requirement(ext_name.to_s, ext_version_requirements)
1099
+ e.satisfying_versions.all? do |ext_ver|
1100
+ requirement.satisfied_by?(ext_ver)
1101
+ end
1102
+ end
1103
+ end
1104
+ else
1105
+ raise "unexpected type" unless unconfigured?
1106
+
1107
+ false
1108
+ end
1109
+ @ext_cache[[ext_name, ext_version_requirements]] = result
1110
+ end
1111
+
1112
+ # @return [Array<ExceptionCode>] All exception codes known to be implemented
1113
+ sig { returns(T::Array[ExceptionCode]) }
1114
+ def implemented_exception_codes
1115
+ @implemented_exception_codes ||=
1116
+ exception_codes.select { |code| code.defined_by_condition.satisfiable_by_cfg_arch?(self) }
1117
+ end
1118
+
1119
+ # @return [Array<InteruptCode>] All interrupt codes known to be implemented
1120
+ sig { returns(T::Array[InterruptCode]) }
1121
+ def implemented_interrupt_codes
1122
+ @implemented_interupt_codes ||=
1123
+ implemented_exception_codes.select { |code| code.defined_by_condition.satisfiable_by_cfg_arch?(self) }
1124
+ end
1125
+
1126
+ # @return [Array<Idl::FunctionBodyAst>] List of all functions defined by the architecture
1127
+ sig { returns(T::Array[Idl::FunctionDefAst]) }
1128
+ def functions
1129
+ @functions ||= global_ast.functions
1130
+ end
1131
+
1132
+ sig { returns(T::Hash[String, Idl::FunctionDefAst]) }
1133
+ def function_hash
1134
+ @function_hash ||= functions.map { |f| [f.name, f] }.to_h
1135
+ end
1136
+
1137
+ sig { params(name: String).returns(T.nilable(Idl::FunctionDefAst)) }
1138
+ def function(name)
1139
+ function_hash[name]
1140
+ end
1141
+
1142
+ # @return [Idl::FetchAst] Fetch block
1143
+ sig { returns(Idl::FetchAst) }
1144
+ def fetch
1145
+ @fetch ||= global_ast.fetch
1146
+ end
1147
+
1148
+ # @return [Array<Idl::GlobalAst>] List of globals
1149
+ sig { returns(T::Array[T.any(Idl::GlobalAst, Idl::GlobalWithInitializationAst)]) }
1150
+ def globals
1151
+ return @globals unless @globals.nil?
1152
+
1153
+ @globals = global_ast.globals
1154
+ end
1155
+
1156
+ # @return [Array<Csr>] List of all implemented CSRs
1157
+ sig { returns(T::Array[Csr]) }
1158
+ def implemented_csrs
1159
+ @implemented_csrs ||=
1160
+ begin
1161
+ unless fully_configured?
1162
+ raise ArgumentError, "implemented_csrs is only defined for fully configured systems"
1163
+ end
1164
+
1165
+ csrs.select do |csr|
1166
+ csr.defined_by_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::Yes
1167
+ end
1168
+ end
1169
+ end
1170
+
1171
+ # @deprecated in favor of implemented_csrs
1172
+ def transitive_implemented_csrs = implemented_csrs
1173
+
1174
+ # @return [Array<Csr>] List of all CSRs that it is possible to implement
1175
+ sig { params(show_progress: T::Boolean).returns(T::Array[Csr]) }
1176
+ def possible_csrs(show_progress: false)
1177
+ @not_prohibited_csrs ||=
1178
+ if @config.fully_configured?
1179
+ implemented_csrs
1180
+ elsif @config.partially_configured?
1181
+ bar =
1182
+ if show_progress
1183
+ TTY::ProgressBar.new("determining possible CSRs [:bar]", total: csrs.size, output: $stdout)
1184
+ end
1185
+ csrs.select do |csr|
1186
+ bar.advance if show_progress
1187
+ csr.defined_by_condition.satisfiable_by_cfg_arch?(self)
1188
+ end
1189
+ else
1190
+ csrs
1191
+ end
1192
+ end
1193
+ alias not_prohibited_csrs possible_csrs
1194
+
1195
+ sig { params(show_progress: T::Boolean).returns(T::Array[Csr]) }
1196
+ def csrs_that_must_be_implemented(show_progress: false)
1197
+ @csrs_that_must_be_implemented ||=
1198
+ if @config.fully_configured?
1199
+ implemented_csrs
1200
+ elsif @config.partially_configured?
1201
+ bar =
1202
+ if show_progress
1203
+ Udb.create_progressbar("determining CSRs that must be implemented [:bar]", total: csrs.size, output: $stdout)
1204
+ end
1205
+ csrs.select do |csr|
1206
+ bar.advance if show_progress
1207
+ (-csr.defined_by_condition).unsatisfiable_by_cfg_arch?(self)
1208
+ end
1209
+ else
1210
+ []
1211
+ end
1212
+ end
1213
+
1214
+ # CSRs that are defined by mentioned extensions in the config
1215
+ #
1216
+ # For a full config, this is CSRs defined by the implemented extensions
1217
+ #
1218
+ # For a partial config, this is CSRs defined by the mandatory or
1219
+ # non-mandatory extensions
1220
+ sig { params(show_progress: T::Boolean).returns(T::Array[Csr]) }
1221
+ def in_scope_csrs(show_progress: false)
1222
+ @mentioned_csrs ||=
1223
+ if @config.fully_configured?
1224
+ implemented_csrs
1225
+ elsif @config.partially_configured?
1226
+ bar =
1227
+ if show_progress
1228
+ Udb.create_progressbar("determining in scope CSRs [:bar]", total: csrs.size, output: $stdout)
1229
+ end
1230
+ csrs.select do |csr|
1231
+ bar.advance if show_progress
1232
+ (-csr.defined_by_condition & in_scope_condition).unsatisfiable?
1233
+ end
1234
+ else
1235
+ []
1236
+ end
1237
+ end
1238
+
1239
+ # a condition representing the architecture, independent of the config
1240
+ sig { returns(Condition) }
1241
+ def arch_condition
1242
+ @arch_condition ||=
1243
+ begin
1244
+ extension_version_conditions =
1245
+ extension_versions.map do |ext_ver|
1246
+ unless ext_ver.requirements_condition.empty?
1247
+ ext_ver.to_condition.implies(ext_ver.requirements_condition)
1248
+ end
1249
+ end.compact
1250
+ c = Condition.conjunction(extension_version_conditions, self)
1251
+ params.each do |param|
1252
+ unless param.requirements_condition.empty?
1253
+ c = c & param.defined_by_condition.implies(param.requirements_condition)
1254
+ end
1255
+ end
1256
+ c
1257
+ end
1258
+ end
1259
+
1260
+ # represent the config and architecture defintion as a Condition
1261
+ sig { returns(Condition) }
1262
+ def to_condition
1263
+ @to_condition ||=
1264
+ begin
1265
+ if fully_configured?
1266
+ (
1267
+ arch_condition \
1268
+ & \
1269
+ Condition.conjunction(implemented_extension_versions.map(&:to_condition), self) \
1270
+ & \
1271
+ Condition.conjunction(
1272
+ params_with_value.map do |pv|
1273
+ Condition.new({ "param" => { "name" => pv.name, "equal" => pv.value } }, self)
1274
+ end,
1275
+ self
1276
+ )
1277
+ )
1278
+ elsif partially_configured?
1279
+ c = arch_condition
1280
+ c = c & Condition.conjunction(mandatory_extension_reqs.map(&:to_condition), self)
1281
+ unless params_with_value.empty?
1282
+ c = c & Condition.conjunction(
1283
+ params_with_value.map do |pv|
1284
+ Condition.new({ "param" => { "name" => pv.name, "equal" => pv.value } }, self)
1285
+ end,
1286
+ self
1287
+ )
1288
+ end
1289
+ unless T.cast(@config, PartialConfig).prohibited_extensions.empty?
1290
+ prohib = T.cast(@config, PartialConfig).prohibited_extensions.map do |e|
1291
+ extension_requirement(T.cast(e.fetch("name"), String), e.fetch("version"))
1292
+ end
1293
+ c = c & -Condition.disjunction(prohib.map(&:to_condition), self)
1294
+ end
1295
+ reqs = T.cast(@config, PartialConfig).requirements
1296
+ unless reqs.nil?
1297
+ c = (c & Condition.new(reqs, self))
1298
+ end
1299
+ c
1300
+ else
1301
+ arch_condition
1302
+ end
1303
+ end
1304
+ end
1305
+
1306
+ # a condition where both mandatory and non-mandatory extensions are required
1307
+ sig { returns(Condition) }
1308
+ def in_scope_condition
1309
+ @in_scope_condition ||=
1310
+ begin
1311
+ if fully_configured?
1312
+ (
1313
+ Condition.conjunction(implemented_extension_versions.map(&:to_condition), self) \
1314
+ & \
1315
+ Condition.conjunction(
1316
+ params_with_value.map do |pv|
1317
+ Condition.new({ "param" => { "name" => pv.name, "equal" => pv.value } }, self)
1318
+ end,
1319
+ self
1320
+ )
1321
+ )
1322
+ elsif partially_configured?
1323
+ c = (
1324
+ Condition.conjunction(mandatory_extension_reqs.map(&:to_condition) + non_mandatory_extension_reqs.map(&:to_condition), self) \
1325
+ & \
1326
+ Condition.conjunction(
1327
+ params_with_value.map do |pv|
1328
+ Condition.new({ "param" => { "name" => pv.name, "equal" => pv.value } }, self)
1329
+ end,
1330
+ self
1331
+ )
1332
+ )
1333
+ reqs = T.cast(@config, PartialConfig).requirements
1334
+ unless reqs.nil?
1335
+ c = (c & Condition.new(reqs, self))
1336
+ end
1337
+ c
1338
+ end
1339
+ end
1340
+ end
1341
+
1342
+ # @return List of all implemented instructions, sorted by name
1343
+ sig { returns(T::Array[Instruction]) }
1344
+ def implemented_instructions
1345
+ unless fully_configured?
1346
+ raise ArgumentError, "implemented_instructions is only defined for fully configured systems"
1347
+ end
1348
+
1349
+ @implemented_instructions ||=
1350
+ instructions.select do |inst|
1351
+ inst.defined_by_condition.satisfiable_by_cfg_arch?(self)
1352
+ # inst.defined_by_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::Yes
1353
+ end
1354
+ end
1355
+
1356
+ # @depracted in favor of #implemented_instructions
1357
+ def transitive_implemented_instructions = implemented_instructions
1358
+
1359
+ # @return [Array<Instruction>] List of all prohibited instructions, sorted by name
1360
+ sig { returns(T::Array[Instruction]) }
1361
+ def prohibited_instructions
1362
+ @prohibited_instructions ||=
1363
+ if fully_configured?
1364
+ (instructions - implemented_instructions).sort
1365
+ elsif partially_configured?
1366
+ instructions.select do |inst|
1367
+ inst.defined_by_condition.unsatisfiable_by_cfg_arch?(self)
1368
+ # inst.defined_by_condition.satisfied_by_cfg_arch?(self) == SatisfiedResult::No
1369
+ end.sort
1370
+ else
1371
+ []
1372
+ end
1373
+ end
1374
+
1375
+ # @depracated in favor of #prohibited_instructions
1376
+ def transitive_prohibited_instructions = prohibited_instructions
1377
+
1378
+ # @return List of all instructions that are not prohibited by the config, sorted by name
1379
+ sig { params(show_progress: T::Boolean).returns(T::Array[Instruction]) }
1380
+ def possible_instructions(show_progress: false)
1381
+ return @not_prohibited_instructions if defined?(@not_prohibited_instructions)
1382
+
1383
+ @not_prohibited_instructions ||=
1384
+ if @config.fully_configured?
1385
+ implemented_instructions
1386
+ elsif @config.partially_configured?
1387
+ bar =
1388
+ if show_progress
1389
+ TTY::ProgressBar.new("determining possible instructions [:bar]", total: instructions.size, output: $stdout)
1390
+ end
1391
+ instructions.select do |inst|
1392
+ bar.advance if show_progress
1393
+
1394
+ inst.defined_by_condition.satisfiable_by_cfg_arch?(self)
1395
+
1396
+ # possible_xlens.any? { |xlen| inst.defined_in_base?(xlen) } && \
1397
+ # inst.defined_by_condition.satisfied_by_cfg_arch?(self) != SatisfiedResult::No
1398
+ end
1399
+ else
1400
+ instructions
1401
+ end
1402
+
1403
+ @not_prohibited_instructions
1404
+ end
1405
+
1406
+ alias not_prohibited_instructions possible_instructions
1407
+
1408
+ # @return [Integer] The largest instruction encoding in the config
1409
+ sig { returns(Integer) }
1410
+ def largest_encoding
1411
+ @largest_encoding ||= possible_instructions.map(&:max_encoding_width).max
1412
+ end
1413
+
1414
+ # @return [Array<FuncDefAst>] List of all reachable IDL functions for the config
1415
+ sig { returns(T::Array[Idl::FunctionDefAst]) }
1416
+ def implemented_functions
1417
+ reachable_functions(show_progress: false)
1418
+ end
1419
+
1420
+ # @return [Array<FunctionDefAst>] List of functions that can be reached by the configuration
1421
+ sig { params(show_progress: T::Boolean).returns(T::Array[Idl::FunctionDefAst]) }
1422
+ def reachable_functions(show_progress: false)
1423
+ return @reachable_functions unless @reachable_functions.nil?
1424
+
1425
+ @reachable_functions = []
1426
+
1427
+ insts = possible_instructions(show_progress:)
1428
+ csrs = possible_csrs(show_progress:)
1429
+
1430
+ bar =
1431
+ if show_progress
1432
+ TTY::ProgressBar.new("determining reachable IDL functions [:bar]", total: insts.size + csrs.size + 1 + global_ast.functions.size, output: $stdout)
1433
+ end
1434
+
1435
+ # Shared cache across all instructions/CSRs so that common utility functions
1436
+ # are only traversed once rather than once per instruction.
1437
+ shared_cache = {
1438
+ 32 => T.let({}, Idl::AstNode::ReachableFunctionCacheType),
1439
+ 64 => T.let({}, Idl::AstNode::ReachableFunctionCacheType)
1440
+ }
1441
+
1442
+ possible_instructions.each do |inst|
1443
+ bar.advance if show_progress
1444
+
1445
+ fns =
1446
+ if inst.base.nil?
1447
+ if multi_xlen?
1448
+ (inst.reachable_functions(32, shared_cache.fetch(32)) +
1449
+ inst.reachable_functions(64, shared_cache.fetch(32)))
1450
+ else
1451
+ inst.reachable_functions(possible_xlens.fetch(0), shared_cache.fetch(possible_xlens.fetch(0)))
1452
+ end
1453
+ else
1454
+ inst.reachable_functions(T.must(inst.base), shared_cache.fetch(T.must(inst.base)))
1455
+ end
1456
+
1457
+ @reachable_functions.concat(fns)
1458
+ end
1459
+
1460
+ @reachable_functions +=
1461
+ possible_csrs.flat_map do |csr|
1462
+ bar.advance if show_progress
1463
+
1464
+ csr.reachable_functions(nil, shared_cache)
1465
+ end.uniq
1466
+
1467
+ # now add everything from fetch
1468
+ st = @symtab.global_clone
1469
+ st.push(global_ast.fetch.body)
1470
+ possible_xlens.each do |xlen|
1471
+ @reachable_functions += global_ast.fetch.body.reachable_functions(st, shared_cache.fetch(xlen))
1472
+ end
1473
+ bar.advance if show_progress
1474
+ st.release
1475
+
1476
+ # now add everything from external functions
1477
+ st = @symtab.global_clone
1478
+ global_ast.functions.select { |fn| fn.external? }.each do |fn|
1479
+ st.push(fn)
1480
+ @reachable_functions << fn
1481
+ bar.advance if show_progress
1482
+ st.pop
1483
+ end
1484
+ st.release
1485
+
1486
+ @reachable_functions.uniq!
1487
+ @reachable_functions
1488
+ end
1489
+
1490
+ # Given an adoc string, find names of CSR/Instruction/Extension enclosed in `monospace`
1491
+ # and replace them with links to the relevant object page.
1492
+ # See backend_helpers.rb for a definition of the proprietary link format.
1493
+ #
1494
+ # @param adoc [String] Asciidoc source
1495
+ # @return [String] Asciidoc source, with link placeholders
1496
+ sig { params(adoc: String).returns(String) }
1497
+ def convert_monospace_to_links(adoc)
1498
+ h = Class.new do include Udb::Helpers::TemplateHelpers end.new
1499
+ adoc.gsub(/`([\w.]+)`/) do |match|
1500
+ name = Regexp.last_match(1)
1501
+ csr_name, field_name = T.must(name).split(".")
1502
+ csr = not_prohibited_csrs.find { |c| c.name == csr_name }
1503
+ if !field_name.nil? && !csr.nil? && csr.field?(field_name)
1504
+ h.link_to_udb_doc_csr_field(csr_name, field_name)
1505
+ elsif !csr.nil?
1506
+ h.link_to_udb_doc_csr(csr_name)
1507
+ elsif not_prohibited_instructions.any? { |inst| inst.name == name }
1508
+ h.link_to_udb_doc_inst(name)
1509
+ elsif not_prohibited_extensions.any? { |ext| ext.name == name }
1510
+ h.link_to_udb_doc_ext(name)
1511
+ else
1512
+ match
1513
+ end
1514
+ end
1515
+ end
1516
+
1517
+ # Returns an environment hash suitable for use with ERb templates.
1518
+ #
1519
+ # This method returns a hash containing the architecture definition and other
1520
+ # relevant data that can be used to generate ERb templates.
1521
+ #
1522
+ # @return [Hash] An environment hash suitable for use with ERb templates.
1523
+ sig { returns(Object) }
1524
+ def erb_env
1525
+ return @env unless @env.nil?
1526
+
1527
+ @env = Class.new
1528
+ @env.extend T::Sig
1529
+ @env.instance_variable_set(:@cfg, @cfg)
1530
+ @env.instance_variable_set(:@params, @params)
1531
+ @env.instance_variable_set(:@cfg_arch, self)
1532
+ @env.instance_variable_set(:@arch, self) # For backwards-compatibility
1533
+
1534
+ # add each parameter, either as a method (lowercase) or constant (uppercase)
1535
+ params_with_value.each do |param|
1536
+ @env.const_set(param.name, param.value) unless @env.const_defined?(param.name)
1537
+ end
1538
+
1539
+ params_without_value.each do |param|
1540
+ @env.const_set(param.name, :unknown) unless @env.const_defined?(param.name)
1541
+ end
1542
+
1543
+ @env.instance_exec do
1544
+ # method to check if a given extension (with an optional version number) is present
1545
+ #
1546
+ # @param ext_name [String,#to_s] Name of the extension
1547
+ # @param ext_requirement [String, #to_s] Version string, as a Gem Requirement (https://guides.rubygems.org/patterns/#pessimistic-version-constraint)
1548
+ # @return [Boolean] whether or not extension +ext_name+ meeting +ext_requirement+ is implemented in the config
1549
+ sig { params(ext_name: T.any(String, Symbol), ext_requirements: T.any(String, T::Array[String])).returns(T::Boolean) }
1550
+ def ext?(ext_name, ext_requirements = [])
1551
+ ext_reqs =
1552
+ case ext_requirements
1553
+ when Array
1554
+ ext_requirements
1555
+ when String
1556
+ [ext_requirements]
1557
+ else
1558
+ T.absurd(ext_requirements)
1559
+ end
1560
+ @cfg_arch.ext?(ext_name.to_s, ext_reqs)
1561
+ end
1562
+
1563
+ # List of possible XLENs for any implemented mode
1564
+ sig { returns(T::Array[Integer]) }
1565
+ def possible_xlens
1566
+ @cfg_arch.possible_xlens
1567
+ end
1568
+
1569
+ # @returns [Hash<Integer, String>] architecturally-defined exception codes and their names
1570
+ def implemented_exception_codes
1571
+ @cfg_arch.implemented_exception_codes
1572
+ end
1573
+
1574
+ # returns [Hash<Integer, String>] architecturally-defined interrupt codes and their names
1575
+ def implemented_interrupt_codes
1576
+ @cfg_arch.implemented_interrupt_codes
1577
+ end
1578
+ end
1579
+
1580
+ @env
1581
+ end
1582
+ private :erb_env
1583
+
1584
+ # passes _erb_template_ through ERB within the content of this config
1585
+ #
1586
+ # @param erb_template [String] ERB source
1587
+ # @return [String] The rendered text
1588
+ sig { params(erb_template: String, what: String).returns(String) }
1589
+ def render_erb(erb_template, what = "")
1590
+ t = Tempfile.new("template")
1591
+ t.write erb_template
1592
+ t.flush
1593
+ begin
1594
+ Tilt["erb"].new(t.path, trim: "-").render(erb_env)
1595
+ rescue
1596
+ Udb.logger.error "While rendering ERB template: #{what}"
1597
+ raise
1598
+ ensure
1599
+ t.close
1600
+ t.unlink
1601
+ end
1602
+ end
1603
+
1604
+
1605
+ # @return [Array<NonIsaSpecification>] List of all non-ISA specs that could apply to this configuration
1606
+ sig { returns(T::Array[T.untyped]) }
1607
+ def possible_non_isa_specs
1608
+ return @possible_non_isa_specs if defined?(@possible_non_isa_specs)
1609
+
1610
+
1611
+
1612
+ @possible_non_isa_specs = []
1613
+
1614
+ # Discover local non-ISA specifications
1615
+ non_isa_path = Pathname.new(__dir__).parent.parent.parent.parent.parent / "spec/custom/non_isa"
1616
+ if non_isa_path.exist?
1617
+ non_isa_path.glob("*.yaml").each do |spec_file|
1618
+ next if spec_file.basename.to_s.start_with?("prm") # Skip PRM files
1619
+
1620
+ begin
1621
+ spec_name = spec_file.basename(".yaml").to_s
1622
+ spec_data = YAML.load_file(spec_file)
1623
+ next unless spec_data["kind"] == "non-isa specification"
1624
+
1625
+ spec_obj = Udb::NonIsaSpecification.new(spec_name, spec_data)
1626
+ @possible_non_isa_specs << spec_obj
1627
+ rescue => e
1628
+ Udb.logger.warn "Failed to load non-ISA spec #{spec_file}: #{e.message}"
1629
+ end
1630
+ end
1631
+ end
1632
+
1633
+ @possible_non_isa_specs.sort_by(&:name)
1634
+ end
1635
+
1636
+ # @return [Array<NonIsaSpecification>] List of all implemented non-ISA specs, filtered by configuration
1637
+ sig { returns(T::Array[T.untyped]) }
1638
+ def implemented_non_isa_specs
1639
+ return @implemented_non_isa_specs if defined?(@implemented_non_isa_specs)
1640
+
1641
+ @implemented_non_isa_specs = possible_non_isa_specs.select do |spec|
1642
+ spec.exists_in_cfg?(self)
1643
+ end
1644
+
1645
+ @implemented_non_isa_specs
1646
+ end
1647
+
1648
+ # @deprecated in favor of #implemented_non_isa_specs
1649
+ def transitive_implemented_non_isa_specs = implemented_non_isa_specs
1650
+
1651
+ # Given an adoc string, find names of CSR/Instruction/Extension enclosed in `monospace`
1652
+ # and replace them with links to the relevant object page.
1653
+ # See backend_helpers.rb for a definition of the proprietary link format.
1654
+ #
1655
+ # @param adoc [String] Asciidoc source
1656
+ # @return [String] Asciidoc source, with link placeholders
1657
+ sig { params(adoc: String).returns(String) }
1658
+ def convert_monospace_to_links(adoc)
1659
+ h = Class.new do include Udb::Helpers::TemplateHelpers end.new
1660
+ adoc.gsub(/`([\w.]+)`/) do |match|
1661
+ name = Regexp.last_match(1)
1662
+ csr_name, field_name = T.must(name).split(".")
1663
+ csr = not_prohibited_csrs.find { |c| c.name == csr_name }
1664
+ if !field_name.nil? && !csr.nil? && csr.field?(field_name)
1665
+ h.link_to_udb_doc_csr_field(csr_name, field_name)
1666
+ elsif !csr.nil?
1667
+ h.link_to_udb_doc_csr(csr_name)
1668
+ elsif not_prohibited_instructions.any? { |inst| inst.name == name }
1669
+ h.link_to_udb_doc_inst(name)
1670
+ elsif not_prohibited_extensions.any? { |ext| ext.name == name }
1671
+ h.link_to_udb_doc_ext(name)
1672
+ else
1673
+ match
1674
+ end
1675
+ end
1676
+ end
1677
+
1678
+ end
1679
+ end