wasmtime 9.0.4 → 10.0.1

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.1/.cargo-checksum.json +1 -0
  325. data/ext/cargo-vendor/wasi-cap-std-sync-10.0.1/Cargo.toml +90 -0
  326. data/ext/cargo-vendor/wasi-cap-std-sync-10.0.1/src/dir.rs +464 -0
  327. data/ext/cargo-vendor/wasi-cap-std-sync-10.0.1/src/lib.rs +141 -0
  328. data/ext/cargo-vendor/wasi-common-10.0.1/.cargo-checksum.json +1 -0
  329. data/ext/cargo-vendor/wasi-common-10.0.1/Cargo.toml +87 -0
  330. data/ext/cargo-vendor/wasi-common-10.0.1/src/ctx.rs +128 -0
  331. data/ext/cargo-vendor/wasi-common-10.0.1/src/file.rs +262 -0
  332. data/ext/cargo-vendor/wasi-common-10.0.1/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.1/.cargo-checksum.json +1 -0
  444. data/ext/cargo-vendor/wasmtime-10.0.1/Cargo.toml +183 -0
  445. data/ext/cargo-vendor/wasmtime-10.0.1/src/compiler.rs +710 -0
  446. data/ext/cargo-vendor/wasmtime-10.0.1/src/component/component.rs +382 -0
  447. data/ext/cargo-vendor/wasmtime-10.0.1/src/component/instance.rs +727 -0
  448. data/ext/cargo-vendor/wasmtime-10.0.1/src/component/matching.rs +112 -0
  449. data/ext/cargo-vendor/wasmtime-10.0.1/src/component/mod.rs +313 -0
  450. data/ext/cargo-vendor/wasmtime-10.0.1/src/config.rs +2066 -0
  451. data/ext/cargo-vendor/wasmtime-10.0.1/src/engine/serialization.rs +622 -0
  452. data/ext/cargo-vendor/wasmtime-10.0.1/src/engine.rs +757 -0
  453. data/ext/cargo-vendor/wasmtime-10.0.1/src/externals.rs +763 -0
  454. data/ext/cargo-vendor/wasmtime-10.0.1/src/func/typed.rs +638 -0
  455. data/ext/cargo-vendor/wasmtime-10.0.1/src/func.rs +2355 -0
  456. data/ext/cargo-vendor/wasmtime-10.0.1/src/instance.rs +905 -0
  457. data/ext/cargo-vendor/wasmtime-10.0.1/src/lib.rs +486 -0
  458. data/ext/cargo-vendor/wasmtime-10.0.1/src/linker.rs +1479 -0
  459. data/ext/cargo-vendor/wasmtime-10.0.1/src/memory.rs +950 -0
  460. data/ext/cargo-vendor/wasmtime-10.0.1/src/module.rs +1274 -0
  461. data/ext/cargo-vendor/wasmtime-10.0.1/src/ref.rs +109 -0
  462. data/ext/cargo-vendor/wasmtime-10.0.1/src/store/context.rs +243 -0
  463. data/ext/cargo-vendor/wasmtime-10.0.1/src/store/func_refs.rs +85 -0
  464. data/ext/cargo-vendor/wasmtime-10.0.1/src/store.rs +2166 -0
  465. data/ext/cargo-vendor/wasmtime-10.0.1/src/trampoline/func.rs +133 -0
  466. data/ext/cargo-vendor/wasmtime-10.0.1/src/trampoline/global.rs +67 -0
  467. data/ext/cargo-vendor/wasmtime-10.0.1/src/types/matching.rs +312 -0
  468. data/ext/cargo-vendor/wasmtime-10.0.1/src/types.rs +572 -0
  469. data/ext/cargo-vendor/wasmtime-10.0.1/src/values.rs +290 -0
  470. data/ext/cargo-vendor/wasmtime-asm-macros-10.0.1/.cargo-checksum.json +1 -0
  471. data/ext/cargo-vendor/wasmtime-asm-macros-10.0.1/Cargo.toml +22 -0
  472. data/ext/cargo-vendor/wasmtime-cache-10.0.1/.cargo-checksum.json +1 -0
  473. data/ext/cargo-vendor/wasmtime-cache-10.0.1/Cargo.toml +73 -0
  474. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/.cargo-checksum.json +1 -0
  475. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/Cargo.toml +58 -0
  476. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/src/bindgen.rs +316 -0
  477. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/char.wit +13 -0
  478. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/conventions.wit +39 -0
  479. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/direct-import.wit +5 -0
  480. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/empty.wit +2 -0
  481. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/flags.wit +55 -0
  482. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/floats.wit +13 -0
  483. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/function-new.wit +4 -0
  484. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/integers.wit +40 -0
  485. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/lists.wit +85 -0
  486. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/many-arguments.wit +52 -0
  487. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/multi-return.wit +14 -0
  488. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/records.wit +61 -0
  489. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/rename.wit +16 -0
  490. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/share-types.wit +21 -0
  491. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/simple-functions.wit +17 -0
  492. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/simple-lists.wit +13 -0
  493. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/simple-wasi.wit +23 -0
  494. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/small-anonymous.wit +15 -0
  495. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/smoke-default.wit +5 -0
  496. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/smoke-export.wit +7 -0
  497. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/smoke.wit +7 -0
  498. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/strings.wit +12 -0
  499. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/unions.wit +66 -0
  500. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/use-paths.wit +29 -0
  501. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/variants.wit +147 -0
  502. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen/worlds-with-types.wit +16 -0
  503. data/ext/cargo-vendor/wasmtime-component-macro-10.0.1/tests/codegen.rs +24 -0
  504. data/ext/cargo-vendor/wasmtime-component-util-10.0.1/.cargo-checksum.json +1 -0
  505. data/ext/cargo-vendor/wasmtime-component-util-10.0.1/Cargo.toml +25 -0
  506. data/ext/cargo-vendor/wasmtime-cranelift-10.0.1/.cargo-checksum.json +1 -0
  507. data/ext/cargo-vendor/wasmtime-cranelift-10.0.1/Cargo.toml +90 -0
  508. data/ext/cargo-vendor/wasmtime-cranelift-10.0.1/src/compiler.rs +1200 -0
  509. data/ext/cargo-vendor/wasmtime-cranelift-10.0.1/src/debug/transform/simulate.rs +410 -0
  510. data/ext/cargo-vendor/wasmtime-cranelift-10.0.1/src/func_environ.rs +2206 -0
  511. data/ext/cargo-vendor/wasmtime-cranelift-10.0.1/src/lib.rs +178 -0
  512. data/ext/cargo-vendor/wasmtime-cranelift-shared-10.0.1/.cargo-checksum.json +1 -0
  513. data/ext/cargo-vendor/wasmtime-cranelift-shared-10.0.1/Cargo.toml +57 -0
  514. data/ext/cargo-vendor/wasmtime-cranelift-shared-10.0.1/src/lib.rs +120 -0
  515. data/ext/cargo-vendor/wasmtime-environ-10.0.1/.cargo-checksum.json +1 -0
  516. data/ext/cargo-vendor/wasmtime-environ-10.0.1/Cargo.lock +681 -0
  517. data/ext/cargo-vendor/wasmtime-environ-10.0.1/Cargo.toml +116 -0
  518. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/component/compiler.rs +84 -0
  519. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/component/translate/inline.rs +1067 -0
  520. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/component/translate.rs +1070 -0
  521. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/component/types.rs +1916 -0
  522. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/fact.rs +623 -0
  523. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/module.rs +1083 -0
  524. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/module_environ.rs +884 -0
  525. data/ext/cargo-vendor/wasmtime-environ-10.0.1/src/trap_encoding.rs +238 -0
  526. data/ext/cargo-vendor/wasmtime-fiber-10.0.1/.cargo-checksum.json +1 -0
  527. data/ext/cargo-vendor/wasmtime-fiber-10.0.1/Cargo.toml +46 -0
  528. data/ext/cargo-vendor/wasmtime-fiber-10.0.1/src/lib.rs +305 -0
  529. data/ext/cargo-vendor/wasmtime-fiber-10.0.1/src/unix.rs +212 -0
  530. data/ext/cargo-vendor/wasmtime-fiber-10.0.1/src/windows.rs +161 -0
  531. data/ext/cargo-vendor/wasmtime-jit-10.0.1/.cargo-checksum.json +1 -0
  532. data/ext/cargo-vendor/wasmtime-jit-10.0.1/Cargo.toml +104 -0
  533. data/ext/cargo-vendor/wasmtime-jit-10.0.1/src/instantiate.rs +760 -0
  534. data/ext/cargo-vendor/wasmtime-jit-10.0.1/src/lib.rs +38 -0
  535. data/ext/cargo-vendor/wasmtime-jit-10.0.1/src/profiling/jitdump.rs +66 -0
  536. data/ext/cargo-vendor/wasmtime-jit-10.0.1/src/profiling/perfmap.rs +47 -0
  537. data/ext/cargo-vendor/wasmtime-jit-10.0.1/src/profiling/vtune.rs +80 -0
  538. data/ext/cargo-vendor/wasmtime-jit-10.0.1/src/profiling.rs +108 -0
  539. data/ext/cargo-vendor/wasmtime-jit-debug-10.0.1/.cargo-checksum.json +1 -0
  540. data/ext/cargo-vendor/wasmtime-jit-debug-10.0.1/Cargo.toml +55 -0
  541. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-10.0.1/.cargo-checksum.json +1 -0
  542. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-10.0.1/Cargo.toml +37 -0
  543. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/.cargo-checksum.json +1 -0
  544. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/Cargo.toml +110 -0
  545. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/component.rs +701 -0
  546. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/cow.rs +1060 -0
  547. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/debug_builtins.rs +58 -0
  548. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/externref.rs +1073 -0
  549. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/instance/allocator/pooling.rs +1368 -0
  550. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/instance/allocator.rs +531 -0
  551. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/instance.rs +1345 -0
  552. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/lib.rs +285 -0
  553. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/libcalls.rs +578 -0
  554. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/memory.rs +958 -0
  555. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/mmap/miri.rs +94 -0
  556. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/mmap/unix.rs +148 -0
  557. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/mmap/windows.rs +208 -0
  558. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/send_sync_ptr.rs +69 -0
  559. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/table.rs +595 -0
  560. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/traphandlers/unix.rs +387 -0
  561. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/traphandlers.rs +749 -0
  562. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/src/vmcontext/vm_host_func_context.rs +137 -0
  563. data/ext/cargo-vendor/wasmtime-runtime-10.0.1/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.1/.cargo-checksum.json +1 -0
  568. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/Cargo.toml +153 -0
  569. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/lib.rs +131 -0
  570. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/clocks/host.rs +73 -0
  571. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/clocks.rs +17 -0
  572. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/ctx.rs +206 -0
  573. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/error.rs +16 -0
  574. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/filesystem.rs +269 -0
  575. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/mod.rs +44 -0
  576. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/pipe.rs +233 -0
  577. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview1/mod.rs +1860 -0
  578. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/clocks.rs +80 -0
  579. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/env.rs +48 -0
  580. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/exit.rs +12 -0
  581. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/filesystem.rs +1020 -0
  582. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/io.rs +215 -0
  583. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/mod.rs +7 -0
  584. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/poll.rs +84 -0
  585. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/preview2/random.rs +41 -0
  586. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/random.rs +58 -0
  587. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/sched/subscription.rs +104 -0
  588. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/sched/sync.rs +156 -0
  589. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/sched.rs +105 -0
  590. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/stdio.rs +176 -0
  591. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/stream.rs +210 -0
  592. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/table.rs +107 -0
  593. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/wasi/command.rs +43 -0
  594. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/src/preview2/wasi/mod.rs +30 -0
  595. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/clocks/monotonic-clock.wit +34 -0
  596. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/clocks/timezone.wit +63 -0
  597. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/clocks/wall-clock.wit +43 -0
  598. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/filesystem/filesystem.wit +782 -0
  599. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/http/incoming-handler.wit +24 -0
  600. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/http/outgoing-handler.wit +18 -0
  601. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/http/types.wit +159 -0
  602. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/io/streams.wit +215 -0
  603. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/logging/handler.wit +34 -0
  604. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/poll/poll.wit +41 -0
  605. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/preview/command-extended.wit +36 -0
  606. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/preview/command.wit +26 -0
  607. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/preview/proxy.wit +9 -0
  608. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/preview/reactor.wit +24 -0
  609. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/random/insecure-seed.wit +24 -0
  610. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/random/insecure.wit +21 -0
  611. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/random/random.wit +25 -0
  612. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/sockets/instance-network.wit +9 -0
  613. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/sockets/ip-name-lookup.wit +69 -0
  614. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/sockets/network.wit +187 -0
  615. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/sockets/tcp-create-socket.wit +27 -0
  616. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/sockets/tcp.wit +255 -0
  617. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/sockets/udp-create-socket.wit +27 -0
  618. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/sockets/udp.wit +211 -0
  619. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/wasi-cli-base/environment.wit +16 -0
  620. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/wasi-cli-base/exit.wit +4 -0
  621. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/wasi-cli-base/preopens.wit +7 -0
  622. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/deps/wasi-cli-base/stdio.wit +17 -0
  623. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/main.wit +1 -0
  624. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/wit/test.wit +19 -0
  625. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/witx/typenames.witx +750 -0
  626. data/ext/cargo-vendor/wasmtime-wasi-10.0.1/witx/wasi_snapshot_preview1.witx +521 -0
  627. data/ext/cargo-vendor/wasmtime-winch-10.0.1/.cargo-checksum.json +1 -0
  628. data/ext/cargo-vendor/wasmtime-winch-10.0.1/Cargo.toml +63 -0
  629. data/ext/cargo-vendor/wasmtime-winch-10.0.1/src/compiler.rs +220 -0
  630. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.1/.cargo-checksum.json +1 -0
  631. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.1/Cargo.toml +29 -0
  632. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.1/src/lib.rs +1631 -0
  633. data/ext/cargo-vendor/wasmtime-wit-bindgen-10.0.1/src/types.rs +179 -0
  634. data/ext/cargo-vendor/wiggle-10.0.1/.cargo-checksum.json +1 -0
  635. data/ext/cargo-vendor/wiggle-10.0.1/Cargo.toml +106 -0
  636. data/ext/cargo-vendor/wiggle-10.0.1/LICENSE +220 -0
  637. data/ext/cargo-vendor/wiggle-10.0.1/README.md +18 -0
  638. data/ext/cargo-vendor/wiggle-generate-10.0.1/.cargo-checksum.json +1 -0
  639. data/ext/cargo-vendor/wiggle-generate-10.0.1/Cargo.toml +58 -0
  640. data/ext/cargo-vendor/wiggle-generate-10.0.1/LICENSE +220 -0
  641. data/ext/cargo-vendor/wiggle-macro-10.0.1/.cargo-checksum.json +1 -0
  642. data/ext/cargo-vendor/wiggle-macro-10.0.1/Cargo.toml +55 -0
  643. data/ext/cargo-vendor/wiggle-macro-10.0.1/LICENSE +220 -0
  644. data/ext/cargo-vendor/wiggle-macro-10.0.1/src/lib.rs +210 -0
  645. data/ext/cargo-vendor/winch-codegen-0.8.1/.cargo-checksum.json +1 -0
  646. data/ext/cargo-vendor/winch-codegen-0.8.1/Cargo.toml +62 -0
  647. data/ext/cargo-vendor/winch-codegen-0.8.1/src/abi/local.rs +70 -0
  648. data/ext/cargo-vendor/winch-codegen-0.8.1/src/abi/mod.rs +237 -0
  649. data/ext/cargo-vendor/winch-codegen-0.8.1/src/codegen/call.rs +225 -0
  650. data/ext/cargo-vendor/winch-codegen-0.8.1/src/codegen/context.rs +270 -0
  651. data/ext/cargo-vendor/winch-codegen-0.8.1/src/codegen/env.rs +52 -0
  652. data/ext/cargo-vendor/winch-codegen-0.8.1/src/codegen/mod.rs +214 -0
  653. data/ext/cargo-vendor/winch-codegen-0.8.1/src/frame/mod.rs +172 -0
  654. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/aarch64/abi.rs +243 -0
  655. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/aarch64/asm.rs +300 -0
  656. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/aarch64/masm.rs +230 -0
  657. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/aarch64/mod.rs +127 -0
  658. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/aarch64/regs.rs +166 -0
  659. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/mod.rs +215 -0
  660. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/x64/abi.rs +369 -0
  661. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/x64/address.rs +17 -0
  662. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/x64/asm.rs +576 -0
  663. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/x64/masm.rs +288 -0
  664. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/x64/mod.rs +149 -0
  665. data/ext/cargo-vendor/winch-codegen-0.8.1/src/isa/x64/regs.rs +192 -0
  666. data/ext/cargo-vendor/winch-codegen-0.8.1/src/lib.rs +21 -0
  667. data/ext/cargo-vendor/winch-codegen-0.8.1/src/masm.rs +255 -0
  668. data/ext/cargo-vendor/winch-codegen-0.8.1/src/regalloc.rs +70 -0
  669. data/ext/cargo-vendor/winch-codegen-0.8.1/src/stack.rs +235 -0
  670. data/ext/cargo-vendor/winch-codegen-0.8.1/src/trampoline.rs +494 -0
  671. data/ext/cargo-vendor/winch-codegen-0.8.1/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.1}/LICENSE +0 -0
  1669. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/README.md +0 -0
  1670. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/src/clocks.rs +0 -0
  1671. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/src/file.rs +0 -0
  1672. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/src/net.rs +0 -0
  1673. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/src/sched/unix.rs +0 -0
  1674. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/src/sched/windows.rs +0 -0
  1675. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/src/sched.rs +0 -0
  1676. /data/ext/cargo-vendor/{wasi-cap-std-sync-9.0.4 → wasi-cap-std-sync-10.0.1}/src/stdio.rs +0 -0
  1677. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/LICENSE +0 -0
  1678. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/README.md +0 -0
  1679. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/README.md +0 -0
  1680. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/docs/README.md +0 -0
  1681. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/README.md +0 -0
  1682. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/docs.md +0 -0
  1683. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/typenames.witx +0 -0
  1684. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_args.witx +0 -0
  1685. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_clock.witx +0 -0
  1686. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_environ.witx +0 -0
  1687. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_fd.witx +0 -0
  1688. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_path.witx +0 -0
  1689. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_poll.witx +0 -0
  1690. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_proc.witx +0 -0
  1691. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_random.witx +0 -0
  1692. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_sched.witx +0 -0
  1693. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/ephemeral/witx/wasi_ephemeral_sock.witx +0 -0
  1694. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/old/snapshot_0/docs.md +0 -0
  1695. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/old/snapshot_0/witx/typenames.witx +0 -0
  1696. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/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.1}/WASI/phases/snapshot/docs.html +0 -0
  1698. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/snapshot/docs.md +0 -0
  1699. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/snapshot/witx/typenames.witx +0 -0
  1700. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/phases/snapshot/witx/wasi_snapshot_preview1.witx +0 -0
  1701. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/proposal-template/README.md +0 -0
  1702. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/proposals/README.md +0 -0
  1703. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/snapshots/README.md +0 -0
  1704. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/WASI/standard/README.md +0 -0
  1705. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/build.rs +0 -0
  1706. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/clocks.rs +0 -0
  1707. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/dir.rs +0 -0
  1708. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/error.rs +0 -0
  1709. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/lib.rs +0 -0
  1710. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/pipe.rs +0 -0
  1711. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/random.rs +0 -0
  1712. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/sched/subscription.rs +0 -0
  1713. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/sched.rs +0 -0
  1714. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/snapshots/mod.rs +0 -0
  1715. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/snapshots/preview_0.rs +0 -0
  1716. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/snapshots/preview_1/error.rs +0 -0
  1717. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/src/string_array.rs +0 -0
  1718. /data/ext/cargo-vendor/{wasi-common-9.0.4 → wasi-common-10.0.1}/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.1}/LICENSE +0 -0
  1749. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/README.md +0 -0
  1750. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/code.rs +0 -0
  1751. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/func/host.rs +0 -0
  1752. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/func/options.rs +0 -0
  1753. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/func/typed.rs +0 -0
  1754. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/func.rs +0 -0
  1755. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/linker.rs +0 -0
  1756. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/storage.rs +0 -0
  1757. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/store.rs +0 -0
  1758. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/types.rs +0 -0
  1759. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/component/values.rs +0 -0
  1760. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/limits.rs +0 -0
  1761. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/module/registry.rs +0 -0
  1762. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/profiling.rs +0 -0
  1763. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/signatures.rs +0 -0
  1764. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/store/data.rs +0 -0
  1765. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/trampoline/memory.rs +0 -0
  1766. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/trampoline/table.rs +0 -0
  1767. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/trampoline.rs +0 -0
  1768. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/trap.rs +0 -0
  1769. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/unix.rs +0 -0
  1770. /data/ext/cargo-vendor/{wasmtime-9.0.4 → wasmtime-10.0.1}/src/windows.rs +0 -0
  1771. /data/ext/cargo-vendor/{wasmtime-asm-macros-9.0.4 → wasmtime-asm-macros-10.0.1}/src/lib.rs +0 -0
  1772. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-cache-10.0.1}/LICENSE +0 -0
  1773. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/build.rs +0 -0
  1774. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/src/config/tests.rs +0 -0
  1775. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/src/config.rs +0 -0
  1776. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/src/lib.rs +0 -0
  1777. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/src/tests.rs +0 -0
  1778. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/src/worker/tests/system_time_stub.rs +0 -0
  1779. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/src/worker/tests.rs +0 -0
  1780. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/src/worker.rs +0 -0
  1781. /data/ext/cargo-vendor/{wasmtime-cache-9.0.4 → wasmtime-cache-10.0.1}/tests/cache_write_default_config.rs +0 -0
  1782. /data/ext/cargo-vendor/{wasmtime-component-macro-9.0.4 → wasmtime-component-macro-10.0.1}/src/component.rs +0 -0
  1783. /data/ext/cargo-vendor/{wasmtime-component-macro-9.0.4 → wasmtime-component-macro-10.0.1}/src/lib.rs +0 -0
  1784. /data/ext/cargo-vendor/{wasmtime-component-util-9.0.4 → wasmtime-component-util-10.0.1}/src/lib.rs +0 -0
  1785. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-cranelift-10.0.1}/LICENSE +0 -0
  1786. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/SECURITY.md +0 -0
  1787. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/builder.rs +0 -0
  1788. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/compiler/component.rs +0 -0
  1789. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/gc.rs +0 -0
  1790. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/address_transform.rs +0 -0
  1791. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/attr.rs +0 -0
  1792. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/expression.rs +0 -0
  1793. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/line_program.rs +0 -0
  1794. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/mod.rs +0 -0
  1795. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/range_info_builder.rs +0 -0
  1796. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/refs.rs +0 -0
  1797. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/unit.rs +0 -0
  1798. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/transform/utils.rs +0 -0
  1799. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug/write_debuginfo.rs +0 -0
  1800. /data/ext/cargo-vendor/{wasmtime-cranelift-9.0.4 → wasmtime-cranelift-10.0.1}/src/debug.rs +0 -0
  1801. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-9.0.4 → wasmtime-cranelift-shared-10.0.1}/src/compiled_function.rs +0 -0
  1802. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-9.0.4 → wasmtime-cranelift-shared-10.0.1}/src/isa_builder.rs +0 -0
  1803. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-9.0.4 → wasmtime-cranelift-shared-10.0.1}/src/obj.rs +0 -0
  1804. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-environ-10.0.1}/LICENSE +0 -0
  1805. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/examples/factc.rs +0 -0
  1806. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/address_map.rs +0 -0
  1807. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/builtin.rs +0 -0
  1808. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/compilation.rs +0 -0
  1809. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/component/dfg.rs +0 -0
  1810. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/component/info.rs +0 -0
  1811. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/component/translate/adapt.rs +0 -0
  1812. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/component/vmcomponent_offsets.rs +0 -0
  1813. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/component.rs +0 -0
  1814. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/fact/core_types.rs +0 -0
  1815. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/fact/signature.rs +0 -0
  1816. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/fact/trampoline.rs +0 -0
  1817. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/fact/transcode.rs +0 -0
  1818. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/fact/traps.rs +0 -0
  1819. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/lib.rs +0 -0
  1820. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/module_types.rs +0 -0
  1821. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/obj.rs +0 -0
  1822. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/ref_bits.rs +0 -0
  1823. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/scopevec.rs +0 -0
  1824. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/stack_map.rs +0 -0
  1825. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/tunables.rs +0 -0
  1826. /data/ext/cargo-vendor/{wasmtime-environ-9.0.4 → wasmtime-environ-10.0.1}/src/vmoffsets.rs +0 -0
  1827. /data/ext/cargo-vendor/{wasmtime-types-9.0.4 → wasmtime-fiber-10.0.1}/LICENSE +0 -0
  1828. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/build.rs +0 -0
  1829. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/src/unix/aarch64.rs +0 -0
  1830. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/src/unix/arm.rs +0 -0
  1831. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/src/unix/riscv64.rs +0 -0
  1832. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/src/unix/s390x.S +0 -0
  1833. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/src/unix/x86.rs +0 -0
  1834. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/src/unix/x86_64.rs +0 -0
  1835. /data/ext/cargo-vendor/{wasmtime-fiber-9.0.4 → wasmtime-fiber-10.0.1}/src/windows.c +0 -0
  1836. /data/ext/cargo-vendor/{wasmtime-wasi-9.0.4 → wasmtime-jit-10.0.1}/LICENSE +0 -0
  1837. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.1}/src/code_memory.rs +0 -0
  1838. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.1}/src/debug.rs +0 -0
  1839. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.1}/src/demangling.rs +0 -0
  1840. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.1}/src/unwind/miri.rs +0 -0
  1841. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.1}/src/unwind/systemv.rs +0 -0
  1842. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.1}/src/unwind/winx64.rs +0 -0
  1843. /data/ext/cargo-vendor/{wasmtime-jit-9.0.4 → wasmtime-jit-10.0.1}/src/unwind.rs +0 -0
  1844. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.1}/README.md +0 -0
  1845. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.1}/src/gdb_jit_int.rs +0 -0
  1846. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.1}/src/lib.rs +0 -0
  1847. /data/ext/cargo-vendor/{wasmtime-jit-debug-9.0.4 → wasmtime-jit-debug-10.0.1}/src/perf_jitdump.rs +0 -0
  1848. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.1}/src/lib.rs +0 -0
  1849. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.1}/src/libc.rs +0 -0
  1850. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.1}/src/miri.rs +0 -0
  1851. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-9.0.4 → wasmtime-jit-icache-coherence-10.0.1}/src/win.rs +0 -0
  1852. /data/ext/cargo-vendor/{wiggle-9.0.4 → wasmtime-runtime-10.0.1}/LICENSE +0 -0
  1853. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/build.rs +0 -0
  1854. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/component/transcode.rs +0 -0
  1855. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/export.rs +0 -0
  1856. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/helpers.c +0 -0
  1857. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/imports.rs +0 -0
  1858. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/instance/allocator/pooling/index_allocator.rs +0 -0
  1859. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/instance/allocator/pooling/unix.rs +0 -0
  1860. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/instance/allocator/pooling/windows.rs +0 -0
  1861. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/mmap.rs +0 -0
  1862. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/mmap_vec.rs +0 -0
  1863. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/module_id.rs +0 -0
  1864. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/parking_spot.rs +0 -0
  1865. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/store_box.rs +0 -0
  1866. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/trampolines/aarch64.rs +0 -0
  1867. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/trampolines/riscv64.rs +0 -0
  1868. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/trampolines/s390x.S +0 -0
  1869. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/trampolines/s390x.rs +0 -0
  1870. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/trampolines/x86_64.rs +0 -0
  1871. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/trampolines.rs +0 -0
  1872. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/traphandlers/backtrace/aarch64.rs +0 -0
  1873. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/traphandlers/backtrace/riscv64.rs +0 -0
  1874. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/traphandlers/backtrace/s390x.rs +0 -0
  1875. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/traphandlers/backtrace/x86_64.rs +0 -0
  1876. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/traphandlers/backtrace.rs +0 -0
  1877. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/src/traphandlers/macos.rs +0 -0
  1878. /data/ext/cargo-vendor/{wasmtime-runtime-9.0.4 → wasmtime-runtime-10.0.1}/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.1}/LICENSE +0 -0
  1882. /data/ext/cargo-vendor/{wasmtime-wasi-9.0.4 → wasmtime-wasi-10.0.1}/README.md +0 -0
  1883. /data/ext/cargo-vendor/{wasmtime-wasi-9.0.4 → wasmtime-wasi-10.0.1}/build.rs +0 -0
  1884. /data/ext/cargo-vendor/{wasmtime-winch-9.0.4 → wasmtime-winch-10.0.1}/LICENSE +0 -0
  1885. /data/ext/cargo-vendor/{wasmtime-winch-9.0.4 → wasmtime-winch-10.0.1}/src/builder.rs +0 -0
  1886. /data/ext/cargo-vendor/{wasmtime-winch-9.0.4 → wasmtime-winch-10.0.1}/src/lib.rs +0 -0
  1887. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-9.0.4 → wasmtime-wit-bindgen-10.0.1}/src/rust.rs +0 -0
  1888. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-9.0.4 → wasmtime-wit-bindgen-10.0.1}/src/source.rs +0 -0
  1889. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.1}/src/borrow.rs +0 -0
  1890. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.1}/src/error.rs +0 -0
  1891. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.1}/src/guest_type.rs +0 -0
  1892. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.1}/src/lib.rs +0 -0
  1893. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.1}/src/region.rs +0 -0
  1894. /data/ext/cargo-vendor/{wiggle-9.0.4 → wiggle-10.0.1}/src/wasmtime.rs +0 -0
  1895. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/README.md +0 -0
  1896. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/codegen_settings.rs +0 -0
  1897. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/config.rs +0 -0
  1898. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/funcs.rs +0 -0
  1899. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/lib.rs +0 -0
  1900. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/lifetimes.rs +0 -0
  1901. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/module_trait.rs +0 -0
  1902. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/names.rs +0 -0
  1903. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/types/error.rs +0 -0
  1904. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/types/flags.rs +0 -0
  1905. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/types/handle.rs +0 -0
  1906. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/types/mod.rs +0 -0
  1907. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/types/record.rs +0 -0
  1908. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/types/variant.rs +0 -0
  1909. /data/ext/cargo-vendor/{wiggle-generate-9.0.4 → wiggle-generate-10.0.1}/src/wasmtime.rs +0 -0
  1910. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.1}/LICENSE +0 -0
  1911. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.1}/build.rs +0 -0
  1912. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.1}/src/isa/aarch64/address.rs +0 -0
  1913. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.1}/src/isa/reg.rs +0 -0
  1914. /data/ext/cargo-vendor/{winch-codegen-0.7.4 → winch-codegen-0.8.1}/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
@@ -0,0 +1,2966 @@
1
+ //! This module defines aarch64-specific machine instruction types.
2
+
3
+ use crate::binemit::{Addend, CodeOffset, Reloc};
4
+ use crate::ir::types::{F32, F64, I128, I16, I32, I64, I8, I8X16, R32, R64};
5
+ use crate::ir::{types, ExternalName, MemFlags, Opcode, Type};
6
+ use crate::isa::{CallConv, FunctionAlignment};
7
+ use crate::machinst::*;
8
+ use crate::{settings, CodegenError, CodegenResult};
9
+
10
+ use crate::machinst::{PrettyPrint, Reg, RegClass, Writable};
11
+
12
+ use alloc::vec::Vec;
13
+ use regalloc2::{PRegSet, VReg};
14
+ use smallvec::{smallvec, SmallVec};
15
+ use std::fmt::Write;
16
+ use std::string::{String, ToString};
17
+
18
+ pub(crate) mod regs;
19
+ pub(crate) use self::regs::*;
20
+ pub mod imms;
21
+ pub use self::imms::*;
22
+ pub mod args;
23
+ pub use self::args::*;
24
+ pub mod emit;
25
+ pub(crate) use self::emit::*;
26
+ use crate::isa::aarch64::abi::AArch64MachineDeps;
27
+
28
+ pub(crate) mod unwind;
29
+
30
+ #[cfg(test)]
31
+ mod emit_tests;
32
+
33
+ //=============================================================================
34
+ // Instructions (top level): definition
35
+
36
+ pub use crate::isa::aarch64::lower::isle::generated_code::{
37
+ ALUOp, ALUOp3, AMode, APIKey, AtomicRMWLoopOp, AtomicRMWOp, BitOp, BranchTargetType, FPUOp1,
38
+ FPUOp2, FPUOp3, FpuRoundMode, FpuToIntOp, IntToFpuOp, MInst as Inst, MoveWideOp, VecALUModOp,
39
+ VecALUOp, VecExtendOp, VecLanesOp, VecMisc2, VecPairOp, VecRRLongOp, VecRRNarrowOp,
40
+ VecRRPairLongOp, VecRRRLongModOp, VecRRRLongOp, VecShiftImmModOp, VecShiftImmOp,
41
+ };
42
+
43
+ /// A floating-point unit (FPU) operation with two args, a register and an immediate.
44
+ #[derive(Copy, Clone, Debug)]
45
+ pub enum FPUOpRI {
46
+ /// Unsigned right shift. Rd = Rn << #imm
47
+ UShr32(FPURightShiftImm),
48
+ /// Unsigned right shift. Rd = Rn << #imm
49
+ UShr64(FPURightShiftImm),
50
+ }
51
+
52
+ /// A floating-point unit (FPU) operation with two args, a register and
53
+ /// an immediate that modifies its dest (so takes that input value as a
54
+ /// separate virtual register).
55
+ #[derive(Copy, Clone, Debug)]
56
+ pub enum FPUOpRIMod {
57
+ /// Shift left and insert. Rd |= Rn << #imm
58
+ Sli32(FPULeftShiftImm),
59
+ /// Shift left and insert. Rd |= Rn << #imm
60
+ Sli64(FPULeftShiftImm),
61
+ }
62
+
63
+ impl BitOp {
64
+ /// Get the assembly mnemonic for this opcode.
65
+ pub fn op_str(&self) -> &'static str {
66
+ match self {
67
+ BitOp::RBit => "rbit",
68
+ BitOp::Clz => "clz",
69
+ BitOp::Cls => "cls",
70
+ BitOp::Rev16 => "rev16",
71
+ BitOp::Rev32 => "rev32",
72
+ BitOp::Rev64 => "rev64",
73
+ }
74
+ }
75
+ }
76
+
77
+ /// Additional information for (direct) Call instructions, left out of line to lower the size of
78
+ /// the Inst enum.
79
+ #[derive(Clone, Debug)]
80
+ pub struct CallInfo {
81
+ /// Call destination.
82
+ pub dest: ExternalName,
83
+ /// Arguments to the call instruction.
84
+ pub uses: CallArgList,
85
+ /// Return values from the call instruction.
86
+ pub defs: CallRetList,
87
+ /// Clobbers register set.
88
+ pub clobbers: PRegSet,
89
+ /// Instruction opcode.
90
+ pub opcode: Opcode,
91
+ /// Caller calling convention.
92
+ pub caller_callconv: CallConv,
93
+ /// Callee calling convention.
94
+ pub callee_callconv: CallConv,
95
+ }
96
+
97
+ /// Additional information for CallInd instructions, left out of line to lower the size of the Inst
98
+ /// enum.
99
+ #[derive(Clone, Debug)]
100
+ pub struct CallIndInfo {
101
+ /// Function pointer for indirect call.
102
+ pub rn: Reg,
103
+ /// Arguments to the call instruction.
104
+ pub uses: SmallVec<[CallArgPair; 8]>,
105
+ /// Return values from the call instruction.
106
+ pub defs: SmallVec<[CallRetPair; 8]>,
107
+ /// Clobbers register set.
108
+ pub clobbers: PRegSet,
109
+ /// Instruction opcode.
110
+ pub opcode: Opcode,
111
+ /// Caller calling convention.
112
+ pub caller_callconv: CallConv,
113
+ /// Callee calling convention.
114
+ pub callee_callconv: CallConv,
115
+ }
116
+
117
+ /// Additional information for JTSequence instructions, left out of line to lower the size of the Inst
118
+ /// enum.
119
+ #[derive(Clone, Debug)]
120
+ pub struct JTSequenceInfo {
121
+ /// Possible branch targets.
122
+ pub targets: Vec<BranchTarget>,
123
+ /// Default branch target.
124
+ pub default_target: BranchTarget,
125
+ }
126
+
127
+ fn count_zero_half_words(mut value: u64, num_half_words: u8) -> usize {
128
+ let mut count = 0;
129
+ for _ in 0..num_half_words {
130
+ if value & 0xffff == 0 {
131
+ count += 1;
132
+ }
133
+ value >>= 16;
134
+ }
135
+
136
+ count
137
+ }
138
+
139
+ #[test]
140
+ fn inst_size_test() {
141
+ // This test will help with unintentionally growing the size
142
+ // of the Inst enum.
143
+ assert_eq!(32, std::mem::size_of::<Inst>());
144
+ }
145
+
146
+ impl Inst {
147
+ /// Create an instruction that loads a constant, using one of serveral options (MOVZ, MOVN,
148
+ /// logical immediate, or constant pool).
149
+ pub fn load_constant<F: FnMut(Type) -> Writable<Reg>>(
150
+ rd: Writable<Reg>,
151
+ value: u64,
152
+ alloc_tmp: &mut F,
153
+ ) -> SmallVec<[Inst; 4]> {
154
+ // NB: this is duplicated in `lower/isle.rs` and `inst.isle` right now,
155
+ // if modifications are made here before this is deleted after moving to
156
+ // ISLE then those locations should be updated as well.
157
+
158
+ if let Some(imm) = MoveWideConst::maybe_from_u64(value) {
159
+ // 16-bit immediate (shifted by 0, 16, 32 or 48 bits) in MOVZ
160
+ smallvec![Inst::MovWide {
161
+ op: MoveWideOp::MovZ,
162
+ rd,
163
+ imm,
164
+ size: OperandSize::Size64
165
+ }]
166
+ } else if let Some(imm) = MoveWideConst::maybe_from_u64(!value) {
167
+ // 16-bit immediate (shifted by 0, 16, 32 or 48 bits) in MOVN
168
+ smallvec![Inst::MovWide {
169
+ op: MoveWideOp::MovN,
170
+ rd,
171
+ imm,
172
+ size: OperandSize::Size64
173
+ }]
174
+ } else if let Some(imml) = ImmLogic::maybe_from_u64(value, I64) {
175
+ // Weird logical-instruction immediate in ORI using zero register
176
+ smallvec![Inst::AluRRImmLogic {
177
+ alu_op: ALUOp::Orr,
178
+ size: OperandSize::Size64,
179
+ rd,
180
+ rn: zero_reg(),
181
+ imml,
182
+ }]
183
+ } else {
184
+ let mut insts = smallvec![];
185
+
186
+ // If the top 32 bits are zero, use 32-bit `mov` operations.
187
+ let (num_half_words, size, negated) = if value >> 32 == 0 {
188
+ (2, OperandSize::Size32, (!value << 32) >> 32)
189
+ } else {
190
+ (4, OperandSize::Size64, !value)
191
+ };
192
+
193
+ // If the number of 0xffff half words is greater than the number of 0x0000 half words
194
+ // it is more efficient to use `movn` for the first instruction.
195
+ let first_is_inverted = count_zero_half_words(negated, num_half_words)
196
+ > count_zero_half_words(value, num_half_words);
197
+
198
+ // Either 0xffff or 0x0000 half words can be skipped, depending on the first
199
+ // instruction used.
200
+ let ignored_halfword = if first_is_inverted { 0xffff } else { 0 };
201
+
202
+ let halfwords: SmallVec<[_; 4]> = (0..num_half_words)
203
+ .filter_map(|i| {
204
+ let imm16 = (value >> (16 * i)) & 0xffff;
205
+ if imm16 == ignored_halfword {
206
+ None
207
+ } else {
208
+ Some((i, imm16))
209
+ }
210
+ })
211
+ .collect();
212
+
213
+ let mut prev_result = None;
214
+ let last_index = halfwords.last().unwrap().0;
215
+ for (i, imm16) in halfwords {
216
+ let shift = i * 16;
217
+ let rd = if i == last_index { rd } else { alloc_tmp(I16) };
218
+
219
+ if let Some(rn) = prev_result {
220
+ let imm = MoveWideConst::maybe_with_shift(imm16 as u16, shift).unwrap();
221
+ insts.push(Inst::MovK { rd, rn, imm, size });
222
+ } else {
223
+ if first_is_inverted {
224
+ let imm =
225
+ MoveWideConst::maybe_with_shift(((!imm16) & 0xffff) as u16, shift)
226
+ .unwrap();
227
+ insts.push(Inst::MovWide {
228
+ op: MoveWideOp::MovN,
229
+ rd,
230
+ imm,
231
+ size,
232
+ });
233
+ } else {
234
+ let imm = MoveWideConst::maybe_with_shift(imm16 as u16, shift).unwrap();
235
+ insts.push(Inst::MovWide {
236
+ op: MoveWideOp::MovZ,
237
+ rd,
238
+ imm,
239
+ size,
240
+ });
241
+ }
242
+ }
243
+
244
+ prev_result = Some(rd.to_reg());
245
+ }
246
+
247
+ assert!(prev_result.is_some());
248
+
249
+ insts
250
+ }
251
+ }
252
+
253
+ /// Generic constructor for a load (zero-extending where appropriate).
254
+ pub fn gen_load(into_reg: Writable<Reg>, mem: AMode, ty: Type, flags: MemFlags) -> Inst {
255
+ match ty {
256
+ I8 => Inst::ULoad8 {
257
+ rd: into_reg,
258
+ mem,
259
+ flags,
260
+ },
261
+ I16 => Inst::ULoad16 {
262
+ rd: into_reg,
263
+ mem,
264
+ flags,
265
+ },
266
+ I32 | R32 => Inst::ULoad32 {
267
+ rd: into_reg,
268
+ mem,
269
+ flags,
270
+ },
271
+ I64 | R64 => Inst::ULoad64 {
272
+ rd: into_reg,
273
+ mem,
274
+ flags,
275
+ },
276
+ F32 => Inst::FpuLoad32 {
277
+ rd: into_reg,
278
+ mem,
279
+ flags,
280
+ },
281
+ F64 => Inst::FpuLoad64 {
282
+ rd: into_reg,
283
+ mem,
284
+ flags,
285
+ },
286
+ _ => {
287
+ if ty.is_vector() {
288
+ let bits = ty_bits(ty);
289
+ let rd = into_reg;
290
+
291
+ if bits == 128 {
292
+ Inst::FpuLoad128 { rd, mem, flags }
293
+ } else {
294
+ assert_eq!(bits, 64);
295
+ Inst::FpuLoad64 { rd, mem, flags }
296
+ }
297
+ } else {
298
+ unimplemented!("gen_load({})", ty);
299
+ }
300
+ }
301
+ }
302
+ }
303
+
304
+ /// Generic constructor for a store.
305
+ pub fn gen_store(mem: AMode, from_reg: Reg, ty: Type, flags: MemFlags) -> Inst {
306
+ match ty {
307
+ I8 => Inst::Store8 {
308
+ rd: from_reg,
309
+ mem,
310
+ flags,
311
+ },
312
+ I16 => Inst::Store16 {
313
+ rd: from_reg,
314
+ mem,
315
+ flags,
316
+ },
317
+ I32 | R32 => Inst::Store32 {
318
+ rd: from_reg,
319
+ mem,
320
+ flags,
321
+ },
322
+ I64 | R64 => Inst::Store64 {
323
+ rd: from_reg,
324
+ mem,
325
+ flags,
326
+ },
327
+ F32 => Inst::FpuStore32 {
328
+ rd: from_reg,
329
+ mem,
330
+ flags,
331
+ },
332
+ F64 => Inst::FpuStore64 {
333
+ rd: from_reg,
334
+ mem,
335
+ flags,
336
+ },
337
+ _ => {
338
+ if ty.is_vector() {
339
+ let bits = ty_bits(ty);
340
+ let rd = from_reg;
341
+
342
+ if bits == 128 {
343
+ Inst::FpuStore128 { rd, mem, flags }
344
+ } else {
345
+ assert_eq!(bits, 64);
346
+ Inst::FpuStore64 { rd, mem, flags }
347
+ }
348
+ } else {
349
+ unimplemented!("gen_store({})", ty);
350
+ }
351
+ }
352
+ }
353
+ }
354
+ }
355
+
356
+ //=============================================================================
357
+ // Instructions: get_regs
358
+
359
+ fn memarg_operands<F: Fn(VReg) -> VReg>(memarg: &AMode, collector: &mut OperandCollector<'_, F>) {
360
+ // This should match `AMode::with_allocs()`.
361
+ match memarg {
362
+ &AMode::Unscaled { rn, .. } | &AMode::UnsignedOffset { rn, .. } => {
363
+ collector.reg_use(rn);
364
+ }
365
+ &AMode::RegReg { rn, rm, .. }
366
+ | &AMode::RegScaled { rn, rm, .. }
367
+ | &AMode::RegScaledExtended { rn, rm, .. }
368
+ | &AMode::RegExtended { rn, rm, .. } => {
369
+ collector.reg_use(rn);
370
+ collector.reg_use(rm);
371
+ }
372
+ &AMode::Label { .. } => {}
373
+ &AMode::SPPreIndexed { .. } | &AMode::SPPostIndexed { .. } => {}
374
+ &AMode::FPOffset { .. } => {}
375
+ &AMode::SPOffset { .. } | &AMode::NominalSPOffset { .. } => {}
376
+ &AMode::RegOffset { rn, .. } => {
377
+ collector.reg_use(rn);
378
+ }
379
+ &AMode::Const { .. } => {}
380
+ }
381
+ }
382
+
383
+ fn pairmemarg_operands<F: Fn(VReg) -> VReg>(
384
+ pairmemarg: &PairAMode,
385
+ collector: &mut OperandCollector<'_, F>,
386
+ ) {
387
+ // This should match `PairAMode::with_allocs()`.
388
+ match pairmemarg {
389
+ &PairAMode::SignedOffset(reg, ..) => {
390
+ collector.reg_use(reg);
391
+ }
392
+ &PairAMode::SPPreIndexed(..) | &PairAMode::SPPostIndexed(..) => {}
393
+ }
394
+ }
395
+
396
+ fn aarch64_get_operands<F: Fn(VReg) -> VReg>(inst: &Inst, collector: &mut OperandCollector<'_, F>) {
397
+ match inst {
398
+ &Inst::AluRRR { rd, rn, rm, .. } => {
399
+ collector.reg_def(rd);
400
+ collector.reg_use(rn);
401
+ collector.reg_use(rm);
402
+ }
403
+ &Inst::AluRRRR { rd, rn, rm, ra, .. } => {
404
+ collector.reg_def(rd);
405
+ collector.reg_use(rn);
406
+ collector.reg_use(rm);
407
+ collector.reg_use(ra);
408
+ }
409
+ &Inst::AluRRImm12 { rd, rn, .. } => {
410
+ collector.reg_def(rd);
411
+ collector.reg_use(rn);
412
+ }
413
+ &Inst::AluRRImmLogic { rd, rn, .. } => {
414
+ collector.reg_def(rd);
415
+ collector.reg_use(rn);
416
+ }
417
+ &Inst::AluRRImmShift { rd, rn, .. } => {
418
+ collector.reg_def(rd);
419
+ collector.reg_use(rn);
420
+ }
421
+ &Inst::AluRRRShift { rd, rn, rm, .. } => {
422
+ collector.reg_def(rd);
423
+ collector.reg_use(rn);
424
+ collector.reg_use(rm);
425
+ }
426
+ &Inst::AluRRRExtend { rd, rn, rm, .. } => {
427
+ collector.reg_def(rd);
428
+ collector.reg_use(rn);
429
+ collector.reg_use(rm);
430
+ }
431
+ &Inst::BitRR { rd, rn, .. } => {
432
+ collector.reg_def(rd);
433
+ collector.reg_use(rn);
434
+ }
435
+ &Inst::ULoad8 { rd, ref mem, .. }
436
+ | &Inst::SLoad8 { rd, ref mem, .. }
437
+ | &Inst::ULoad16 { rd, ref mem, .. }
438
+ | &Inst::SLoad16 { rd, ref mem, .. }
439
+ | &Inst::ULoad32 { rd, ref mem, .. }
440
+ | &Inst::SLoad32 { rd, ref mem, .. }
441
+ | &Inst::ULoad64 { rd, ref mem, .. } => {
442
+ collector.reg_def(rd);
443
+ memarg_operands(mem, collector);
444
+ }
445
+ &Inst::Store8 { rd, ref mem, .. }
446
+ | &Inst::Store16 { rd, ref mem, .. }
447
+ | &Inst::Store32 { rd, ref mem, .. }
448
+ | &Inst::Store64 { rd, ref mem, .. } => {
449
+ collector.reg_use(rd);
450
+ memarg_operands(mem, collector);
451
+ }
452
+ &Inst::StoreP64 {
453
+ rt, rt2, ref mem, ..
454
+ } => {
455
+ collector.reg_use(rt);
456
+ collector.reg_use(rt2);
457
+ pairmemarg_operands(mem, collector);
458
+ }
459
+ &Inst::LoadP64 {
460
+ rt, rt2, ref mem, ..
461
+ } => {
462
+ collector.reg_def(rt);
463
+ collector.reg_def(rt2);
464
+ pairmemarg_operands(mem, collector);
465
+ }
466
+ &Inst::Mov { rd, rm, .. } => {
467
+ collector.reg_def(rd);
468
+ collector.reg_use(rm);
469
+ }
470
+ &Inst::MovFromPReg { rd, rm } => {
471
+ debug_assert!(rd.to_reg().is_virtual());
472
+ collector.reg_def(rd);
473
+ collector.reg_fixed_nonallocatable(rm);
474
+ }
475
+ &Inst::MovToPReg { rd, rm } => {
476
+ debug_assert!(rm.is_virtual());
477
+ collector.reg_fixed_nonallocatable(rd);
478
+ collector.reg_use(rm);
479
+ }
480
+ &Inst::MovK { rd, rn, .. } => {
481
+ collector.reg_use(rn);
482
+ collector.reg_reuse_def(rd, 0); // `rn` == `rd`.
483
+ }
484
+ &Inst::MovWide { rd, .. } => {
485
+ collector.reg_def(rd);
486
+ }
487
+ &Inst::CSel { rd, rn, rm, .. } => {
488
+ collector.reg_def(rd);
489
+ collector.reg_use(rn);
490
+ collector.reg_use(rm);
491
+ }
492
+ &Inst::CSNeg { rd, rn, rm, .. } => {
493
+ collector.reg_def(rd);
494
+ collector.reg_use(rn);
495
+ collector.reg_use(rm);
496
+ }
497
+ &Inst::CSet { rd, .. } | &Inst::CSetm { rd, .. } => {
498
+ collector.reg_def(rd);
499
+ }
500
+ &Inst::CCmp { rn, rm, .. } => {
501
+ collector.reg_use(rn);
502
+ collector.reg_use(rm);
503
+ }
504
+ &Inst::CCmpImm { rn, .. } => {
505
+ collector.reg_use(rn);
506
+ }
507
+ &Inst::AtomicRMWLoop {
508
+ op,
509
+ addr,
510
+ operand,
511
+ oldval,
512
+ scratch1,
513
+ scratch2,
514
+ ..
515
+ } => {
516
+ collector.reg_fixed_use(addr, xreg(25));
517
+ collector.reg_fixed_use(operand, xreg(26));
518
+ collector.reg_fixed_def(oldval, xreg(27));
519
+ collector.reg_fixed_def(scratch1, xreg(24));
520
+ if op != AtomicRMWLoopOp::Xchg {
521
+ collector.reg_fixed_def(scratch2, xreg(28));
522
+ }
523
+ }
524
+ &Inst::AtomicRMW { rs, rt, rn, .. } => {
525
+ collector.reg_use(rs);
526
+ collector.reg_def(rt);
527
+ collector.reg_use(rn);
528
+ }
529
+ &Inst::AtomicCAS { rd, rs, rt, rn, .. } => {
530
+ collector.reg_reuse_def(rd, 1); // reuse `rs`.
531
+ collector.reg_use(rs);
532
+ collector.reg_use(rt);
533
+ collector.reg_use(rn);
534
+ }
535
+ &Inst::AtomicCASLoop {
536
+ addr,
537
+ expected,
538
+ replacement,
539
+ oldval,
540
+ scratch,
541
+ ..
542
+ } => {
543
+ collector.reg_fixed_use(addr, xreg(25));
544
+ collector.reg_fixed_use(expected, xreg(26));
545
+ collector.reg_fixed_use(replacement, xreg(28));
546
+ collector.reg_fixed_def(oldval, xreg(27));
547
+ collector.reg_fixed_def(scratch, xreg(24));
548
+ }
549
+ &Inst::LoadAcquire { rt, rn, .. } => {
550
+ collector.reg_use(rn);
551
+ collector.reg_def(rt);
552
+ }
553
+ &Inst::StoreRelease { rt, rn, .. } => {
554
+ collector.reg_use(rn);
555
+ collector.reg_use(rt);
556
+ }
557
+ &Inst::Fence {} | &Inst::Csdb {} => {}
558
+ &Inst::FpuMove64 { rd, rn } => {
559
+ collector.reg_def(rd);
560
+ collector.reg_use(rn);
561
+ }
562
+ &Inst::FpuMove128 { rd, rn } => {
563
+ collector.reg_def(rd);
564
+ collector.reg_use(rn);
565
+ }
566
+ &Inst::FpuMoveFromVec { rd, rn, .. } => {
567
+ collector.reg_def(rd);
568
+ collector.reg_use(rn);
569
+ }
570
+ &Inst::FpuExtend { rd, rn, .. } => {
571
+ collector.reg_def(rd);
572
+ collector.reg_use(rn);
573
+ }
574
+ &Inst::FpuRR { rd, rn, .. } => {
575
+ collector.reg_def(rd);
576
+ collector.reg_use(rn);
577
+ }
578
+ &Inst::FpuRRR { rd, rn, rm, .. } => {
579
+ collector.reg_def(rd);
580
+ collector.reg_use(rn);
581
+ collector.reg_use(rm);
582
+ }
583
+ &Inst::FpuRRI { rd, rn, .. } => {
584
+ collector.reg_def(rd);
585
+ collector.reg_use(rn);
586
+ }
587
+ &Inst::FpuRRIMod { rd, ri, rn, .. } => {
588
+ collector.reg_reuse_def(rd, 1); // reuse `ri`.
589
+ collector.reg_use(ri);
590
+ collector.reg_use(rn);
591
+ }
592
+ &Inst::FpuRRRR { rd, rn, rm, ra, .. } => {
593
+ collector.reg_def(rd);
594
+ collector.reg_use(rn);
595
+ collector.reg_use(rm);
596
+ collector.reg_use(ra);
597
+ }
598
+ &Inst::VecMisc { rd, rn, .. } => {
599
+ collector.reg_def(rd);
600
+ collector.reg_use(rn);
601
+ }
602
+
603
+ &Inst::VecLanes { rd, rn, .. } => {
604
+ collector.reg_def(rd);
605
+ collector.reg_use(rn);
606
+ }
607
+ &Inst::VecShiftImm { rd, rn, .. } => {
608
+ collector.reg_def(rd);
609
+ collector.reg_use(rn);
610
+ }
611
+ &Inst::VecShiftImmMod { rd, ri, rn, .. } => {
612
+ collector.reg_reuse_def(rd, 1); // `rd` == `ri`.
613
+ collector.reg_use(ri);
614
+ collector.reg_use(rn);
615
+ }
616
+ &Inst::VecExtract { rd, rn, rm, .. } => {
617
+ collector.reg_def(rd);
618
+ collector.reg_use(rn);
619
+ collector.reg_use(rm);
620
+ }
621
+ &Inst::VecTbl { rd, rn, rm } => {
622
+ collector.reg_use(rn);
623
+ collector.reg_use(rm);
624
+ collector.reg_def(rd);
625
+ }
626
+ &Inst::VecTblExt { rd, ri, rn, rm } => {
627
+ collector.reg_use(rn);
628
+ collector.reg_use(rm);
629
+ collector.reg_reuse_def(rd, 3); // `rd` == `ri`.
630
+ collector.reg_use(ri);
631
+ }
632
+
633
+ &Inst::VecTbl2 { rd, rn, rn2, rm } => {
634
+ // Constrain to v30 / v31 so that we satisfy the "adjacent
635
+ // registers" constraint without use of pinned vregs in
636
+ // lowering.
637
+ collector.reg_fixed_use(rn, vreg(30));
638
+ collector.reg_fixed_use(rn2, vreg(31));
639
+ collector.reg_use(rm);
640
+ collector.reg_def(rd);
641
+ }
642
+ &Inst::VecTbl2Ext {
643
+ rd,
644
+ ri,
645
+ rn,
646
+ rn2,
647
+ rm,
648
+ } => {
649
+ // Constrain to v30 / v31 so that we satisfy the "adjacent
650
+ // registers" constraint without use of pinned vregs in
651
+ // lowering.
652
+ collector.reg_fixed_use(rn, vreg(30));
653
+ collector.reg_fixed_use(rn2, vreg(31));
654
+ collector.reg_use(rm);
655
+ collector.reg_reuse_def(rd, 4); // `rd` == `ri`.
656
+ collector.reg_use(ri);
657
+ }
658
+ &Inst::VecLoadReplicate { rd, rn, .. } => {
659
+ collector.reg_def(rd);
660
+ collector.reg_use(rn);
661
+ }
662
+ &Inst::VecCSel { rd, rn, rm, .. } => {
663
+ collector.reg_def(rd);
664
+ collector.reg_use(rn);
665
+ collector.reg_use(rm);
666
+ }
667
+ &Inst::FpuCmp { rn, rm, .. } => {
668
+ collector.reg_use(rn);
669
+ collector.reg_use(rm);
670
+ }
671
+ &Inst::FpuLoad32 { rd, ref mem, .. } => {
672
+ collector.reg_def(rd);
673
+ memarg_operands(mem, collector);
674
+ }
675
+ &Inst::FpuLoad64 { rd, ref mem, .. } => {
676
+ collector.reg_def(rd);
677
+ memarg_operands(mem, collector);
678
+ }
679
+ &Inst::FpuLoad128 { rd, ref mem, .. } => {
680
+ collector.reg_def(rd);
681
+ memarg_operands(mem, collector);
682
+ }
683
+ &Inst::FpuStore32 { rd, ref mem, .. } => {
684
+ collector.reg_use(rd);
685
+ memarg_operands(mem, collector);
686
+ }
687
+ &Inst::FpuStore64 { rd, ref mem, .. } => {
688
+ collector.reg_use(rd);
689
+ memarg_operands(mem, collector);
690
+ }
691
+ &Inst::FpuStore128 { rd, ref mem, .. } => {
692
+ collector.reg_use(rd);
693
+ memarg_operands(mem, collector);
694
+ }
695
+ &Inst::FpuLoadP64 {
696
+ rt, rt2, ref mem, ..
697
+ } => {
698
+ collector.reg_def(rt);
699
+ collector.reg_def(rt2);
700
+ pairmemarg_operands(mem, collector);
701
+ }
702
+ &Inst::FpuStoreP64 {
703
+ rt, rt2, ref mem, ..
704
+ } => {
705
+ collector.reg_use(rt);
706
+ collector.reg_use(rt2);
707
+ pairmemarg_operands(mem, collector);
708
+ }
709
+ &Inst::FpuLoadP128 {
710
+ rt, rt2, ref mem, ..
711
+ } => {
712
+ collector.reg_def(rt);
713
+ collector.reg_def(rt2);
714
+ pairmemarg_operands(mem, collector);
715
+ }
716
+ &Inst::FpuStoreP128 {
717
+ rt, rt2, ref mem, ..
718
+ } => {
719
+ collector.reg_use(rt);
720
+ collector.reg_use(rt2);
721
+ pairmemarg_operands(mem, collector);
722
+ }
723
+ &Inst::FpuToInt { rd, rn, .. } => {
724
+ collector.reg_def(rd);
725
+ collector.reg_use(rn);
726
+ }
727
+ &Inst::IntToFpu { rd, rn, .. } => {
728
+ collector.reg_def(rd);
729
+ collector.reg_use(rn);
730
+ }
731
+ &Inst::FpuCSel32 { rd, rn, rm, .. } | &Inst::FpuCSel64 { rd, rn, rm, .. } => {
732
+ collector.reg_def(rd);
733
+ collector.reg_use(rn);
734
+ collector.reg_use(rm);
735
+ }
736
+ &Inst::FpuRound { rd, rn, .. } => {
737
+ collector.reg_def(rd);
738
+ collector.reg_use(rn);
739
+ }
740
+ &Inst::MovToFpu { rd, rn, .. } => {
741
+ collector.reg_def(rd);
742
+ collector.reg_use(rn);
743
+ }
744
+ &Inst::FpuMoveFPImm { rd, .. } => {
745
+ collector.reg_def(rd);
746
+ }
747
+ &Inst::MovToVec { rd, ri, rn, .. } => {
748
+ collector.reg_reuse_def(rd, 1); // `rd` == `ri`.
749
+ collector.reg_use(ri);
750
+ collector.reg_use(rn);
751
+ }
752
+ &Inst::MovFromVec { rd, rn, .. } | &Inst::MovFromVecSigned { rd, rn, .. } => {
753
+ collector.reg_def(rd);
754
+ collector.reg_use(rn);
755
+ }
756
+ &Inst::VecDup { rd, rn, .. } => {
757
+ collector.reg_def(rd);
758
+ collector.reg_use(rn);
759
+ }
760
+ &Inst::VecDupFromFpu { rd, rn, .. } => {
761
+ collector.reg_def(rd);
762
+ collector.reg_use(rn);
763
+ }
764
+ &Inst::VecDupFPImm { rd, .. } => {
765
+ collector.reg_def(rd);
766
+ }
767
+ &Inst::VecDupImm { rd, .. } => {
768
+ collector.reg_def(rd);
769
+ }
770
+ &Inst::VecExtend { rd, rn, .. } => {
771
+ collector.reg_def(rd);
772
+ collector.reg_use(rn);
773
+ }
774
+ &Inst::VecMovElement { rd, ri, rn, .. } => {
775
+ collector.reg_reuse_def(rd, 1); // `rd` == `ri`.
776
+ collector.reg_use(ri);
777
+ collector.reg_use(rn);
778
+ }
779
+ &Inst::VecRRLong { rd, rn, .. } => {
780
+ collector.reg_def(rd);
781
+ collector.reg_use(rn);
782
+ }
783
+ &Inst::VecRRNarrowLow { rd, rn, .. } => {
784
+ collector.reg_use(rn);
785
+ collector.reg_def(rd);
786
+ }
787
+ &Inst::VecRRNarrowHigh { rd, ri, rn, .. } => {
788
+ collector.reg_use(rn);
789
+ collector.reg_reuse_def(rd, 2); // `rd` == `ri`.
790
+ collector.reg_use(ri);
791
+ }
792
+ &Inst::VecRRPair { rd, rn, .. } => {
793
+ collector.reg_def(rd);
794
+ collector.reg_use(rn);
795
+ }
796
+ &Inst::VecRRRLong { rd, rn, rm, .. } => {
797
+ collector.reg_def(rd);
798
+ collector.reg_use(rn);
799
+ collector.reg_use(rm);
800
+ }
801
+ &Inst::VecRRRLongMod { rd, ri, rn, rm, .. } => {
802
+ collector.reg_reuse_def(rd, 1); // `rd` == `ri`.
803
+ collector.reg_use(ri);
804
+ collector.reg_use(rn);
805
+ collector.reg_use(rm);
806
+ }
807
+ &Inst::VecRRPairLong { rd, rn, .. } => {
808
+ collector.reg_def(rd);
809
+ collector.reg_use(rn);
810
+ }
811
+ &Inst::VecRRR { rd, rn, rm, .. } => {
812
+ collector.reg_def(rd);
813
+ collector.reg_use(rn);
814
+ collector.reg_use(rm);
815
+ }
816
+ &Inst::VecRRRMod { rd, ri, rn, rm, .. } | &Inst::VecFmlaElem { rd, ri, rn, rm, .. } => {
817
+ collector.reg_reuse_def(rd, 1); // `rd` == `ri`.
818
+ collector.reg_use(ri);
819
+ collector.reg_use(rn);
820
+ collector.reg_use(rm);
821
+ }
822
+ &Inst::MovToNZCV { rn } => {
823
+ collector.reg_use(rn);
824
+ }
825
+ &Inst::MovFromNZCV { rd } => {
826
+ collector.reg_def(rd);
827
+ }
828
+ &Inst::Extend { rd, rn, .. } => {
829
+ collector.reg_def(rd);
830
+ collector.reg_use(rn);
831
+ }
832
+ &Inst::Args { ref args } => {
833
+ for arg in args {
834
+ collector.reg_fixed_def(arg.vreg, arg.preg);
835
+ }
836
+ }
837
+ &Inst::Ret { ref rets, .. } | &Inst::AuthenticatedRet { ref rets, .. } => {
838
+ for ret in rets {
839
+ collector.reg_fixed_use(ret.vreg, ret.preg);
840
+ }
841
+ }
842
+ &Inst::Jump { .. } => {}
843
+ &Inst::Call { ref info, .. } => {
844
+ for u in &info.uses {
845
+ collector.reg_fixed_use(u.vreg, u.preg);
846
+ }
847
+ for d in &info.defs {
848
+ collector.reg_fixed_def(d.vreg, d.preg);
849
+ }
850
+ collector.reg_clobbers(info.clobbers);
851
+ }
852
+ &Inst::CallInd { ref info, .. } => {
853
+ collector.reg_use(info.rn);
854
+ for u in &info.uses {
855
+ collector.reg_fixed_use(u.vreg, u.preg);
856
+ }
857
+ for d in &info.defs {
858
+ collector.reg_fixed_def(d.vreg, d.preg);
859
+ }
860
+ collector.reg_clobbers(info.clobbers);
861
+ }
862
+ &Inst::CondBr { ref kind, .. } => match kind {
863
+ CondBrKind::Zero(rt) | CondBrKind::NotZero(rt) => {
864
+ collector.reg_use(*rt);
865
+ }
866
+ CondBrKind::Cond(_) => {}
867
+ },
868
+ &Inst::IndirectBr { rn, .. } => {
869
+ collector.reg_use(rn);
870
+ }
871
+ &Inst::Nop0 | Inst::Nop4 => {}
872
+ &Inst::Brk => {}
873
+ &Inst::Udf { .. } => {}
874
+ &Inst::TrapIf { ref kind, .. } => match kind {
875
+ CondBrKind::Zero(rt) | CondBrKind::NotZero(rt) => {
876
+ collector.reg_use(*rt);
877
+ }
878
+ CondBrKind::Cond(_) => {}
879
+ },
880
+ &Inst::Adr { rd, .. } | &Inst::Adrp { rd, .. } => {
881
+ collector.reg_def(rd);
882
+ }
883
+ &Inst::Word4 { .. } | &Inst::Word8 { .. } => {}
884
+ &Inst::JTSequence {
885
+ ridx, rtmp1, rtmp2, ..
886
+ } => {
887
+ collector.reg_use(ridx);
888
+ collector.reg_early_def(rtmp1);
889
+ collector.reg_early_def(rtmp2);
890
+ }
891
+ &Inst::LoadExtName { rd, .. } => {
892
+ collector.reg_def(rd);
893
+ }
894
+ &Inst::LoadAddr { rd, ref mem } => {
895
+ collector.reg_def(rd);
896
+ memarg_operands(mem, collector);
897
+ }
898
+ &Inst::Pacisp { .. } | &Inst::Xpaclri => {
899
+ // Neither LR nor SP is an allocatable register, so there is no need
900
+ // to do anything.
901
+ }
902
+ &Inst::Bti { .. } => {}
903
+ &Inst::VirtualSPOffsetAdj { .. } => {}
904
+
905
+ &Inst::ElfTlsGetAddr { rd, .. } => {
906
+ collector.reg_fixed_def(rd, regs::xreg(0));
907
+ let mut clobbers = AArch64MachineDeps::get_regs_clobbered_by_call(CallConv::SystemV);
908
+ clobbers.remove(regs::xreg_preg(0));
909
+ collector.reg_clobbers(clobbers);
910
+ }
911
+ &Inst::MachOTlsGetAddr { rd, .. } => {
912
+ collector.reg_fixed_def(rd, regs::xreg(0));
913
+ let mut clobbers =
914
+ AArch64MachineDeps::get_regs_clobbered_by_call(CallConv::AppleAarch64);
915
+ clobbers.remove(regs::xreg_preg(0));
916
+ collector.reg_clobbers(clobbers);
917
+ }
918
+ &Inst::Unwind { .. } => {}
919
+ &Inst::EmitIsland { .. } => {}
920
+ &Inst::DummyUse { reg } => {
921
+ collector.reg_use(reg);
922
+ }
923
+ &Inst::StackProbeLoop { start, end, .. } => {
924
+ collector.reg_early_def(start);
925
+ collector.reg_use(end);
926
+ }
927
+ }
928
+ }
929
+
930
+ //=============================================================================
931
+ // Instructions: misc functions and external interface
932
+
933
+ impl MachInst for Inst {
934
+ type ABIMachineSpec = AArch64MachineDeps;
935
+ type LabelUse = LabelUse;
936
+
937
+ // "CLIF" in hex, to make the trap recognizable during
938
+ // debugging.
939
+ const TRAP_OPCODE: &'static [u8] = &0xc11f_u32.to_le_bytes();
940
+
941
+ fn get_operands<F: Fn(VReg) -> VReg>(&self, collector: &mut OperandCollector<'_, F>) {
942
+ aarch64_get_operands(self, collector);
943
+ }
944
+
945
+ fn is_move(&self) -> Option<(Writable<Reg>, Reg)> {
946
+ match self {
947
+ &Inst::Mov {
948
+ size: OperandSize::Size64,
949
+ rd,
950
+ rm,
951
+ } => Some((rd, rm)),
952
+ &Inst::FpuMove64 { rd, rn } => Some((rd, rn)),
953
+ &Inst::FpuMove128 { rd, rn } => Some((rd, rn)),
954
+ _ => None,
955
+ }
956
+ }
957
+
958
+ fn is_included_in_clobbers(&self) -> bool {
959
+ let (caller_callconv, callee_callconv) = match self {
960
+ Inst::Args { .. } => return false,
961
+ Inst::Call { info } => (info.caller_callconv, info.callee_callconv),
962
+ Inst::CallInd { info } => (info.caller_callconv, info.callee_callconv),
963
+ _ => return true,
964
+ };
965
+
966
+ // We exclude call instructions from the clobber-set when they are calls
967
+ // from caller to callee that both clobber the same register (such as
968
+ // using the same or similar ABIs). Such calls cannot possibly force any
969
+ // new registers to be saved in the prologue, because anything that the
970
+ // callee clobbers, the caller is also allowed to clobber. This both
971
+ // saves work and enables us to more precisely follow the
972
+ // half-caller-save, half-callee-save SysV ABI for some vector
973
+ // registers.
974
+ //
975
+ // See the note in [crate::isa::aarch64::abi::is_caller_save_reg] for
976
+ // more information on this ABI-implementation hack.
977
+ let caller_clobbers = AArch64MachineDeps::get_regs_clobbered_by_call(caller_callconv);
978
+ let callee_clobbers = AArch64MachineDeps::get_regs_clobbered_by_call(callee_callconv);
979
+
980
+ let mut all_clobbers = caller_clobbers;
981
+ all_clobbers.union_from(callee_clobbers);
982
+ all_clobbers != caller_clobbers
983
+ }
984
+
985
+ fn is_trap(&self) -> bool {
986
+ match self {
987
+ Self::Udf { .. } => true,
988
+ _ => false,
989
+ }
990
+ }
991
+
992
+ fn is_args(&self) -> bool {
993
+ match self {
994
+ Self::Args { .. } => true,
995
+ _ => false,
996
+ }
997
+ }
998
+
999
+ fn is_term(&self) -> MachTerminator {
1000
+ match self {
1001
+ &Inst::Ret { .. } | &Inst::AuthenticatedRet { .. } => MachTerminator::Ret,
1002
+ &Inst::Jump { .. } => MachTerminator::Uncond,
1003
+ &Inst::CondBr { .. } => MachTerminator::Cond,
1004
+ &Inst::IndirectBr { .. } => MachTerminator::Indirect,
1005
+ &Inst::JTSequence { .. } => MachTerminator::Indirect,
1006
+ _ => MachTerminator::None,
1007
+ }
1008
+ }
1009
+
1010
+ fn gen_move(to_reg: Writable<Reg>, from_reg: Reg, ty: Type) -> Inst {
1011
+ let bits = ty.bits();
1012
+
1013
+ assert!(bits <= 128);
1014
+ assert!(to_reg.to_reg().class() == from_reg.class());
1015
+ match from_reg.class() {
1016
+ RegClass::Int => Inst::Mov {
1017
+ size: OperandSize::Size64,
1018
+ rd: to_reg,
1019
+ rm: from_reg,
1020
+ },
1021
+ RegClass::Float => {
1022
+ if bits > 64 {
1023
+ Inst::FpuMove128 {
1024
+ rd: to_reg,
1025
+ rn: from_reg,
1026
+ }
1027
+ } else {
1028
+ Inst::FpuMove64 {
1029
+ rd: to_reg,
1030
+ rn: from_reg,
1031
+ }
1032
+ }
1033
+ }
1034
+ RegClass::Vector => unreachable!(),
1035
+ }
1036
+ }
1037
+
1038
+ fn is_safepoint(&self) -> bool {
1039
+ match self {
1040
+ &Inst::Call { .. }
1041
+ | &Inst::CallInd { .. }
1042
+ | &Inst::TrapIf { .. }
1043
+ | &Inst::Udf { .. } => true,
1044
+ _ => false,
1045
+ }
1046
+ }
1047
+
1048
+ fn gen_dummy_use(reg: Reg) -> Inst {
1049
+ Inst::DummyUse { reg }
1050
+ }
1051
+
1052
+ fn gen_nop(preferred_size: usize) -> Inst {
1053
+ if preferred_size == 0 {
1054
+ return Inst::Nop0;
1055
+ }
1056
+ // We can't give a NOP (or any insn) < 4 bytes.
1057
+ assert!(preferred_size >= 4);
1058
+ Inst::Nop4
1059
+ }
1060
+
1061
+ fn rc_for_type(ty: Type) -> CodegenResult<(&'static [RegClass], &'static [Type])> {
1062
+ match ty {
1063
+ I8 => Ok((&[RegClass::Int], &[I8])),
1064
+ I16 => Ok((&[RegClass::Int], &[I16])),
1065
+ I32 => Ok((&[RegClass::Int], &[I32])),
1066
+ I64 => Ok((&[RegClass::Int], &[I64])),
1067
+ R32 => panic!("32-bit reftype pointer should never be seen on AArch64"),
1068
+ R64 => Ok((&[RegClass::Int], &[R64])),
1069
+ F32 => Ok((&[RegClass::Float], &[F32])),
1070
+ F64 => Ok((&[RegClass::Float], &[F64])),
1071
+ I128 => Ok((&[RegClass::Int, RegClass::Int], &[I64, I64])),
1072
+ _ if ty.is_vector() => {
1073
+ assert!(ty.bits() <= 128);
1074
+ Ok((&[RegClass::Float], &[I8X16]))
1075
+ }
1076
+ _ if ty.is_dynamic_vector() => Ok((&[RegClass::Float], &[I8X16])),
1077
+ _ => Err(CodegenError::Unsupported(format!(
1078
+ "Unexpected SSA-value type: {}",
1079
+ ty
1080
+ ))),
1081
+ }
1082
+ }
1083
+
1084
+ fn canonical_type_for_rc(rc: RegClass) -> Type {
1085
+ match rc {
1086
+ RegClass::Float => types::I8X16,
1087
+ RegClass::Int => types::I64,
1088
+ RegClass::Vector => unreachable!(),
1089
+ }
1090
+ }
1091
+
1092
+ fn gen_jump(target: MachLabel) -> Inst {
1093
+ Inst::Jump {
1094
+ dest: BranchTarget::Label(target),
1095
+ }
1096
+ }
1097
+
1098
+ fn worst_case_size() -> CodeOffset {
1099
+ // The maximum size, in bytes, of any `Inst`'s emitted code. We have at least one case of
1100
+ // an 8-instruction sequence (saturating int-to-float conversions) with three embedded
1101
+ // 64-bit f64 constants.
1102
+ //
1103
+ // Note that inline jump-tables handle island/pool insertion separately, so we do not need
1104
+ // to account for them here (otherwise the worst case would be 2^31 * 4, clearly not
1105
+ // feasible for other reasons).
1106
+ 44
1107
+ }
1108
+
1109
+ fn ref_type_regclass(_: &settings::Flags) -> RegClass {
1110
+ RegClass::Int
1111
+ }
1112
+
1113
+ fn gen_block_start(
1114
+ is_indirect_branch_target: bool,
1115
+ is_forward_edge_cfi_enabled: bool,
1116
+ ) -> Option<Self> {
1117
+ if is_indirect_branch_target && is_forward_edge_cfi_enabled {
1118
+ Some(Inst::Bti {
1119
+ targets: BranchTargetType::J,
1120
+ })
1121
+ } else {
1122
+ None
1123
+ }
1124
+ }
1125
+
1126
+ fn function_alignment() -> FunctionAlignment {
1127
+ // We use 32-byte alignment for performance reasons, but for correctness
1128
+ // we would only need 4-byte alignment.
1129
+ FunctionAlignment {
1130
+ minimum: 4,
1131
+ preferred: 32,
1132
+ }
1133
+ }
1134
+ }
1135
+
1136
+ //=============================================================================
1137
+ // Pretty-printing of instructions.
1138
+
1139
+ fn mem_finalize_for_show(mem: &AMode, state: &EmitState) -> (String, AMode) {
1140
+ let (mem_insts, mem) = mem_finalize(None, mem, state);
1141
+ let mut mem_str = mem_insts
1142
+ .into_iter()
1143
+ .map(|inst| {
1144
+ inst.print_with_state(&mut EmitState::default(), &mut AllocationConsumer::new(&[]))
1145
+ })
1146
+ .collect::<Vec<_>>()
1147
+ .join(" ; ");
1148
+ if !mem_str.is_empty() {
1149
+ mem_str += " ; ";
1150
+ }
1151
+
1152
+ (mem_str, mem)
1153
+ }
1154
+
1155
+ impl Inst {
1156
+ fn print_with_state(&self, state: &mut EmitState, allocs: &mut AllocationConsumer) -> String {
1157
+ let mut empty_allocs = AllocationConsumer::default();
1158
+
1159
+ fn op_name(alu_op: ALUOp) -> &'static str {
1160
+ match alu_op {
1161
+ ALUOp::Add => "add",
1162
+ ALUOp::Sub => "sub",
1163
+ ALUOp::Orr => "orr",
1164
+ ALUOp::And => "and",
1165
+ ALUOp::AndS => "ands",
1166
+ ALUOp::Eor => "eor",
1167
+ ALUOp::AddS => "adds",
1168
+ ALUOp::SubS => "subs",
1169
+ ALUOp::SMulH => "smulh",
1170
+ ALUOp::UMulH => "umulh",
1171
+ ALUOp::SDiv => "sdiv",
1172
+ ALUOp::UDiv => "udiv",
1173
+ ALUOp::AndNot => "bic",
1174
+ ALUOp::OrrNot => "orn",
1175
+ ALUOp::EorNot => "eon",
1176
+ ALUOp::RotR => "ror",
1177
+ ALUOp::Lsr => "lsr",
1178
+ ALUOp::Asr => "asr",
1179
+ ALUOp::Lsl => "lsl",
1180
+ ALUOp::Adc => "adc",
1181
+ ALUOp::AdcS => "adcs",
1182
+ ALUOp::Sbc => "sbc",
1183
+ ALUOp::SbcS => "sbcs",
1184
+ }
1185
+ }
1186
+
1187
+ // N.B.: order of `allocs` consumption (via register
1188
+ // pretty-printing or memarg.with_allocs()) needs to match the
1189
+ // order in `aarch64_get_operands` above.
1190
+ match self {
1191
+ &Inst::Nop0 => "nop-zero-len".to_string(),
1192
+ &Inst::Nop4 => "nop".to_string(),
1193
+ &Inst::AluRRR {
1194
+ alu_op,
1195
+ size,
1196
+ rd,
1197
+ rn,
1198
+ rm,
1199
+ } => {
1200
+ let op = op_name(alu_op);
1201
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1202
+ let rn = pretty_print_ireg(rn, size, allocs);
1203
+ let rm = pretty_print_ireg(rm, size, allocs);
1204
+ format!("{} {}, {}, {}", op, rd, rn, rm)
1205
+ }
1206
+ &Inst::AluRRRR {
1207
+ alu_op,
1208
+ size,
1209
+ rd,
1210
+ rn,
1211
+ rm,
1212
+ ra,
1213
+ } => {
1214
+ let (op, da_size) = match alu_op {
1215
+ ALUOp3::MAdd => ("madd", size),
1216
+ ALUOp3::MSub => ("msub", size),
1217
+ ALUOp3::UMAddL => ("umaddl", OperandSize::Size64),
1218
+ ALUOp3::SMAddL => ("smaddl", OperandSize::Size64),
1219
+ };
1220
+ let rd = pretty_print_ireg(rd.to_reg(), da_size, allocs);
1221
+ let rn = pretty_print_ireg(rn, size, allocs);
1222
+ let rm = pretty_print_ireg(rm, size, allocs);
1223
+ let ra = pretty_print_ireg(ra, da_size, allocs);
1224
+
1225
+ format!("{} {}, {}, {}, {}", op, rd, rn, rm, ra)
1226
+ }
1227
+ &Inst::AluRRImm12 {
1228
+ alu_op,
1229
+ size,
1230
+ rd,
1231
+ rn,
1232
+ ref imm12,
1233
+ } => {
1234
+ let op = op_name(alu_op);
1235
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1236
+ let rn = pretty_print_ireg(rn, size, allocs);
1237
+
1238
+ if imm12.bits == 0 && alu_op == ALUOp::Add && size.is64() {
1239
+ // special-case MOV (used for moving into SP).
1240
+ format!("mov {}, {}", rd, rn)
1241
+ } else {
1242
+ let imm12 = imm12.pretty_print(0, allocs);
1243
+ format!("{} {}, {}, {}", op, rd, rn, imm12)
1244
+ }
1245
+ }
1246
+ &Inst::AluRRImmLogic {
1247
+ alu_op,
1248
+ size,
1249
+ rd,
1250
+ rn,
1251
+ ref imml,
1252
+ } => {
1253
+ let op = op_name(alu_op);
1254
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1255
+ let rn = pretty_print_ireg(rn, size, allocs);
1256
+ let imml = imml.pretty_print(0, allocs);
1257
+ format!("{} {}, {}, {}", op, rd, rn, imml)
1258
+ }
1259
+ &Inst::AluRRImmShift {
1260
+ alu_op,
1261
+ size,
1262
+ rd,
1263
+ rn,
1264
+ ref immshift,
1265
+ } => {
1266
+ let op = op_name(alu_op);
1267
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1268
+ let rn = pretty_print_ireg(rn, size, allocs);
1269
+ let immshift = immshift.pretty_print(0, allocs);
1270
+ format!("{} {}, {}, {}", op, rd, rn, immshift)
1271
+ }
1272
+ &Inst::AluRRRShift {
1273
+ alu_op,
1274
+ size,
1275
+ rd,
1276
+ rn,
1277
+ rm,
1278
+ ref shiftop,
1279
+ } => {
1280
+ let op = op_name(alu_op);
1281
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1282
+ let rn = pretty_print_ireg(rn, size, allocs);
1283
+ let rm = pretty_print_ireg(rm, size, allocs);
1284
+ let shiftop = shiftop.pretty_print(0, allocs);
1285
+ format!("{} {}, {}, {}, {}", op, rd, rn, rm, shiftop)
1286
+ }
1287
+ &Inst::AluRRRExtend {
1288
+ alu_op,
1289
+ size,
1290
+ rd,
1291
+ rn,
1292
+ rm,
1293
+ ref extendop,
1294
+ } => {
1295
+ let op = op_name(alu_op);
1296
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1297
+ let rn = pretty_print_ireg(rn, size, allocs);
1298
+ let rm = pretty_print_ireg(rm, size, allocs);
1299
+ let extendop = extendop.pretty_print(0, allocs);
1300
+ format!("{} {}, {}, {}, {}", op, rd, rn, rm, extendop)
1301
+ }
1302
+ &Inst::BitRR { op, size, rd, rn } => {
1303
+ let op = op.op_str();
1304
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1305
+ let rn = pretty_print_ireg(rn, size, allocs);
1306
+ format!("{} {}, {}", op, rd, rn)
1307
+ }
1308
+ &Inst::ULoad8 { rd, ref mem, .. }
1309
+ | &Inst::SLoad8 { rd, ref mem, .. }
1310
+ | &Inst::ULoad16 { rd, ref mem, .. }
1311
+ | &Inst::SLoad16 { rd, ref mem, .. }
1312
+ | &Inst::ULoad32 { rd, ref mem, .. }
1313
+ | &Inst::SLoad32 { rd, ref mem, .. }
1314
+ | &Inst::ULoad64 { rd, ref mem, .. } => {
1315
+ let is_unscaled = match &mem {
1316
+ &AMode::Unscaled { .. } => true,
1317
+ _ => false,
1318
+ };
1319
+ let (op, size) = match (self, is_unscaled) {
1320
+ (&Inst::ULoad8 { .. }, false) => ("ldrb", OperandSize::Size32),
1321
+ (&Inst::ULoad8 { .. }, true) => ("ldurb", OperandSize::Size32),
1322
+ (&Inst::SLoad8 { .. }, false) => ("ldrsb", OperandSize::Size64),
1323
+ (&Inst::SLoad8 { .. }, true) => ("ldursb", OperandSize::Size64),
1324
+ (&Inst::ULoad16 { .. }, false) => ("ldrh", OperandSize::Size32),
1325
+ (&Inst::ULoad16 { .. }, true) => ("ldurh", OperandSize::Size32),
1326
+ (&Inst::SLoad16 { .. }, false) => ("ldrsh", OperandSize::Size64),
1327
+ (&Inst::SLoad16 { .. }, true) => ("ldursh", OperandSize::Size64),
1328
+ (&Inst::ULoad32 { .. }, false) => ("ldr", OperandSize::Size32),
1329
+ (&Inst::ULoad32 { .. }, true) => ("ldur", OperandSize::Size32),
1330
+ (&Inst::SLoad32 { .. }, false) => ("ldrsw", OperandSize::Size64),
1331
+ (&Inst::SLoad32 { .. }, true) => ("ldursw", OperandSize::Size64),
1332
+ (&Inst::ULoad64 { .. }, false) => ("ldr", OperandSize::Size64),
1333
+ (&Inst::ULoad64 { .. }, true) => ("ldur", OperandSize::Size64),
1334
+ _ => unreachable!(),
1335
+ };
1336
+
1337
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1338
+ let mem = mem.with_allocs(allocs);
1339
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1340
+ let mem = mem.pretty_print_default();
1341
+
1342
+ format!("{}{} {}, {}", mem_str, op, rd, mem)
1343
+ }
1344
+ &Inst::Store8 { rd, ref mem, .. }
1345
+ | &Inst::Store16 { rd, ref mem, .. }
1346
+ | &Inst::Store32 { rd, ref mem, .. }
1347
+ | &Inst::Store64 { rd, ref mem, .. } => {
1348
+ let is_unscaled = match &mem {
1349
+ &AMode::Unscaled { .. } => true,
1350
+ _ => false,
1351
+ };
1352
+ let (op, size) = match (self, is_unscaled) {
1353
+ (&Inst::Store8 { .. }, false) => ("strb", OperandSize::Size32),
1354
+ (&Inst::Store8 { .. }, true) => ("sturb", OperandSize::Size32),
1355
+ (&Inst::Store16 { .. }, false) => ("strh", OperandSize::Size32),
1356
+ (&Inst::Store16 { .. }, true) => ("sturh", OperandSize::Size32),
1357
+ (&Inst::Store32 { .. }, false) => ("str", OperandSize::Size32),
1358
+ (&Inst::Store32 { .. }, true) => ("stur", OperandSize::Size32),
1359
+ (&Inst::Store64 { .. }, false) => ("str", OperandSize::Size64),
1360
+ (&Inst::Store64 { .. }, true) => ("stur", OperandSize::Size64),
1361
+ _ => unreachable!(),
1362
+ };
1363
+
1364
+ let rd = pretty_print_ireg(rd, size, allocs);
1365
+ let mem = mem.with_allocs(allocs);
1366
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1367
+ let mem = mem.pretty_print_default();
1368
+
1369
+ format!("{}{} {}, {}", mem_str, op, rd, mem)
1370
+ }
1371
+ &Inst::StoreP64 {
1372
+ rt, rt2, ref mem, ..
1373
+ } => {
1374
+ let rt = pretty_print_ireg(rt, OperandSize::Size64, allocs);
1375
+ let rt2 = pretty_print_ireg(rt2, OperandSize::Size64, allocs);
1376
+ let mem = mem.with_allocs(allocs);
1377
+ let mem = mem.pretty_print_default();
1378
+ format!("stp {}, {}, {}", rt, rt2, mem)
1379
+ }
1380
+ &Inst::LoadP64 {
1381
+ rt, rt2, ref mem, ..
1382
+ } => {
1383
+ let rt = pretty_print_ireg(rt.to_reg(), OperandSize::Size64, allocs);
1384
+ let rt2 = pretty_print_ireg(rt2.to_reg(), OperandSize::Size64, allocs);
1385
+ let mem = mem.with_allocs(allocs);
1386
+ let mem = mem.pretty_print_default();
1387
+ format!("ldp {}, {}, {}", rt, rt2, mem)
1388
+ }
1389
+ &Inst::Mov { size, rd, rm } => {
1390
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1391
+ let rm = pretty_print_ireg(rm, size, allocs);
1392
+ format!("mov {}, {}", rd, rm)
1393
+ }
1394
+ &Inst::MovFromPReg { rd, rm } => {
1395
+ let rd = pretty_print_ireg(rd.to_reg(), OperandSize::Size64, allocs);
1396
+ allocs.next_fixed_nonallocatable(rm);
1397
+ let rm = show_ireg_sized(rm.into(), OperandSize::Size64);
1398
+ format!("mov {}, {}", rd, rm)
1399
+ }
1400
+ &Inst::MovToPReg { rd, rm } => {
1401
+ allocs.next_fixed_nonallocatable(rd);
1402
+ let rd = show_ireg_sized(rd.into(), OperandSize::Size64);
1403
+ let rm = pretty_print_ireg(rm, OperandSize::Size64, allocs);
1404
+ format!("mov {}, {}", rd, rm)
1405
+ }
1406
+ &Inst::MovWide {
1407
+ op,
1408
+ rd,
1409
+ ref imm,
1410
+ size,
1411
+ } => {
1412
+ let op_str = match op {
1413
+ MoveWideOp::MovZ => "movz",
1414
+ MoveWideOp::MovN => "movn",
1415
+ };
1416
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1417
+ let imm = imm.pretty_print(0, allocs);
1418
+ format!("{} {}, {}", op_str, rd, imm)
1419
+ }
1420
+ &Inst::MovK {
1421
+ rd,
1422
+ rn,
1423
+ ref imm,
1424
+ size,
1425
+ } => {
1426
+ let rn = pretty_print_ireg(rn, size, allocs);
1427
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1428
+ let imm = imm.pretty_print(0, allocs);
1429
+ format!("movk {}, {}, {}", rd, rn, imm)
1430
+ }
1431
+ &Inst::CSel { rd, rn, rm, cond } => {
1432
+ let rd = pretty_print_ireg(rd.to_reg(), OperandSize::Size64, allocs);
1433
+ let rn = pretty_print_ireg(rn, OperandSize::Size64, allocs);
1434
+ let rm = pretty_print_ireg(rm, OperandSize::Size64, allocs);
1435
+ let cond = cond.pretty_print(0, allocs);
1436
+ format!("csel {}, {}, {}, {}", rd, rn, rm, cond)
1437
+ }
1438
+ &Inst::CSNeg { rd, rn, rm, cond } => {
1439
+ let rd = pretty_print_ireg(rd.to_reg(), OperandSize::Size64, allocs);
1440
+ let rn = pretty_print_ireg(rn, OperandSize::Size64, allocs);
1441
+ let rm = pretty_print_ireg(rm, OperandSize::Size64, allocs);
1442
+ let cond = cond.pretty_print(0, allocs);
1443
+ format!("csneg {}, {}, {}, {}", rd, rn, rm, cond)
1444
+ }
1445
+ &Inst::CSet { rd, cond } => {
1446
+ let rd = pretty_print_ireg(rd.to_reg(), OperandSize::Size64, allocs);
1447
+ let cond = cond.pretty_print(0, allocs);
1448
+ format!("cset {}, {}", rd, cond)
1449
+ }
1450
+ &Inst::CSetm { rd, cond } => {
1451
+ let rd = pretty_print_ireg(rd.to_reg(), OperandSize::Size64, allocs);
1452
+ let cond = cond.pretty_print(0, allocs);
1453
+ format!("csetm {}, {}", rd, cond)
1454
+ }
1455
+ &Inst::CCmp {
1456
+ size,
1457
+ rn,
1458
+ rm,
1459
+ nzcv,
1460
+ cond,
1461
+ } => {
1462
+ let rn = pretty_print_ireg(rn, size, allocs);
1463
+ let rm = pretty_print_ireg(rm, size, allocs);
1464
+ let nzcv = nzcv.pretty_print(0, allocs);
1465
+ let cond = cond.pretty_print(0, allocs);
1466
+ format!("ccmp {}, {}, {}, {}", rn, rm, nzcv, cond)
1467
+ }
1468
+ &Inst::CCmpImm {
1469
+ size,
1470
+ rn,
1471
+ imm,
1472
+ nzcv,
1473
+ cond,
1474
+ } => {
1475
+ let rn = pretty_print_ireg(rn, size, allocs);
1476
+ let imm = imm.pretty_print(0, allocs);
1477
+ let nzcv = nzcv.pretty_print(0, allocs);
1478
+ let cond = cond.pretty_print(0, allocs);
1479
+ format!("ccmp {}, {}, {}, {}", rn, imm, nzcv, cond)
1480
+ }
1481
+ &Inst::AtomicRMW {
1482
+ rs, rt, rn, ty, op, ..
1483
+ } => {
1484
+ let op = match op {
1485
+ AtomicRMWOp::Add => "ldaddal",
1486
+ AtomicRMWOp::Clr => "ldclral",
1487
+ AtomicRMWOp::Eor => "ldeoral",
1488
+ AtomicRMWOp::Set => "ldsetal",
1489
+ AtomicRMWOp::Smax => "ldsmaxal",
1490
+ AtomicRMWOp::Umax => "ldumaxal",
1491
+ AtomicRMWOp::Smin => "ldsminal",
1492
+ AtomicRMWOp::Umin => "lduminal",
1493
+ AtomicRMWOp::Swp => "swpal",
1494
+ };
1495
+
1496
+ let size = OperandSize::from_ty(ty);
1497
+ let rs = pretty_print_ireg(rs, size, allocs);
1498
+ let rt = pretty_print_ireg(rt.to_reg(), size, allocs);
1499
+ let rn = pretty_print_ireg(rn, OperandSize::Size64, allocs);
1500
+
1501
+ let ty_suffix = match ty {
1502
+ I8 => "b",
1503
+ I16 => "h",
1504
+ _ => "",
1505
+ };
1506
+ format!("{}{} {}, {}, [{}]", op, ty_suffix, rs, rt, rn)
1507
+ }
1508
+ &Inst::AtomicRMWLoop {
1509
+ ty,
1510
+ op,
1511
+ addr,
1512
+ operand,
1513
+ oldval,
1514
+ scratch1,
1515
+ scratch2,
1516
+ ..
1517
+ } => {
1518
+ let op = match op {
1519
+ AtomicRMWLoopOp::Add => "add",
1520
+ AtomicRMWLoopOp::Sub => "sub",
1521
+ AtomicRMWLoopOp::Eor => "eor",
1522
+ AtomicRMWLoopOp::Orr => "orr",
1523
+ AtomicRMWLoopOp::And => "and",
1524
+ AtomicRMWLoopOp::Nand => "nand",
1525
+ AtomicRMWLoopOp::Smin => "smin",
1526
+ AtomicRMWLoopOp::Smax => "smax",
1527
+ AtomicRMWLoopOp::Umin => "umin",
1528
+ AtomicRMWLoopOp::Umax => "umax",
1529
+ AtomicRMWLoopOp::Xchg => "xchg",
1530
+ };
1531
+ let addr = pretty_print_ireg(addr, OperandSize::Size64, allocs);
1532
+ let operand = pretty_print_ireg(operand, OperandSize::Size64, allocs);
1533
+ let oldval = pretty_print_ireg(oldval.to_reg(), OperandSize::Size64, allocs);
1534
+ let scratch1 = pretty_print_ireg(scratch1.to_reg(), OperandSize::Size64, allocs);
1535
+ let scratch2 = pretty_print_ireg(scratch2.to_reg(), OperandSize::Size64, allocs);
1536
+ format!(
1537
+ "atomic_rmw_loop_{}_{} addr={} operand={} oldval={} scratch1={} scratch2={}",
1538
+ op,
1539
+ ty.bits(),
1540
+ addr,
1541
+ operand,
1542
+ oldval,
1543
+ scratch1,
1544
+ scratch2,
1545
+ )
1546
+ }
1547
+ &Inst::AtomicCAS {
1548
+ rd, rs, rt, rn, ty, ..
1549
+ } => {
1550
+ let op = match ty {
1551
+ I8 => "casalb",
1552
+ I16 => "casalh",
1553
+ I32 | I64 => "casal",
1554
+ _ => panic!("Unsupported type: {}", ty),
1555
+ };
1556
+ let size = OperandSize::from_ty(ty);
1557
+ let rd = pretty_print_ireg(rd.to_reg(), size, allocs);
1558
+ let rs = pretty_print_ireg(rs, size, allocs);
1559
+ let rt = pretty_print_ireg(rt, size, allocs);
1560
+ let rn = pretty_print_ireg(rn, OperandSize::Size64, allocs);
1561
+
1562
+ format!("{} {}, {}, {}, [{}]", op, rd, rs, rt, rn)
1563
+ }
1564
+ &Inst::AtomicCASLoop {
1565
+ ty,
1566
+ addr,
1567
+ expected,
1568
+ replacement,
1569
+ oldval,
1570
+ scratch,
1571
+ ..
1572
+ } => {
1573
+ let addr = pretty_print_ireg(addr, OperandSize::Size64, allocs);
1574
+ let expected = pretty_print_ireg(expected, OperandSize::Size64, allocs);
1575
+ let replacement = pretty_print_ireg(replacement, OperandSize::Size64, allocs);
1576
+ let oldval = pretty_print_ireg(oldval.to_reg(), OperandSize::Size64, allocs);
1577
+ let scratch = pretty_print_ireg(scratch.to_reg(), OperandSize::Size64, allocs);
1578
+ format!(
1579
+ "atomic_cas_loop_{} addr={}, expect={}, replacement={}, oldval={}, scratch={}",
1580
+ ty.bits(),
1581
+ addr,
1582
+ expected,
1583
+ replacement,
1584
+ oldval,
1585
+ scratch,
1586
+ )
1587
+ }
1588
+ &Inst::LoadAcquire {
1589
+ access_ty, rt, rn, ..
1590
+ } => {
1591
+ let (op, ty) = match access_ty {
1592
+ I8 => ("ldarb", I32),
1593
+ I16 => ("ldarh", I32),
1594
+ I32 => ("ldar", I32),
1595
+ I64 => ("ldar", I64),
1596
+ _ => panic!("Unsupported type: {}", access_ty),
1597
+ };
1598
+ let size = OperandSize::from_ty(ty);
1599
+ let rn = pretty_print_ireg(rn, OperandSize::Size64, allocs);
1600
+ let rt = pretty_print_ireg(rt.to_reg(), size, allocs);
1601
+ format!("{} {}, [{}]", op, rt, rn)
1602
+ }
1603
+ &Inst::StoreRelease {
1604
+ access_ty, rt, rn, ..
1605
+ } => {
1606
+ let (op, ty) = match access_ty {
1607
+ I8 => ("stlrb", I32),
1608
+ I16 => ("stlrh", I32),
1609
+ I32 => ("stlr", I32),
1610
+ I64 => ("stlr", I64),
1611
+ _ => panic!("Unsupported type: {}", access_ty),
1612
+ };
1613
+ let size = OperandSize::from_ty(ty);
1614
+ let rn = pretty_print_ireg(rn, OperandSize::Size64, allocs);
1615
+ let rt = pretty_print_ireg(rt, size, allocs);
1616
+ format!("{} {}, [{}]", op, rt, rn)
1617
+ }
1618
+ &Inst::Fence {} => {
1619
+ format!("dmb ish")
1620
+ }
1621
+ &Inst::Csdb {} => {
1622
+ format!("csdb")
1623
+ }
1624
+ &Inst::FpuMove64 { rd, rn } => {
1625
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size64, allocs);
1626
+ let rn = pretty_print_vreg_scalar(rn, ScalarSize::Size64, allocs);
1627
+ format!("fmov {}, {}", rd, rn)
1628
+ }
1629
+ &Inst::FpuMove128 { rd, rn } => {
1630
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1631
+ let rn = pretty_print_reg(rn, allocs);
1632
+ format!("mov {}.16b, {}.16b", rd, rn)
1633
+ }
1634
+ &Inst::FpuMoveFromVec { rd, rn, idx, size } => {
1635
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size.lane_size(), allocs);
1636
+ let rn = pretty_print_vreg_element(rn, idx as usize, size.lane_size(), allocs);
1637
+ format!("mov {}, {}", rd, rn)
1638
+ }
1639
+ &Inst::FpuExtend { rd, rn, size } => {
1640
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size, allocs);
1641
+ let rn = pretty_print_vreg_scalar(rn, size, allocs);
1642
+ format!("fmov {}, {}", rd, rn)
1643
+ }
1644
+ &Inst::FpuRR {
1645
+ fpu_op,
1646
+ size,
1647
+ rd,
1648
+ rn,
1649
+ } => {
1650
+ let op = match fpu_op {
1651
+ FPUOp1::Abs => "fabs",
1652
+ FPUOp1::Neg => "fneg",
1653
+ FPUOp1::Sqrt => "fsqrt",
1654
+ FPUOp1::Cvt32To64 | FPUOp1::Cvt64To32 => "fcvt",
1655
+ };
1656
+ let dst_size = match fpu_op {
1657
+ FPUOp1::Cvt32To64 => ScalarSize::Size64,
1658
+ FPUOp1::Cvt64To32 => ScalarSize::Size32,
1659
+ _ => size,
1660
+ };
1661
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), dst_size, allocs);
1662
+ let rn = pretty_print_vreg_scalar(rn, size, allocs);
1663
+ format!("{} {}, {}", op, rd, rn)
1664
+ }
1665
+ &Inst::FpuRRR {
1666
+ fpu_op,
1667
+ size,
1668
+ rd,
1669
+ rn,
1670
+ rm,
1671
+ } => {
1672
+ let op = match fpu_op {
1673
+ FPUOp2::Add => "fadd",
1674
+ FPUOp2::Sub => "fsub",
1675
+ FPUOp2::Mul => "fmul",
1676
+ FPUOp2::Div => "fdiv",
1677
+ FPUOp2::Max => "fmax",
1678
+ FPUOp2::Min => "fmin",
1679
+ };
1680
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size, allocs);
1681
+ let rn = pretty_print_vreg_scalar(rn, size, allocs);
1682
+ let rm = pretty_print_vreg_scalar(rm, size, allocs);
1683
+ format!("{} {}, {}, {}", op, rd, rn, rm)
1684
+ }
1685
+ &Inst::FpuRRI { fpu_op, rd, rn } => {
1686
+ let (op, imm, vector) = match fpu_op {
1687
+ FPUOpRI::UShr32(imm) => ("ushr", imm.pretty_print(0, allocs), true),
1688
+ FPUOpRI::UShr64(imm) => ("ushr", imm.pretty_print(0, allocs), false),
1689
+ };
1690
+
1691
+ let (rd, rn) = if vector {
1692
+ (
1693
+ pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size32x2, allocs),
1694
+ pretty_print_vreg_vector(rn, VectorSize::Size32x2, allocs),
1695
+ )
1696
+ } else {
1697
+ (
1698
+ pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size64, allocs),
1699
+ pretty_print_vreg_scalar(rn, ScalarSize::Size64, allocs),
1700
+ )
1701
+ };
1702
+ format!("{} {}, {}, {}", op, rd, rn, imm)
1703
+ }
1704
+ &Inst::FpuRRIMod { fpu_op, rd, ri, rn } => {
1705
+ let (op, imm, vector) = match fpu_op {
1706
+ FPUOpRIMod::Sli32(imm) => ("sli", imm.pretty_print(0, allocs), true),
1707
+ FPUOpRIMod::Sli64(imm) => ("sli", imm.pretty_print(0, allocs), false),
1708
+ };
1709
+
1710
+ let (rd, ri, rn) = if vector {
1711
+ (
1712
+ pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size32x2, allocs),
1713
+ pretty_print_vreg_vector(ri, VectorSize::Size32x2, allocs),
1714
+ pretty_print_vreg_vector(rn, VectorSize::Size32x2, allocs),
1715
+ )
1716
+ } else {
1717
+ (
1718
+ pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size64, allocs),
1719
+ pretty_print_vreg_scalar(ri, ScalarSize::Size64, allocs),
1720
+ pretty_print_vreg_scalar(rn, ScalarSize::Size64, allocs),
1721
+ )
1722
+ };
1723
+ format!("{} {}, {}, {}, {}", op, rd, ri, rn, imm)
1724
+ }
1725
+ &Inst::FpuRRRR {
1726
+ fpu_op,
1727
+ size,
1728
+ rd,
1729
+ rn,
1730
+ rm,
1731
+ ra,
1732
+ } => {
1733
+ let op = match fpu_op {
1734
+ FPUOp3::MAdd => "fmadd",
1735
+ };
1736
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size, allocs);
1737
+ let rn = pretty_print_vreg_scalar(rn, size, allocs);
1738
+ let rm = pretty_print_vreg_scalar(rm, size, allocs);
1739
+ let ra = pretty_print_vreg_scalar(ra, size, allocs);
1740
+ format!("{} {}, {}, {}, {}", op, rd, rn, rm, ra)
1741
+ }
1742
+ &Inst::FpuCmp { size, rn, rm } => {
1743
+ let rn = pretty_print_vreg_scalar(rn, size, allocs);
1744
+ let rm = pretty_print_vreg_scalar(rm, size, allocs);
1745
+ format!("fcmp {}, {}", rn, rm)
1746
+ }
1747
+ &Inst::FpuLoad32 { rd, ref mem, .. } => {
1748
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size32, allocs);
1749
+ let mem = mem.with_allocs(allocs);
1750
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1751
+ let mem = mem.pretty_print_default();
1752
+ format!("{}ldr {}, {}", mem_str, rd, mem)
1753
+ }
1754
+ &Inst::FpuLoad64 { rd, ref mem, .. } => {
1755
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size64, allocs);
1756
+ let mem = mem.with_allocs(allocs);
1757
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1758
+ let mem = mem.pretty_print_default();
1759
+ format!("{}ldr {}, {}", mem_str, rd, mem)
1760
+ }
1761
+ &Inst::FpuLoad128 { rd, ref mem, .. } => {
1762
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1763
+ let rd = "q".to_string() + &rd[1..];
1764
+ let mem = mem.with_allocs(allocs);
1765
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1766
+ let mem = mem.pretty_print_default();
1767
+ format!("{}ldr {}, {}", mem_str, rd, mem)
1768
+ }
1769
+ &Inst::FpuStore32 { rd, ref mem, .. } => {
1770
+ let rd = pretty_print_vreg_scalar(rd, ScalarSize::Size32, allocs);
1771
+ let mem = mem.with_allocs(allocs);
1772
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1773
+ let mem = mem.pretty_print_default();
1774
+ format!("{}str {}, {}", mem_str, rd, mem)
1775
+ }
1776
+ &Inst::FpuStore64 { rd, ref mem, .. } => {
1777
+ let rd = pretty_print_vreg_scalar(rd, ScalarSize::Size64, allocs);
1778
+ let mem = mem.with_allocs(allocs);
1779
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1780
+ let mem = mem.pretty_print_default();
1781
+ format!("{}str {}, {}", mem_str, rd, mem)
1782
+ }
1783
+ &Inst::FpuStore128 { rd, ref mem, .. } => {
1784
+ let rd = pretty_print_reg(rd, allocs);
1785
+ let rd = "q".to_string() + &rd[1..];
1786
+ let mem = mem.with_allocs(allocs);
1787
+ let (mem_str, mem) = mem_finalize_for_show(&mem, state);
1788
+ let mem = mem.pretty_print_default();
1789
+ format!("{}str {}, {}", mem_str, rd, mem)
1790
+ }
1791
+ &Inst::FpuLoadP64 {
1792
+ rt, rt2, ref mem, ..
1793
+ } => {
1794
+ let rt = pretty_print_vreg_scalar(rt.to_reg(), ScalarSize::Size64, allocs);
1795
+ let rt2 = pretty_print_vreg_scalar(rt2.to_reg(), ScalarSize::Size64, allocs);
1796
+ let mem = mem.with_allocs(allocs);
1797
+ let mem = mem.pretty_print_default();
1798
+
1799
+ format!("ldp {}, {}, {}", rt, rt2, mem)
1800
+ }
1801
+ &Inst::FpuStoreP64 {
1802
+ rt, rt2, ref mem, ..
1803
+ } => {
1804
+ let rt = pretty_print_vreg_scalar(rt, ScalarSize::Size64, allocs);
1805
+ let rt2 = pretty_print_vreg_scalar(rt2, ScalarSize::Size64, allocs);
1806
+ let mem = mem.with_allocs(allocs);
1807
+ let mem = mem.pretty_print_default();
1808
+
1809
+ format!("stp {}, {}, {}", rt, rt2, mem)
1810
+ }
1811
+ &Inst::FpuLoadP128 {
1812
+ rt, rt2, ref mem, ..
1813
+ } => {
1814
+ let rt = pretty_print_vreg_scalar(rt.to_reg(), ScalarSize::Size128, allocs);
1815
+ let rt2 = pretty_print_vreg_scalar(rt2.to_reg(), ScalarSize::Size128, allocs);
1816
+ let mem = mem.with_allocs(allocs);
1817
+ let mem = mem.pretty_print_default();
1818
+
1819
+ format!("ldp {}, {}, {}", rt, rt2, mem)
1820
+ }
1821
+ &Inst::FpuStoreP128 {
1822
+ rt, rt2, ref mem, ..
1823
+ } => {
1824
+ let rt = pretty_print_vreg_scalar(rt, ScalarSize::Size128, allocs);
1825
+ let rt2 = pretty_print_vreg_scalar(rt2, ScalarSize::Size128, allocs);
1826
+ let mem = mem.with_allocs(allocs);
1827
+ let mem = mem.pretty_print_default();
1828
+
1829
+ format!("stp {}, {}, {}", rt, rt2, mem)
1830
+ }
1831
+ &Inst::FpuToInt { op, rd, rn } => {
1832
+ let (op, sizesrc, sizedest) = match op {
1833
+ FpuToIntOp::F32ToI32 => ("fcvtzs", ScalarSize::Size32, OperandSize::Size32),
1834
+ FpuToIntOp::F32ToU32 => ("fcvtzu", ScalarSize::Size32, OperandSize::Size32),
1835
+ FpuToIntOp::F32ToI64 => ("fcvtzs", ScalarSize::Size32, OperandSize::Size64),
1836
+ FpuToIntOp::F32ToU64 => ("fcvtzu", ScalarSize::Size32, OperandSize::Size64),
1837
+ FpuToIntOp::F64ToI32 => ("fcvtzs", ScalarSize::Size64, OperandSize::Size32),
1838
+ FpuToIntOp::F64ToU32 => ("fcvtzu", ScalarSize::Size64, OperandSize::Size32),
1839
+ FpuToIntOp::F64ToI64 => ("fcvtzs", ScalarSize::Size64, OperandSize::Size64),
1840
+ FpuToIntOp::F64ToU64 => ("fcvtzu", ScalarSize::Size64, OperandSize::Size64),
1841
+ };
1842
+ let rd = pretty_print_ireg(rd.to_reg(), sizedest, allocs);
1843
+ let rn = pretty_print_vreg_scalar(rn, sizesrc, allocs);
1844
+ format!("{} {}, {}", op, rd, rn)
1845
+ }
1846
+ &Inst::IntToFpu { op, rd, rn } => {
1847
+ let (op, sizesrc, sizedest) = match op {
1848
+ IntToFpuOp::I32ToF32 => ("scvtf", OperandSize::Size32, ScalarSize::Size32),
1849
+ IntToFpuOp::U32ToF32 => ("ucvtf", OperandSize::Size32, ScalarSize::Size32),
1850
+ IntToFpuOp::I64ToF32 => ("scvtf", OperandSize::Size64, ScalarSize::Size32),
1851
+ IntToFpuOp::U64ToF32 => ("ucvtf", OperandSize::Size64, ScalarSize::Size32),
1852
+ IntToFpuOp::I32ToF64 => ("scvtf", OperandSize::Size32, ScalarSize::Size64),
1853
+ IntToFpuOp::U32ToF64 => ("ucvtf", OperandSize::Size32, ScalarSize::Size64),
1854
+ IntToFpuOp::I64ToF64 => ("scvtf", OperandSize::Size64, ScalarSize::Size64),
1855
+ IntToFpuOp::U64ToF64 => ("ucvtf", OperandSize::Size64, ScalarSize::Size64),
1856
+ };
1857
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), sizedest, allocs);
1858
+ let rn = pretty_print_ireg(rn, sizesrc, allocs);
1859
+ format!("{} {}, {}", op, rd, rn)
1860
+ }
1861
+ &Inst::FpuCSel32 { rd, rn, rm, cond } => {
1862
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size32, allocs);
1863
+ let rn = pretty_print_vreg_scalar(rn, ScalarSize::Size32, allocs);
1864
+ let rm = pretty_print_vreg_scalar(rm, ScalarSize::Size32, allocs);
1865
+ let cond = cond.pretty_print(0, allocs);
1866
+ format!("fcsel {}, {}, {}, {}", rd, rn, rm, cond)
1867
+ }
1868
+ &Inst::FpuCSel64 { rd, rn, rm, cond } => {
1869
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size64, allocs);
1870
+ let rn = pretty_print_vreg_scalar(rn, ScalarSize::Size64, allocs);
1871
+ let rm = pretty_print_vreg_scalar(rm, ScalarSize::Size64, allocs);
1872
+ let cond = cond.pretty_print(0, allocs);
1873
+ format!("fcsel {}, {}, {}, {}", rd, rn, rm, cond)
1874
+ }
1875
+ &Inst::FpuRound { op, rd, rn } => {
1876
+ let (inst, size) = match op {
1877
+ FpuRoundMode::Minus32 => ("frintm", ScalarSize::Size32),
1878
+ FpuRoundMode::Minus64 => ("frintm", ScalarSize::Size64),
1879
+ FpuRoundMode::Plus32 => ("frintp", ScalarSize::Size32),
1880
+ FpuRoundMode::Plus64 => ("frintp", ScalarSize::Size64),
1881
+ FpuRoundMode::Zero32 => ("frintz", ScalarSize::Size32),
1882
+ FpuRoundMode::Zero64 => ("frintz", ScalarSize::Size64),
1883
+ FpuRoundMode::Nearest32 => ("frintn", ScalarSize::Size32),
1884
+ FpuRoundMode::Nearest64 => ("frintn", ScalarSize::Size64),
1885
+ };
1886
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size, allocs);
1887
+ let rn = pretty_print_vreg_scalar(rn, size, allocs);
1888
+ format!("{} {}, {}", inst, rd, rn)
1889
+ }
1890
+ &Inst::MovToFpu { rd, rn, size } => {
1891
+ let operand_size = size.operand_size();
1892
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size, allocs);
1893
+ let rn = pretty_print_ireg(rn, operand_size, allocs);
1894
+ format!("fmov {}, {}", rd, rn)
1895
+ }
1896
+ &Inst::FpuMoveFPImm { rd, imm, size } => {
1897
+ let imm = imm.pretty_print(0, allocs);
1898
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size, allocs);
1899
+
1900
+ format!("fmov {}, {}", rd, imm)
1901
+ }
1902
+ &Inst::MovToVec {
1903
+ rd,
1904
+ ri,
1905
+ rn,
1906
+ idx,
1907
+ size,
1908
+ } => {
1909
+ let rd =
1910
+ pretty_print_vreg_element(rd.to_reg(), idx as usize, size.lane_size(), allocs);
1911
+ let ri = pretty_print_vreg_element(ri, idx as usize, size.lane_size(), allocs);
1912
+ let rn = pretty_print_ireg(rn, size.operand_size(), allocs);
1913
+ format!("mov {}, {}, {}", rd, ri, rn)
1914
+ }
1915
+ &Inst::MovFromVec { rd, rn, idx, size } => {
1916
+ let op = match size {
1917
+ ScalarSize::Size8 => "umov",
1918
+ ScalarSize::Size16 => "umov",
1919
+ ScalarSize::Size32 => "mov",
1920
+ ScalarSize::Size64 => "mov",
1921
+ _ => unimplemented!(),
1922
+ };
1923
+ let rd = pretty_print_ireg(rd.to_reg(), size.operand_size(), allocs);
1924
+ let rn = pretty_print_vreg_element(rn, idx as usize, size, allocs);
1925
+ format!("{} {}, {}", op, rd, rn)
1926
+ }
1927
+ &Inst::MovFromVecSigned {
1928
+ rd,
1929
+ rn,
1930
+ idx,
1931
+ size,
1932
+ scalar_size,
1933
+ } => {
1934
+ let rd = pretty_print_ireg(rd.to_reg(), scalar_size, allocs);
1935
+ let rn = pretty_print_vreg_element(rn, idx as usize, size.lane_size(), allocs);
1936
+ format!("smov {}, {}", rd, rn)
1937
+ }
1938
+ &Inst::VecDup { rd, rn, size } => {
1939
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
1940
+ let rn = pretty_print_ireg(rn, size.operand_size(), allocs);
1941
+ format!("dup {}, {}", rd, rn)
1942
+ }
1943
+ &Inst::VecDupFromFpu { rd, rn, size, lane } => {
1944
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
1945
+ let rn = pretty_print_vreg_element(rn, lane.into(), size.lane_size(), allocs);
1946
+ format!("dup {}, {}", rd, rn)
1947
+ }
1948
+ &Inst::VecDupFPImm { rd, imm, size } => {
1949
+ let imm = imm.pretty_print(0, allocs);
1950
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
1951
+
1952
+ format!("fmov {}, {}", rd, imm)
1953
+ }
1954
+ &Inst::VecDupImm {
1955
+ rd,
1956
+ imm,
1957
+ invert,
1958
+ size,
1959
+ } => {
1960
+ let imm = imm.pretty_print(0, allocs);
1961
+ let op = if invert { "mvni" } else { "movi" };
1962
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
1963
+
1964
+ format!("{} {}, {}", op, rd, imm)
1965
+ }
1966
+ &Inst::VecExtend {
1967
+ t,
1968
+ rd,
1969
+ rn,
1970
+ high_half,
1971
+ lane_size,
1972
+ } => {
1973
+ let vec64 = VectorSize::from_lane_size(lane_size.narrow(), false);
1974
+ let vec128 = VectorSize::from_lane_size(lane_size.narrow(), true);
1975
+ let rd_size = VectorSize::from_lane_size(lane_size, true);
1976
+ let (op, rn_size) = match (t, high_half) {
1977
+ (VecExtendOp::Sxtl, false) => ("sxtl", vec64),
1978
+ (VecExtendOp::Sxtl, true) => ("sxtl2", vec128),
1979
+ (VecExtendOp::Uxtl, false) => ("uxtl", vec64),
1980
+ (VecExtendOp::Uxtl, true) => ("uxtl2", vec128),
1981
+ };
1982
+ let rd = pretty_print_vreg_vector(rd.to_reg(), rd_size, allocs);
1983
+ let rn = pretty_print_vreg_vector(rn, rn_size, allocs);
1984
+ format!("{} {}, {}", op, rd, rn)
1985
+ }
1986
+ &Inst::VecMovElement {
1987
+ rd,
1988
+ ri,
1989
+ rn,
1990
+ dest_idx,
1991
+ src_idx,
1992
+ size,
1993
+ } => {
1994
+ let rd = pretty_print_vreg_element(
1995
+ rd.to_reg(),
1996
+ dest_idx as usize,
1997
+ size.lane_size(),
1998
+ allocs,
1999
+ );
2000
+ let ri = pretty_print_vreg_element(ri, dest_idx as usize, size.lane_size(), allocs);
2001
+ let rn = pretty_print_vreg_element(rn, src_idx as usize, size.lane_size(), allocs);
2002
+ format!("mov {}, {}, {}", rd, ri, rn)
2003
+ }
2004
+ &Inst::VecRRLong {
2005
+ op,
2006
+ rd,
2007
+ rn,
2008
+ high_half,
2009
+ } => {
2010
+ let (op, rd_size, size, suffix) = match (op, high_half) {
2011
+ (VecRRLongOp::Fcvtl16, false) => {
2012
+ ("fcvtl", VectorSize::Size32x4, VectorSize::Size16x4, "")
2013
+ }
2014
+ (VecRRLongOp::Fcvtl16, true) => {
2015
+ ("fcvtl2", VectorSize::Size32x4, VectorSize::Size16x8, "")
2016
+ }
2017
+ (VecRRLongOp::Fcvtl32, false) => {
2018
+ ("fcvtl", VectorSize::Size64x2, VectorSize::Size32x2, "")
2019
+ }
2020
+ (VecRRLongOp::Fcvtl32, true) => {
2021
+ ("fcvtl2", VectorSize::Size64x2, VectorSize::Size32x4, "")
2022
+ }
2023
+ (VecRRLongOp::Shll8, false) => {
2024
+ ("shll", VectorSize::Size16x8, VectorSize::Size8x8, ", #8")
2025
+ }
2026
+ (VecRRLongOp::Shll8, true) => {
2027
+ ("shll2", VectorSize::Size16x8, VectorSize::Size8x16, ", #8")
2028
+ }
2029
+ (VecRRLongOp::Shll16, false) => {
2030
+ ("shll", VectorSize::Size32x4, VectorSize::Size16x4, ", #16")
2031
+ }
2032
+ (VecRRLongOp::Shll16, true) => {
2033
+ ("shll2", VectorSize::Size32x4, VectorSize::Size16x8, ", #16")
2034
+ }
2035
+ (VecRRLongOp::Shll32, false) => {
2036
+ ("shll", VectorSize::Size64x2, VectorSize::Size32x2, ", #32")
2037
+ }
2038
+ (VecRRLongOp::Shll32, true) => {
2039
+ ("shll2", VectorSize::Size64x2, VectorSize::Size32x4, ", #32")
2040
+ }
2041
+ };
2042
+ let rd = pretty_print_vreg_vector(rd.to_reg(), rd_size, allocs);
2043
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2044
+
2045
+ format!("{} {}, {}{}", op, rd, rn, suffix)
2046
+ }
2047
+ &Inst::VecRRNarrowLow {
2048
+ op,
2049
+ rd,
2050
+ rn,
2051
+ lane_size,
2052
+ ..
2053
+ }
2054
+ | &Inst::VecRRNarrowHigh {
2055
+ op,
2056
+ rd,
2057
+ rn,
2058
+ lane_size,
2059
+ ..
2060
+ } => {
2061
+ let vec64 = VectorSize::from_lane_size(lane_size, false);
2062
+ let vec128 = VectorSize::from_lane_size(lane_size, true);
2063
+ let rn_size = VectorSize::from_lane_size(lane_size.widen(), true);
2064
+ let high_half = match self {
2065
+ &Inst::VecRRNarrowLow { .. } => false,
2066
+ &Inst::VecRRNarrowHigh { .. } => true,
2067
+ _ => unreachable!(),
2068
+ };
2069
+ let (op, rd_size) = match (op, high_half) {
2070
+ (VecRRNarrowOp::Xtn, false) => ("xtn", vec64),
2071
+ (VecRRNarrowOp::Xtn, true) => ("xtn2", vec128),
2072
+ (VecRRNarrowOp::Sqxtn, false) => ("sqxtn", vec64),
2073
+ (VecRRNarrowOp::Sqxtn, true) => ("sqxtn2", vec128),
2074
+ (VecRRNarrowOp::Sqxtun, false) => ("sqxtun", vec64),
2075
+ (VecRRNarrowOp::Sqxtun, true) => ("sqxtun2", vec128),
2076
+ (VecRRNarrowOp::Uqxtn, false) => ("uqxtn", vec64),
2077
+ (VecRRNarrowOp::Uqxtn, true) => ("uqxtn2", vec128),
2078
+ (VecRRNarrowOp::Fcvtn, false) => ("fcvtn", vec64),
2079
+ (VecRRNarrowOp::Fcvtn, true) => ("fcvtn2", vec128),
2080
+ };
2081
+ let rn = pretty_print_vreg_vector(rn, rn_size, allocs);
2082
+ let rd = pretty_print_vreg_vector(rd.to_reg(), rd_size, allocs);
2083
+ let ri = match self {
2084
+ &Inst::VecRRNarrowLow { .. } => "".to_string(),
2085
+ &Inst::VecRRNarrowHigh { ri, .. } => {
2086
+ format!("{}, ", pretty_print_vreg_vector(ri, rd_size, allocs))
2087
+ }
2088
+ _ => unreachable!(),
2089
+ };
2090
+
2091
+ format!("{} {}, {}{}", op, rd, ri, rn)
2092
+ }
2093
+ &Inst::VecRRPair { op, rd, rn } => {
2094
+ let op = match op {
2095
+ VecPairOp::Addp => "addp",
2096
+ };
2097
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), ScalarSize::Size64, allocs);
2098
+ let rn = pretty_print_vreg_vector(rn, VectorSize::Size64x2, allocs);
2099
+
2100
+ format!("{} {}, {}", op, rd, rn)
2101
+ }
2102
+ &Inst::VecRRPairLong { op, rd, rn } => {
2103
+ let (op, dest, src) = match op {
2104
+ VecRRPairLongOp::Saddlp8 => {
2105
+ ("saddlp", VectorSize::Size16x8, VectorSize::Size8x16)
2106
+ }
2107
+ VecRRPairLongOp::Saddlp16 => {
2108
+ ("saddlp", VectorSize::Size32x4, VectorSize::Size16x8)
2109
+ }
2110
+ VecRRPairLongOp::Uaddlp8 => {
2111
+ ("uaddlp", VectorSize::Size16x8, VectorSize::Size8x16)
2112
+ }
2113
+ VecRRPairLongOp::Uaddlp16 => {
2114
+ ("uaddlp", VectorSize::Size32x4, VectorSize::Size16x8)
2115
+ }
2116
+ };
2117
+ let rd = pretty_print_vreg_vector(rd.to_reg(), dest, allocs);
2118
+ let rn = pretty_print_vreg_vector(rn, src, allocs);
2119
+
2120
+ format!("{} {}, {}", op, rd, rn)
2121
+ }
2122
+ &Inst::VecRRR {
2123
+ rd,
2124
+ rn,
2125
+ rm,
2126
+ alu_op,
2127
+ size,
2128
+ } => {
2129
+ let (op, size) = match alu_op {
2130
+ VecALUOp::Sqadd => ("sqadd", size),
2131
+ VecALUOp::Uqadd => ("uqadd", size),
2132
+ VecALUOp::Sqsub => ("sqsub", size),
2133
+ VecALUOp::Uqsub => ("uqsub", size),
2134
+ VecALUOp::Cmeq => ("cmeq", size),
2135
+ VecALUOp::Cmge => ("cmge", size),
2136
+ VecALUOp::Cmgt => ("cmgt", size),
2137
+ VecALUOp::Cmhs => ("cmhs", size),
2138
+ VecALUOp::Cmhi => ("cmhi", size),
2139
+ VecALUOp::Fcmeq => ("fcmeq", size),
2140
+ VecALUOp::Fcmgt => ("fcmgt", size),
2141
+ VecALUOp::Fcmge => ("fcmge", size),
2142
+ VecALUOp::And => ("and", VectorSize::Size8x16),
2143
+ VecALUOp::Bic => ("bic", VectorSize::Size8x16),
2144
+ VecALUOp::Orr => ("orr", VectorSize::Size8x16),
2145
+ VecALUOp::Eor => ("eor", VectorSize::Size8x16),
2146
+ VecALUOp::Umaxp => ("umaxp", size),
2147
+ VecALUOp::Add => ("add", size),
2148
+ VecALUOp::Sub => ("sub", size),
2149
+ VecALUOp::Mul => ("mul", size),
2150
+ VecALUOp::Sshl => ("sshl", size),
2151
+ VecALUOp::Ushl => ("ushl", size),
2152
+ VecALUOp::Umin => ("umin", size),
2153
+ VecALUOp::Smin => ("smin", size),
2154
+ VecALUOp::Umax => ("umax", size),
2155
+ VecALUOp::Smax => ("smax", size),
2156
+ VecALUOp::Urhadd => ("urhadd", size),
2157
+ VecALUOp::Fadd => ("fadd", size),
2158
+ VecALUOp::Fsub => ("fsub", size),
2159
+ VecALUOp::Fdiv => ("fdiv", size),
2160
+ VecALUOp::Fmax => ("fmax", size),
2161
+ VecALUOp::Fmin => ("fmin", size),
2162
+ VecALUOp::Fmul => ("fmul", size),
2163
+ VecALUOp::Addp => ("addp", size),
2164
+ VecALUOp::Zip1 => ("zip1", size),
2165
+ VecALUOp::Zip2 => ("zip2", size),
2166
+ VecALUOp::Sqrdmulh => ("sqrdmulh", size),
2167
+ VecALUOp::Uzp1 => ("uzp1", size),
2168
+ VecALUOp::Uzp2 => ("uzp2", size),
2169
+ VecALUOp::Trn1 => ("trn1", size),
2170
+ VecALUOp::Trn2 => ("trn2", size),
2171
+ };
2172
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
2173
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2174
+ let rm = pretty_print_vreg_vector(rm, size, allocs);
2175
+ format!("{} {}, {}, {}", op, rd, rn, rm)
2176
+ }
2177
+ &Inst::VecRRRMod {
2178
+ rd,
2179
+ ri,
2180
+ rn,
2181
+ rm,
2182
+ alu_op,
2183
+ size,
2184
+ } => {
2185
+ let (op, size) = match alu_op {
2186
+ VecALUModOp::Bsl => ("bsl", VectorSize::Size8x16),
2187
+ VecALUModOp::Fmla => ("fmla", size),
2188
+ VecALUModOp::Fmls => ("fmls", size),
2189
+ };
2190
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
2191
+ let ri = pretty_print_vreg_vector(ri, size, allocs);
2192
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2193
+ let rm = pretty_print_vreg_vector(rm, size, allocs);
2194
+ format!("{} {}, {}, {}, {}", op, rd, ri, rn, rm)
2195
+ }
2196
+ &Inst::VecFmlaElem {
2197
+ rd,
2198
+ ri,
2199
+ rn,
2200
+ rm,
2201
+ alu_op,
2202
+ size,
2203
+ idx,
2204
+ } => {
2205
+ let (op, size) = match alu_op {
2206
+ VecALUModOp::Fmla => ("fmla", size),
2207
+ VecALUModOp::Fmls => ("fmls", size),
2208
+ _ => unreachable!(),
2209
+ };
2210
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
2211
+ let ri = pretty_print_vreg_vector(ri, size, allocs);
2212
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2213
+ let rm = pretty_print_vreg_element(rm, idx.into(), size.lane_size(), allocs);
2214
+ format!("{} {}, {}, {}, {}", op, rd, ri, rn, rm)
2215
+ }
2216
+ &Inst::VecRRRLong {
2217
+ rd,
2218
+ rn,
2219
+ rm,
2220
+ alu_op,
2221
+ high_half,
2222
+ } => {
2223
+ let (op, dest_size, src_size) = match (alu_op, high_half) {
2224
+ (VecRRRLongOp::Smull8, false) => {
2225
+ ("smull", VectorSize::Size16x8, VectorSize::Size8x8)
2226
+ }
2227
+ (VecRRRLongOp::Smull8, true) => {
2228
+ ("smull2", VectorSize::Size16x8, VectorSize::Size8x16)
2229
+ }
2230
+ (VecRRRLongOp::Smull16, false) => {
2231
+ ("smull", VectorSize::Size32x4, VectorSize::Size16x4)
2232
+ }
2233
+ (VecRRRLongOp::Smull16, true) => {
2234
+ ("smull2", VectorSize::Size32x4, VectorSize::Size16x8)
2235
+ }
2236
+ (VecRRRLongOp::Smull32, false) => {
2237
+ ("smull", VectorSize::Size64x2, VectorSize::Size32x2)
2238
+ }
2239
+ (VecRRRLongOp::Smull32, true) => {
2240
+ ("smull2", VectorSize::Size64x2, VectorSize::Size32x4)
2241
+ }
2242
+ (VecRRRLongOp::Umull8, false) => {
2243
+ ("umull", VectorSize::Size16x8, VectorSize::Size8x8)
2244
+ }
2245
+ (VecRRRLongOp::Umull8, true) => {
2246
+ ("umull2", VectorSize::Size16x8, VectorSize::Size8x16)
2247
+ }
2248
+ (VecRRRLongOp::Umull16, false) => {
2249
+ ("umull", VectorSize::Size32x4, VectorSize::Size16x4)
2250
+ }
2251
+ (VecRRRLongOp::Umull16, true) => {
2252
+ ("umull2", VectorSize::Size32x4, VectorSize::Size16x8)
2253
+ }
2254
+ (VecRRRLongOp::Umull32, false) => {
2255
+ ("umull", VectorSize::Size64x2, VectorSize::Size32x2)
2256
+ }
2257
+ (VecRRRLongOp::Umull32, true) => {
2258
+ ("umull2", VectorSize::Size64x2, VectorSize::Size32x4)
2259
+ }
2260
+ };
2261
+ let rd = pretty_print_vreg_vector(rd.to_reg(), dest_size, allocs);
2262
+ let rn = pretty_print_vreg_vector(rn, src_size, allocs);
2263
+ let rm = pretty_print_vreg_vector(rm, src_size, allocs);
2264
+ format!("{} {}, {}, {}", op, rd, rn, rm)
2265
+ }
2266
+ &Inst::VecRRRLongMod {
2267
+ rd,
2268
+ ri,
2269
+ rn,
2270
+ rm,
2271
+ alu_op,
2272
+ high_half,
2273
+ } => {
2274
+ let (op, dest_size, src_size) = match (alu_op, high_half) {
2275
+ (VecRRRLongModOp::Umlal8, false) => {
2276
+ ("umlal", VectorSize::Size16x8, VectorSize::Size8x8)
2277
+ }
2278
+ (VecRRRLongModOp::Umlal8, true) => {
2279
+ ("umlal2", VectorSize::Size16x8, VectorSize::Size8x16)
2280
+ }
2281
+ (VecRRRLongModOp::Umlal16, false) => {
2282
+ ("umlal", VectorSize::Size32x4, VectorSize::Size16x4)
2283
+ }
2284
+ (VecRRRLongModOp::Umlal16, true) => {
2285
+ ("umlal2", VectorSize::Size32x4, VectorSize::Size16x8)
2286
+ }
2287
+ (VecRRRLongModOp::Umlal32, false) => {
2288
+ ("umlal", VectorSize::Size64x2, VectorSize::Size32x2)
2289
+ }
2290
+ (VecRRRLongModOp::Umlal32, true) => {
2291
+ ("umlal2", VectorSize::Size64x2, VectorSize::Size32x4)
2292
+ }
2293
+ };
2294
+ let rd = pretty_print_vreg_vector(rd.to_reg(), dest_size, allocs);
2295
+ let ri = pretty_print_vreg_vector(ri, dest_size, allocs);
2296
+ let rn = pretty_print_vreg_vector(rn, src_size, allocs);
2297
+ let rm = pretty_print_vreg_vector(rm, src_size, allocs);
2298
+ format!("{} {}, {}, {}, {}", op, rd, ri, rn, rm)
2299
+ }
2300
+ &Inst::VecMisc { op, rd, rn, size } => {
2301
+ let (op, size, suffix) = match op {
2302
+ VecMisc2::Not => (
2303
+ "mvn",
2304
+ if size.is_128bits() {
2305
+ VectorSize::Size8x16
2306
+ } else {
2307
+ VectorSize::Size8x8
2308
+ },
2309
+ "",
2310
+ ),
2311
+ VecMisc2::Neg => ("neg", size, ""),
2312
+ VecMisc2::Abs => ("abs", size, ""),
2313
+ VecMisc2::Fabs => ("fabs", size, ""),
2314
+ VecMisc2::Fneg => ("fneg", size, ""),
2315
+ VecMisc2::Fsqrt => ("fsqrt", size, ""),
2316
+ VecMisc2::Rev16 => ("rev16", size, ""),
2317
+ VecMisc2::Rev32 => ("rev32", size, ""),
2318
+ VecMisc2::Rev64 => ("rev64", size, ""),
2319
+ VecMisc2::Fcvtzs => ("fcvtzs", size, ""),
2320
+ VecMisc2::Fcvtzu => ("fcvtzu", size, ""),
2321
+ VecMisc2::Scvtf => ("scvtf", size, ""),
2322
+ VecMisc2::Ucvtf => ("ucvtf", size, ""),
2323
+ VecMisc2::Frintn => ("frintn", size, ""),
2324
+ VecMisc2::Frintz => ("frintz", size, ""),
2325
+ VecMisc2::Frintm => ("frintm", size, ""),
2326
+ VecMisc2::Frintp => ("frintp", size, ""),
2327
+ VecMisc2::Cnt => ("cnt", size, ""),
2328
+ VecMisc2::Cmeq0 => ("cmeq", size, ", #0"),
2329
+ VecMisc2::Cmge0 => ("cmge", size, ", #0"),
2330
+ VecMisc2::Cmgt0 => ("cmgt", size, ", #0"),
2331
+ VecMisc2::Cmle0 => ("cmle", size, ", #0"),
2332
+ VecMisc2::Cmlt0 => ("cmlt", size, ", #0"),
2333
+ VecMisc2::Fcmeq0 => ("fcmeq", size, ", #0.0"),
2334
+ VecMisc2::Fcmge0 => ("fcmge", size, ", #0.0"),
2335
+ VecMisc2::Fcmgt0 => ("fcmgt", size, ", #0.0"),
2336
+ VecMisc2::Fcmle0 => ("fcmle", size, ", #0.0"),
2337
+ VecMisc2::Fcmlt0 => ("fcmlt", size, ", #0.0"),
2338
+ };
2339
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
2340
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2341
+ format!("{} {}, {}{}", op, rd, rn, suffix)
2342
+ }
2343
+ &Inst::VecLanes { op, rd, rn, size } => {
2344
+ let op = match op {
2345
+ VecLanesOp::Uminv => "uminv",
2346
+ VecLanesOp::Addv => "addv",
2347
+ };
2348
+ let rd = pretty_print_vreg_scalar(rd.to_reg(), size.lane_size(), allocs);
2349
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2350
+ format!("{} {}, {}", op, rd, rn)
2351
+ }
2352
+ &Inst::VecShiftImm {
2353
+ op,
2354
+ rd,
2355
+ rn,
2356
+ size,
2357
+ imm,
2358
+ } => {
2359
+ let op = match op {
2360
+ VecShiftImmOp::Shl => "shl",
2361
+ VecShiftImmOp::Ushr => "ushr",
2362
+ VecShiftImmOp::Sshr => "sshr",
2363
+ };
2364
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
2365
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2366
+ format!("{} {}, {}, #{}", op, rd, rn, imm)
2367
+ }
2368
+ &Inst::VecShiftImmMod {
2369
+ op,
2370
+ rd,
2371
+ ri,
2372
+ rn,
2373
+ size,
2374
+ imm,
2375
+ } => {
2376
+ let op = match op {
2377
+ VecShiftImmModOp::Sli => "sli",
2378
+ };
2379
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
2380
+ let ri = pretty_print_vreg_vector(ri, size, allocs);
2381
+ let rn = pretty_print_vreg_vector(rn, size, allocs);
2382
+ format!("{} {}, {}, {}, #{}", op, rd, ri, rn, imm)
2383
+ }
2384
+ &Inst::VecExtract { rd, rn, rm, imm4 } => {
2385
+ let rd = pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size8x16, allocs);
2386
+ let rn = pretty_print_vreg_vector(rn, VectorSize::Size8x16, allocs);
2387
+ let rm = pretty_print_vreg_vector(rm, VectorSize::Size8x16, allocs);
2388
+ format!("ext {}, {}, {}, #{}", rd, rn, rm, imm4)
2389
+ }
2390
+ &Inst::VecTbl { rd, rn, rm } => {
2391
+ let rn = pretty_print_vreg_vector(rn, VectorSize::Size8x16, allocs);
2392
+ let rm = pretty_print_vreg_vector(rm, VectorSize::Size8x16, allocs);
2393
+ let rd = pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size8x16, allocs);
2394
+ format!("tbl {}, {{ {} }}, {}", rd, rn, rm)
2395
+ }
2396
+ &Inst::VecTblExt { rd, ri, rn, rm } => {
2397
+ let rn = pretty_print_vreg_vector(rn, VectorSize::Size8x16, allocs);
2398
+ let rm = pretty_print_vreg_vector(rm, VectorSize::Size8x16, allocs);
2399
+ let rd = pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size8x16, allocs);
2400
+ let ri = pretty_print_vreg_vector(ri, VectorSize::Size8x16, allocs);
2401
+ format!("tbx {}, {}, {{ {} }}, {}", rd, ri, rn, rm)
2402
+ }
2403
+ &Inst::VecTbl2 { rd, rn, rn2, rm } => {
2404
+ let rn = pretty_print_vreg_vector(rn, VectorSize::Size8x16, allocs);
2405
+ let rn2 = pretty_print_vreg_vector(rn2, VectorSize::Size8x16, allocs);
2406
+ let rm = pretty_print_vreg_vector(rm, VectorSize::Size8x16, allocs);
2407
+ let rd = pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size8x16, allocs);
2408
+ format!("tbl {}, {{ {}, {} }}, {}", rd, rn, rn2, rm)
2409
+ }
2410
+ &Inst::VecTbl2Ext {
2411
+ rd,
2412
+ ri,
2413
+ rn,
2414
+ rn2,
2415
+ rm,
2416
+ } => {
2417
+ let rn = pretty_print_vreg_vector(rn, VectorSize::Size8x16, allocs);
2418
+ let rn2 = pretty_print_vreg_vector(rn2, VectorSize::Size8x16, allocs);
2419
+ let rm = pretty_print_vreg_vector(rm, VectorSize::Size8x16, allocs);
2420
+ let rd = pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size8x16, allocs);
2421
+ let ri = pretty_print_vreg_vector(ri, VectorSize::Size8x16, allocs);
2422
+ format!("tbx {}, {}, {{ {}, {} }}, {}", rd, ri, rn, rn2, rm)
2423
+ }
2424
+ &Inst::VecLoadReplicate { rd, rn, size, .. } => {
2425
+ let rd = pretty_print_vreg_vector(rd.to_reg(), size, allocs);
2426
+ let rn = pretty_print_reg(rn, allocs);
2427
+
2428
+ format!("ld1r {{ {} }}, [{}]", rd, rn)
2429
+ }
2430
+ &Inst::VecCSel { rd, rn, rm, cond } => {
2431
+ let rd = pretty_print_vreg_vector(rd.to_reg(), VectorSize::Size8x16, allocs);
2432
+ let rn = pretty_print_vreg_vector(rn, VectorSize::Size8x16, allocs);
2433
+ let rm = pretty_print_vreg_vector(rm, VectorSize::Size8x16, allocs);
2434
+ let cond = cond.pretty_print(0, allocs);
2435
+ format!(
2436
+ "vcsel {}, {}, {}, {} (if-then-else diamond)",
2437
+ rd, rn, rm, cond
2438
+ )
2439
+ }
2440
+ &Inst::MovToNZCV { rn } => {
2441
+ let rn = pretty_print_reg(rn, allocs);
2442
+ format!("msr nzcv, {}", rn)
2443
+ }
2444
+ &Inst::MovFromNZCV { rd } => {
2445
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2446
+ format!("mrs {}, nzcv", rd)
2447
+ }
2448
+ &Inst::Extend {
2449
+ rd,
2450
+ rn,
2451
+ signed: false,
2452
+ from_bits: 1,
2453
+ ..
2454
+ } => {
2455
+ let rd = pretty_print_ireg(rd.to_reg(), OperandSize::Size32, allocs);
2456
+ let rn = pretty_print_ireg(rn, OperandSize::Size32, allocs);
2457
+ format!("and {}, {}, #1", rd, rn)
2458
+ }
2459
+ &Inst::Extend {
2460
+ rd,
2461
+ rn,
2462
+ signed: false,
2463
+ from_bits: 32,
2464
+ to_bits: 64,
2465
+ } => {
2466
+ // The case of a zero extension from 32 to 64 bits, is implemented
2467
+ // with a "mov" to a 32-bit (W-reg) dest, because this zeroes
2468
+ // the top 32 bits.
2469
+ let rd = pretty_print_ireg(rd.to_reg(), OperandSize::Size32, allocs);
2470
+ let rn = pretty_print_ireg(rn, OperandSize::Size32, allocs);
2471
+ format!("mov {}, {}", rd, rn)
2472
+ }
2473
+ &Inst::Extend {
2474
+ rd,
2475
+ rn,
2476
+ signed,
2477
+ from_bits,
2478
+ to_bits,
2479
+ } => {
2480
+ assert!(from_bits <= to_bits);
2481
+ let op = match (signed, from_bits) {
2482
+ (false, 8) => "uxtb",
2483
+ (true, 8) => "sxtb",
2484
+ (false, 16) => "uxth",
2485
+ (true, 16) => "sxth",
2486
+ (true, 32) => "sxtw",
2487
+ (true, _) => "sbfx",
2488
+ (false, _) => "ubfx",
2489
+ };
2490
+ if op == "sbfx" || op == "ubfx" {
2491
+ let dest_size = OperandSize::from_bits(to_bits);
2492
+ let rd = pretty_print_ireg(rd.to_reg(), dest_size, allocs);
2493
+ let rn = pretty_print_ireg(rn, dest_size, allocs);
2494
+ format!("{} {}, {}, #0, #{}", op, rd, rn, from_bits)
2495
+ } else {
2496
+ let dest_size = if signed {
2497
+ OperandSize::from_bits(to_bits)
2498
+ } else {
2499
+ OperandSize::Size32
2500
+ };
2501
+ let rd = pretty_print_ireg(rd.to_reg(), dest_size, allocs);
2502
+ let rn = pretty_print_ireg(rn, OperandSize::from_bits(from_bits), allocs);
2503
+ format!("{} {}, {}", op, rd, rn)
2504
+ }
2505
+ }
2506
+ &Inst::Call { .. } => format!("bl 0"),
2507
+ &Inst::CallInd { ref info, .. } => {
2508
+ let rn = pretty_print_reg(info.rn, allocs);
2509
+ format!("blr {}", rn)
2510
+ }
2511
+ &Inst::Args { ref args } => {
2512
+ let mut s = "args".to_string();
2513
+ for arg in args {
2514
+ let preg = pretty_print_reg(arg.preg, &mut empty_allocs);
2515
+ let def = pretty_print_reg(arg.vreg.to_reg(), allocs);
2516
+ write!(&mut s, " {}={}", def, preg).unwrap();
2517
+ }
2518
+ s
2519
+ }
2520
+ &Inst::Ret {
2521
+ ref rets,
2522
+ stack_bytes_to_pop,
2523
+ } => {
2524
+ let mut s = if stack_bytes_to_pop == 0 {
2525
+ "ret".to_string()
2526
+ } else {
2527
+ format!("add sp, sp, #{} ; ret", stack_bytes_to_pop)
2528
+ };
2529
+ for ret in rets {
2530
+ let preg = pretty_print_reg(ret.preg, &mut empty_allocs);
2531
+ let vreg = pretty_print_reg(ret.vreg, allocs);
2532
+ write!(&mut s, " {vreg}={preg}").unwrap();
2533
+ }
2534
+ s
2535
+ }
2536
+ &Inst::AuthenticatedRet {
2537
+ key,
2538
+ is_hint,
2539
+ stack_bytes_to_pop,
2540
+ ref rets,
2541
+ } => {
2542
+ let key = match key {
2543
+ APIKey::A => "a",
2544
+ APIKey::B => "b",
2545
+ };
2546
+ let mut s = match (is_hint, stack_bytes_to_pop) {
2547
+ (false, 0) => format!("reta{key}"),
2548
+ (false, n) => {
2549
+ format!("add sp, sp, #{n} ; reta{key}")
2550
+ }
2551
+ (true, 0) => format!("auti{key}sp ; ret"),
2552
+ (true, n) => {
2553
+ format!("add sp, sp, #{n} ; auti{key} ; ret")
2554
+ }
2555
+ };
2556
+ for ret in rets {
2557
+ let preg = pretty_print_reg(ret.preg, &mut empty_allocs);
2558
+ let vreg = pretty_print_reg(ret.vreg, allocs);
2559
+ write!(&mut s, " {vreg}={preg}").unwrap();
2560
+ }
2561
+ s
2562
+ }
2563
+ &Inst::Jump { ref dest } => {
2564
+ let dest = dest.pretty_print(0, allocs);
2565
+ format!("b {}", dest)
2566
+ }
2567
+ &Inst::CondBr {
2568
+ ref taken,
2569
+ ref not_taken,
2570
+ ref kind,
2571
+ } => {
2572
+ let taken = taken.pretty_print(0, allocs);
2573
+ let not_taken = not_taken.pretty_print(0, allocs);
2574
+ match kind {
2575
+ &CondBrKind::Zero(reg) => {
2576
+ let reg = pretty_print_reg(reg, allocs);
2577
+ format!("cbz {}, {} ; b {}", reg, taken, not_taken)
2578
+ }
2579
+ &CondBrKind::NotZero(reg) => {
2580
+ let reg = pretty_print_reg(reg, allocs);
2581
+ format!("cbnz {}, {} ; b {}", reg, taken, not_taken)
2582
+ }
2583
+ &CondBrKind::Cond(c) => {
2584
+ let c = c.pretty_print(0, allocs);
2585
+ format!("b.{} {} ; b {}", c, taken, not_taken)
2586
+ }
2587
+ }
2588
+ }
2589
+ &Inst::IndirectBr { rn, .. } => {
2590
+ let rn = pretty_print_reg(rn, allocs);
2591
+ format!("br {}", rn)
2592
+ }
2593
+ &Inst::Brk => "brk #0".to_string(),
2594
+ &Inst::Udf { .. } => "udf #0xc11f".to_string(),
2595
+ &Inst::TrapIf {
2596
+ ref kind,
2597
+ trap_code,
2598
+ } => match kind {
2599
+ &CondBrKind::Zero(reg) => {
2600
+ let reg = pretty_print_reg(reg, allocs);
2601
+ format!("cbz {reg}, #trap={trap_code}")
2602
+ }
2603
+ &CondBrKind::NotZero(reg) => {
2604
+ let reg = pretty_print_reg(reg, allocs);
2605
+ format!("cbnz {reg}, #trap={trap_code}")
2606
+ }
2607
+ &CondBrKind::Cond(c) => {
2608
+ let c = c.pretty_print(0, allocs);
2609
+ format!("b.{c} #trap={trap_code}")
2610
+ }
2611
+ },
2612
+ &Inst::Adr { rd, off } => {
2613
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2614
+ format!("adr {}, pc+{}", rd, off)
2615
+ }
2616
+ &Inst::Adrp { rd, off } => {
2617
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2618
+ // This instruction addresses 4KiB pages, so multiply it by the page size.
2619
+ let byte_offset = off * 4096;
2620
+ format!("adrp {}, pc+{}", rd, byte_offset)
2621
+ }
2622
+ &Inst::Word4 { data } => format!("data.i32 {}", data),
2623
+ &Inst::Word8 { data } => format!("data.i64 {}", data),
2624
+ &Inst::JTSequence {
2625
+ ref info,
2626
+ ridx,
2627
+ rtmp1,
2628
+ rtmp2,
2629
+ ..
2630
+ } => {
2631
+ let ridx = pretty_print_reg(ridx, allocs);
2632
+ let rtmp1 = pretty_print_reg(rtmp1.to_reg(), allocs);
2633
+ let rtmp2 = pretty_print_reg(rtmp2.to_reg(), allocs);
2634
+ let default_target = info.default_target.pretty_print(0, allocs);
2635
+ format!(
2636
+ concat!(
2637
+ "b.hs {} ; ",
2638
+ "csel {}, xzr, {}, hs ; ",
2639
+ "csdb ; ",
2640
+ "adr {}, pc+16 ; ",
2641
+ "ldrsw {}, [{}, {}, uxtw #2] ; ",
2642
+ "add {}, {}, {} ; ",
2643
+ "br {} ; ",
2644
+ "jt_entries {:?}"
2645
+ ),
2646
+ default_target,
2647
+ rtmp2,
2648
+ ridx,
2649
+ rtmp1,
2650
+ rtmp2,
2651
+ rtmp1,
2652
+ rtmp2,
2653
+ rtmp1,
2654
+ rtmp1,
2655
+ rtmp2,
2656
+ rtmp1,
2657
+ info.targets
2658
+ )
2659
+ }
2660
+ &Inst::LoadExtName {
2661
+ rd,
2662
+ ref name,
2663
+ offset,
2664
+ } => {
2665
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2666
+ format!("load_ext_name {rd}, {name:?}+{offset}")
2667
+ }
2668
+ &Inst::LoadAddr { rd, ref mem } => {
2669
+ // TODO: we really should find a better way to avoid duplication of
2670
+ // this logic between `emit()` and `show_rru()` -- a separate 1-to-N
2671
+ // expansion stage (i.e., legalization, but without the slow edit-in-place
2672
+ // of the existing legalization framework).
2673
+ let rd = allocs.next_writable(rd);
2674
+ let mem = mem.with_allocs(allocs);
2675
+ let (mem_insts, mem) = mem_finalize(None, &mem, state);
2676
+ let mut ret = String::new();
2677
+ for inst in mem_insts.into_iter() {
2678
+ ret.push_str(
2679
+ &inst.print_with_state(&mut EmitState::default(), &mut empty_allocs),
2680
+ );
2681
+ }
2682
+ let (reg, index_reg, offset) = match mem {
2683
+ AMode::RegExtended { rn, rm, extendop } => (rn, Some((rm, extendop)), 0),
2684
+ AMode::Unscaled { rn, simm9 } => (rn, None, simm9.value()),
2685
+ AMode::UnsignedOffset { rn, uimm12 } => (rn, None, uimm12.value() as i32),
2686
+ _ => panic!("Unsupported case for LoadAddr: {:?}", mem),
2687
+ };
2688
+ let abs_offset = if offset < 0 {
2689
+ -offset as u64
2690
+ } else {
2691
+ offset as u64
2692
+ };
2693
+ let alu_op = if offset < 0 { ALUOp::Sub } else { ALUOp::Add };
2694
+
2695
+ if let Some((idx, extendop)) = index_reg {
2696
+ let add = Inst::AluRRRExtend {
2697
+ alu_op: ALUOp::Add,
2698
+ size: OperandSize::Size64,
2699
+ rd,
2700
+ rn: reg,
2701
+ rm: idx,
2702
+ extendop,
2703
+ };
2704
+
2705
+ ret.push_str(
2706
+ &add.print_with_state(&mut EmitState::default(), &mut empty_allocs),
2707
+ );
2708
+ } else if offset == 0 {
2709
+ let mov = Inst::gen_move(rd, reg, I64);
2710
+ ret.push_str(
2711
+ &mov.print_with_state(&mut EmitState::default(), &mut empty_allocs),
2712
+ );
2713
+ } else if let Some(imm12) = Imm12::maybe_from_u64(abs_offset) {
2714
+ let add = Inst::AluRRImm12 {
2715
+ alu_op,
2716
+ size: OperandSize::Size64,
2717
+ rd,
2718
+ rn: reg,
2719
+ imm12,
2720
+ };
2721
+ ret.push_str(
2722
+ &add.print_with_state(&mut EmitState::default(), &mut empty_allocs),
2723
+ );
2724
+ } else {
2725
+ let tmp = writable_spilltmp_reg();
2726
+ for inst in Inst::load_constant(tmp, abs_offset, &mut |_| tmp).into_iter() {
2727
+ ret.push_str(
2728
+ &inst.print_with_state(&mut EmitState::default(), &mut empty_allocs),
2729
+ );
2730
+ }
2731
+ let add = Inst::AluRRR {
2732
+ alu_op,
2733
+ size: OperandSize::Size64,
2734
+ rd,
2735
+ rn: reg,
2736
+ rm: tmp.to_reg(),
2737
+ };
2738
+ ret.push_str(
2739
+ &add.print_with_state(&mut EmitState::default(), &mut empty_allocs),
2740
+ );
2741
+ }
2742
+ ret
2743
+ }
2744
+ &Inst::Pacisp { key } => {
2745
+ let key = match key {
2746
+ APIKey::A => "a",
2747
+ APIKey::B => "b",
2748
+ };
2749
+
2750
+ "paci".to_string() + key + "sp"
2751
+ }
2752
+ &Inst::Xpaclri => "xpaclri".to_string(),
2753
+ &Inst::Bti { targets } => {
2754
+ let targets = match targets {
2755
+ BranchTargetType::None => "",
2756
+ BranchTargetType::C => " c",
2757
+ BranchTargetType::J => " j",
2758
+ BranchTargetType::JC => " jc",
2759
+ };
2760
+
2761
+ "bti".to_string() + targets
2762
+ }
2763
+ &Inst::VirtualSPOffsetAdj { offset } => {
2764
+ state.virtual_sp_offset += offset;
2765
+ format!("virtual_sp_offset_adjust {}", offset)
2766
+ }
2767
+ &Inst::EmitIsland { needed_space } => format!("emit_island {}", needed_space),
2768
+
2769
+ &Inst::ElfTlsGetAddr { ref symbol, rd } => {
2770
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2771
+ format!("elf_tls_get_addr {}, {}", rd, symbol.display(None))
2772
+ }
2773
+ &Inst::MachOTlsGetAddr { ref symbol, rd } => {
2774
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2775
+ format!("macho_tls_get_addr {}, {}", rd, symbol.display(None))
2776
+ }
2777
+ &Inst::Unwind { ref inst } => {
2778
+ format!("unwind {:?}", inst)
2779
+ }
2780
+ &Inst::DummyUse { reg } => {
2781
+ let reg = pretty_print_reg(reg, allocs);
2782
+ format!("dummy_use {}", reg)
2783
+ }
2784
+ &Inst::StackProbeLoop { start, end, step } => {
2785
+ let start = pretty_print_reg(start.to_reg(), allocs);
2786
+ let end = pretty_print_reg(end, allocs);
2787
+ let step = step.pretty_print(0, allocs);
2788
+ format!("stack_probe_loop {start}, {end}, {step}")
2789
+ }
2790
+ }
2791
+ }
2792
+ }
2793
+
2794
+ //=============================================================================
2795
+ // Label fixups and jump veneers.
2796
+
2797
+ /// Different forms of label references for different instruction formats.
2798
+ #[derive(Clone, Copy, Debug, PartialEq, Eq)]
2799
+ pub enum LabelUse {
2800
+ /// 19-bit branch offset (conditional branches). PC-rel, offset is imm << 2. Immediate is 19
2801
+ /// signed bits, in bits 23:5. Used by cbz, cbnz, b.cond.
2802
+ Branch19,
2803
+ /// 26-bit branch offset (unconditional branches). PC-rel, offset is imm << 2. Immediate is 26
2804
+ /// signed bits, in bits 25:0. Used by b, bl.
2805
+ Branch26,
2806
+ #[allow(dead_code)]
2807
+ /// 19-bit offset for LDR (load literal). PC-rel, offset is imm << 2. Immediate is 19 signed bits,
2808
+ /// in bits 23:5.
2809
+ Ldr19,
2810
+ #[allow(dead_code)]
2811
+ /// 21-bit offset for ADR (get address of label). PC-rel, offset is not shifted. Immediate is
2812
+ /// 21 signed bits, with high 19 bits in bits 23:5 and low 2 bits in bits 30:29.
2813
+ Adr21,
2814
+ /// 32-bit PC relative constant offset (from address of constant itself),
2815
+ /// signed. Used in jump tables.
2816
+ PCRel32,
2817
+ }
2818
+
2819
+ impl MachInstLabelUse for LabelUse {
2820
+ /// Alignment for veneer code. Every AArch64 instruction must be 4-byte-aligned.
2821
+ const ALIGN: CodeOffset = 4;
2822
+
2823
+ /// Maximum PC-relative range (positive), inclusive.
2824
+ fn max_pos_range(self) -> CodeOffset {
2825
+ match self {
2826
+ // 19-bit immediate, left-shifted by 2, for 21 bits of total range. Signed, so +2^20
2827
+ // from zero. Likewise for two other shifted cases below.
2828
+ LabelUse::Branch19 => (1 << 20) - 1,
2829
+ LabelUse::Branch26 => (1 << 27) - 1,
2830
+ LabelUse::Ldr19 => (1 << 20) - 1,
2831
+ // Adr does not shift its immediate, so the 21-bit immediate gives 21 bits of total
2832
+ // range.
2833
+ LabelUse::Adr21 => (1 << 20) - 1,
2834
+ LabelUse::PCRel32 => 0x7fffffff,
2835
+ }
2836
+ }
2837
+
2838
+ /// Maximum PC-relative range (negative).
2839
+ fn max_neg_range(self) -> CodeOffset {
2840
+ // All forms are twos-complement signed offsets, so negative limit is one more than
2841
+ // positive limit.
2842
+ self.max_pos_range() + 1
2843
+ }
2844
+
2845
+ /// Size of window into code needed to do the patch.
2846
+ fn patch_size(self) -> CodeOffset {
2847
+ // Patch is on one instruction only for all of these label reference types.
2848
+ 4
2849
+ }
2850
+
2851
+ /// Perform the patch.
2852
+ fn patch(self, buffer: &mut [u8], use_offset: CodeOffset, label_offset: CodeOffset) {
2853
+ let pc_rel = (label_offset as i64) - (use_offset as i64);
2854
+ debug_assert!(pc_rel <= self.max_pos_range() as i64);
2855
+ debug_assert!(pc_rel >= -(self.max_neg_range() as i64));
2856
+ let pc_rel = pc_rel as u32;
2857
+ let insn_word = u32::from_le_bytes([buffer[0], buffer[1], buffer[2], buffer[3]]);
2858
+ let mask = match self {
2859
+ LabelUse::Branch19 => 0x00ffffe0, // bits 23..5 inclusive
2860
+ LabelUse::Branch26 => 0x03ffffff, // bits 25..0 inclusive
2861
+ LabelUse::Ldr19 => 0x00ffffe0, // bits 23..5 inclusive
2862
+ LabelUse::Adr21 => 0x60ffffe0, // bits 30..29, 25..5 inclusive
2863
+ LabelUse::PCRel32 => 0xffffffff,
2864
+ };
2865
+ let pc_rel_shifted = match self {
2866
+ LabelUse::Adr21 | LabelUse::PCRel32 => pc_rel,
2867
+ _ => {
2868
+ debug_assert!(pc_rel & 3 == 0);
2869
+ pc_rel >> 2
2870
+ }
2871
+ };
2872
+ let pc_rel_inserted = match self {
2873
+ LabelUse::Branch19 | LabelUse::Ldr19 => (pc_rel_shifted & 0x7ffff) << 5,
2874
+ LabelUse::Branch26 => pc_rel_shifted & 0x3ffffff,
2875
+ LabelUse::Adr21 => (pc_rel_shifted & 0x7ffff) << 5 | (pc_rel_shifted & 0x180000) << 10,
2876
+ LabelUse::PCRel32 => pc_rel_shifted,
2877
+ };
2878
+ let is_add = match self {
2879
+ LabelUse::PCRel32 => true,
2880
+ _ => false,
2881
+ };
2882
+ let insn_word = if is_add {
2883
+ insn_word.wrapping_add(pc_rel_inserted)
2884
+ } else {
2885
+ (insn_word & !mask) | pc_rel_inserted
2886
+ };
2887
+ buffer[0..4].clone_from_slice(&u32::to_le_bytes(insn_word));
2888
+ }
2889
+
2890
+ /// Is a veneer supported for this label reference type?
2891
+ fn supports_veneer(self) -> bool {
2892
+ match self {
2893
+ LabelUse::Branch19 => true, // veneer is a Branch26
2894
+ LabelUse::Branch26 => true, // veneer is a PCRel32
2895
+ _ => false,
2896
+ }
2897
+ }
2898
+
2899
+ /// How large is the veneer, if supported?
2900
+ fn veneer_size(self) -> CodeOffset {
2901
+ match self {
2902
+ LabelUse::Branch19 => 4,
2903
+ LabelUse::Branch26 => 20,
2904
+ _ => unreachable!(),
2905
+ }
2906
+ }
2907
+
2908
+ /// Generate a veneer into the buffer, given that this veneer is at `veneer_offset`, and return
2909
+ /// an offset and label-use for the veneer's use of the original label.
2910
+ fn generate_veneer(
2911
+ self,
2912
+ buffer: &mut [u8],
2913
+ veneer_offset: CodeOffset,
2914
+ ) -> (CodeOffset, LabelUse) {
2915
+ match self {
2916
+ LabelUse::Branch19 => {
2917
+ // veneer is a Branch26 (unconditional branch). Just encode directly here -- don't
2918
+ // bother with constructing an Inst.
2919
+ let insn_word = 0b000101 << 26;
2920
+ buffer[0..4].clone_from_slice(&u32::to_le_bytes(insn_word));
2921
+ (veneer_offset, LabelUse::Branch26)
2922
+ }
2923
+
2924
+ // This is promoting a 26-bit call/jump to a 32-bit call/jump to
2925
+ // get a further range. This jump translates to a jump to a
2926
+ // relative location based on the address of the constant loaded
2927
+ // from here.
2928
+ //
2929
+ // If this path is taken from a call instruction then caller-saved
2930
+ // registers are available (minus arguments), so x16/x17 are
2931
+ // available. Otherwise for intra-function jumps we also reserve
2932
+ // x16/x17 as spill-style registers. In both cases these are
2933
+ // available for us to use.
2934
+ LabelUse::Branch26 => {
2935
+ let tmp1 = regs::spilltmp_reg();
2936
+ let tmp1_w = regs::writable_spilltmp_reg();
2937
+ let tmp2 = regs::tmp2_reg();
2938
+ let tmp2_w = regs::writable_tmp2_reg();
2939
+ // ldrsw x16, 16
2940
+ let ldr = emit::enc_ldst_imm19(0b1001_1000, 16 / 4, tmp1);
2941
+ // adr x17, 12
2942
+ let adr = emit::enc_adr(12, tmp2_w);
2943
+ // add x16, x16, x17
2944
+ let add = emit::enc_arith_rrr(0b10001011_000, 0, tmp1_w, tmp1, tmp2);
2945
+ // br x16
2946
+ let br = emit::enc_br(tmp1);
2947
+ buffer[0..4].clone_from_slice(&u32::to_le_bytes(ldr));
2948
+ buffer[4..8].clone_from_slice(&u32::to_le_bytes(adr));
2949
+ buffer[8..12].clone_from_slice(&u32::to_le_bytes(add));
2950
+ buffer[12..16].clone_from_slice(&u32::to_le_bytes(br));
2951
+ // the 4-byte signed immediate we'll load is after these
2952
+ // instructions, 16-bytes in.
2953
+ (veneer_offset + 16, LabelUse::PCRel32)
2954
+ }
2955
+
2956
+ _ => panic!("Unsupported label-reference type for veneer generation!"),
2957
+ }
2958
+ }
2959
+
2960
+ fn from_reloc(reloc: Reloc, addend: Addend) -> Option<LabelUse> {
2961
+ match (reloc, addend) {
2962
+ (Reloc::Arm64Call, 0) => Some(LabelUse::Branch26),
2963
+ _ => None,
2964
+ }
2965
+ }
2966
+ }