wasmtime 9.0.4 → 10.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1933) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +184 -101
  3. data/ext/Cargo.toml +6 -6
  4. data/ext/build.rs +2 -2
  5. data/ext/cargo-vendor/cranelift-bforest-0.97.1/.cargo-checksum.json +1 -0
  6. data/ext/cargo-vendor/cranelift-bforest-0.97.1/Cargo.toml +31 -0
  7. data/ext/cargo-vendor/cranelift-codegen-0.97.1/.cargo-checksum.json +1 -0
  8. data/ext/cargo-vendor/cranelift-codegen-0.97.1/Cargo.toml +158 -0
  9. data/ext/cargo-vendor/cranelift-codegen-0.97.1/benches/x64-evex-encoding.rs +52 -0
  10. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/ir/trapcode.rs +144 -0
  11. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/abi.rs +1294 -0
  12. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/inst/emit.rs +3684 -0
  13. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/inst/emit_tests.rs +7895 -0
  14. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/inst/imms.rs +1210 -0
  15. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/inst/mod.rs +2966 -0
  16. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/inst.isle +4037 -0
  17. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/lower/isle.rs +816 -0
  18. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/lower.isle +2906 -0
  19. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/aarch64/mod.rs +238 -0
  20. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/mod.rs +424 -0
  21. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/abi.rs +825 -0
  22. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/args.rs +1812 -0
  23. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/emit.rs +3008 -0
  24. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/emit_tests.rs +2338 -0
  25. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/encode.rs +262 -0
  26. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/imms.rs +250 -0
  27. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/mod.rs +1963 -0
  28. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/regs.rs +223 -0
  29. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/unwind/systemv.rs +174 -0
  30. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst/vector.rs +669 -0
  31. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst.isle +2915 -0
  32. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/inst_vector.isle +760 -0
  33. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/lower/isle.rs +553 -0
  34. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/lower.isle +1409 -0
  35. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/riscv64/mod.rs +216 -0
  36. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/s390x/abi.rs +957 -0
  37. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/s390x/inst/emit.rs +3707 -0
  38. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/s390x/inst/emit_tests.rs +13409 -0
  39. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/s390x/inst/mod.rs +3426 -0
  40. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/s390x/inst.isle +5046 -0
  41. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/s390x/lower.isle +3991 -0
  42. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/s390x/mod.rs +213 -0
  43. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/abi.rs +985 -0
  44. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/encoding/evex.rs +749 -0
  45. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/encoding/rex.rs +588 -0
  46. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/encoding/vex.rs +492 -0
  47. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/inst/args.rs +2193 -0
  48. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/inst/emit.rs +4090 -0
  49. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/inst/emit_tests.rs +5674 -0
  50. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/inst/mod.rs +2667 -0
  51. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/inst.isle +5104 -0
  52. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/lower/isle.rs +1148 -0
  53. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/lower.isle +4481 -0
  54. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/lower.rs +328 -0
  55. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isa/x64/mod.rs +251 -0
  56. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/isle_prelude.rs +862 -0
  57. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/abi.rs +2455 -0
  58. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/buffer.rs +2277 -0
  59. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/compile.rs +92 -0
  60. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/isle.rs +827 -0
  61. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/lower.rs +1388 -0
  62. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/mod.rs +549 -0
  63. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/reg.rs +537 -0
  64. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/machinst/vcode.rs +1580 -0
  65. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/prelude.isle +578 -0
  66. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/prelude_lower.isle +1012 -0
  67. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/settings.rs +600 -0
  68. data/ext/cargo-vendor/cranelift-codegen-0.97.1/src/verifier/mod.rs +1884 -0
  69. data/ext/cargo-vendor/cranelift-codegen-meta-0.97.1/.cargo-checksum.json +1 -0
  70. data/ext/cargo-vendor/cranelift-codegen-meta-0.97.1/Cargo.toml +23 -0
  71. data/ext/cargo-vendor/cranelift-codegen-meta-0.97.1/src/isa/x86.rs +444 -0
  72. data/ext/cargo-vendor/cranelift-codegen-meta-0.97.1/src/shared/settings.rs +348 -0
  73. data/ext/cargo-vendor/cranelift-codegen-shared-0.97.1/.cargo-checksum.json +1 -0
  74. data/ext/cargo-vendor/cranelift-codegen-shared-0.97.1/Cargo.toml +22 -0
  75. data/ext/cargo-vendor/cranelift-control-0.97.1/.cargo-checksum.json +1 -0
  76. data/ext/cargo-vendor/cranelift-control-0.97.1/Cargo.toml +30 -0
  77. data/ext/cargo-vendor/cranelift-control-0.97.1/src/chaos.rs +125 -0
  78. data/ext/cargo-vendor/cranelift-control-0.97.1/src/lib.rs +45 -0
  79. data/ext/cargo-vendor/cranelift-control-0.97.1/src/zero_sized.rs +53 -0
  80. data/ext/cargo-vendor/cranelift-entity-0.97.1/.cargo-checksum.json +1 -0
  81. data/ext/cargo-vendor/cranelift-entity-0.97.1/Cargo.toml +35 -0
  82. data/ext/cargo-vendor/cranelift-entity-0.97.1/src/list.rs +955 -0
  83. data/ext/cargo-vendor/cranelift-frontend-0.97.1/.cargo-checksum.json +1 -0
  84. data/ext/cargo-vendor/cranelift-frontend-0.97.1/Cargo.toml +53 -0
  85. data/ext/cargo-vendor/cranelift-isle-0.97.1/.cargo-checksum.json +1 -0
  86. data/ext/cargo-vendor/cranelift-isle-0.97.1/Cargo.toml +37 -0
  87. data/ext/cargo-vendor/cranelift-native-0.97.1/.cargo-checksum.json +1 -0
  88. data/ext/cargo-vendor/cranelift-native-0.97.1/Cargo.toml +38 -0
  89. data/ext/cargo-vendor/cranelift-native-0.97.1/src/lib.rs +215 -0
  90. data/ext/cargo-vendor/cranelift-wasm-0.97.1/.cargo-checksum.json +1 -0
  91. data/ext/cargo-vendor/cranelift-wasm-0.97.1/Cargo.toml +85 -0
  92. data/ext/cargo-vendor/cranelift-wasm-0.97.1/src/code_translator.rs +3538 -0
  93. data/ext/cargo-vendor/cranelift-wasm-0.97.1/src/environ/dummy.rs +924 -0
  94. data/ext/cargo-vendor/cranelift-wasm-0.97.1/src/environ/spec.rs +834 -0
  95. data/ext/cargo-vendor/cranelift-wasm-0.97.1/src/func_translator.rs +440 -0
  96. data/ext/cargo-vendor/cranelift-wasm-0.97.1/src/sections_translator.rs +417 -0
  97. data/ext/cargo-vendor/cranelift-wasm-0.97.1/src/translation_utils.rs +99 -0
  98. data/ext/cargo-vendor/encoding_rs-0.8.32/.cargo-checksum.json +1 -0
  99. data/ext/cargo-vendor/encoding_rs-0.8.32/CONTRIBUTING.md +48 -0
  100. data/ext/cargo-vendor/encoding_rs-0.8.32/COPYRIGHT +17 -0
  101. data/ext/cargo-vendor/encoding_rs-0.8.32/Cargo.toml +84 -0
  102. data/ext/cargo-vendor/encoding_rs-0.8.32/Ideas.md +106 -0
  103. data/ext/cargo-vendor/encoding_rs-0.8.32/LICENSE-APACHE +202 -0
  104. data/ext/cargo-vendor/encoding_rs-0.8.32/LICENSE-MIT +25 -0
  105. data/ext/cargo-vendor/encoding_rs-0.8.32/LICENSE-WHATWG +26 -0
  106. data/ext/cargo-vendor/encoding_rs-0.8.32/README.md +827 -0
  107. data/ext/cargo-vendor/encoding_rs-0.8.32/ci/miri.sh +14 -0
  108. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/Big5.txt +16 -0
  109. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/EUC-JP.txt +12 -0
  110. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/EUC-KR.txt +10 -0
  111. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/GBK.txt +16 -0
  112. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/IBM866.txt +8 -0
  113. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-2022-JP.txt +10 -0
  114. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-10.txt +8 -0
  115. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-13.txt +8 -0
  116. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-14.txt +8 -0
  117. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-15.txt +7 -0
  118. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-16.txt +8 -0
  119. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-2.txt +6 -0
  120. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-3.txt +6 -0
  121. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-4.txt +6 -0
  122. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-5.txt +6 -0
  123. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-6.txt +7 -0
  124. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-7.txt +11 -0
  125. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-8-I.txt +9 -0
  126. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/ISO-8859-8.txt +9 -0
  127. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/KOI8-R.txt +6 -0
  128. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/KOI8-U.txt +6 -0
  129. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/Shift_JIS.txt +8 -0
  130. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/UTF-16BE.txt +8 -0
  131. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/UTF-16LE.txt +8 -0
  132. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/UTF-8.txt +5 -0
  133. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/gb18030.txt +9 -0
  134. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/macintosh.txt +7 -0
  135. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/replacement.txt +10 -0
  136. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1250.txt +6 -0
  137. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1251.txt +6 -0
  138. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1252.txt +7 -0
  139. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1253.txt +8 -0
  140. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1254.txt +7 -0
  141. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1255.txt +8 -0
  142. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1256.txt +6 -0
  143. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1257.txt +7 -0
  144. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-1258.txt +11 -0
  145. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/windows-874.txt +7 -0
  146. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/x-mac-cyrillic.txt +6 -0
  147. data/ext/cargo-vendor/encoding_rs-0.8.32/doc/x-user-defined.txt +6 -0
  148. data/ext/cargo-vendor/encoding_rs-0.8.32/generate-encoding-data.py +2008 -0
  149. data/ext/cargo-vendor/encoding_rs-0.8.32/rustfmt.toml +1 -0
  150. data/ext/cargo-vendor/encoding_rs-0.8.32/src/ascii.rs +1546 -0
  151. data/ext/cargo-vendor/encoding_rs-0.8.32/src/big5.rs +427 -0
  152. data/ext/cargo-vendor/encoding_rs-0.8.32/src/data.rs +114378 -0
  153. data/ext/cargo-vendor/encoding_rs-0.8.32/src/euc_jp.rs +469 -0
  154. data/ext/cargo-vendor/encoding_rs-0.8.32/src/euc_kr.rs +442 -0
  155. data/ext/cargo-vendor/encoding_rs-0.8.32/src/gb18030.rs +767 -0
  156. data/ext/cargo-vendor/encoding_rs-0.8.32/src/handles.rs +1969 -0
  157. data/ext/cargo-vendor/encoding_rs-0.8.32/src/iso_2022_jp.rs +1068 -0
  158. data/ext/cargo-vendor/encoding_rs-0.8.32/src/lib.rs +6133 -0
  159. data/ext/cargo-vendor/encoding_rs-0.8.32/src/macros.rs +1622 -0
  160. data/ext/cargo-vendor/encoding_rs-0.8.32/src/mem.rs +3354 -0
  161. data/ext/cargo-vendor/encoding_rs-0.8.32/src/replacement.rs +104 -0
  162. data/ext/cargo-vendor/encoding_rs-0.8.32/src/shift_jis.rs +426 -0
  163. data/ext/cargo-vendor/encoding_rs-0.8.32/src/simd_funcs.rs +453 -0
  164. data/ext/cargo-vendor/encoding_rs-0.8.32/src/single_byte.rs +714 -0
  165. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/big5_in.txt +19787 -0
  166. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/big5_in_ref.txt +19787 -0
  167. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/big5_out.txt +14601 -0
  168. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/big5_out_ref.txt +14601 -0
  169. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/euc_kr_in.txt +23945 -0
  170. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/euc_kr_in_ref.txt +23945 -0
  171. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/euc_kr_out.txt +17053 -0
  172. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/euc_kr_out_ref.txt +17053 -0
  173. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/gb18030_in.txt +23945 -0
  174. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/gb18030_in_ref.txt +23945 -0
  175. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/gb18030_out.txt +23944 -0
  176. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/gb18030_out_ref.txt +23944 -0
  177. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/iso_2022_jp_in.txt +8841 -0
  178. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/iso_2022_jp_in_ref.txt +8841 -0
  179. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/iso_2022_jp_out.txt +7404 -0
  180. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/iso_2022_jp_out_ref.txt +7404 -0
  181. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/jis0208_in.txt +8841 -0
  182. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/jis0208_in_ref.txt +8841 -0
  183. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/jis0208_out.txt +7341 -0
  184. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/jis0208_out_ref.txt +7341 -0
  185. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/jis0212_in.txt +8841 -0
  186. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/jis0212_in_ref.txt +8841 -0
  187. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/shift_jis_in.txt +11285 -0
  188. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/shift_jis_in_ref.txt +11285 -0
  189. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/shift_jis_out.txt +7355 -0
  190. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_data/shift_jis_out_ref.txt +7355 -0
  191. data/ext/cargo-vendor/encoding_rs-0.8.32/src/test_labels_names.rs +242 -0
  192. data/ext/cargo-vendor/encoding_rs-0.8.32/src/testing.rs +262 -0
  193. data/ext/cargo-vendor/encoding_rs-0.8.32/src/utf_16.rs +472 -0
  194. data/ext/cargo-vendor/encoding_rs-0.8.32/src/utf_8.rs +1629 -0
  195. data/ext/cargo-vendor/encoding_rs-0.8.32/src/variant.rs +400 -0
  196. data/ext/cargo-vendor/encoding_rs-0.8.32/src/x_user_defined.rs +249 -0
  197. data/ext/cargo-vendor/equivalent-1.0.1/.cargo-checksum.json +1 -0
  198. data/ext/cargo-vendor/equivalent-1.0.1/Cargo.toml +27 -0
  199. data/ext/cargo-vendor/equivalent-1.0.1/LICENSE-APACHE +201 -0
  200. data/ext/cargo-vendor/equivalent-1.0.1/LICENSE-MIT +25 -0
  201. data/ext/cargo-vendor/equivalent-1.0.1/README.md +25 -0
  202. data/ext/cargo-vendor/equivalent-1.0.1/src/lib.rs +113 -0
  203. data/ext/cargo-vendor/file-per-thread-logger-0.2.0/.cargo-checksum.json +1 -0
  204. data/ext/cargo-vendor/file-per-thread-logger-0.2.0/Cargo.toml +36 -0
  205. data/ext/cargo-vendor/file-per-thread-logger-0.2.0/run-tests.sh +12 -0
  206. data/ext/cargo-vendor/file-per-thread-logger-0.2.0/src/lib.rs +200 -0
  207. data/ext/cargo-vendor/file-per-thread-logger-0.2.0/tests/test.rs +323 -0
  208. data/ext/cargo-vendor/hashbrown-0.14.0/.cargo-checksum.json +1 -0
  209. data/ext/cargo-vendor/hashbrown-0.14.0/CHANGELOG.md +475 -0
  210. data/ext/cargo-vendor/hashbrown-0.14.0/Cargo.toml +131 -0
  211. data/ext/cargo-vendor/hashbrown-0.14.0/LICENSE-APACHE +201 -0
  212. data/ext/cargo-vendor/hashbrown-0.14.0/LICENSE-MIT +25 -0
  213. data/ext/cargo-vendor/hashbrown-0.14.0/README.md +125 -0
  214. data/ext/cargo-vendor/hashbrown-0.14.0/benches/bench.rs +331 -0
  215. data/ext/cargo-vendor/hashbrown-0.14.0/benches/insert_unique_unchecked.rs +32 -0
  216. data/ext/cargo-vendor/hashbrown-0.14.0/clippy.toml +1 -0
  217. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/mod.rs +6 -0
  218. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rayon/helpers.rs +27 -0
  219. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rayon/map.rs +731 -0
  220. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rayon/mod.rs +4 -0
  221. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rayon/raw.rs +231 -0
  222. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rayon/set.rs +659 -0
  223. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rkyv/hash_map.rs +125 -0
  224. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rkyv/hash_set.rs +123 -0
  225. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/rkyv/mod.rs +2 -0
  226. data/ext/cargo-vendor/hashbrown-0.14.0/src/external_trait_impls/serde.rs +201 -0
  227. data/ext/cargo-vendor/hashbrown-0.14.0/src/lib.rs +165 -0
  228. data/ext/cargo-vendor/hashbrown-0.14.0/src/macros.rs +70 -0
  229. data/ext/cargo-vendor/hashbrown-0.14.0/src/map.rs +8506 -0
  230. data/ext/cargo-vendor/hashbrown-0.14.0/src/raw/alloc.rs +86 -0
  231. data/ext/cargo-vendor/hashbrown-0.14.0/src/raw/bitmask.rs +133 -0
  232. data/ext/cargo-vendor/hashbrown-0.14.0/src/raw/generic.rs +157 -0
  233. data/ext/cargo-vendor/hashbrown-0.14.0/src/raw/mod.rs +3378 -0
  234. data/ext/cargo-vendor/hashbrown-0.14.0/src/raw/neon.rs +124 -0
  235. data/ext/cargo-vendor/hashbrown-0.14.0/src/raw/sse2.rs +149 -0
  236. data/ext/cargo-vendor/hashbrown-0.14.0/src/rustc_entry.rs +630 -0
  237. data/ext/cargo-vendor/hashbrown-0.14.0/src/scopeguard.rs +72 -0
  238. data/ext/cargo-vendor/hashbrown-0.14.0/src/set.rs +2903 -0
  239. data/ext/cargo-vendor/hashbrown-0.14.0/tests/equivalent_trait.rs +53 -0
  240. data/ext/cargo-vendor/hashbrown-0.14.0/tests/hasher.rs +65 -0
  241. data/ext/cargo-vendor/hashbrown-0.14.0/tests/raw.rs +11 -0
  242. data/ext/cargo-vendor/hashbrown-0.14.0/tests/rayon.rs +535 -0
  243. data/ext/cargo-vendor/hashbrown-0.14.0/tests/serde.rs +65 -0
  244. data/ext/cargo-vendor/hashbrown-0.14.0/tests/set.rs +34 -0
  245. data/ext/cargo-vendor/indexmap-2.0.0/.cargo-checksum.json +1 -0
  246. data/ext/cargo-vendor/indexmap-2.0.0/Cargo.toml +112 -0
  247. data/ext/cargo-vendor/indexmap-2.0.0/LICENSE-APACHE +201 -0
  248. data/ext/cargo-vendor/indexmap-2.0.0/LICENSE-MIT +25 -0
  249. data/ext/cargo-vendor/indexmap-2.0.0/README.md +55 -0
  250. data/ext/cargo-vendor/indexmap-2.0.0/RELEASES.md +424 -0
  251. data/ext/cargo-vendor/indexmap-2.0.0/benches/bench.rs +763 -0
  252. data/ext/cargo-vendor/indexmap-2.0.0/benches/faststring.rs +185 -0
  253. data/ext/cargo-vendor/indexmap-2.0.0/src/arbitrary.rs +77 -0
  254. data/ext/cargo-vendor/indexmap-2.0.0/src/lib.rs +278 -0
  255. data/ext/cargo-vendor/indexmap-2.0.0/src/macros.rs +178 -0
  256. data/ext/cargo-vendor/indexmap-2.0.0/src/map/core/raw.rs +217 -0
  257. data/ext/cargo-vendor/indexmap-2.0.0/src/map/core.rs +742 -0
  258. data/ext/cargo-vendor/indexmap-2.0.0/src/map/iter.rs +541 -0
  259. data/ext/cargo-vendor/indexmap-2.0.0/src/map/serde_seq.rs +138 -0
  260. data/ext/cargo-vendor/indexmap-2.0.0/src/map/slice.rs +471 -0
  261. data/ext/cargo-vendor/indexmap-2.0.0/src/map/tests.rs +449 -0
  262. data/ext/cargo-vendor/indexmap-2.0.0/src/map.rs +1223 -0
  263. data/ext/cargo-vendor/indexmap-2.0.0/src/mutable_keys.rs +91 -0
  264. data/ext/cargo-vendor/indexmap-2.0.0/src/rayon/map.rs +679 -0
  265. data/ext/cargo-vendor/indexmap-2.0.0/src/rayon/mod.rs +27 -0
  266. data/ext/cargo-vendor/indexmap-2.0.0/src/rayon/set.rs +774 -0
  267. data/ext/cargo-vendor/indexmap-2.0.0/src/rustc.rs +158 -0
  268. data/ext/cargo-vendor/indexmap-2.0.0/src/serde.rs +151 -0
  269. data/ext/cargo-vendor/indexmap-2.0.0/src/set/iter.rs +543 -0
  270. data/ext/cargo-vendor/indexmap-2.0.0/src/set/slice.rs +278 -0
  271. data/ext/cargo-vendor/indexmap-2.0.0/src/set/tests.rs +545 -0
  272. data/ext/cargo-vendor/indexmap-2.0.0/src/set.rs +1011 -0
  273. data/ext/cargo-vendor/indexmap-2.0.0/src/util.rs +53 -0
  274. data/ext/cargo-vendor/indexmap-2.0.0/tests/equivalent_trait.rs +53 -0
  275. data/ext/cargo-vendor/indexmap-2.0.0/tests/macros_full_path.rs +19 -0
  276. data/ext/cargo-vendor/indexmap-2.0.0/tests/quick.rs +579 -0
  277. data/ext/cargo-vendor/indexmap-2.0.0/tests/tests.rs +28 -0
  278. data/ext/cargo-vendor/regalloc2-0.9.2/.cargo-checksum.json +1 -0
  279. data/ext/cargo-vendor/regalloc2-0.9.2/Cargo.toml +72 -0
  280. data/ext/cargo-vendor/regalloc2-0.9.2/deny.toml +28 -0
  281. data/ext/cargo-vendor/regalloc2-0.9.2/src/checker.rs +1089 -0
  282. data/ext/cargo-vendor/regalloc2-0.9.2/src/fuzzing/func.rs +702 -0
  283. data/ext/cargo-vendor/regalloc2-0.9.2/src/index.rs +268 -0
  284. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/data_structures.rs +857 -0
  285. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/liveranges.rs +961 -0
  286. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/merge.rs +368 -0
  287. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/mod.rs +150 -0
  288. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/moves.rs +1017 -0
  289. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/process.rs +1307 -0
  290. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/requirement.rs +174 -0
  291. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/spill.rs +165 -0
  292. data/ext/cargo-vendor/regalloc2-0.9.2/src/ion/stackmap.rs +79 -0
  293. data/ext/cargo-vendor/regalloc2-0.9.2/src/lib.rs +1526 -0
  294. data/ext/cargo-vendor/regalloc2-0.9.2/src/moves.rs +439 -0
  295. data/ext/cargo-vendor/regalloc2-0.9.2/src/serialize.rs +311 -0
  296. data/ext/cargo-vendor/semver-1.0.18/.cargo-checksum.json +1 -0
  297. data/ext/cargo-vendor/semver-1.0.18/Cargo.toml +47 -0
  298. data/ext/cargo-vendor/semver-1.0.18/LICENSE-APACHE +176 -0
  299. data/ext/cargo-vendor/semver-1.0.18/LICENSE-MIT +23 -0
  300. data/ext/cargo-vendor/semver-1.0.18/README.md +84 -0
  301. data/ext/cargo-vendor/semver-1.0.18/benches/parse.rs +24 -0
  302. data/ext/cargo-vendor/semver-1.0.18/build.rs +75 -0
  303. data/ext/cargo-vendor/semver-1.0.18/src/backport.rs +23 -0
  304. data/ext/cargo-vendor/semver-1.0.18/src/display.rs +165 -0
  305. data/ext/cargo-vendor/semver-1.0.18/src/error.rs +126 -0
  306. data/ext/cargo-vendor/semver-1.0.18/src/eval.rs +181 -0
  307. data/ext/cargo-vendor/semver-1.0.18/src/identifier.rs +422 -0
  308. data/ext/cargo-vendor/semver-1.0.18/src/impls.rs +156 -0
  309. data/ext/cargo-vendor/semver-1.0.18/src/lib.rs +533 -0
  310. data/ext/cargo-vendor/semver-1.0.18/src/parse.rs +409 -0
  311. data/ext/cargo-vendor/semver-1.0.18/src/serde.rs +109 -0
  312. data/ext/cargo-vendor/semver-1.0.18/tests/node/mod.rs +43 -0
  313. data/ext/cargo-vendor/semver-1.0.18/tests/test_autotrait.rs +14 -0
  314. data/ext/cargo-vendor/semver-1.0.18/tests/test_identifier.rs +45 -0
  315. data/ext/cargo-vendor/semver-1.0.18/tests/test_version.rs +238 -0
  316. data/ext/cargo-vendor/semver-1.0.18/tests/test_version_req.rs +443 -0
  317. data/ext/cargo-vendor/semver-1.0.18/tests/util/mod.rs +39 -0
  318. data/ext/cargo-vendor/sptr-0.3.2/.cargo-checksum.json +1 -0
  319. data/ext/cargo-vendor/sptr-0.3.2/Cargo.toml +28 -0
  320. data/ext/cargo-vendor/sptr-0.3.2/README.md +73 -0
  321. data/ext/cargo-vendor/sptr-0.3.2/src/func.rs +83 -0
  322. data/ext/cargo-vendor/sptr-0.3.2/src/int.rs +364 -0
  323. data/ext/cargo-vendor/sptr-0.3.2/src/lib.rs +756 -0
  324. data/ext/cargo-vendor/wasi-cap-std-sync-10.0.0/.cargo-checksum.json +1 -0
  325. data/ext/cargo-vendor/wasi-cap-std-sync-10.0.0/Cargo.toml +90 -0
  326. data/ext/cargo-vendor/wasi-cap-std-sync-10.0.0/src/dir.rs +464 -0
  327. data/ext/cargo-vendor/wasi-cap-std-sync-10.0.0/src/lib.rs +141 -0
  328. data/ext/cargo-vendor/wasi-common-10.0.0/.cargo-checksum.json +1 -0
  329. data/ext/cargo-vendor/wasi-common-10.0.0/Cargo.toml +87 -0
  330. data/ext/cargo-vendor/wasi-common-10.0.0/src/ctx.rs +128 -0
  331. data/ext/cargo-vendor/wasi-common-10.0.0/src/file.rs +262 -0
  332. data/ext/cargo-vendor/wasi-common-10.0.0/src/snapshots/preview_1.rs +1490 -0
  333. data/ext/cargo-vendor/wasm-encoder-0.29.0/.cargo-checksum.json +1 -0
  334. data/ext/cargo-vendor/wasm-encoder-0.29.0/Cargo.toml +33 -0
  335. data/ext/cargo-vendor/wasm-encoder-0.29.0/README.md +80 -0
  336. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/aliases.rs +160 -0
  337. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/canonicals.rs +159 -0
  338. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/components.rs +29 -0
  339. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/exports.rs +127 -0
  340. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/imports.rs +200 -0
  341. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/instances.rs +200 -0
  342. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/modules.rs +29 -0
  343. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/names.rs +149 -0
  344. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/start.rs +52 -0
  345. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component/types.rs +759 -0
  346. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/component.rs +160 -0
  347. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/code.rs +2913 -0
  348. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/custom.rs +55 -0
  349. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/data.rs +185 -0
  350. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/dump.rs +627 -0
  351. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/elements.rs +224 -0
  352. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/exports.rs +85 -0
  353. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/functions.rs +63 -0
  354. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/globals.rs +90 -0
  355. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/imports.rs +142 -0
  356. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/linking.rs +263 -0
  357. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/memories.rs +99 -0
  358. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/names.rs +265 -0
  359. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/producers.rs +180 -0
  360. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/start.rs +39 -0
  361. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/tables.rs +104 -0
  362. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/tags.rs +85 -0
  363. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core/types.rs +246 -0
  364. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/core.rs +168 -0
  365. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/lib.rs +215 -0
  366. data/ext/cargo-vendor/wasm-encoder-0.29.0/src/raw.rs +30 -0
  367. data/ext/cargo-vendor/wasmparser-0.107.0/.cargo-checksum.json +1 -0
  368. data/ext/cargo-vendor/wasmparser-0.107.0/Cargo.lock +621 -0
  369. data/ext/cargo-vendor/wasmparser-0.107.0/Cargo.toml +54 -0
  370. data/ext/cargo-vendor/wasmparser-0.107.0/benches/benchmark.rs +351 -0
  371. data/ext/cargo-vendor/wasmparser-0.107.0/src/binary_reader.rs +1706 -0
  372. data/ext/cargo-vendor/wasmparser-0.107.0/src/lib.rs +723 -0
  373. data/ext/cargo-vendor/wasmparser-0.107.0/src/parser.rs +1535 -0
  374. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/component/canonicals.rs +119 -0
  375. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/component/exports.rs +117 -0
  376. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/component/imports.rs +137 -0
  377. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/component/instances.rs +163 -0
  378. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/component/types.rs +548 -0
  379. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/core/coredumps.rs +243 -0
  380. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/core/producers.rs +83 -0
  381. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/core/types.rs +874 -0
  382. data/ext/cargo-vendor/wasmparser-0.107.0/src/readers/core.rs +35 -0
  383. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/component.rs +3082 -0
  384. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/core.rs +1334 -0
  385. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/names.rs +606 -0
  386. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/operators.rs +3463 -0
  387. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator/types.rs +3070 -0
  388. data/ext/cargo-vendor/wasmparser-0.107.0/src/validator.rs +1589 -0
  389. data/ext/cargo-vendor/wasmparser-0.111.0/.cargo-checksum.json +1 -0
  390. data/ext/cargo-vendor/wasmparser-0.111.0/Cargo.lock +644 -0
  391. data/ext/cargo-vendor/wasmparser-0.111.0/Cargo.toml +54 -0
  392. data/ext/cargo-vendor/wasmparser-0.111.0/README.md +36 -0
  393. data/ext/cargo-vendor/wasmparser-0.111.0/benches/benchmark.rs +349 -0
  394. data/ext/cargo-vendor/wasmparser-0.111.0/examples/simple.rs +37 -0
  395. data/ext/cargo-vendor/wasmparser-0.111.0/src/binary_reader.rs +1706 -0
  396. data/ext/cargo-vendor/wasmparser-0.111.0/src/lib.rs +726 -0
  397. data/ext/cargo-vendor/wasmparser-0.111.0/src/limits.rs +59 -0
  398. data/ext/cargo-vendor/wasmparser-0.111.0/src/parser.rs +1612 -0
  399. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/aliases.rs +119 -0
  400. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/canonicals.rs +120 -0
  401. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/exports.rs +117 -0
  402. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/imports.rs +137 -0
  403. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/instances.rs +163 -0
  404. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/names.rs +102 -0
  405. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/start.rs +30 -0
  406. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component/types.rs +548 -0
  407. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/component.rs +17 -0
  408. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/code.rs +146 -0
  409. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/coredumps.rs +243 -0
  410. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/custom.rs +63 -0
  411. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/data.rs +96 -0
  412. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/dylink0.rs +132 -0
  413. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/elements.rs +152 -0
  414. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/exports.rs +65 -0
  415. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/functions.rs +17 -0
  416. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/globals.rs +49 -0
  417. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/imports.rs +76 -0
  418. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/init.rs +51 -0
  419. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/memories.rs +56 -0
  420. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/names.rs +153 -0
  421. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/operators.rs +354 -0
  422. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/producers.rs +83 -0
  423. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/tables.rs +87 -0
  424. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/tags.rs +32 -0
  425. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core/types.rs +1141 -0
  426. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers/core.rs +37 -0
  427. data/ext/cargo-vendor/wasmparser-0.111.0/src/readers.rs +316 -0
  428. data/ext/cargo-vendor/wasmparser-0.111.0/src/resources.rs +398 -0
  429. data/ext/cargo-vendor/wasmparser-0.111.0/src/validator/component.rs +3148 -0
  430. data/ext/cargo-vendor/wasmparser-0.111.0/src/validator/core.rs +1314 -0
  431. data/ext/cargo-vendor/wasmparser-0.111.0/src/validator/func.rs +348 -0
  432. data/ext/cargo-vendor/wasmparser-0.111.0/src/validator/names.rs +606 -0
  433. data/ext/cargo-vendor/wasmparser-0.111.0/src/validator/operators.rs +3466 -0
  434. data/ext/cargo-vendor/wasmparser-0.111.0/src/validator/types.rs +3283 -0
  435. data/ext/cargo-vendor/wasmparser-0.111.0/src/validator.rs +1568 -0
  436. data/ext/cargo-vendor/wasmparser-0.111.0/tests/big-module.rs +33 -0
  437. data/ext/cargo-vendor/wasmprinter-0.2.63/.cargo-checksum.json +1 -0
  438. data/ext/cargo-vendor/wasmprinter-0.2.63/Cargo.toml +39 -0
  439. data/ext/cargo-vendor/wasmprinter-0.2.63/README.md +47 -0
  440. data/ext/cargo-vendor/wasmprinter-0.2.63/src/lib.rs +2962 -0
  441. data/ext/cargo-vendor/wasmprinter-0.2.63/src/operator.rs +873 -0
  442. data/ext/cargo-vendor/wasmprinter-0.2.63/tests/all.rs +278 -0
  443. data/ext/cargo-vendor/wasmtime-10.0.0/.cargo-checksum.json +1 -0
  444. data/ext/cargo-vendor/wasmtime-10.0.0/Cargo.toml +183 -0
  445. data/ext/cargo-vendor/wasmtime-10.0.0/src/compiler.rs +710 -0
  446. data/ext/cargo-vendor/wasmtime-10.0.0/src/component/component.rs +382 -0
  447. data/ext/cargo-vendor/wasmtime-10.0.0/src/component/instance.rs +727 -0
  448. data/ext/cargo-vendor/wasmtime-10.0.0/src/component/matching.rs +112 -0
  449. data/ext/cargo-vendor/wasmtime-10.0.0/src/component/mod.rs +313 -0
  450. data/ext/cargo-vendor/wasmtime-10.0.0/src/config.rs +2066 -0
  451. data/ext/cargo-vendor/wasmtime-10.0.0/src/engine/serialization.rs +622 -0
  452. data/ext/cargo-vendor/wasmtime-10.0.0/src/engine.rs +757 -0
  453. data/ext/cargo-vendor/wasmtime-10.0.0/src/externals.rs +763 -0
  454. data/ext/cargo-vendor/wasmtime-10.0.0/src/func/typed.rs +638 -0
  455. data/ext/cargo-vendor/wasmtime-10.0.0/src/func.rs +2355 -0
  456. data/ext/cargo-vendor/wasmtime-10.0.0/src/instance.rs +905 -0
  457. data/ext/cargo-vendor/wasmtime-10.0.0/src/lib.rs +486 -0
  458. data/ext/cargo-vendor/wasmtime-10.0.0/src/linker.rs +1479 -0
  459. data/ext/cargo-vendor/wasmtime-10.0.0/src/memory.rs +950 -0
  460. data/ext/cargo-vendor/wasmtime-10.0.0/src/module.rs +1274 -0
  461. data/ext/cargo-vendor/wasmtime-10.0.0/src/ref.rs +109 -0
  462. data/ext/cargo-vendor/wasmtime-10.0.0/src/store/context.rs +243 -0
  463. data/ext/cargo-vendor/wasmtime-10.0.0/src/store/func_refs.rs +85 -0
  464. data/ext/cargo-vendor/wasmtime-10.0.0/src/store.rs +2166 -0
  465. data/ext/cargo-vendor/wasmtime-10.0.0/src/trampoline/func.rs +133 -0
  466. data/ext/cargo-vendor/wasmtime-10.0.0/src/trampoline/global.rs +67 -0
  467. data/ext/cargo-vendor/wasmtime-10.0.0/src/types/matching.rs +312 -0
  468. data/ext/cargo-vendor/wasmtime-10.0.0/src/types.rs +572 -0
  469. data/ext/cargo-vendor/wasmtime-10.0.0/src/values.rs +290 -0
  470. data/ext/cargo-vendor/wasmtime-asm-macros-10.0.0/.cargo-checksum.json +1 -0
  471. data/ext/cargo-vendor/wasmtime-asm-macros-10.0.0/Cargo.toml +22 -0
  472. data/ext/cargo-vendor/wasmtime-cache-10.0.0/.cargo-checksum.json +1 -0
  473. data/ext/cargo-vendor/wasmtime-cache-10.0.0/Cargo.toml +73 -0
  474. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/.cargo-checksum.json +1 -0
  475. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/Cargo.toml +58 -0
  476. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/src/bindgen.rs +316 -0
  477. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/char.wit +13 -0
  478. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/conventions.wit +39 -0
  479. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/direct-import.wit +5 -0
  480. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/empty.wit +2 -0
  481. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/flags.wit +55 -0
  482. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/floats.wit +13 -0
  483. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/function-new.wit +4 -0
  484. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/integers.wit +40 -0
  485. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/lists.wit +85 -0
  486. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/many-arguments.wit +52 -0
  487. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/multi-return.wit +14 -0
  488. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/records.wit +61 -0
  489. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/rename.wit +16 -0
  490. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/share-types.wit +21 -0
  491. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/simple-functions.wit +17 -0
  492. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/simple-lists.wit +13 -0
  493. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/simple-wasi.wit +23 -0
  494. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/small-anonymous.wit +15 -0
  495. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/smoke-default.wit +5 -0
  496. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/smoke-export.wit +7 -0
  497. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/smoke.wit +7 -0
  498. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/strings.wit +12 -0
  499. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/unions.wit +66 -0
  500. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/use-paths.wit +29 -0
  501. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/variants.wit +147 -0
  502. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen/worlds-with-types.wit +16 -0
  503. data/ext/cargo-vendor/wasmtime-component-macro-10.0.0/tests/codegen.rs +24 -0
  504. data/ext/cargo-vendor/wasmtime-component-util-10.0.0/.cargo-checksum.json +1 -0
  505. data/ext/cargo-vendor/wasmtime-component-util-10.0.0/Cargo.toml +25 -0
  506. data/ext/cargo-vendor/wasmtime-cranelift-10.0.0/.cargo-checksum.json +1 -0
  507. data/ext/cargo-vendor/wasmtime-cranelift-10.0.0/Cargo.toml +90 -0
  508. data/ext/cargo-vendor/wasmtime-cranelift-10.0.0/src/compiler.rs +1200 -0
  509. data/ext/cargo-vendor/wasmtime-cranelift-10.0.0/src/debug/transform/simulate.rs +410 -0
  510. data/ext/cargo-vendor/wasmtime-cranelift-10.0.0/src/func_environ.rs +2206 -0
  511. data/ext/cargo-vendor/wasmtime-cranelift-10.0.0/src/lib.rs +178 -0
  512. data/ext/cargo-vendor/wasmtime-cranelift-shared-10.0.0/.cargo-checksum.json +1 -0
  513. data/ext/cargo-vendor/wasmtime-cranelift-shared-10.0.0/Cargo.toml +57 -0
  514. data/ext/cargo-vendor/wasmtime-cranelift-shared-10.0.0/src/lib.rs +120 -0
  515. data/ext/cargo-vendor/wasmtime-environ-10.0.0/.cargo-checksum.json +1 -0
  516. data/ext/cargo-vendor/wasmtime-environ-10.0.0/Cargo.lock +681 -0
  517. data/ext/cargo-vendor/wasmtime-environ-10.0.0/Cargo.toml +116 -0
  518. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/component/compiler.rs +84 -0
  519. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/component/translate/inline.rs +1067 -0
  520. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/component/translate.rs +1070 -0
  521. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/component/types.rs +1916 -0
  522. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/fact.rs +623 -0
  523. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/module.rs +1083 -0
  524. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/module_environ.rs +884 -0
  525. data/ext/cargo-vendor/wasmtime-environ-10.0.0/src/trap_encoding.rs +238 -0
  526. data/ext/cargo-vendor/wasmtime-fiber-10.0.0/.cargo-checksum.json +1 -0
  527. data/ext/cargo-vendor/wasmtime-fiber-10.0.0/Cargo.toml +46 -0
  528. data/ext/cargo-vendor/wasmtime-fiber-10.0.0/src/lib.rs +305 -0
  529. data/ext/cargo-vendor/wasmtime-fiber-10.0.0/src/unix.rs +212 -0
  530. data/ext/cargo-vendor/wasmtime-fiber-10.0.0/src/windows.rs +161 -0
  531. data/ext/cargo-vendor/wasmtime-jit-10.0.0/.cargo-checksum.json +1 -0
  532. data/ext/cargo-vendor/wasmtime-jit-10.0.0/Cargo.toml +104 -0
  533. data/ext/cargo-vendor/wasmtime-jit-10.0.0/src/instantiate.rs +760 -0
  534. data/ext/cargo-vendor/wasmtime-jit-10.0.0/src/lib.rs +38 -0
  535. data/ext/cargo-vendor/wasmtime-jit-10.0.0/src/profiling/jitdump.rs +66 -0
  536. data/ext/cargo-vendor/wasmtime-jit-10.0.0/src/profiling/perfmap.rs +47 -0
  537. data/ext/cargo-vendor/wasmtime-jit-10.0.0/src/profiling/vtune.rs +80 -0
  538. data/ext/cargo-vendor/wasmtime-jit-10.0.0/src/profiling.rs +108 -0
  539. data/ext/cargo-vendor/wasmtime-jit-debug-10.0.0/.cargo-checksum.json +1 -0
  540. data/ext/cargo-vendor/wasmtime-jit-debug-10.0.0/Cargo.toml +55 -0
  541. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-10.0.0/.cargo-checksum.json +1 -0
  542. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-10.0.0/Cargo.toml +37 -0
  543. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/.cargo-checksum.json +1 -0
  544. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/Cargo.toml +110 -0
  545. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/component.rs +701 -0
  546. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/cow.rs +1060 -0
  547. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/debug_builtins.rs +58 -0
  548. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/externref.rs +1073 -0
  549. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/instance/allocator/pooling.rs +1368 -0
  550. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/instance/allocator.rs +531 -0
  551. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/instance.rs +1345 -0
  552. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/lib.rs +285 -0
  553. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/libcalls.rs +578 -0
  554. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/memory.rs +958 -0
  555. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/mmap/miri.rs +94 -0
  556. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/mmap/unix.rs +148 -0
  557. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/mmap/windows.rs +208 -0
  558. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/send_sync_ptr.rs +69 -0
  559. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/table.rs +595 -0
  560. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/traphandlers/unix.rs +387 -0
  561. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/traphandlers.rs +749 -0
  562. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/vmcontext/vm_host_func_context.rs +137 -0
  563. data/ext/cargo-vendor/wasmtime-runtime-10.0.0/src/vmcontext.rs +1221 -0
  564. data/ext/cargo-vendor/wasmtime-types-10.0.1/.cargo-checksum.json +1 -0
  565. data/ext/cargo-vendor/wasmtime-types-10.0.1/Cargo.toml +34 -0
  566. data/ext/cargo-vendor/wasmtime-types-10.0.1/src/lib.rs +462 -0
  567. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/.cargo-checksum.json +1 -0
  568. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/Cargo.toml +153 -0
  569. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/lib.rs +130 -0
  570. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/clocks/host.rs +73 -0
  571. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/clocks.rs +17 -0
  572. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/ctx.rs +206 -0
  573. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/error.rs +16 -0
  574. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/filesystem.rs +269 -0
  575. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/mod.rs +44 -0
  576. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/pipe.rs +233 -0
  577. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview1/mod.rs +1860 -0
  578. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/clocks.rs +80 -0
  579. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/env.rs +48 -0
  580. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/exit.rs +12 -0
  581. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/filesystem.rs +1020 -0
  582. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/io.rs +215 -0
  583. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/mod.rs +7 -0
  584. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/poll.rs +84 -0
  585. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/preview2/random.rs +41 -0
  586. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/random.rs +58 -0
  587. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/sched/subscription.rs +104 -0
  588. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/sched/sync.rs +156 -0
  589. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/sched.rs +105 -0
  590. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/stdio.rs +176 -0
  591. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/stream.rs +210 -0
  592. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/table.rs +107 -0
  593. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/wasi/command.rs +43 -0
  594. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/src/preview2/wasi/mod.rs +30 -0
  595. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/clocks/monotonic-clock.wit +34 -0
  596. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/clocks/timezone.wit +63 -0
  597. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/clocks/wall-clock.wit +43 -0
  598. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/filesystem/filesystem.wit +782 -0
  599. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/http/incoming-handler.wit +24 -0
  600. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/http/outgoing-handler.wit +18 -0
  601. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/http/types.wit +159 -0
  602. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/io/streams.wit +215 -0
  603. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/logging/handler.wit +34 -0
  604. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/poll/poll.wit +41 -0
  605. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/preview/command-extended.wit +36 -0
  606. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/preview/command.wit +26 -0
  607. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/preview/proxy.wit +9 -0
  608. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/preview/reactor.wit +24 -0
  609. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/random/insecure-seed.wit +24 -0
  610. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/random/insecure.wit +21 -0
  611. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/random/random.wit +25 -0
  612. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/sockets/instance-network.wit +9 -0
  613. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/sockets/ip-name-lookup.wit +69 -0
  614. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/sockets/network.wit +187 -0
  615. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/sockets/tcp-create-socket.wit +27 -0
  616. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/sockets/tcp.wit +255 -0
  617. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/sockets/udp-create-socket.wit +27 -0
  618. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/sockets/udp.wit +211 -0
  619. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/wasi-cli-base/environment.wit +16 -0
  620. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/wasi-cli-base/exit.wit +4 -0
  621. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/wasi-cli-base/preopens.wit +7 -0
  622. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/deps/wasi-cli-base/stdio.wit +17 -0
  623. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/main.wit +1 -0
  624. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/wit/test.wit +19 -0
  625. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/witx/typenames.witx +750 -0
  626. data/ext/cargo-vendor/wasmtime-wasi-10.0.0/witx/wasi_snapshot_preview1.witx +521 -0
  627. data/ext/cargo-vendor/wasmtime-winch-10.0.0/.cargo-checksum.json +1 -0
  628. data/ext/cargo-vendor/wasmtime-winch-10.0.0/Cargo.toml +63 -0
  629. data/ext/cargo-vendor/wasmtime-winch-10.0.0/src/compiler.rs +220 -0
  630. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.0/.cargo-checksum.json +1 -0
  631. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.0/Cargo.toml +29 -0
  632. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.0/src/lib.rs +1631 -0
  633. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.0/src/types.rs +179 -0
  634. data/ext/cargo-vendor/wiggle-10.0.0/.cargo-checksum.json +1 -0
  635. data/ext/cargo-vendor/wiggle-10.0.0/Cargo.toml +106 -0
  636. data/ext/cargo-vendor/wiggle-10.0.0/LICENSE +220 -0
  637. data/ext/cargo-vendor/wiggle-10.0.0/README.md +18 -0
  638. data/ext/cargo-vendor/wiggle-generate-10.0.0/.cargo-checksum.json +1 -0
  639. data/ext/cargo-vendor/wiggle-generate-10.0.0/Cargo.toml +58 -0
  640. data/ext/cargo-vendor/wiggle-generate-10.0.0/LICENSE +220 -0
  641. data/ext/cargo-vendor/wiggle-macro-10.0.0/.cargo-checksum.json +1 -0
  642. data/ext/cargo-vendor/wiggle-macro-10.0.0/Cargo.toml +55 -0
  643. data/ext/cargo-vendor/wiggle-macro-10.0.0/LICENSE +220 -0
  644. data/ext/cargo-vendor/wiggle-macro-10.0.0/src/lib.rs +210 -0
  645. data/ext/cargo-vendor/winch-codegen-0.8.0/.cargo-checksum.json +1 -0
  646. data/ext/cargo-vendor/winch-codegen-0.8.0/Cargo.toml +62 -0
  647. data/ext/cargo-vendor/winch-codegen-0.8.0/src/abi/local.rs +70 -0
  648. data/ext/cargo-vendor/winch-codegen-0.8.0/src/abi/mod.rs +237 -0
  649. data/ext/cargo-vendor/winch-codegen-0.8.0/src/codegen/call.rs +225 -0
  650. data/ext/cargo-vendor/winch-codegen-0.8.0/src/codegen/context.rs +270 -0
  651. data/ext/cargo-vendor/winch-codegen-0.8.0/src/codegen/env.rs +52 -0
  652. data/ext/cargo-vendor/winch-codegen-0.8.0/src/codegen/mod.rs +214 -0
  653. data/ext/cargo-vendor/winch-codegen-0.8.0/src/frame/mod.rs +172 -0
  654. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/aarch64/abi.rs +243 -0
  655. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/aarch64/asm.rs +300 -0
  656. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/aarch64/masm.rs +230 -0
  657. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/aarch64/mod.rs +127 -0
  658. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/aarch64/regs.rs +166 -0
  659. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/mod.rs +215 -0
  660. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/x64/abi.rs +369 -0
  661. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/x64/address.rs +17 -0
  662. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/x64/asm.rs +576 -0
  663. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/x64/masm.rs +288 -0
  664. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/x64/mod.rs +149 -0
  665. data/ext/cargo-vendor/winch-codegen-0.8.0/src/isa/x64/regs.rs +192 -0
  666. data/ext/cargo-vendor/winch-codegen-0.8.0/src/lib.rs +21 -0
  667. data/ext/cargo-vendor/winch-codegen-0.8.0/src/masm.rs +255 -0
  668. data/ext/cargo-vendor/winch-codegen-0.8.0/src/regalloc.rs +70 -0
  669. data/ext/cargo-vendor/winch-codegen-0.8.0/src/stack.rs +235 -0
  670. data/ext/cargo-vendor/winch-codegen-0.8.0/src/trampoline.rs +494 -0
  671. data/ext/cargo-vendor/winch-codegen-0.8.0/src/visitor.rs +353 -0
  672. data/ext/cargo-vendor/wit-parser-0.8.0/.cargo-checksum.json +1 -0
  673. data/ext/cargo-vendor/wit-parser-0.8.0/Cargo.toml +62 -0
  674. data/ext/cargo-vendor/wit-parser-0.8.0/src/ast/lex.rs +679 -0
  675. data/ext/cargo-vendor/wit-parser-0.8.0/src/ast/resolve.rs +1122 -0
  676. data/ext/cargo-vendor/wit-parser-0.8.0/src/ast.rs +1207 -0
  677. data/ext/cargo-vendor/wit-parser-0.8.0/src/lib.rs +622 -0
  678. data/ext/cargo-vendor/wit-parser-0.8.0/src/live.rs +111 -0
  679. data/ext/cargo-vendor/wit-parser-0.8.0/src/resolve.rs +1307 -0
  680. data/ext/cargo-vendor/wit-parser-0.8.0/tests/all.rs +168 -0
  681. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/comments.wit +25 -0
  682. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/diamond1/deps/dep1/types.wit +2 -0
  683. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/diamond1/deps/dep2/types.wit +2 -0
  684. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/diamond1/join.wit +6 -0
  685. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/disambiguate-diamond/shared1.wit +3 -0
  686. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/disambiguate-diamond/shared2.wit +3 -0
  687. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/disambiguate-diamond/world.wit +13 -0
  688. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/embedded.wit.md +34 -0
  689. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/empty.wit +1 -0
  690. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +3 -0
  691. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/deps/corp/saas.wit +4 -0
  692. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +2 -0
  693. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +5 -0
  694. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +13 -0
  695. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/deps/wasi/clocks.wit +5 -0
  696. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/deps/wasi/filesystem.wit +7 -0
  697. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/foreign-deps/root.wit +44 -0
  698. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/functions.wit +14 -0
  699. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/many-names/a.wit +2 -0
  700. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/many-names/b.wit +5 -0
  701. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/multi-file/bar.wit +21 -0
  702. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/multi-file/cycle-a.wit +7 -0
  703. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/multi-file/cycle-b.wit +3 -0
  704. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/multi-file/foo.wit +31 -0
  705. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/package-syntax1.wit +1 -0
  706. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/package-syntax3.wit +1 -0
  707. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/package-syntax4.wit +1 -0
  708. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/alias-no-type.wit.result +1 -0
  709. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-function.wit +7 -0
  710. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-function.wit.result +5 -0
  711. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-function2.wit +7 -0
  712. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-function2.wit.result +5 -0
  713. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg1/root.wit +5 -0
  714. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg1.wit.result +8 -0
  715. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg2/deps/bar/empty.wit +1 -0
  716. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg2/root.wit +5 -0
  717. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg2.wit.result +5 -0
  718. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +2 -0
  719. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg3/root.wit +5 -0
  720. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg3.wit.result +5 -0
  721. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +4 -0
  722. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg4/root.wit +4 -0
  723. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg4.wit.result +5 -0
  724. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +3 -0
  725. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg5/root.wit +4 -0
  726. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg5.wit.result +5 -0
  727. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +4 -0
  728. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg6/root.wit +4 -0
  729. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-pkg6.wit.result +5 -0
  730. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-world-type1.wit +5 -0
  731. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/bad-world-type1.wit.result +5 -0
  732. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/conflicting-package/a.wit +1 -0
  733. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/conflicting-package/b.wit +1 -0
  734. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/conflicting-package.wit.result +8 -0
  735. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle.wit +6 -0
  736. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle.wit.result +5 -0
  737. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle2.wit +7 -0
  738. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle2.wit.result +5 -0
  739. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle3.wit +7 -0
  740. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle3.wit.result +5 -0
  741. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle4.wit +7 -0
  742. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle4.wit.result +5 -0
  743. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle5.wit +7 -0
  744. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/cycle5.wit.result +5 -0
  745. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-functions.wit +8 -0
  746. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-functions.wit.result +5 -0
  747. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-interface.wit +6 -0
  748. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-interface.wit.result +5 -0
  749. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-interface2/foo.wit +3 -0
  750. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-interface2/foo2.wit +3 -0
  751. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-interface2.wit.result +8 -0
  752. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-type.wit +7 -0
  753. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/duplicate-type.wit.result +5 -0
  754. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/empty-enum.wit +6 -0
  755. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/empty-enum.wit.result +5 -0
  756. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/empty-union.wit +6 -0
  757. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/empty-union.wit.result +5 -0
  758. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/empty-variant1.wit +6 -0
  759. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/empty-variant1.wit.result +5 -0
  760. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/export-twice.wit +8 -0
  761. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/export-twice.wit.result +5 -0
  762. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/import-export-overlap1.wit +5 -0
  763. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/import-export-overlap1.wit.result +5 -0
  764. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/import-export-overlap2.wit +5 -0
  765. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/import-export-overlap2.wit.result +5 -0
  766. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/import-twice.wit +8 -0
  767. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/import-twice.wit.result +5 -0
  768. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/invalid-md.wit.result +5 -0
  769. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/invalid-type-reference.wit +10 -0
  770. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/invalid-type-reference.wit.result +5 -0
  771. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/invalid-type-reference2.wit +6 -0
  772. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/invalid-type-reference2.wit.result +5 -0
  773. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/missing-package.wit.result +1 -0
  774. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/no-access-to-sibling-use/bar.wit +1 -0
  775. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/no-access-to-sibling-use/foo.wit +5 -0
  776. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +8 -0
  777. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +4 -0
  778. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/pkg-cycle/root.wit +4 -0
  779. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/pkg-cycle.wit.result +5 -0
  780. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +4 -0
  781. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +4 -0
  782. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/pkg-cycle2/root.wit +4 -0
  783. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/pkg-cycle2.wit.result +5 -0
  784. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/undefined-typed.wit +6 -0
  785. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/undefined-typed.wit.result +5 -0
  786. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unknown-interface.wit +7 -0
  787. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unknown-interface.wit.result +5 -0
  788. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface1.wit +7 -0
  789. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface1.wit.result +5 -0
  790. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface2.wit +8 -0
  791. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface2.wit.result +5 -0
  792. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface3.wit +5 -0
  793. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface3.wit.result +5 -0
  794. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface4.wit +7 -0
  795. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-interface4.wit.result +5 -0
  796. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use1.wit +7 -0
  797. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use1.wit.result +5 -0
  798. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use10/bar.wit +5 -0
  799. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use10.wit.result +8 -0
  800. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use2.wit +10 -0
  801. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use2.wit.result +5 -0
  802. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use3.wit +11 -0
  803. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use3.wit.result +5 -0
  804. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use7.wit +10 -0
  805. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use7.wit.result +5 -0
  806. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use8.wit +9 -0
  807. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use8.wit.result +5 -0
  808. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use9.wit +9 -0
  809. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/unresolved-use9.wit.result +5 -0
  810. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-conflict.wit +11 -0
  811. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-conflict.wit.result +5 -0
  812. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-conflict2.wit +13 -0
  813. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-conflict2.wit.result +5 -0
  814. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-conflict3.wit +13 -0
  815. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-conflict3.wit.result +5 -0
  816. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-cycle1.wit +7 -0
  817. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-cycle1.wit.result +5 -0
  818. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-cycle4.wit +14 -0
  819. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-cycle4.wit.result +5 -0
  820. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-shadow1.wit +7 -0
  821. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/use-shadow1.wit.result +5 -0
  822. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-interface-clash.wit +3 -0
  823. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-interface-clash.wit.result +5 -0
  824. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-same-fields2.wit +8 -0
  825. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-same-fields2.wit.result +5 -0
  826. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-same-fields3.wit +8 -0
  827. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-same-fields3.wit.result +5 -0
  828. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-top-level-func.wit +5 -0
  829. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-top-level-func.wit.result +5 -0
  830. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-top-level-func2.wit +4 -0
  831. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/parse-fail/world-top-level-func2.wit.result +5 -0
  832. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/shared-types.wit +10 -0
  833. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/type-then-eof.wit +5 -0
  834. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/types.wit +61 -0
  835. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/use-chain.wit +11 -0
  836. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/use.wit +34 -0
  837. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/versions/deps/a1/foo.wit +5 -0
  838. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/versions/deps/a2/foo.wit +5 -0
  839. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/versions/foo.wit +7 -0
  840. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/wasi.wit +178 -0
  841. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-diamond.wit +22 -0
  842. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-iface-no-collide.wit +11 -0
  843. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-implicit-import1.wit +12 -0
  844. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-implicit-import2.wit +11 -0
  845. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-implicit-import3.wit +11 -0
  846. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-same-fields4.wit +13 -0
  847. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/world-top-level-funcs.wit +9 -0
  848. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/worlds-same-fields5.wit +17 -0
  849. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/worlds-with-types.wit +34 -0
  850. data/ext/cargo-vendor/wit-parser-0.8.0/tests/ui/worlds.wit +37 -0
  851. data/ext/src/ruby_api/global.rs +3 -3
  852. data/ext/src/ruby_api/memory/unsafe_slice.rs +9 -3
  853. data/ext/src/ruby_api/params.rs +14 -12
  854. data/ext/src/ruby_api/table.rs +1 -1
  855. data/lib/wasmtime/version.rb +1 -1
  856. metadata +1418 -1079
  857. data/ext/cargo-vendor/cranelift-bforest-0.96.4/.cargo-checksum.json +0 -1
  858. data/ext/cargo-vendor/cranelift-bforest-0.96.4/Cargo.toml +0 -31
  859. data/ext/cargo-vendor/cranelift-codegen-0.96.4/.cargo-checksum.json +0 -1
  860. data/ext/cargo-vendor/cranelift-codegen-0.96.4/Cargo.toml +0 -159
  861. data/ext/cargo-vendor/cranelift-codegen-0.96.4/benches/x64-evex-encoding.rs +0 -53
  862. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/ir/trapcode.rs +0 -138
  863. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/abi.rs +0 -1281
  864. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/inst/emit.rs +0 -3658
  865. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/inst/emit_tests.rs +0 -7868
  866. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/inst/imms.rs +0 -1215
  867. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/inst/mod.rs +0 -2945
  868. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/inst.isle +0 -4035
  869. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/lower/isle.rs +0 -813
  870. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/lower.isle +0 -2906
  871. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/aarch64/mod.rs +0 -240
  872. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/mod.rs +0 -420
  873. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/abi.rs +0 -726
  874. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/args.rs +0 -1822
  875. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/emit.rs +0 -2914
  876. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/emit_tests.rs +0 -2317
  877. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/encode.rs +0 -188
  878. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/imms.rs +0 -244
  879. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/mod.rs +0 -1823
  880. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/regs.rs +0 -231
  881. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/unwind/systemv.rs +0 -177
  882. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst/vector.rs +0 -354
  883. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst.isle +0 -2746
  884. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/inst_vector.isle +0 -224
  885. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/lower/isle.rs +0 -544
  886. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/lower.isle +0 -1012
  887. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/riscv64/mod.rs +0 -219
  888. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/s390x/abi.rs +0 -947
  889. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/s390x/inst/emit.rs +0 -3697
  890. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/s390x/inst/emit_tests.rs +0 -13397
  891. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/s390x/inst/mod.rs +0 -3409
  892. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/s390x/inst.isle +0 -5045
  893. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/s390x/lower.isle +0 -3991
  894. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/s390x/mod.rs +0 -215
  895. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/abi.rs +0 -978
  896. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/encoding/evex.rs +0 -403
  897. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/encoding/rex.rs +0 -565
  898. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/encoding/vex.rs +0 -498
  899. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/inst/args.rs +0 -2168
  900. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/inst/emit.rs +0 -3938
  901. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/inst/emit_tests.rs +0 -5669
  902. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/inst/mod.rs +0 -2763
  903. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/inst.isle +0 -5186
  904. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/lower/isle.rs +0 -1158
  905. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/lower.isle +0 -4262
  906. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/lower.rs +0 -328
  907. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isa/x64/mod.rs +0 -250
  908. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/isle_prelude.rs +0 -818
  909. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/abi.rs +0 -2410
  910. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/buffer.rs +0 -2219
  911. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/compile.rs +0 -92
  912. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/isle.rs +0 -827
  913. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/lower.rs +0 -1366
  914. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/mod.rs +0 -538
  915. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/reg.rs +0 -532
  916. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/machinst/vcode.rs +0 -1571
  917. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/prelude.isle +0 -552
  918. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/prelude_lower.isle +0 -1012
  919. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/settings.rs +0 -599
  920. data/ext/cargo-vendor/cranelift-codegen-0.96.4/src/verifier/mod.rs +0 -1881
  921. data/ext/cargo-vendor/cranelift-codegen-meta-0.96.4/.cargo-checksum.json +0 -1
  922. data/ext/cargo-vendor/cranelift-codegen-meta-0.96.4/Cargo.toml +0 -23
  923. data/ext/cargo-vendor/cranelift-codegen-meta-0.96.4/src/isa/x86.rs +0 -445
  924. data/ext/cargo-vendor/cranelift-codegen-meta-0.96.4/src/shared/settings.rs +0 -331
  925. data/ext/cargo-vendor/cranelift-codegen-shared-0.96.4/.cargo-checksum.json +0 -1
  926. data/ext/cargo-vendor/cranelift-codegen-shared-0.96.4/Cargo.toml +0 -22
  927. data/ext/cargo-vendor/cranelift-control-0.96.4/.cargo-checksum.json +0 -1
  928. data/ext/cargo-vendor/cranelift-control-0.96.4/Cargo.toml +0 -30
  929. data/ext/cargo-vendor/cranelift-control-0.96.4/src/chaos.rs +0 -78
  930. data/ext/cargo-vendor/cranelift-control-0.96.4/src/lib.rs +0 -30
  931. data/ext/cargo-vendor/cranelift-control-0.96.4/src/zero_sized.rs +0 -42
  932. data/ext/cargo-vendor/cranelift-entity-0.96.4/.cargo-checksum.json +0 -1
  933. data/ext/cargo-vendor/cranelift-entity-0.96.4/Cargo.toml +0 -35
  934. data/ext/cargo-vendor/cranelift-entity-0.96.4/src/list.rs +0 -868
  935. data/ext/cargo-vendor/cranelift-frontend-0.96.4/.cargo-checksum.json +0 -1
  936. data/ext/cargo-vendor/cranelift-frontend-0.96.4/Cargo.toml +0 -53
  937. data/ext/cargo-vendor/cranelift-isle-0.96.4/.cargo-checksum.json +0 -1
  938. data/ext/cargo-vendor/cranelift-isle-0.96.4/Cargo.toml +0 -37
  939. data/ext/cargo-vendor/cranelift-native-0.96.4/.cargo-checksum.json +0 -1
  940. data/ext/cargo-vendor/cranelift-native-0.96.4/Cargo.toml +0 -38
  941. data/ext/cargo-vendor/cranelift-native-0.96.4/src/lib.rs +0 -216
  942. data/ext/cargo-vendor/cranelift-wasm-0.96.4/.cargo-checksum.json +0 -1
  943. data/ext/cargo-vendor/cranelift-wasm-0.96.4/Cargo.toml +0 -85
  944. data/ext/cargo-vendor/cranelift-wasm-0.96.4/src/code_translator.rs +0 -3479
  945. data/ext/cargo-vendor/cranelift-wasm-0.96.4/src/environ/dummy.rs +0 -901
  946. data/ext/cargo-vendor/cranelift-wasm-0.96.4/src/environ/spec.rs +0 -807
  947. data/ext/cargo-vendor/cranelift-wasm-0.96.4/src/func_translator.rs +0 -419
  948. data/ext/cargo-vendor/cranelift-wasm-0.96.4/src/sections_translator.rs +0 -429
  949. data/ext/cargo-vendor/cranelift-wasm-0.96.4/src/translation_utils.rs +0 -108
  950. data/ext/cargo-vendor/file-per-thread-logger-0.1.6/.cargo-checksum.json +0 -1
  951. data/ext/cargo-vendor/file-per-thread-logger-0.1.6/Cargo.toml +0 -36
  952. data/ext/cargo-vendor/file-per-thread-logger-0.1.6/run-tests.sh +0 -11
  953. data/ext/cargo-vendor/file-per-thread-logger-0.1.6/src/lib.rs +0 -162
  954. data/ext/cargo-vendor/file-per-thread-logger-0.1.6/tests/test.rs +0 -267
  955. data/ext/cargo-vendor/regalloc2-0.8.1/.cargo-checksum.json +0 -1
  956. data/ext/cargo-vendor/regalloc2-0.8.1/Cargo.toml +0 -72
  957. data/ext/cargo-vendor/regalloc2-0.8.1/deny.toml +0 -28
  958. data/ext/cargo-vendor/regalloc2-0.8.1/src/checker.rs +0 -1089
  959. data/ext/cargo-vendor/regalloc2-0.8.1/src/fuzzing/func.rs +0 -673
  960. data/ext/cargo-vendor/regalloc2-0.8.1/src/index.rs +0 -188
  961. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/data_structures.rs +0 -688
  962. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/liveranges.rs +0 -1012
  963. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/merge.rs +0 -394
  964. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/mod.rs +0 -152
  965. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/moves.rs +0 -985
  966. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/process.rs +0 -1322
  967. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/requirement.rs +0 -174
  968. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/spill.rs +0 -198
  969. data/ext/cargo-vendor/regalloc2-0.8.1/src/ion/stackmap.rs +0 -74
  970. data/ext/cargo-vendor/regalloc2-0.8.1/src/lib.rs +0 -1523
  971. data/ext/cargo-vendor/regalloc2-0.8.1/src/moves.rs +0 -438
  972. data/ext/cargo-vendor/wasi-cap-std-sync-9.0.4/.cargo-checksum.json +0 -1
  973. data/ext/cargo-vendor/wasi-cap-std-sync-9.0.4/Cargo.toml +0 -89
  974. data/ext/cargo-vendor/wasi-cap-std-sync-9.0.4/src/dir.rs +0 -465
  975. data/ext/cargo-vendor/wasi-cap-std-sync-9.0.4/src/lib.rs +0 -140
  976. data/ext/cargo-vendor/wasi-common-9.0.4/.cargo-checksum.json +0 -1
  977. data/ext/cargo-vendor/wasi-common-9.0.4/Cargo.toml +0 -86
  978. data/ext/cargo-vendor/wasi-common-9.0.4/src/ctx.rs +0 -127
  979. data/ext/cargo-vendor/wasi-common-9.0.4/src/file.rs +0 -260
  980. data/ext/cargo-vendor/wasi-common-9.0.4/src/snapshots/preview_1.rs +0 -1490
  981. data/ext/cargo-vendor/wasmparser-0.103.0/.cargo-checksum.json +0 -1
  982. data/ext/cargo-vendor/wasmparser-0.103.0/Cargo.lock +0 -692
  983. data/ext/cargo-vendor/wasmparser-0.103.0/Cargo.toml +0 -54
  984. data/ext/cargo-vendor/wasmparser-0.103.0/benches/benchmark.rs +0 -350
  985. data/ext/cargo-vendor/wasmparser-0.103.0/src/binary_reader.rs +0 -1682
  986. data/ext/cargo-vendor/wasmparser-0.103.0/src/lib.rs +0 -712
  987. data/ext/cargo-vendor/wasmparser-0.103.0/src/parser.rs +0 -1496
  988. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/component/canonicals.rs +0 -95
  989. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/component/exports.rs +0 -105
  990. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/component/imports.rs +0 -109
  991. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/component/instances.rs +0 -164
  992. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/component/types.rs +0 -508
  993. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/core/producers.rs +0 -78
  994. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/core/types.rs +0 -511
  995. data/ext/cargo-vendor/wasmparser-0.103.0/src/readers/core.rs +0 -33
  996. data/ext/cargo-vendor/wasmparser-0.103.0/src/validator/component.rs +0 -2097
  997. data/ext/cargo-vendor/wasmparser-0.103.0/src/validator/core.rs +0 -1278
  998. data/ext/cargo-vendor/wasmparser-0.103.0/src/validator/operators.rs +0 -3456
  999. data/ext/cargo-vendor/wasmparser-0.103.0/src/validator/types.rs +0 -2159
  1000. data/ext/cargo-vendor/wasmparser-0.103.0/src/validator.rs +0 -1514
  1001. data/ext/cargo-vendor/wasmtime-9.0.4/.cargo-checksum.json +0 -1
  1002. data/ext/cargo-vendor/wasmtime-9.0.4/Cargo.toml +0 -183
  1003. data/ext/cargo-vendor/wasmtime-9.0.4/build.rs +0 -20
  1004. data/ext/cargo-vendor/wasmtime-9.0.4/src/component/component.rs +0 -519
  1005. data/ext/cargo-vendor/wasmtime-9.0.4/src/component/instance.rs +0 -728
  1006. data/ext/cargo-vendor/wasmtime-9.0.4/src/component/matching.rs +0 -112
  1007. data/ext/cargo-vendor/wasmtime-9.0.4/src/component/mod.rs +0 -313
  1008. data/ext/cargo-vendor/wasmtime-9.0.4/src/config.rs +0 -2036
  1009. data/ext/cargo-vendor/wasmtime-9.0.4/src/engine/serialization.rs +0 -613
  1010. data/ext/cargo-vendor/wasmtime-9.0.4/src/engine.rs +0 -729
  1011. data/ext/cargo-vendor/wasmtime-9.0.4/src/externals.rs +0 -762
  1012. data/ext/cargo-vendor/wasmtime-9.0.4/src/func/typed.rs +0 -638
  1013. data/ext/cargo-vendor/wasmtime-9.0.4/src/func.rs +0 -2385
  1014. data/ext/cargo-vendor/wasmtime-9.0.4/src/instance.rs +0 -905
  1015. data/ext/cargo-vendor/wasmtime-9.0.4/src/lib.rs +0 -481
  1016. data/ext/cargo-vendor/wasmtime-9.0.4/src/linker.rs +0 -1479
  1017. data/ext/cargo-vendor/wasmtime-9.0.4/src/memory.rs +0 -948
  1018. data/ext/cargo-vendor/wasmtime-9.0.4/src/module.rs +0 -1542
  1019. data/ext/cargo-vendor/wasmtime-9.0.4/src/ref.rs +0 -108
  1020. data/ext/cargo-vendor/wasmtime-9.0.4/src/store/context.rs +0 -243
  1021. data/ext/cargo-vendor/wasmtime-9.0.4/src/store/func_refs.rs +0 -110
  1022. data/ext/cargo-vendor/wasmtime-9.0.4/src/store.rs +0 -2059
  1023. data/ext/cargo-vendor/wasmtime-9.0.4/src/trampoline/func.rs +0 -171
  1024. data/ext/cargo-vendor/wasmtime-9.0.4/src/trampoline/global.rs +0 -71
  1025. data/ext/cargo-vendor/wasmtime-9.0.4/src/types/matching.rs +0 -254
  1026. data/ext/cargo-vendor/wasmtime-9.0.4/src/types.rs +0 -551
  1027. data/ext/cargo-vendor/wasmtime-9.0.4/src/values.rs +0 -290
  1028. data/ext/cargo-vendor/wasmtime-asm-macros-9.0.4/.cargo-checksum.json +0 -1
  1029. data/ext/cargo-vendor/wasmtime-asm-macros-9.0.4/Cargo.toml +0 -22
  1030. data/ext/cargo-vendor/wasmtime-cache-9.0.4/.cargo-checksum.json +0 -1
  1031. data/ext/cargo-vendor/wasmtime-cache-9.0.4/Cargo.toml +0 -73
  1032. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/.cargo-checksum.json +0 -1
  1033. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/Cargo.toml +0 -58
  1034. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/src/bindgen.rs +0 -316
  1035. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/char.wit +0 -11
  1036. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/conventions.wit +0 -38
  1037. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/direct-import.wit +0 -3
  1038. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/empty.wit +0 -1
  1039. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/flags.wit +0 -53
  1040. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/floats.wit +0 -11
  1041. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/function-new.wit +0 -3
  1042. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/integers.wit +0 -38
  1043. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/lists.wit +0 -83
  1044. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/many-arguments.wit +0 -50
  1045. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/multi-return.wit +0 -12
  1046. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/records.wit +0 -59
  1047. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/rename.wit +0 -14
  1048. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/share-types.wit +0 -19
  1049. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/simple-functions.wit +0 -15
  1050. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/simple-lists.wit +0 -11
  1051. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/simple-wasi.wit +0 -21
  1052. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/small-anonymous.wit +0 -13
  1053. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/smoke-default.wit +0 -3
  1054. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/smoke-export.wit +0 -5
  1055. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/smoke.wit +0 -5
  1056. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/strings.wit +0 -10
  1057. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/unions.wit +0 -64
  1058. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/use-paths.wit +0 -27
  1059. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/variants.wit +0 -145
  1060. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen/worlds-with-types.wit +0 -14
  1061. data/ext/cargo-vendor/wasmtime-component-macro-9.0.4/tests/codegen.rs +0 -30
  1062. data/ext/cargo-vendor/wasmtime-component-util-9.0.4/.cargo-checksum.json +0 -1
  1063. data/ext/cargo-vendor/wasmtime-component-util-9.0.4/Cargo.toml +0 -25
  1064. data/ext/cargo-vendor/wasmtime-cranelift-9.0.4/.cargo-checksum.json +0 -1
  1065. data/ext/cargo-vendor/wasmtime-cranelift-9.0.4/Cargo.toml +0 -90
  1066. data/ext/cargo-vendor/wasmtime-cranelift-9.0.4/src/compiler.rs +0 -1200
  1067. data/ext/cargo-vendor/wasmtime-cranelift-9.0.4/src/debug/transform/simulate.rs +0 -411
  1068. data/ext/cargo-vendor/wasmtime-cranelift-9.0.4/src/func_environ.rs +0 -2162
  1069. data/ext/cargo-vendor/wasmtime-cranelift-9.0.4/src/lib.rs +0 -177
  1070. data/ext/cargo-vendor/wasmtime-cranelift-shared-9.0.4/.cargo-checksum.json +0 -1
  1071. data/ext/cargo-vendor/wasmtime-cranelift-shared-9.0.4/Cargo.toml +0 -57
  1072. data/ext/cargo-vendor/wasmtime-cranelift-shared-9.0.4/src/lib.rs +0 -119
  1073. data/ext/cargo-vendor/wasmtime-environ-9.0.4/.cargo-checksum.json +0 -1
  1074. data/ext/cargo-vendor/wasmtime-environ-9.0.4/Cargo.lock +0 -735
  1075. data/ext/cargo-vendor/wasmtime-environ-9.0.4/Cargo.toml +0 -116
  1076. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/component/compiler.rs +0 -84
  1077. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/component/translate/inline.rs +0 -1064
  1078. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/component/translate.rs +0 -1066
  1079. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/component/types.rs +0 -1903
  1080. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/fact.rs +0 -622
  1081. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/module.rs +0 -1043
  1082. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/module_environ.rs +0 -841
  1083. data/ext/cargo-vendor/wasmtime-environ-9.0.4/src/trap_encoding.rs +0 -234
  1084. data/ext/cargo-vendor/wasmtime-fiber-9.0.4/.cargo-checksum.json +0 -1
  1085. data/ext/cargo-vendor/wasmtime-fiber-9.0.4/Cargo.toml +0 -46
  1086. data/ext/cargo-vendor/wasmtime-fiber-9.0.4/src/lib.rs +0 -293
  1087. data/ext/cargo-vendor/wasmtime-fiber-9.0.4/src/unix.rs +0 -199
  1088. data/ext/cargo-vendor/wasmtime-fiber-9.0.4/src/windows.rs +0 -156
  1089. data/ext/cargo-vendor/wasmtime-jit-9.0.4/.cargo-checksum.json +0 -1
  1090. data/ext/cargo-vendor/wasmtime-jit-9.0.4/Cargo.toml +0 -100
  1091. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/instantiate.rs +0 -786
  1092. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/lib.rs +0 -39
  1093. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/profiling/jitdump_disabled.rs +0 -32
  1094. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/profiling/jitdump_linux.rs +0 -444
  1095. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/profiling/perfmap_disabled.rs +0 -28
  1096. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/profiling/perfmap_linux.rs +0 -104
  1097. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/profiling/vtune.rs +0 -147
  1098. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/profiling/vtune_disabled.rs +0 -32
  1099. data/ext/cargo-vendor/wasmtime-jit-9.0.4/src/profiling.rs +0 -74
  1100. data/ext/cargo-vendor/wasmtime-jit-debug-9.0.4/.cargo-checksum.json +0 -1
  1101. data/ext/cargo-vendor/wasmtime-jit-debug-9.0.4/Cargo.toml +0 -55
  1102. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-9.0.4/.cargo-checksum.json +0 -1
  1103. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-9.0.4/Cargo.toml +0 -37
  1104. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/.cargo-checksum.json +0 -1
  1105. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/Cargo.toml +0 -107
  1106. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/component.rs +0 -724
  1107. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/cow.rs +0 -1063
  1108. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/debug_builtins.rs +0 -56
  1109. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/externref.rs +0 -1078
  1110. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/instance/allocator/pooling.rs +0 -1371
  1111. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/instance/allocator.rs +0 -528
  1112. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/instance.rs +0 -1267
  1113. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/lib.rs +0 -286
  1114. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/libcalls.rs +0 -597
  1115. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/memory.rs +0 -945
  1116. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/mmap/miri.rs +0 -93
  1117. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/mmap/unix.rs +0 -147
  1118. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/mmap/windows.rs +0 -207
  1119. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/table.rs +0 -573
  1120. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/traphandlers/unix.rs +0 -387
  1121. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/traphandlers.rs +0 -664
  1122. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/vmcontext/vm_host_func_context.rs +0 -147
  1123. data/ext/cargo-vendor/wasmtime-runtime-9.0.4/src/vmcontext.rs +0 -1244
  1124. data/ext/cargo-vendor/wasmtime-types-9.0.4/.cargo-checksum.json +0 -1
  1125. data/ext/cargo-vendor/wasmtime-types-9.0.4/Cargo.toml +0 -34
  1126. data/ext/cargo-vendor/wasmtime-types-9.0.4/src/lib.rs +0 -413
  1127. data/ext/cargo-vendor/wasmtime-wasi-9.0.4/.cargo-checksum.json +0 -1
  1128. data/ext/cargo-vendor/wasmtime-wasi-9.0.4/Cargo.toml +0 -67
  1129. data/ext/cargo-vendor/wasmtime-wasi-9.0.4/src/lib.rs +0 -128
  1130. data/ext/cargo-vendor/wasmtime-winch-9.0.4/.cargo-checksum.json +0 -1
  1131. data/ext/cargo-vendor/wasmtime-winch-9.0.4/Cargo.toml +0 -66
  1132. data/ext/cargo-vendor/wasmtime-winch-9.0.4/src/compiler.rs +0 -191
  1133. data/ext/cargo-vendor/wasmtime-wit-bindgen-9.0.4/.cargo-checksum.json +0 -1
  1134. data/ext/cargo-vendor/wasmtime-wit-bindgen-9.0.4/Cargo.toml +0 -29
  1135. data/ext/cargo-vendor/wasmtime-wit-bindgen-9.0.4/src/lib.rs +0 -1488
  1136. data/ext/cargo-vendor/wasmtime-wit-bindgen-9.0.4/src/types.rs +0 -178
  1137. data/ext/cargo-vendor/wiggle-9.0.4/.cargo-checksum.json +0 -1
  1138. data/ext/cargo-vendor/wiggle-9.0.4/Cargo.toml +0 -106
  1139. data/ext/cargo-vendor/wiggle-9.0.4/README.md +0 -18
  1140. data/ext/cargo-vendor/wiggle-generate-9.0.4/.cargo-checksum.json +0 -1
  1141. data/ext/cargo-vendor/wiggle-generate-9.0.4/Cargo.toml +0 -58
  1142. data/ext/cargo-vendor/wiggle-macro-9.0.4/.cargo-checksum.json +0 -1
  1143. data/ext/cargo-vendor/wiggle-macro-9.0.4/Cargo.toml +0 -55
  1144. data/ext/cargo-vendor/wiggle-macro-9.0.4/src/lib.rs +0 -210
  1145. data/ext/cargo-vendor/winch-codegen-0.7.4/.cargo-checksum.json +0 -1
  1146. data/ext/cargo-vendor/winch-codegen-0.7.4/Cargo.toml +0 -59
  1147. data/ext/cargo-vendor/winch-codegen-0.7.4/src/abi/local.rs +0 -69
  1148. data/ext/cargo-vendor/winch-codegen-0.7.4/src/abi/mod.rs +0 -223
  1149. data/ext/cargo-vendor/winch-codegen-0.7.4/src/codegen/call.rs +0 -215
  1150. data/ext/cargo-vendor/winch-codegen-0.7.4/src/codegen/context.rs +0 -259
  1151. data/ext/cargo-vendor/winch-codegen-0.7.4/src/codegen/env.rs +0 -19
  1152. data/ext/cargo-vendor/winch-codegen-0.7.4/src/codegen/mod.rs +0 -183
  1153. data/ext/cargo-vendor/winch-codegen-0.7.4/src/frame/mod.rs +0 -166
  1154. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/aarch64/abi.rs +0 -221
  1155. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/aarch64/asm.rs +0 -244
  1156. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/aarch64/masm.rs +0 -221
  1157. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/aarch64/mod.rs +0 -122
  1158. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/aarch64/regs.rs +0 -160
  1159. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/mod.rs +0 -202
  1160. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/x64/abi.rs +0 -337
  1161. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/x64/address.rs +0 -17
  1162. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/x64/asm.rs +0 -499
  1163. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/x64/masm.rs +0 -267
  1164. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/x64/mod.rs +0 -135
  1165. data/ext/cargo-vendor/winch-codegen-0.7.4/src/isa/x64/regs.rs +0 -178
  1166. data/ext/cargo-vendor/winch-codegen-0.7.4/src/lib.rs +0 -20
  1167. data/ext/cargo-vendor/winch-codegen-0.7.4/src/masm.rs +0 -213
  1168. data/ext/cargo-vendor/winch-codegen-0.7.4/src/regalloc.rs +0 -61
  1169. data/ext/cargo-vendor/winch-codegen-0.7.4/src/stack.rs +0 -230
  1170. data/ext/cargo-vendor/winch-codegen-0.7.4/src/trampoline.rs +0 -206
  1171. data/ext/cargo-vendor/winch-codegen-0.7.4/src/visitor.rs +0 -215
  1172. data/ext/cargo-vendor/winch-environ-0.7.4/.cargo-checksum.json +0 -1
  1173. data/ext/cargo-vendor/winch-environ-0.7.4/Cargo.toml +0 -28
  1174. data/ext/cargo-vendor/winch-environ-0.7.4/src/lib.rs +0 -41
  1175. data/ext/cargo-vendor/wit-parser-0.7.1/.cargo-checksum.json +0 -1
  1176. data/ext/cargo-vendor/wit-parser-0.7.1/Cargo.toml +0 -59
  1177. data/ext/cargo-vendor/wit-parser-0.7.1/src/ast/lex.rs +0 -662
  1178. data/ext/cargo-vendor/wit-parser-0.7.1/src/ast/resolve.rs +0 -1072
  1179. data/ext/cargo-vendor/wit-parser-0.7.1/src/ast.rs +0 -1099
  1180. data/ext/cargo-vendor/wit-parser-0.7.1/src/lib.rs +0 -617
  1181. data/ext/cargo-vendor/wit-parser-0.7.1/src/live.rs +0 -123
  1182. data/ext/cargo-vendor/wit-parser-0.7.1/src/resolve.rs +0 -1478
  1183. data/ext/cargo-vendor/wit-parser-0.7.1/tests/all.rs +0 -168
  1184. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/comments.wit +0 -23
  1185. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/disambiguate-diamond/shared1.wit +0 -3
  1186. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/disambiguate-diamond/shared2.wit +0 -3
  1187. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/disambiguate-diamond/world.wit +0 -11
  1188. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/embedded.wit.md +0 -32
  1189. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +0 -1
  1190. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/deps/corp/saas.wit +0 -2
  1191. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +0 -1
  1192. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +0 -3
  1193. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +0 -11
  1194. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/deps/wasi/clocks.wit +0 -3
  1195. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/deps/wasi/filesystem.wit +0 -5
  1196. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/foreign-deps/root.wit +0 -31
  1197. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/functions.wit +0 -12
  1198. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/multi-file/bar.wit +0 -19
  1199. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/multi-file/foo.wit +0 -15
  1200. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/alias-no-type.wit.result +0 -5
  1201. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-diamond/a.wit +0 -9
  1202. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-diamond/b.wit +0 -9
  1203. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-diamond/join.wit +0 -4
  1204. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-diamond.wit.result +0 -8
  1205. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-function.wit +0 -5
  1206. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-function.wit.result +0 -5
  1207. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-function2.wit +0 -5
  1208. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-function2.wit.result +0 -5
  1209. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg1/root.wit +0 -3
  1210. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg1.wit.result +0 -5
  1211. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg2/root.wit +0 -3
  1212. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg2.wit.result +0 -5
  1213. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +0 -0
  1214. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg3/root.wit +0 -3
  1215. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg3.wit.result +0 -5
  1216. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +0 -3
  1217. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg4/root.wit +0 -3
  1218. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg4.wit.result +0 -5
  1219. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +0 -2
  1220. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg5/root.wit +0 -3
  1221. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg5.wit.result +0 -5
  1222. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +0 -0
  1223. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg6/root.wit +0 -3
  1224. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-pkg6.wit.result +0 -5
  1225. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-world-type1.wit +0 -4
  1226. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-world-type1.wit.result +0 -5
  1227. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-world-type2.wit +0 -9
  1228. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/bad-world-type2.wit.result +0 -5
  1229. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle.wit +0 -5
  1230. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle.wit.result +0 -5
  1231. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle2.wit +0 -6
  1232. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle2.wit.result +0 -5
  1233. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle3.wit +0 -6
  1234. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle3.wit.result +0 -5
  1235. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle4.wit +0 -6
  1236. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle4.wit.result +0 -5
  1237. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle5.wit +0 -6
  1238. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/cycle5.wit.result +0 -5
  1239. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/default-interface1.wit +0 -3
  1240. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/default-interface1.wit.result +0 -5
  1241. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/default-world1.wit +0 -3
  1242. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/default-world1.wit.result +0 -5
  1243. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/duplicate-functions.wit +0 -6
  1244. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/duplicate-functions.wit.result +0 -5
  1245. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/duplicate-interface.wit +0 -4
  1246. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/duplicate-interface.wit.result +0 -5
  1247. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/duplicate-type.wit +0 -6
  1248. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/duplicate-type.wit.result +0 -5
  1249. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/empty-enum.wit +0 -5
  1250. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/empty-enum.wit.result +0 -5
  1251. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/empty-union.wit +0 -5
  1252. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/empty-union.wit.result +0 -5
  1253. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/empty-variant1.wit +0 -5
  1254. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/empty-variant1.wit.result +0 -5
  1255. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/import-export-overlap1.wit +0 -4
  1256. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/import-export-overlap1.wit.result +0 -5
  1257. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/import-export-overlap2.wit +0 -4
  1258. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/import-export-overlap2.wit.result +0 -5
  1259. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/import-export-overlap3.wit +0 -11
  1260. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/import-export-overlap3.wit.result +0 -6
  1261. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/invalid-md.wit.result +0 -5
  1262. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/invalid-type-reference.wit +0 -8
  1263. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/invalid-type-reference.wit.result +0 -5
  1264. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/invalid-type-reference2.wit +0 -4
  1265. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/invalid-type-reference2.wit.result +0 -5
  1266. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/invalid@filename.wit +0 -0
  1267. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/invalid@filename.wit.result +0 -4
  1268. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +0 -3
  1269. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/pkg-cycle/root.wit +0 -3
  1270. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/pkg-cycle.wit.result +0 -5
  1271. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +0 -3
  1272. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +0 -3
  1273. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/pkg-cycle2/root.wit +0 -3
  1274. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/pkg-cycle2.wit.result +0 -5
  1275. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/undefined-typed.wit +0 -5
  1276. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/undefined-typed.wit.result +0 -5
  1277. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unknown-interface.wit +0 -5
  1278. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unknown-interface.wit.result +0 -5
  1279. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface1.wit +0 -5
  1280. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface1.wit.result +0 -5
  1281. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface2.wit +0 -6
  1282. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface2.wit.result +0 -5
  1283. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface3.wit +0 -5
  1284. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface3.wit.result +0 -5
  1285. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface4.wit +0 -5
  1286. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface4.wit.result +0 -5
  1287. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface5.wit +0 -5
  1288. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-interface5.wit.result +0 -5
  1289. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use1.wit +0 -5
  1290. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use1.wit.result +0 -5
  1291. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use10/bar.wit +0 -3
  1292. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use10.wit.result +0 -8
  1293. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use11/bar.wit +0 -3
  1294. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use11/foo.wit +0 -2
  1295. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use11.wit.result +0 -8
  1296. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use2.wit +0 -8
  1297. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use2.wit.result +0 -5
  1298. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use3.wit +0 -9
  1299. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use3.wit.result +0 -5
  1300. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use4.wit +0 -5
  1301. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use4.wit.result +0 -5
  1302. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use5.wit +0 -6
  1303. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use5.wit.result +0 -5
  1304. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use6.wit +0 -5
  1305. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use6.wit.result +0 -5
  1306. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use7.wit +0 -8
  1307. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use7.wit.result +0 -5
  1308. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use8.wit +0 -7
  1309. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use8.wit.result +0 -5
  1310. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use9.wit +0 -7
  1311. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/unresolved-use9.wit.result +0 -5
  1312. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-conflict.wit +0 -9
  1313. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-conflict.wit.result +0 -5
  1314. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-conflict2.wit +0 -11
  1315. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-conflict2.wit.result +0 -5
  1316. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-conflict3.wit +0 -11
  1317. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-conflict3.wit.result +0 -5
  1318. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle1.wit +0 -5
  1319. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle1.wit.result +0 -5
  1320. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle2.wit +0 -5
  1321. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle2.wit.result +0 -5
  1322. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle3.wit +0 -6
  1323. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle3.wit.result +0 -5
  1324. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle4.wit +0 -13
  1325. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-cycle4.wit.result +0 -5
  1326. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-from-package-world.wit +0 -8
  1327. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-from-package-world.wit.result +0 -5
  1328. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-from-package-world2/bar.wit +0 -3
  1329. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-from-package-world2/foo.wit +0 -2
  1330. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/use-from-package-world2.wit.result +0 -8
  1331. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-implicit-import1.wit +0 -10
  1332. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-implicit-import1.wit.result +0 -6
  1333. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-implicit-import2.wit +0 -9
  1334. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-implicit-import2.wit.result +0 -5
  1335. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-implicit-import3.wit +0 -9
  1336. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-implicit-import3.wit.result +0 -5
  1337. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-interface-clash.wit +0 -2
  1338. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-interface-clash.wit.result +0 -5
  1339. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields.wit +0 -9
  1340. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields.wit.result +0 -5
  1341. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields2.wit +0 -6
  1342. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields2.wit.result +0 -5
  1343. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields3.wit +0 -6
  1344. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields3.wit.result +0 -5
  1345. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields4.wit +0 -11
  1346. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-fields4.wit.result +0 -8
  1347. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-import.wit +0 -6
  1348. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-same-import.wit.result +0 -5
  1349. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-top-level-func.wit +0 -4
  1350. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-top-level-func.wit.result +0 -5
  1351. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-top-level-func2.wit +0 -3
  1352. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/world-top-level-func2.wit.result +0 -5
  1353. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/worlds-same-fields5.wit +0 -16
  1354. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/parse-fail/worlds-same-fields5.wit.result +0 -9
  1355. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/shared-types.wit +0 -8
  1356. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/type-then-eof.wit +0 -3
  1357. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/types.wit +0 -59
  1358. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/use.wit +0 -33
  1359. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/wasi.wit +0 -176
  1360. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/world-diamond.wit +0 -20
  1361. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/world-top-level-funcs.wit +0 -7
  1362. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/worlds-with-types.wit +0 -32
  1363. data/ext/cargo-vendor/wit-parser-0.7.1/tests/ui/worlds.wit +0 -40
  1364. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/LICENSE +0 -0
  1365. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/README.md +0 -0
  1366. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/src/lib.rs +0 -0
  1367. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/src/map.rs +0 -0
  1368. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/src/node.rs +0 -0
  1369. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/src/path.rs +0 -0
  1370. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/src/pool.rs +0 -0
  1371. /data/ext/cargo-vendor/{cranelift-bforest-0.96.4 → cranelift-bforest-0.97.1}/src/set.rs +0 -0
  1372. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/LICENSE +0 -0
  1373. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/README.md +0 -0
  1374. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/build.rs +0 -0
  1375. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/alias_analysis.rs +0 -0
  1376. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/binemit/mod.rs +0 -0
  1377. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/binemit/stack_map.rs +0 -0
  1378. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/bitset.rs +0 -0
  1379. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/cfg_printer.rs +0 -0
  1380. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/constant_hash.rs +0 -0
  1381. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/context.rs +0 -0
  1382. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ctxhash.rs +0 -0
  1383. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/cursor.rs +0 -0
  1384. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/data_value.rs +0 -0
  1385. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/dbg.rs +0 -0
  1386. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/dce.rs +0 -0
  1387. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/dominator_tree.rs +0 -0
  1388. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/egraph/cost.rs +0 -0
  1389. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/egraph/domtree.rs +0 -0
  1390. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/egraph/elaborate.rs +0 -0
  1391. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/egraph.rs +0 -0
  1392. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/flowgraph.rs +0 -0
  1393. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/fx.rs +0 -0
  1394. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/incremental_cache.rs +0 -0
  1395. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/inst_predicates.rs +0 -0
  1396. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/atomic_rmw_op.rs +0 -0
  1397. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/builder.rs +0 -0
  1398. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/condcodes.rs +0 -0
  1399. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/constant.rs +0 -0
  1400. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/dfg.rs +0 -0
  1401. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/dynamic_type.rs +0 -0
  1402. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/entities.rs +0 -0
  1403. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/extfunc.rs +0 -0
  1404. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/extname.rs +0 -0
  1405. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/function.rs +0 -0
  1406. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/globalvalue.rs +0 -0
  1407. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/immediates.rs +0 -0
  1408. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/instructions.rs +0 -0
  1409. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/jumptable.rs +0 -0
  1410. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/known_symbol.rs +0 -0
  1411. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/layout.rs +0 -0
  1412. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/libcall.rs +0 -0
  1413. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/memflags.rs +0 -0
  1414. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/mod.rs +0 -0
  1415. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/progpoint.rs +0 -0
  1416. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/sourceloc.rs +0 -0
  1417. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/stackslot.rs +0 -0
  1418. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/table.rs +0 -0
  1419. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/ir/types.rs +0 -0
  1420. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/inst/args.rs +0 -0
  1421. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/inst/regs.rs +0 -0
  1422. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/inst/unwind/systemv.rs +0 -0
  1423. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/inst/unwind.rs +0 -0
  1424. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/inst_neon.isle +0 -0
  1425. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
  1426. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/lower.rs +0 -0
  1427. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
  1428. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/aarch64/settings.rs +0 -0
  1429. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/call_conv.rs +0 -0
  1430. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/riscv64/inst/unwind.rs +0 -0
  1431. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
  1432. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/riscv64/lower.rs +0 -0
  1433. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/riscv64/settings.rs +0 -0
  1434. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/inst/args.rs +0 -0
  1435. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/inst/imms.rs +0 -0
  1436. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/inst/regs.rs +0 -0
  1437. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/inst/unwind/systemv.rs +0 -0
  1438. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/inst/unwind.rs +0 -0
  1439. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
  1440. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/lower/isle.rs +0 -0
  1441. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/lower.rs +0 -0
  1442. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/s390x/settings.rs +0 -0
  1443. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/unwind/systemv.rs +0 -0
  1444. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/unwind/winx64.rs +0 -0
  1445. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/unwind.rs +0 -0
  1446. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/x64/encoding/mod.rs +0 -0
  1447. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/x64/inst/regs.rs +0 -0
  1448. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/x64/inst/unwind/systemv.rs +0 -0
  1449. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/x64/inst/unwind/winx64.rs +0 -0
  1450. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/x64/inst/unwind.rs +0 -0
  1451. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/x64/lower/isle/generated_code.rs +0 -0
  1452. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/isa/x64/settings.rs +0 -0
  1453. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/iterators.rs +0 -0
  1454. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/legalizer/globalvalue.rs +0 -0
  1455. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/legalizer/mod.rs +0 -0
  1456. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/legalizer/table.rs +0 -0
  1457. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/lib.rs +0 -0
  1458. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/loop_analysis.rs +0 -0
  1459. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/machinst/blockorder.rs +0 -0
  1460. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/machinst/helpers.rs +0 -0
  1461. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/machinst/inst_common.rs +0 -0
  1462. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/machinst/valueregs.rs +0 -0
  1463. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/nan_canonicalization.rs +0 -0
  1464. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/README.md +0 -0
  1465. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/arithmetic.isle +0 -0
  1466. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/bitops.isle +0 -0
  1467. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/cprop.isle +0 -0
  1468. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/extends.isle +0 -0
  1469. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/generated_code.rs +0 -0
  1470. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/icmp.isle +0 -0
  1471. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/remat.isle +0 -0
  1472. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/selects.isle +0 -0
  1473. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts/shifts.isle +0 -0
  1474. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/opts.rs +0 -0
  1475. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/prelude_opt.isle +0 -0
  1476. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/print_errors.rs +0 -0
  1477. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/remove_constant_phis.rs +0 -0
  1478. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/result.rs +0 -0
  1479. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/scoped_hash_map.rs +0 -0
  1480. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/souper_harvest.rs +0 -0
  1481. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/timing.rs +0 -0
  1482. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/unionfind.rs +0 -0
  1483. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/unreachable_code.rs +0 -0
  1484. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/value_label.rs +0 -0
  1485. /data/ext/cargo-vendor/{cranelift-codegen-0.96.4 → cranelift-codegen-0.97.1}/src/write.rs +0 -0
  1486. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/LICENSE +0 -0
  1487. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/README.md +0 -0
  1488. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/formats.rs +0 -0
  1489. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/instructions.rs +0 -0
  1490. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/isa.rs +0 -0
  1491. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/mod.rs +0 -0
  1492. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/operands.rs +0 -0
  1493. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/settings.rs +0 -0
  1494. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/types.rs +0 -0
  1495. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/cdsl/typevar.rs +0 -0
  1496. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/constant_hash.rs +0 -0
  1497. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/error.rs +0 -0
  1498. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/gen_inst.rs +0 -0
  1499. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/gen_settings.rs +0 -0
  1500. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/gen_types.rs +0 -0
  1501. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/isa/arm64.rs +0 -0
  1502. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/isa/mod.rs +0 -0
  1503. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/isa/riscv64.rs +0 -0
  1504. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/isa/s390x.rs +0 -0
  1505. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/lib.rs +0 -0
  1506. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/shared/entities.rs +0 -0
  1507. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/shared/formats.rs +0 -0
  1508. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/shared/immediates.rs +0 -0
  1509. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/shared/instructions.rs +0 -0
  1510. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/shared/mod.rs +0 -0
  1511. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/shared/types.rs +0 -0
  1512. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/srcgen.rs +0 -0
  1513. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.96.4 → cranelift-codegen-meta-0.97.1}/src/unique_table.rs +0 -0
  1514. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.96.4 → cranelift-codegen-shared-0.97.1}/LICENSE +0 -0
  1515. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.96.4 → cranelift-codegen-shared-0.97.1}/README.md +0 -0
  1516. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.96.4 → cranelift-codegen-shared-0.97.1}/src/constant_hash.rs +0 -0
  1517. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.96.4 → cranelift-codegen-shared-0.97.1}/src/constants.rs +0 -0
  1518. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.96.4 → cranelift-codegen-shared-0.97.1}/src/lib.rs +0 -0
  1519. /data/ext/cargo-vendor/{cranelift-control-0.96.4 → cranelift-control-0.97.1}/LICENSE +0 -0
  1520. /data/ext/cargo-vendor/{cranelift-control-0.96.4 → cranelift-control-0.97.1}/README.md +0 -0
  1521. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/LICENSE +0 -0
  1522. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/README.md +0 -0
  1523. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/boxed_slice.rs +0 -0
  1524. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/iter.rs +0 -0
  1525. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/keys.rs +0 -0
  1526. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/lib.rs +0 -0
  1527. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/map.rs +0 -0
  1528. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/packed_option.rs +0 -0
  1529. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/primary.rs +0 -0
  1530. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/set.rs +0 -0
  1531. /data/ext/cargo-vendor/{cranelift-entity-0.96.4 → cranelift-entity-0.97.1}/src/sparse.rs +0 -0
  1532. /data/ext/cargo-vendor/{cranelift-frontend-0.96.4 → cranelift-frontend-0.97.1}/LICENSE +0 -0
  1533. /data/ext/cargo-vendor/{cranelift-frontend-0.96.4 → cranelift-frontend-0.97.1}/README.md +0 -0
  1534. /data/ext/cargo-vendor/{cranelift-frontend-0.96.4 → cranelift-frontend-0.97.1}/src/frontend.rs +0 -0
  1535. /data/ext/cargo-vendor/{cranelift-frontend-0.96.4 → cranelift-frontend-0.97.1}/src/lib.rs +0 -0
  1536. /data/ext/cargo-vendor/{cranelift-frontend-0.96.4 → cranelift-frontend-0.97.1}/src/ssa.rs +0 -0
  1537. /data/ext/cargo-vendor/{cranelift-frontend-0.96.4 → cranelift-frontend-0.97.1}/src/switch.rs +0 -0
  1538. /data/ext/cargo-vendor/{cranelift-frontend-0.96.4 → cranelift-frontend-0.97.1}/src/variable.rs +0 -0
  1539. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/README.md +0 -0
  1540. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/build.rs +0 -0
  1541. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/bad_converters.isle +0 -0
  1542. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
  1543. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
  1544. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/error1.isle +0 -0
  1545. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/extra_parens.isle +0 -0
  1546. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/impure_expression.isle +0 -0
  1547. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/impure_rhs.isle +0 -0
  1548. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/multi_internal_etor.isle +0 -0
  1549. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/fail/multi_prio.isle +0 -0
  1550. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/borrows.isle +0 -0
  1551. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/borrows_main.rs +0 -0
  1552. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/iflets.isle +0 -0
  1553. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/iflets_main.rs +0 -0
  1554. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/multi_constructor.isle +0 -0
  1555. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/multi_constructor_main.rs +0 -0
  1556. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/multi_extractor.isle +0 -0
  1557. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/multi_extractor_main.rs +0 -0
  1558. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/test.isle +0 -0
  1559. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/link/test_main.rs +0 -0
  1560. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/bound_var.isle +0 -0
  1561. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/construct_and_extract.isle +0 -0
  1562. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/conversions.isle +0 -0
  1563. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/conversions_extern.isle +0 -0
  1564. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/let.isle +0 -0
  1565. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/nodebug.isle +0 -0
  1566. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/prio_trie_bug.isle +0 -0
  1567. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/test2.isle +0 -0
  1568. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/test3.isle +0 -0
  1569. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/test4.isle +0 -0
  1570. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/pass/tutorial.isle +0 -0
  1571. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/run/iconst.isle +0 -0
  1572. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/run/iconst_main.rs +0 -0
  1573. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/run/let_shadowing.isle +0 -0
  1574. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/isle_examples/run/let_shadowing_main.rs +0 -0
  1575. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/ast.rs +0 -0
  1576. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/codegen.rs +0 -0
  1577. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/compile.rs +0 -0
  1578. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/error.rs +0 -0
  1579. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/lexer.rs +0 -0
  1580. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/lib.rs +0 -0
  1581. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/log.rs +0 -0
  1582. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/overlap.rs +0 -0
  1583. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/parser.rs +0 -0
  1584. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/sema.rs +0 -0
  1585. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/serialize.rs +0 -0
  1586. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/src/trie_again.rs +0 -0
  1587. /data/ext/cargo-vendor/{cranelift-isle-0.96.4 → cranelift-isle-0.97.1}/tests/run_tests.rs +0 -0
  1588. /data/ext/cargo-vendor/{cranelift-native-0.96.4 → cranelift-native-0.97.1}/LICENSE +0 -0
  1589. /data/ext/cargo-vendor/{cranelift-native-0.96.4 → cranelift-native-0.97.1}/README.md +0 -0
  1590. /data/ext/cargo-vendor/{cranelift-native-0.96.4 → cranelift-native-0.97.1}/src/riscv.rs +0 -0
  1591. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/LICENSE +0 -0
  1592. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/README.md +0 -0
  1593. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/src/code_translator/bounds_checks.rs +0 -0
  1594. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/src/environ/mod.rs +0 -0
  1595. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/src/heap.rs +0 -0
  1596. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/src/lib.rs +0 -0
  1597. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/src/module_translator.rs +0 -0
  1598. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/src/state.rs +0 -0
  1599. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/tests/wasm_testsuite.rs +0 -0
  1600. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/arith.wat +0 -0
  1601. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/br_table.wat +0 -0
  1602. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/call-simd.wat +0 -0
  1603. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/call.wat +0 -0
  1604. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/embenchen_fannkuch.wat +0 -0
  1605. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/embenchen_fasta.wat +0 -0
  1606. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/embenchen_ifs.wat +0 -0
  1607. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/embenchen_primes.wat +0 -0
  1608. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/fac-multi-value.wat +0 -0
  1609. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/fibonacci.wat +0 -0
  1610. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/globals.wat +0 -0
  1611. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/icall-simd.wat +0 -0
  1612. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/icall.wat +0 -0
  1613. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-reachability-translation-0.wat +0 -0
  1614. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-reachability-translation-1.wat +0 -0
  1615. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-reachability-translation-2.wat +0 -0
  1616. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-reachability-translation-3.wat +0 -0
  1617. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-reachability-translation-4.wat +0 -0
  1618. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-reachability-translation-5.wat +0 -0
  1619. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-reachability-translation-6.wat +0 -0
  1620. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-unreachable-else-params-2.wat +0 -0
  1621. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/if-unreachable-else-params.wat +0 -0
  1622. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/issue-1306-name-section-with-u32-max-function-index.wasm +0 -0
  1623. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/memory.wat +0 -0
  1624. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-0.wat +0 -0
  1625. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-1.wat +0 -0
  1626. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-10.wat +0 -0
  1627. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-11.wat +0 -0
  1628. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-12.wat +0 -0
  1629. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-13.wat +0 -0
  1630. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-14.wat +0 -0
  1631. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-15.wat +0 -0
  1632. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-16.wat +0 -0
  1633. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-17.wat +0 -0
  1634. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-2.wat +0 -0
  1635. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-3.wat +0 -0
  1636. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-4.wat +0 -0
  1637. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-5.wat +0 -0
  1638. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-6.wat +0 -0
  1639. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-7.wat +0 -0
  1640. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-8.wat +0 -0
  1641. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/multi-9.wat +0 -0
  1642. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/nullref.wat +0 -0
  1643. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/passive-data.wat +0 -0
  1644. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/pr2303.wat +0 -0
  1645. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/pr2559.wat +0 -0
  1646. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/ref-func-0.wat +0 -0
  1647. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/rust_fannkuch.wat +0 -0
  1648. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/select.wat +0 -0
  1649. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/simd-store.wat +0 -0
  1650. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/simd.wat +0 -0
  1651. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/table-copy.wat +0 -0
  1652. /data/ext/cargo-vendor/{cranelift-wasm-0.96.4 → cranelift-wasm-0.97.1}/wasmtests/unreachable_code.wat +0 -0
  1653. /data/ext/cargo-vendor/{file-per-thread-logger-0.1.6 → file-per-thread-logger-0.2.0}/LICENSE +0 -0
  1654. /data/ext/cargo-vendor/{file-per-thread-logger-0.1.6 → file-per-thread-logger-0.2.0}/README.md +0 -0
  1655. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/LICENSE +0 -0
  1656. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/README.md +0 -0
  1657. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/doc/DESIGN.md +0 -0
  1658. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/doc/TODO +0 -0
  1659. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/cfg.rs +0 -0
  1660. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/domtree.rs +0 -0
  1661. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/fuzzing/mod.rs +0 -0
  1662. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/indexset.rs +0 -0
  1663. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/ion/dump.rs +0 -0
  1664. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/ion/redundant_moves.rs +0 -0
  1665. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/ion/reg_traversal.rs +0 -0
  1666. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/postorder.rs +0 -0
  1667. /data/ext/cargo-vendor/{regalloc2-0.8.1 → regalloc2-0.9.2}/src/ssa.rs +0 -0
  1668. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/LICENSE +0 -0
  1669. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/README.md +0 -0
  1670. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/src/clocks.rs +0 -0
  1671. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/src/file.rs +0 -0
  1672. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/src/net.rs +0 -0
  1673. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/src/sched/unix.rs +0 -0
  1674. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/src/sched/windows.rs +0 -0
  1675. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/src/sched.rs +0 -0
  1676. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.0}/src/stdio.rs +0 -0
  1677. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/LICENSE +0 -0
  1678. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/README.md +0 -0
  1679. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/README.md +0 -0
  1680. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/docs/README.md +0 -0
  1681. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/README.md +0 -0
  1682. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/docs.md +0 -0
  1683. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/typenames.witx +0 -0
  1684. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_args.witx +0 -0
  1685. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_clock.witx +0 -0
  1686. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_environ.witx +0 -0
  1687. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_fd.witx +0 -0
  1688. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_path.witx +0 -0
  1689. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_poll.witx +0 -0
  1690. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_proc.witx +0 -0
  1691. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_random.witx +0 -0
  1692. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_sched.witx +0 -0
  1693. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_sock.witx +0 -0
  1694. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/old/snapshot_0/docs.md +0 -0
  1695. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/old/snapshot_0/witx/typenames.witx +0 -0
  1696. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/old/snapshot_0/witx/wasi_unstable.witx +0 -0
  1697. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/snapshot/docs.html +0 -0
  1698. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/snapshot/docs.md +0 -0
  1699. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/snapshot/witx/typenames.witx +0 -0
  1700. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/phases/snapshot/witx/wasi_snapshot_preview1.witx +0 -0
  1701. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/proposal-template/README.md +0 -0
  1702. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/proposals/README.md +0 -0
  1703. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/snapshots/README.md +0 -0
  1704. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/WASI/standard/README.md +0 -0
  1705. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/build.rs +0 -0
  1706. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/clocks.rs +0 -0
  1707. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/dir.rs +0 -0
  1708. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/error.rs +0 -0
  1709. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/lib.rs +0 -0
  1710. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/pipe.rs +0 -0
  1711. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/random.rs +0 -0
  1712. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/sched/subscription.rs +0 -0
  1713. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/sched.rs +0 -0
  1714. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/snapshots/mod.rs +0 -0
  1715. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/snapshots/preview_0.rs +0 -0
  1716. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/snapshots/preview_1/error.rs +0 -0
  1717. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/string_array.rs +0 -0
  1718. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.0}/src/table.rs +0 -0
  1719. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasm-encoder-0.29.0}/LICENSE +0 -0
  1720. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmparser-0.107.0}/LICENSE +0 -0
  1721. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/README.md +0 -0
  1722. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/examples/simple.rs +0 -0
  1723. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/limits.rs +0 -0
  1724. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/component/aliases.rs +0 -0
  1725. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/component/names.rs +0 -0
  1726. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/component/start.rs +0 -0
  1727. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/component.rs +0 -0
  1728. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/code.rs +0 -0
  1729. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/custom.rs +0 -0
  1730. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/data.rs +0 -0
  1731. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/elements.rs +0 -0
  1732. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/exports.rs +0 -0
  1733. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/functions.rs +0 -0
  1734. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/globals.rs +0 -0
  1735. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/imports.rs +0 -0
  1736. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/init.rs +0 -0
  1737. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/memories.rs +0 -0
  1738. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/names.rs +0 -0
  1739. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/operators.rs +0 -0
  1740. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/tables.rs +0 -0
  1741. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers/core/tags.rs +0 -0
  1742. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/readers.rs +0 -0
  1743. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/resources.rs +0 -0
  1744. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/src/validator/func.rs +0 -0
  1745. /data/ext/cargo-vendor/{wasmparser-0.103.0 → wasmparser-0.107.0}/tests/big-module.rs +0 -0
  1746. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmparser-0.111.0}/LICENSE +0 -0
  1747. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmprinter-0.2.63}/LICENSE +0 -0
  1748. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-10.0.0}/LICENSE +0 -0
  1749. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/README.md +0 -0
  1750. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/code.rs +0 -0
  1751. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/func/host.rs +0 -0
  1752. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/func/options.rs +0 -0
  1753. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/func/typed.rs +0 -0
  1754. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/func.rs +0 -0
  1755. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/linker.rs +0 -0
  1756. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/storage.rs +0 -0
  1757. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/store.rs +0 -0
  1758. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/types.rs +0 -0
  1759. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/component/values.rs +0 -0
  1760. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/limits.rs +0 -0
  1761. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/module/registry.rs +0 -0
  1762. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/profiling.rs +0 -0
  1763. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/signatures.rs +0 -0
  1764. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/store/data.rs +0 -0
  1765. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/trampoline/memory.rs +0 -0
  1766. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/trampoline/table.rs +0 -0
  1767. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/trampoline.rs +0 -0
  1768. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/trap.rs +0 -0
  1769. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/unix.rs +0 -0
  1770. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.0}/src/windows.rs +0 -0
  1771. /data/ext/cargo-vendor/{wasmtime-asm-macros-9.0.4 → wasmtime-asm-macros-10.0.0}/src/lib.rs +0 -0
  1772. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-cache-10.0.0}/LICENSE +0 -0
  1773. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/build.rs +0 -0
  1774. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/src/config/tests.rs +0 -0
  1775. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/src/config.rs +0 -0
  1776. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/src/lib.rs +0 -0
  1777. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/src/tests.rs +0 -0
  1778. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/src/worker/tests/system_time_stub.rs +0 -0
  1779. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/src/worker/tests.rs +0 -0
  1780. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/src/worker.rs +0 -0
  1781. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.0}/tests/cache_write_default_config.rs +0 -0
  1782. /data/ext/cargo-vendor/{wasmtime-component-macro-9.0.4 → wasmtime-component-macro-10.0.0}/src/component.rs +0 -0
  1783. /data/ext/cargo-vendor/{wasmtime-component-macro-9.0.4 → wasmtime-component-macro-10.0.0}/src/lib.rs +0 -0
  1784. /data/ext/cargo-vendor/{wasmtime-component-util-9.0.4 → wasmtime-component-util-10.0.0}/src/lib.rs +0 -0
  1785. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-cranelift-10.0.0}/LICENSE +0 -0
  1786. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/SECURITY.md +0 -0
  1787. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/builder.rs +0 -0
  1788. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/compiler/component.rs +0 -0
  1789. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/gc.rs +0 -0
  1790. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/address_transform.rs +0 -0
  1791. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/attr.rs +0 -0
  1792. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/expression.rs +0 -0
  1793. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/line_program.rs +0 -0
  1794. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/mod.rs +0 -0
  1795. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/range_info_builder.rs +0 -0
  1796. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/refs.rs +0 -0
  1797. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/unit.rs +0 -0
  1798. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/transform/utils.rs +0 -0
  1799. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug/write_debuginfo.rs +0 -0
  1800. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.0}/src/debug.rs +0 -0
  1801. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-9.0.4 → wasmtime-cranelift-shared-10.0.0}/src/compiled_function.rs +0 -0
  1802. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-9.0.4 → wasmtime-cranelift-shared-10.0.0}/src/isa_builder.rs +0 -0
  1803. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-9.0.4 → wasmtime-cranelift-shared-10.0.0}/src/obj.rs +0 -0
  1804. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-environ-10.0.0}/LICENSE +0 -0
  1805. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/examples/factc.rs +0 -0
  1806. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/address_map.rs +0 -0
  1807. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/builtin.rs +0 -0
  1808. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/compilation.rs +0 -0
  1809. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/component/dfg.rs +0 -0
  1810. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/component/info.rs +0 -0
  1811. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/component/translate/adapt.rs +0 -0
  1812. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/component/vmcomponent_offsets.rs +0 -0
  1813. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/component.rs +0 -0
  1814. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/fact/core_types.rs +0 -0
  1815. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/fact/signature.rs +0 -0
  1816. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/fact/trampoline.rs +0 -0
  1817. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/fact/transcode.rs +0 -0
  1818. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/fact/traps.rs +0 -0
  1819. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/lib.rs +0 -0
  1820. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/module_types.rs +0 -0
  1821. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/obj.rs +0 -0
  1822. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/ref_bits.rs +0 -0
  1823. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/scopevec.rs +0 -0
  1824. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/stack_map.rs +0 -0
  1825. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/tunables.rs +0 -0
  1826. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.0}/src/vmoffsets.rs +0 -0
  1827. /data/ext/cargo-vendor/{wasmtime-types-9.0.4 → wasmtime-fiber-10.0.0}/LICENSE +0 -0
  1828. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/build.rs +0 -0
  1829. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/src/unix/aarch64.rs +0 -0
  1830. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/src/unix/arm.rs +0 -0
  1831. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/src/unix/riscv64.rs +0 -0
  1832. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/src/unix/s390x.S +0 -0
  1833. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/src/unix/x86.rs +0 -0
  1834. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/src/unix/x86_64.rs +0 -0
  1835. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.0}/src/windows.c +0 -0
  1836. /data/ext/cargo-vendor/{wasmtime-wasi-9.0.4 → wasmtime-jit-10.0.0}/LICENSE +0 -0
  1837. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.0}/src/code_memory.rs +0 -0
  1838. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.0}/src/debug.rs +0 -0
  1839. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.0}/src/demangling.rs +0 -0
  1840. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.0}/src/unwind/miri.rs +0 -0
  1841. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.0}/src/unwind/systemv.rs +0 -0
  1842. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.0}/src/unwind/winx64.rs +0 -0
  1843. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.0}/src/unwind.rs +0 -0
  1844. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.0}/README.md +0 -0
  1845. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.0}/src/gdb_jit_int.rs +0 -0
  1846. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.0}/src/lib.rs +0 -0
  1847. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.0}/src/perf_jitdump.rs +0 -0
  1848. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.0}/src/lib.rs +0 -0
  1849. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.0}/src/libc.rs +0 -0
  1850. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.0}/src/miri.rs +0 -0
  1851. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.0}/src/win.rs +0 -0
  1852. /data/ext/cargo-vendor/{wiggle-9.0.4 → wasmtime-runtime-10.0.0}/LICENSE +0 -0
  1853. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/build.rs +0 -0
  1854. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/component/transcode.rs +0 -0
  1855. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/export.rs +0 -0
  1856. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/helpers.c +0 -0
  1857. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/imports.rs +0 -0
  1858. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/instance/allocator/pooling/index_allocator.rs +0 -0
  1859. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/instance/allocator/pooling/unix.rs +0 -0
  1860. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/instance/allocator/pooling/windows.rs +0 -0
  1861. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/mmap.rs +0 -0
  1862. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/mmap_vec.rs +0 -0
  1863. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/module_id.rs +0 -0
  1864. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/parking_spot.rs +0 -0
  1865. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/store_box.rs +0 -0
  1866. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/trampolines/aarch64.rs +0 -0
  1867. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/trampolines/riscv64.rs +0 -0
  1868. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/trampolines/s390x.S +0 -0
  1869. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/trampolines/s390x.rs +0 -0
  1870. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/trampolines/x86_64.rs +0 -0
  1871. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/trampolines.rs +0 -0
  1872. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/traphandlers/backtrace/aarch64.rs +0 -0
  1873. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/traphandlers/backtrace/riscv64.rs +0 -0
  1874. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/traphandlers/backtrace/s390x.rs +0 -0
  1875. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/traphandlers/backtrace/x86_64.rs +0 -0
  1876. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/traphandlers/backtrace.rs +0 -0
  1877. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/traphandlers/macos.rs +0 -0
  1878. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.0}/src/traphandlers/windows.rs +0 -0
  1879. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wasmtime-types-10.0.1}/LICENSE +0 -0
  1880. /data/ext/cargo-vendor/{wasmtime-types-9.0.4 → wasmtime-types-10.0.1}/src/error.rs +0 -0
  1881. /data/ext/cargo-vendor/{wiggle-macro-9.0.4 → wasmtime-wasi-10.0.0}/LICENSE +0 -0
  1882. /data/ext/cargo-vendor/{wasmtime-wasi-9.0.4 → wasmtime-wasi-10.0.0}/README.md +0 -0
  1883. /data/ext/cargo-vendor/{wasmtime-wasi-9.0.4 → wasmtime-wasi-10.0.0}/build.rs +0 -0
  1884. /data/ext/cargo-vendor/{wasmtime-winch-9.0.4 → wasmtime-winch-10.0.0}/LICENSE +0 -0
  1885. /data/ext/cargo-vendor/{wasmtime-winch-9.0.4 → wasmtime-winch-10.0.0}/src/builder.rs +0 -0
  1886. /data/ext/cargo-vendor/{wasmtime-winch-9.0.4 → wasmtime-winch-10.0.0}/src/lib.rs +0 -0
  1887. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-9.0.4 → wasmtime-wit-bindgen-10.0.0}/src/rust.rs +0 -0
  1888. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-9.0.4 → wasmtime-wit-bindgen-10.0.0}/src/source.rs +0 -0
  1889. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.0}/src/borrow.rs +0 -0
  1890. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.0}/src/error.rs +0 -0
  1891. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.0}/src/guest_type.rs +0 -0
  1892. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.0}/src/lib.rs +0 -0
  1893. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.0}/src/region.rs +0 -0
  1894. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.0}/src/wasmtime.rs +0 -0
  1895. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/README.md +0 -0
  1896. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/codegen_settings.rs +0 -0
  1897. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/config.rs +0 -0
  1898. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/funcs.rs +0 -0
  1899. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/lib.rs +0 -0
  1900. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/lifetimes.rs +0 -0
  1901. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/module_trait.rs +0 -0
  1902. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/names.rs +0 -0
  1903. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/types/error.rs +0 -0
  1904. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/types/flags.rs +0 -0
  1905. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/types/handle.rs +0 -0
  1906. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/types/mod.rs +0 -0
  1907. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/types/record.rs +0 -0
  1908. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/types/variant.rs +0 -0
  1909. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.0}/src/wasmtime.rs +0 -0
  1910. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.0}/LICENSE +0 -0
  1911. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.0}/build.rs +0 -0
  1912. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.0}/src/isa/aarch64/address.rs +0 -0
  1913. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.0}/src/isa/reg.rs +0 -0
  1914. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.0}/src/regset.rs +0 -0
  1915. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/README.md +0 -0
  1916. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/src/abi.rs +0 -0
  1917. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/src/ast/toposort.rs +0 -0
  1918. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/src/sizealign.rs +0 -0
  1919. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/alias-no-type.wit +0 -0
  1920. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/async.wit.result +0 -0
  1921. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/async1.wit.result +0 -0
  1922. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/bad-list.wit +0 -0
  1923. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/bad-list.wit.result +0 -0
  1924. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/dangling-type.wit +0 -0
  1925. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/dangling-type.wit.result +0 -0
  1926. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/invalid-md.md +0 -0
  1927. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/invalid-toplevel.wit +0 -0
  1928. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/invalid-toplevel.wit.result +0 -0
  1929. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/keyword.wit +0 -0
  1930. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/keyword.wit.result +0 -0
  1931. /data/ext/cargo-vendor/{wit-parser-0.7.1/tests/ui/empty.wit → wit-parser-0.8.0/tests/ui/parse-fail/missing-package.wit} +0 -0
  1932. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/unresolved-use10/foo.wit +0 -0
  1933. /data/ext/cargo-vendor/{wit-parser-0.7.1 → wit-parser-0.8.0}/tests/ui/parse-fail/unterminated-string.wit.result +0 -0
@@ -1,3409 +0,0 @@
1
- //! This module defines s390x-specific machine instruction types.
2
-
3
- use crate::binemit::{Addend, CodeOffset, Reloc};
4
- use crate::ir::{types, ExternalName, Opcode, Type};
5
- use crate::isa::s390x::abi::S390xMachineDeps;
6
- use crate::isa::{CallConv, FunctionAlignment};
7
- use crate::machinst::*;
8
- use crate::{settings, CodegenError, CodegenResult};
9
- use alloc::boxed::Box;
10
- use alloc::vec::Vec;
11
- use regalloc2::{PRegSet, VReg};
12
- use smallvec::SmallVec;
13
- use std::string::{String, ToString};
14
- pub mod regs;
15
- pub use self::regs::*;
16
- pub mod imms;
17
- pub use self::imms::*;
18
- pub mod args;
19
- pub use self::args::*;
20
- pub mod emit;
21
- pub use self::emit::*;
22
- pub mod unwind;
23
-
24
- #[cfg(test)]
25
- mod emit_tests;
26
-
27
- //=============================================================================
28
- // Instructions (top level): definition
29
-
30
- pub use crate::isa::s390x::lower::isle::generated_code::{
31
- ALUOp, CmpOp, FPUOp1, FPUOp2, FPUOp3, FpuRoundMode, FpuRoundOp, LaneOrder, MInst as Inst,
32
- RxSBGOp, ShiftOp, SymbolReloc, UnaryOp, VecBinaryOp, VecFloatCmpOp, VecIntCmpOp, VecShiftOp,
33
- VecUnaryOp,
34
- };
35
-
36
- /// Additional information for (direct) Call instructions, left out of line to lower the size of
37
- /// the Inst enum.
38
- #[derive(Clone, Debug)]
39
- pub struct CallInfo {
40
- pub dest: ExternalName,
41
- pub uses: CallArgList,
42
- pub defs: CallRetList,
43
- pub clobbers: PRegSet,
44
- pub opcode: Opcode,
45
- pub caller_callconv: CallConv,
46
- pub callee_callconv: CallConv,
47
- pub tls_symbol: Option<SymbolReloc>,
48
- }
49
-
50
- /// Additional information for CallInd instructions, left out of line to lower the size of the Inst
51
- /// enum.
52
- #[derive(Clone, Debug)]
53
- pub struct CallIndInfo {
54
- pub rn: Reg,
55
- pub uses: CallArgList,
56
- pub defs: CallRetList,
57
- pub clobbers: PRegSet,
58
- pub opcode: Opcode,
59
- pub caller_callconv: CallConv,
60
- pub callee_callconv: CallConv,
61
- }
62
-
63
- #[test]
64
- fn inst_size_test() {
65
- // This test will help with unintentionally growing the size
66
- // of the Inst enum.
67
- assert_eq!(32, std::mem::size_of::<Inst>());
68
- }
69
-
70
- /// A register pair. Enum so it can be destructured in ISLE.
71
- #[derive(Clone, Copy, Debug)]
72
- pub struct RegPair {
73
- pub hi: Reg,
74
- pub lo: Reg,
75
- }
76
-
77
- /// A writable register pair. Enum so it can be destructured in ISLE.
78
- #[derive(Clone, Copy, Debug)]
79
- pub struct WritableRegPair {
80
- pub hi: Writable<Reg>,
81
- pub lo: Writable<Reg>,
82
- }
83
-
84
- impl WritableRegPair {
85
- pub fn to_regpair(&self) -> RegPair {
86
- RegPair {
87
- hi: self.hi.to_reg(),
88
- lo: self.lo.to_reg(),
89
- }
90
- }
91
- }
92
-
93
- /// Supported instruction sets
94
- #[allow(non_camel_case_types)]
95
- #[derive(Debug)]
96
- pub(crate) enum InstructionSet {
97
- /// Baseline ISA for cranelift is z14.
98
- Base,
99
- /// Miscellaneous-Instruction-Extensions Facility 2 (z15)
100
- MIE2,
101
- /// Vector-Enhancements Facility 2 (z15)
102
- VXRS_EXT2,
103
- }
104
-
105
- impl Inst {
106
- /// Retrieve the ISA feature set in which the instruction is available.
107
- fn available_in_isa(&self) -> InstructionSet {
108
- match self {
109
- // These instructions are part of the baseline ISA for cranelift (z14)
110
- Inst::Nop0
111
- | Inst::Nop2
112
- | Inst::AluRRSImm16 { .. }
113
- | Inst::AluRR { .. }
114
- | Inst::AluRX { .. }
115
- | Inst::AluRSImm16 { .. }
116
- | Inst::AluRSImm32 { .. }
117
- | Inst::AluRUImm32 { .. }
118
- | Inst::AluRUImm16Shifted { .. }
119
- | Inst::AluRUImm32Shifted { .. }
120
- | Inst::ShiftRR { .. }
121
- | Inst::RxSBG { .. }
122
- | Inst::RxSBGTest { .. }
123
- | Inst::SMulWide { .. }
124
- | Inst::UMulWide { .. }
125
- | Inst::SDivMod32 { .. }
126
- | Inst::SDivMod64 { .. }
127
- | Inst::UDivMod32 { .. }
128
- | Inst::UDivMod64 { .. }
129
- | Inst::Flogr { .. }
130
- | Inst::CmpRR { .. }
131
- | Inst::CmpRX { .. }
132
- | Inst::CmpRSImm16 { .. }
133
- | Inst::CmpRSImm32 { .. }
134
- | Inst::CmpRUImm32 { .. }
135
- | Inst::CmpTrapRR { .. }
136
- | Inst::CmpTrapRSImm16 { .. }
137
- | Inst::CmpTrapRUImm16 { .. }
138
- | Inst::AtomicRmw { .. }
139
- | Inst::AtomicCas32 { .. }
140
- | Inst::AtomicCas64 { .. }
141
- | Inst::Fence
142
- | Inst::Load32 { .. }
143
- | Inst::Load32ZExt8 { .. }
144
- | Inst::Load32SExt8 { .. }
145
- | Inst::Load32ZExt16 { .. }
146
- | Inst::Load32SExt16 { .. }
147
- | Inst::Load64 { .. }
148
- | Inst::Load64ZExt8 { .. }
149
- | Inst::Load64SExt8 { .. }
150
- | Inst::Load64ZExt16 { .. }
151
- | Inst::Load64SExt16 { .. }
152
- | Inst::Load64ZExt32 { .. }
153
- | Inst::Load64SExt32 { .. }
154
- | Inst::LoadRev16 { .. }
155
- | Inst::LoadRev32 { .. }
156
- | Inst::LoadRev64 { .. }
157
- | Inst::Store8 { .. }
158
- | Inst::Store16 { .. }
159
- | Inst::Store32 { .. }
160
- | Inst::Store64 { .. }
161
- | Inst::StoreImm8 { .. }
162
- | Inst::StoreImm16 { .. }
163
- | Inst::StoreImm32SExt16 { .. }
164
- | Inst::StoreImm64SExt16 { .. }
165
- | Inst::StoreRev16 { .. }
166
- | Inst::StoreRev32 { .. }
167
- | Inst::StoreRev64 { .. }
168
- | Inst::Mvc { .. }
169
- | Inst::LoadMultiple64 { .. }
170
- | Inst::StoreMultiple64 { .. }
171
- | Inst::Mov32 { .. }
172
- | Inst::Mov64 { .. }
173
- | Inst::MovPReg { .. }
174
- | Inst::Mov32Imm { .. }
175
- | Inst::Mov32SImm16 { .. }
176
- | Inst::Mov64SImm16 { .. }
177
- | Inst::Mov64SImm32 { .. }
178
- | Inst::Mov64UImm16Shifted { .. }
179
- | Inst::Mov64UImm32Shifted { .. }
180
- | Inst::Insert64UImm16Shifted { .. }
181
- | Inst::Insert64UImm32Shifted { .. }
182
- | Inst::LoadAR { .. }
183
- | Inst::InsertAR { .. }
184
- | Inst::Extend { .. }
185
- | Inst::CMov32 { .. }
186
- | Inst::CMov64 { .. }
187
- | Inst::CMov32SImm16 { .. }
188
- | Inst::CMov64SImm16 { .. }
189
- | Inst::FpuMove32 { .. }
190
- | Inst::FpuMove64 { .. }
191
- | Inst::FpuCMov32 { .. }
192
- | Inst::FpuCMov64 { .. }
193
- | Inst::FpuRR { .. }
194
- | Inst::FpuRRR { .. }
195
- | Inst::FpuRRRR { .. }
196
- | Inst::FpuCmp32 { .. }
197
- | Inst::FpuCmp64 { .. }
198
- | Inst::LoadFpuConst32 { .. }
199
- | Inst::LoadFpuConst64 { .. }
200
- | Inst::VecRRR { .. }
201
- | Inst::VecRR { .. }
202
- | Inst::VecShiftRR { .. }
203
- | Inst::VecSelect { .. }
204
- | Inst::VecPermute { .. }
205
- | Inst::VecPermuteDWImm { .. }
206
- | Inst::VecIntCmp { .. }
207
- | Inst::VecIntCmpS { .. }
208
- | Inst::VecFloatCmp { .. }
209
- | Inst::VecFloatCmpS { .. }
210
- | Inst::VecInt128SCmpHi { .. }
211
- | Inst::VecInt128UCmpHi { .. }
212
- | Inst::VecLoad { .. }
213
- | Inst::VecStore { .. }
214
- | Inst::VecLoadReplicate { .. }
215
- | Inst::VecMov { .. }
216
- | Inst::VecCMov { .. }
217
- | Inst::MovToVec128 { .. }
218
- | Inst::VecLoadConst { .. }
219
- | Inst::VecLoadConstReplicate { .. }
220
- | Inst::VecImmByteMask { .. }
221
- | Inst::VecImmBitMask { .. }
222
- | Inst::VecImmReplicate { .. }
223
- | Inst::VecLoadLane { .. }
224
- | Inst::VecLoadLaneUndef { .. }
225
- | Inst::VecStoreLane { .. }
226
- | Inst::VecInsertLane { .. }
227
- | Inst::VecInsertLaneUndef { .. }
228
- | Inst::VecExtractLane { .. }
229
- | Inst::VecInsertLaneImm { .. }
230
- | Inst::VecReplicateLane { .. }
231
- | Inst::Call { .. }
232
- | Inst::CallInd { .. }
233
- | Inst::Args { .. }
234
- | Inst::Ret { .. }
235
- | Inst::Jump { .. }
236
- | Inst::CondBr { .. }
237
- | Inst::TrapIf { .. }
238
- | Inst::OneWayCondBr { .. }
239
- | Inst::IndirectBr { .. }
240
- | Inst::Debugtrap
241
- | Inst::Trap { .. }
242
- | Inst::JTSequence { .. }
243
- | Inst::LoadSymbolReloc { .. }
244
- | Inst::LoadAddr { .. }
245
- | Inst::Loop { .. }
246
- | Inst::CondBreak { .. }
247
- | Inst::VirtualSPOffsetAdj { .. }
248
- | Inst::Unwind { .. } => InstructionSet::Base,
249
-
250
- // These depend on the opcode
251
- Inst::AluRRR { alu_op, .. } => match alu_op {
252
- ALUOp::NotAnd32 | ALUOp::NotAnd64 => InstructionSet::MIE2,
253
- ALUOp::NotOrr32 | ALUOp::NotOrr64 => InstructionSet::MIE2,
254
- ALUOp::NotXor32 | ALUOp::NotXor64 => InstructionSet::MIE2,
255
- ALUOp::AndNot32 | ALUOp::AndNot64 => InstructionSet::MIE2,
256
- ALUOp::OrrNot32 | ALUOp::OrrNot64 => InstructionSet::MIE2,
257
- _ => InstructionSet::Base,
258
- },
259
- Inst::UnaryRR { op, .. } => match op {
260
- UnaryOp::PopcntReg => InstructionSet::MIE2,
261
- _ => InstructionSet::Base,
262
- },
263
- Inst::FpuRound { op, .. } => match op {
264
- FpuRoundOp::ToSInt32 | FpuRoundOp::FromSInt32 => InstructionSet::VXRS_EXT2,
265
- FpuRoundOp::ToUInt32 | FpuRoundOp::FromUInt32 => InstructionSet::VXRS_EXT2,
266
- FpuRoundOp::ToSInt32x4 | FpuRoundOp::FromSInt32x4 => InstructionSet::VXRS_EXT2,
267
- FpuRoundOp::ToUInt32x4 | FpuRoundOp::FromUInt32x4 => InstructionSet::VXRS_EXT2,
268
- _ => InstructionSet::Base,
269
- },
270
-
271
- // These are all part of VXRS_EXT2
272
- Inst::VecLoadRev { .. }
273
- | Inst::VecLoadByte16Rev { .. }
274
- | Inst::VecLoadByte32Rev { .. }
275
- | Inst::VecLoadByte64Rev { .. }
276
- | Inst::VecLoadElt16Rev { .. }
277
- | Inst::VecLoadElt32Rev { .. }
278
- | Inst::VecLoadElt64Rev { .. }
279
- | Inst::VecStoreRev { .. }
280
- | Inst::VecStoreByte16Rev { .. }
281
- | Inst::VecStoreByte32Rev { .. }
282
- | Inst::VecStoreByte64Rev { .. }
283
- | Inst::VecStoreElt16Rev { .. }
284
- | Inst::VecStoreElt32Rev { .. }
285
- | Inst::VecStoreElt64Rev { .. }
286
- | Inst::VecLoadReplicateRev { .. }
287
- | Inst::VecLoadLaneRev { .. }
288
- | Inst::VecLoadLaneRevUndef { .. }
289
- | Inst::VecStoreLaneRev { .. } => InstructionSet::VXRS_EXT2,
290
-
291
- Inst::DummyUse { .. } => InstructionSet::Base,
292
- }
293
- }
294
-
295
- /// Create a 128-bit move instruction.
296
- pub fn mov128(to_reg: Writable<Reg>, from_reg: Reg) -> Inst {
297
- assert!(to_reg.to_reg().class() == RegClass::Float);
298
- assert!(from_reg.class() == RegClass::Float);
299
- Inst::VecMov {
300
- rd: to_reg,
301
- rn: from_reg,
302
- }
303
- }
304
-
305
- /// Create a 64-bit move instruction.
306
- pub fn mov64(to_reg: Writable<Reg>, from_reg: Reg) -> Inst {
307
- assert!(to_reg.to_reg().class() == from_reg.class());
308
- if from_reg.class() == RegClass::Int {
309
- Inst::Mov64 {
310
- rd: to_reg,
311
- rm: from_reg,
312
- }
313
- } else {
314
- Inst::FpuMove64 {
315
- rd: to_reg,
316
- rn: from_reg,
317
- }
318
- }
319
- }
320
-
321
- /// Create a 32-bit move instruction.
322
- pub fn mov32(to_reg: Writable<Reg>, from_reg: Reg) -> Inst {
323
- if from_reg.class() == RegClass::Int {
324
- Inst::Mov32 {
325
- rd: to_reg,
326
- rm: from_reg,
327
- }
328
- } else {
329
- Inst::FpuMove32 {
330
- rd: to_reg,
331
- rn: from_reg,
332
- }
333
- }
334
- }
335
-
336
- /// Generic constructor for a load (zero-extending where appropriate).
337
- pub fn gen_load(into_reg: Writable<Reg>, mem: MemArg, ty: Type) -> Inst {
338
- match ty {
339
- types::I8 => Inst::Load64ZExt8 { rd: into_reg, mem },
340
- types::I16 => Inst::Load64ZExt16 { rd: into_reg, mem },
341
- types::I32 => Inst::Load64ZExt32 { rd: into_reg, mem },
342
- types::I64 | types::R64 => Inst::Load64 { rd: into_reg, mem },
343
- types::F32 => Inst::VecLoadLaneUndef {
344
- size: 32,
345
- rd: into_reg,
346
- mem,
347
- lane_imm: 0,
348
- },
349
- types::F64 => Inst::VecLoadLaneUndef {
350
- size: 64,
351
- rd: into_reg,
352
- mem,
353
- lane_imm: 0,
354
- },
355
- _ if ty.is_vector() && ty.bits() == 128 => Inst::VecLoad { rd: into_reg, mem },
356
- types::I128 => Inst::VecLoad { rd: into_reg, mem },
357
- _ => unimplemented!("gen_load({})", ty),
358
- }
359
- }
360
-
361
- /// Generic constructor for a store.
362
- pub fn gen_store(mem: MemArg, from_reg: Reg, ty: Type) -> Inst {
363
- match ty {
364
- types::I8 => Inst::Store8 { rd: from_reg, mem },
365
- types::I16 => Inst::Store16 { rd: from_reg, mem },
366
- types::I32 => Inst::Store32 { rd: from_reg, mem },
367
- types::I64 | types::R64 => Inst::Store64 { rd: from_reg, mem },
368
- types::F32 => Inst::VecStoreLane {
369
- size: 32,
370
- rd: from_reg,
371
- mem,
372
- lane_imm: 0,
373
- },
374
- types::F64 => Inst::VecStoreLane {
375
- size: 64,
376
- rd: from_reg,
377
- mem,
378
- lane_imm: 0,
379
- },
380
- _ if ty.is_vector() && ty.bits() == 128 => Inst::VecStore { rd: from_reg, mem },
381
- types::I128 => Inst::VecStore { rd: from_reg, mem },
382
- _ => unimplemented!("gen_store({})", ty),
383
- }
384
- }
385
- }
386
-
387
- //=============================================================================
388
- // Instructions: get_regs
389
-
390
- fn memarg_operands<F: Fn(VReg) -> VReg>(memarg: &MemArg, collector: &mut OperandCollector<'_, F>) {
391
- match memarg {
392
- &MemArg::BXD12 { base, index, .. } | &MemArg::BXD20 { base, index, .. } => {
393
- collector.reg_use(base);
394
- collector.reg_use(index);
395
- }
396
- &MemArg::Label { .. } | &MemArg::Symbol { .. } => {}
397
- &MemArg::RegOffset { reg, .. } => {
398
- collector.reg_use(reg);
399
- }
400
- &MemArg::InitialSPOffset { .. } | &MemArg::NominalSPOffset { .. } => {}
401
- }
402
- // mem_finalize might require %r1 to hold (part of) the address.
403
- // Conservatively assume this will always be necessary here.
404
- collector.reg_early_def(writable_gpr(1));
405
- }
406
-
407
- fn s390x_get_operands<F: Fn(VReg) -> VReg>(inst: &Inst, collector: &mut OperandCollector<'_, F>) {
408
- match inst {
409
- &Inst::AluRRR { rd, rn, rm, .. } => {
410
- collector.reg_def(rd);
411
- collector.reg_use(rn);
412
- collector.reg_use(rm);
413
- }
414
- &Inst::AluRRSImm16 { rd, rn, .. } => {
415
- collector.reg_def(rd);
416
- collector.reg_use(rn);
417
- }
418
- &Inst::AluRR { rd, ri, rm, .. } => {
419
- collector.reg_reuse_def(rd, 1);
420
- collector.reg_use(ri);
421
- collector.reg_use(rm);
422
- }
423
- &Inst::AluRX {
424
- rd, ri, ref mem, ..
425
- } => {
426
- collector.reg_reuse_def(rd, 1);
427
- collector.reg_use(ri);
428
- memarg_operands(mem, collector);
429
- }
430
- &Inst::AluRSImm16 { rd, ri, .. } => {
431
- collector.reg_reuse_def(rd, 1);
432
- collector.reg_use(ri);
433
- }
434
- &Inst::AluRSImm32 { rd, ri, .. } => {
435
- collector.reg_reuse_def(rd, 1);
436
- collector.reg_use(ri);
437
- }
438
- &Inst::AluRUImm32 { rd, ri, .. } => {
439
- collector.reg_reuse_def(rd, 1);
440
- collector.reg_use(ri);
441
- }
442
- &Inst::AluRUImm16Shifted { rd, ri, .. } => {
443
- collector.reg_reuse_def(rd, 1);
444
- collector.reg_use(ri);
445
- }
446
- &Inst::AluRUImm32Shifted { rd, ri, .. } => {
447
- collector.reg_reuse_def(rd, 1);
448
- collector.reg_use(ri);
449
- }
450
- &Inst::SMulWide { rd, rn, rm } => {
451
- collector.reg_use(rn);
452
- collector.reg_use(rm);
453
- // FIXME: The pair is hard-coded as %r2/%r3 because regalloc cannot handle pairs. If
454
- // that changes, all the hard-coded uses of %r2/%r3 can be changed.
455
- collector.reg_fixed_def(rd.hi, gpr(2));
456
- collector.reg_fixed_def(rd.lo, gpr(3));
457
- }
458
- &Inst::UMulWide { rd, ri, rn } => {
459
- collector.reg_use(rn);
460
- collector.reg_fixed_def(rd.hi, gpr(2));
461
- collector.reg_fixed_def(rd.lo, gpr(3));
462
- collector.reg_fixed_use(ri, gpr(3));
463
- }
464
- &Inst::SDivMod32 { rd, ri, rn } | &Inst::SDivMod64 { rd, ri, rn } => {
465
- collector.reg_use(rn);
466
- collector.reg_fixed_def(rd.hi, gpr(2));
467
- collector.reg_fixed_def(rd.lo, gpr(3));
468
- collector.reg_fixed_use(ri, gpr(3));
469
- }
470
- &Inst::UDivMod32 { rd, ri, rn } | &Inst::UDivMod64 { rd, ri, rn } => {
471
- collector.reg_use(rn);
472
- collector.reg_fixed_def(rd.hi, gpr(2));
473
- collector.reg_fixed_def(rd.lo, gpr(3));
474
- collector.reg_fixed_use(ri.hi, gpr(2));
475
- collector.reg_fixed_use(ri.lo, gpr(3));
476
- }
477
- &Inst::Flogr { rd, rn } => {
478
- collector.reg_use(rn);
479
- collector.reg_fixed_def(rd.hi, gpr(2));
480
- collector.reg_fixed_def(rd.lo, gpr(3));
481
- }
482
- &Inst::ShiftRR {
483
- rd, rn, shift_reg, ..
484
- } => {
485
- collector.reg_def(rd);
486
- collector.reg_use(rn);
487
- if shift_reg != zero_reg() {
488
- collector.reg_use(shift_reg);
489
- }
490
- }
491
- &Inst::RxSBG { rd, ri, rn, .. } => {
492
- collector.reg_reuse_def(rd, 1);
493
- collector.reg_use(ri);
494
- collector.reg_use(rn);
495
- }
496
- &Inst::RxSBGTest { rd, rn, .. } => {
497
- collector.reg_use(rd);
498
- collector.reg_use(rn);
499
- }
500
- &Inst::UnaryRR { rd, rn, .. } => {
501
- collector.reg_def(rd);
502
- collector.reg_use(rn);
503
- }
504
- &Inst::CmpRR { rn, rm, .. } => {
505
- collector.reg_use(rn);
506
- collector.reg_use(rm);
507
- }
508
- &Inst::CmpRX { rn, ref mem, .. } => {
509
- collector.reg_use(rn);
510
- memarg_operands(mem, collector);
511
- }
512
- &Inst::CmpRSImm16 { rn, .. } => {
513
- collector.reg_use(rn);
514
- }
515
- &Inst::CmpRSImm32 { rn, .. } => {
516
- collector.reg_use(rn);
517
- }
518
- &Inst::CmpRUImm32 { rn, .. } => {
519
- collector.reg_use(rn);
520
- }
521
- &Inst::CmpTrapRR { rn, rm, .. } => {
522
- collector.reg_use(rn);
523
- collector.reg_use(rm);
524
- }
525
- &Inst::CmpTrapRSImm16 { rn, .. } => {
526
- collector.reg_use(rn);
527
- }
528
- &Inst::CmpTrapRUImm16 { rn, .. } => {
529
- collector.reg_use(rn);
530
- }
531
- &Inst::AtomicRmw {
532
- rd, rn, ref mem, ..
533
- } => {
534
- collector.reg_def(rd);
535
- collector.reg_use(rn);
536
- memarg_operands(mem, collector);
537
- }
538
- &Inst::AtomicCas32 {
539
- rd,
540
- ri,
541
- rn,
542
- ref mem,
543
- ..
544
- }
545
- | &Inst::AtomicCas64 {
546
- rd,
547
- ri,
548
- rn,
549
- ref mem,
550
- ..
551
- } => {
552
- collector.reg_reuse_def(rd, 1);
553
- collector.reg_use(ri);
554
- collector.reg_use(rn);
555
- memarg_operands(mem, collector);
556
- }
557
- &Inst::Fence => {}
558
- &Inst::Load32 { rd, ref mem, .. }
559
- | &Inst::Load32ZExt8 { rd, ref mem, .. }
560
- | &Inst::Load32SExt8 { rd, ref mem, .. }
561
- | &Inst::Load32ZExt16 { rd, ref mem, .. }
562
- | &Inst::Load32SExt16 { rd, ref mem, .. }
563
- | &Inst::Load64 { rd, ref mem, .. }
564
- | &Inst::Load64ZExt8 { rd, ref mem, .. }
565
- | &Inst::Load64SExt8 { rd, ref mem, .. }
566
- | &Inst::Load64ZExt16 { rd, ref mem, .. }
567
- | &Inst::Load64SExt16 { rd, ref mem, .. }
568
- | &Inst::Load64ZExt32 { rd, ref mem, .. }
569
- | &Inst::Load64SExt32 { rd, ref mem, .. }
570
- | &Inst::LoadRev16 { rd, ref mem, .. }
571
- | &Inst::LoadRev32 { rd, ref mem, .. }
572
- | &Inst::LoadRev64 { rd, ref mem, .. } => {
573
- collector.reg_def(rd);
574
- memarg_operands(mem, collector);
575
- }
576
- &Inst::Store8 { rd, ref mem, .. }
577
- | &Inst::Store16 { rd, ref mem, .. }
578
- | &Inst::Store32 { rd, ref mem, .. }
579
- | &Inst::Store64 { rd, ref mem, .. }
580
- | &Inst::StoreRev16 { rd, ref mem, .. }
581
- | &Inst::StoreRev32 { rd, ref mem, .. }
582
- | &Inst::StoreRev64 { rd, ref mem, .. } => {
583
- collector.reg_use(rd);
584
- memarg_operands(mem, collector);
585
- }
586
- &Inst::StoreImm8 { ref mem, .. }
587
- | &Inst::StoreImm16 { ref mem, .. }
588
- | &Inst::StoreImm32SExt16 { ref mem, .. }
589
- | &Inst::StoreImm64SExt16 { ref mem, .. } => {
590
- memarg_operands(mem, collector);
591
- }
592
- &Inst::Mvc {
593
- ref dst, ref src, ..
594
- } => {
595
- collector.reg_use(dst.base);
596
- collector.reg_use(src.base);
597
- }
598
- &Inst::LoadMultiple64 {
599
- rt, rt2, ref mem, ..
600
- } => {
601
- memarg_operands(mem, collector);
602
- let first_regnum = rt.to_reg().to_real_reg().unwrap().hw_enc();
603
- let last_regnum = rt2.to_reg().to_real_reg().unwrap().hw_enc();
604
- for regnum in first_regnum..last_regnum + 1 {
605
- collector.reg_def(writable_gpr(regnum));
606
- }
607
- }
608
- &Inst::StoreMultiple64 {
609
- rt, rt2, ref mem, ..
610
- } => {
611
- memarg_operands(mem, collector);
612
- let first_regnum = rt.to_real_reg().unwrap().hw_enc();
613
- let last_regnum = rt2.to_real_reg().unwrap().hw_enc();
614
- for regnum in first_regnum..last_regnum + 1 {
615
- collector.reg_use(gpr(regnum));
616
- }
617
- }
618
- &Inst::Mov64 { rd, rm } => {
619
- collector.reg_def(rd);
620
- collector.reg_use(rm);
621
- }
622
- &Inst::MovPReg { rd, rm } => {
623
- debug_assert!([regs::gpr(0), regs::gpr(14), regs::gpr(15)].contains(&rm.into()));
624
- debug_assert!(rd.to_reg().is_virtual());
625
- collector.reg_def(rd);
626
- }
627
- &Inst::Mov32 { rd, rm } => {
628
- collector.reg_def(rd);
629
- collector.reg_use(rm);
630
- }
631
- &Inst::Mov32Imm { rd, .. }
632
- | &Inst::Mov32SImm16 { rd, .. }
633
- | &Inst::Mov64SImm16 { rd, .. }
634
- | &Inst::Mov64SImm32 { rd, .. }
635
- | &Inst::Mov64UImm16Shifted { rd, .. }
636
- | &Inst::Mov64UImm32Shifted { rd, .. } => {
637
- collector.reg_def(rd);
638
- }
639
- &Inst::CMov32 { rd, ri, rm, .. } | &Inst::CMov64 { rd, ri, rm, .. } => {
640
- collector.reg_reuse_def(rd, 1);
641
- collector.reg_use(ri);
642
- collector.reg_use(rm);
643
- }
644
- &Inst::CMov32SImm16 { rd, ri, .. } | &Inst::CMov64SImm16 { rd, ri, .. } => {
645
- collector.reg_reuse_def(rd, 1);
646
- collector.reg_use(ri);
647
- }
648
- &Inst::Insert64UImm16Shifted { rd, ri, .. }
649
- | &Inst::Insert64UImm32Shifted { rd, ri, .. } => {
650
- collector.reg_reuse_def(rd, 1);
651
- collector.reg_use(ri);
652
- }
653
- &Inst::LoadAR { rd, .. } => {
654
- collector.reg_def(rd);
655
- }
656
- &Inst::InsertAR { rd, ri, .. } => {
657
- collector.reg_reuse_def(rd, 1);
658
- collector.reg_use(ri);
659
- }
660
- &Inst::FpuMove32 { rd, rn } | &Inst::FpuMove64 { rd, rn } => {
661
- collector.reg_def(rd);
662
- collector.reg_use(rn);
663
- }
664
- &Inst::FpuCMov32 { rd, ri, rm, .. } | &Inst::FpuCMov64 { rd, ri, rm, .. } => {
665
- collector.reg_reuse_def(rd, 1);
666
- collector.reg_use(ri);
667
- collector.reg_use(rm);
668
- }
669
- &Inst::FpuRR { rd, rn, .. } => {
670
- collector.reg_def(rd);
671
- collector.reg_use(rn);
672
- }
673
- &Inst::FpuRRR { rd, rn, rm, .. } => {
674
- collector.reg_def(rd);
675
- collector.reg_use(rn);
676
- collector.reg_use(rm);
677
- }
678
- &Inst::FpuRRRR { rd, rn, rm, ra, .. } => {
679
- collector.reg_def(rd);
680
- collector.reg_use(rn);
681
- collector.reg_use(rm);
682
- collector.reg_use(ra);
683
- }
684
- &Inst::FpuCmp32 { rn, rm } | &Inst::FpuCmp64 { rn, rm } => {
685
- collector.reg_use(rn);
686
- collector.reg_use(rm);
687
- }
688
- &Inst::LoadFpuConst32 { rd, .. } | &Inst::LoadFpuConst64 { rd, .. } => {
689
- collector.reg_def(rd);
690
- collector.reg_def(writable_gpr(1));
691
- }
692
- &Inst::FpuRound { rd, rn, .. } => {
693
- collector.reg_def(rd);
694
- collector.reg_use(rn);
695
- }
696
- &Inst::VecRRR { rd, rn, rm, .. } => {
697
- collector.reg_def(rd);
698
- collector.reg_use(rn);
699
- collector.reg_use(rm);
700
- }
701
- &Inst::VecRR { rd, rn, .. } => {
702
- collector.reg_def(rd);
703
- collector.reg_use(rn);
704
- }
705
- &Inst::VecShiftRR {
706
- rd, rn, shift_reg, ..
707
- } => {
708
- collector.reg_def(rd);
709
- collector.reg_use(rn);
710
- if shift_reg != zero_reg() {
711
- collector.reg_use(shift_reg);
712
- }
713
- }
714
- &Inst::VecSelect { rd, rn, rm, ra, .. } => {
715
- collector.reg_def(rd);
716
- collector.reg_use(rn);
717
- collector.reg_use(rm);
718
- collector.reg_use(ra);
719
- }
720
- &Inst::VecPermute { rd, rn, rm, ra, .. } => {
721
- collector.reg_def(rd);
722
- collector.reg_use(rn);
723
- collector.reg_use(rm);
724
- collector.reg_use(ra);
725
- }
726
- &Inst::VecPermuteDWImm { rd, rn, rm, .. } => {
727
- collector.reg_def(rd);
728
- collector.reg_use(rn);
729
- collector.reg_use(rm);
730
- }
731
- &Inst::VecIntCmp { rd, rn, rm, .. } | &Inst::VecIntCmpS { rd, rn, rm, .. } => {
732
- collector.reg_def(rd);
733
- collector.reg_use(rn);
734
- collector.reg_use(rm);
735
- }
736
- &Inst::VecFloatCmp { rd, rn, rm, .. } | &Inst::VecFloatCmpS { rd, rn, rm, .. } => {
737
- collector.reg_def(rd);
738
- collector.reg_use(rn);
739
- collector.reg_use(rm);
740
- }
741
- &Inst::VecInt128SCmpHi { tmp, rn, rm, .. } | &Inst::VecInt128UCmpHi { tmp, rn, rm, .. } => {
742
- collector.reg_def(tmp);
743
- collector.reg_use(rn);
744
- collector.reg_use(rm);
745
- }
746
- &Inst::VecLoad { rd, ref mem, .. } => {
747
- collector.reg_def(rd);
748
- memarg_operands(mem, collector);
749
- }
750
- &Inst::VecLoadRev { rd, ref mem, .. } => {
751
- collector.reg_def(rd);
752
- memarg_operands(mem, collector);
753
- }
754
- &Inst::VecLoadByte16Rev { rd, ref mem, .. } => {
755
- collector.reg_def(rd);
756
- memarg_operands(mem, collector);
757
- }
758
- &Inst::VecLoadByte32Rev { rd, ref mem, .. } => {
759
- collector.reg_def(rd);
760
- memarg_operands(mem, collector);
761
- }
762
- &Inst::VecLoadByte64Rev { rd, ref mem, .. } => {
763
- collector.reg_def(rd);
764
- memarg_operands(mem, collector);
765
- }
766
- &Inst::VecLoadElt16Rev { rd, ref mem, .. } => {
767
- collector.reg_def(rd);
768
- memarg_operands(mem, collector);
769
- }
770
- &Inst::VecLoadElt32Rev { rd, ref mem, .. } => {
771
- collector.reg_def(rd);
772
- memarg_operands(mem, collector);
773
- }
774
- &Inst::VecLoadElt64Rev { rd, ref mem, .. } => {
775
- collector.reg_def(rd);
776
- memarg_operands(mem, collector);
777
- }
778
- &Inst::VecStore { rd, ref mem, .. } => {
779
- collector.reg_use(rd);
780
- memarg_operands(mem, collector);
781
- }
782
- &Inst::VecStoreRev { rd, ref mem, .. } => {
783
- collector.reg_use(rd);
784
- memarg_operands(mem, collector);
785
- }
786
- &Inst::VecStoreByte16Rev { rd, ref mem, .. } => {
787
- collector.reg_use(rd);
788
- memarg_operands(mem, collector);
789
- }
790
- &Inst::VecStoreByte32Rev { rd, ref mem, .. } => {
791
- collector.reg_use(rd);
792
- memarg_operands(mem, collector);
793
- }
794
- &Inst::VecStoreByte64Rev { rd, ref mem, .. } => {
795
- collector.reg_use(rd);
796
- memarg_operands(mem, collector);
797
- }
798
- &Inst::VecStoreElt16Rev { rd, ref mem, .. } => {
799
- collector.reg_use(rd);
800
- memarg_operands(mem, collector);
801
- }
802
- &Inst::VecStoreElt32Rev { rd, ref mem, .. } => {
803
- collector.reg_use(rd);
804
- memarg_operands(mem, collector);
805
- }
806
- &Inst::VecStoreElt64Rev { rd, ref mem, .. } => {
807
- collector.reg_use(rd);
808
- memarg_operands(mem, collector);
809
- }
810
- &Inst::VecLoadReplicate { rd, ref mem, .. } => {
811
- collector.reg_def(rd);
812
- memarg_operands(mem, collector);
813
- }
814
- &Inst::VecLoadReplicateRev { rd, ref mem, .. } => {
815
- collector.reg_def(rd);
816
- memarg_operands(mem, collector);
817
- }
818
- &Inst::VecMov { rd, rn } => {
819
- collector.reg_def(rd);
820
- collector.reg_use(rn);
821
- }
822
- &Inst::VecCMov { rd, ri, rm, .. } => {
823
- collector.reg_reuse_def(rd, 1);
824
- collector.reg_use(ri);
825
- collector.reg_use(rm);
826
- }
827
- &Inst::MovToVec128 { rd, rn, rm } => {
828
- collector.reg_def(rd);
829
- collector.reg_use(rn);
830
- collector.reg_use(rm);
831
- }
832
- &Inst::VecLoadConst { rd, .. } | &Inst::VecLoadConstReplicate { rd, .. } => {
833
- collector.reg_def(rd);
834
- collector.reg_def(writable_gpr(1));
835
- }
836
- &Inst::VecImmByteMask { rd, .. } => {
837
- collector.reg_def(rd);
838
- }
839
- &Inst::VecImmBitMask { rd, .. } => {
840
- collector.reg_def(rd);
841
- }
842
- &Inst::VecImmReplicate { rd, .. } => {
843
- collector.reg_def(rd);
844
- }
845
- &Inst::VecLoadLane {
846
- rd, ri, ref mem, ..
847
- } => {
848
- collector.reg_reuse_def(rd, 1);
849
- collector.reg_use(ri);
850
- memarg_operands(mem, collector);
851
- }
852
- &Inst::VecLoadLaneUndef { rd, ref mem, .. } => {
853
- collector.reg_def(rd);
854
- memarg_operands(mem, collector);
855
- }
856
- &Inst::VecStoreLaneRev { rd, ref mem, .. } => {
857
- collector.reg_use(rd);
858
- memarg_operands(mem, collector);
859
- }
860
- &Inst::VecLoadLaneRevUndef { rd, ref mem, .. } => {
861
- collector.reg_def(rd);
862
- memarg_operands(mem, collector);
863
- }
864
- &Inst::VecStoreLane { rd, ref mem, .. } => {
865
- collector.reg_use(rd);
866
- memarg_operands(mem, collector);
867
- }
868
- &Inst::VecLoadLaneRev {
869
- rd, ri, ref mem, ..
870
- } => {
871
- collector.reg_reuse_def(rd, 1);
872
- collector.reg_use(ri);
873
- memarg_operands(mem, collector);
874
- }
875
- &Inst::VecInsertLane {
876
- rd,
877
- ri,
878
- rn,
879
- lane_reg,
880
- ..
881
- } => {
882
- collector.reg_reuse_def(rd, 1);
883
- collector.reg_use(ri);
884
- collector.reg_use(rn);
885
- if lane_reg != zero_reg() {
886
- collector.reg_use(lane_reg);
887
- }
888
- }
889
- &Inst::VecInsertLaneUndef {
890
- rd, rn, lane_reg, ..
891
- } => {
892
- collector.reg_def(rd);
893
- collector.reg_use(rn);
894
- if lane_reg != zero_reg() {
895
- collector.reg_use(lane_reg);
896
- }
897
- }
898
- &Inst::VecExtractLane {
899
- rd, rn, lane_reg, ..
900
- } => {
901
- collector.reg_def(rd);
902
- collector.reg_use(rn);
903
- if lane_reg != zero_reg() {
904
- collector.reg_use(lane_reg);
905
- }
906
- }
907
- &Inst::VecInsertLaneImm { rd, ri, .. } => {
908
- collector.reg_reuse_def(rd, 1);
909
- collector.reg_use(ri);
910
- }
911
- &Inst::VecReplicateLane { rd, rn, .. } => {
912
- collector.reg_def(rd);
913
- collector.reg_use(rn);
914
- }
915
- &Inst::Extend { rd, rn, .. } => {
916
- collector.reg_def(rd);
917
- collector.reg_use(rn);
918
- }
919
- &Inst::Call { link, ref info } => {
920
- for u in &info.uses {
921
- collector.reg_fixed_use(u.vreg, u.preg);
922
- }
923
- for d in &info.defs {
924
- collector.reg_fixed_def(d.vreg, d.preg);
925
- }
926
- let mut clobbers = info.clobbers.clone();
927
- clobbers.add(link.to_reg().to_real_reg().unwrap().into());
928
- collector.reg_clobbers(clobbers);
929
- }
930
- &Inst::CallInd { link, ref info } => {
931
- collector.reg_use(info.rn);
932
- for u in &info.uses {
933
- collector.reg_fixed_use(u.vreg, u.preg);
934
- }
935
- for d in &info.defs {
936
- collector.reg_fixed_def(d.vreg, d.preg);
937
- }
938
- let mut clobbers = info.clobbers.clone();
939
- clobbers.add(link.to_reg().to_real_reg().unwrap().into());
940
- collector.reg_clobbers(clobbers);
941
- }
942
- &Inst::Args { ref args } => {
943
- for arg in args {
944
- collector.reg_fixed_def(arg.vreg, arg.preg);
945
- }
946
- }
947
- &Inst::Ret { ref rets, .. } => {
948
- // NOTE: we explicitly don't mark the link register as used here, as the use is only in
949
- // the epilog where callee-save registers are restored.
950
- for ret in rets {
951
- collector.reg_fixed_use(ret.vreg, ret.preg);
952
- }
953
- }
954
- &Inst::Jump { .. } => {}
955
- &Inst::IndirectBr { rn, .. } => {
956
- collector.reg_use(rn);
957
- }
958
- &Inst::CondBr { .. } | &Inst::OneWayCondBr { .. } => {}
959
- &Inst::Nop0 | Inst::Nop2 => {}
960
- &Inst::Debugtrap => {}
961
- &Inst::Trap { .. } => {}
962
- &Inst::TrapIf { .. } => {}
963
- &Inst::JTSequence { ridx, .. } => {
964
- collector.reg_use(ridx);
965
- collector.reg_early_def(writable_gpr(1));
966
- }
967
- &Inst::LoadSymbolReloc { rd, .. } => {
968
- collector.reg_def(rd);
969
- collector.reg_def(writable_gpr(1));
970
- }
971
- &Inst::LoadAddr { rd, ref mem } => {
972
- collector.reg_def(rd);
973
- memarg_operands(mem, collector);
974
- }
975
- &Inst::Loop { ref body, .. } => {
976
- for inst in body.iter() {
977
- s390x_get_operands(inst, collector);
978
- }
979
-
980
- // `reuse_def` constraints can't be permitted in a Loop instruction because the operand
981
- // index will always be relative to the Loop instruction, not the individual
982
- // instruction in the loop body. However, fixed-nonallocatable registers used with
983
- // instructions that would have emitted `reuse_def` constraints are fine.
984
- debug_assert!(collector.no_reuse_def());
985
- }
986
- &Inst::CondBreak { .. } => {}
987
- &Inst::VirtualSPOffsetAdj { .. } => {}
988
- &Inst::Unwind { .. } => {}
989
- &Inst::DummyUse { reg } => {
990
- collector.reg_use(reg);
991
- }
992
- }
993
- }
994
-
995
- //=============================================================================
996
- // Instructions: misc functions and external interface
997
-
998
- impl MachInst for Inst {
999
- type ABIMachineSpec = S390xMachineDeps;
1000
- type LabelUse = LabelUse;
1001
- const TRAP_OPCODE: &'static [u8] = &[0, 0];
1002
-
1003
- fn get_operands<F: Fn(VReg) -> VReg>(&self, collector: &mut OperandCollector<'_, F>) {
1004
- s390x_get_operands(self, collector);
1005
- }
1006
-
1007
- fn is_move(&self) -> Option<(Writable<Reg>, Reg)> {
1008
- match self {
1009
- &Inst::Mov32 { rd, rm } => Some((rd, rm)),
1010
- &Inst::Mov64 { rd, rm } => Some((rd, rm)),
1011
- &Inst::FpuMove32 { rd, rn } => Some((rd, rn)),
1012
- &Inst::FpuMove64 { rd, rn } => Some((rd, rn)),
1013
- &Inst::VecMov { rd, rn } => Some((rd, rn)),
1014
- _ => None,
1015
- }
1016
- }
1017
-
1018
- fn is_included_in_clobbers(&self) -> bool {
1019
- // We exclude call instructions from the clobber-set when they are calls
1020
- // from caller to callee with the same ABI. Such calls cannot possibly
1021
- // force any new registers to be saved in the prologue, because anything
1022
- // that the callee clobbers, the caller is also allowed to clobber. This
1023
- // both saves work and enables us to more precisely follow the
1024
- // half-caller-save, half-callee-save SysV ABI for some vector
1025
- // registers.
1026
- match self {
1027
- &Inst::Args { .. } => false,
1028
- &Inst::Call { ref info, .. } => info.caller_callconv != info.callee_callconv,
1029
- &Inst::CallInd { ref info, .. } => info.caller_callconv != info.callee_callconv,
1030
- _ => true,
1031
- }
1032
- }
1033
-
1034
- fn is_trap(&self) -> bool {
1035
- match self {
1036
- Self::Trap { .. } => true,
1037
- _ => false,
1038
- }
1039
- }
1040
-
1041
- fn is_args(&self) -> bool {
1042
- match self {
1043
- Self::Args { .. } => true,
1044
- _ => false,
1045
- }
1046
- }
1047
-
1048
- fn is_term(&self) -> MachTerminator {
1049
- match self {
1050
- &Inst::Ret { .. } => MachTerminator::Ret,
1051
- &Inst::Jump { .. } => MachTerminator::Uncond,
1052
- &Inst::CondBr { .. } => MachTerminator::Cond,
1053
- &Inst::OneWayCondBr { .. } => {
1054
- // Explicitly invisible to CFG processing.
1055
- MachTerminator::None
1056
- }
1057
- &Inst::IndirectBr { .. } => MachTerminator::Indirect,
1058
- &Inst::JTSequence { .. } => MachTerminator::Indirect,
1059
- _ => MachTerminator::None,
1060
- }
1061
- }
1062
-
1063
- fn is_safepoint(&self) -> bool {
1064
- match self {
1065
- &Inst::Call { .. }
1066
- | &Inst::CallInd { .. }
1067
- | &Inst::Trap { .. }
1068
- | Inst::TrapIf { .. }
1069
- | &Inst::CmpTrapRR { .. }
1070
- | &Inst::CmpTrapRSImm16 { .. }
1071
- | &Inst::CmpTrapRUImm16 { .. } => true,
1072
- _ => false,
1073
- }
1074
- }
1075
-
1076
- fn gen_move(to_reg: Writable<Reg>, from_reg: Reg, ty: Type) -> Inst {
1077
- assert!(ty.bits() <= 128);
1078
- if ty.bits() <= 32 {
1079
- Inst::mov32(to_reg, from_reg)
1080
- } else if ty.bits() <= 64 {
1081
- Inst::mov64(to_reg, from_reg)
1082
- } else {
1083
- Inst::mov128(to_reg, from_reg)
1084
- }
1085
- }
1086
-
1087
- fn gen_nop(preferred_size: usize) -> Inst {
1088
- if preferred_size == 0 {
1089
- Inst::Nop0
1090
- } else {
1091
- // We can't give a NOP (or any insn) < 2 bytes.
1092
- assert!(preferred_size >= 2);
1093
- Inst::Nop2
1094
- }
1095
- }
1096
-
1097
- fn rc_for_type(ty: Type) -> CodegenResult<(&'static [RegClass], &'static [Type])> {
1098
- match ty {
1099
- types::I8 => Ok((&[RegClass::Int], &[types::I8])),
1100
- types::I16 => Ok((&[RegClass::Int], &[types::I16])),
1101
- types::I32 => Ok((&[RegClass::Int], &[types::I32])),
1102
- types::I64 => Ok((&[RegClass::Int], &[types::I64])),
1103
- types::R32 => panic!("32-bit reftype pointer should never be seen on s390x"),
1104
- types::R64 => Ok((&[RegClass::Int], &[types::R64])),
1105
- types::F32 => Ok((&[RegClass::Float], &[types::F32])),
1106
- types::F64 => Ok((&[RegClass::Float], &[types::F64])),
1107
- types::I128 => Ok((&[RegClass::Float], &[types::I128])),
1108
- _ if ty.is_vector() && ty.bits() == 128 => Ok((&[RegClass::Float], &[types::I8X16])),
1109
- _ => Err(CodegenError::Unsupported(format!(
1110
- "Unexpected SSA-value type: {}",
1111
- ty
1112
- ))),
1113
- }
1114
- }
1115
-
1116
- fn canonical_type_for_rc(rc: RegClass) -> Type {
1117
- match rc {
1118
- RegClass::Int => types::I64,
1119
- RegClass::Float => types::I8X16,
1120
- RegClass::Vector => unreachable!(),
1121
- }
1122
- }
1123
-
1124
- fn gen_jump(target: MachLabel) -> Inst {
1125
- Inst::Jump { dest: target }
1126
- }
1127
-
1128
- fn worst_case_size() -> CodeOffset {
1129
- // The maximum size, in bytes, of any `Inst`'s emitted code. We have at least one case of
1130
- // an 8-instruction sequence (saturating int-to-float conversions) with three embedded
1131
- // 64-bit f64 constants.
1132
- //
1133
- // Note that inline jump-tables handle island/pool insertion separately, so we do not need
1134
- // to account for them here (otherwise the worst case would be 2^31 * 4, clearly not
1135
- // feasible for other reasons).
1136
- 44
1137
- }
1138
-
1139
- fn ref_type_regclass(_: &settings::Flags) -> RegClass {
1140
- RegClass::Int
1141
- }
1142
-
1143
- fn gen_dummy_use(reg: Reg) -> Inst {
1144
- Inst::DummyUse { reg }
1145
- }
1146
-
1147
- fn function_alignment() -> FunctionAlignment {
1148
- FunctionAlignment {
1149
- minimum: 4,
1150
- preferred: 4,
1151
- }
1152
- }
1153
- }
1154
-
1155
- //=============================================================================
1156
- // Pretty-printing of instructions.
1157
-
1158
- fn mem_finalize_for_show(mem: &MemArg, state: &EmitState, mi: MemInstType) -> (String, MemArg) {
1159
- let (mem_insts, mem) = mem_finalize(mem, state, mi);
1160
- let mut mem_str = mem_insts
1161
- .into_iter()
1162
- .map(|inst| {
1163
- inst.print_with_state(&mut EmitState::default(), &mut AllocationConsumer::new(&[]))
1164
- })
1165
- .collect::<Vec<_>>()
1166
- .join(" ; ");
1167
- if !mem_str.is_empty() {
1168
- mem_str += " ; ";
1169
- }
1170
-
1171
- (mem_str, mem)
1172
- }
1173
-
1174
- impl Inst {
1175
- fn print_with_state(
1176
- &self,
1177
- state: &mut EmitState,
1178
- allocs: &mut AllocationConsumer<'_>,
1179
- ) -> String {
1180
- // N.B.: order of consumption of `allocs` must match the order
1181
- // in `s390x_get_operands()`.
1182
-
1183
- let mut empty_allocs = AllocationConsumer::new(&[]);
1184
-
1185
- match self {
1186
- &Inst::Nop0 => "nop-zero-len".to_string(),
1187
- &Inst::Nop2 => "nop".to_string(),
1188
- &Inst::AluRRR { alu_op, rd, rn, rm } => {
1189
- let rd = allocs.next_writable(rd);
1190
- let rn = allocs.next(rn);
1191
- let rm = allocs.next(rm);
1192
-
1193
- let (op, have_rr) = match alu_op {
1194
- ALUOp::Add32 => ("ark", true),
1195
- ALUOp::Add64 => ("agrk", true),
1196
- ALUOp::AddLogical32 => ("alrk", true),
1197
- ALUOp::AddLogical64 => ("algrk", true),
1198
- ALUOp::Sub32 => ("srk", true),
1199
- ALUOp::Sub64 => ("sgrk", true),
1200
- ALUOp::SubLogical32 => ("slrk", true),
1201
- ALUOp::SubLogical64 => ("slgrk", true),
1202
- ALUOp::Mul32 => ("msrkc", true),
1203
- ALUOp::Mul64 => ("msgrkc", true),
1204
- ALUOp::And32 => ("nrk", true),
1205
- ALUOp::And64 => ("ngrk", true),
1206
- ALUOp::Orr32 => ("ork", true),
1207
- ALUOp::Orr64 => ("ogrk", true),
1208
- ALUOp::Xor32 => ("xrk", true),
1209
- ALUOp::Xor64 => ("xgrk", true),
1210
- ALUOp::NotAnd32 => ("nnrk", false),
1211
- ALUOp::NotAnd64 => ("nngrk", false),
1212
- ALUOp::NotOrr32 => ("nork", false),
1213
- ALUOp::NotOrr64 => ("nogrk", false),
1214
- ALUOp::NotXor32 => ("nxrk", false),
1215
- ALUOp::NotXor64 => ("nxgrk", false),
1216
- ALUOp::AndNot32 => ("ncrk", false),
1217
- ALUOp::AndNot64 => ("ncgrk", false),
1218
- ALUOp::OrrNot32 => ("ocrk", false),
1219
- ALUOp::OrrNot64 => ("ocgrk", false),
1220
- _ => unreachable!(),
1221
- };
1222
- if have_rr && rd.to_reg() == rn {
1223
- let inst = Inst::AluRR {
1224
- alu_op,
1225
- rd,
1226
- ri: rd.to_reg(),
1227
- rm,
1228
- };
1229
- return inst.print_with_state(state, &mut empty_allocs);
1230
- }
1231
- let rd = pretty_print_reg(rd.to_reg(), &mut empty_allocs);
1232
- let rn = pretty_print_reg(rn, &mut empty_allocs);
1233
- let rm = pretty_print_reg(rm, &mut empty_allocs);
1234
- format!("{} {}, {}, {}", op, rd, rn, rm)
1235
- }
1236
- &Inst::AluRRSImm16 {
1237
- alu_op,
1238
- rd,
1239
- rn,
1240
- imm,
1241
- } => {
1242
- let rd = allocs.next_writable(rd);
1243
- let rn = allocs.next(rn);
1244
-
1245
- if rd.to_reg() == rn {
1246
- let inst = Inst::AluRSImm16 {
1247
- alu_op,
1248
- rd,
1249
- ri: rd.to_reg(),
1250
- imm,
1251
- };
1252
- return inst.print_with_state(state, &mut empty_allocs);
1253
- }
1254
- let op = match alu_op {
1255
- ALUOp::Add32 => "ahik",
1256
- ALUOp::Add64 => "aghik",
1257
- _ => unreachable!(),
1258
- };
1259
- let rd = pretty_print_reg(rd.to_reg(), &mut empty_allocs);
1260
- let rn = pretty_print_reg(rn, &mut empty_allocs);
1261
- format!("{} {}, {}, {}", op, rd, rn, imm)
1262
- }
1263
- &Inst::AluRR { alu_op, rd, ri, rm } => {
1264
- let op = match alu_op {
1265
- ALUOp::Add32 => "ar",
1266
- ALUOp::Add64 => "agr",
1267
- ALUOp::Add64Ext32 => "agfr",
1268
- ALUOp::AddLogical32 => "alr",
1269
- ALUOp::AddLogical64 => "algr",
1270
- ALUOp::AddLogical64Ext32 => "algfr",
1271
- ALUOp::Sub32 => "sr",
1272
- ALUOp::Sub64 => "sgr",
1273
- ALUOp::Sub64Ext32 => "sgfr",
1274
- ALUOp::SubLogical32 => "slr",
1275
- ALUOp::SubLogical64 => "slgr",
1276
- ALUOp::SubLogical64Ext32 => "slgfr",
1277
- ALUOp::Mul32 => "msr",
1278
- ALUOp::Mul64 => "msgr",
1279
- ALUOp::Mul64Ext32 => "msgfr",
1280
- ALUOp::And32 => "nr",
1281
- ALUOp::And64 => "ngr",
1282
- ALUOp::Orr32 => "or",
1283
- ALUOp::Orr64 => "ogr",
1284
- ALUOp::Xor32 => "xr",
1285
- ALUOp::Xor64 => "xgr",
1286
- _ => unreachable!(),
1287
- };
1288
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1289
- let rm = pretty_print_reg(rm, allocs);
1290
- format!("{} {}, {}", op, rd, rm)
1291
- }
1292
- &Inst::AluRX {
1293
- alu_op,
1294
- rd,
1295
- ri,
1296
- ref mem,
1297
- } => {
1298
- let (opcode_rx, opcode_rxy) = match alu_op {
1299
- ALUOp::Add32 => (Some("a"), Some("ay")),
1300
- ALUOp::Add32Ext16 => (Some("ah"), Some("ahy")),
1301
- ALUOp::Add64 => (None, Some("ag")),
1302
- ALUOp::Add64Ext16 => (None, Some("agh")),
1303
- ALUOp::Add64Ext32 => (None, Some("agf")),
1304
- ALUOp::AddLogical32 => (Some("al"), Some("aly")),
1305
- ALUOp::AddLogical64 => (None, Some("alg")),
1306
- ALUOp::AddLogical64Ext32 => (None, Some("algf")),
1307
- ALUOp::Sub32 => (Some("s"), Some("sy")),
1308
- ALUOp::Sub32Ext16 => (Some("sh"), Some("shy")),
1309
- ALUOp::Sub64 => (None, Some("sg")),
1310
- ALUOp::Sub64Ext16 => (None, Some("sgh")),
1311
- ALUOp::Sub64Ext32 => (None, Some("sgf")),
1312
- ALUOp::SubLogical32 => (Some("sl"), Some("sly")),
1313
- ALUOp::SubLogical64 => (None, Some("slg")),
1314
- ALUOp::SubLogical64Ext32 => (None, Some("slgf")),
1315
- ALUOp::Mul32 => (Some("ms"), Some("msy")),
1316
- ALUOp::Mul32Ext16 => (Some("mh"), Some("mhy")),
1317
- ALUOp::Mul64 => (None, Some("msg")),
1318
- ALUOp::Mul64Ext16 => (None, Some("mgh")),
1319
- ALUOp::Mul64Ext32 => (None, Some("msgf")),
1320
- ALUOp::And32 => (Some("n"), Some("ny")),
1321
- ALUOp::And64 => (None, Some("ng")),
1322
- ALUOp::Orr32 => (Some("o"), Some("oy")),
1323
- ALUOp::Orr64 => (None, Some("og")),
1324
- ALUOp::Xor32 => (Some("x"), Some("xy")),
1325
- ALUOp::Xor64 => (None, Some("xg")),
1326
- _ => unreachable!(),
1327
- };
1328
-
1329
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1330
- let mem = mem.with_allocs(allocs);
1331
- let (mem_str, mem) = mem_finalize_for_show(
1332
- &mem,
1333
- state,
1334
- MemInstType {
1335
- have_d12: opcode_rx.is_some(),
1336
- have_d20: opcode_rxy.is_some(),
1337
- have_pcrel: false,
1338
- have_unaligned_pcrel: false,
1339
- have_index: true,
1340
- },
1341
- );
1342
- let op = match &mem {
1343
- &MemArg::BXD12 { .. } => opcode_rx,
1344
- &MemArg::BXD20 { .. } => opcode_rxy,
1345
- _ => unreachable!(),
1346
- };
1347
- let mem = mem.pretty_print_default();
1348
-
1349
- format!("{}{} {}, {}", mem_str, op.unwrap(), rd, mem)
1350
- }
1351
- &Inst::AluRSImm16 {
1352
- alu_op,
1353
- rd,
1354
- ri,
1355
- imm,
1356
- } => {
1357
- let op = match alu_op {
1358
- ALUOp::Add32 => "ahi",
1359
- ALUOp::Add64 => "aghi",
1360
- ALUOp::Mul32 => "mhi",
1361
- ALUOp::Mul64 => "mghi",
1362
- _ => unreachable!(),
1363
- };
1364
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1365
- format!("{} {}, {}", op, rd, imm)
1366
- }
1367
- &Inst::AluRSImm32 {
1368
- alu_op,
1369
- rd,
1370
- ri,
1371
- imm,
1372
- } => {
1373
- let op = match alu_op {
1374
- ALUOp::Add32 => "afi",
1375
- ALUOp::Add64 => "agfi",
1376
- ALUOp::Mul32 => "msfi",
1377
- ALUOp::Mul64 => "msgfi",
1378
- _ => unreachable!(),
1379
- };
1380
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1381
- format!("{} {}, {}", op, rd, imm)
1382
- }
1383
- &Inst::AluRUImm32 {
1384
- alu_op,
1385
- rd,
1386
- ri,
1387
- imm,
1388
- } => {
1389
- let op = match alu_op {
1390
- ALUOp::AddLogical32 => "alfi",
1391
- ALUOp::AddLogical64 => "algfi",
1392
- ALUOp::SubLogical32 => "slfi",
1393
- ALUOp::SubLogical64 => "slgfi",
1394
- _ => unreachable!(),
1395
- };
1396
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1397
- format!("{} {}, {}", op, rd, imm)
1398
- }
1399
- &Inst::AluRUImm16Shifted {
1400
- alu_op,
1401
- rd,
1402
- ri,
1403
- imm,
1404
- } => {
1405
- let op = match (alu_op, imm.shift) {
1406
- (ALUOp::And32, 0) => "nill",
1407
- (ALUOp::And32, 1) => "nilh",
1408
- (ALUOp::And64, 0) => "nill",
1409
- (ALUOp::And64, 1) => "nilh",
1410
- (ALUOp::And64, 2) => "nihl",
1411
- (ALUOp::And64, 3) => "nihh",
1412
- (ALUOp::Orr32, 0) => "oill",
1413
- (ALUOp::Orr32, 1) => "oilh",
1414
- (ALUOp::Orr64, 0) => "oill",
1415
- (ALUOp::Orr64, 1) => "oilh",
1416
- (ALUOp::Orr64, 2) => "oihl",
1417
- (ALUOp::Orr64, 3) => "oihh",
1418
- _ => unreachable!(),
1419
- };
1420
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1421
- format!("{} {}, {}", op, rd, imm.bits)
1422
- }
1423
- &Inst::AluRUImm32Shifted {
1424
- alu_op,
1425
- rd,
1426
- ri,
1427
- imm,
1428
- } => {
1429
- let op = match (alu_op, imm.shift) {
1430
- (ALUOp::And32, 0) => "nilf",
1431
- (ALUOp::And64, 0) => "nilf",
1432
- (ALUOp::And64, 1) => "nihf",
1433
- (ALUOp::Orr32, 0) => "oilf",
1434
- (ALUOp::Orr64, 0) => "oilf",
1435
- (ALUOp::Orr64, 1) => "oihf",
1436
- (ALUOp::Xor32, 0) => "xilf",
1437
- (ALUOp::Xor64, 0) => "xilf",
1438
- (ALUOp::Xor64, 1) => "xihf",
1439
- _ => unreachable!(),
1440
- };
1441
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1442
- format!("{} {}, {}", op, rd, imm.bits)
1443
- }
1444
- &Inst::SMulWide { rd, rn, rm } => {
1445
- let op = "mgrk";
1446
- let rn = pretty_print_reg(rn, allocs);
1447
- let rm = pretty_print_reg(rm, allocs);
1448
- let rd = pretty_print_regpair(rd.to_regpair(), allocs);
1449
- format!("{} {}, {}, {}", op, rd, rn, rm)
1450
- }
1451
- &Inst::UMulWide { rd, ri, rn } => {
1452
- let op = "mlgr";
1453
- let rn = pretty_print_reg(rn, allocs);
1454
- let rd = pretty_print_regpair_mod_lo(rd, ri, allocs);
1455
- format!("{} {}, {}", op, rd, rn)
1456
- }
1457
- &Inst::SDivMod32 { rd, ri, rn } => {
1458
- let op = "dsgfr";
1459
- let rn = pretty_print_reg(rn, allocs);
1460
- let rd = pretty_print_regpair_mod_lo(rd, ri, allocs);
1461
- format!("{} {}, {}", op, rd, rn)
1462
- }
1463
- &Inst::SDivMod64 { rd, ri, rn } => {
1464
- let op = "dsgr";
1465
- let rn = pretty_print_reg(rn, allocs);
1466
- let rd = pretty_print_regpair_mod_lo(rd, ri, allocs);
1467
- format!("{} {}, {}", op, rd, rn)
1468
- }
1469
- &Inst::UDivMod32 { rd, ri, rn } => {
1470
- let op = "dlr";
1471
- let rn = pretty_print_reg(rn, allocs);
1472
- let rd = pretty_print_regpair_mod(rd, ri, allocs);
1473
- format!("{} {}, {}", op, rd, rn)
1474
- }
1475
- &Inst::UDivMod64 { rd, ri, rn } => {
1476
- let op = "dlgr";
1477
- let rn = pretty_print_reg(rn, allocs);
1478
- let rd = pretty_print_regpair_mod(rd, ri, allocs);
1479
- format!("{} {}, {}", op, rd, rn)
1480
- }
1481
- &Inst::Flogr { rd, rn } => {
1482
- let op = "flogr";
1483
- let rn = pretty_print_reg(rn, allocs);
1484
- let rd = pretty_print_regpair(rd.to_regpair(), allocs);
1485
- format!("{} {}, {}", op, rd, rn)
1486
- }
1487
- &Inst::ShiftRR {
1488
- shift_op,
1489
- rd,
1490
- rn,
1491
- shift_imm,
1492
- shift_reg,
1493
- } => {
1494
- let op = match shift_op {
1495
- ShiftOp::RotL32 => "rll",
1496
- ShiftOp::RotL64 => "rllg",
1497
- ShiftOp::LShL32 => "sllk",
1498
- ShiftOp::LShL64 => "sllg",
1499
- ShiftOp::LShR32 => "srlk",
1500
- ShiftOp::LShR64 => "srlg",
1501
- ShiftOp::AShR32 => "srak",
1502
- ShiftOp::AShR64 => "srag",
1503
- };
1504
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1505
- let rn = pretty_print_reg(rn, allocs);
1506
- let shift_reg = if shift_reg != zero_reg() {
1507
- format!("({})", pretty_print_reg(shift_reg, allocs))
1508
- } else {
1509
- "".to_string()
1510
- };
1511
- format!("{} {}, {}, {}{}", op, rd, rn, shift_imm, shift_reg)
1512
- }
1513
- &Inst::RxSBG {
1514
- op,
1515
- rd,
1516
- ri,
1517
- rn,
1518
- start_bit,
1519
- end_bit,
1520
- rotate_amt,
1521
- } => {
1522
- let op = match op {
1523
- RxSBGOp::Insert => "risbgn",
1524
- RxSBGOp::And => "rnsbg",
1525
- RxSBGOp::Or => "rosbg",
1526
- RxSBGOp::Xor => "rxsbg",
1527
- };
1528
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1529
- let rn = pretty_print_reg(rn, allocs);
1530
- format!(
1531
- "{} {}, {}, {}, {}, {}",
1532
- op,
1533
- rd,
1534
- rn,
1535
- start_bit,
1536
- end_bit,
1537
- (rotate_amt as u8) & 63
1538
- )
1539
- }
1540
- &Inst::RxSBGTest {
1541
- op,
1542
- rd,
1543
- rn,
1544
- start_bit,
1545
- end_bit,
1546
- rotate_amt,
1547
- } => {
1548
- let op = match op {
1549
- RxSBGOp::And => "rnsbg",
1550
- RxSBGOp::Or => "rosbg",
1551
- RxSBGOp::Xor => "rxsbg",
1552
- _ => unreachable!(),
1553
- };
1554
- let rd = pretty_print_reg(rd, allocs);
1555
- let rn = pretty_print_reg(rn, allocs);
1556
- format!(
1557
- "{} {}, {}, {}, {}, {}",
1558
- op,
1559
- rd,
1560
- rn,
1561
- start_bit | 0x80,
1562
- end_bit,
1563
- (rotate_amt as u8) & 63
1564
- )
1565
- }
1566
- &Inst::UnaryRR { op, rd, rn } => {
1567
- let (op, extra) = match op {
1568
- UnaryOp::Abs32 => ("lpr", ""),
1569
- UnaryOp::Abs64 => ("lpgr", ""),
1570
- UnaryOp::Abs64Ext32 => ("lpgfr", ""),
1571
- UnaryOp::Neg32 => ("lcr", ""),
1572
- UnaryOp::Neg64 => ("lcgr", ""),
1573
- UnaryOp::Neg64Ext32 => ("lcgfr", ""),
1574
- UnaryOp::PopcntByte => ("popcnt", ""),
1575
- UnaryOp::PopcntReg => ("popcnt", ", 8"),
1576
- UnaryOp::BSwap32 => ("lrvr", ""),
1577
- UnaryOp::BSwap64 => ("lrvgr", ""),
1578
- };
1579
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1580
- let rn = pretty_print_reg(rn, allocs);
1581
- format!("{} {}, {}{}", op, rd, rn, extra)
1582
- }
1583
- &Inst::CmpRR { op, rn, rm } => {
1584
- let op = match op {
1585
- CmpOp::CmpS32 => "cr",
1586
- CmpOp::CmpS64 => "cgr",
1587
- CmpOp::CmpS64Ext32 => "cgfr",
1588
- CmpOp::CmpL32 => "clr",
1589
- CmpOp::CmpL64 => "clgr",
1590
- CmpOp::CmpL64Ext32 => "clgfr",
1591
- _ => unreachable!(),
1592
- };
1593
- let rn = pretty_print_reg(rn, allocs);
1594
- let rm = pretty_print_reg(rm, allocs);
1595
- format!("{} {}, {}", op, rn, rm)
1596
- }
1597
- &Inst::CmpRX { op, rn, ref mem } => {
1598
- let (opcode_rx, opcode_rxy, opcode_ril) = match op {
1599
- CmpOp::CmpS32 => (Some("c"), Some("cy"), Some("crl")),
1600
- CmpOp::CmpS32Ext16 => (Some("ch"), Some("chy"), Some("chrl")),
1601
- CmpOp::CmpS64 => (None, Some("cg"), Some("cgrl")),
1602
- CmpOp::CmpS64Ext16 => (None, Some("cgh"), Some("cghrl")),
1603
- CmpOp::CmpS64Ext32 => (None, Some("cgf"), Some("cgfrl")),
1604
- CmpOp::CmpL32 => (Some("cl"), Some("cly"), Some("clrl")),
1605
- CmpOp::CmpL32Ext16 => (None, None, Some("clhrl")),
1606
- CmpOp::CmpL64 => (None, Some("clg"), Some("clgrl")),
1607
- CmpOp::CmpL64Ext16 => (None, None, Some("clghrl")),
1608
- CmpOp::CmpL64Ext32 => (None, Some("clgf"), Some("clgfrl")),
1609
- };
1610
-
1611
- let rn = pretty_print_reg(rn, allocs);
1612
- let mem = mem.with_allocs(allocs);
1613
- let (mem_str, mem) = mem_finalize_for_show(
1614
- &mem,
1615
- state,
1616
- MemInstType {
1617
- have_d12: opcode_rx.is_some(),
1618
- have_d20: opcode_rxy.is_some(),
1619
- have_pcrel: opcode_ril.is_some(),
1620
- have_unaligned_pcrel: false,
1621
- have_index: true,
1622
- },
1623
- );
1624
- let op = match &mem {
1625
- &MemArg::BXD12 { .. } => opcode_rx,
1626
- &MemArg::BXD20 { .. } => opcode_rxy,
1627
- &MemArg::Label { .. } | &MemArg::Symbol { .. } => opcode_ril,
1628
- _ => unreachable!(),
1629
- };
1630
- let mem = mem.pretty_print_default();
1631
-
1632
- format!("{}{} {}, {}", mem_str, op.unwrap(), rn, mem)
1633
- }
1634
- &Inst::CmpRSImm16 { op, rn, imm } => {
1635
- let op = match op {
1636
- CmpOp::CmpS32 => "chi",
1637
- CmpOp::CmpS64 => "cghi",
1638
- _ => unreachable!(),
1639
- };
1640
- let rn = pretty_print_reg(rn, allocs);
1641
- format!("{} {}, {}", op, rn, imm)
1642
- }
1643
- &Inst::CmpRSImm32 { op, rn, imm } => {
1644
- let op = match op {
1645
- CmpOp::CmpS32 => "cfi",
1646
- CmpOp::CmpS64 => "cgfi",
1647
- _ => unreachable!(),
1648
- };
1649
- let rn = pretty_print_reg(rn, allocs);
1650
- format!("{} {}, {}", op, rn, imm)
1651
- }
1652
- &Inst::CmpRUImm32 { op, rn, imm } => {
1653
- let op = match op {
1654
- CmpOp::CmpL32 => "clfi",
1655
- CmpOp::CmpL64 => "clgfi",
1656
- _ => unreachable!(),
1657
- };
1658
- let rn = pretty_print_reg(rn, allocs);
1659
- format!("{} {}, {}", op, rn, imm)
1660
- }
1661
- &Inst::CmpTrapRR {
1662
- op, rn, rm, cond, ..
1663
- } => {
1664
- let op = match op {
1665
- CmpOp::CmpS32 => "crt",
1666
- CmpOp::CmpS64 => "cgrt",
1667
- CmpOp::CmpL32 => "clrt",
1668
- CmpOp::CmpL64 => "clgrt",
1669
- _ => unreachable!(),
1670
- };
1671
- let rn = pretty_print_reg(rn, allocs);
1672
- let rm = pretty_print_reg(rm, allocs);
1673
- let cond = cond.pretty_print_default();
1674
- format!("{}{} {}, {}", op, cond, rn, rm)
1675
- }
1676
- &Inst::CmpTrapRSImm16 {
1677
- op, rn, imm, cond, ..
1678
- } => {
1679
- let op = match op {
1680
- CmpOp::CmpS32 => "cit",
1681
- CmpOp::CmpS64 => "cgit",
1682
- _ => unreachable!(),
1683
- };
1684
- let rn = pretty_print_reg(rn, allocs);
1685
- let cond = cond.pretty_print_default();
1686
- format!("{}{} {}, {}", op, cond, rn, imm)
1687
- }
1688
- &Inst::CmpTrapRUImm16 {
1689
- op, rn, imm, cond, ..
1690
- } => {
1691
- let op = match op {
1692
- CmpOp::CmpL32 => "clfit",
1693
- CmpOp::CmpL64 => "clgit",
1694
- _ => unreachable!(),
1695
- };
1696
- let rn = pretty_print_reg(rn, allocs);
1697
- let cond = cond.pretty_print_default();
1698
- format!("{}{} {}, {}", op, cond, rn, imm)
1699
- }
1700
- &Inst::AtomicRmw {
1701
- alu_op,
1702
- rd,
1703
- rn,
1704
- ref mem,
1705
- } => {
1706
- let op = match alu_op {
1707
- ALUOp::Add32 => "laa",
1708
- ALUOp::Add64 => "laag",
1709
- ALUOp::AddLogical32 => "laal",
1710
- ALUOp::AddLogical64 => "laalg",
1711
- ALUOp::And32 => "lan",
1712
- ALUOp::And64 => "lang",
1713
- ALUOp::Orr32 => "lao",
1714
- ALUOp::Orr64 => "laog",
1715
- ALUOp::Xor32 => "lax",
1716
- ALUOp::Xor64 => "laxg",
1717
- _ => unreachable!(),
1718
- };
1719
-
1720
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1721
- let rn = pretty_print_reg(rn, allocs);
1722
- let mem = mem.with_allocs(allocs);
1723
- let (mem_str, mem) = mem_finalize_for_show(
1724
- &mem,
1725
- state,
1726
- MemInstType {
1727
- have_d12: false,
1728
- have_d20: true,
1729
- have_pcrel: false,
1730
- have_unaligned_pcrel: false,
1731
- have_index: false,
1732
- },
1733
- );
1734
- let mem = mem.pretty_print_default();
1735
- format!("{}{} {}, {}, {}", mem_str, op, rd, rn, mem)
1736
- }
1737
- &Inst::AtomicCas32 {
1738
- rd,
1739
- ri,
1740
- rn,
1741
- ref mem,
1742
- }
1743
- | &Inst::AtomicCas64 {
1744
- rd,
1745
- ri,
1746
- rn,
1747
- ref mem,
1748
- } => {
1749
- let (opcode_rs, opcode_rsy) = match self {
1750
- &Inst::AtomicCas32 { .. } => (Some("cs"), Some("csy")),
1751
- &Inst::AtomicCas64 { .. } => (None, Some("csg")),
1752
- _ => unreachable!(),
1753
- };
1754
-
1755
- let rd = pretty_print_reg_mod(rd, ri, allocs);
1756
- let rn = pretty_print_reg(rn, allocs);
1757
- let mem = mem.with_allocs(allocs);
1758
- let (mem_str, mem) = mem_finalize_for_show(
1759
- &mem,
1760
- state,
1761
- MemInstType {
1762
- have_d12: opcode_rs.is_some(),
1763
- have_d20: opcode_rsy.is_some(),
1764
- have_pcrel: false,
1765
- have_unaligned_pcrel: false,
1766
- have_index: false,
1767
- },
1768
- );
1769
- let op = match &mem {
1770
- &MemArg::BXD12 { .. } => opcode_rs,
1771
- &MemArg::BXD20 { .. } => opcode_rsy,
1772
- _ => unreachable!(),
1773
- };
1774
- let mem = mem.pretty_print_default();
1775
-
1776
- format!("{}{} {}, {}, {}", mem_str, op.unwrap(), rd, rn, mem)
1777
- }
1778
- &Inst::Fence => "bcr 14, 0".to_string(),
1779
- &Inst::Load32 { rd, ref mem }
1780
- | &Inst::Load32ZExt8 { rd, ref mem }
1781
- | &Inst::Load32SExt8 { rd, ref mem }
1782
- | &Inst::Load32ZExt16 { rd, ref mem }
1783
- | &Inst::Load32SExt16 { rd, ref mem }
1784
- | &Inst::Load64 { rd, ref mem }
1785
- | &Inst::Load64ZExt8 { rd, ref mem }
1786
- | &Inst::Load64SExt8 { rd, ref mem }
1787
- | &Inst::Load64ZExt16 { rd, ref mem }
1788
- | &Inst::Load64SExt16 { rd, ref mem }
1789
- | &Inst::Load64ZExt32 { rd, ref mem }
1790
- | &Inst::Load64SExt32 { rd, ref mem }
1791
- | &Inst::LoadRev16 { rd, ref mem }
1792
- | &Inst::LoadRev32 { rd, ref mem }
1793
- | &Inst::LoadRev64 { rd, ref mem } => {
1794
- let (opcode_rx, opcode_rxy, opcode_ril) = match self {
1795
- &Inst::Load32 { .. } => (Some("l"), Some("ly"), Some("lrl")),
1796
- &Inst::Load32ZExt8 { .. } => (None, Some("llc"), None),
1797
- &Inst::Load32SExt8 { .. } => (None, Some("lb"), None),
1798
- &Inst::Load32ZExt16 { .. } => (None, Some("llh"), Some("llhrl")),
1799
- &Inst::Load32SExt16 { .. } => (Some("lh"), Some("lhy"), Some("lhrl")),
1800
- &Inst::Load64 { .. } => (None, Some("lg"), Some("lgrl")),
1801
- &Inst::Load64ZExt8 { .. } => (None, Some("llgc"), None),
1802
- &Inst::Load64SExt8 { .. } => (None, Some("lgb"), None),
1803
- &Inst::Load64ZExt16 { .. } => (None, Some("llgh"), Some("llghrl")),
1804
- &Inst::Load64SExt16 { .. } => (None, Some("lgh"), Some("lghrl")),
1805
- &Inst::Load64ZExt32 { .. } => (None, Some("llgf"), Some("llgfrl")),
1806
- &Inst::Load64SExt32 { .. } => (None, Some("lgf"), Some("lgfrl")),
1807
- &Inst::LoadRev16 { .. } => (None, Some("lrvh"), None),
1808
- &Inst::LoadRev32 { .. } => (None, Some("lrv"), None),
1809
- &Inst::LoadRev64 { .. } => (None, Some("lrvg"), None),
1810
- _ => unreachable!(),
1811
- };
1812
-
1813
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1814
- let mem = mem.with_allocs(allocs);
1815
- let (mem_str, mem) = mem_finalize_for_show(
1816
- &mem,
1817
- state,
1818
- MemInstType {
1819
- have_d12: opcode_rx.is_some(),
1820
- have_d20: opcode_rxy.is_some(),
1821
- have_pcrel: opcode_ril.is_some(),
1822
- have_unaligned_pcrel: false,
1823
- have_index: true,
1824
- },
1825
- );
1826
- let op = match &mem {
1827
- &MemArg::BXD12 { .. } => opcode_rx,
1828
- &MemArg::BXD20 { .. } => opcode_rxy,
1829
- &MemArg::Label { .. } | &MemArg::Symbol { .. } => opcode_ril,
1830
- _ => unreachable!(),
1831
- };
1832
- let mem = mem.pretty_print_default();
1833
- format!("{}{} {}, {}", mem_str, op.unwrap(), rd, mem)
1834
- }
1835
- &Inst::Store8 { rd, ref mem }
1836
- | &Inst::Store16 { rd, ref mem }
1837
- | &Inst::Store32 { rd, ref mem }
1838
- | &Inst::Store64 { rd, ref mem }
1839
- | &Inst::StoreRev16 { rd, ref mem }
1840
- | &Inst::StoreRev32 { rd, ref mem }
1841
- | &Inst::StoreRev64 { rd, ref mem } => {
1842
- let (opcode_rx, opcode_rxy, opcode_ril) = match self {
1843
- &Inst::Store8 { .. } => (Some("stc"), Some("stcy"), None),
1844
- &Inst::Store16 { .. } => (Some("sth"), Some("sthy"), Some("sthrl")),
1845
- &Inst::Store32 { .. } => (Some("st"), Some("sty"), Some("strl")),
1846
- &Inst::Store64 { .. } => (None, Some("stg"), Some("stgrl")),
1847
- &Inst::StoreRev16 { .. } => (None, Some("strvh"), None),
1848
- &Inst::StoreRev32 { .. } => (None, Some("strv"), None),
1849
- &Inst::StoreRev64 { .. } => (None, Some("strvg"), None),
1850
- _ => unreachable!(),
1851
- };
1852
-
1853
- let rd = pretty_print_reg(rd, allocs);
1854
- let mem = mem.with_allocs(allocs);
1855
- let (mem_str, mem) = mem_finalize_for_show(
1856
- &mem,
1857
- state,
1858
- MemInstType {
1859
- have_d12: opcode_rx.is_some(),
1860
- have_d20: opcode_rxy.is_some(),
1861
- have_pcrel: opcode_ril.is_some(),
1862
- have_unaligned_pcrel: false,
1863
- have_index: true,
1864
- },
1865
- );
1866
- let op = match &mem {
1867
- &MemArg::BXD12 { .. } => opcode_rx,
1868
- &MemArg::BXD20 { .. } => opcode_rxy,
1869
- &MemArg::Label { .. } | &MemArg::Symbol { .. } => opcode_ril,
1870
- _ => unreachable!(),
1871
- };
1872
- let mem = mem.pretty_print_default();
1873
-
1874
- format!("{}{} {}, {}", mem_str, op.unwrap(), rd, mem)
1875
- }
1876
- &Inst::StoreImm8 { imm, ref mem } => {
1877
- let mem = mem.with_allocs(allocs);
1878
- let (mem_str, mem) = mem_finalize_for_show(
1879
- &mem,
1880
- state,
1881
- MemInstType {
1882
- have_d12: true,
1883
- have_d20: true,
1884
- have_pcrel: false,
1885
- have_unaligned_pcrel: false,
1886
- have_index: false,
1887
- },
1888
- );
1889
- let op = match &mem {
1890
- &MemArg::BXD12 { .. } => "mvi",
1891
- &MemArg::BXD20 { .. } => "mviy",
1892
- _ => unreachable!(),
1893
- };
1894
- let mem = mem.pretty_print_default();
1895
-
1896
- format!("{}{} {}, {}", mem_str, op, mem, imm)
1897
- }
1898
- &Inst::StoreImm16 { imm, ref mem }
1899
- | &Inst::StoreImm32SExt16 { imm, ref mem }
1900
- | &Inst::StoreImm64SExt16 { imm, ref mem } => {
1901
- let mem = mem.with_allocs(allocs);
1902
- let (mem_str, mem) = mem_finalize_for_show(
1903
- &mem,
1904
- state,
1905
- MemInstType {
1906
- have_d12: false,
1907
- have_d20: true,
1908
- have_pcrel: false,
1909
- have_unaligned_pcrel: false,
1910
- have_index: false,
1911
- },
1912
- );
1913
- let op = match self {
1914
- &Inst::StoreImm16 { .. } => "mvhhi",
1915
- &Inst::StoreImm32SExt16 { .. } => "mvhi",
1916
- &Inst::StoreImm64SExt16 { .. } => "mvghi",
1917
- _ => unreachable!(),
1918
- };
1919
- let mem = mem.pretty_print_default();
1920
-
1921
- format!("{}{} {}, {}", mem_str, op, mem, imm)
1922
- }
1923
- &Inst::Mvc {
1924
- ref dst,
1925
- ref src,
1926
- len_minus_one,
1927
- } => {
1928
- let dst = dst.with_allocs(allocs);
1929
- let src = src.with_allocs(allocs);
1930
- format!(
1931
- "mvc {}({},{}), {}({})",
1932
- dst.disp.pretty_print_default(),
1933
- len_minus_one,
1934
- show_reg(dst.base),
1935
- src.disp.pretty_print_default(),
1936
- show_reg(src.base)
1937
- )
1938
- }
1939
- &Inst::LoadMultiple64 { rt, rt2, ref mem } => {
1940
- let mem = mem.with_allocs(allocs);
1941
- let (mem_str, mem) = mem_finalize_for_show(
1942
- &mem,
1943
- state,
1944
- MemInstType {
1945
- have_d12: false,
1946
- have_d20: true,
1947
- have_pcrel: false,
1948
- have_unaligned_pcrel: false,
1949
- have_index: false,
1950
- },
1951
- );
1952
- let rt = pretty_print_reg(rt.to_reg(), &mut empty_allocs);
1953
- let rt2 = pretty_print_reg(rt2.to_reg(), &mut empty_allocs);
1954
- let mem = mem.pretty_print_default();
1955
- format!("{}lmg {}, {}, {}", mem_str, rt, rt2, mem)
1956
- }
1957
- &Inst::StoreMultiple64 { rt, rt2, ref mem } => {
1958
- let mem = mem.with_allocs(allocs);
1959
- let (mem_str, mem) = mem_finalize_for_show(
1960
- &mem,
1961
- state,
1962
- MemInstType {
1963
- have_d12: false,
1964
- have_d20: true,
1965
- have_pcrel: false,
1966
- have_unaligned_pcrel: false,
1967
- have_index: false,
1968
- },
1969
- );
1970
- let rt = pretty_print_reg(rt, &mut empty_allocs);
1971
- let rt2 = pretty_print_reg(rt2, &mut empty_allocs);
1972
- let mem = mem.pretty_print_default();
1973
- format!("{}stmg {}, {}, {}", mem_str, rt, rt2, mem)
1974
- }
1975
- &Inst::Mov64 { rd, rm } => {
1976
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1977
- let rm = pretty_print_reg(rm, allocs);
1978
- format!("lgr {}, {}", rd, rm)
1979
- }
1980
- &Inst::MovPReg { rd, rm } => {
1981
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1982
- let rm = show_reg(rm.into());
1983
- format!("lgr {}, {}", rd, rm)
1984
- }
1985
- &Inst::Mov32 { rd, rm } => {
1986
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1987
- let rm = pretty_print_reg(rm, allocs);
1988
- format!("lr {}, {}", rd, rm)
1989
- }
1990
- &Inst::Mov32Imm { rd, ref imm } => {
1991
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1992
- format!("iilf {}, {}", rd, imm)
1993
- }
1994
- &Inst::Mov32SImm16 { rd, ref imm } => {
1995
- let rd = pretty_print_reg(rd.to_reg(), allocs);
1996
- format!("lhi {}, {}", rd, imm)
1997
- }
1998
- &Inst::Mov64SImm16 { rd, ref imm } => {
1999
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2000
- format!("lghi {}, {}", rd, imm)
2001
- }
2002
- &Inst::Mov64SImm32 { rd, ref imm } => {
2003
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2004
- format!("lgfi {}, {}", rd, imm)
2005
- }
2006
- &Inst::Mov64UImm16Shifted { rd, ref imm } => {
2007
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2008
- let op = match imm.shift {
2009
- 0 => "llill",
2010
- 1 => "llilh",
2011
- 2 => "llihl",
2012
- 3 => "llihh",
2013
- _ => unreachable!(),
2014
- };
2015
- format!("{} {}, {}", op, rd, imm.bits)
2016
- }
2017
- &Inst::Mov64UImm32Shifted { rd, ref imm } => {
2018
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2019
- let op = match imm.shift {
2020
- 0 => "llilf",
2021
- 1 => "llihf",
2022
- _ => unreachable!(),
2023
- };
2024
- format!("{} {}, {}", op, rd, imm.bits)
2025
- }
2026
- &Inst::Insert64UImm16Shifted { rd, ri, ref imm } => {
2027
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2028
- let op = match imm.shift {
2029
- 0 => "iill",
2030
- 1 => "iilh",
2031
- 2 => "iihl",
2032
- 3 => "iihh",
2033
- _ => unreachable!(),
2034
- };
2035
- format!("{} {}, {}", op, rd, imm.bits)
2036
- }
2037
- &Inst::Insert64UImm32Shifted { rd, ri, ref imm } => {
2038
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2039
- let op = match imm.shift {
2040
- 0 => "iilf",
2041
- 1 => "iihf",
2042
- _ => unreachable!(),
2043
- };
2044
- format!("{} {}, {}", op, rd, imm.bits)
2045
- }
2046
- &Inst::LoadAR { rd, ar } => {
2047
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2048
- format!("ear {}, %a{}", rd, ar)
2049
- }
2050
- &Inst::InsertAR { rd, ri, ar } => {
2051
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2052
- format!("ear {}, %a{}", rd, ar)
2053
- }
2054
- &Inst::CMov32 { rd, cond, ri, rm } => {
2055
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2056
- let rm = pretty_print_reg(rm, allocs);
2057
- let cond = cond.pretty_print_default();
2058
- format!("locr{} {}, {}", cond, rd, rm)
2059
- }
2060
- &Inst::CMov64 { rd, cond, ri, rm } => {
2061
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2062
- let rm = pretty_print_reg(rm, allocs);
2063
- let cond = cond.pretty_print_default();
2064
- format!("locgr{} {}, {}", cond, rd, rm)
2065
- }
2066
- &Inst::CMov32SImm16 {
2067
- rd,
2068
- cond,
2069
- ri,
2070
- ref imm,
2071
- } => {
2072
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2073
- let cond = cond.pretty_print_default();
2074
- format!("lochi{} {}, {}", cond, rd, imm)
2075
- }
2076
- &Inst::CMov64SImm16 {
2077
- rd,
2078
- cond,
2079
- ri,
2080
- ref imm,
2081
- } => {
2082
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2083
- let cond = cond.pretty_print_default();
2084
- format!("locghi{} {}, {}", cond, rd, imm)
2085
- }
2086
- &Inst::FpuMove32 { rd, rn } => {
2087
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2088
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2089
- if rd_fpr.is_some() && rn_fpr.is_some() {
2090
- format!("ler {}, {}", rd_fpr.unwrap(), rn_fpr.unwrap())
2091
- } else {
2092
- format!("vlr {}, {}", rd, rn)
2093
- }
2094
- }
2095
- &Inst::FpuMove64 { rd, rn } => {
2096
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2097
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2098
- if rd_fpr.is_some() && rn_fpr.is_some() {
2099
- format!("ldr {}, {}", rd_fpr.unwrap(), rn_fpr.unwrap())
2100
- } else {
2101
- format!("vlr {}, {}", rd, rn)
2102
- }
2103
- }
2104
- &Inst::FpuCMov32 { rd, cond, ri, rm } => {
2105
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2106
- let _ri = allocs.next(ri);
2107
- let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2108
- if rd_fpr.is_some() && rm_fpr.is_some() {
2109
- let cond = cond.invert().pretty_print_default();
2110
- format!("j{} 6 ; ler {}, {}", cond, rd_fpr.unwrap(), rm_fpr.unwrap())
2111
- } else {
2112
- let cond = cond.invert().pretty_print_default();
2113
- format!("j{} 10 ; vlr {}, {}", cond, rd, rm)
2114
- }
2115
- }
2116
- &Inst::FpuCMov64 { rd, cond, ri, rm } => {
2117
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2118
- let _ri = allocs.next(ri);
2119
- let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2120
- if rd_fpr.is_some() && rm_fpr.is_some() {
2121
- let cond = cond.invert().pretty_print_default();
2122
- format!("j{} 6 ; ldr {}, {}", cond, rd_fpr.unwrap(), rm_fpr.unwrap())
2123
- } else {
2124
- let cond = cond.invert().pretty_print_default();
2125
- format!("j{} 10 ; vlr {}, {}", cond, rd, rm)
2126
- }
2127
- }
2128
- &Inst::FpuRR { fpu_op, rd, rn } => {
2129
- let (op, op_fpr) = match fpu_op {
2130
- FPUOp1::Abs32 => ("wflpsb", Some("lpebr")),
2131
- FPUOp1::Abs64 => ("wflpdb", Some("lpdbr")),
2132
- FPUOp1::Abs32x4 => ("vflpsb", None),
2133
- FPUOp1::Abs64x2 => ("vflpdb", None),
2134
- FPUOp1::Neg32 => ("wflcsb", Some("lcebr")),
2135
- FPUOp1::Neg64 => ("wflcdb", Some("lcdbr")),
2136
- FPUOp1::Neg32x4 => ("vflcsb", None),
2137
- FPUOp1::Neg64x2 => ("vflcdb", None),
2138
- FPUOp1::NegAbs32 => ("wflnsb", Some("lnebr")),
2139
- FPUOp1::NegAbs64 => ("wflndb", Some("lndbr")),
2140
- FPUOp1::NegAbs32x4 => ("vflnsb", None),
2141
- FPUOp1::NegAbs64x2 => ("vflndb", None),
2142
- FPUOp1::Sqrt32 => ("wfsqsb", Some("sqebr")),
2143
- FPUOp1::Sqrt64 => ("wfsqdb", Some("sqdbr")),
2144
- FPUOp1::Sqrt32x4 => ("vfsqsb", None),
2145
- FPUOp1::Sqrt64x2 => ("vfsqdb", None),
2146
- FPUOp1::Cvt32To64 => ("wldeb", Some("ldebr")),
2147
- FPUOp1::Cvt32x4To64x2 => ("vldeb", None),
2148
- };
2149
-
2150
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2151
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2152
- if op_fpr.is_some() && rd_fpr.is_some() && rn_fpr.is_some() {
2153
- format!(
2154
- "{} {}, {}",
2155
- op_fpr.unwrap(),
2156
- rd_fpr.unwrap(),
2157
- rn_fpr.unwrap()
2158
- )
2159
- } else if op.starts_with('w') {
2160
- format!("{} {}, {}", op, rd_fpr.unwrap_or(rd), rn_fpr.unwrap_or(rn))
2161
- } else {
2162
- format!("{} {}, {}", op, rd, rn)
2163
- }
2164
- }
2165
- &Inst::FpuRRR { fpu_op, rd, rn, rm } => {
2166
- let (op, opt_m6, op_fpr) = match fpu_op {
2167
- FPUOp2::Add32 => ("wfasb", "", Some("aebr")),
2168
- FPUOp2::Add64 => ("wfadb", "", Some("adbr")),
2169
- FPUOp2::Add32x4 => ("vfasb", "", None),
2170
- FPUOp2::Add64x2 => ("vfadb", "", None),
2171
- FPUOp2::Sub32 => ("wfssb", "", Some("sebr")),
2172
- FPUOp2::Sub64 => ("wfsdb", "", Some("sdbr")),
2173
- FPUOp2::Sub32x4 => ("vfssb", "", None),
2174
- FPUOp2::Sub64x2 => ("vfsdb", "", None),
2175
- FPUOp2::Mul32 => ("wfmsb", "", Some("meebr")),
2176
- FPUOp2::Mul64 => ("wfmdb", "", Some("mdbr")),
2177
- FPUOp2::Mul32x4 => ("vfmsb", "", None),
2178
- FPUOp2::Mul64x2 => ("vfmdb", "", None),
2179
- FPUOp2::Div32 => ("wfdsb", "", Some("debr")),
2180
- FPUOp2::Div64 => ("wfddb", "", Some("ddbr")),
2181
- FPUOp2::Div32x4 => ("vfdsb", "", None),
2182
- FPUOp2::Div64x2 => ("vfddb", "", None),
2183
- FPUOp2::Max32 => ("wfmaxsb", ", 1", None),
2184
- FPUOp2::Max64 => ("wfmaxdb", ", 1", None),
2185
- FPUOp2::Max32x4 => ("vfmaxsb", ", 1", None),
2186
- FPUOp2::Max64x2 => ("vfmaxdb", ", 1", None),
2187
- FPUOp2::Min32 => ("wfminsb", ", 1", None),
2188
- FPUOp2::Min64 => ("wfmindb", ", 1", None),
2189
- FPUOp2::Min32x4 => ("vfminsb", ", 1", None),
2190
- FPUOp2::Min64x2 => ("vfmindb", ", 1", None),
2191
- FPUOp2::MaxPseudo32 => ("wfmaxsb", ", 3", None),
2192
- FPUOp2::MaxPseudo64 => ("wfmaxdb", ", 3", None),
2193
- FPUOp2::MaxPseudo32x4 => ("vfmaxsb", ", 3", None),
2194
- FPUOp2::MaxPseudo64x2 => ("vfmaxdb", ", 3", None),
2195
- FPUOp2::MinPseudo32 => ("wfminsb", ", 3", None),
2196
- FPUOp2::MinPseudo64 => ("wfmindb", ", 3", None),
2197
- FPUOp2::MinPseudo32x4 => ("vfminsb", ", 3", None),
2198
- FPUOp2::MinPseudo64x2 => ("vfmindb", ", 3", None),
2199
- };
2200
-
2201
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2202
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2203
- let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2204
- if op_fpr.is_some() && rd == rn && rd_fpr.is_some() && rm_fpr.is_some() {
2205
- format!(
2206
- "{} {}, {}",
2207
- op_fpr.unwrap(),
2208
- rd_fpr.unwrap(),
2209
- rm_fpr.unwrap()
2210
- )
2211
- } else if op.starts_with('w') {
2212
- format!(
2213
- "{} {}, {}, {}{}",
2214
- op,
2215
- rd_fpr.unwrap_or(rd),
2216
- rn_fpr.unwrap_or(rn),
2217
- rm_fpr.unwrap_or(rm),
2218
- opt_m6
2219
- )
2220
- } else {
2221
- format!("{} {}, {}, {}{}", op, rd, rn, rm, opt_m6)
2222
- }
2223
- }
2224
- &Inst::FpuRRRR {
2225
- fpu_op,
2226
- rd,
2227
- rn,
2228
- rm,
2229
- ra,
2230
- } => {
2231
- let (op, op_fpr) = match fpu_op {
2232
- FPUOp3::MAdd32 => ("wfmasb", Some("maebr")),
2233
- FPUOp3::MAdd64 => ("wfmadb", Some("madbr")),
2234
- FPUOp3::MAdd32x4 => ("vfmasb", None),
2235
- FPUOp3::MAdd64x2 => ("vfmadb", None),
2236
- FPUOp3::MSub32 => ("wfmssb", Some("msebr")),
2237
- FPUOp3::MSub64 => ("wfmsdb", Some("msdbr")),
2238
- FPUOp3::MSub32x4 => ("vfmssb", None),
2239
- FPUOp3::MSub64x2 => ("vfmsdb", None),
2240
- };
2241
-
2242
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2243
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2244
- let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2245
- let (ra, ra_fpr) = pretty_print_fpr(ra, allocs);
2246
- if op_fpr.is_some()
2247
- && rd == ra
2248
- && rd_fpr.is_some()
2249
- && rn_fpr.is_some()
2250
- && rm_fpr.is_some()
2251
- {
2252
- format!(
2253
- "{} {}, {}, {}",
2254
- op_fpr.unwrap(),
2255
- rd_fpr.unwrap(),
2256
- rn_fpr.unwrap(),
2257
- rm_fpr.unwrap()
2258
- )
2259
- } else if op.starts_with('w') {
2260
- format!(
2261
- "{} {}, {}, {}, {}",
2262
- op,
2263
- rd_fpr.unwrap_or(rd),
2264
- rn_fpr.unwrap_or(rn),
2265
- rm_fpr.unwrap_or(rm),
2266
- ra_fpr.unwrap_or(ra)
2267
- )
2268
- } else {
2269
- format!("{} {}, {}, {}, {}", op, rd, rn, rm, ra)
2270
- }
2271
- }
2272
- &Inst::FpuCmp32 { rn, rm } => {
2273
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2274
- let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2275
- if rn_fpr.is_some() && rm_fpr.is_some() {
2276
- format!("cebr {}, {}", rn_fpr.unwrap(), rm_fpr.unwrap())
2277
- } else {
2278
- format!("wfcsb {}, {}", rn_fpr.unwrap_or(rn), rm_fpr.unwrap_or(rm))
2279
- }
2280
- }
2281
- &Inst::FpuCmp64 { rn, rm } => {
2282
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2283
- let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2284
- if rn_fpr.is_some() && rm_fpr.is_some() {
2285
- format!("cdbr {}, {}", rn_fpr.unwrap(), rm_fpr.unwrap())
2286
- } else {
2287
- format!("wfcdb {}, {}", rn_fpr.unwrap_or(rn), rm_fpr.unwrap_or(rm))
2288
- }
2289
- }
2290
- &Inst::LoadFpuConst32 { rd, const_data } => {
2291
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2292
- let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2293
- if rd_fpr.is_some() {
2294
- format!(
2295
- "bras {}, 8 ; data.f32 {} ; le {}, 0({})",
2296
- tmp,
2297
- f32::from_bits(const_data),
2298
- rd_fpr.unwrap(),
2299
- tmp
2300
- )
2301
- } else {
2302
- format!(
2303
- "bras {}, 8 ; data.f32 {} ; vlef {}, 0({}), 0",
2304
- tmp,
2305
- f32::from_bits(const_data),
2306
- rd,
2307
- tmp
2308
- )
2309
- }
2310
- }
2311
- &Inst::LoadFpuConst64 { rd, const_data } => {
2312
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2313
- let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2314
- if rd_fpr.is_some() {
2315
- format!(
2316
- "bras {}, 12 ; data.f64 {} ; ld {}, 0({})",
2317
- tmp,
2318
- f64::from_bits(const_data),
2319
- rd_fpr.unwrap(),
2320
- tmp
2321
- )
2322
- } else {
2323
- format!(
2324
- "bras {}, 12 ; data.f64 {} ; vleg {}, 0({}), 0",
2325
- tmp,
2326
- f64::from_bits(const_data),
2327
- rd,
2328
- tmp
2329
- )
2330
- }
2331
- }
2332
- &Inst::FpuRound { op, mode, rd, rn } => {
2333
- let mode = match mode {
2334
- FpuRoundMode::Current => 0,
2335
- FpuRoundMode::ToNearest => 1,
2336
- FpuRoundMode::ShorterPrecision => 3,
2337
- FpuRoundMode::ToNearestTiesToEven => 4,
2338
- FpuRoundMode::ToZero => 5,
2339
- FpuRoundMode::ToPosInfinity => 6,
2340
- FpuRoundMode::ToNegInfinity => 7,
2341
- };
2342
- let (opcode, opcode_fpr) = match op {
2343
- FpuRoundOp::Cvt64To32 => ("wledb", Some("ledbra")),
2344
- FpuRoundOp::Cvt64x2To32x4 => ("vledb", None),
2345
- FpuRoundOp::Round32 => ("wfisb", Some("fiebr")),
2346
- FpuRoundOp::Round64 => ("wfidb", Some("fidbr")),
2347
- FpuRoundOp::Round32x4 => ("vfisb", None),
2348
- FpuRoundOp::Round64x2 => ("vfidb", None),
2349
- FpuRoundOp::ToSInt32 => ("wcfeb", None),
2350
- FpuRoundOp::ToSInt64 => ("wcgdb", None),
2351
- FpuRoundOp::ToUInt32 => ("wclfeb", None),
2352
- FpuRoundOp::ToUInt64 => ("wclgdb", None),
2353
- FpuRoundOp::ToSInt32x4 => ("vcfeb", None),
2354
- FpuRoundOp::ToSInt64x2 => ("vcgdb", None),
2355
- FpuRoundOp::ToUInt32x4 => ("vclfeb", None),
2356
- FpuRoundOp::ToUInt64x2 => ("vclgdb", None),
2357
- FpuRoundOp::FromSInt32 => ("wcefb", None),
2358
- FpuRoundOp::FromSInt64 => ("wcdgb", None),
2359
- FpuRoundOp::FromUInt32 => ("wcelfb", None),
2360
- FpuRoundOp::FromUInt64 => ("wcdlgb", None),
2361
- FpuRoundOp::FromSInt32x4 => ("vcefb", None),
2362
- FpuRoundOp::FromSInt64x2 => ("vcdgb", None),
2363
- FpuRoundOp::FromUInt32x4 => ("vcelfb", None),
2364
- FpuRoundOp::FromUInt64x2 => ("vcdlgb", None),
2365
- };
2366
-
2367
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2368
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2369
- if opcode_fpr.is_some() && rd_fpr.is_some() && rn_fpr.is_some() {
2370
- format!(
2371
- "{} {}, {}, {}{}",
2372
- opcode_fpr.unwrap(),
2373
- rd_fpr.unwrap(),
2374
- mode,
2375
- rn_fpr.unwrap(),
2376
- if opcode_fpr.unwrap().ends_with('a') {
2377
- ", 0"
2378
- } else {
2379
- ""
2380
- }
2381
- )
2382
- } else if opcode.starts_with('w') {
2383
- format!(
2384
- "{} {}, {}, 0, {}",
2385
- opcode,
2386
- rd_fpr.unwrap_or(rd),
2387
- rn_fpr.unwrap_or(rn),
2388
- mode
2389
- )
2390
- } else {
2391
- format!("{} {}, {}, 0, {}", opcode, rd, rn, mode)
2392
- }
2393
- }
2394
- &Inst::VecRRR { op, rd, rn, rm } => {
2395
- let op = match op {
2396
- VecBinaryOp::Add8x16 => "vab",
2397
- VecBinaryOp::Add16x8 => "vah",
2398
- VecBinaryOp::Add32x4 => "vaf",
2399
- VecBinaryOp::Add64x2 => "vag",
2400
- VecBinaryOp::Add128 => "vaq",
2401
- VecBinaryOp::Sub8x16 => "vsb",
2402
- VecBinaryOp::Sub16x8 => "vsh",
2403
- VecBinaryOp::Sub32x4 => "vsf",
2404
- VecBinaryOp::Sub64x2 => "vsg",
2405
- VecBinaryOp::Sub128 => "vsq",
2406
- VecBinaryOp::Mul8x16 => "vmlb",
2407
- VecBinaryOp::Mul16x8 => "vmlhw",
2408
- VecBinaryOp::Mul32x4 => "vmlf",
2409
- VecBinaryOp::UMulHi8x16 => "vmlhb",
2410
- VecBinaryOp::UMulHi16x8 => "vmlhh",
2411
- VecBinaryOp::UMulHi32x4 => "vmlhf",
2412
- VecBinaryOp::SMulHi8x16 => "vmhb",
2413
- VecBinaryOp::SMulHi16x8 => "vmhh",
2414
- VecBinaryOp::SMulHi32x4 => "vmhf",
2415
- VecBinaryOp::UMulEven8x16 => "vmleb",
2416
- VecBinaryOp::UMulEven16x8 => "vmleh",
2417
- VecBinaryOp::UMulEven32x4 => "vmlef",
2418
- VecBinaryOp::SMulEven8x16 => "vmeb",
2419
- VecBinaryOp::SMulEven16x8 => "vmeh",
2420
- VecBinaryOp::SMulEven32x4 => "vmef",
2421
- VecBinaryOp::UMulOdd8x16 => "vmlob",
2422
- VecBinaryOp::UMulOdd16x8 => "vmloh",
2423
- VecBinaryOp::UMulOdd32x4 => "vmlof",
2424
- VecBinaryOp::SMulOdd8x16 => "vmob",
2425
- VecBinaryOp::SMulOdd16x8 => "vmoh",
2426
- VecBinaryOp::SMulOdd32x4 => "vmof",
2427
- VecBinaryOp::UMax8x16 => "vmxlb",
2428
- VecBinaryOp::UMax16x8 => "vmxlh",
2429
- VecBinaryOp::UMax32x4 => "vmxlf",
2430
- VecBinaryOp::UMax64x2 => "vmxlg",
2431
- VecBinaryOp::SMax8x16 => "vmxb",
2432
- VecBinaryOp::SMax16x8 => "vmxh",
2433
- VecBinaryOp::SMax32x4 => "vmxf",
2434
- VecBinaryOp::SMax64x2 => "vmxg",
2435
- VecBinaryOp::UMin8x16 => "vmnlb",
2436
- VecBinaryOp::UMin16x8 => "vmnlh",
2437
- VecBinaryOp::UMin32x4 => "vmnlf",
2438
- VecBinaryOp::UMin64x2 => "vmnlg",
2439
- VecBinaryOp::SMin8x16 => "vmnb",
2440
- VecBinaryOp::SMin16x8 => "vmnh",
2441
- VecBinaryOp::SMin32x4 => "vmnf",
2442
- VecBinaryOp::SMin64x2 => "vmng",
2443
- VecBinaryOp::UAvg8x16 => "vavglb",
2444
- VecBinaryOp::UAvg16x8 => "vavglh",
2445
- VecBinaryOp::UAvg32x4 => "vavglf",
2446
- VecBinaryOp::UAvg64x2 => "vavglg",
2447
- VecBinaryOp::SAvg8x16 => "vavgb",
2448
- VecBinaryOp::SAvg16x8 => "vavgh",
2449
- VecBinaryOp::SAvg32x4 => "vavgf",
2450
- VecBinaryOp::SAvg64x2 => "vavgg",
2451
- VecBinaryOp::And128 => "vn",
2452
- VecBinaryOp::Orr128 => "vo",
2453
- VecBinaryOp::Xor128 => "vx",
2454
- VecBinaryOp::NotAnd128 => "vnn",
2455
- VecBinaryOp::NotOrr128 => "vno",
2456
- VecBinaryOp::NotXor128 => "vnx",
2457
- VecBinaryOp::AndNot128 => "vnc",
2458
- VecBinaryOp::OrrNot128 => "voc",
2459
- VecBinaryOp::BitPermute128 => "vbperm",
2460
- VecBinaryOp::LShLByByte128 => "vslb",
2461
- VecBinaryOp::LShRByByte128 => "vsrlb",
2462
- VecBinaryOp::AShRByByte128 => "vsrab",
2463
- VecBinaryOp::LShLByBit128 => "vsl",
2464
- VecBinaryOp::LShRByBit128 => "vsrl",
2465
- VecBinaryOp::AShRByBit128 => "vsra",
2466
- VecBinaryOp::Pack16x8 => "vpkh",
2467
- VecBinaryOp::Pack32x4 => "vpkf",
2468
- VecBinaryOp::Pack64x2 => "vpkg",
2469
- VecBinaryOp::PackUSat16x8 => "vpklsh",
2470
- VecBinaryOp::PackUSat32x4 => "vpklsf",
2471
- VecBinaryOp::PackUSat64x2 => "vpklsg",
2472
- VecBinaryOp::PackSSat16x8 => "vpksh",
2473
- VecBinaryOp::PackSSat32x4 => "vpksf",
2474
- VecBinaryOp::PackSSat64x2 => "vpksg",
2475
- VecBinaryOp::MergeLow8x16 => "vmrlb",
2476
- VecBinaryOp::MergeLow16x8 => "vmrlh",
2477
- VecBinaryOp::MergeLow32x4 => "vmrlf",
2478
- VecBinaryOp::MergeLow64x2 => "vmrlg",
2479
- VecBinaryOp::MergeHigh8x16 => "vmrhb",
2480
- VecBinaryOp::MergeHigh16x8 => "vmrhh",
2481
- VecBinaryOp::MergeHigh32x4 => "vmrhf",
2482
- VecBinaryOp::MergeHigh64x2 => "vmrhg",
2483
- };
2484
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2485
- let rn = pretty_print_reg(rn, allocs);
2486
- let rm = pretty_print_reg(rm, allocs);
2487
- format!("{} {}, {}, {}", op, rd, rn, rm)
2488
- }
2489
- &Inst::VecRR { op, rd, rn } => {
2490
- let op = match op {
2491
- VecUnaryOp::Abs8x16 => "vlpb",
2492
- VecUnaryOp::Abs16x8 => "vlph",
2493
- VecUnaryOp::Abs32x4 => "vlpf",
2494
- VecUnaryOp::Abs64x2 => "vlpg",
2495
- VecUnaryOp::Neg8x16 => "vlcb",
2496
- VecUnaryOp::Neg16x8 => "vlch",
2497
- VecUnaryOp::Neg32x4 => "vlcf",
2498
- VecUnaryOp::Neg64x2 => "vlcg",
2499
- VecUnaryOp::Popcnt8x16 => "vpopctb",
2500
- VecUnaryOp::Popcnt16x8 => "vpopcth",
2501
- VecUnaryOp::Popcnt32x4 => "vpopctf",
2502
- VecUnaryOp::Popcnt64x2 => "vpopctg",
2503
- VecUnaryOp::Clz8x16 => "vclzb",
2504
- VecUnaryOp::Clz16x8 => "vclzh",
2505
- VecUnaryOp::Clz32x4 => "vclzf",
2506
- VecUnaryOp::Clz64x2 => "vclzg",
2507
- VecUnaryOp::Ctz8x16 => "vctzb",
2508
- VecUnaryOp::Ctz16x8 => "vctzh",
2509
- VecUnaryOp::Ctz32x4 => "vctzf",
2510
- VecUnaryOp::Ctz64x2 => "vctzg",
2511
- VecUnaryOp::UnpackULow8x16 => "vupllb",
2512
- VecUnaryOp::UnpackULow16x8 => "vupllh",
2513
- VecUnaryOp::UnpackULow32x4 => "vupllf",
2514
- VecUnaryOp::UnpackUHigh8x16 => "vuplhb",
2515
- VecUnaryOp::UnpackUHigh16x8 => "vuplhh",
2516
- VecUnaryOp::UnpackUHigh32x4 => "vuplhf",
2517
- VecUnaryOp::UnpackSLow8x16 => "vuplb",
2518
- VecUnaryOp::UnpackSLow16x8 => "vuplh",
2519
- VecUnaryOp::UnpackSLow32x4 => "vuplf",
2520
- VecUnaryOp::UnpackSHigh8x16 => "vuphb",
2521
- VecUnaryOp::UnpackSHigh16x8 => "vuphh",
2522
- VecUnaryOp::UnpackSHigh32x4 => "vuphf",
2523
- };
2524
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2525
- let rn = pretty_print_reg(rn, allocs);
2526
- format!("{} {}, {}", op, rd, rn)
2527
- }
2528
- &Inst::VecShiftRR {
2529
- shift_op,
2530
- rd,
2531
- rn,
2532
- shift_imm,
2533
- shift_reg,
2534
- } => {
2535
- let op = match shift_op {
2536
- VecShiftOp::RotL8x16 => "verllb",
2537
- VecShiftOp::RotL16x8 => "verllh",
2538
- VecShiftOp::RotL32x4 => "verllf",
2539
- VecShiftOp::RotL64x2 => "verllg",
2540
- VecShiftOp::LShL8x16 => "veslb",
2541
- VecShiftOp::LShL16x8 => "veslh",
2542
- VecShiftOp::LShL32x4 => "veslf",
2543
- VecShiftOp::LShL64x2 => "veslg",
2544
- VecShiftOp::LShR8x16 => "vesrlb",
2545
- VecShiftOp::LShR16x8 => "vesrlh",
2546
- VecShiftOp::LShR32x4 => "vesrlf",
2547
- VecShiftOp::LShR64x2 => "vesrlg",
2548
- VecShiftOp::AShR8x16 => "vesrab",
2549
- VecShiftOp::AShR16x8 => "vesrah",
2550
- VecShiftOp::AShR32x4 => "vesraf",
2551
- VecShiftOp::AShR64x2 => "vesrag",
2552
- };
2553
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2554
- let rn = pretty_print_reg(rn, allocs);
2555
- let shift_reg = if shift_reg != zero_reg() {
2556
- format!("({})", pretty_print_reg(shift_reg, allocs))
2557
- } else {
2558
- "".to_string()
2559
- };
2560
- format!("{} {}, {}, {}{}", op, rd, rn, shift_imm, shift_reg)
2561
- }
2562
- &Inst::VecSelect { rd, rn, rm, ra } => {
2563
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2564
- let rn = pretty_print_reg(rn, allocs);
2565
- let rm = pretty_print_reg(rm, allocs);
2566
- let ra = pretty_print_reg(ra, allocs);
2567
- format!("vsel {}, {}, {}, {}", rd, rn, rm, ra)
2568
- }
2569
- &Inst::VecPermute { rd, rn, rm, ra } => {
2570
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2571
- let rn = pretty_print_reg(rn, allocs);
2572
- let rm = pretty_print_reg(rm, allocs);
2573
- let ra = pretty_print_reg(ra, allocs);
2574
- format!("vperm {}, {}, {}, {}", rd, rn, rm, ra)
2575
- }
2576
- &Inst::VecPermuteDWImm {
2577
- rd,
2578
- rn,
2579
- rm,
2580
- idx1,
2581
- idx2,
2582
- } => {
2583
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2584
- let rn = pretty_print_reg(rn, allocs);
2585
- let rm = pretty_print_reg(rm, allocs);
2586
- let m4 = (idx1 & 1) * 4 + (idx2 & 1);
2587
- format!("vpdi {}, {}, {}, {}", rd, rn, rm, m4)
2588
- }
2589
- &Inst::VecIntCmp { op, rd, rn, rm } | &Inst::VecIntCmpS { op, rd, rn, rm } => {
2590
- let op = match op {
2591
- VecIntCmpOp::CmpEq8x16 => "vceqb",
2592
- VecIntCmpOp::CmpEq16x8 => "vceqh",
2593
- VecIntCmpOp::CmpEq32x4 => "vceqf",
2594
- VecIntCmpOp::CmpEq64x2 => "vceqg",
2595
- VecIntCmpOp::SCmpHi8x16 => "vchb",
2596
- VecIntCmpOp::SCmpHi16x8 => "vchh",
2597
- VecIntCmpOp::SCmpHi32x4 => "vchf",
2598
- VecIntCmpOp::SCmpHi64x2 => "vchg",
2599
- VecIntCmpOp::UCmpHi8x16 => "vchlb",
2600
- VecIntCmpOp::UCmpHi16x8 => "vchlh",
2601
- VecIntCmpOp::UCmpHi32x4 => "vchlf",
2602
- VecIntCmpOp::UCmpHi64x2 => "vchlg",
2603
- };
2604
- let s = match self {
2605
- &Inst::VecIntCmp { .. } => "",
2606
- &Inst::VecIntCmpS { .. } => "s",
2607
- _ => unreachable!(),
2608
- };
2609
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2610
- let rn = pretty_print_reg(rn, allocs);
2611
- let rm = pretty_print_reg(rm, allocs);
2612
- format!("{}{} {}, {}, {}", op, s, rd, rn, rm)
2613
- }
2614
- &Inst::VecFloatCmp { op, rd, rn, rm } | &Inst::VecFloatCmpS { op, rd, rn, rm } => {
2615
- let op = match op {
2616
- VecFloatCmpOp::CmpEq32x4 => "vfcesb",
2617
- VecFloatCmpOp::CmpEq64x2 => "vfcedb",
2618
- VecFloatCmpOp::CmpHi32x4 => "vfchsb",
2619
- VecFloatCmpOp::CmpHi64x2 => "vfchdb",
2620
- VecFloatCmpOp::CmpHiEq32x4 => "vfchesb",
2621
- VecFloatCmpOp::CmpHiEq64x2 => "vfchedb",
2622
- };
2623
- let s = match self {
2624
- &Inst::VecFloatCmp { .. } => "",
2625
- &Inst::VecFloatCmpS { .. } => "s",
2626
- _ => unreachable!(),
2627
- };
2628
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2629
- let rn = pretty_print_reg(rn, allocs);
2630
- let rm = pretty_print_reg(rm, allocs);
2631
- format!("{}{} {}, {}, {}", op, s, rd, rn, rm)
2632
- }
2633
- &Inst::VecInt128SCmpHi { tmp, rn, rm } | &Inst::VecInt128UCmpHi { tmp, rn, rm } => {
2634
- let op = match self {
2635
- &Inst::VecInt128SCmpHi { .. } => "vecg",
2636
- &Inst::VecInt128UCmpHi { .. } => "veclg",
2637
- _ => unreachable!(),
2638
- };
2639
- let tmp = pretty_print_reg(tmp.to_reg(), allocs);
2640
- let rn = pretty_print_reg(rn, allocs);
2641
- let rm = pretty_print_reg(rm, allocs);
2642
- format!(
2643
- "{} {}, {} ; jne 10 ; vchlgs {}, {}, {}",
2644
- op, rm, rn, tmp, rn, rm
2645
- )
2646
- }
2647
- &Inst::VecLoad { rd, ref mem }
2648
- | &Inst::VecLoadRev { rd, ref mem }
2649
- | &Inst::VecLoadByte16Rev { rd, ref mem }
2650
- | &Inst::VecLoadByte32Rev { rd, ref mem }
2651
- | &Inst::VecLoadByte64Rev { rd, ref mem }
2652
- | &Inst::VecLoadElt16Rev { rd, ref mem }
2653
- | &Inst::VecLoadElt32Rev { rd, ref mem }
2654
- | &Inst::VecLoadElt64Rev { rd, ref mem } => {
2655
- let opcode = match self {
2656
- &Inst::VecLoad { .. } => "vl",
2657
- &Inst::VecLoadRev { .. } => "vlbrq",
2658
- &Inst::VecLoadByte16Rev { .. } => "vlbrh",
2659
- &Inst::VecLoadByte32Rev { .. } => "vlbrf",
2660
- &Inst::VecLoadByte64Rev { .. } => "vlbrg",
2661
- &Inst::VecLoadElt16Rev { .. } => "vlerh",
2662
- &Inst::VecLoadElt32Rev { .. } => "vlerf",
2663
- &Inst::VecLoadElt64Rev { .. } => "vlerg",
2664
- _ => unreachable!(),
2665
- };
2666
-
2667
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2668
- let mem = mem.with_allocs(allocs);
2669
- let (mem_str, mem) = mem_finalize_for_show(
2670
- &mem,
2671
- state,
2672
- MemInstType {
2673
- have_d12: true,
2674
- have_d20: false,
2675
- have_pcrel: false,
2676
- have_unaligned_pcrel: false,
2677
- have_index: true,
2678
- },
2679
- );
2680
- let mem = mem.pretty_print_default();
2681
- format!("{}{} {}, {}", mem_str, opcode, rd, mem)
2682
- }
2683
- &Inst::VecStore { rd, ref mem }
2684
- | &Inst::VecStoreRev { rd, ref mem }
2685
- | &Inst::VecStoreByte16Rev { rd, ref mem }
2686
- | &Inst::VecStoreByte32Rev { rd, ref mem }
2687
- | &Inst::VecStoreByte64Rev { rd, ref mem }
2688
- | &Inst::VecStoreElt16Rev { rd, ref mem }
2689
- | &Inst::VecStoreElt32Rev { rd, ref mem }
2690
- | &Inst::VecStoreElt64Rev { rd, ref mem } => {
2691
- let opcode = match self {
2692
- &Inst::VecStore { .. } => "vst",
2693
- &Inst::VecStoreRev { .. } => "vstbrq",
2694
- &Inst::VecStoreByte16Rev { .. } => "vstbrh",
2695
- &Inst::VecStoreByte32Rev { .. } => "vstbrf",
2696
- &Inst::VecStoreByte64Rev { .. } => "vstbrg",
2697
- &Inst::VecStoreElt16Rev { .. } => "vsterh",
2698
- &Inst::VecStoreElt32Rev { .. } => "vsterf",
2699
- &Inst::VecStoreElt64Rev { .. } => "vsterg",
2700
- _ => unreachable!(),
2701
- };
2702
-
2703
- let rd = pretty_print_reg(rd, allocs);
2704
- let mem = mem.with_allocs(allocs);
2705
- let (mem_str, mem) = mem_finalize_for_show(
2706
- &mem,
2707
- state,
2708
- MemInstType {
2709
- have_d12: true,
2710
- have_d20: false,
2711
- have_pcrel: false,
2712
- have_unaligned_pcrel: false,
2713
- have_index: true,
2714
- },
2715
- );
2716
- let mem = mem.pretty_print_default();
2717
- format!("{}{} {}, {}", mem_str, opcode, rd, mem)
2718
- }
2719
- &Inst::VecLoadReplicate { size, rd, ref mem }
2720
- | &Inst::VecLoadReplicateRev { size, rd, ref mem } => {
2721
- let opcode = match (self, size) {
2722
- (&Inst::VecLoadReplicate { .. }, 8) => "vlrepb",
2723
- (&Inst::VecLoadReplicate { .. }, 16) => "vlreph",
2724
- (&Inst::VecLoadReplicate { .. }, 32) => "vlrepf",
2725
- (&Inst::VecLoadReplicate { .. }, 64) => "vlrepg",
2726
- (&Inst::VecLoadReplicateRev { .. }, 16) => "vlbrreph",
2727
- (&Inst::VecLoadReplicateRev { .. }, 32) => "vlbrrepf",
2728
- (&Inst::VecLoadReplicateRev { .. }, 64) => "vlbrrepg",
2729
- _ => unreachable!(),
2730
- };
2731
-
2732
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2733
- let mem = mem.with_allocs(allocs);
2734
- let (mem_str, mem) = mem_finalize_for_show(
2735
- &mem,
2736
- state,
2737
- MemInstType {
2738
- have_d12: true,
2739
- have_d20: false,
2740
- have_pcrel: false,
2741
- have_unaligned_pcrel: false,
2742
- have_index: true,
2743
- },
2744
- );
2745
- let mem = mem.pretty_print_default();
2746
- format!("{}{} {}, {}", mem_str, opcode, rd, mem)
2747
- }
2748
- &Inst::VecMov { rd, rn } => {
2749
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2750
- let rn = pretty_print_reg(rn, allocs);
2751
- format!("vlr {}, {}", rd, rn)
2752
- }
2753
- &Inst::VecCMov { rd, cond, ri, rm } => {
2754
- let rd = pretty_print_reg_mod(rd, ri, allocs);
2755
- let rm = pretty_print_reg(rm, allocs);
2756
- let cond = cond.invert().pretty_print_default();
2757
- format!("j{} 10 ; vlr {}, {}", cond, rd, rm)
2758
- }
2759
- &Inst::MovToVec128 { rd, rn, rm } => {
2760
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2761
- let rn = pretty_print_reg(rn, allocs);
2762
- let rm = pretty_print_reg(rm, allocs);
2763
- format!("vlvgp {}, {}, {}", rd, rn, rm)
2764
- }
2765
- &Inst::VecLoadConst { rd, const_data } => {
2766
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2767
- let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2768
- format!(
2769
- "bras {}, 20 ; data.u128 0x{:032x} ; vl {}, 0({})",
2770
- tmp, const_data, rd, tmp
2771
- )
2772
- }
2773
- &Inst::VecLoadConstReplicate {
2774
- size,
2775
- rd,
2776
- const_data,
2777
- } => {
2778
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2779
- let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2780
- let (opcode, data) = match size {
2781
- 32 => ("vlrepf", format!("0x{:08x}", const_data as u32)),
2782
- 64 => ("vlrepg", format!("0x{:016x}", const_data)),
2783
- _ => unreachable!(),
2784
- };
2785
- format!(
2786
- "bras {}, {} ; data.u{} {} ; {} {}, 0({})",
2787
- tmp,
2788
- 4 + size / 8,
2789
- size,
2790
- data,
2791
- opcode,
2792
- rd,
2793
- tmp
2794
- )
2795
- }
2796
- &Inst::VecImmByteMask { rd, mask } => {
2797
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2798
- format!("vgbm {}, {}", rd, mask)
2799
- }
2800
- &Inst::VecImmBitMask {
2801
- size,
2802
- rd,
2803
- start_bit,
2804
- end_bit,
2805
- } => {
2806
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2807
- let op = match size {
2808
- 8 => "vgmb",
2809
- 16 => "vgmh",
2810
- 32 => "vgmf",
2811
- 64 => "vgmg",
2812
- _ => unreachable!(),
2813
- };
2814
- format!("{} {}, {}, {}", op, rd, start_bit, end_bit)
2815
- }
2816
- &Inst::VecImmReplicate { size, rd, imm } => {
2817
- let rd = pretty_print_reg(rd.to_reg(), allocs);
2818
- let op = match size {
2819
- 8 => "vrepib",
2820
- 16 => "vrepih",
2821
- 32 => "vrepif",
2822
- 64 => "vrepig",
2823
- _ => unreachable!(),
2824
- };
2825
- format!("{} {}, {}", op, rd, imm)
2826
- }
2827
- &Inst::VecLoadLane {
2828
- size,
2829
- rd,
2830
- ri,
2831
- ref mem,
2832
- lane_imm,
2833
- }
2834
- | &Inst::VecLoadLaneRev {
2835
- size,
2836
- rd,
2837
- ri,
2838
- ref mem,
2839
- lane_imm,
2840
- } => {
2841
- let opcode_vrx = match (self, size) {
2842
- (&Inst::VecLoadLane { .. }, 8) => "vleb",
2843
- (&Inst::VecLoadLane { .. }, 16) => "vleh",
2844
- (&Inst::VecLoadLane { .. }, 32) => "vlef",
2845
- (&Inst::VecLoadLane { .. }, 64) => "vleg",
2846
- (&Inst::VecLoadLaneRev { .. }, 16) => "vlebrh",
2847
- (&Inst::VecLoadLaneRev { .. }, 32) => "vlebrf",
2848
- (&Inst::VecLoadLaneRev { .. }, 64) => "vlebrg",
2849
- _ => unreachable!(),
2850
- };
2851
-
2852
- let (rd, _) = pretty_print_fpr(rd.to_reg(), allocs);
2853
- let _ri = allocs.next(ri);
2854
- let mem = mem.with_allocs(allocs);
2855
- let (mem_str, mem) = mem_finalize_for_show(
2856
- &mem,
2857
- state,
2858
- MemInstType {
2859
- have_d12: true,
2860
- have_d20: false,
2861
- have_pcrel: false,
2862
- have_unaligned_pcrel: false,
2863
- have_index: true,
2864
- },
2865
- );
2866
- let mem = mem.pretty_print_default();
2867
- format!("{}{} {}, {}, {}", mem_str, opcode_vrx, rd, mem, lane_imm)
2868
- }
2869
- &Inst::VecLoadLaneUndef {
2870
- size,
2871
- rd,
2872
- ref mem,
2873
- lane_imm,
2874
- }
2875
- | &Inst::VecLoadLaneRevUndef {
2876
- size,
2877
- rd,
2878
- ref mem,
2879
- lane_imm,
2880
- } => {
2881
- let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
2882
- (&Inst::VecLoadLaneUndef { .. }, 8) => ("vleb", None, None),
2883
- (&Inst::VecLoadLaneUndef { .. }, 16) => ("vleh", None, None),
2884
- (&Inst::VecLoadLaneUndef { .. }, 32) => ("vlef", Some("le"), Some("ley")),
2885
- (&Inst::VecLoadLaneUndef { .. }, 64) => ("vleg", Some("ld"), Some("ldy")),
2886
- (&Inst::VecLoadLaneRevUndef { .. }, 16) => ("vlebrh", None, None),
2887
- (&Inst::VecLoadLaneRevUndef { .. }, 32) => ("vlebrf", None, None),
2888
- (&Inst::VecLoadLaneRevUndef { .. }, 64) => ("vlebrg", None, None),
2889
- _ => unreachable!(),
2890
- };
2891
-
2892
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2893
- let mem = mem.with_allocs(allocs);
2894
- if lane_imm == 0 && rd_fpr.is_some() && opcode_rx.is_some() {
2895
- let (mem_str, mem) = mem_finalize_for_show(
2896
- &mem,
2897
- state,
2898
- MemInstType {
2899
- have_d12: true,
2900
- have_d20: true,
2901
- have_pcrel: false,
2902
- have_unaligned_pcrel: false,
2903
- have_index: true,
2904
- },
2905
- );
2906
- let op = match &mem {
2907
- &MemArg::BXD12 { .. } => opcode_rx,
2908
- &MemArg::BXD20 { .. } => opcode_rxy,
2909
- _ => unreachable!(),
2910
- };
2911
- let mem = mem.pretty_print_default();
2912
- format!("{}{} {}, {}", mem_str, op.unwrap(), rd_fpr.unwrap(), mem)
2913
- } else {
2914
- let (mem_str, mem) = mem_finalize_for_show(
2915
- &mem,
2916
- state,
2917
- MemInstType {
2918
- have_d12: true,
2919
- have_d20: false,
2920
- have_pcrel: false,
2921
- have_unaligned_pcrel: false,
2922
- have_index: true,
2923
- },
2924
- );
2925
- let mem = mem.pretty_print_default();
2926
- format!("{}{} {}, {}, {}", mem_str, opcode_vrx, rd, mem, lane_imm)
2927
- }
2928
- }
2929
- &Inst::VecStoreLane {
2930
- size,
2931
- rd,
2932
- ref mem,
2933
- lane_imm,
2934
- }
2935
- | &Inst::VecStoreLaneRev {
2936
- size,
2937
- rd,
2938
- ref mem,
2939
- lane_imm,
2940
- } => {
2941
- let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
2942
- (&Inst::VecStoreLane { .. }, 8) => ("vsteb", None, None),
2943
- (&Inst::VecStoreLane { .. }, 16) => ("vsteh", None, None),
2944
- (&Inst::VecStoreLane { .. }, 32) => ("vstef", Some("ste"), Some("stey")),
2945
- (&Inst::VecStoreLane { .. }, 64) => ("vsteg", Some("std"), Some("stdy")),
2946
- (&Inst::VecStoreLaneRev { .. }, 16) => ("vstebrh", None, None),
2947
- (&Inst::VecStoreLaneRev { .. }, 32) => ("vstebrf", None, None),
2948
- (&Inst::VecStoreLaneRev { .. }, 64) => ("vstebrg", None, None),
2949
- _ => unreachable!(),
2950
- };
2951
-
2952
- let (rd, rd_fpr) = pretty_print_fpr(rd, allocs);
2953
- let mem = mem.with_allocs(allocs);
2954
- if lane_imm == 0 && rd_fpr.is_some() && opcode_rx.is_some() {
2955
- let (mem_str, mem) = mem_finalize_for_show(
2956
- &mem,
2957
- state,
2958
- MemInstType {
2959
- have_d12: true,
2960
- have_d20: true,
2961
- have_pcrel: false,
2962
- have_unaligned_pcrel: false,
2963
- have_index: true,
2964
- },
2965
- );
2966
- let op = match &mem {
2967
- &MemArg::BXD12 { .. } => opcode_rx,
2968
- &MemArg::BXD20 { .. } => opcode_rxy,
2969
- _ => unreachable!(),
2970
- };
2971
- let mem = mem.pretty_print_default();
2972
- format!("{}{} {}, {}", mem_str, op.unwrap(), rd_fpr.unwrap(), mem)
2973
- } else {
2974
- let (mem_str, mem) = mem_finalize_for_show(
2975
- &mem,
2976
- state,
2977
- MemInstType {
2978
- have_d12: true,
2979
- have_d20: false,
2980
- have_pcrel: false,
2981
- have_unaligned_pcrel: false,
2982
- have_index: true,
2983
- },
2984
- );
2985
- let mem = mem.pretty_print_default();
2986
- format!("{}{} {}, {}, {}", mem_str, opcode_vrx, rd, mem, lane_imm,)
2987
- }
2988
- }
2989
- &Inst::VecInsertLane {
2990
- size,
2991
- rd,
2992
- ri,
2993
- rn,
2994
- lane_imm,
2995
- lane_reg,
2996
- } => {
2997
- let op = match size {
2998
- 8 => "vlvgb",
2999
- 16 => "vlvgh",
3000
- 32 => "vlvgf",
3001
- 64 => "vlvgg",
3002
- _ => unreachable!(),
3003
- };
3004
- let rd = pretty_print_reg_mod(rd, ri, allocs);
3005
- let rn = pretty_print_reg(rn, allocs);
3006
- let lane_reg = if lane_reg != zero_reg() {
3007
- format!("({})", pretty_print_reg(lane_reg, allocs))
3008
- } else {
3009
- "".to_string()
3010
- };
3011
- format!("{} {}, {}, {}{}", op, rd, rn, lane_imm, lane_reg)
3012
- }
3013
- &Inst::VecInsertLaneUndef {
3014
- size,
3015
- rd,
3016
- rn,
3017
- lane_imm,
3018
- lane_reg,
3019
- } => {
3020
- let (opcode_vrs, opcode_rre) = match size {
3021
- 8 => ("vlvgb", None),
3022
- 16 => ("vlvgh", None),
3023
- 32 => ("vlvgf", None),
3024
- 64 => ("vlvgg", Some("ldgr")),
3025
- _ => unreachable!(),
3026
- };
3027
- let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
3028
- let rn = pretty_print_reg(rn, allocs);
3029
- let lane_reg = if lane_reg != zero_reg() {
3030
- format!("({})", pretty_print_reg(lane_reg, allocs))
3031
- } else {
3032
- "".to_string()
3033
- };
3034
- if opcode_rre.is_some() && lane_imm == 0 && lane_reg.is_empty() && rd_fpr.is_some()
3035
- {
3036
- format!("{} {}, {}", opcode_rre.unwrap(), rd_fpr.unwrap(), rn)
3037
- } else {
3038
- format!("{} {}, {}, {}{}", opcode_vrs, rd, rn, lane_imm, lane_reg)
3039
- }
3040
- }
3041
- &Inst::VecExtractLane {
3042
- size,
3043
- rd,
3044
- rn,
3045
- lane_imm,
3046
- lane_reg,
3047
- } => {
3048
- let (opcode_vrs, opcode_rre) = match size {
3049
- 8 => ("vlgvb", None),
3050
- 16 => ("vlgvh", None),
3051
- 32 => ("vlgvf", None),
3052
- 64 => ("vlgvg", Some("lgdr")),
3053
- _ => unreachable!(),
3054
- };
3055
- let rd = pretty_print_reg(rd.to_reg(), allocs);
3056
- let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
3057
- let lane_reg = if lane_reg != zero_reg() {
3058
- format!("({})", pretty_print_reg(lane_reg, allocs))
3059
- } else {
3060
- "".to_string()
3061
- };
3062
- if opcode_rre.is_some() && lane_imm == 0 && lane_reg.is_empty() && rn_fpr.is_some()
3063
- {
3064
- format!("{} {}, {}", opcode_rre.unwrap(), rd, rn_fpr.unwrap())
3065
- } else {
3066
- format!("{} {}, {}, {}{}", opcode_vrs, rd, rn, lane_imm, lane_reg)
3067
- }
3068
- }
3069
- &Inst::VecInsertLaneImm {
3070
- size,
3071
- rd,
3072
- ri,
3073
- imm,
3074
- lane_imm,
3075
- } => {
3076
- let op = match size {
3077
- 8 => "vleib",
3078
- 16 => "vleih",
3079
- 32 => "vleif",
3080
- 64 => "vleig",
3081
- _ => unreachable!(),
3082
- };
3083
- let rd = pretty_print_reg_mod(rd, ri, allocs);
3084
- format!("{} {}, {}, {}", op, rd, imm, lane_imm)
3085
- }
3086
- &Inst::VecReplicateLane {
3087
- size,
3088
- rd,
3089
- rn,
3090
- lane_imm,
3091
- } => {
3092
- let op = match size {
3093
- 8 => "vrepb",
3094
- 16 => "vreph",
3095
- 32 => "vrepf",
3096
- 64 => "vrepg",
3097
- _ => unreachable!(),
3098
- };
3099
- let rd = pretty_print_reg(rd.to_reg(), allocs);
3100
- let rn = pretty_print_reg(rn, allocs);
3101
- format!("{} {}, {}, {}", op, rd, rn, lane_imm)
3102
- }
3103
- &Inst::Extend {
3104
- rd,
3105
- rn,
3106
- signed,
3107
- from_bits,
3108
- to_bits,
3109
- } => {
3110
- let rd = pretty_print_reg(rd.to_reg(), allocs);
3111
- let rn = pretty_print_reg(rn, allocs);
3112
- let op = match (signed, from_bits, to_bits) {
3113
- (_, 1, 32) => "llcr",
3114
- (_, 1, 64) => "llgcr",
3115
- (false, 8, 32) => "llcr",
3116
- (false, 8, 64) => "llgcr",
3117
- (true, 8, 32) => "lbr",
3118
- (true, 8, 64) => "lgbr",
3119
- (false, 16, 32) => "llhr",
3120
- (false, 16, 64) => "llghr",
3121
- (true, 16, 32) => "lhr",
3122
- (true, 16, 64) => "lghr",
3123
- (false, 32, 64) => "llgfr",
3124
- (true, 32, 64) => "lgfr",
3125
- _ => panic!("Unsupported Extend case: {:?}", self),
3126
- };
3127
- format!("{} {}, {}", op, rd, rn)
3128
- }
3129
- &Inst::Call { link, ref info, .. } => {
3130
- let link = link.to_reg();
3131
- let tls_symbol = match &info.tls_symbol {
3132
- None => "".to_string(),
3133
- Some(SymbolReloc::TlsGd { name }) => {
3134
- format!(":tls_gdcall:{}", name.display(None))
3135
- }
3136
- _ => unreachable!(),
3137
- };
3138
- debug_assert_eq!(link, gpr(14));
3139
- format!(
3140
- "brasl {}, {}{}",
3141
- show_reg(link),
3142
- info.dest.display(None),
3143
- tls_symbol
3144
- )
3145
- }
3146
- &Inst::CallInd { link, ref info, .. } => {
3147
- let link = link.to_reg();
3148
- let rn = pretty_print_reg(info.rn, allocs);
3149
- debug_assert_eq!(link, gpr(14));
3150
- format!("basr {}, {}", show_reg(link), rn)
3151
- }
3152
- &Inst::Args { ref args } => {
3153
- let mut s = "args".to_string();
3154
- for arg in args {
3155
- use std::fmt::Write;
3156
- let preg = pretty_print_reg(arg.preg, &mut empty_allocs);
3157
- let def = pretty_print_reg(arg.vreg.to_reg(), allocs);
3158
- write!(&mut s, " {}={}", def, preg).unwrap();
3159
- }
3160
- s
3161
- }
3162
- &Inst::Ret { link, ref rets } => {
3163
- debug_assert_eq!(link, gpr(14));
3164
- let mut s = format!("br {}", show_reg(link));
3165
- for ret in rets {
3166
- use std::fmt::Write;
3167
- let preg = pretty_print_reg(ret.preg, &mut empty_allocs);
3168
- let vreg = pretty_print_reg(ret.vreg, allocs);
3169
- write!(&mut s, " {}={}", vreg, preg).unwrap();
3170
- }
3171
- s
3172
- }
3173
- &Inst::Jump { dest } => {
3174
- let dest = dest.to_string();
3175
- format!("jg {}", dest)
3176
- }
3177
- &Inst::IndirectBr { rn, .. } => {
3178
- let rn = pretty_print_reg(rn, allocs);
3179
- format!("br {}", rn)
3180
- }
3181
- &Inst::CondBr {
3182
- taken,
3183
- not_taken,
3184
- cond,
3185
- } => {
3186
- let taken = taken.to_string();
3187
- let not_taken = not_taken.to_string();
3188
- let cond = cond.pretty_print_default();
3189
- format!("jg{} {} ; jg {}", cond, taken, not_taken)
3190
- }
3191
- &Inst::OneWayCondBr { target, cond } => {
3192
- let target = target.to_string();
3193
- let cond = cond.pretty_print_default();
3194
- format!("jg{} {}", cond, target)
3195
- }
3196
- &Inst::Debugtrap => ".word 0x0001 # debugtrap".to_string(),
3197
- &Inst::Trap { trap_code } => {
3198
- format!(".word 0x0000 # trap={}", trap_code)
3199
- }
3200
- &Inst::TrapIf { cond, trap_code } => {
3201
- let cond = cond.pretty_print_default();
3202
- format!("jg{} .+2 # trap={}", cond, trap_code)
3203
- }
3204
- &Inst::JTSequence { ridx, ref targets } => {
3205
- let ridx = pretty_print_reg(ridx, allocs);
3206
- let rtmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
3207
- // The first entry is the default target, which is not emitted
3208
- // into the jump table, so we skip it here. It is only in the
3209
- // list so MachTerminator will see the potential target.
3210
- let jt_entries: String = targets
3211
- .iter()
3212
- .skip(1)
3213
- .map(|label| format!(" {}", label.to_string()))
3214
- .collect();
3215
- format!(
3216
- concat!(
3217
- "larl {}, 14 ; ",
3218
- "agf {}, 0({}, {}) ; ",
3219
- "br {} ; ",
3220
- "jt_entries{}"
3221
- ),
3222
- rtmp, rtmp, rtmp, ridx, rtmp, jt_entries,
3223
- )
3224
- }
3225
- &Inst::LoadSymbolReloc {
3226
- rd,
3227
- ref symbol_reloc,
3228
- } => {
3229
- let rd = pretty_print_reg(rd.to_reg(), allocs);
3230
- let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
3231
- let symbol = match &**symbol_reloc {
3232
- SymbolReloc::Absolute { name, offset } => {
3233
- format!("{} + {}", name.display(None), offset)
3234
- }
3235
- SymbolReloc::TlsGd { name } => format!("{}@tlsgd", name.display(None)),
3236
- };
3237
- format!("bras {}, 12 ; data {} ; lg {}, 0({})", tmp, symbol, rd, tmp)
3238
- }
3239
- &Inst::LoadAddr { rd, ref mem } => {
3240
- let rd = pretty_print_reg(rd.to_reg(), allocs);
3241
- let mem = mem.with_allocs(allocs);
3242
- let (mem_str, mem) = mem_finalize_for_show(
3243
- &mem,
3244
- state,
3245
- MemInstType {
3246
- have_d12: true,
3247
- have_d20: true,
3248
- have_pcrel: true,
3249
- have_unaligned_pcrel: true,
3250
- have_index: true,
3251
- },
3252
- );
3253
- let op = match &mem {
3254
- &MemArg::BXD12 { .. } => "la",
3255
- &MemArg::BXD20 { .. } => "lay",
3256
- &MemArg::Label { .. } | &MemArg::Symbol { .. } => "larl",
3257
- _ => unreachable!(),
3258
- };
3259
- let mem = mem.pretty_print_default();
3260
-
3261
- format!("{}{} {}, {}", mem_str, op, rd, mem)
3262
- }
3263
- &Inst::Loop { ref body, cond } => {
3264
- let body = body
3265
- .into_iter()
3266
- .map(|inst| inst.print_with_state(state, allocs))
3267
- .collect::<Vec<_>>()
3268
- .join(" ; ");
3269
- let cond = cond.pretty_print_default();
3270
- format!("0: {} ; jg{} 0b ; 1:", body, cond)
3271
- }
3272
- &Inst::CondBreak { cond } => {
3273
- let cond = cond.pretty_print_default();
3274
- format!("jg{} 1f", cond)
3275
- }
3276
- &Inst::VirtualSPOffsetAdj { offset } => {
3277
- state.virtual_sp_offset += offset;
3278
- format!("virtual_sp_offset_adjust {}", offset)
3279
- }
3280
- &Inst::Unwind { ref inst } => {
3281
- format!("unwind {:?}", inst)
3282
- }
3283
- &Inst::DummyUse { reg } => {
3284
- let reg = pretty_print_reg(reg, allocs);
3285
- format!("dummy_use {}", reg)
3286
- }
3287
- }
3288
- }
3289
- }
3290
-
3291
- //=============================================================================
3292
- // Label fixups and jump veneers.
3293
-
3294
- /// Different forms of label references for different instruction formats.
3295
- #[derive(Clone, Copy, Debug, PartialEq, Eq)]
3296
- pub enum LabelUse {
3297
- #[allow(dead_code)]
3298
- /// RI-format branch. 16-bit signed offset. PC-relative, offset is imm << 1.
3299
- BranchRI,
3300
- /// RIL-format branch. 32-bit signed offset. PC-relative, offset is imm << 1.
3301
- BranchRIL,
3302
- /// 32-bit PC relative constant offset (from address of constant itself),
3303
- /// signed. Used in jump tables.
3304
- PCRel32,
3305
- /// 32-bit PC relative constant offset (from address of call instruction),
3306
- /// signed. Offset is imm << 1. Used for call relocations.
3307
- PCRel32Dbl,
3308
- }
3309
-
3310
- impl MachInstLabelUse for LabelUse {
3311
- /// Alignment for veneer code.
3312
- const ALIGN: CodeOffset = 2;
3313
-
3314
- /// Maximum PC-relative range (positive), inclusive.
3315
- fn max_pos_range(self) -> CodeOffset {
3316
- match self {
3317
- // 16-bit signed immediate, left-shifted by 1.
3318
- LabelUse::BranchRI => ((1 << 15) - 1) << 1,
3319
- // 32-bit signed immediate, left-shifted by 1.
3320
- LabelUse::BranchRIL => 0xffff_fffe,
3321
- // 32-bit signed immediate.
3322
- LabelUse::PCRel32 => 0x7fff_ffff,
3323
- // 32-bit signed immediate, left-shifted by 1, offset by 2.
3324
- LabelUse::PCRel32Dbl => 0xffff_fffc,
3325
- }
3326
- }
3327
-
3328
- /// Maximum PC-relative range (negative).
3329
- fn max_neg_range(self) -> CodeOffset {
3330
- match self {
3331
- // 16-bit signed immediate, left-shifted by 1.
3332
- LabelUse::BranchRI => (1 << 15) << 1,
3333
- // 32-bit signed immediate, left-shifted by 1.
3334
- // NOTE: This should be 4GB, but CodeOffset is only u32.
3335
- LabelUse::BranchRIL => 0xffff_ffff,
3336
- // 32-bit signed immediate.
3337
- LabelUse::PCRel32 => 0x8000_0000,
3338
- // 32-bit signed immediate, left-shifted by 1, offset by 2.
3339
- // NOTE: This should be 4GB + 2, but CodeOffset is only u32.
3340
- LabelUse::PCRel32Dbl => 0xffff_ffff,
3341
- }
3342
- }
3343
-
3344
- /// Size of window into code needed to do the patch.
3345
- fn patch_size(self) -> CodeOffset {
3346
- match self {
3347
- LabelUse::BranchRI => 4,
3348
- LabelUse::BranchRIL => 6,
3349
- LabelUse::PCRel32 => 4,
3350
- LabelUse::PCRel32Dbl => 4,
3351
- }
3352
- }
3353
-
3354
- /// Perform the patch.
3355
- fn patch(self, buffer: &mut [u8], use_offset: CodeOffset, label_offset: CodeOffset) {
3356
- let pc_rel = (label_offset as i64) - (use_offset as i64);
3357
- debug_assert!(pc_rel <= self.max_pos_range() as i64);
3358
- debug_assert!(pc_rel >= -(self.max_neg_range() as i64));
3359
- debug_assert!(pc_rel & 1 == 0);
3360
- let pc_rel_shifted = pc_rel >> 1;
3361
-
3362
- match self {
3363
- LabelUse::BranchRI => {
3364
- buffer[2..4].clone_from_slice(&u16::to_be_bytes(pc_rel_shifted as u16));
3365
- }
3366
- LabelUse::BranchRIL => {
3367
- buffer[2..6].clone_from_slice(&u32::to_be_bytes(pc_rel_shifted as u32));
3368
- }
3369
- LabelUse::PCRel32 => {
3370
- let insn_word = u32::from_be_bytes([buffer[0], buffer[1], buffer[2], buffer[3]]);
3371
- let insn_word = insn_word.wrapping_add(pc_rel as u32);
3372
- buffer[0..4].clone_from_slice(&u32::to_be_bytes(insn_word));
3373
- }
3374
- LabelUse::PCRel32Dbl => {
3375
- let insn_word = u32::from_be_bytes([buffer[0], buffer[1], buffer[2], buffer[3]]);
3376
- let insn_word = insn_word.wrapping_add((pc_rel_shifted + 1) as u32);
3377
- buffer[0..4].clone_from_slice(&u32::to_be_bytes(insn_word));
3378
- }
3379
- }
3380
- }
3381
-
3382
- /// Is a veneer supported for this label reference type?
3383
- fn supports_veneer(self) -> bool {
3384
- false
3385
- }
3386
-
3387
- /// How large is the veneer, if supported?
3388
- fn veneer_size(self) -> CodeOffset {
3389
- 0
3390
- }
3391
-
3392
- /// Generate a veneer into the buffer, given that this veneer is at `veneer_offset`, and return
3393
- /// an offset and label-use for the veneer's use of the original label.
3394
- fn generate_veneer(
3395
- self,
3396
- _buffer: &mut [u8],
3397
- _veneer_offset: CodeOffset,
3398
- ) -> (CodeOffset, LabelUse) {
3399
- unreachable!();
3400
- }
3401
-
3402
- fn from_reloc(reloc: Reloc, addend: Addend) -> Option<Self> {
3403
- match (reloc, addend) {
3404
- (Reloc::S390xPCRel32Dbl, 2) => Some(LabelUse::PCRel32Dbl),
3405
- (Reloc::S390xPLTRel32Dbl, 2) => Some(LabelUse::PCRel32Dbl),
3406
- _ => None,
3407
- }
3408
- }
3409
- }