wasmtime 24.0.0 → 25.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (2458) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +112 -111
  3. data/ext/Cargo.toml +6 -6
  4. data/ext/cargo-vendor/cranelift-bforest-0.112.1/.cargo-checksum.json +1 -0
  5. data/ext/cargo-vendor/cranelift-bforest-0.112.1/Cargo.toml +59 -0
  6. data/ext/cargo-vendor/cranelift-bforest-0.112.1/src/node.rs +806 -0
  7. data/ext/cargo-vendor/cranelift-bforest-0.112.1/src/path.rs +830 -0
  8. data/ext/cargo-vendor/cranelift-bforest-0.112.1/src/pool.rs +219 -0
  9. data/ext/cargo-vendor/cranelift-bitset-0.112.1/.cargo-checksum.json +1 -0
  10. data/ext/cargo-vendor/cranelift-bitset-0.112.1/Cargo.toml +74 -0
  11. data/ext/cargo-vendor/cranelift-bitset-0.112.1/src/scalar.rs +626 -0
  12. data/ext/cargo-vendor/cranelift-codegen-0.112.1/.cargo-checksum.json +1 -0
  13. data/ext/cargo-vendor/cranelift-codegen-0.112.1/Cargo.toml +222 -0
  14. data/ext/cargo-vendor/cranelift-codegen-0.112.1/build.rs +267 -0
  15. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/binemit/mod.rs +168 -0
  16. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/cfg_printer.rs +83 -0
  17. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/data_value.rs +402 -0
  18. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/dbg.rs +28 -0
  19. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/egraph.rs +835 -0
  20. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/incremental_cache.rs +256 -0
  21. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/inst_predicates.rs +207 -0
  22. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/constant.rs +485 -0
  23. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/dfg.rs +1802 -0
  24. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/entities.rs +564 -0
  25. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/extfunc.rs +408 -0
  26. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/extname.rs +333 -0
  27. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/function.rs +500 -0
  28. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/globalvalue.rs +147 -0
  29. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/immediates.rs +1941 -0
  30. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/instructions.rs +1021 -0
  31. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/memtype.rs +190 -0
  32. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/progpoint.rs +75 -0
  33. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/trapcode.rs +148 -0
  34. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/types.rs +624 -0
  35. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/ir/user_stack_maps.rs +199 -0
  36. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/abi.rs +1520 -0
  37. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst/args.rs +711 -0
  38. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst/emit.rs +3567 -0
  39. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst/emit_tests.rs +7972 -0
  40. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst/imms.rs +1244 -0
  41. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst/mod.rs +3051 -0
  42. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst/regs.rs +269 -0
  43. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst/unwind/systemv.rs +174 -0
  44. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/inst.isle +4267 -0
  45. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/lower/isle.rs +811 -0
  46. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/lower.isle +2968 -0
  47. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/pcc.rs +570 -0
  48. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/aarch64/settings.rs +9 -0
  49. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/mod.rs +471 -0
  50. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley32.rs +13 -0
  51. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley64.rs +13 -0
  52. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/abi.rs +798 -0
  53. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/inst/args.rs +192 -0
  54. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/inst/emit.rs +482 -0
  55. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/inst/mod.rs +905 -0
  56. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/inst/regs.rs +164 -0
  57. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/inst.isle +543 -0
  58. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/lower/isle/generated_code.rs +17 -0
  59. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/lower/isle.rs +195 -0
  60. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/lower.isle +178 -0
  61. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/lower.rs +36 -0
  62. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/mod.rs +281 -0
  63. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/pulley_shared/settings.rs +16 -0
  64. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/abi.rs +993 -0
  65. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst/args.rs +1957 -0
  66. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst/emit.rs +2685 -0
  67. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst/emit_tests.rs +2277 -0
  68. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst/encode.rs +721 -0
  69. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst/mod.rs +1865 -0
  70. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst/unwind/systemv.rs +170 -0
  71. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst/vector.rs +1150 -0
  72. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst.isle +3128 -0
  73. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/inst_vector.isle +1907 -0
  74. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/lower/isle.rs +721 -0
  75. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/riscv64/lower.isle +2940 -0
  76. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/abi.rs +1348 -0
  77. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/inst/emit.rs +3470 -0
  78. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/inst/emit_tests.rs +13370 -0
  79. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/inst/mod.rs +3461 -0
  80. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/inst/regs.rs +169 -0
  81. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/inst/unwind/systemv.rs +212 -0
  82. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/inst.isle +5071 -0
  83. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/lower/isle.rs +1109 -0
  84. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/s390x/lower.isle +3981 -0
  85. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/unwind/systemv.rs +276 -0
  86. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/abi.rs +1390 -0
  87. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/encoding/evex.rs +747 -0
  88. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/args.rs +2318 -0
  89. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/emit.rs +4400 -0
  90. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/emit_state.rs +55 -0
  91. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/emit_tests.rs +5146 -0
  92. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/mod.rs +2811 -0
  93. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/regs.rs +275 -0
  94. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/stack_switch.rs +52 -0
  95. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst/unwind/systemv.rs +198 -0
  96. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/inst.isle +5382 -0
  97. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/lower/isle.rs +1047 -0
  98. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/lower.isle +4919 -0
  99. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/lower.rs +338 -0
  100. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/mod.rs +239 -0
  101. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isa/x64/pcc.rs +1022 -0
  102. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/isle_prelude.rs +1144 -0
  103. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/lib.rs +106 -0
  104. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/machinst/abi.rs +2417 -0
  105. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/machinst/buffer.rs +2492 -0
  106. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/machinst/isle.rs +890 -0
  107. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/machinst/lower.rs +1590 -0
  108. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/machinst/mod.rs +560 -0
  109. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/machinst/reg.rs +484 -0
  110. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/machinst/vcode.rs +1762 -0
  111. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/opts/extends.isle +95 -0
  112. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/opts/icmp.isle +258 -0
  113. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/opts/selects.isle +88 -0
  114. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/prelude.isle +751 -0
  115. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/prelude_lower.isle +1081 -0
  116. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/print_errors.rs +223 -0
  117. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/remove_constant_phis.rs +419 -0
  118. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/result.rs +111 -0
  119. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/settings.rs +591 -0
  120. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/timing.rs +296 -0
  121. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/verifier/mod.rs +1941 -0
  122. data/ext/cargo-vendor/cranelift-codegen-0.112.1/src/write.rs +694 -0
  123. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/.cargo-checksum.json +1 -0
  124. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/Cargo.toml +54 -0
  125. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/cdsl/settings.rs +429 -0
  126. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/cdsl/types.rs +420 -0
  127. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/cdsl/typevar.rs +946 -0
  128. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/error.rs +48 -0
  129. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/gen_inst.rs +1274 -0
  130. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/gen_isle.rs +519 -0
  131. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/gen_settings.rs +505 -0
  132. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/gen_types.rs +70 -0
  133. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/isa/arm64.rs +59 -0
  134. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/isa/mod.rs +81 -0
  135. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/isa/pulley.rs +14 -0
  136. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/isa/riscv64.rs +181 -0
  137. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/isa/x86.rs +414 -0
  138. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/isle.rs +142 -0
  139. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/lib.rs +98 -0
  140. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/shared/instructions.rs +3801 -0
  141. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/shared/mod.rs +87 -0
  142. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/shared/settings.rs +361 -0
  143. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/shared/types.rs +103 -0
  144. data/ext/cargo-vendor/cranelift-codegen-meta-0.112.1/src/srcgen.rs +464 -0
  145. data/ext/cargo-vendor/cranelift-codegen-shared-0.112.1/.cargo-checksum.json +1 -0
  146. data/ext/cargo-vendor/cranelift-codegen-shared-0.112.1/Cargo.toml +32 -0
  147. data/ext/cargo-vendor/cranelift-control-0.112.1/.cargo-checksum.json +1 -0
  148. data/ext/cargo-vendor/cranelift-control-0.112.1/Cargo.toml +43 -0
  149. data/ext/cargo-vendor/cranelift-entity-0.112.1/.cargo-checksum.json +1 -0
  150. data/ext/cargo-vendor/cranelift-entity-0.112.1/Cargo.toml +75 -0
  151. data/ext/cargo-vendor/cranelift-entity-0.112.1/src/lib.rs +381 -0
  152. data/ext/cargo-vendor/cranelift-entity-0.112.1/src/packed_option.rs +173 -0
  153. data/ext/cargo-vendor/cranelift-entity-0.112.1/src/sparse.rs +367 -0
  154. data/ext/cargo-vendor/cranelift-frontend-0.112.1/.cargo-checksum.json +1 -0
  155. data/ext/cargo-vendor/cranelift-frontend-0.112.1/Cargo.toml +97 -0
  156. data/ext/cargo-vendor/cranelift-frontend-0.112.1/src/frontend.rs +1963 -0
  157. data/ext/cargo-vendor/cranelift-frontend-0.112.1/src/ssa.rs +1325 -0
  158. data/ext/cargo-vendor/cranelift-frontend-0.112.1/src/switch.rs +676 -0
  159. data/ext/cargo-vendor/cranelift-isle-0.112.1/.cargo-checksum.json +1 -0
  160. data/ext/cargo-vendor/cranelift-isle-0.112.1/Cargo.toml +69 -0
  161. data/ext/cargo-vendor/cranelift-isle-0.112.1/build.rs +35 -0
  162. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/ast.rs +412 -0
  163. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/codegen.rs +922 -0
  164. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/compile.rs +65 -0
  165. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/error.rs +318 -0
  166. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/files.rs +133 -0
  167. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/lexer.rs +343 -0
  168. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/lib.rs +34 -0
  169. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/overlap.rs +130 -0
  170. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/parser.rs +551 -0
  171. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/sema.rs +2482 -0
  172. data/ext/cargo-vendor/cranelift-isle-0.112.1/src/trie_again.rs +696 -0
  173. data/ext/cargo-vendor/cranelift-isle-0.112.1/tests/run_tests.rs +77 -0
  174. data/ext/cargo-vendor/cranelift-native-0.112.1/.cargo-checksum.json +1 -0
  175. data/ext/cargo-vendor/cranelift-native-0.112.1/Cargo.toml +52 -0
  176. data/ext/cargo-vendor/cranelift-native-0.112.1/src/lib.rs +192 -0
  177. data/ext/cargo-vendor/cranelift-wasm-0.112.1/.cargo-checksum.json +1 -0
  178. data/ext/cargo-vendor/cranelift-wasm-0.112.1/Cargo.toml +128 -0
  179. data/ext/cargo-vendor/cranelift-wasm-0.112.1/src/code_translator.rs +3723 -0
  180. data/ext/cargo-vendor/cranelift-wasm-0.112.1/src/environ/dummy.rs +897 -0
  181. data/ext/cargo-vendor/cranelift-wasm-0.112.1/src/environ/spec.rs +922 -0
  182. data/ext/cargo-vendor/cranelift-wasm-0.112.1/src/func_translator.rs +283 -0
  183. data/ext/cargo-vendor/cranelift-wasm-0.112.1/src/module_translator.rs +120 -0
  184. data/ext/cargo-vendor/cranelift-wasm-0.112.1/src/sections_translator.rs +332 -0
  185. data/ext/cargo-vendor/cranelift-wasm-0.112.1/src/translation_utils.rs +95 -0
  186. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.25/.cargo-checksum.json +1 -0
  187. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.25/Cargo.toml +69 -0
  188. data/ext/cargo-vendor/pulley-interpreter-0.1.1/.cargo-checksum.json +1 -0
  189. data/ext/cargo-vendor/pulley-interpreter-0.1.1/Cargo.toml +85 -0
  190. data/ext/cargo-vendor/pulley-interpreter-0.1.1/README.md +109 -0
  191. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/decode.rs +657 -0
  192. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/disas.rs +256 -0
  193. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/encode.rs +198 -0
  194. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/imms.rs +31 -0
  195. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/interp.rs +1113 -0
  196. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/lib.rs +215 -0
  197. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/op.rs +256 -0
  198. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/opcode.rs +126 -0
  199. data/ext/cargo-vendor/pulley-interpreter-0.1.1/src/regs.rs +329 -0
  200. data/ext/cargo-vendor/pulley-interpreter-0.1.1/tests/all/disas.rs +87 -0
  201. data/ext/cargo-vendor/pulley-interpreter-0.1.1/tests/all/interp.rs +1216 -0
  202. data/ext/cargo-vendor/pulley-interpreter-0.1.1/tests/all/main.rs +5 -0
  203. data/ext/cargo-vendor/regalloc2-0.10.2/.cargo-checksum.json +1 -0
  204. data/ext/cargo-vendor/regalloc2-0.10.2/Cargo.toml +83 -0
  205. data/ext/cargo-vendor/regalloc2-0.10.2/doc/DESIGN.md +1411 -0
  206. data/ext/cargo-vendor/regalloc2-0.10.2/src/cfg.rs +135 -0
  207. data/ext/cargo-vendor/regalloc2-0.10.2/src/checker.rs +993 -0
  208. data/ext/cargo-vendor/regalloc2-0.10.2/src/fuzzing/func.rs +651 -0
  209. data/ext/cargo-vendor/regalloc2-0.10.2/src/fuzzing/mod.rs +31 -0
  210. data/ext/cargo-vendor/regalloc2-0.10.2/src/index.rs +209 -0
  211. data/ext/cargo-vendor/regalloc2-0.10.2/src/ion/data_structures.rs +838 -0
  212. data/ext/cargo-vendor/regalloc2-0.10.2/src/ion/liveranges.rs +882 -0
  213. data/ext/cargo-vendor/regalloc2-0.10.2/src/ion/merge.rs +366 -0
  214. data/ext/cargo-vendor/regalloc2-0.10.2/src/ion/mod.rs +143 -0
  215. data/ext/cargo-vendor/regalloc2-0.10.2/src/ion/moves.rs +1006 -0
  216. data/ext/cargo-vendor/regalloc2-0.10.2/src/ion/process.rs +1319 -0
  217. data/ext/cargo-vendor/regalloc2-0.10.2/src/ion/requirement.rs +167 -0
  218. data/ext/cargo-vendor/regalloc2-0.10.2/src/lib.rs +1518 -0
  219. data/ext/cargo-vendor/regalloc2-0.10.2/src/serialize.rs +293 -0
  220. data/ext/cargo-vendor/rustc-hash-2.0.0/.cargo-checksum.json +1 -0
  221. data/ext/cargo-vendor/rustc-hash-2.0.0/CHANGELOG.md +19 -0
  222. data/ext/cargo-vendor/rustc-hash-2.0.0/CODE_OF_CONDUCT.md +3 -0
  223. data/ext/cargo-vendor/rustc-hash-2.0.0/Cargo.toml +39 -0
  224. data/ext/cargo-vendor/rustc-hash-2.0.0/LICENSE-APACHE +176 -0
  225. data/ext/cargo-vendor/rustc-hash-2.0.0/LICENSE-MIT +23 -0
  226. data/ext/cargo-vendor/rustc-hash-2.0.0/README.md +42 -0
  227. data/ext/cargo-vendor/rustc-hash-2.0.0/src/lib.rs +459 -0
  228. data/ext/cargo-vendor/rustc-hash-2.0.0/src/random_state.rs +92 -0
  229. data/ext/cargo-vendor/rustc-hash-2.0.0/src/seeded_state.rs +53 -0
  230. data/ext/cargo-vendor/wasi-common-25.0.1/.cargo-checksum.json +1 -0
  231. data/ext/cargo-vendor/wasi-common-25.0.1/Cargo.toml +242 -0
  232. data/ext/cargo-vendor/wasi-common-25.0.1/src/ctx.rs +128 -0
  233. data/ext/cargo-vendor/wasi-common-25.0.1/src/lib.rs +193 -0
  234. data/ext/cargo-vendor/wasi-common-25.0.1/src/snapshots/mod.rs +24 -0
  235. data/ext/cargo-vendor/wasi-common-25.0.1/src/sync/dir.rs +461 -0
  236. data/ext/cargo-vendor/wasi-common-25.0.1/src/tokio/dir.rs +220 -0
  237. data/ext/cargo-vendor/wasi-common-25.0.1/tests/all/async_.rs +294 -0
  238. data/ext/cargo-vendor/wasi-common-25.0.1/tests/all/main.rs +21 -0
  239. data/ext/cargo-vendor/wasi-common-25.0.1/tests/all/sync.rs +283 -0
  240. data/ext/cargo-vendor/wasm-encoder-0.217.0/.cargo-checksum.json +1 -0
  241. data/ext/cargo-vendor/wasm-encoder-0.217.0/Cargo.toml +65 -0
  242. data/ext/cargo-vendor/wasm-encoder-0.217.0/src/component/builder.rs +469 -0
  243. data/ext/cargo-vendor/wasm-encoder-0.217.0/src/component/exports.rs +129 -0
  244. data/ext/cargo-vendor/wasm-encoder-0.217.0/src/component/imports.rs +169 -0
  245. data/ext/cargo-vendor/wasm-encoder-0.217.0/src/component/instances.rs +199 -0
  246. data/ext/cargo-vendor/wasm-encoder-0.217.0/src/component/types.rs +800 -0
  247. data/ext/cargo-vendor/wasm-encoder-0.217.0/src/core/code.rs +3947 -0
  248. data/ext/cargo-vendor/wasmparser-0.217.0/.cargo-checksum.json +1 -0
  249. data/ext/cargo-vendor/wasmparser-0.217.0/Cargo.lock +679 -0
  250. data/ext/cargo-vendor/wasmparser-0.217.0/Cargo.toml +139 -0
  251. data/ext/cargo-vendor/wasmparser-0.217.0/benches/benchmark.rs +350 -0
  252. data/ext/cargo-vendor/wasmparser-0.217.0/src/binary_reader.rs +2115 -0
  253. data/ext/cargo-vendor/wasmparser-0.217.0/src/features.rs +281 -0
  254. data/ext/cargo-vendor/wasmparser-0.217.0/src/limits.rs +80 -0
  255. data/ext/cargo-vendor/wasmparser-0.217.0/src/parser.rs +1691 -0
  256. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/component/aliases.rs +119 -0
  257. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/component/canonicals.rs +121 -0
  258. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/component/exports.rs +135 -0
  259. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/component/imports.rs +145 -0
  260. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/component/instances.rs +166 -0
  261. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/component/types.rs +553 -0
  262. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/code.rs +142 -0
  263. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/coredumps.rs +278 -0
  264. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/data.rs +94 -0
  265. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/exports.rs +65 -0
  266. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/globals.rs +61 -0
  267. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/imports.rs +76 -0
  268. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/init.rs +65 -0
  269. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/operators.rs +479 -0
  270. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/producers.rs +84 -0
  271. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers/core/types.rs +1987 -0
  272. data/ext/cargo-vendor/wasmparser-0.217.0/src/readers.rs +315 -0
  273. data/ext/cargo-vendor/wasmparser-0.217.0/src/resources.rs +245 -0
  274. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator/component.rs +3297 -0
  275. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator/core/canonical.rs +409 -0
  276. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator/core.rs +1374 -0
  277. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator/func.rs +340 -0
  278. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator/names.rs +1012 -0
  279. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator/operators.rs +4845 -0
  280. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator/types.rs +4612 -0
  281. data/ext/cargo-vendor/wasmparser-0.217.0/src/validator.rs +1658 -0
  282. data/ext/cargo-vendor/wasmprinter-0.217.0/.cargo-checksum.json +1 -0
  283. data/ext/cargo-vendor/wasmprinter-0.217.0/Cargo.toml +74 -0
  284. data/ext/cargo-vendor/wasmprinter-0.217.0/src/lib.rs +3250 -0
  285. data/ext/cargo-vendor/wasmtime-25.0.1/.cargo-checksum.json +1 -0
  286. data/ext/cargo-vendor/wasmtime-25.0.1/Cargo.toml +407 -0
  287. data/ext/cargo-vendor/wasmtime-25.0.1/build.rs +38 -0
  288. data/ext/cargo-vendor/wasmtime-25.0.1/src/compile/code_builder.rs +317 -0
  289. data/ext/cargo-vendor/wasmtime-25.0.1/src/compile/runtime.rs +167 -0
  290. data/ext/cargo-vendor/wasmtime-25.0.1/src/compile.rs +881 -0
  291. data/ext/cargo-vendor/wasmtime-25.0.1/src/config.rs +3021 -0
  292. data/ext/cargo-vendor/wasmtime-25.0.1/src/engine/serialization.rs +906 -0
  293. data/ext/cargo-vendor/wasmtime-25.0.1/src/engine.rs +778 -0
  294. data/ext/cargo-vendor/wasmtime-25.0.1/src/lib.rs +406 -0
  295. data/ext/cargo-vendor/wasmtime-25.0.1/src/profiling_agent/jitdump.rs +64 -0
  296. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/component/component.rs +810 -0
  297. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/component/func/host.rs +458 -0
  298. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/component/func/typed.rs +2497 -0
  299. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/component/linker.rs +704 -0
  300. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/component/mod.rs +673 -0
  301. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/component/resources.rs +1132 -0
  302. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/component/types.rs +897 -0
  303. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/coredump.rs +339 -0
  304. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/externals/global.rs +312 -0
  305. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/externals/table.rs +480 -0
  306. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/func.rs +2607 -0
  307. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/disabled/anyref.rs +126 -0
  308. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/disabled/arrayref.rs +56 -0
  309. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/disabled/rooting.rs +229 -0
  310. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/disabled.rs +23 -0
  311. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/enabled/anyref.rs +662 -0
  312. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/enabled/arrayref.rs +879 -0
  313. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/enabled/i31.rs +291 -0
  314. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/enabled/rooting.rs +1755 -0
  315. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/gc/enabled.rs +16 -0
  316. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/instance.rs +989 -0
  317. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/linker.rs +1498 -0
  318. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/memory.rs +1101 -0
  319. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/module.rs +1178 -0
  320. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/store.rs +2877 -0
  321. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/trampoline/global.rs +70 -0
  322. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/trap.rs +641 -0
  323. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/types.rs +2932 -0
  324. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/values.rs +1050 -0
  325. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/const_expr.rs +132 -0
  326. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/cow.rs +992 -0
  327. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/disabled.rs +41 -0
  328. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/enabled/arrayref.rs +342 -0
  329. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/enabled/data.rs +149 -0
  330. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/enabled/drc.rs +1163 -0
  331. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/enabled/structref.rs +336 -0
  332. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/enabled.rs +29 -0
  333. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/gc_ref.rs +479 -0
  334. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc/gc_runtime.rs +718 -0
  335. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/gc.rs +339 -0
  336. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/helpers.c +118 -0
  337. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/instance/allocator/pooling/gc_heap_pool.rs +95 -0
  338. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/instance/allocator/pooling/index_allocator.rs +702 -0
  339. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/libcalls.rs +850 -0
  340. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/sys/custom/traphandlers.rs +57 -0
  341. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/sys/unix/machports.rs +440 -0
  342. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/sys/unix/mmap.rs +159 -0
  343. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/sys/unix/signals.rs +465 -0
  344. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/sys/windows/traphandlers.rs +135 -0
  345. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/threads/parking_spot.rs +623 -0
  346. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/traphandlers.rs +787 -0
  347. data/ext/cargo-vendor/wasmtime-25.0.1/src/runtime/vm/vmcontext.rs +1246 -0
  348. data/ext/cargo-vendor/wasmtime-asm-macros-25.0.1/.cargo-checksum.json +1 -0
  349. data/ext/cargo-vendor/wasmtime-asm-macros-25.0.1/Cargo.toml +33 -0
  350. data/ext/cargo-vendor/wasmtime-cache-25.0.1/.cargo-checksum.json +1 -0
  351. data/ext/cargo-vendor/wasmtime-cache-25.0.1/Cargo.toml +112 -0
  352. data/ext/cargo-vendor/wasmtime-cache-25.0.1/build.rs +10 -0
  353. data/ext/cargo-vendor/wasmtime-cache-25.0.1/src/config.rs +584 -0
  354. data/ext/cargo-vendor/wasmtime-cache-25.0.1/src/lib.rs +235 -0
  355. data/ext/cargo-vendor/wasmtime-cache-25.0.1/src/worker/tests.rs +758 -0
  356. data/ext/cargo-vendor/wasmtime-cache-25.0.1/src/worker.rs +890 -0
  357. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/.cargo-checksum.json +1 -0
  358. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/Cargo.toml +115 -0
  359. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/src/bindgen.rs +507 -0
  360. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/src/component.rs +1540 -0
  361. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/codegen.rs +699 -0
  362. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/char.rs +387 -0
  363. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/char_async.rs +414 -0
  364. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/char_tracing_async.rs +461 -0
  365. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/conventions.rs +824 -0
  366. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/conventions_async.rs +899 -0
  367. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/conventions_tracing_async.rs +1190 -0
  368. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/dead-code.rs +279 -0
  369. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/dead-code_async.rs +300 -0
  370. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/dead-code_tracing_async.rs +313 -0
  371. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/direct-import.rs +205 -0
  372. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/direct-import_async.rs +219 -0
  373. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/direct-import_tracing_async.rs +232 -0
  374. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/empty.rs +159 -0
  375. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/empty_async.rs +165 -0
  376. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/empty_tracing_async.rs +165 -0
  377. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/flags.rs +859 -0
  378. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/flags_async.rs +921 -0
  379. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/flags_tracing_async.rs +1096 -0
  380. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/floats.rs +459 -0
  381. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/floats_async.rs +500 -0
  382. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/floats_tracing_async.rs +594 -0
  383. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/function-new.rs +182 -0
  384. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/function-new_async.rs +191 -0
  385. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/function-new_tracing_async.rs +199 -0
  386. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/integers.rs +989 -0
  387. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/integers_async.rs +1128 -0
  388. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/integers_tracing_async.rs +1555 -0
  389. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/lists.rs +2040 -0
  390. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/lists_async.rs +2288 -0
  391. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/lists_tracing_async.rs +2980 -0
  392. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/many-arguments.rs +730 -0
  393. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/many-arguments_async.rs +758 -0
  394. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/many-arguments_tracing_async.rs +819 -0
  395. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/multi-return.rs +475 -0
  396. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/multi-return_async.rs +519 -0
  397. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/multi-return_tracing_async.rs +633 -0
  398. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/multiversion.rs +508 -0
  399. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/multiversion_async.rs +537 -0
  400. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/multiversion_tracing_async.rs +585 -0
  401. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/records.rs +1056 -0
  402. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/records_async.rs +1146 -0
  403. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/records_tracing_async.rs +1406 -0
  404. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/rename.rs +268 -0
  405. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/rename_async.rs +289 -0
  406. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/rename_tracing_async.rs +302 -0
  407. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/resources-export.rs +879 -0
  408. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/resources-export_async.rs +937 -0
  409. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/resources-export_tracing_async.rs +1011 -0
  410. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/resources-import.rs +1217 -0
  411. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/resources-import_async.rs +1361 -0
  412. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/resources-import_tracing_async.rs +1774 -0
  413. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/share-types.rs +429 -0
  414. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/share-types_async.rs +453 -0
  415. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/share-types_tracing_async.rs +477 -0
  416. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-functions.rs +522 -0
  417. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-functions_async.rs +574 -0
  418. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-functions_tracing_async.rs +718 -0
  419. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-lists.rs +545 -0
  420. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-lists_async.rs +590 -0
  421. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-lists_tracing_async.rs +687 -0
  422. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-wasi.rs +331 -0
  423. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-wasi_async.rs +354 -0
  424. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/simple-wasi_tracing_async.rs +380 -0
  425. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/small-anonymous.rs +454 -0
  426. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/small-anonymous_async.rs +474 -0
  427. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/small-anonymous_tracing_async.rs +496 -0
  428. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke-default.rs +182 -0
  429. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke-default_async.rs +191 -0
  430. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke-default_tracing_async.rs +199 -0
  431. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke-export.rs +263 -0
  432. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke-export_async.rs +272 -0
  433. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke-export_tracing_async.rs +280 -0
  434. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke.rs +218 -0
  435. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke_async.rs +233 -0
  436. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/smoke_tracing_async.rs +246 -0
  437. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/strings.rs +432 -0
  438. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/strings_async.rs +466 -0
  439. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/strings_tracing_async.rs +538 -0
  440. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/unversioned-foo.rs +250 -0
  441. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/unversioned-foo_async.rs +265 -0
  442. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/unversioned-foo_tracing_async.rs +278 -0
  443. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/use-paths.rs +402 -0
  444. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/use-paths_async.rs +442 -0
  445. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/use-paths_tracing_async.rs +494 -0
  446. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/variants.rs +2016 -0
  447. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/variants_async.rs +2183 -0
  448. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/variants_tracing_async.rs +2705 -0
  449. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/wat.rs +265 -0
  450. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/wat_async.rs +271 -0
  451. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/wat_tracing_async.rs +271 -0
  452. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/worlds-with-types.rs +263 -0
  453. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/worlds-with-types_async.rs +279 -0
  454. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded/worlds-with-types_tracing_async.rs +287 -0
  455. data/ext/cargo-vendor/wasmtime-component-macro-25.0.1/tests/expanded.rs +72 -0
  456. data/ext/cargo-vendor/wasmtime-component-util-25.0.1/.cargo-checksum.json +1 -0
  457. data/ext/cargo-vendor/wasmtime-component-util-25.0.1/Cargo.toml +36 -0
  458. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/.cargo-checksum.json +1 -0
  459. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/Cargo.toml +137 -0
  460. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/compiler.rs +1035 -0
  461. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/debug/transform/attr.rs +308 -0
  462. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/debug/transform/line_program.rs +264 -0
  463. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/debug/transform/mod.rs +256 -0
  464. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/debug/transform/range_info_builder.rs +215 -0
  465. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/debug/transform/simulate.rs +423 -0
  466. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/debug/transform/unit.rs +512 -0
  467. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/func_environ.rs +2757 -0
  468. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/gc/enabled.rs +631 -0
  469. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/gc.rs +189 -0
  470. data/ext/cargo-vendor/wasmtime-cranelift-25.0.1/src/lib.rs +399 -0
  471. data/ext/cargo-vendor/wasmtime-environ-25.0.1/.cargo-checksum.json +1 -0
  472. data/ext/cargo-vendor/wasmtime-environ-25.0.1/Cargo.lock +792 -0
  473. data/ext/cargo-vendor/wasmtime-environ-25.0.1/Cargo.toml +195 -0
  474. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/builtin.rs +184 -0
  475. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/compile/mod.rs +379 -0
  476. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/compile/module_environ.rs +1264 -0
  477. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/component/types.rs +1059 -0
  478. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/demangling.rs +28 -0
  479. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/fact/trampoline.rs +3234 -0
  480. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/fact/traps.rs +116 -0
  481. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/stack_map.rs +60 -0
  482. data/ext/cargo-vendor/wasmtime-environ-25.0.1/src/trap_encoding.rs +189 -0
  483. data/ext/cargo-vendor/wasmtime-fiber-25.0.1/.cargo-checksum.json +1 -0
  484. data/ext/cargo-vendor/wasmtime-fiber-25.0.1/Cargo.toml +84 -0
  485. data/ext/cargo-vendor/wasmtime-fiber-25.0.1/build.rs +39 -0
  486. data/ext/cargo-vendor/wasmtime-fiber-25.0.1/src/lib.rs +343 -0
  487. data/ext/cargo-vendor/wasmtime-jit-debug-25.0.1/.cargo-checksum.json +1 -0
  488. data/ext/cargo-vendor/wasmtime-jit-debug-25.0.1/Cargo.toml +86 -0
  489. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-25.0.1/.cargo-checksum.json +1 -0
  490. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-25.0.1/Cargo.toml +71 -0
  491. data/ext/cargo-vendor/wasmtime-slab-25.0.1/.cargo-checksum.json +1 -0
  492. data/ext/cargo-vendor/wasmtime-slab-25.0.1/Cargo.toml +50 -0
  493. data/ext/cargo-vendor/wasmtime-types-25.0.1/.cargo-checksum.json +1 -0
  494. data/ext/cargo-vendor/wasmtime-types-25.0.1/Cargo.toml +80 -0
  495. data/ext/cargo-vendor/wasmtime-types-25.0.1/src/lib.rs +1846 -0
  496. data/ext/cargo-vendor/wasmtime-versioned-export-macros-25.0.1/.cargo-checksum.json +1 -0
  497. data/ext/cargo-vendor/wasmtime-versioned-export-macros-25.0.1/Cargo.toml +41 -0
  498. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/.cargo-checksum.json +1 -0
  499. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/Cargo.toml +224 -0
  500. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/bindings.rs +563 -0
  501. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/filesystem.rs +607 -0
  502. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/host/filesystem.rs +1091 -0
  503. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/host/io.rs +372 -0
  504. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/pipe.rs +833 -0
  505. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/preview1.rs +2764 -0
  506. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/runtime.rs +188 -0
  507. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/stdio.rs +616 -0
  508. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/stream.rs +265 -0
  509. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/tcp.rs +877 -0
  510. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/src/write_stream.rs +211 -0
  511. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/tests/all/main.rs +91 -0
  512. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/tests/process_stdin.rs +165 -0
  513. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/cli/command.wit +10 -0
  514. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/cli/environment.wit +22 -0
  515. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/cli/exit.wit +17 -0
  516. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/cli/imports.wit +36 -0
  517. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/cli/run.wit +6 -0
  518. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/cli/stdio.wit +26 -0
  519. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/cli/terminal.wit +62 -0
  520. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/clocks/monotonic-clock.wit +50 -0
  521. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/clocks/timezone.wit +55 -0
  522. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/clocks/wall-clock.wit +46 -0
  523. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/clocks/world.wit +11 -0
  524. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/filesystem/preopens.wit +11 -0
  525. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/filesystem/types.wit +678 -0
  526. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/filesystem/world.wit +9 -0
  527. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/io/error.wit +34 -0
  528. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/io/poll.wit +47 -0
  529. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/io/streams.wit +286 -0
  530. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/io/world.wit +10 -0
  531. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/random/insecure-seed.wit +27 -0
  532. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/random/insecure.wit +25 -0
  533. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/random/random.wit +29 -0
  534. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/random/world.wit +13 -0
  535. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/instance-network.wit +11 -0
  536. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/ip-name-lookup.wit +56 -0
  537. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/network.wit +153 -0
  538. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/tcp-create-socket.wit +30 -0
  539. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/tcp.wit +387 -0
  540. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/udp-create-socket.wit +30 -0
  541. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/udp.wit +288 -0
  542. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/deps/sockets/world.wit +19 -0
  543. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/test.wit +13 -0
  544. data/ext/cargo-vendor/wasmtime-wasi-25.0.1/wit/world.wit +6 -0
  545. data/ext/cargo-vendor/wasmtime-winch-25.0.1/.cargo-checksum.json +1 -0
  546. data/ext/cargo-vendor/wasmtime-winch-25.0.1/Cargo.toml +100 -0
  547. data/ext/cargo-vendor/wasmtime-wit-bindgen-25.0.1/.cargo-checksum.json +1 -0
  548. data/ext/cargo-vendor/wasmtime-wit-bindgen-25.0.1/Cargo.toml +66 -0
  549. data/ext/cargo-vendor/wasmtime-wit-bindgen-25.0.1/src/lib.rs +3117 -0
  550. data/ext/cargo-vendor/wasmtime-wit-bindgen-25.0.1/src/rust.rs +427 -0
  551. data/ext/cargo-vendor/wast-217.0.0/.cargo-checksum.json +1 -0
  552. data/ext/cargo-vendor/wast-217.0.0/Cargo.toml +101 -0
  553. data/ext/cargo-vendor/wast-217.0.0/src/component/binary.rs +1014 -0
  554. data/ext/cargo-vendor/wast-217.0.0/src/component/component.rs +324 -0
  555. data/ext/cargo-vendor/wast-217.0.0/src/component/expand.rs +879 -0
  556. data/ext/cargo-vendor/wast-217.0.0/src/component/import.rs +216 -0
  557. data/ext/cargo-vendor/wast-217.0.0/src/component/resolve.rs +994 -0
  558. data/ext/cargo-vendor/wast-217.0.0/src/core/binary/dwarf.rs +613 -0
  559. data/ext/cargo-vendor/wast-217.0.0/src/core/binary.rs +1556 -0
  560. data/ext/cargo-vendor/wast-217.0.0/src/core/expr.rs +2110 -0
  561. data/ext/cargo-vendor/wast-217.0.0/src/core/module.rs +218 -0
  562. data/ext/cargo-vendor/wast-217.0.0/src/core/resolve/mod.rs +111 -0
  563. data/ext/cargo-vendor/wast-217.0.0/src/core/resolve/names.rs +808 -0
  564. data/ext/cargo-vendor/wast-217.0.0/src/core/resolve/types.rs +273 -0
  565. data/ext/cargo-vendor/wast-217.0.0/src/lexer.rs +1573 -0
  566. data/ext/cargo-vendor/wast-217.0.0/src/lib.rs +557 -0
  567. data/ext/cargo-vendor/wast-217.0.0/src/parser.rs +1447 -0
  568. data/ext/cargo-vendor/wast-217.0.0/src/wast.rs +552 -0
  569. data/ext/cargo-vendor/wast-217.0.0/src/wat.rs +66 -0
  570. data/ext/cargo-vendor/wat-1.217.0/.cargo-checksum.json +1 -0
  571. data/ext/cargo-vendor/wat-1.217.0/Cargo.toml +56 -0
  572. data/ext/cargo-vendor/wiggle-25.0.1/.cargo-checksum.json +1 -0
  573. data/ext/cargo-vendor/wiggle-25.0.1/Cargo.toml +119 -0
  574. data/ext/cargo-vendor/wiggle-25.0.1/src/lib.rs +605 -0
  575. data/ext/cargo-vendor/wiggle-generate-25.0.1/.cargo-checksum.json +1 -0
  576. data/ext/cargo-vendor/wiggle-generate-25.0.1/Cargo.toml +85 -0
  577. data/ext/cargo-vendor/wiggle-generate-25.0.1/src/funcs.rs +434 -0
  578. data/ext/cargo-vendor/wiggle-generate-25.0.1/src/lib.rs +100 -0
  579. data/ext/cargo-vendor/wiggle-generate-25.0.1/src/names.rs +299 -0
  580. data/ext/cargo-vendor/wiggle-generate-25.0.1/src/wasmtime.rs +172 -0
  581. data/ext/cargo-vendor/wiggle-macro-25.0.1/.cargo-checksum.json +1 -0
  582. data/ext/cargo-vendor/wiggle-macro-25.0.1/Cargo.toml +78 -0
  583. data/ext/cargo-vendor/winch-codegen-0.23.1/.cargo-checksum.json +1 -0
  584. data/ext/cargo-vendor/winch-codegen-0.23.1/Cargo.toml +95 -0
  585. data/ext/cargo-vendor/winch-codegen-0.23.1/src/abi/local.rs +82 -0
  586. data/ext/cargo-vendor/winch-codegen-0.23.1/src/abi/mod.rs +666 -0
  587. data/ext/cargo-vendor/winch-codegen-0.23.1/src/codegen/bounds.rs +220 -0
  588. data/ext/cargo-vendor/winch-codegen-0.23.1/src/codegen/context.rs +593 -0
  589. data/ext/cargo-vendor/winch-codegen-0.23.1/src/codegen/mod.rs +905 -0
  590. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/aarch64/abi.rs +288 -0
  591. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/aarch64/address.rs +143 -0
  592. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/aarch64/asm.rs +840 -0
  593. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/aarch64/masm.rs +680 -0
  594. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/mod.rs +320 -0
  595. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/x64/abi.rs +494 -0
  596. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/x64/asm.rs +1422 -0
  597. data/ext/cargo-vendor/winch-codegen-0.23.1/src/isa/x64/masm.rs +1113 -0
  598. data/ext/cargo-vendor/winch-codegen-0.23.1/src/masm.rs +986 -0
  599. data/ext/cargo-vendor/winch-codegen-0.23.1/src/regalloc.rs +65 -0
  600. data/ext/cargo-vendor/winch-codegen-0.23.1/src/stack.rs +447 -0
  601. data/ext/cargo-vendor/winch-codegen-0.23.1/src/visitor.rs +2169 -0
  602. data/ext/cargo-vendor/wit-parser-0.217.0/.cargo-checksum.json +1 -0
  603. data/ext/cargo-vendor/wit-parser-0.217.0/Cargo.toml +129 -0
  604. data/ext/cargo-vendor/wit-parser-0.217.0/src/ast/resolve.rs +1575 -0
  605. data/ext/cargo-vendor/wit-parser-0.217.0/src/ast.rs +1886 -0
  606. data/ext/cargo-vendor/wit-parser-0.217.0/src/decoding.rs +1794 -0
  607. data/ext/cargo-vendor/wit-parser-0.217.0/src/lib.rs +910 -0
  608. data/ext/cargo-vendor/wit-parser-0.217.0/src/sizealign.rs +584 -0
  609. data/ext/cargo-vendor/wit-parser-0.217.0/tests/all.rs +154 -0
  610. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-gate3.wit.result +5 -0
  611. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-gate4.wit.result +5 -0
  612. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-gate5.wit.result +5 -0
  613. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-pkg1.wit.result +5 -0
  614. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-pkg2.wit.result +5 -0
  615. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-pkg3.wit.result +5 -0
  616. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-pkg4.wit.result +5 -0
  617. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-pkg5.wit.result +5 -0
  618. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-pkg6.wit.result +5 -0
  619. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/bad-resource15.wit.result +5 -0
  620. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/conflicting-package.wit.result +5 -0
  621. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/duplicate-interface2.wit.result +5 -0
  622. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/include-foreign.wit.result +5 -0
  623. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/multi-file-missing-delimiter.wit.result +5 -0
  624. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/multi-package-deps-share-nest.wit.result +3 -0
  625. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/multiple-package-docs.wit.result +5 -0
  626. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +5 -0
  627. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/non-existance-world-include.wit.result +5 -0
  628. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/pkg-cycle.wit.result +5 -0
  629. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/pkg-cycle2.wit.result +5 -0
  630. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/resources-multiple-returns-borrow.wit.result +5 -0
  631. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/resources-return-borrow.wit.result +5 -0
  632. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/return-borrow1.wit.result +5 -0
  633. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/return-borrow2.wit.result +5 -0
  634. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/return-borrow6.wit.result +5 -0
  635. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/return-borrow7.wit.result +5 -0
  636. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/return-borrow8.wit.result +5 -0
  637. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/type-and-resource-same-name.wit.result +5 -0
  638. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/unresolved-use10.wit.result +5 -0
  639. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/use-and-include-world.wit.result +5 -0
  640. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/use-world.wit.result +5 -0
  641. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/parse-fail/very-nested-packages.wit.result +5 -0
  642. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/since-and-unstable.wit +107 -0
  643. data/ext/cargo-vendor/wit-parser-0.217.0/tests/ui/since-and-unstable.wit.json +621 -0
  644. data/ext/src/ruby_api/config.rs +3 -0
  645. data/ext/src/ruby_api/convert.rs +17 -2
  646. data/ext/src/ruby_api/engine.rs +2 -1
  647. data/ext/src/ruby_api/externals.rs +112 -2
  648. data/ext/src/ruby_api/func.rs +57 -0
  649. data/ext/src/ruby_api/global.rs +56 -3
  650. data/ext/src/ruby_api/memory.rs +43 -0
  651. data/ext/src/ruby_api/module.rs +29 -3
  652. data/ext/src/ruby_api/pooling_allocation_config.rs +7 -7
  653. data/ext/src/ruby_api/store.rs +58 -4
  654. data/ext/src/ruby_api/table.rs +49 -3
  655. data/ext/src/ruby_api/wasi_ctx.rs +6 -6
  656. data/lib/wasmtime/version.rb +1 -1
  657. metadata +1808 -1804
  658. data/ext/cargo-vendor/cranelift-bforest-0.111.0/.cargo-checksum.json +0 -1
  659. data/ext/cargo-vendor/cranelift-bforest-0.111.0/Cargo.toml +0 -57
  660. data/ext/cargo-vendor/cranelift-bforest-0.111.0/src/node.rs +0 -806
  661. data/ext/cargo-vendor/cranelift-bforest-0.111.0/src/path.rs +0 -835
  662. data/ext/cargo-vendor/cranelift-bforest-0.111.0/src/pool.rs +0 -219
  663. data/ext/cargo-vendor/cranelift-bitset-0.111.0/.cargo-checksum.json +0 -1
  664. data/ext/cargo-vendor/cranelift-bitset-0.111.0/Cargo.toml +0 -67
  665. data/ext/cargo-vendor/cranelift-bitset-0.111.0/src/scalar.rs +0 -575
  666. data/ext/cargo-vendor/cranelift-codegen-0.111.0/.cargo-checksum.json +0 -1
  667. data/ext/cargo-vendor/cranelift-codegen-0.111.0/Cargo.toml +0 -213
  668. data/ext/cargo-vendor/cranelift-codegen-0.111.0/build.rs +0 -266
  669. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/binemit/mod.rs +0 -171
  670. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/binemit/stack_map.rs +0 -141
  671. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/cfg_printer.rs +0 -83
  672. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/data_value.rs +0 -410
  673. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/dbg.rs +0 -28
  674. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/egraph.rs +0 -835
  675. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/incremental_cache.rs +0 -256
  676. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/inst_predicates.rs +0 -231
  677. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/constant.rs +0 -489
  678. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/dfg.rs +0 -1806
  679. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/entities.rs +0 -564
  680. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/extfunc.rs +0 -408
  681. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/extname.rs +0 -333
  682. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/function.rs +0 -500
  683. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/globalvalue.rs +0 -147
  684. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/immediates.rs +0 -1941
  685. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/instructions.rs +0 -1026
  686. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/memtype.rs +0 -190
  687. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/progpoint.rs +0 -75
  688. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/trapcode.rs +0 -148
  689. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/types.rs +0 -643
  690. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/ir/user_stack_maps.rs +0 -101
  691. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/abi.rs +0 -1548
  692. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst/args.rs +0 -711
  693. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst/emit.rs +0 -3599
  694. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst/emit_tests.rs +0 -7925
  695. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst/imms.rs +0 -1213
  696. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst/mod.rs +0 -3052
  697. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst/regs.rs +0 -269
  698. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst/unwind/systemv.rs +0 -174
  699. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/inst.isle +0 -4221
  700. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/lower/isle.rs +0 -807
  701. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/lower.isle +0 -2969
  702. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/pcc.rs +0 -568
  703. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/aarch64/settings.rs +0 -9
  704. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/mod.rs +0 -462
  705. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/abi.rs +0 -1021
  706. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst/args.rs +0 -2054
  707. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst/emit.rs +0 -2736
  708. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst/emit_tests.rs +0 -2219
  709. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst/encode.rs +0 -675
  710. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst/mod.rs +0 -1932
  711. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst/unwind/systemv.rs +0 -170
  712. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst/vector.rs +0 -1150
  713. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst.isle +0 -3153
  714. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/inst_vector.isle +0 -1907
  715. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/lower/isle.rs +0 -651
  716. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/riscv64/lower.isle +0 -2953
  717. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/abi.rs +0 -1357
  718. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/inst/emit.rs +0 -3481
  719. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/inst/emit_tests.rs +0 -13388
  720. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/inst/mod.rs +0 -3481
  721. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/inst/regs.rs +0 -169
  722. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/inst/unwind/systemv.rs +0 -212
  723. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/inst.isle +0 -5070
  724. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/lower/isle.rs +0 -1156
  725. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/s390x/lower.isle +0 -4022
  726. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/unwind/systemv.rs +0 -276
  727. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/abi.rs +0 -1410
  728. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/encoding/evex.rs +0 -748
  729. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst/args.rs +0 -2318
  730. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst/emit.rs +0 -4309
  731. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst/emit_state.rs +0 -65
  732. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst/emit_tests.rs +0 -5137
  733. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst/mod.rs +0 -2819
  734. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst/regs.rs +0 -275
  735. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst/unwind/systemv.rs +0 -198
  736. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/inst.isle +0 -5381
  737. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/lower/isle.rs +0 -1048
  738. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/lower.isle +0 -4892
  739. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/lower.rs +0 -339
  740. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/mod.rs +0 -239
  741. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isa/x64/pcc.rs +0 -1014
  742. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/isle_prelude.rs +0 -1097
  743. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/lib.rs +0 -106
  744. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/machinst/abi.rs +0 -2411
  745. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/machinst/buffer.rs +0 -2537
  746. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/machinst/isle.rs +0 -881
  747. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/machinst/lower.rs +0 -1462
  748. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/machinst/mod.rs +0 -564
  749. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/machinst/reg.rs +0 -479
  750. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/machinst/vcode.rs +0 -1840
  751. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/opts/extends.isle +0 -91
  752. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/opts/icmp.isle +0 -215
  753. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/opts/selects.isle +0 -77
  754. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/prelude.isle +0 -725
  755. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/prelude_lower.isle +0 -1074
  756. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/print_errors.rs +0 -223
  757. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/remove_constant_phis.rs +0 -419
  758. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/result.rs +0 -111
  759. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/settings.rs +0 -590
  760. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/timing.rs +0 -296
  761. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/verifier/mod.rs +0 -1963
  762. data/ext/cargo-vendor/cranelift-codegen-0.111.0/src/write.rs +0 -694
  763. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/.cargo-checksum.json +0 -1
  764. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/Cargo.toml +0 -52
  765. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/cdsl/settings.rs +0 -429
  766. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/cdsl/types.rs +0 -512
  767. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/cdsl/typevar.rs +0 -980
  768. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/error.rs +0 -48
  769. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/gen_inst.rs +0 -1278
  770. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/gen_isle.rs +0 -519
  771. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/gen_settings.rs +0 -508
  772. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/gen_types.rs +0 -75
  773. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/isa/arm64.rs +0 -53
  774. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/isa/mod.rs +0 -66
  775. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/isa/riscv64.rs +0 -174
  776. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/isa/x86.rs +0 -414
  777. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/isle.rs +0 -126
  778. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/lib.rs +0 -98
  779. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/shared/instructions.rs +0 -3794
  780. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/shared/mod.rs +0 -87
  781. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/shared/settings.rs +0 -348
  782. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/shared/types.rs +0 -143
  783. data/ext/cargo-vendor/cranelift-codegen-meta-0.111.0/src/srcgen.rs +0 -464
  784. data/ext/cargo-vendor/cranelift-codegen-shared-0.111.0/.cargo-checksum.json +0 -1
  785. data/ext/cargo-vendor/cranelift-codegen-shared-0.111.0/Cargo.toml +0 -31
  786. data/ext/cargo-vendor/cranelift-control-0.111.0/.cargo-checksum.json +0 -1
  787. data/ext/cargo-vendor/cranelift-control-0.111.0/Cargo.toml +0 -42
  788. data/ext/cargo-vendor/cranelift-entity-0.111.0/.cargo-checksum.json +0 -1
  789. data/ext/cargo-vendor/cranelift-entity-0.111.0/Cargo.toml +0 -73
  790. data/ext/cargo-vendor/cranelift-entity-0.111.0/src/lib.rs +0 -381
  791. data/ext/cargo-vendor/cranelift-entity-0.111.0/src/packed_option.rs +0 -171
  792. data/ext/cargo-vendor/cranelift-entity-0.111.0/src/sparse.rs +0 -367
  793. data/ext/cargo-vendor/cranelift-frontend-0.111.0/.cargo-checksum.json +0 -1
  794. data/ext/cargo-vendor/cranelift-frontend-0.111.0/Cargo.toml +0 -97
  795. data/ext/cargo-vendor/cranelift-frontend-0.111.0/src/frontend.rs +0 -1977
  796. data/ext/cargo-vendor/cranelift-frontend-0.111.0/src/ssa.rs +0 -1328
  797. data/ext/cargo-vendor/cranelift-frontend-0.111.0/src/switch.rs +0 -683
  798. data/ext/cargo-vendor/cranelift-isle-0.111.0/.cargo-checksum.json +0 -1
  799. data/ext/cargo-vendor/cranelift-isle-0.111.0/Cargo.toml +0 -67
  800. data/ext/cargo-vendor/cranelift-isle-0.111.0/build.rs +0 -35
  801. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/ast.rs +0 -421
  802. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/codegen.rs +0 -920
  803. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/compile.rs +0 -24
  804. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/error.rs +0 -317
  805. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/lexer.rs +0 -405
  806. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/lib.rs +0 -33
  807. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/overlap.rs +0 -137
  808. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/parser.rs +0 -562
  809. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/sema.rs +0 -2503
  810. data/ext/cargo-vendor/cranelift-isle-0.111.0/src/trie_again.rs +0 -695
  811. data/ext/cargo-vendor/cranelift-isle-0.111.0/tests/run_tests.rs +0 -77
  812. data/ext/cargo-vendor/cranelift-native-0.111.0/.cargo-checksum.json +0 -1
  813. data/ext/cargo-vendor/cranelift-native-0.111.0/Cargo.toml +0 -52
  814. data/ext/cargo-vendor/cranelift-native-0.111.0/src/lib.rs +0 -188
  815. data/ext/cargo-vendor/cranelift-wasm-0.111.0/.cargo-checksum.json +0 -1
  816. data/ext/cargo-vendor/cranelift-wasm-0.111.0/Cargo.toml +0 -127
  817. data/ext/cargo-vendor/cranelift-wasm-0.111.0/src/code_translator.rs +0 -3721
  818. data/ext/cargo-vendor/cranelift-wasm-0.111.0/src/environ/dummy.rs +0 -906
  819. data/ext/cargo-vendor/cranelift-wasm-0.111.0/src/environ/spec.rs +0 -945
  820. data/ext/cargo-vendor/cranelift-wasm-0.111.0/src/func_translator.rs +0 -271
  821. data/ext/cargo-vendor/cranelift-wasm-0.111.0/src/module_translator.rs +0 -120
  822. data/ext/cargo-vendor/cranelift-wasm-0.111.0/src/sections_translator.rs +0 -333
  823. data/ext/cargo-vendor/cranelift-wasm-0.111.0/src/translation_utils.rs +0 -91
  824. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.24/.cargo-checksum.json +0 -1
  825. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.24/Cargo.toml +0 -48
  826. data/ext/cargo-vendor/hashbrown-0.13.2/.cargo-checksum.json +0 -1
  827. data/ext/cargo-vendor/hashbrown-0.13.2/CHANGELOG.md +0 -437
  828. data/ext/cargo-vendor/hashbrown-0.13.2/Cargo.toml +0 -111
  829. data/ext/cargo-vendor/hashbrown-0.13.2/LICENSE-APACHE +0 -201
  830. data/ext/cargo-vendor/hashbrown-0.13.2/LICENSE-MIT +0 -25
  831. data/ext/cargo-vendor/hashbrown-0.13.2/README.md +0 -124
  832. data/ext/cargo-vendor/hashbrown-0.13.2/benches/bench.rs +0 -331
  833. data/ext/cargo-vendor/hashbrown-0.13.2/benches/insert_unique_unchecked.rs +0 -32
  834. data/ext/cargo-vendor/hashbrown-0.13.2/clippy.toml +0 -1
  835. data/ext/cargo-vendor/hashbrown-0.13.2/src/external_trait_impls/mod.rs +0 -4
  836. data/ext/cargo-vendor/hashbrown-0.13.2/src/external_trait_impls/rayon/helpers.rs +0 -27
  837. data/ext/cargo-vendor/hashbrown-0.13.2/src/external_trait_impls/rayon/map.rs +0 -734
  838. data/ext/cargo-vendor/hashbrown-0.13.2/src/external_trait_impls/rayon/mod.rs +0 -4
  839. data/ext/cargo-vendor/hashbrown-0.13.2/src/external_trait_impls/rayon/raw.rs +0 -231
  840. data/ext/cargo-vendor/hashbrown-0.13.2/src/external_trait_impls/rayon/set.rs +0 -659
  841. data/ext/cargo-vendor/hashbrown-0.13.2/src/external_trait_impls/serde.rs +0 -201
  842. data/ext/cargo-vendor/hashbrown-0.13.2/src/lib.rs +0 -183
  843. data/ext/cargo-vendor/hashbrown-0.13.2/src/macros.rs +0 -70
  844. data/ext/cargo-vendor/hashbrown-0.13.2/src/map.rs +0 -8512
  845. data/ext/cargo-vendor/hashbrown-0.13.2/src/raw/alloc.rs +0 -73
  846. data/ext/cargo-vendor/hashbrown-0.13.2/src/raw/bitmask.rs +0 -122
  847. data/ext/cargo-vendor/hashbrown-0.13.2/src/raw/generic.rs +0 -154
  848. data/ext/cargo-vendor/hashbrown-0.13.2/src/raw/mod.rs +0 -2518
  849. data/ext/cargo-vendor/hashbrown-0.13.2/src/raw/sse2.rs +0 -146
  850. data/ext/cargo-vendor/hashbrown-0.13.2/src/rustc_entry.rs +0 -630
  851. data/ext/cargo-vendor/hashbrown-0.13.2/src/scopeguard.rs +0 -72
  852. data/ext/cargo-vendor/hashbrown-0.13.2/src/set.rs +0 -2889
  853. data/ext/cargo-vendor/hashbrown-0.13.2/tests/equivalent_trait.rs +0 -53
  854. data/ext/cargo-vendor/hashbrown-0.13.2/tests/hasher.rs +0 -65
  855. data/ext/cargo-vendor/hashbrown-0.13.2/tests/raw.rs +0 -11
  856. data/ext/cargo-vendor/hashbrown-0.13.2/tests/rayon.rs +0 -533
  857. data/ext/cargo-vendor/hashbrown-0.13.2/tests/serde.rs +0 -65
  858. data/ext/cargo-vendor/hashbrown-0.13.2/tests/set.rs +0 -34
  859. data/ext/cargo-vendor/regalloc2-0.9.3/.cargo-checksum.json +0 -1
  860. data/ext/cargo-vendor/regalloc2-0.9.3/Cargo.toml +0 -72
  861. data/ext/cargo-vendor/regalloc2-0.9.3/doc/DESIGN.md +0 -1420
  862. data/ext/cargo-vendor/regalloc2-0.9.3/src/cfg.rs +0 -134
  863. data/ext/cargo-vendor/regalloc2-0.9.3/src/checker.rs +0 -1089
  864. data/ext/cargo-vendor/regalloc2-0.9.3/src/fuzzing/func.rs +0 -677
  865. data/ext/cargo-vendor/regalloc2-0.9.3/src/fuzzing/mod.rs +0 -28
  866. data/ext/cargo-vendor/regalloc2-0.9.3/src/index.rs +0 -268
  867. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/data_structures.rs +0 -857
  868. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/liveranges.rs +0 -961
  869. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/merge.rs +0 -383
  870. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/mod.rs +0 -150
  871. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/moves.rs +0 -1017
  872. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/process.rs +0 -1307
  873. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/requirement.rs +0 -174
  874. data/ext/cargo-vendor/regalloc2-0.9.3/src/ion/stackmap.rs +0 -79
  875. data/ext/cargo-vendor/regalloc2-0.9.3/src/lib.rs +0 -1526
  876. data/ext/cargo-vendor/regalloc2-0.9.3/src/serialize.rs +0 -311
  877. data/ext/cargo-vendor/wasi-common-24.0.0/.cargo-checksum.json +0 -1
  878. data/ext/cargo-vendor/wasi-common-24.0.0/Cargo.toml +0 -240
  879. data/ext/cargo-vendor/wasi-common-24.0.0/src/ctx.rs +0 -128
  880. data/ext/cargo-vendor/wasi-common-24.0.0/src/lib.rs +0 -193
  881. data/ext/cargo-vendor/wasi-common-24.0.0/src/snapshots/mod.rs +0 -27
  882. data/ext/cargo-vendor/wasi-common-24.0.0/src/sync/dir.rs +0 -462
  883. data/ext/cargo-vendor/wasi-common-24.0.0/src/tokio/dir.rs +0 -221
  884. data/ext/cargo-vendor/wasi-common-24.0.0/tests/all/async_.rs +0 -295
  885. data/ext/cargo-vendor/wasi-common-24.0.0/tests/all/main.rs +0 -21
  886. data/ext/cargo-vendor/wasi-common-24.0.0/tests/all/sync.rs +0 -284
  887. data/ext/cargo-vendor/wasm-encoder-0.215.0/.cargo-checksum.json +0 -1
  888. data/ext/cargo-vendor/wasm-encoder-0.215.0/Cargo.toml +0 -65
  889. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/builder.rs +0 -455
  890. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/exports.rs +0 -124
  891. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/imports.rs +0 -175
  892. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/instances.rs +0 -200
  893. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/names.rs +0 -149
  894. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/types.rs +0 -802
  895. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/code.rs +0 -3947
  896. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/names.rs +0 -298
  897. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/types.rs +0 -678
  898. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/reencode.rs +0 -2002
  899. data/ext/cargo-vendor/wasm-encoder-0.216.0/.cargo-checksum.json +0 -1
  900. data/ext/cargo-vendor/wasm-encoder-0.216.0/Cargo.toml +0 -65
  901. data/ext/cargo-vendor/wasm-encoder-0.216.0/README.md +0 -80
  902. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/aliases.rs +0 -160
  903. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/builder.rs +0 -455
  904. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/canonicals.rs +0 -159
  905. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/components.rs +0 -29
  906. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/exports.rs +0 -124
  907. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/imports.rs +0 -175
  908. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/instances.rs +0 -200
  909. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/modules.rs +0 -29
  910. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/start.rs +0 -52
  911. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component/types.rs +0 -802
  912. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/component.rs +0 -168
  913. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/code.rs +0 -3947
  914. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/custom.rs +0 -73
  915. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/data.rs +0 -186
  916. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/dump.rs +0 -627
  917. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/elements.rs +0 -222
  918. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/exports.rs +0 -85
  919. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/functions.rs +0 -63
  920. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/globals.rs +0 -100
  921. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/imports.rs +0 -143
  922. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/linking.rs +0 -263
  923. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/memories.rs +0 -115
  924. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/producers.rs +0 -181
  925. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/start.rs +0 -39
  926. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/tables.rs +0 -129
  927. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core/tags.rs +0 -85
  928. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/core.rs +0 -168
  929. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/lib.rs +0 -218
  930. data/ext/cargo-vendor/wasm-encoder-0.216.0/src/raw.rs +0 -30
  931. data/ext/cargo-vendor/wasmparser-0.215.0/.cargo-checksum.json +0 -1
  932. data/ext/cargo-vendor/wasmparser-0.215.0/Cargo.lock +0 -669
  933. data/ext/cargo-vendor/wasmparser-0.215.0/Cargo.toml +0 -137
  934. data/ext/cargo-vendor/wasmparser-0.215.0/benches/benchmark.rs +0 -349
  935. data/ext/cargo-vendor/wasmparser-0.215.0/src/binary_reader.rs +0 -2064
  936. data/ext/cargo-vendor/wasmparser-0.215.0/src/features.rs +0 -175
  937. data/ext/cargo-vendor/wasmparser-0.215.0/src/limits.rs +0 -80
  938. data/ext/cargo-vendor/wasmparser-0.215.0/src/parser.rs +0 -1682
  939. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/component/aliases.rs +0 -119
  940. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/component/canonicals.rs +0 -121
  941. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/component/exports.rs +0 -135
  942. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/component/imports.rs +0 -130
  943. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/component/instances.rs +0 -166
  944. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/component/types.rs +0 -553
  945. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/code.rs +0 -142
  946. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/coredumps.rs +0 -278
  947. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/data.rs +0 -96
  948. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/exports.rs +0 -65
  949. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/globals.rs +0 -61
  950. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/imports.rs +0 -76
  951. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/init.rs +0 -57
  952. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/operators.rs +0 -479
  953. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/producers.rs +0 -84
  954. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers/core/types.rs +0 -1964
  955. data/ext/cargo-vendor/wasmparser-0.215.0/src/readers.rs +0 -315
  956. data/ext/cargo-vendor/wasmparser-0.215.0/src/resources.rs +0 -234
  957. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator/component.rs +0 -3277
  958. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator/core/canonical.rs +0 -233
  959. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator/core.rs +0 -1499
  960. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator/func.rs +0 -334
  961. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator/names.rs +0 -1016
  962. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator/operators.rs +0 -4716
  963. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator/types.rs +0 -4592
  964. data/ext/cargo-vendor/wasmparser-0.215.0/src/validator.rs +0 -1643
  965. data/ext/cargo-vendor/wasmprinter-0.215.0/.cargo-checksum.json +0 -1
  966. data/ext/cargo-vendor/wasmprinter-0.215.0/Cargo.toml +0 -74
  967. data/ext/cargo-vendor/wasmprinter-0.215.0/src/lib.rs +0 -3242
  968. data/ext/cargo-vendor/wasmtime-24.0.0/.cargo-checksum.json +0 -1
  969. data/ext/cargo-vendor/wasmtime-24.0.0/Cargo.toml +0 -406
  970. data/ext/cargo-vendor/wasmtime-24.0.0/build.rs +0 -38
  971. data/ext/cargo-vendor/wasmtime-24.0.0/src/compile/code_builder.rs +0 -274
  972. data/ext/cargo-vendor/wasmtime-24.0.0/src/compile/runtime.rs +0 -167
  973. data/ext/cargo-vendor/wasmtime-24.0.0/src/compile.rs +0 -881
  974. data/ext/cargo-vendor/wasmtime-24.0.0/src/config.rs +0 -2875
  975. data/ext/cargo-vendor/wasmtime-24.0.0/src/engine/serialization.rs +0 -902
  976. data/ext/cargo-vendor/wasmtime-24.0.0/src/engine.rs +0 -765
  977. data/ext/cargo-vendor/wasmtime-24.0.0/src/lib.rs +0 -406
  978. data/ext/cargo-vendor/wasmtime-24.0.0/src/profiling_agent/jitdump.rs +0 -64
  979. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/component/component.rs +0 -811
  980. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/component/func/host.rs +0 -439
  981. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/component/func/typed.rs +0 -2497
  982. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/component/linker.rs +0 -673
  983. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/component/mod.rs +0 -663
  984. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/component/resources.rs +0 -1132
  985. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/component/types.rs +0 -897
  986. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/coredump.rs +0 -339
  987. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/externals/global.rs +0 -310
  988. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/externals/table.rs +0 -480
  989. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/func.rs +0 -2598
  990. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/gc/disabled/anyref.rs +0 -77
  991. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/gc/disabled/rooting.rs +0 -229
  992. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/gc/disabled.rs +0 -21
  993. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/gc/enabled/anyref.rs +0 -584
  994. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/gc/enabled/i31.rs +0 -299
  995. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/gc/enabled/rooting.rs +0 -1755
  996. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/gc/enabled.rs +0 -14
  997. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/instance.rs +0 -990
  998. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/linker.rs +0 -1498
  999. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/memory.rs +0 -1101
  1000. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/module.rs +0 -1179
  1001. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/store.rs +0 -2885
  1002. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/trampoline/global.rs +0 -68
  1003. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/trap.rs +0 -642
  1004. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/types.rs +0 -2868
  1005. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/values.rs +0 -1016
  1006. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/const_expr.rs +0 -102
  1007. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/cow.rs +0 -988
  1008. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/gc/disabled.rs +0 -39
  1009. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/gc/enabled/drc.rs +0 -1113
  1010. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/gc/enabled/structref.rs +0 -481
  1011. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/gc/enabled.rs +0 -20
  1012. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/gc/gc_ref.rs +0 -502
  1013. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/gc/gc_runtime.rs +0 -651
  1014. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/gc.rs +0 -303
  1015. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/helpers.c +0 -113
  1016. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/instance/allocator/pooling/gc_heap_pool.rs +0 -93
  1017. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/instance/allocator/pooling/index_allocator.rs +0 -703
  1018. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/libcalls.rs +0 -832
  1019. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/sys/custom/traphandlers.rs +0 -60
  1020. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/sys/unix/machports.rs +0 -445
  1021. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/sys/unix/mmap.rs +0 -159
  1022. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/sys/unix/signals.rs +0 -464
  1023. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/sys/windows/traphandlers.rs +0 -133
  1024. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/threads/parking_spot.rs +0 -623
  1025. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/traphandlers.rs +0 -783
  1026. data/ext/cargo-vendor/wasmtime-24.0.0/src/runtime/vm/vmcontext.rs +0 -1246
  1027. data/ext/cargo-vendor/wasmtime-asm-macros-24.0.0/.cargo-checksum.json +0 -1
  1028. data/ext/cargo-vendor/wasmtime-asm-macros-24.0.0/Cargo.toml +0 -32
  1029. data/ext/cargo-vendor/wasmtime-cache-24.0.0/.cargo-checksum.json +0 -1
  1030. data/ext/cargo-vendor/wasmtime-cache-24.0.0/Cargo.toml +0 -110
  1031. data/ext/cargo-vendor/wasmtime-cache-24.0.0/build.rs +0 -10
  1032. data/ext/cargo-vendor/wasmtime-cache-24.0.0/src/config.rs +0 -584
  1033. data/ext/cargo-vendor/wasmtime-cache-24.0.0/src/lib.rs +0 -235
  1034. data/ext/cargo-vendor/wasmtime-cache-24.0.0/src/worker/tests.rs +0 -758
  1035. data/ext/cargo-vendor/wasmtime-cache-24.0.0/src/worker.rs +0 -890
  1036. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/.cargo-checksum.json +0 -1
  1037. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/Cargo.toml +0 -113
  1038. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/src/bindgen.rs +0 -500
  1039. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/src/component.rs +0 -1330
  1040. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/codegen.rs +0 -698
  1041. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/char.rs +0 -268
  1042. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/char_async.rs +0 -291
  1043. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/conventions.rs +0 -706
  1044. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/conventions_async.rs +0 -757
  1045. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/dead-code.rs +0 -194
  1046. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/dead-code_async.rs +0 -213
  1047. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/direct-import.rs +0 -120
  1048. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/direct-import_async.rs +0 -132
  1049. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/empty.rs +0 -74
  1050. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/empty_async.rs +0 -80
  1051. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/flags.rs +0 -743
  1052. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/flags_async.rs +0 -791
  1053. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/floats.rs +0 -343
  1054. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/floats_async.rs +0 -376
  1055. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/function-new.rs +0 -94
  1056. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/function-new_async.rs +0 -103
  1057. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/integers.rs +0 -873
  1058. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/integers_async.rs +0 -976
  1059. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/lists.rs +0 -1924
  1060. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/lists_async.rs +0 -2114
  1061. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/many-arguments.rs +0 -614
  1062. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/many-arguments_async.rs +0 -638
  1063. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/multi-return.rs +0 -357
  1064. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/multi-return_async.rs +0 -391
  1065. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/multiversion.rs +0 -354
  1066. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/multiversion_async.rs +0 -379
  1067. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/records.rs +0 -940
  1068. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/records_async.rs +0 -1008
  1069. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/rename.rs +0 -183
  1070. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/rename_async.rs +0 -202
  1071. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/resources-export.rs +0 -657
  1072. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/resources-export_async.rs +0 -712
  1073. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/resources-import.rs +0 -1088
  1074. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/resources-import_async.rs +0 -1166
  1075. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/share-types.rs +0 -315
  1076. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/share-types_async.rs +0 -337
  1077. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/simple-functions.rs +0 -399
  1078. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/simple-functions_async.rs +0 -439
  1079. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/simple-lists.rs +0 -427
  1080. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/simple-lists_async.rs +0 -464
  1081. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/simple-wasi.rs +0 -245
  1082. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/simple-wasi_async.rs +0 -264
  1083. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/small-anonymous.rs +0 -338
  1084. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/small-anonymous_async.rs +0 -356
  1085. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/smoke-default.rs +0 -94
  1086. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/smoke-default_async.rs +0 -103
  1087. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/smoke-export.rs +0 -149
  1088. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/smoke-export_async.rs +0 -158
  1089. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/smoke.rs +0 -133
  1090. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/smoke_async.rs +0 -146
  1091. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/strings.rs +0 -316
  1092. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/strings_async.rs +0 -344
  1093. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/unversioned-foo.rs +0 -165
  1094. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/unversioned-foo_async.rs +0 -178
  1095. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/use-paths.rs +0 -317
  1096. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/use-paths_async.rs +0 -349
  1097. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/variants.rs +0 -1896
  1098. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/variants_async.rs +0 -2019
  1099. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/wat.rs +0 -145
  1100. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/wat_async.rs +0 -151
  1101. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/worlds-with-types.rs +0 -175
  1102. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded/worlds-with-types_async.rs +0 -191
  1103. data/ext/cargo-vendor/wasmtime-component-macro-24.0.0/tests/expanded.rs +0 -65
  1104. data/ext/cargo-vendor/wasmtime-component-util-24.0.0/.cargo-checksum.json +0 -1
  1105. data/ext/cargo-vendor/wasmtime-component-util-24.0.0/Cargo.toml +0 -35
  1106. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/.cargo-checksum.json +0 -1
  1107. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/Cargo.toml +0 -132
  1108. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/compiler.rs +0 -1029
  1109. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/debug/transform/attr.rs +0 -328
  1110. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/debug/transform/line_program.rs +0 -287
  1111. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/debug/transform/mod.rs +0 -273
  1112. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/debug/transform/range_info_builder.rs +0 -234
  1113. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/debug/transform/simulate.rs +0 -423
  1114. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/debug/transform/unit.rs +0 -520
  1115. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/func_environ.rs +0 -2721
  1116. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/gc/enabled.rs +0 -648
  1117. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/gc.rs +0 -198
  1118. data/ext/cargo-vendor/wasmtime-cranelift-24.0.0/src/lib.rs +0 -431
  1119. data/ext/cargo-vendor/wasmtime-environ-24.0.0/.cargo-checksum.json +0 -1
  1120. data/ext/cargo-vendor/wasmtime-environ-24.0.0/Cargo.lock +0 -792
  1121. data/ext/cargo-vendor/wasmtime-environ-24.0.0/Cargo.toml +0 -192
  1122. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/builtin.rs +0 -184
  1123. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/compile/mod.rs +0 -379
  1124. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/compile/module_environ.rs +0 -1264
  1125. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/component/types.rs +0 -1041
  1126. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/demangling.rs +0 -28
  1127. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/fact/trampoline.rs +0 -3234
  1128. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/fact/traps.rs +0 -116
  1129. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/stack_map.rs +0 -31
  1130. data/ext/cargo-vendor/wasmtime-environ-24.0.0/src/trap_encoding.rs +0 -189
  1131. data/ext/cargo-vendor/wasmtime-fiber-24.0.0/.cargo-checksum.json +0 -1
  1132. data/ext/cargo-vendor/wasmtime-fiber-24.0.0/Cargo.toml +0 -82
  1133. data/ext/cargo-vendor/wasmtime-fiber-24.0.0/build.rs +0 -39
  1134. data/ext/cargo-vendor/wasmtime-fiber-24.0.0/src/lib.rs +0 -343
  1135. data/ext/cargo-vendor/wasmtime-jit-debug-24.0.0/.cargo-checksum.json +0 -1
  1136. data/ext/cargo-vendor/wasmtime-jit-debug-24.0.0/Cargo.toml +0 -84
  1137. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-24.0.0/.cargo-checksum.json +0 -1
  1138. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-24.0.0/Cargo.toml +0 -69
  1139. data/ext/cargo-vendor/wasmtime-slab-24.0.0/.cargo-checksum.json +0 -1
  1140. data/ext/cargo-vendor/wasmtime-slab-24.0.0/Cargo.toml +0 -48
  1141. data/ext/cargo-vendor/wasmtime-types-24.0.0/.cargo-checksum.json +0 -1
  1142. data/ext/cargo-vendor/wasmtime-types-24.0.0/Cargo.toml +0 -78
  1143. data/ext/cargo-vendor/wasmtime-types-24.0.0/src/lib.rs +0 -1835
  1144. data/ext/cargo-vendor/wasmtime-versioned-export-macros-24.0.0/.cargo-checksum.json +0 -1
  1145. data/ext/cargo-vendor/wasmtime-versioned-export-macros-24.0.0/Cargo.toml +0 -40
  1146. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/.cargo-checksum.json +0 -1
  1147. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/Cargo.toml +0 -222
  1148. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/bindings.rs +0 -561
  1149. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/filesystem.rs +0 -448
  1150. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/host/filesystem.rs +0 -1091
  1151. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/host/io.rs +0 -391
  1152. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/pipe.rs +0 -826
  1153. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/preview1.rs +0 -2801
  1154. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/runtime.rs +0 -176
  1155. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/stdio.rs +0 -596
  1156. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/stream.rs +0 -181
  1157. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/tcp.rs +0 -871
  1158. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/src/write_stream.rs +0 -203
  1159. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/tests/all/main.rs +0 -91
  1160. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/tests/process_stdin.rs +0 -165
  1161. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/command-extended.wit +0 -6
  1162. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/cli/command.wit +0 -7
  1163. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/cli/environment.wit +0 -18
  1164. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/cli/exit.wit +0 -4
  1165. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/cli/imports.wit +0 -20
  1166. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/cli/run.wit +0 -4
  1167. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/cli/stdio.wit +0 -17
  1168. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/cli/terminal.wit +0 -49
  1169. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/clocks/monotonic-clock.wit +0 -45
  1170. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/clocks/wall-clock.wit +0 -42
  1171. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/clocks/world.wit +0 -6
  1172. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/filesystem/preopens.wit +0 -8
  1173. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/filesystem/types.wit +0 -634
  1174. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/filesystem/world.wit +0 -6
  1175. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/http/handler.wit +0 -43
  1176. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/http/proxy.wit +0 -32
  1177. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/http/types.wit +0 -570
  1178. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/io/error.wit +0 -34
  1179. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/io/poll.wit +0 -41
  1180. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/io/streams.wit +0 -262
  1181. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/io/world.wit +0 -6
  1182. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/random/insecure-seed.wit +0 -25
  1183. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/random/insecure.wit +0 -22
  1184. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/random/random.wit +0 -26
  1185. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/random/world.wit +0 -7
  1186. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/instance-network.wit +0 -9
  1187. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/ip-name-lookup.wit +0 -51
  1188. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/network.wit +0 -145
  1189. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/tcp-create-socket.wit +0 -27
  1190. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/tcp.wit +0 -353
  1191. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/udp-create-socket.wit +0 -27
  1192. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/udp.wit +0 -266
  1193. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/deps/sockets/world.wit +0 -11
  1194. data/ext/cargo-vendor/wasmtime-wasi-24.0.0/wit/test.wit +0 -22
  1195. data/ext/cargo-vendor/wasmtime-winch-24.0.0/.cargo-checksum.json +0 -1
  1196. data/ext/cargo-vendor/wasmtime-winch-24.0.0/Cargo.toml +0 -99
  1197. data/ext/cargo-vendor/wasmtime-wit-bindgen-24.0.0/.cargo-checksum.json +0 -1
  1198. data/ext/cargo-vendor/wasmtime-wit-bindgen-24.0.0/Cargo.toml +0 -64
  1199. data/ext/cargo-vendor/wasmtime-wit-bindgen-24.0.0/src/lib.rs +0 -2798
  1200. data/ext/cargo-vendor/wasmtime-wit-bindgen-24.0.0/src/rust.rs +0 -427
  1201. data/ext/cargo-vendor/wast-216.0.0/.cargo-checksum.json +0 -1
  1202. data/ext/cargo-vendor/wast-216.0.0/Cargo.toml +0 -101
  1203. data/ext/cargo-vendor/wast-216.0.0/src/component/binary.rs +0 -1014
  1204. data/ext/cargo-vendor/wast-216.0.0/src/component/component.rs +0 -320
  1205. data/ext/cargo-vendor/wast-216.0.0/src/component/expand.rs +0 -875
  1206. data/ext/cargo-vendor/wast-216.0.0/src/component/import.rs +0 -215
  1207. data/ext/cargo-vendor/wast-216.0.0/src/component/resolve.rs +0 -988
  1208. data/ext/cargo-vendor/wast-216.0.0/src/core/binary/dwarf.rs +0 -610
  1209. data/ext/cargo-vendor/wast-216.0.0/src/core/binary.rs +0 -1539
  1210. data/ext/cargo-vendor/wast-216.0.0/src/core/expr.rs +0 -2110
  1211. data/ext/cargo-vendor/wast-216.0.0/src/core/module.rs +0 -215
  1212. data/ext/cargo-vendor/wast-216.0.0/src/core/resolve/mod.rs +0 -109
  1213. data/ext/cargo-vendor/wast-216.0.0/src/core/resolve/names.rs +0 -791
  1214. data/ext/cargo-vendor/wast-216.0.0/src/core/resolve/types.rs +0 -270
  1215. data/ext/cargo-vendor/wast-216.0.0/src/lexer.rs +0 -1572
  1216. data/ext/cargo-vendor/wast-216.0.0/src/lib.rs +0 -556
  1217. data/ext/cargo-vendor/wast-216.0.0/src/parser.rs +0 -1434
  1218. data/ext/cargo-vendor/wast-216.0.0/src/wast.rs +0 -459
  1219. data/ext/cargo-vendor/wast-216.0.0/src/wat.rs +0 -68
  1220. data/ext/cargo-vendor/wat-1.216.0/.cargo-checksum.json +0 -1
  1221. data/ext/cargo-vendor/wat-1.216.0/Cargo.toml +0 -56
  1222. data/ext/cargo-vendor/wiggle-24.0.0/.cargo-checksum.json +0 -1
  1223. data/ext/cargo-vendor/wiggle-24.0.0/Cargo.toml +0 -117
  1224. data/ext/cargo-vendor/wiggle-24.0.0/src/lib.rs +0 -605
  1225. data/ext/cargo-vendor/wiggle-generate-24.0.0/.cargo-checksum.json +0 -1
  1226. data/ext/cargo-vendor/wiggle-generate-24.0.0/Cargo.toml +0 -83
  1227. data/ext/cargo-vendor/wiggle-generate-24.0.0/src/funcs.rs +0 -434
  1228. data/ext/cargo-vendor/wiggle-generate-24.0.0/src/lib.rs +0 -100
  1229. data/ext/cargo-vendor/wiggle-generate-24.0.0/src/names.rs +0 -299
  1230. data/ext/cargo-vendor/wiggle-generate-24.0.0/src/wasmtime.rs +0 -172
  1231. data/ext/cargo-vendor/wiggle-macro-24.0.0/.cargo-checksum.json +0 -1
  1232. data/ext/cargo-vendor/wiggle-macro-24.0.0/Cargo.toml +0 -76
  1233. data/ext/cargo-vendor/winch-codegen-0.22.0/.cargo-checksum.json +0 -1
  1234. data/ext/cargo-vendor/winch-codegen-0.22.0/Cargo.toml +0 -94
  1235. data/ext/cargo-vendor/winch-codegen-0.22.0/src/abi/local.rs +0 -81
  1236. data/ext/cargo-vendor/winch-codegen-0.22.0/src/abi/mod.rs +0 -666
  1237. data/ext/cargo-vendor/winch-codegen-0.22.0/src/codegen/bounds.rs +0 -220
  1238. data/ext/cargo-vendor/winch-codegen-0.22.0/src/codegen/context.rs +0 -591
  1239. data/ext/cargo-vendor/winch-codegen-0.22.0/src/codegen/mod.rs +0 -880
  1240. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/aarch64/abi.rs +0 -296
  1241. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/aarch64/address.rs +0 -143
  1242. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/aarch64/asm.rs +0 -709
  1243. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/aarch64/masm.rs +0 -665
  1244. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/mod.rs +0 -223
  1245. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/x64/abi.rs +0 -564
  1246. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/x64/asm.rs +0 -1418
  1247. data/ext/cargo-vendor/winch-codegen-0.22.0/src/isa/x64/masm.rs +0 -1115
  1248. data/ext/cargo-vendor/winch-codegen-0.22.0/src/masm.rs +0 -957
  1249. data/ext/cargo-vendor/winch-codegen-0.22.0/src/regalloc.rs +0 -65
  1250. data/ext/cargo-vendor/winch-codegen-0.22.0/src/stack.rs +0 -447
  1251. data/ext/cargo-vendor/winch-codegen-0.22.0/src/visitor.rs +0 -2158
  1252. data/ext/cargo-vendor/wit-parser-0.215.0/.cargo-checksum.json +0 -1
  1253. data/ext/cargo-vendor/wit-parser-0.215.0/Cargo.toml +0 -129
  1254. data/ext/cargo-vendor/wit-parser-0.215.0/src/ast/resolve.rs +0 -1583
  1255. data/ext/cargo-vendor/wit-parser-0.215.0/src/ast.rs +0 -1904
  1256. data/ext/cargo-vendor/wit-parser-0.215.0/src/decoding.rs +0 -1795
  1257. data/ext/cargo-vendor/wit-parser-0.215.0/src/lib.rs +0 -912
  1258. data/ext/cargo-vendor/wit-parser-0.215.0/src/sizealign.rs +0 -179
  1259. data/ext/cargo-vendor/wit-parser-0.215.0/tests/all.rs +0 -154
  1260. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-gate3.wit.result +0 -8
  1261. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-gate4.wit.result +0 -8
  1262. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-gate5.wit.result +0 -8
  1263. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-pkg1.wit.result +0 -9
  1264. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-pkg2.wit.result +0 -8
  1265. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-pkg3.wit.result +0 -8
  1266. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-pkg4.wit.result +0 -8
  1267. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-pkg5.wit.result +0 -8
  1268. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-pkg6.wit.result +0 -8
  1269. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/bad-resource15.wit.result +0 -8
  1270. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/conflicting-package.wit.result +0 -10
  1271. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/duplicate-interface2.wit.result +0 -9
  1272. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/include-foreign.wit.result +0 -8
  1273. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/multi-file-missing-delimiter.wit.result +0 -9
  1274. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/multi-package-deps-share-nest.wit.result +0 -6
  1275. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/multiple-package-docs.wit.result +0 -10
  1276. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +0 -9
  1277. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/non-existance-world-include.wit.result +0 -8
  1278. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/pkg-cycle.wit.result +0 -8
  1279. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/pkg-cycle2.wit.result +0 -8
  1280. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/resources-multiple-returns-borrow.wit.result +0 -8
  1281. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/resources-return-borrow.wit.result +0 -8
  1282. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/return-borrow1.wit.result +0 -8
  1283. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/return-borrow2.wit.result +0 -8
  1284. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/return-borrow6.wit.result +0 -8
  1285. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/return-borrow7.wit.result +0 -8
  1286. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/return-borrow8.wit.result +0 -9
  1287. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/type-and-resource-same-name.wit.result +0 -8
  1288. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/unresolved-use10.wit.result +0 -9
  1289. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/use-and-include-world.wit.result +0 -9
  1290. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/use-world.wit.result +0 -8
  1291. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/parse-fail/very-nested-packages.wit.result +0 -8
  1292. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/since-and-unstable.wit +0 -107
  1293. data/ext/cargo-vendor/wit-parser-0.215.0/tests/ui/since-and-unstable.wit.json +0 -623
  1294. /data/ext/cargo-vendor/{cranelift-bforest-0.111.0 → cranelift-bforest-0.112.1}/LICENSE +0 -0
  1295. /data/ext/cargo-vendor/{cranelift-bforest-0.111.0 → cranelift-bforest-0.112.1}/README.md +0 -0
  1296. /data/ext/cargo-vendor/{cranelift-bforest-0.111.0 → cranelift-bforest-0.112.1}/src/lib.rs +0 -0
  1297. /data/ext/cargo-vendor/{cranelift-bforest-0.111.0 → cranelift-bforest-0.112.1}/src/map.rs +0 -0
  1298. /data/ext/cargo-vendor/{cranelift-bforest-0.111.0 → cranelift-bforest-0.112.1}/src/set.rs +0 -0
  1299. /data/ext/cargo-vendor/{cranelift-bitset-0.111.0 → cranelift-bitset-0.112.1}/src/compound.rs +0 -0
  1300. /data/ext/cargo-vendor/{cranelift-bitset-0.111.0 → cranelift-bitset-0.112.1}/src/lib.rs +0 -0
  1301. /data/ext/cargo-vendor/{cranelift-bitset-0.111.0 → cranelift-bitset-0.112.1}/tests/bitset.rs +0 -0
  1302. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/LICENSE +0 -0
  1303. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/README.md +0 -0
  1304. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/benches/x64-evex-encoding.rs +0 -0
  1305. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/alias_analysis.rs +0 -0
  1306. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/constant_hash.rs +0 -0
  1307. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/context.rs +0 -0
  1308. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ctxhash.rs +0 -0
  1309. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/cursor.rs +0 -0
  1310. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/dominator_tree.rs +0 -0
  1311. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/egraph/cost.rs +0 -0
  1312. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/egraph/elaborate.rs +0 -0
  1313. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/flowgraph.rs +0 -0
  1314. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/atomic_rmw_op.rs +0 -0
  1315. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/builder.rs +0 -0
  1316. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/condcodes.rs +0 -0
  1317. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/dynamic_type.rs +0 -0
  1318. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/jumptable.rs +0 -0
  1319. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/known_symbol.rs +0 -0
  1320. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/layout.rs +0 -0
  1321. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/libcall.rs +0 -0
  1322. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/memflags.rs +0 -0
  1323. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/mod.rs +0 -0
  1324. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/pcc.rs +0 -0
  1325. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/sourceloc.rs +0 -0
  1326. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ir/stackslot.rs +0 -0
  1327. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/aarch64/inst/unwind.rs +0 -0
  1328. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/aarch64/inst_neon.isle +0 -0
  1329. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
  1330. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/aarch64/lower.rs +0 -0
  1331. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
  1332. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/aarch64/mod.rs +0 -0
  1333. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/call_conv.rs +0 -0
  1334. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/riscv64/inst/imms.rs +0 -0
  1335. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/riscv64/inst/regs.rs +0 -0
  1336. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/riscv64/inst/unwind.rs +0 -0
  1337. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
  1338. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/riscv64/lower.rs +0 -0
  1339. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/riscv64/mod.rs +0 -0
  1340. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/riscv64/settings.rs +0 -0
  1341. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/s390x/inst/args.rs +0 -0
  1342. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/s390x/inst/imms.rs +0 -0
  1343. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/s390x/inst/unwind.rs +0 -0
  1344. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
  1345. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/s390x/lower.rs +0 -0
  1346. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/s390x/mod.rs +0 -0
  1347. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/s390x/settings.rs +0 -0
  1348. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/unwind/winx64.rs +0 -0
  1349. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/unwind.rs +0 -0
  1350. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/x64/encoding/mod.rs +0 -0
  1351. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/x64/encoding/rex.rs +0 -0
  1352. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/x64/encoding/vex.rs +0 -0
  1353. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/x64/inst/unwind/winx64.rs +0 -0
  1354. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/x64/inst/unwind.rs +0 -0
  1355. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/x64/lower/isle/generated_code.rs +0 -0
  1356. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/isa/x64/settings.rs +0 -0
  1357. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/iterators.rs +0 -0
  1358. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/legalizer/globalvalue.rs +0 -0
  1359. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/legalizer/mod.rs +0 -0
  1360. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/loop_analysis.rs +0 -0
  1361. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/machinst/blockorder.rs +0 -0
  1362. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/machinst/compile.rs +0 -0
  1363. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/machinst/helpers.rs +0 -0
  1364. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/machinst/inst_common.rs +0 -0
  1365. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/machinst/pcc.rs +0 -0
  1366. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/machinst/valueregs.rs +0 -0
  1367. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/nan_canonicalization.rs +0 -0
  1368. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/README.md +0 -0
  1369. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/arithmetic.isle +0 -0
  1370. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/bitops.isle +0 -0
  1371. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/cprop.isle +0 -0
  1372. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/generated_code.rs +0 -0
  1373. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/remat.isle +0 -0
  1374. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/shifts.isle +0 -0
  1375. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/spaceship.isle +0 -0
  1376. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/spectre.isle +0 -0
  1377. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts/vector.isle +0 -0
  1378. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/opts.rs +0 -0
  1379. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/prelude_opt.isle +0 -0
  1380. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/ranges.rs +0 -0
  1381. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/scoped_hash_map.rs +0 -0
  1382. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/souper_harvest.rs +0 -0
  1383. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/traversals.rs +0 -0
  1384. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/unionfind.rs +0 -0
  1385. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/unreachable_code.rs +0 -0
  1386. /data/ext/cargo-vendor/{cranelift-codegen-0.111.0 → cranelift-codegen-0.112.1}/src/value_label.rs +0 -0
  1387. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/LICENSE +0 -0
  1388. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/README.md +0 -0
  1389. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/cdsl/formats.rs +0 -0
  1390. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/cdsl/instructions.rs +0 -0
  1391. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/cdsl/isa.rs +0 -0
  1392. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/cdsl/mod.rs +0 -0
  1393. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/cdsl/operands.rs +0 -0
  1394. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/constant_hash.rs +0 -0
  1395. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/isa/s390x.rs +0 -0
  1396. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/shared/entities.rs +0 -0
  1397. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/shared/formats.rs +0 -0
  1398. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/shared/immediates.rs +0 -0
  1399. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.111.0 → cranelift-codegen-meta-0.112.1}/src/unique_table.rs +0 -0
  1400. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.111.0 → cranelift-codegen-shared-0.112.1}/LICENSE +0 -0
  1401. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.111.0 → cranelift-codegen-shared-0.112.1}/README.md +0 -0
  1402. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.111.0 → cranelift-codegen-shared-0.112.1}/src/constant_hash.rs +0 -0
  1403. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.111.0 → cranelift-codegen-shared-0.112.1}/src/constants.rs +0 -0
  1404. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.111.0 → cranelift-codegen-shared-0.112.1}/src/lib.rs +0 -0
  1405. /data/ext/cargo-vendor/{cranelift-control-0.111.0 → cranelift-control-0.112.1}/LICENSE +0 -0
  1406. /data/ext/cargo-vendor/{cranelift-control-0.111.0 → cranelift-control-0.112.1}/README.md +0 -0
  1407. /data/ext/cargo-vendor/{cranelift-control-0.111.0 → cranelift-control-0.112.1}/src/chaos.rs +0 -0
  1408. /data/ext/cargo-vendor/{cranelift-control-0.111.0 → cranelift-control-0.112.1}/src/lib.rs +0 -0
  1409. /data/ext/cargo-vendor/{cranelift-control-0.111.0 → cranelift-control-0.112.1}/src/zero_sized.rs +0 -0
  1410. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/LICENSE +0 -0
  1411. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/README.md +0 -0
  1412. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/boxed_slice.rs +0 -0
  1413. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/iter.rs +0 -0
  1414. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/keys.rs +0 -0
  1415. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/list.rs +0 -0
  1416. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/map.rs +0 -0
  1417. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/primary.rs +0 -0
  1418. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/set.rs +0 -0
  1419. /data/ext/cargo-vendor/{cranelift-entity-0.111.0 → cranelift-entity-0.112.1}/src/unsigned.rs +0 -0
  1420. /data/ext/cargo-vendor/{cranelift-frontend-0.111.0 → cranelift-frontend-0.112.1}/LICENSE +0 -0
  1421. /data/ext/cargo-vendor/{cranelift-frontend-0.111.0 → cranelift-frontend-0.112.1}/README.md +0 -0
  1422. /data/ext/cargo-vendor/{cranelift-frontend-0.111.0 → cranelift-frontend-0.112.1}/src/frontend/safepoints.rs +0 -0
  1423. /data/ext/cargo-vendor/{cranelift-frontend-0.111.0 → cranelift-frontend-0.112.1}/src/lib.rs +0 -0
  1424. /data/ext/cargo-vendor/{cranelift-frontend-0.111.0 → cranelift-frontend-0.112.1}/src/variable.rs +0 -0
  1425. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/README.md +0 -0
  1426. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/bad_converters.isle +0 -0
  1427. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
  1428. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
  1429. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/error1.isle +0 -0
  1430. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/extra_parens.isle +0 -0
  1431. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/impure_expression.isle +0 -0
  1432. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/impure_rhs.isle +0 -0
  1433. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/multi_internal_etor.isle +0 -0
  1434. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/fail/multi_prio.isle +0 -0
  1435. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/borrows.isle +0 -0
  1436. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/borrows_main.rs +0 -0
  1437. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/iflets.isle +0 -0
  1438. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/iflets_main.rs +0 -0
  1439. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/multi_constructor.isle +0 -0
  1440. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/multi_constructor_main.rs +0 -0
  1441. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/multi_extractor.isle +0 -0
  1442. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/multi_extractor_main.rs +0 -0
  1443. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/test.isle +0 -0
  1444. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/link/test_main.rs +0 -0
  1445. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/bound_var.isle +0 -0
  1446. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/construct_and_extract.isle +0 -0
  1447. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/conversions.isle +0 -0
  1448. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/conversions_extern.isle +0 -0
  1449. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/let.isle +0 -0
  1450. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/nodebug.isle +0 -0
  1451. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/prio_trie_bug.isle +0 -0
  1452. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/test2.isle +0 -0
  1453. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/test3.isle +0 -0
  1454. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/test4.isle +0 -0
  1455. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/pass/tutorial.isle +0 -0
  1456. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/run/iconst.isle +0 -0
  1457. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/run/iconst_main.rs +0 -0
  1458. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/run/let_shadowing.isle +0 -0
  1459. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/isle_examples/run/let_shadowing_main.rs +0 -0
  1460. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/src/disjointsets.rs +0 -0
  1461. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/src/log.rs +0 -0
  1462. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/src/serialize.rs +0 -0
  1463. /data/ext/cargo-vendor/{cranelift-isle-0.111.0 → cranelift-isle-0.112.1}/src/stablemapset.rs +0 -0
  1464. /data/ext/cargo-vendor/{cranelift-native-0.111.0 → cranelift-native-0.112.1}/LICENSE +0 -0
  1465. /data/ext/cargo-vendor/{cranelift-native-0.111.0 → cranelift-native-0.112.1}/README.md +0 -0
  1466. /data/ext/cargo-vendor/{cranelift-native-0.111.0 → cranelift-native-0.112.1}/src/riscv.rs +0 -0
  1467. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/LICENSE +0 -0
  1468. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/README.md +0 -0
  1469. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/src/code_translator/bounds_checks.rs +0 -0
  1470. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/src/environ/mod.rs +0 -0
  1471. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/src/heap.rs +0 -0
  1472. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/src/lib.rs +0 -0
  1473. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/src/state.rs +0 -0
  1474. /data/ext/cargo-vendor/{cranelift-wasm-0.111.0 → cranelift-wasm-0.112.1}/src/table.rs +0 -0
  1475. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/README.md +0 -0
  1476. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/src/clocks.rs +0 -0
  1477. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/src/lib.rs +0 -0
  1478. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/src/noop_scheduler.rs +0 -0
  1479. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/tests/clocks.rs +0 -0
  1480. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/tests/common/mod.rs +0 -0
  1481. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/tests/random.rs +0 -0
  1482. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.24 → deterministic-wasi-ctx-0.1.25}/tests/scheduler.rs +0 -0
  1483. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/LICENSE +0 -0
  1484. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/README.md +0 -0
  1485. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/deny.toml +0 -0
  1486. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/doc/TODO +0 -0
  1487. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/domtree.rs +0 -0
  1488. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/indexset.rs +0 -0
  1489. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/ion/dump.rs +0 -0
  1490. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/ion/redundant_moves.rs +0 -0
  1491. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/ion/reg_traversal.rs +0 -0
  1492. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/ion/spill.rs +0 -0
  1493. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/moves.rs +0 -0
  1494. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/postorder.rs +0 -0
  1495. /data/ext/cargo-vendor/{regalloc2-0.9.3 → regalloc2-0.10.2}/src/ssa.rs +0 -0
  1496. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/LICENSE +0 -0
  1497. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/README.md +0 -0
  1498. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/clocks.rs +0 -0
  1499. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/dir.rs +0 -0
  1500. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/error.rs +0 -0
  1501. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/file.rs +0 -0
  1502. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/pipe.rs +0 -0
  1503. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/random.rs +0 -0
  1504. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sched/subscription.rs +0 -0
  1505. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sched.rs +0 -0
  1506. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/snapshots/preview_0.rs +0 -0
  1507. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/snapshots/preview_1/error.rs +0 -0
  1508. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/snapshots/preview_1.rs +0 -0
  1509. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/string_array.rs +0 -0
  1510. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/clocks.rs +0 -0
  1511. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/file.rs +0 -0
  1512. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/mod.rs +0 -0
  1513. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/net.rs +0 -0
  1514. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/sched/unix.rs +0 -0
  1515. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/sched/windows.rs +0 -0
  1516. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/sched.rs +0 -0
  1517. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/sync/stdio.rs +0 -0
  1518. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/table.rs +0 -0
  1519. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/tokio/file.rs +0 -0
  1520. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/tokio/mod.rs +0 -0
  1521. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/tokio/net.rs +0 -0
  1522. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/tokio/sched/unix.rs +0 -0
  1523. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/tokio/sched/windows.rs +0 -0
  1524. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/tokio/sched.rs +0 -0
  1525. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/src/tokio/stdio.rs +0 -0
  1526. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/witx/preview0/typenames.witx +0 -0
  1527. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/witx/preview0/wasi_unstable.witx +0 -0
  1528. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/witx/preview1/typenames.witx +0 -0
  1529. /data/ext/cargo-vendor/{wasi-common-24.0.0 → wasi-common-25.0.1}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1530. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/README.md +0 -0
  1531. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/component/aliases.rs +0 -0
  1532. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/component/canonicals.rs +0 -0
  1533. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/component/components.rs +0 -0
  1534. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/component/modules.rs +0 -0
  1535. /data/ext/cargo-vendor/{wasm-encoder-0.216.0 → wasm-encoder-0.217.0}/src/component/names.rs +0 -0
  1536. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/component/start.rs +0 -0
  1537. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/component.rs +0 -0
  1538. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/custom.rs +0 -0
  1539. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/data.rs +0 -0
  1540. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/dump.rs +0 -0
  1541. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/elements.rs +0 -0
  1542. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/exports.rs +0 -0
  1543. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/functions.rs +0 -0
  1544. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/globals.rs +0 -0
  1545. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/imports.rs +0 -0
  1546. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/linking.rs +0 -0
  1547. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/memories.rs +0 -0
  1548. /data/ext/cargo-vendor/{wasm-encoder-0.216.0 → wasm-encoder-0.217.0}/src/core/names.rs +0 -0
  1549. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/producers.rs +0 -0
  1550. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/start.rs +0 -0
  1551. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/tables.rs +0 -0
  1552. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core/tags.rs +0 -0
  1553. /data/ext/cargo-vendor/{wasm-encoder-0.216.0 → wasm-encoder-0.217.0}/src/core/types.rs +0 -0
  1554. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/core.rs +0 -0
  1555. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/lib.rs +0 -0
  1556. /data/ext/cargo-vendor/{wasm-encoder-0.215.0 → wasm-encoder-0.217.0}/src/raw.rs +0 -0
  1557. /data/ext/cargo-vendor/{wasm-encoder-0.216.0 → wasm-encoder-0.217.0}/src/reencode/component.rs +0 -0
  1558. /data/ext/cargo-vendor/{wasm-encoder-0.216.0 → wasm-encoder-0.217.0}/src/reencode.rs +0 -0
  1559. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/README.md +0 -0
  1560. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/examples/simple.rs +0 -0
  1561. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/hash.rs +0 -0
  1562. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/index_map/detail.rs +0 -0
  1563. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/index_map/tests.rs +0 -0
  1564. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/index_map.rs +0 -0
  1565. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/index_set.rs +0 -0
  1566. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/map.rs +0 -0
  1567. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/mod.rs +0 -0
  1568. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/collections/set.rs +0 -0
  1569. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/lib.rs +0 -0
  1570. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/component/names.rs +0 -0
  1571. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/component/start.rs +0 -0
  1572. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/component.rs +0 -0
  1573. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/branch_hinting.rs +0 -0
  1574. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/custom.rs +0 -0
  1575. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/dylink0.rs +0 -0
  1576. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/elements.rs +0 -0
  1577. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/functions.rs +0 -0
  1578. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/linking.rs +0 -0
  1579. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/memories.rs +0 -0
  1580. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/names.rs +0 -0
  1581. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/reloc.rs +0 -0
  1582. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/tables.rs +0 -0
  1583. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/tags.rs +0 -0
  1584. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core/types/matches.rs +0 -0
  1585. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/src/readers/core.rs +0 -0
  1586. /data/ext/cargo-vendor/{wasmparser-0.215.0 → wasmparser-0.217.0}/tests/big-module.rs +0 -0
  1587. /data/ext/cargo-vendor/{wasmprinter-0.215.0 → wasmprinter-0.217.0}/README.md +0 -0
  1588. /data/ext/cargo-vendor/{wasmprinter-0.215.0 → wasmprinter-0.217.0}/src/operator.rs +0 -0
  1589. /data/ext/cargo-vendor/{wasmprinter-0.215.0 → wasmprinter-0.217.0}/src/print.rs +0 -0
  1590. /data/ext/cargo-vendor/{wasmprinter-0.215.0 → wasmprinter-0.217.0}/tests/all.rs +0 -0
  1591. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/LICENSE +0 -0
  1592. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/README.md +0 -0
  1593. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/proptest-regressions/runtime/vm/instance/allocator/pooling/memory_pool.txt +0 -0
  1594. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/profiling_agent/perfmap.rs +0 -0
  1595. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/profiling_agent/vtune.rs +0 -0
  1596. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/profiling_agent.rs +0 -0
  1597. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/code.rs +0 -0
  1598. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/code_memory.rs +0 -0
  1599. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/_0_hello_world.rs +0 -0
  1600. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/_1_world_imports.rs +0 -0
  1601. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/_2_world_exports.rs +0 -0
  1602. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/_3_interface_imports.rs +0 -0
  1603. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/_4_imported_resources.rs +0 -0
  1604. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/_5_all_world_export_kinds.rs +0 -0
  1605. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/_6_exported_resources.rs +0 -0
  1606. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/bindgen_examples/mod.rs +0 -0
  1607. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/func/options.rs +0 -0
  1608. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/func.rs +0 -0
  1609. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/instance.rs +0 -0
  1610. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/matching.rs +0 -0
  1611. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/resource_table.rs +0 -0
  1612. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/storage.rs +0 -0
  1613. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/store.rs +0 -0
  1614. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/component/values.rs +0 -0
  1615. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/debug.rs +0 -0
  1616. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/externals.rs +0 -0
  1617. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/func/typed.rs +0 -0
  1618. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/gc/disabled/externref.rs +0 -0
  1619. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/gc/disabled/i31.rs +0 -0
  1620. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/gc/disabled/structref.rs +0 -0
  1621. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/gc/enabled/externref.rs +0 -0
  1622. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/gc/enabled/structref.rs +0 -0
  1623. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/gc/noextern.rs +0 -0
  1624. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/gc.rs +0 -0
  1625. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/instantiate.rs +0 -0
  1626. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/limits.rs +0 -0
  1627. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/module/registry.rs +0 -0
  1628. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/profiling.rs +0 -0
  1629. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/resources.rs +0 -0
  1630. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/signatures.rs +0 -0
  1631. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/stack.rs +0 -0
  1632. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/store/context.rs +0 -0
  1633. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/store/data.rs +0 -0
  1634. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/store/func_refs.rs +0 -0
  1635. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/trampoline/func.rs +0 -0
  1636. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/trampoline/memory.rs +0 -0
  1637. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/trampoline/table.rs +0 -0
  1638. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/trampoline.rs +0 -0
  1639. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/type_registry.rs +0 -0
  1640. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/types/matching.rs +0 -0
  1641. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/uninhabited.rs +0 -0
  1642. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/unix.rs +0 -0
  1643. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/v128.rs +0 -0
  1644. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/arch/aarch64.rs +0 -0
  1645. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/arch/mod.rs +0 -0
  1646. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/arch/riscv64.rs +0 -0
  1647. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/arch/s390x.S +0 -0
  1648. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/arch/s390x.rs +0 -0
  1649. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/arch/unsupported.rs +0 -0
  1650. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/arch/x86_64.rs +0 -0
  1651. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/async_yield.rs +0 -0
  1652. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/component/libcalls.rs +0 -0
  1653. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/component/resources.rs +0 -0
  1654. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/component.rs +0 -0
  1655. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/debug_builtins.rs +0 -0
  1656. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/export.rs +0 -0
  1657. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/gc/enabled/externref.rs +0 -0
  1658. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/gc/enabled/free_list.rs +0 -0
  1659. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/gc/host_data.rs +0 -0
  1660. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/gc/i31.rs +0 -0
  1661. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/imports.rs +0 -0
  1662. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator/on_demand.rs +0 -0
  1663. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator/pooling/decommit_queue.rs +0 -0
  1664. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator/pooling/generic_stack_pool.rs +0 -0
  1665. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator/pooling/memory_pool.rs +0 -0
  1666. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator/pooling/table_pool.rs +0 -0
  1667. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator/pooling/unix_stack_pool.rs +0 -0
  1668. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator/pooling.rs +0 -0
  1669. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance/allocator.rs +0 -0
  1670. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/instance.rs +0 -0
  1671. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/memory.rs +0 -0
  1672. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/mmap.rs +0 -0
  1673. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/mmap_vec.rs +0 -0
  1674. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/module_id.rs +0 -0
  1675. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/mpk/disabled.rs +0 -0
  1676. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/mpk/enabled.rs +0 -0
  1677. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/mpk/mod.rs +0 -0
  1678. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/mpk/pkru.rs +0 -0
  1679. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/mpk/sys.rs +0 -0
  1680. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/send_sync_ptr.rs +0 -0
  1681. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/store_box.rs +0 -0
  1682. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/custom/capi.rs +0 -0
  1683. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/custom/mmap.rs +0 -0
  1684. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/custom/mod.rs +0 -0
  1685. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/custom/unwind.rs +0 -0
  1686. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/custom/vm.rs +0 -0
  1687. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/miri/mmap.rs +0 -0
  1688. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/miri/mod.rs +0 -0
  1689. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/miri/traphandlers.rs +0 -0
  1690. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/miri/unwind.rs +0 -0
  1691. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/miri/vm.rs +0 -0
  1692. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/mod.rs +0 -0
  1693. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/unix/macos_traphandlers.rs +0 -0
  1694. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/unix/mod.rs +0 -0
  1695. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/unix/unwind.rs +0 -0
  1696. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/unix/vm.rs +0 -0
  1697. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/windows/mmap.rs +0 -0
  1698. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/windows/mod.rs +0 -0
  1699. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/windows/unwind.rs +0 -0
  1700. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/sys/windows/vm.rs +0 -0
  1701. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/table.rs +0 -0
  1702. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/threads/mod.rs +0 -0
  1703. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/threads/shared_memory.rs +0 -0
  1704. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/threads/shared_memory_disabled.rs +0 -0
  1705. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/traphandlers/backtrace.rs +0 -0
  1706. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/traphandlers/coredump_disabled.rs +0 -0
  1707. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/traphandlers/coredump_enabled.rs +0 -0
  1708. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm/vmcontext/vm_host_func_context.rs +0 -0
  1709. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/vm.rs +0 -0
  1710. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime/windows.rs +0 -0
  1711. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/runtime.rs +0 -0
  1712. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/sync_nostd.rs +0 -0
  1713. /data/ext/cargo-vendor/{wasmtime-24.0.0 → wasmtime-25.0.1}/src/sync_std.rs +0 -0
  1714. /data/ext/cargo-vendor/{wasmtime-asm-macros-24.0.0 → wasmtime-asm-macros-25.0.1}/src/lib.rs +0 -0
  1715. /data/ext/cargo-vendor/{wasmtime-cache-24.0.0 → wasmtime-cache-25.0.1}/LICENSE +0 -0
  1716. /data/ext/cargo-vendor/{wasmtime-cache-24.0.0 → wasmtime-cache-25.0.1}/src/config/tests.rs +0 -0
  1717. /data/ext/cargo-vendor/{wasmtime-cache-24.0.0 → wasmtime-cache-25.0.1}/src/tests.rs +0 -0
  1718. /data/ext/cargo-vendor/{wasmtime-cache-24.0.0 → wasmtime-cache-25.0.1}/src/worker/tests/system_time_stub.rs +0 -0
  1719. /data/ext/cargo-vendor/{wasmtime-cache-24.0.0 → wasmtime-cache-25.0.1}/tests/cache_write_default_config.rs +0 -0
  1720. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/build.rs +0 -0
  1721. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/src/lib.rs +0 -0
  1722. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/char.wit +0 -0
  1723. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/conventions.wit +0 -0
  1724. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/dead-code.wit +0 -0
  1725. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/direct-import.wit +0 -0
  1726. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/empty.wit +0 -0
  1727. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/flags.wit +0 -0
  1728. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/floats.wit +0 -0
  1729. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/function-new.wit +0 -0
  1730. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/integers.wit +0 -0
  1731. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/lists.wit +0 -0
  1732. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/many-arguments.wit +0 -0
  1733. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/multi-return.wit +0 -0
  1734. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/multiversion/deps/v1/root.wit +0 -0
  1735. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/multiversion/deps/v2/root.wit +0 -0
  1736. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/multiversion/root.wit +0 -0
  1737. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/records.wit +0 -0
  1738. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/rename.wit +0 -0
  1739. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/resources-export.wit +0 -0
  1740. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/resources-import.wit +0 -0
  1741. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/share-types.wit +0 -0
  1742. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/simple-functions.wit +0 -0
  1743. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/simple-lists.wit +0 -0
  1744. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/simple-wasi.wit +0 -0
  1745. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/small-anonymous.wit +0 -0
  1746. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/smoke-default.wit +0 -0
  1747. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/smoke-export.wit +0 -0
  1748. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/smoke.wit +0 -0
  1749. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/strings.wit +0 -0
  1750. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/unversioned-foo.wit +0 -0
  1751. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/use-paths.wit +0 -0
  1752. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/variants.wit +0 -0
  1753. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/wat.wit +0 -0
  1754. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen/worlds-with-types.wit +0 -0
  1755. /data/ext/cargo-vendor/{wasmtime-component-macro-24.0.0 → wasmtime-component-macro-25.0.1}/tests/codegen_no_std.rs +0 -0
  1756. /data/ext/cargo-vendor/{wasmtime-component-util-24.0.0 → wasmtime-component-util-25.0.1}/src/lib.rs +0 -0
  1757. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/LICENSE +0 -0
  1758. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/SECURITY.md +0 -0
  1759. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/builder.rs +0 -0
  1760. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/compiled_function.rs +0 -0
  1761. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/compiler/component.rs +0 -0
  1762. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/debug/gc.rs +0 -0
  1763. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/debug/transform/address_transform.rs +0 -0
  1764. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/debug/transform/expression.rs +0 -0
  1765. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/debug/transform/refs.rs +0 -0
  1766. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/debug/transform/utils.rs +0 -0
  1767. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/debug/write_debuginfo.rs +0 -0
  1768. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/debug.rs +0 -0
  1769. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/gc/disabled.rs +0 -0
  1770. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/isa_builder.rs +0 -0
  1771. /data/ext/cargo-vendor/{wasmtime-cranelift-24.0.0 → wasmtime-cranelift-25.0.1}/src/obj.rs +0 -0
  1772. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/LICENSE +0 -0
  1773. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/examples/factc.rs +0 -0
  1774. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/address_map.rs +0 -0
  1775. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/compile/address_map.rs +0 -0
  1776. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/compile/module_artifacts.rs +0 -0
  1777. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/compile/module_types.rs +0 -0
  1778. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/compile/trap_encoding.rs +0 -0
  1779. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/artifacts.rs +0 -0
  1780. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/compiler.rs +0 -0
  1781. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/dfg.rs +0 -0
  1782. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/info.rs +0 -0
  1783. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/names.rs +0 -0
  1784. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/translate/adapt.rs +0 -0
  1785. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/translate/inline.rs +0 -0
  1786. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/translate.rs +0 -0
  1787. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/types_builder/resources.rs +0 -0
  1788. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/types_builder.rs +0 -0
  1789. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component/vmcomponent_offsets.rs +0 -0
  1790. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/component.rs +0 -0
  1791. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/fact/core_types.rs +0 -0
  1792. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/fact/signature.rs +0 -0
  1793. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/fact/transcode.rs +0 -0
  1794. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/fact.rs +0 -0
  1795. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/gc.rs +0 -0
  1796. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/lib.rs +0 -0
  1797. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/module.rs +0 -0
  1798. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/module_artifacts.rs +0 -0
  1799. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/module_types.rs +0 -0
  1800. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/obj.rs +0 -0
  1801. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/ref_bits.rs +0 -0
  1802. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/scopevec.rs +0 -0
  1803. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/tunables.rs +0 -0
  1804. /data/ext/cargo-vendor/{wasmtime-environ-24.0.0 → wasmtime-environ-25.0.1}/src/vmoffsets.rs +0 -0
  1805. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/LICENSE +0 -0
  1806. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/unix/aarch64.rs +0 -0
  1807. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/unix/arm.rs +0 -0
  1808. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/unix/riscv64.rs +0 -0
  1809. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/unix/s390x.S +0 -0
  1810. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/unix/x86.rs +0 -0
  1811. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/unix/x86_64.rs +0 -0
  1812. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/unix.rs +0 -0
  1813. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/windows.c +0 -0
  1814. /data/ext/cargo-vendor/{wasmtime-fiber-24.0.0 → wasmtime-fiber-25.0.1}/src/windows.rs +0 -0
  1815. /data/ext/cargo-vendor/{wasmtime-jit-debug-24.0.0 → wasmtime-jit-debug-25.0.1}/README.md +0 -0
  1816. /data/ext/cargo-vendor/{wasmtime-jit-debug-24.0.0 → wasmtime-jit-debug-25.0.1}/src/gdb_jit_int.rs +0 -0
  1817. /data/ext/cargo-vendor/{wasmtime-jit-debug-24.0.0 → wasmtime-jit-debug-25.0.1}/src/lib.rs +0 -0
  1818. /data/ext/cargo-vendor/{wasmtime-jit-debug-24.0.0 → wasmtime-jit-debug-25.0.1}/src/perf_jitdump.rs +0 -0
  1819. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-24.0.0 → wasmtime-jit-icache-coherence-25.0.1}/src/lib.rs +0 -0
  1820. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-24.0.0 → wasmtime-jit-icache-coherence-25.0.1}/src/libc.rs +0 -0
  1821. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-24.0.0 → wasmtime-jit-icache-coherence-25.0.1}/src/miri.rs +0 -0
  1822. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-24.0.0 → wasmtime-jit-icache-coherence-25.0.1}/src/win.rs +0 -0
  1823. /data/ext/cargo-vendor/{wasmtime-slab-24.0.0 → wasmtime-slab-25.0.1}/src/lib.rs +0 -0
  1824. /data/ext/cargo-vendor/{wasmtime-types-24.0.0 → wasmtime-types-25.0.1}/LICENSE +0 -0
  1825. /data/ext/cargo-vendor/{wasmtime-types-24.0.0 → wasmtime-types-25.0.1}/src/error.rs +0 -0
  1826. /data/ext/cargo-vendor/{wasmtime-types-24.0.0 → wasmtime-types-25.0.1}/src/prelude.rs +0 -0
  1827. /data/ext/cargo-vendor/{wasmtime-versioned-export-macros-24.0.0 → wasmtime-versioned-export-macros-25.0.1}/src/lib.rs +0 -0
  1828. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/LICENSE +0 -0
  1829. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/README.md +0 -0
  1830. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/clocks/host.rs +0 -0
  1831. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/clocks.rs +0 -0
  1832. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/ctx.rs +0 -0
  1833. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/error.rs +0 -0
  1834. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/clocks.rs +0 -0
  1835. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/env.rs +0 -0
  1836. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/exit.rs +0 -0
  1837. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/filesystem/sync.rs +0 -0
  1838. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/instance_network.rs +0 -0
  1839. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/mod.rs +0 -0
  1840. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/network.rs +0 -0
  1841. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/random.rs +0 -0
  1842. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/tcp.rs +0 -0
  1843. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/tcp_create_socket.rs +0 -0
  1844. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/udp.rs +0 -0
  1845. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/host/udp_create_socket.rs +0 -0
  1846. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/ip_name_lookup.rs +0 -0
  1847. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/lib.rs +0 -0
  1848. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/network.rs +0 -0
  1849. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/poll.rs +0 -0
  1850. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/preview0.rs +0 -0
  1851. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/random.rs +0 -0
  1852. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/stdio/worker_thread_stdin.rs +0 -0
  1853. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/src/udp.rs +0 -0
  1854. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/tests/all/api.rs +0 -0
  1855. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/tests/all/async_.rs +0 -0
  1856. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/tests/all/preview1.rs +0 -0
  1857. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/tests/all/sync.rs +0 -0
  1858. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/witx/preview0/typenames.witx +0 -0
  1859. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/witx/preview0/wasi_unstable.witx +0 -0
  1860. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/witx/preview1/typenames.witx +0 -0
  1861. /data/ext/cargo-vendor/{wasmtime-wasi-24.0.0 → wasmtime-wasi-25.0.1}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1862. /data/ext/cargo-vendor/{wasmtime-winch-24.0.0 → wasmtime-winch-25.0.1}/LICENSE +0 -0
  1863. /data/ext/cargo-vendor/{wasmtime-winch-24.0.0 → wasmtime-winch-25.0.1}/src/builder.rs +0 -0
  1864. /data/ext/cargo-vendor/{wasmtime-winch-24.0.0 → wasmtime-winch-25.0.1}/src/compiler.rs +0 -0
  1865. /data/ext/cargo-vendor/{wasmtime-winch-24.0.0 → wasmtime-winch-25.0.1}/src/lib.rs +0 -0
  1866. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-24.0.0 → wasmtime-wit-bindgen-25.0.1}/src/source.rs +0 -0
  1867. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-24.0.0 → wasmtime-wit-bindgen-25.0.1}/src/types.rs +0 -0
  1868. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/README.md +0 -0
  1869. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/alias.rs +0 -0
  1870. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/custom.rs +0 -0
  1871. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/export.rs +0 -0
  1872. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/func.rs +0 -0
  1873. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/instance.rs +0 -0
  1874. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/item_ref.rs +0 -0
  1875. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/module.rs +0 -0
  1876. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/types.rs +0 -0
  1877. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component/wast.rs +0 -0
  1878. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/component.rs +0 -0
  1879. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/binary/dwarf_disabled.rs +0 -0
  1880. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/custom.rs +0 -0
  1881. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/export.rs +0 -0
  1882. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/func.rs +0 -0
  1883. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/global.rs +0 -0
  1884. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/import.rs +0 -0
  1885. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/memory.rs +0 -0
  1886. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/resolve/deinline_import_export.rs +0 -0
  1887. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/table.rs +0 -0
  1888. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/tag.rs +0 -0
  1889. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/types.rs +0 -0
  1890. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core/wast.rs +0 -0
  1891. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/core.rs +0 -0
  1892. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/encode.rs +0 -0
  1893. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/error.rs +0 -0
  1894. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/gensym.rs +0 -0
  1895. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/names.rs +0 -0
  1896. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/src/token.rs +0 -0
  1897. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/annotations.rs +0 -0
  1898. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/comments.rs +0 -0
  1899. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-core-func-alias.wat +0 -0
  1900. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-core-func-alias.wat.err +0 -0
  1901. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-func-alias.wat +0 -0
  1902. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-func-alias.wat.err +0 -0
  1903. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-index.wat +0 -0
  1904. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-index.wat.err +0 -0
  1905. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-name.wat +0 -0
  1906. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-name.wat.err +0 -0
  1907. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-name2.wat +0 -0
  1908. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-name2.wat.err +0 -0
  1909. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-name3.wat +0 -0
  1910. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/bad-name3.wat.err +0 -0
  1911. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/block1.wat +0 -0
  1912. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/block1.wat.err +0 -0
  1913. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/block2.wat +0 -0
  1914. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/block2.wat.err +0 -0
  1915. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/block3.wat +0 -0
  1916. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/block3.wat.err +0 -0
  1917. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment0.wat +0 -0
  1918. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment0.wat.err +0 -0
  1919. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment1.wat +0 -0
  1920. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment1.wat.err +0 -0
  1921. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment2.wat +0 -0
  1922. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment2.wat.err +0 -0
  1923. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment3.wat +0 -0
  1924. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment3.wat.err +0 -0
  1925. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment4.wat +0 -0
  1926. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment4.wat.err +0 -0
  1927. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment5.wat +0 -0
  1928. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment5.wat.err +0 -0
  1929. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment6.wat +0 -0
  1930. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment6.wat.err +0 -0
  1931. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment7.wat +0 -0
  1932. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment7.wat.err +0 -0
  1933. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment8.wat +0 -0
  1934. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-block-comment8.wat.err +0 -0
  1935. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment0.wat +0 -0
  1936. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment0.wat.err +0 -0
  1937. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment1.wat +0 -0
  1938. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment1.wat.err +0 -0
  1939. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment2.wat +0 -0
  1940. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment2.wat.err +0 -0
  1941. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment3.wat +0 -0
  1942. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment3.wat.err +0 -0
  1943. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment4.wat +0 -0
  1944. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment4.wat.err +0 -0
  1945. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment5.wat +0 -0
  1946. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment5.wat.err +0 -0
  1947. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment6.wat +0 -0
  1948. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment6.wat.err +0 -0
  1949. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment7.wat +0 -0
  1950. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment7.wat.err +0 -0
  1951. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment8.wat +0 -0
  1952. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-line-comment8.wat.err +0 -0
  1953. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string0.wat +0 -0
  1954. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string0.wat.err +0 -0
  1955. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string1.wat +0 -0
  1956. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string1.wat.err +0 -0
  1957. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string2.wat +0 -0
  1958. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string2.wat.err +0 -0
  1959. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string3.wat +0 -0
  1960. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string3.wat.err +0 -0
  1961. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string4.wat +0 -0
  1962. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string4.wat.err +0 -0
  1963. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string5.wat +0 -0
  1964. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string5.wat.err +0 -0
  1965. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string6.wat +0 -0
  1966. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string6.wat.err +0 -0
  1967. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string7.wat +0 -0
  1968. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string7.wat.err +0 -0
  1969. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string8.wat +0 -0
  1970. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/confusing-string8.wat.err +0 -0
  1971. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/inline1.wat +0 -0
  1972. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/inline1.wat.err +0 -0
  1973. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/newline-in-string.wat +0 -0
  1974. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/newline-in-string.wat.err +0 -0
  1975. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string1.wat +0 -0
  1976. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string1.wat.err +0 -0
  1977. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string10.wat +0 -0
  1978. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string10.wat.err +0 -0
  1979. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string11.wat +0 -0
  1980. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string11.wat.err +0 -0
  1981. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string12.wat +0 -0
  1982. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string12.wat.err +0 -0
  1983. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string13.wat +0 -0
  1984. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string13.wat.err +0 -0
  1985. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string14.wat +0 -0
  1986. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string14.wat.err +0 -0
  1987. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string15.wat +0 -0
  1988. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string15.wat.err +0 -0
  1989. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string16.wat +0 -0
  1990. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string16.wat.err +0 -0
  1991. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string2.wat +0 -0
  1992. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string2.wat.err +0 -0
  1993. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string3.wat +0 -0
  1994. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string3.wat.err +0 -0
  1995. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string4.wat +0 -0
  1996. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string4.wat.err +0 -0
  1997. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string5.wat +0 -0
  1998. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string5.wat.err +0 -0
  1999. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string6.wat +0 -0
  2000. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string6.wat.err +0 -0
  2001. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string7.wat +0 -0
  2002. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string7.wat.err +0 -0
  2003. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string8.wat +0 -0
  2004. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string8.wat.err +0 -0
  2005. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string9.wat +0 -0
  2006. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/string9.wat.err +0 -0
  2007. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/unbalanced.wat +0 -0
  2008. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail/unbalanced.wat.err +0 -0
  2009. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/parse-fail.rs +0 -0
  2010. /data/ext/cargo-vendor/{wast-216.0.0 → wast-217.0.0}/tests/recursive.rs +0 -0
  2011. /data/ext/cargo-vendor/{wat-1.216.0 → wat-1.217.0}/README.md +0 -0
  2012. /data/ext/cargo-vendor/{wat-1.216.0 → wat-1.217.0}/src/lib.rs +0 -0
  2013. /data/ext/cargo-vendor/{wiggle-24.0.0 → wiggle-25.0.1}/LICENSE +0 -0
  2014. /data/ext/cargo-vendor/{wiggle-24.0.0 → wiggle-25.0.1}/README.md +0 -0
  2015. /data/ext/cargo-vendor/{wiggle-24.0.0 → wiggle-25.0.1}/src/error.rs +0 -0
  2016. /data/ext/cargo-vendor/{wiggle-24.0.0 → wiggle-25.0.1}/src/guest_type.rs +0 -0
  2017. /data/ext/cargo-vendor/{wiggle-24.0.0 → wiggle-25.0.1}/src/region.rs +0 -0
  2018. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/LICENSE +0 -0
  2019. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/README.md +0 -0
  2020. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/codegen_settings.rs +0 -0
  2021. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/config.rs +0 -0
  2022. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/lifetimes.rs +0 -0
  2023. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/module_trait.rs +0 -0
  2024. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/types/error.rs +0 -0
  2025. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/types/flags.rs +0 -0
  2026. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/types/handle.rs +0 -0
  2027. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/types/mod.rs +0 -0
  2028. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/types/record.rs +0 -0
  2029. /data/ext/cargo-vendor/{wiggle-generate-24.0.0 → wiggle-generate-25.0.1}/src/types/variant.rs +0 -0
  2030. /data/ext/cargo-vendor/{wiggle-macro-24.0.0 → wiggle-macro-25.0.1}/LICENSE +0 -0
  2031. /data/ext/cargo-vendor/{wiggle-macro-24.0.0 → wiggle-macro-25.0.1}/build.rs +0 -0
  2032. /data/ext/cargo-vendor/{wiggle-macro-24.0.0 → wiggle-macro-25.0.1}/src/lib.rs +0 -0
  2033. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/LICENSE +0 -0
  2034. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/build.rs +0 -0
  2035. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/codegen/builtin.rs +0 -0
  2036. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/codegen/call.rs +0 -0
  2037. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/codegen/control.rs +0 -0
  2038. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/codegen/env.rs +0 -0
  2039. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/frame/mod.rs +0 -0
  2040. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/isa/aarch64/mod.rs +0 -0
  2041. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/isa/aarch64/regs.rs +0 -0
  2042. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/isa/reg.rs +0 -0
  2043. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/isa/x64/address.rs +0 -0
  2044. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/isa/x64/mod.rs +0 -0
  2045. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/isa/x64/regs.rs +0 -0
  2046. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/lib.rs +0 -0
  2047. /data/ext/cargo-vendor/{winch-codegen-0.22.0 → winch-codegen-0.23.1}/src/regset.rs +0 -0
  2048. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/README.md +0 -0
  2049. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/src/abi.rs +0 -0
  2050. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/src/ast/lex.rs +0 -0
  2051. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/src/ast/toposort.rs +0 -0
  2052. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/src/live.rs +0 -0
  2053. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/src/metadata.rs +0 -0
  2054. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/src/resolve.rs +0 -0
  2055. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/src/serde_.rs +0 -0
  2056. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/comments.wit +0 -0
  2057. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/comments.wit.json +0 -0
  2058. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/complex-include/deps/bar/root.wit +0 -0
  2059. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/complex-include/deps/baz/root.wit +0 -0
  2060. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/complex-include/root.wit +0 -0
  2061. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/complex-include.wit.json +0 -0
  2062. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/cross-package-resource/deps/foo/foo.wit +0 -0
  2063. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/cross-package-resource/foo.wit +0 -0
  2064. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/cross-package-resource.wit.json +0 -0
  2065. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/diamond1/deps/dep1/types.wit +0 -0
  2066. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/diamond1/deps/dep2/types.wit +0 -0
  2067. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/diamond1/join.wit +0 -0
  2068. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/diamond1.wit.json +0 -0
  2069. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/disambiguate-diamond/shared1.wit +0 -0
  2070. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/disambiguate-diamond/shared2.wit +0 -0
  2071. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/disambiguate-diamond/world.wit +0 -0
  2072. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/disambiguate-diamond.wit.json +0 -0
  2073. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/empty.wit +0 -0
  2074. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/empty.wit.json +0 -0
  2075. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/feature-gates.wit +0 -0
  2076. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/feature-gates.wit.json +0 -0
  2077. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +0 -0
  2078. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/deps/corp/saas.wit +0 -0
  2079. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +0 -0
  2080. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +0 -0
  2081. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +0 -0
  2082. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/deps/wasi/clocks.wit +0 -0
  2083. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/deps/wasi/filesystem.wit +0 -0
  2084. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps/root.wit +0 -0
  2085. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/another-pkg/other-doc.wit +0 -0
  2086. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/corp/saas.wit +0 -0
  2087. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/different-pkg/the-doc.wit +0 -0
  2088. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/foreign-pkg/the-doc.wit +0 -0
  2089. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/some-pkg/some-doc.wit +0 -0
  2090. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/wasi/clocks.wit +0 -0
  2091. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/wasi/filesystem.wit +0 -0
  2092. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/deps/wasi/wasi.wit +0 -0
  2093. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union/root.wit +0 -0
  2094. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps-union.wit.json +0 -0
  2095. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/foreign-deps.wit.json +0 -0
  2096. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/functions.wit +0 -0
  2097. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/functions.wit.json +0 -0
  2098. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/ignore-files-deps/deps/bar/types.wit +0 -0
  2099. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/ignore-files-deps/deps/ignore-me.txt +0 -0
  2100. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/ignore-files-deps/world.wit +0 -0
  2101. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/ignore-files-deps.wit.json +0 -0
  2102. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/import-export-overlap1.wit +0 -0
  2103. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/import-export-overlap1.wit.json +0 -0
  2104. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/import-export-overlap2.wit +0 -0
  2105. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/import-export-overlap2.wit.json +0 -0
  2106. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/include-reps.wit +0 -0
  2107. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/include-reps.wit.json +0 -0
  2108. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kebab-name-include-with.wit +0 -0
  2109. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kebab-name-include-with.wit.json +0 -0
  2110. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kinds-of-deps/a.wit +0 -0
  2111. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kinds-of-deps/deps/b/root.wit +0 -0
  2112. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kinds-of-deps/deps/c.wit +0 -0
  2113. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kinds-of-deps/deps/d.wat +0 -0
  2114. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kinds-of-deps/deps/e.wasm +0 -0
  2115. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/kinds-of-deps.wit.json +0 -0
  2116. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/many-names/a.wit +0 -0
  2117. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/many-names/b.wit +0 -0
  2118. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/many-names.wit.json +0 -0
  2119. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file/bar.wit +0 -0
  2120. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file/cycle-a.wit +0 -0
  2121. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file/cycle-b.wit +0 -0
  2122. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file/foo.wit +0 -0
  2123. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file-multi-package/a.wit +0 -0
  2124. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file-multi-package/b.wit +0 -0
  2125. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file-multi-package.wit.json +0 -0
  2126. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-file.wit.json +0 -0
  2127. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-deps/deps/dep.wit +0 -0
  2128. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-deps/root.wit +0 -0
  2129. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-deps.wit.json +0 -0
  2130. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-shared-deps/deps/dep1/types.wit +0 -0
  2131. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-shared-deps/deps/dep2/types.wit +0 -0
  2132. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-shared-deps/packages.wit +0 -0
  2133. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-shared-deps.wit.json +0 -0
  2134. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-transitive-deps/deps/dep1/types.wit +0 -0
  2135. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-transitive-deps/deps/dep2/types.wit +0 -0
  2136. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-transitive-deps/packages.wit +0 -0
  2137. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/multi-package-transitive-deps.wit.json +0 -0
  2138. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/name-both-resource-and-type/deps/dep/foo.wit +0 -0
  2139. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/name-both-resource-and-type/foo.wit +0 -0
  2140. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/name-both-resource-and-type.wit.json +0 -0
  2141. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/package-syntax1.wit +0 -0
  2142. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/package-syntax1.wit.json +0 -0
  2143. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/package-syntax3.wit +0 -0
  2144. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/package-syntax3.wit.json +0 -0
  2145. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/package-syntax4.wit +0 -0
  2146. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/package-syntax4.wit.json +0 -0
  2147. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-multiple-nested.wit +0 -0
  2148. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-multiple-nested.wit.json +0 -0
  2149. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-nested-colliding-decl-names.wit +0 -0
  2150. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-nested-colliding-decl-names.wit.json +0 -0
  2151. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-nested-internal-references.wit +0 -0
  2152. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-nested-internal-references.wit.json +0 -0
  2153. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-nested-with-semver.wit +0 -0
  2154. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-nested-with-semver.wit.json +0 -0
  2155. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-single-nested.wit +0 -0
  2156. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/packages-single-nested.wit.json +0 -0
  2157. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/alias-no-type.wit +0 -0
  2158. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/alias-no-type.wit.result +0 -0
  2159. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/async.wit.result +0 -0
  2160. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/async1.wit.result +0 -0
  2161. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated1.wit +0 -0
  2162. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated1.wit.result +0 -0
  2163. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated2.wit +0 -0
  2164. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated2.wit.result +0 -0
  2165. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated3.wit +0 -0
  2166. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated3.wit.result +0 -0
  2167. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated4.wit +0 -0
  2168. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-deprecated4.wit.result +0 -0
  2169. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-function.wit +0 -0
  2170. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-function.wit.result +0 -0
  2171. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-function2.wit +0 -0
  2172. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-function2.wit.result +0 -0
  2173. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-gate1.wit +0 -0
  2174. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-gate1.wit.result +0 -0
  2175. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-gate2.wit +0 -0
  2176. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-gate2.wit.result +0 -0
  2177. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-gate3.wit +0 -0
  2178. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-gate4.wit +0 -0
  2179. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-gate5.wit +0 -0
  2180. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-include1.wit +0 -0
  2181. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-include1.wit.result +0 -0
  2182. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-include2.wit +0 -0
  2183. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-include2.wit.result +0 -0
  2184. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-include3.wit +0 -0
  2185. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-include3.wit.result +0 -0
  2186. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-list.wit +0 -0
  2187. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-list.wit.result +0 -0
  2188. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg1/root.wit +0 -0
  2189. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg2/deps/bar/empty.wit +0 -0
  2190. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg2/root.wit +0 -0
  2191. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +0 -0
  2192. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg3/root.wit +0 -0
  2193. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +0 -0
  2194. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg4/root.wit +0 -0
  2195. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +0 -0
  2196. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg5/root.wit +0 -0
  2197. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +0 -0
  2198. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-pkg6/root.wit +0 -0
  2199. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource1.wit +0 -0
  2200. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource1.wit.result +0 -0
  2201. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource10.wit +0 -0
  2202. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource10.wit.result +0 -0
  2203. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource11.wit +0 -0
  2204. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource11.wit.result +0 -0
  2205. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource12.wit +0 -0
  2206. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource12.wit.result +0 -0
  2207. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource13.wit +0 -0
  2208. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource13.wit.result +0 -0
  2209. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource14.wit +0 -0
  2210. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource14.wit.result +0 -0
  2211. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource15/deps/foo/foo.wit +0 -0
  2212. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource15/foo.wit +0 -0
  2213. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource2.wit +0 -0
  2214. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource2.wit.result +0 -0
  2215. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource3.wit +0 -0
  2216. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource3.wit.result +0 -0
  2217. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource4.wit +0 -0
  2218. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource4.wit.result +0 -0
  2219. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource5.wit +0 -0
  2220. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource5.wit.result +0 -0
  2221. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource6.wit +0 -0
  2222. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource6.wit.result +0 -0
  2223. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource7.wit +0 -0
  2224. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource7.wit.result +0 -0
  2225. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource8.wit +0 -0
  2226. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource8.wit.result +0 -0
  2227. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource9.wit +0 -0
  2228. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-resource9.wit.result +0 -0
  2229. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-since1.wit +0 -0
  2230. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-since1.wit.result +0 -0
  2231. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-since3.wit +0 -0
  2232. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-since3.wit.result +0 -0
  2233. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-world-type1.wit +0 -0
  2234. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/bad-world-type1.wit.result +0 -0
  2235. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/conflicting-package/a.wit +0 -0
  2236. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/conflicting-package/b.wit +0 -0
  2237. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle.wit +0 -0
  2238. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle.wit.result +0 -0
  2239. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle2.wit +0 -0
  2240. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle2.wit.result +0 -0
  2241. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle3.wit +0 -0
  2242. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle3.wit.result +0 -0
  2243. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle4.wit +0 -0
  2244. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle4.wit.result +0 -0
  2245. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle5.wit +0 -0
  2246. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/cycle5.wit.result +0 -0
  2247. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/dangling-type.wit +0 -0
  2248. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/dangling-type.wit.result +0 -0
  2249. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-function-params.wit +0 -0
  2250. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-function-params.wit.result +0 -0
  2251. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-functions.wit +0 -0
  2252. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-functions.wit.result +0 -0
  2253. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-interface.wit +0 -0
  2254. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-interface.wit.result +0 -0
  2255. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-interface2/foo.wit +0 -0
  2256. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-interface2/foo2.wit +0 -0
  2257. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-type.wit +0 -0
  2258. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/duplicate-type.wit.result +0 -0
  2259. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/empty-enum.wit +0 -0
  2260. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/empty-enum.wit.result +0 -0
  2261. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/empty-variant1.wit +0 -0
  2262. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/empty-variant1.wit.result +0 -0
  2263. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/export-twice.wit +0 -0
  2264. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/export-twice.wit.result +0 -0
  2265. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export1.wit +0 -0
  2266. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export1.wit.result +0 -0
  2267. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export2.wit +0 -0
  2268. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export2.wit.result +0 -0
  2269. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export3.wit +0 -0
  2270. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export3.wit.result +0 -0
  2271. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export4.wit +0 -0
  2272. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export4.wit.result +0 -0
  2273. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export5.wit +0 -0
  2274. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-and-export5.wit.result +0 -0
  2275. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-twice.wit +0 -0
  2276. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/import-twice.wit.result +0 -0
  2277. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-cycle.wit +0 -0
  2278. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-cycle.wit.result +0 -0
  2279. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-foreign/deps/bar/empty.wit +0 -0
  2280. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-foreign/root.wit +0 -0
  2281. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-with-id.wit +0 -0
  2282. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-with-id.wit.result +0 -0
  2283. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-with-on-id.wit +0 -0
  2284. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/include-with-on-id.wit.result +0 -0
  2285. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/invalid-toplevel.wit +0 -0
  2286. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/invalid-toplevel.wit.result +0 -0
  2287. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/invalid-type-reference.wit +0 -0
  2288. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/invalid-type-reference.wit.result +0 -0
  2289. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/invalid-type-reference2.wit +0 -0
  2290. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/invalid-type-reference2.wit.result +0 -0
  2291. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit +0 -0
  2292. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit.result +0 -0
  2293. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/kebab-name-include.wit +0 -0
  2294. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/kebab-name-include.wit.result +0 -0
  2295. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/keyword.wit +0 -0
  2296. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/keyword.wit.result +0 -0
  2297. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/missing-main-declaration-initial-main.wit +0 -0
  2298. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/missing-main-declaration-initial-main.wit.result +0 -0
  2299. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/missing-main-declaration-initial-nested.wit +0 -0
  2300. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/missing-main-declaration-initial-nested.wit.result +0 -0
  2301. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/missing-package.wit +0 -0
  2302. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/missing-package.wit.result +0 -0
  2303. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multi-file-missing-delimiter/observe.wit +0 -0
  2304. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multi-file-missing-delimiter/world.wit +0 -0
  2305. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multi-package-deps-share-nest/deps/dep1/types.wit +0 -0
  2306. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multi-package-deps-share-nest/deps/dep2/types.wit +0 -0
  2307. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multi-package-deps-share-nest/root.wit +0 -0
  2308. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multiple-package-docs/a.wit +0 -0
  2309. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multiple-package-docs/b.wit +0 -0
  2310. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multiple-package-inline-cycle.wit +0 -0
  2311. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multiple-package-inline-cycle.wit.result +0 -0
  2312. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multiple-packages-no-scope-blocks.wit +0 -0
  2313. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/multiple-packages-no-scope-blocks.wit.result +0 -0
  2314. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/nested-packages-colliding-names.wit +0 -0
  2315. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/nested-packages-colliding-names.wit.result +0 -0
  2316. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/nested-packages-with-error.wit +0 -0
  2317. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/nested-packages-with-error.wit.result +0 -0
  2318. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/no-access-to-sibling-use/bar.wit +0 -0
  2319. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/no-access-to-sibling-use/foo.wit +0 -0
  2320. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/non-existance-world-include/deps/bar/baz.wit +0 -0
  2321. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/non-existance-world-include/root.wit +0 -0
  2322. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +0 -0
  2323. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/pkg-cycle/root.wit +0 -0
  2324. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +0 -0
  2325. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +0 -0
  2326. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/pkg-cycle2/root.wit +0 -0
  2327. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/resources-multiple-returns-borrow.wit +0 -0
  2328. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/resources-return-borrow.wit +0 -0
  2329. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow1.wit +0 -0
  2330. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow2.wit +0 -0
  2331. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow3.wit +0 -0
  2332. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow3.wit.result +0 -0
  2333. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow4.wit +0 -0
  2334. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow4.wit.result +0 -0
  2335. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow5.wit +0 -0
  2336. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow5.wit.result +0 -0
  2337. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow6.wit +0 -0
  2338. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow7.wit +0 -0
  2339. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow8/deps/baz.wit +0 -0
  2340. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/return-borrow8/foo.wit +0 -0
  2341. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/type-and-resource-same-name/deps/dep/foo.wit +0 -0
  2342. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/type-and-resource-same-name/foo.wit +0 -0
  2343. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/undefined-typed.wit +0 -0
  2344. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/undefined-typed.wit.result +0 -0
  2345. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unknown-interface.wit +0 -0
  2346. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unknown-interface.wit.result +0 -0
  2347. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface1.wit +0 -0
  2348. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface1.wit.result +0 -0
  2349. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface2.wit +0 -0
  2350. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface2.wit.result +0 -0
  2351. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface3.wit +0 -0
  2352. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface3.wit.result +0 -0
  2353. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface4.wit +0 -0
  2354. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-interface4.wit.result +0 -0
  2355. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use1.wit +0 -0
  2356. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use1.wit.result +0 -0
  2357. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use10/bar.wit +0 -0
  2358. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use10/foo.wit +0 -0
  2359. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use2.wit +0 -0
  2360. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use2.wit.result +0 -0
  2361. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use3.wit +0 -0
  2362. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use3.wit.result +0 -0
  2363. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use7.wit +0 -0
  2364. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use7.wit.result +0 -0
  2365. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use8.wit +0 -0
  2366. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use8.wit.result +0 -0
  2367. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use9.wit +0 -0
  2368. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unresolved-use9.wit.result +0 -0
  2369. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/unterminated-string.wit.result +0 -0
  2370. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-and-include-world/deps/bar/baz.wit +0 -0
  2371. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-and-include-world/root.wit +0 -0
  2372. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-conflict.wit +0 -0
  2373. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-conflict.wit.result +0 -0
  2374. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-conflict2.wit +0 -0
  2375. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-conflict2.wit.result +0 -0
  2376. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-conflict3.wit +0 -0
  2377. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-conflict3.wit.result +0 -0
  2378. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-cycle1.wit +0 -0
  2379. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-cycle1.wit.result +0 -0
  2380. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-cycle4.wit +0 -0
  2381. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-cycle4.wit.result +0 -0
  2382. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-shadow1.wit +0 -0
  2383. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-shadow1.wit.result +0 -0
  2384. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-world/deps/bar/baz.wit +0 -0
  2385. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/use-world/root.wit +0 -0
  2386. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/very-nested-packages.wit +0 -0
  2387. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-interface-clash.wit +0 -0
  2388. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-interface-clash.wit.result +0 -0
  2389. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-same-fields2.wit +0 -0
  2390. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-same-fields2.wit.result +0 -0
  2391. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-same-fields3.wit +0 -0
  2392. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-same-fields3.wit.result +0 -0
  2393. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-top-level-func.wit +0 -0
  2394. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-top-level-func.wit.result +0 -0
  2395. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-top-level-func2.wit +0 -0
  2396. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/parse-fail/world-top-level-func2.wit.result +0 -0
  2397. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/random.wit +0 -0
  2398. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/random.wit.json +0 -0
  2399. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-empty.wit +0 -0
  2400. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-empty.wit.json +0 -0
  2401. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-multiple-returns-own.wit +0 -0
  2402. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-multiple-returns-own.wit.json +0 -0
  2403. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-multiple.wit +0 -0
  2404. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-multiple.wit.json +0 -0
  2405. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-return-own.wit +0 -0
  2406. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources-return-own.wit.json +0 -0
  2407. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources.wit +0 -0
  2408. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources.wit.json +0 -0
  2409. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources1.wit +0 -0
  2410. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/resources1.wit.json +0 -0
  2411. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/same-name-import-export.wit +0 -0
  2412. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/same-name-import-export.wit.json +0 -0
  2413. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/shared-types.wit +0 -0
  2414. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/shared-types.wit.json +0 -0
  2415. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/simple-wasm-text.wat +0 -0
  2416. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/simple-wasm-text.wit.json +0 -0
  2417. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/stress-export-elaborate.wit +0 -0
  2418. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/stress-export-elaborate.wit.json +0 -0
  2419. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/type-then-eof.wit +0 -0
  2420. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/type-then-eof.wit.json +0 -0
  2421. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/types.wit +0 -0
  2422. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/types.wit.json +0 -0
  2423. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/union-fuzz-1.wit +0 -0
  2424. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/union-fuzz-1.wit.json +0 -0
  2425. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/union-fuzz-2.wit +0 -0
  2426. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/union-fuzz-2.wit.json +0 -0
  2427. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/use-chain.wit +0 -0
  2428. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/use-chain.wit.json +0 -0
  2429. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/use.wit +0 -0
  2430. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/use.wit.json +0 -0
  2431. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/version-syntax.wit +0 -0
  2432. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/version-syntax.wit.json +0 -0
  2433. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/versions/deps/a1/foo.wit +0 -0
  2434. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/versions/deps/a2/foo.wit +0 -0
  2435. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/versions/foo.wit +0 -0
  2436. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/versions.wit.json +0 -0
  2437. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/wasi.wit +0 -0
  2438. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/wasi.wit.json +0 -0
  2439. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-diamond.wit +0 -0
  2440. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-diamond.wit.json +0 -0
  2441. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-iface-no-collide.wit +0 -0
  2442. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-iface-no-collide.wit.json +0 -0
  2443. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-implicit-import1.wit +0 -0
  2444. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-implicit-import1.wit.json +0 -0
  2445. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-implicit-import2.wit +0 -0
  2446. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-implicit-import2.wit.json +0 -0
  2447. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-implicit-import3.wit +0 -0
  2448. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-implicit-import3.wit.json +0 -0
  2449. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-same-fields4.wit +0 -0
  2450. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-same-fields4.wit.json +0 -0
  2451. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-top-level-funcs.wit +0 -0
  2452. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-top-level-funcs.wit.json +0 -0
  2453. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-top-level-resources.wit +0 -0
  2454. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/world-top-level-resources.wit.json +0 -0
  2455. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/worlds-union-dedup.wit +0 -0
  2456. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/worlds-union-dedup.wit.json +0 -0
  2457. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/worlds-with-types.wit +0 -0
  2458. /data/ext/cargo-vendor/{wit-parser-0.215.0 → wit-parser-0.217.0}/tests/ui/worlds-with-types.wit.json +0 -0
@@ -0,0 +1,4267 @@
1
+ ;; Instruction formats.
2
+ (type MInst
3
+ (enum
4
+ ;; A no-op of zero size.
5
+ (Nop0)
6
+
7
+ ;; A no-op that is one instruction large.
8
+ (Nop4)
9
+
10
+ ;; An ALU operation with two register sources and a register destination.
11
+ (AluRRR
12
+ (alu_op ALUOp)
13
+ (size OperandSize)
14
+ (rd WritableReg)
15
+ (rn Reg)
16
+ (rm Reg))
17
+
18
+ ;; An ALU operation with three register sources and a register destination.
19
+ (AluRRRR
20
+ (alu_op ALUOp3)
21
+ (size OperandSize)
22
+ (rd WritableReg)
23
+ (rn Reg)
24
+ (rm Reg)
25
+ (ra Reg))
26
+
27
+ ;; An ALU operation with a register source and an immediate-12 source, and a register
28
+ ;; destination.
29
+ (AluRRImm12
30
+ (alu_op ALUOp)
31
+ (size OperandSize)
32
+ (rd WritableReg)
33
+ (rn Reg)
34
+ (imm12 Imm12))
35
+
36
+ ;; An ALU operation with a register source and an immediate-logic source, and a register destination.
37
+ (AluRRImmLogic
38
+ (alu_op ALUOp)
39
+ (size OperandSize)
40
+ (rd WritableReg)
41
+ (rn Reg)
42
+ (imml ImmLogic))
43
+
44
+ ;; An ALU operation with a register source and an immediate-shiftamt source, and a register destination.
45
+ (AluRRImmShift
46
+ (alu_op ALUOp)
47
+ (size OperandSize)
48
+ (rd WritableReg)
49
+ (rn Reg)
50
+ (immshift ImmShift))
51
+
52
+ ;; An ALU operation with two register sources, one of which can be shifted, and a register
53
+ ;; destination.
54
+ (AluRRRShift
55
+ (alu_op ALUOp)
56
+ (size OperandSize)
57
+ (rd WritableReg)
58
+ (rn Reg)
59
+ (rm Reg)
60
+ (shiftop ShiftOpAndAmt))
61
+
62
+ ;; An ALU operation with two register sources, one of which can be {zero,sign}-extended and
63
+ ;; shifted, and a register destination.
64
+ (AluRRRExtend
65
+ (alu_op ALUOp)
66
+ (size OperandSize)
67
+ (rd WritableReg)
68
+ (rn Reg)
69
+ (rm Reg)
70
+ (extendop ExtendOp))
71
+
72
+ ;; A bit op instruction with a single register source.
73
+ (BitRR
74
+ (op BitOp)
75
+ (size OperandSize)
76
+ (rd WritableReg)
77
+ (rn Reg))
78
+
79
+ ;; An unsigned (zero-extending) 8-bit load.
80
+ (ULoad8
81
+ (rd WritableReg)
82
+ (mem AMode)
83
+ (flags MemFlags))
84
+
85
+ ;; A signed (sign-extending) 8-bit load.
86
+ (SLoad8
87
+ (rd WritableReg)
88
+ (mem AMode)
89
+ (flags MemFlags))
90
+
91
+ ;; An unsigned (zero-extending) 16-bit load.
92
+ (ULoad16
93
+ (rd WritableReg)
94
+ (mem AMode)
95
+ (flags MemFlags))
96
+
97
+ ;; A signed (sign-extending) 16-bit load.
98
+ (SLoad16
99
+ (rd WritableReg)
100
+ (mem AMode)
101
+ (flags MemFlags))
102
+
103
+ ;; An unsigned (zero-extending) 32-bit load.
104
+ (ULoad32
105
+ (rd WritableReg)
106
+ (mem AMode)
107
+ (flags MemFlags))
108
+
109
+ ;; A signed (sign-extending) 32-bit load.
110
+ (SLoad32
111
+ (rd WritableReg)
112
+ (mem AMode)
113
+ (flags MemFlags))
114
+
115
+ ;; A 64-bit load.
116
+ (ULoad64
117
+ (rd WritableReg)
118
+ (mem AMode)
119
+ (flags MemFlags))
120
+
121
+ ;; An 8-bit store.
122
+ (Store8
123
+ (rd Reg)
124
+ (mem AMode)
125
+ (flags MemFlags))
126
+
127
+ ;; A 16-bit store.
128
+ (Store16
129
+ (rd Reg)
130
+ (mem AMode)
131
+ (flags MemFlags))
132
+
133
+ ;; A 32-bit store.
134
+ (Store32
135
+ (rd Reg)
136
+ (mem AMode)
137
+ (flags MemFlags))
138
+
139
+ ;; A 64-bit store.
140
+ (Store64
141
+ (rd Reg)
142
+ (mem AMode)
143
+ (flags MemFlags))
144
+
145
+ ;; A store of a pair of registers.
146
+ (StoreP64
147
+ (rt Reg)
148
+ (rt2 Reg)
149
+ (mem PairAMode)
150
+ (flags MemFlags))
151
+
152
+ ;; A load of a pair of registers.
153
+ (LoadP64
154
+ (rt WritableReg)
155
+ (rt2 WritableReg)
156
+ (mem PairAMode)
157
+ (flags MemFlags))
158
+
159
+ ;; A MOV instruction. These are encoded as ORR's (AluRRR form).
160
+ ;; The 32-bit version zeroes the top 32 bits of the
161
+ ;; destination, which is effectively an alias for an unsigned
162
+ ;; 32-to-64-bit extension.
163
+ (Mov
164
+ (size OperandSize)
165
+ (rd WritableReg)
166
+ (rm Reg))
167
+
168
+ ;; Like `Move` but with a particular `PReg` source (for implementing CLIF
169
+ ;; instructions like `get_stack_pointer`).
170
+ (MovFromPReg
171
+ (rd WritableReg)
172
+ (rm PReg))
173
+
174
+ ;; Like `Move` but with a particular `PReg` destination (for
175
+ ;; implementing CLIF instructions like `set_pinned_reg`).
176
+ (MovToPReg
177
+ (rd PReg)
178
+ (rm Reg))
179
+
180
+ ;; A MOV[Z,N] with a 16-bit immediate.
181
+ (MovWide
182
+ (op MoveWideOp)
183
+ (rd WritableReg)
184
+ (imm MoveWideConst)
185
+ (size OperandSize))
186
+
187
+ ;; A MOVK with a 16-bit immediate. Modifies its register; we
188
+ ;; model this with a separate input `rn` and output `rd` virtual
189
+ ;; register, with a regalloc constraint to tie them together.
190
+ (MovK
191
+ (rd WritableReg)
192
+ (rn Reg)
193
+ (imm MoveWideConst)
194
+ (size OperandSize))
195
+
196
+
197
+ ;; A sign- or zero-extend operation.
198
+ (Extend
199
+ (rd WritableReg)
200
+ (rn Reg)
201
+ (signed bool)
202
+ (from_bits u8)
203
+ (to_bits u8))
204
+
205
+ ;; A conditional-select operation.
206
+ (CSel
207
+ (rd WritableReg)
208
+ (cond Cond)
209
+ (rn Reg)
210
+ (rm Reg))
211
+
212
+ ;; A conditional-select negation operation.
213
+ (CSNeg
214
+ (rd WritableReg)
215
+ (cond Cond)
216
+ (rn Reg)
217
+ (rm Reg))
218
+
219
+ ;; A conditional-set operation.
220
+ (CSet
221
+ (rd WritableReg)
222
+ (cond Cond))
223
+
224
+ ;; A conditional-set-mask operation.
225
+ (CSetm
226
+ (rd WritableReg)
227
+ (cond Cond))
228
+
229
+ ;; A conditional comparison with a second register.
230
+ (CCmp
231
+ (size OperandSize)
232
+ (rn Reg)
233
+ (rm Reg)
234
+ (nzcv NZCV)
235
+ (cond Cond))
236
+
237
+ ;; A conditional comparison with an immediate.
238
+ (CCmpImm
239
+ (size OperandSize)
240
+ (rn Reg)
241
+ (imm UImm5)
242
+ (nzcv NZCV)
243
+ (cond Cond))
244
+
245
+ ;; A synthetic insn, which is a load-linked store-conditional loop, that has the overall
246
+ ;; effect of atomically modifying a memory location in a particular way. Because we have
247
+ ;; no way to explain to the regalloc about earlyclobber registers, this instruction has
248
+ ;; completely fixed operand registers, and we rely on the RA's coalescing to remove copies
249
+ ;; in the surrounding code to the extent it can. Load- and store-exclusive instructions,
250
+ ;; with acquire-release semantics, are used to access memory. The operand conventions are:
251
+ ;;
252
+ ;; x25 (rd) address
253
+ ;; x26 (rd) second operand for `op`
254
+ ;; x27 (wr) old value
255
+ ;; x24 (wr) scratch reg; value afterwards has no meaning
256
+ ;; x28 (wr) scratch reg; value afterwards has no meaning
257
+ (AtomicRMWLoop
258
+ (ty Type) ;; I8, I16, I32 or I64
259
+ (op AtomicRMWLoopOp)
260
+ (flags MemFlags)
261
+ (addr Reg)
262
+ (operand Reg)
263
+ (oldval WritableReg)
264
+ (scratch1 WritableReg)
265
+ (scratch2 WritableReg))
266
+
267
+ ;; Similar to AtomicRMWLoop, a compare-and-swap operation implemented using a load-linked
268
+ ;; store-conditional loop, with acquire-release semantics.
269
+ ;; Note that the operand conventions, although very similar to AtomicRMWLoop, are different:
270
+ ;;
271
+ ;; x25 (rd) address
272
+ ;; x26 (rd) expected value
273
+ ;; x28 (rd) replacement value
274
+ ;; x27 (wr) old value
275
+ ;; x24 (wr) scratch reg; value afterwards has no meaning
276
+ (AtomicCASLoop
277
+ (ty Type) ;; I8, I16, I32 or I64
278
+ (flags MemFlags)
279
+ (addr Reg)
280
+ (expected Reg)
281
+ (replacement Reg)
282
+ (oldval WritableReg)
283
+ (scratch WritableReg))
284
+
285
+ ;; An atomic read-modify-write operation. These instructions require the
286
+ ;; Large System Extension (LSE) ISA support (FEAT_LSE). The instructions have
287
+ ;; acquire-release semantics.
288
+ (AtomicRMW
289
+ (op AtomicRMWOp)
290
+ (rs Reg)
291
+ (rt WritableReg)
292
+ (rn Reg)
293
+ (ty Type)
294
+ (flags MemFlags))
295
+
296
+ ;; An atomic compare-and-swap operation. These instructions require the
297
+ ;; Large System Extension (LSE) ISA support (FEAT_LSE). The instructions have
298
+ ;; acquire-release semantics.
299
+ (AtomicCAS
300
+ ;; `rd` is really `rs` in the encoded instruction (so `rd` == `rs`); we separate
301
+ ;; them here to have separate use and def vregs for regalloc.
302
+ (rd WritableReg)
303
+ (rs Reg)
304
+ (rt Reg)
305
+ (rn Reg)
306
+ (ty Type)
307
+ (flags MemFlags))
308
+
309
+ ;; Read `access_ty` bits from address `rt`, either 8, 16, 32 or 64-bits, and put
310
+ ;; it in `rn`, optionally zero-extending to fill a word or double word result.
311
+ ;; This instruction is sequentially consistent.
312
+ (LoadAcquire
313
+ (access_ty Type) ;; I8, I16, I32 or I64
314
+ (rt WritableReg)
315
+ (rn Reg)
316
+ (flags MemFlags))
317
+
318
+ ;; Write the lowest `ty` bits of `rt` to address `rn`.
319
+ ;; This instruction is sequentially consistent.
320
+ (StoreRelease
321
+ (access_ty Type) ;; I8, I16, I32 or I64
322
+ (rt Reg)
323
+ (rn Reg)
324
+ (flags MemFlags))
325
+
326
+ ;; A memory fence. This must provide ordering to ensure that, at a minimum, neither loads
327
+ ;; nor stores may move forwards or backwards across the fence. Currently emitted as "dmb
328
+ ;; ish". This instruction is sequentially consistent.
329
+ (Fence)
330
+
331
+ ;; Consumption of speculative data barrier.
332
+ (Csdb)
333
+
334
+ ;; FPU 32-bit move.
335
+ (FpuMove32
336
+ (rd WritableReg)
337
+ (rn Reg))
338
+
339
+ ;; FPU move. Note that this is distinct from a vector-register
340
+ ;; move; moving just 64 bits seems to be significantly faster.
341
+ (FpuMove64
342
+ (rd WritableReg)
343
+ (rn Reg))
344
+
345
+ ;; Vector register move.
346
+ (FpuMove128
347
+ (rd WritableReg)
348
+ (rn Reg))
349
+
350
+ ;; Move to scalar from a vector element.
351
+ (FpuMoveFromVec
352
+ (rd WritableReg)
353
+ (rn Reg)
354
+ (idx u8)
355
+ (size VectorSize))
356
+
357
+ ;; Zero-extend a SIMD & FP scalar to the full width of a vector register.
358
+ ;; 16-bit scalars require half-precision floating-point support (FEAT_FP16).
359
+ (FpuExtend
360
+ (rd WritableReg)
361
+ (rn Reg)
362
+ (size ScalarSize))
363
+
364
+ ;; 1-op FPU instruction.
365
+ (FpuRR
366
+ (fpu_op FPUOp1)
367
+ (size ScalarSize)
368
+ (rd WritableReg)
369
+ (rn Reg))
370
+
371
+ ;; 2-op FPU instruction.
372
+ (FpuRRR
373
+ (fpu_op FPUOp2)
374
+ (size ScalarSize)
375
+ (rd WritableReg)
376
+ (rn Reg)
377
+ (rm Reg))
378
+
379
+ (FpuRRI
380
+ (fpu_op FPUOpRI)
381
+ (rd WritableReg)
382
+ (rn Reg))
383
+
384
+ ;; Variant of FpuRRI that modifies its `rd`, and so we name the
385
+ ;; input state `ri` (for "input") and constrain the two
386
+ ;; together.
387
+ (FpuRRIMod
388
+ (fpu_op FPUOpRIMod)
389
+ (rd WritableReg)
390
+ (ri Reg)
391
+ (rn Reg))
392
+
393
+
394
+ ;; 3-op FPU instruction.
395
+ ;; 16-bit scalars require half-precision floating-point support (FEAT_FP16).
396
+ (FpuRRRR
397
+ (fpu_op FPUOp3)
398
+ (size ScalarSize)
399
+ (rd WritableReg)
400
+ (rn Reg)
401
+ (rm Reg)
402
+ (ra Reg))
403
+
404
+ ;; FPU comparison.
405
+ (FpuCmp
406
+ (size ScalarSize)
407
+ (rn Reg)
408
+ (rm Reg))
409
+
410
+ ;; Floating-point load, half-precision (16 bit).
411
+ (FpuLoad16
412
+ (rd WritableReg)
413
+ (mem AMode)
414
+ (flags MemFlags))
415
+
416
+ ;; Floating-point store, half-precision (16 bit).
417
+ (FpuStore16
418
+ (rd Reg)
419
+ (mem AMode)
420
+ (flags MemFlags))
421
+
422
+ ;; Floating-point load, single-precision (32 bit).
423
+ (FpuLoad32
424
+ (rd WritableReg)
425
+ (mem AMode)
426
+ (flags MemFlags))
427
+
428
+ ;; Floating-point store, single-precision (32 bit).
429
+ (FpuStore32
430
+ (rd Reg)
431
+ (mem AMode)
432
+ (flags MemFlags))
433
+
434
+ ;; Floating-point load, double-precision (64 bit).
435
+ (FpuLoad64
436
+ (rd WritableReg)
437
+ (mem AMode)
438
+ (flags MemFlags))
439
+
440
+ ;; Floating-point store, double-precision (64 bit).
441
+ (FpuStore64
442
+ (rd Reg)
443
+ (mem AMode)
444
+ (flags MemFlags))
445
+
446
+ ;; Floating-point/vector load, 128 bit.
447
+ (FpuLoad128
448
+ (rd WritableReg)
449
+ (mem AMode)
450
+ (flags MemFlags))
451
+
452
+ ;; Floating-point/vector store, 128 bit.
453
+ (FpuStore128
454
+ (rd Reg)
455
+ (mem AMode)
456
+ (flags MemFlags))
457
+
458
+ ;; A load of a pair of floating-point registers, double precision (64-bit).
459
+ (FpuLoadP64
460
+ (rt WritableReg)
461
+ (rt2 WritableReg)
462
+ (mem PairAMode)
463
+ (flags MemFlags))
464
+
465
+ ;; A store of a pair of floating-point registers, double precision (64-bit).
466
+ (FpuStoreP64
467
+ (rt Reg)
468
+ (rt2 Reg)
469
+ (mem PairAMode)
470
+ (flags MemFlags))
471
+
472
+ ;; A load of a pair of floating-point registers, 128-bit.
473
+ (FpuLoadP128
474
+ (rt WritableReg)
475
+ (rt2 WritableReg)
476
+ (mem PairAMode)
477
+ (flags MemFlags))
478
+
479
+ ;; A store of a pair of floating-point registers, 128-bit.
480
+ (FpuStoreP128
481
+ (rt Reg)
482
+ (rt2 Reg)
483
+ (mem PairAMode)
484
+ (flags MemFlags))
485
+
486
+ ;; Conversion: FP -> integer.
487
+ (FpuToInt
488
+ (op FpuToIntOp)
489
+ (rd WritableReg)
490
+ (rn Reg))
491
+
492
+ ;; Conversion: integer -> FP.
493
+ (IntToFpu
494
+ (op IntToFpuOp)
495
+ (rd WritableReg)
496
+ (rn Reg))
497
+
498
+ ;; FP conditional select, 16 bit.
499
+ ;; Requires FEAT_FP16.
500
+ (FpuCSel16
501
+ (rd WritableReg)
502
+ (rn Reg)
503
+ (rm Reg)
504
+ (cond Cond))
505
+
506
+ ;; FP conditional select, 32 bit.
507
+ (FpuCSel32
508
+ (rd WritableReg)
509
+ (rn Reg)
510
+ (rm Reg)
511
+ (cond Cond))
512
+
513
+ ;; FP conditional select, 64 bit.
514
+ (FpuCSel64
515
+ (rd WritableReg)
516
+ (rn Reg)
517
+ (rm Reg)
518
+ (cond Cond))
519
+
520
+ ;; Round to integer.
521
+ (FpuRound
522
+ (op FpuRoundMode)
523
+ (rd WritableReg)
524
+ (rn Reg))
525
+
526
+ ;; Move from a GPR to a vector register. The scalar value is parked in the lowest lane
527
+ ;; of the destination, and all other lanes are zeroed out. Currently 16-, 32- and 64-bit
528
+ ;; transactions are supported. 16-bit moves require FEAT_FP16.
529
+ (MovToFpu
530
+ (rd WritableReg)
531
+ (rn Reg)
532
+ (size ScalarSize))
533
+
534
+ ;; Loads a floating-point immediate.
535
+ (FpuMoveFPImm
536
+ (rd WritableReg)
537
+ (imm ASIMDFPModImm)
538
+ (size ScalarSize))
539
+
540
+ ;; Move to a vector element from a GPR.
541
+ (MovToVec
542
+ (rd WritableReg)
543
+ (ri Reg)
544
+ (rn Reg)
545
+ (idx u8)
546
+ (size VectorSize))
547
+
548
+ ;; Unsigned move from a vector element to a GPR.
549
+ (MovFromVec
550
+ (rd WritableReg)
551
+ (rn Reg)
552
+ (idx u8)
553
+ (size ScalarSize))
554
+
555
+ ;; Signed move from a vector element to a GPR.
556
+ (MovFromVecSigned
557
+ (rd WritableReg)
558
+ (rn Reg)
559
+ (idx u8)
560
+ (size VectorSize)
561
+ (scalar_size OperandSize))
562
+
563
+ ;; Duplicate general-purpose register to vector.
564
+ (VecDup
565
+ (rd WritableReg)
566
+ (rn Reg)
567
+ (size VectorSize))
568
+
569
+ ;; Duplicate scalar to vector.
570
+ (VecDupFromFpu
571
+ (rd WritableReg)
572
+ (rn Reg)
573
+ (size VectorSize)
574
+ (lane u8))
575
+
576
+ ;; Duplicate FP immediate to vector.
577
+ (VecDupFPImm
578
+ (rd WritableReg)
579
+ (imm ASIMDFPModImm)
580
+ (size VectorSize))
581
+
582
+ ;; Duplicate immediate to vector.
583
+ (VecDupImm
584
+ (rd WritableReg)
585
+ (imm ASIMDMovModImm)
586
+ (invert bool)
587
+ (size VectorSize))
588
+
589
+ ;; Vector extend.
590
+ (VecExtend
591
+ (t VecExtendOp)
592
+ (rd WritableReg)
593
+ (rn Reg)
594
+ (high_half bool)
595
+ (lane_size ScalarSize))
596
+
597
+ ;; Move vector element to another vector element.
598
+ (VecMovElement
599
+ (rd WritableReg)
600
+ (ri Reg)
601
+ (rn Reg)
602
+ (dest_idx u8)
603
+ (src_idx u8)
604
+ (size VectorSize))
605
+
606
+ ;; Vector widening operation.
607
+ (VecRRLong
608
+ (op VecRRLongOp)
609
+ (rd WritableReg)
610
+ (rn Reg)
611
+ (high_half bool))
612
+
613
+ ;; Vector narrowing operation -- low half.
614
+ (VecRRNarrowLow
615
+ (op VecRRNarrowOp)
616
+ (rd WritableReg)
617
+ (rn Reg)
618
+ (lane_size ScalarSize))
619
+
620
+ ;; Vector narrowing operation -- high half.
621
+ (VecRRNarrowHigh
622
+ (op VecRRNarrowOp)
623
+ (rd WritableReg)
624
+ (ri Reg)
625
+ (rn Reg)
626
+ (lane_size ScalarSize))
627
+
628
+ ;; 1-operand vector instruction that operates on a pair of elements.
629
+ (VecRRPair
630
+ (op VecPairOp)
631
+ (rd WritableReg)
632
+ (rn Reg))
633
+
634
+ ;; 2-operand vector instruction that produces a result with twice the
635
+ ;; lane width and half the number of lanes.
636
+ (VecRRRLong
637
+ (alu_op VecRRRLongOp)
638
+ (rd WritableReg)
639
+ (rn Reg)
640
+ (rm Reg)
641
+ (high_half bool))
642
+
643
+ ;; 2-operand vector instruction that produces a result with
644
+ ;; twice the lane width and half the number of lanes. Variant
645
+ ;; that modifies `rd` (so takes its initial state as `ri`).
646
+ (VecRRRLongMod
647
+ (alu_op VecRRRLongModOp)
648
+ (rd WritableReg)
649
+ (ri Reg)
650
+ (rn Reg)
651
+ (rm Reg)
652
+ (high_half bool))
653
+
654
+ ;; 1-operand vector instruction that extends elements of the input
655
+ ;; register and operates on a pair of elements. The output lane width
656
+ ;; is double that of the input.
657
+ (VecRRPairLong
658
+ (op VecRRPairLongOp)
659
+ (rd WritableReg)
660
+ (rn Reg))
661
+
662
+ ;; A vector ALU op.
663
+ (VecRRR
664
+ (alu_op VecALUOp)
665
+ (rd WritableReg)
666
+ (rn Reg)
667
+ (rm Reg)
668
+ (size VectorSize))
669
+
670
+ ;; A vector ALU op modifying a source register.
671
+ (VecRRRMod
672
+ (alu_op VecALUModOp)
673
+ (rd WritableReg)
674
+ (ri Reg)
675
+ (rn Reg)
676
+ (rm Reg)
677
+ (size VectorSize))
678
+
679
+ ;; A vector ALU op modifying a source register.
680
+ (VecFmlaElem
681
+ (alu_op VecALUModOp)
682
+ (rd WritableReg)
683
+ (ri Reg)
684
+ (rn Reg)
685
+ (rm Reg)
686
+ (size VectorSize)
687
+ (idx u8))
688
+
689
+ ;; Vector two register miscellaneous instruction.
690
+ (VecMisc
691
+ (op VecMisc2)
692
+ (rd WritableReg)
693
+ (rn Reg)
694
+ (size VectorSize))
695
+
696
+ ;; Vector instruction across lanes.
697
+ (VecLanes
698
+ (op VecLanesOp)
699
+ (rd WritableReg)
700
+ (rn Reg)
701
+ (size VectorSize))
702
+
703
+ ;; Vector shift by immediate Shift Left (immediate), Unsigned Shift Right (immediate)
704
+ ;; Signed Shift Right (immediate). These are somewhat unusual in that, for right shifts,
705
+ ;; the allowed range of `imm` values is 1 to lane-size-in-bits, inclusive. A zero
706
+ ;; right-shift cannot be encoded. Left shifts are "normal", though, having valid `imm`
707
+ ;; values from 0 to lane-size-in-bits - 1 inclusive.
708
+ (VecShiftImm
709
+ (op VecShiftImmOp)
710
+ (rd WritableReg)
711
+ (rn Reg)
712
+ (size VectorSize)
713
+ (imm u8))
714
+
715
+ ;; Destructive vector shift by immediate.
716
+ (VecShiftImmMod
717
+ (op VecShiftImmModOp)
718
+ (rd WritableReg)
719
+ (ri Reg)
720
+ (rn Reg)
721
+ (size VectorSize)
722
+ (imm u8))
723
+
724
+ ;; Vector extract - create a new vector, being the concatenation of the lowest `imm4` bytes
725
+ ;; of `rm` followed by the uppermost `16 - imm4` bytes of `rn`.
726
+ (VecExtract
727
+ (rd WritableReg)
728
+ (rn Reg)
729
+ (rm Reg)
730
+ (imm4 u8))
731
+
732
+ ;; Table vector lookup - single register table. The table
733
+ ;; consists of 8-bit elements and is stored in `rn`, while `rm`
734
+ ;; contains 8-bit element indices. This variant emits `TBL`,
735
+ ;; which sets elements that correspond to out-of-range indices
736
+ ;; (greater than 15) to 0.
737
+ (VecTbl
738
+ (rd WritableReg)
739
+ (rn Reg)
740
+ (rm Reg))
741
+
742
+ ;; Table vector lookup - single register table. The table
743
+ ;; consists of 8-bit elements and is stored in `rn`, while `rm`
744
+ ;; contains 8-bit element indices. This variant emits `TBX`,
745
+ ;; which leaves elements that correspond to out-of-range indices
746
+ ;; (greater than 15) unmodified. Hence, it takes an input vreg in
747
+ ;; `ri` that is constrained to the same allocation as `rd`.
748
+ (VecTblExt
749
+ (rd WritableReg)
750
+ (ri Reg)
751
+ (rn Reg)
752
+ (rm Reg))
753
+
754
+ ;; Table vector lookup - two register table. The table consists
755
+ ;; of 8-bit elements and is stored in `rn` and `rn2`, while
756
+ ;; `rm` contains 8-bit element indices. The table registers
757
+ ;; `rn` and `rn2` must have consecutive numbers modulo 32, that
758
+ ;; is v31 and v0 (in that order) are consecutive registers.
759
+ ;; This variant emits `TBL`, which sets out-of-range results to
760
+ ;; 0.
761
+ (VecTbl2
762
+ (rd WritableReg)
763
+ (rn Reg)
764
+ (rn2 Reg)
765
+ (rm Reg))
766
+
767
+ ;; Table vector lookup - two register table. The table consists
768
+ ;; of 8-bit elements and is stored in `rn` and `rn2`, while
769
+ ;; `rm` contains 8-bit element indices. The table registers
770
+ ;; `rn` and `rn2` must have consecutive numbers modulo 32, that
771
+ ;; is v31 and v0 (in that order) are consecutive registers.
772
+ ;; This variant emits `TBX`, which leaves out-of-range results
773
+ ;; unmodified, hence takes the initial state of the result
774
+ ;; register in vreg `ri`.
775
+ (VecTbl2Ext
776
+ (rd WritableReg)
777
+ (ri Reg)
778
+ (rn Reg)
779
+ (rn2 Reg)
780
+ (rm Reg))
781
+
782
+ ;; Load an element and replicate to all lanes of a vector.
783
+ (VecLoadReplicate
784
+ (rd WritableReg)
785
+ (rn Reg)
786
+ (size VectorSize)
787
+ (flags MemFlags))
788
+
789
+ ;; Vector conditional select, 128 bit. A synthetic instruction, which generates a 4-insn
790
+ ;; control-flow diamond.
791
+ (VecCSel
792
+ (rd WritableReg)
793
+ (rn Reg)
794
+ (rm Reg)
795
+ (cond Cond))
796
+
797
+ ;; Move to the NZCV flags (actually a `MSR NZCV, Xn` insn).
798
+ (MovToNZCV
799
+ (rn Reg))
800
+
801
+ ;; Move from the NZCV flags (actually a `MRS Xn, NZCV` insn).
802
+ (MovFromNZCV
803
+ (rd WritableReg))
804
+
805
+ ;; A machine call instruction. N.B.: this allows only a +/- 128MB offset (it uses a relocation
806
+ ;; of type `Reloc::Arm64Call`); if the destination distance is not `RelocDistance::Near`, the
807
+ ;; code should use a `LoadExtName` / `CallInd` sequence instead, allowing an arbitrary 64-bit
808
+ ;; target.
809
+ (Call (info BoxCallInfo))
810
+
811
+ ;; A machine indirect-call instruction.
812
+ (CallInd (info BoxCallIndInfo))
813
+
814
+ ;; A return-call macro instruction.
815
+ (ReturnCall (info BoxReturnCallInfo))
816
+
817
+ ;; An indirect return-call macro instruction.
818
+ (ReturnCallInd (info BoxReturnCallIndInfo))
819
+
820
+ ;; A pseudo-instruction that captures register arguments in vregs.
821
+ (Args
822
+ (args VecArgPair))
823
+
824
+ ;; A pseudo-instruction that moves vregs to return registers.
825
+ (Rets
826
+ (rets VecRetPair))
827
+
828
+ ;; ---- branches (exactly one must appear at end of BB) ----
829
+
830
+ ;; A machine return instruction.
831
+ (Ret)
832
+
833
+ ;; A machine return instruction with pointer authentication using SP as the
834
+ ;; modifier. This instruction requires pointer authentication support
835
+ ;; (FEAT_PAuth) unless `is_hint` is true, in which case it is equivalent to
836
+ ;; the combination of a no-op and a return instruction on platforms without
837
+ ;; the relevant support.
838
+ (AuthenticatedRet
839
+ (key APIKey)
840
+ (is_hint bool))
841
+
842
+ ;; An unconditional branch.
843
+ (Jump
844
+ (dest BranchTarget))
845
+
846
+ ;; A conditional branch. Contains two targets; at emission time, both are emitted, but
847
+ ;; the MachBuffer knows to truncate the trailing branch if fallthrough. We optimize the
848
+ ;; choice of taken/not_taken (inverting the branch polarity as needed) based on the
849
+ ;; fallthrough at the time of lowering.
850
+ (CondBr
851
+ (taken BranchTarget)
852
+ (not_taken BranchTarget)
853
+ (kind CondBrKind))
854
+
855
+ ;; A conditional branch which tests the `bit` of `rn` and branches
856
+ ;; depending on `kind`.
857
+ (TestBitAndBranch
858
+ (kind TestBitAndBranchKind)
859
+ (taken BranchTarget)
860
+ (not_taken BranchTarget)
861
+ (rn Reg)
862
+ (bit u8))
863
+
864
+ ;; A conditional trap: execute a `udf` if the condition is true. This is
865
+ ;; one VCode instruction because it uses embedded control flow; it is
866
+ ;; logically a single-in, single-out region, but needs to appear as one
867
+ ;; unit to the register allocator.
868
+ ;;
869
+ ;; The `CondBrKind` gives the conditional-branch condition that will
870
+ ;; *execute* the embedded `Inst`. (In the emitted code, we use the inverse
871
+ ;; of this condition in a branch that skips the trap instruction.)
872
+ (TrapIf
873
+ (kind CondBrKind)
874
+ (trap_code TrapCode))
875
+
876
+ ;; An indirect branch through a register, augmented with set of all
877
+ ;; possible successors.
878
+ (IndirectBr
879
+ (rn Reg)
880
+ (targets VecMachLabel))
881
+
882
+ ;; A "break" instruction, used for e.g. traps and debug breakpoints.
883
+ (Brk)
884
+
885
+ ;; An instruction guaranteed to always be undefined and to trigger an illegal instruction at
886
+ ;; runtime.
887
+ (Udf
888
+ (trap_code TrapCode))
889
+
890
+ ;; Compute the address (using a PC-relative offset) of a memory location, using the `ADR`
891
+ ;; instruction. Note that we take a simple offset, not a `MemLabel`, here, because `Adr` is
892
+ ;; only used for now in fixed lowering sequences with hardcoded offsets. In the future we may
893
+ ;; need full `MemLabel` support.
894
+ (Adr
895
+ (rd WritableReg)
896
+ ;; Offset in range -2^20 .. 2^20.
897
+ (off i32))
898
+
899
+ ;; Compute the address (using a PC-relative offset) of a 4KB page.
900
+ (Adrp
901
+ (rd WritableReg)
902
+ (off i32))
903
+
904
+ ;; Raw 32-bit word, used for inline constants and jump-table entries.
905
+ (Word4
906
+ (data u32))
907
+
908
+ ;; Raw 64-bit word, used for inline constants.
909
+ (Word8
910
+ (data u64))
911
+
912
+ ;; Jump-table sequence, as one compound instruction (see note in lower_inst.rs for rationale).
913
+ (JTSequence
914
+ (default MachLabel)
915
+ (targets BoxVecMachLabel)
916
+ (ridx Reg)
917
+ (rtmp1 WritableReg)
918
+ (rtmp2 WritableReg))
919
+
920
+ ;; Load an inline symbol reference.
921
+ (LoadExtName
922
+ (rd WritableReg)
923
+ (name BoxExternalName)
924
+ (offset i64))
925
+
926
+ ;; Load address referenced by `mem` into `rd`.
927
+ (LoadAddr
928
+ (rd WritableReg)
929
+ (mem AMode))
930
+
931
+ ;; Pointer authentication code for instruction address with modifier in SP;
932
+ ;; equivalent to a no-op if Pointer authentication (FEAT_PAuth) is not
933
+ ;; supported.
934
+ (Paci
935
+ (key APIKey))
936
+
937
+ ;; Strip pointer authentication code from instruction address in LR;
938
+ ;; equivalent to a no-op if Pointer authentication (FEAT_PAuth) is not
939
+ ;; supported.
940
+ (Xpaclri)
941
+
942
+ ;; Branch target identification; equivalent to a no-op if Branch Target
943
+ ;; Identification (FEAT_BTI) is not supported.
944
+ (Bti
945
+ (targets BranchTargetType))
946
+
947
+ ;; Meta-insn, no-op in generated code: emit constant/branch veneer island
948
+ ;; at this point (with a guard jump around it) if less than the needed
949
+ ;; space is available before the next branch deadline. See the `MachBuffer`
950
+ ;; implementation in `machinst/buffer.rs` for the overall algorithm. In
951
+ ;; brief, we retain a set of "pending/unresolved label references" from
952
+ ;; branches as we scan forward through instructions to emit machine code;
953
+ ;; if we notice we're about to go out of range on an unresolved reference,
954
+ ;; we stop, emit a bunch of "veneers" (branches in a form that has a longer
955
+ ;; range, e.g. a 26-bit-offset unconditional jump), and point the original
956
+ ;; label references to those. This is an "island" because it comes in the
957
+ ;; middle of the code.
958
+ ;;
959
+ ;; This meta-instruction is a necessary part of the logic that determines
960
+ ;; where to place islands. Ordinarily, we want to place them between basic
961
+ ;; blocks, so we compute the worst-case size of each block, and emit the
962
+ ;; island before starting a block if we would exceed a deadline before the
963
+ ;; end of the block. However, some sequences (such as an inline jumptable)
964
+ ;; are variable-length and not accounted for by this logic; so these
965
+ ;; lowered sequences include an `EmitIsland` to trigger island generation
966
+ ;; where necessary.
967
+ (EmitIsland
968
+ ;; The needed space before the next deadline.
969
+ (needed_space CodeOffset))
970
+
971
+ ;; A call to the `ElfTlsGetAddr` libcall. Returns address of TLS symbol in x0.
972
+ (ElfTlsGetAddr
973
+ (symbol BoxExternalName)
974
+ (rd WritableReg)
975
+ (tmp WritableReg))
976
+
977
+ (MachOTlsGetAddr
978
+ (symbol ExternalName)
979
+ (rd WritableReg))
980
+
981
+ ;; An unwind pseudo-instruction.
982
+ (Unwind
983
+ (inst UnwindInst))
984
+
985
+ ;; A dummy use, useful to keep a value alive.
986
+ (DummyUse
987
+ (reg Reg))
988
+
989
+ ;; Emits an inline stack probe loop.
990
+ ;;
991
+ ;; Note that this is emitted post-regalloc so `start` and `end` can be
992
+ ;; temporary registers such as the spilltmp and tmp2 registers. This also
993
+ ;; means that the internal codegen can't use these registers.
994
+ (StackProbeLoop (start WritableReg)
995
+ (end Reg)
996
+ (step Imm12))))
997
+
998
+ ;; An ALU operation. This can be paired with several instruction formats
999
+ ;; below (see `Inst`) in any combination.
1000
+ (type ALUOp
1001
+ (enum
1002
+ (Add)
1003
+ (Sub)
1004
+ (Orr)
1005
+ (OrrNot)
1006
+ (And)
1007
+ (AndS)
1008
+ (AndNot)
1009
+ ;; XOR (AArch64 calls this "EOR")
1010
+ (Eor)
1011
+ ;; XNOR (AArch64 calls this "EOR-NOT")
1012
+ (EorNot)
1013
+ ;; Add, setting flags
1014
+ (AddS)
1015
+ ;; Sub, setting flags
1016
+ (SubS)
1017
+ ;; Signed multiply, high-word result
1018
+ (SMulH)
1019
+ ;; Unsigned multiply, high-word result
1020
+ (UMulH)
1021
+ (SDiv)
1022
+ (UDiv)
1023
+ (RotR)
1024
+ (Lsr)
1025
+ (Asr)
1026
+ (Lsl)
1027
+ ;; Add with carry
1028
+ (Adc)
1029
+ ;; Add with carry, settings flags
1030
+ (AdcS)
1031
+ ;; Subtract with carry
1032
+ (Sbc)
1033
+ ;; Subtract with carry, settings flags
1034
+ (SbcS)
1035
+ ))
1036
+
1037
+ ;; An ALU operation with three arguments.
1038
+ (type ALUOp3
1039
+ (enum
1040
+ ;; Multiply-add
1041
+ (MAdd)
1042
+ ;; Multiply-sub
1043
+ (MSub)
1044
+ ;; Unsigned-Multiply-add
1045
+ (UMAddL)
1046
+ ;; Signed-Multiply-add
1047
+ (SMAddL)
1048
+ ))
1049
+
1050
+ (type MoveWideOp
1051
+ (enum
1052
+ (MovZ)
1053
+ (MovN)
1054
+ ))
1055
+
1056
+ (type UImm5 (primitive UImm5))
1057
+ (type Imm12 (primitive Imm12))
1058
+ (type ImmLogic (primitive ImmLogic))
1059
+ (type ImmShift (primitive ImmShift))
1060
+ (type ShiftOpAndAmt (primitive ShiftOpAndAmt))
1061
+ (type MoveWideConst (primitive MoveWideConst))
1062
+ (type NZCV (primitive NZCV))
1063
+ (type ASIMDFPModImm (primitive ASIMDFPModImm))
1064
+ (type ASIMDMovModImm (primitive ASIMDMovModImm))
1065
+ (type SImm7Scaled (primitive SImm7Scaled))
1066
+
1067
+ (type BoxCallInfo (primitive BoxCallInfo))
1068
+ (type BoxCallIndInfo (primitive BoxCallIndInfo))
1069
+ (type BoxReturnCallInfo (primitive BoxReturnCallInfo))
1070
+ (type BoxReturnCallIndInfo (primitive BoxReturnCallIndInfo))
1071
+ (type CondBrKind (primitive CondBrKind))
1072
+ (type BranchTarget (primitive BranchTarget))
1073
+ (type BoxJTSequenceInfo (primitive BoxJTSequenceInfo))
1074
+ (type CodeOffset (primitive CodeOffset))
1075
+ (type VecMachLabel extern (enum))
1076
+
1077
+ (type ExtendOp extern
1078
+ (enum
1079
+ (UXTB)
1080
+ (UXTH)
1081
+ (UXTW)
1082
+ (UXTX)
1083
+ (SXTB)
1084
+ (SXTH)
1085
+ (SXTW)
1086
+ (SXTX)
1087
+ ))
1088
+
1089
+ ;; An operation on the bits of a register. This can be paired with several instruction formats
1090
+ ;; below (see `Inst`) in any combination.
1091
+ (type BitOp
1092
+ (enum
1093
+ ;; Bit reverse
1094
+ (RBit)
1095
+ (Clz)
1096
+ (Cls)
1097
+ ;; Byte reverse
1098
+ (Rev16)
1099
+ (Rev32)
1100
+ (Rev64)
1101
+ ))
1102
+
1103
+ (type MemLabel extern (enum))
1104
+ (type SImm9 extern (enum))
1105
+ (type UImm12Scaled extern (enum))
1106
+
1107
+ ;; An addressing mode specified for a load/store operation.
1108
+ (type AMode
1109
+ (enum
1110
+ ;;
1111
+ ;; Real ARM64 addressing modes:
1112
+ ;;
1113
+ ;; "post-indexed" mode as per AArch64 docs: postincrement reg after
1114
+ ;; address computation.
1115
+ ;; Specialized here to SP so we don't have to emit regalloc metadata.
1116
+ (SPPostIndexed
1117
+ (simm9 SImm9))
1118
+
1119
+ ;; "pre-indexed" mode as per AArch64 docs: preincrement reg before
1120
+ ;; address computation.
1121
+ ;; Specialized here to SP so we don't have to emit regalloc metadata.
1122
+ (SPPreIndexed
1123
+ (simm9 SImm9))
1124
+
1125
+ ;; N.B.: RegReg, RegScaled, and RegScaledExtended all correspond to
1126
+ ;; what the ISA calls the "register offset" addressing mode. We split
1127
+ ;; out several options here for more ergonomic codegen.
1128
+ ;;
1129
+ ;; Register plus register offset.
1130
+ (RegReg
1131
+ (rn Reg)
1132
+ (rm Reg))
1133
+
1134
+ ;; Register plus register offset, scaled by type's size.
1135
+ (RegScaled
1136
+ (rn Reg)
1137
+ (rm Reg))
1138
+
1139
+ ;; Register plus register offset, scaled by type's size, with index
1140
+ ;; sign- or zero-extended first.
1141
+ (RegScaledExtended
1142
+ (rn Reg)
1143
+ (rm Reg)
1144
+ (extendop ExtendOp))
1145
+
1146
+ ;; Register plus register offset, with index sign- or zero-extended
1147
+ ;; first.
1148
+ (RegExtended
1149
+ (rn Reg)
1150
+ (rm Reg)
1151
+ (extendop ExtendOp))
1152
+
1153
+ ;; Unscaled signed 9-bit immediate offset from reg.
1154
+ (Unscaled
1155
+ (rn Reg)
1156
+ (simm9 SImm9))
1157
+
1158
+ ;; Scaled (by size of a type) unsigned 12-bit immediate offset from reg.
1159
+ (UnsignedOffset
1160
+ (rn Reg)
1161
+ (uimm12 UImm12Scaled))
1162
+
1163
+ ;; virtual addressing modes that are lowered at emission time:
1164
+ ;;
1165
+ ;; Reference to a "label": e.g., a symbol.
1166
+ (Label
1167
+ (label MemLabel))
1168
+
1169
+ ;; Arbitrary offset from a register. Converted to generation of large
1170
+ ;; offsets with multiple instructions as necessary during code emission.
1171
+ (RegOffset
1172
+ (rn Reg)
1173
+ (off i64))
1174
+
1175
+ ;; Offset from the stack pointer.
1176
+ (SPOffset
1177
+ (off i64))
1178
+
1179
+ ;; Offset from the frame pointer.
1180
+ (FPOffset
1181
+ (off i64))
1182
+
1183
+ ;; A reference to a constant which is placed outside of the function's
1184
+ ;; body, typically at the end.
1185
+ (Const
1186
+ (addr VCodeConstant))
1187
+
1188
+ ;; Offset from the beginning of the argument area to the argument
1189
+ ;; referenced. This can only be determined when the function has been
1190
+ ;; processed fully, as the size of the argument area after the prologue
1191
+ ;; is only known once all return_call instructions in the function body
1192
+ ;; have been processed.
1193
+ (IncomingArg
1194
+ (off i64))
1195
+
1196
+ ;; Offset into the slot area of the stack, which lies just above the
1197
+ ;; outgoing argument area that's setup by the function prologue.
1198
+ ;; At emission time, this is converted to `SPOffset` with a fixup added to
1199
+ ;; the offset constant. The fixup is a running value that is tracked as
1200
+ ;; emission iterates through instructions in linear order, and can be
1201
+ ;; adjusted up and down with [Inst::VirtualSPOffsetAdj].
1202
+ ;;
1203
+ ;; The standard ABI is in charge of handling this (by emitting the
1204
+ ;; adjustment meta-instructions). See the diagram in the documentation
1205
+ ;; for [crate::isa::aarch64::abi](the ABI module) for more details.
1206
+ (SlotOffset
1207
+ (off i64))))
1208
+
1209
+ ;; A memory argument to a load/store-pair.
1210
+ (type PairAMode (enum
1211
+ ;; Signed, scaled 7-bit offset from a register.
1212
+ (SignedOffset
1213
+ (reg Reg)
1214
+ (simm7 SImm7Scaled))
1215
+
1216
+ ;; Pre-increment register before address computation.
1217
+ (SPPreIndexed (simm7 SImm7Scaled))
1218
+
1219
+ ;; Post-increment register after address computation.
1220
+ (SPPostIndexed (simm7 SImm7Scaled))
1221
+ ))
1222
+
1223
+ (type FPUOpRI extern (enum))
1224
+ (type FPUOpRIMod extern (enum))
1225
+
1226
+ (type OperandSize extern
1227
+ (enum Size32
1228
+ Size64))
1229
+
1230
+ (type TestBitAndBranchKind (enum (Z) (NZ)))
1231
+
1232
+ ;; Helper for calculating the `OperandSize` corresponding to a type
1233
+ (decl operand_size (Type) OperandSize)
1234
+ (rule 1 (operand_size (fits_in_32 _ty)) (OperandSize.Size32))
1235
+ (rule (operand_size (fits_in_64 _ty)) (OperandSize.Size64))
1236
+
1237
+ (type ScalarSize extern
1238
+ (enum Size8
1239
+ Size16
1240
+ Size32
1241
+ Size64
1242
+ Size128))
1243
+
1244
+ ;; Helper for calculating the `ScalarSize` corresponding to a type
1245
+ (decl scalar_size (Type) ScalarSize)
1246
+
1247
+ (rule (scalar_size $I8) (ScalarSize.Size8))
1248
+ (rule (scalar_size $I16) (ScalarSize.Size16))
1249
+ (rule (scalar_size $I32) (ScalarSize.Size32))
1250
+ (rule (scalar_size $I64) (ScalarSize.Size64))
1251
+ (rule (scalar_size $I128) (ScalarSize.Size128))
1252
+
1253
+ (rule (scalar_size $F32) (ScalarSize.Size32))
1254
+ (rule (scalar_size $F64) (ScalarSize.Size64))
1255
+
1256
+ ;; Helper for calculating the `ScalarSize` lane type from vector type
1257
+ (decl lane_size (Type) ScalarSize)
1258
+ (rule 1 (lane_size (multi_lane 8 _)) (ScalarSize.Size8))
1259
+ (rule 1 (lane_size (multi_lane 16 _)) (ScalarSize.Size16))
1260
+ (rule 1 (lane_size (multi_lane 32 _)) (ScalarSize.Size32))
1261
+ (rule 1 (lane_size (multi_lane 64 _)) (ScalarSize.Size64))
1262
+ (rule (lane_size (dynamic_lane 8 _)) (ScalarSize.Size8))
1263
+ (rule (lane_size (dynamic_lane 16 _)) (ScalarSize.Size16))
1264
+ (rule (lane_size (dynamic_lane 32 _)) (ScalarSize.Size32))
1265
+ (rule (lane_size (dynamic_lane 64 _)) (ScalarSize.Size64))
1266
+
1267
+ ;; Helper for extracting the size of a lane from the input `VectorSize`
1268
+ (decl pure vector_lane_size (VectorSize) ScalarSize)
1269
+ (rule (vector_lane_size (VectorSize.Size8x16)) (ScalarSize.Size8))
1270
+ (rule (vector_lane_size (VectorSize.Size8x8)) (ScalarSize.Size8))
1271
+ (rule (vector_lane_size (VectorSize.Size16x8)) (ScalarSize.Size16))
1272
+ (rule (vector_lane_size (VectorSize.Size16x4)) (ScalarSize.Size16))
1273
+ (rule (vector_lane_size (VectorSize.Size32x4)) (ScalarSize.Size32))
1274
+ (rule (vector_lane_size (VectorSize.Size32x2)) (ScalarSize.Size32))
1275
+ (rule (vector_lane_size (VectorSize.Size64x2)) (ScalarSize.Size64))
1276
+
1277
+ (type Cond extern
1278
+ (enum
1279
+ (Eq)
1280
+ (Ne)
1281
+ (Hs)
1282
+ (Lo)
1283
+ (Mi)
1284
+ (Pl)
1285
+ (Vs)
1286
+ (Vc)
1287
+ (Hi)
1288
+ (Ls)
1289
+ (Ge)
1290
+ (Lt)
1291
+ (Gt)
1292
+ (Le)
1293
+ (Al)
1294
+ (Nv)
1295
+ ))
1296
+
1297
+ (type VectorSize extern
1298
+ (enum
1299
+ (Size8x8)
1300
+ (Size8x16)
1301
+ (Size16x4)
1302
+ (Size16x8)
1303
+ (Size32x2)
1304
+ (Size32x4)
1305
+ (Size64x2)
1306
+ ))
1307
+
1308
+ ;; Helper for calculating the `VectorSize` corresponding to a type
1309
+ (decl vector_size (Type) VectorSize)
1310
+ (rule 1 (vector_size (multi_lane 8 8)) (VectorSize.Size8x8))
1311
+ (rule 1 (vector_size (multi_lane 8 16)) (VectorSize.Size8x16))
1312
+ (rule 1 (vector_size (multi_lane 16 4)) (VectorSize.Size16x4))
1313
+ (rule 1 (vector_size (multi_lane 16 8)) (VectorSize.Size16x8))
1314
+ (rule 1 (vector_size (multi_lane 32 2)) (VectorSize.Size32x2))
1315
+ (rule 1 (vector_size (multi_lane 32 4)) (VectorSize.Size32x4))
1316
+ (rule 1 (vector_size (multi_lane 64 2)) (VectorSize.Size64x2))
1317
+ (rule (vector_size (dynamic_lane 8 8)) (VectorSize.Size8x8))
1318
+ (rule (vector_size (dynamic_lane 8 16)) (VectorSize.Size8x16))
1319
+ (rule (vector_size (dynamic_lane 16 4)) (VectorSize.Size16x4))
1320
+ (rule (vector_size (dynamic_lane 16 8)) (VectorSize.Size16x8))
1321
+ (rule (vector_size (dynamic_lane 32 2)) (VectorSize.Size32x2))
1322
+ (rule (vector_size (dynamic_lane 32 4)) (VectorSize.Size32x4))
1323
+ (rule (vector_size (dynamic_lane 64 2)) (VectorSize.Size64x2))
1324
+
1325
+ ;; A floating-point unit (FPU) operation with one arg.
1326
+ (type FPUOp1
1327
+ (enum
1328
+ (Abs)
1329
+ (Neg)
1330
+ (Sqrt)
1331
+ (Cvt32To64)
1332
+ (Cvt64To32)
1333
+ ))
1334
+
1335
+ ;; A floating-point unit (FPU) operation with two args.
1336
+ (type FPUOp2
1337
+ (enum
1338
+ (Add)
1339
+ (Sub)
1340
+ (Mul)
1341
+ (Div)
1342
+ (Max)
1343
+ (Min)
1344
+ ))
1345
+
1346
+ ;; A floating-point unit (FPU) operation with three args.
1347
+ (type FPUOp3
1348
+ (enum
1349
+ ;; Multiply-add
1350
+ (MAdd)
1351
+ ;; Multiply-sub
1352
+ (MSub)
1353
+ ;; Negated fused Multiply-add
1354
+ (NMAdd)
1355
+ ;; Negated fused Multiply-sub
1356
+ (NMSub)
1357
+ ))
1358
+
1359
+ ;; A conversion from an FP to an integer value.
1360
+ (type FpuToIntOp
1361
+ (enum
1362
+ (F32ToU32)
1363
+ (F32ToI32)
1364
+ (F32ToU64)
1365
+ (F32ToI64)
1366
+ (F64ToU32)
1367
+ (F64ToI32)
1368
+ (F64ToU64)
1369
+ (F64ToI64)
1370
+ ))
1371
+
1372
+ ;; A conversion from an integer to an FP value.
1373
+ (type IntToFpuOp
1374
+ (enum
1375
+ (U32ToF32)
1376
+ (I32ToF32)
1377
+ (U32ToF64)
1378
+ (I32ToF64)
1379
+ (U64ToF32)
1380
+ (I64ToF32)
1381
+ (U64ToF64)
1382
+ (I64ToF64)
1383
+ ))
1384
+
1385
+ ;; Modes for FP rounding ops: round down (floor) or up (ceil), or toward zero (trunc), or to
1386
+ ;; nearest, and for 32- or 64-bit FP values.
1387
+ (type FpuRoundMode
1388
+ (enum
1389
+ (Minus32)
1390
+ (Minus64)
1391
+ (Plus32)
1392
+ (Plus64)
1393
+ (Zero32)
1394
+ (Zero64)
1395
+ (Nearest32)
1396
+ (Nearest64)
1397
+ ))
1398
+
1399
+ ;; Type of vector element extensions.
1400
+ (type VecExtendOp
1401
+ (enum
1402
+ ;; Signed extension
1403
+ (Sxtl)
1404
+ ;; Unsigned extension
1405
+ (Uxtl)
1406
+ ))
1407
+
1408
+ ;; A vector ALU operation.
1409
+ (type VecALUOp
1410
+ (enum
1411
+ ;; Signed saturating add
1412
+ (Sqadd)
1413
+ ;; Unsigned saturating add
1414
+ (Uqadd)
1415
+ ;; Signed saturating subtract
1416
+ (Sqsub)
1417
+ ;; Unsigned saturating subtract
1418
+ (Uqsub)
1419
+ ;; Compare bitwise equal
1420
+ (Cmeq)
1421
+ ;; Compare signed greater than or equal
1422
+ (Cmge)
1423
+ ;; Compare signed greater than
1424
+ (Cmgt)
1425
+ ;; Compare unsigned higher
1426
+ (Cmhs)
1427
+ ;; Compare unsigned higher or same
1428
+ (Cmhi)
1429
+ ;; Floating-point compare equal
1430
+ (Fcmeq)
1431
+ ;; Floating-point compare greater than
1432
+ (Fcmgt)
1433
+ ;; Floating-point compare greater than or equal
1434
+ (Fcmge)
1435
+ ;; Bitwise and
1436
+ (And)
1437
+ ;; Bitwise bit clear
1438
+ (Bic)
1439
+ ;; Bitwise inclusive or
1440
+ (Orr)
1441
+ ;; Bitwise exclusive or
1442
+ (Eor)
1443
+ ;; Unsigned maximum pairwise
1444
+ (Umaxp)
1445
+ ;; Add
1446
+ (Add)
1447
+ ;; Subtract
1448
+ (Sub)
1449
+ ;; Multiply
1450
+ (Mul)
1451
+ ;; Signed shift left
1452
+ (Sshl)
1453
+ ;; Unsigned shift left
1454
+ (Ushl)
1455
+ ;; Unsigned minimum
1456
+ (Umin)
1457
+ ;; Signed minimum
1458
+ (Smin)
1459
+ ;; Unsigned maximum
1460
+ (Umax)
1461
+ ;; Signed maximum
1462
+ (Smax)
1463
+ ;; Unsigned rounding halving add
1464
+ (Urhadd)
1465
+ ;; Floating-point add
1466
+ (Fadd)
1467
+ ;; Floating-point subtract
1468
+ (Fsub)
1469
+ ;; Floating-point divide
1470
+ (Fdiv)
1471
+ ;; Floating-point maximum
1472
+ (Fmax)
1473
+ ;; Floating-point minimum
1474
+ (Fmin)
1475
+ ;; Floating-point multiply
1476
+ (Fmul)
1477
+ ;; Add pairwise
1478
+ (Addp)
1479
+ ;; Zip vectors (primary) [meaning, high halves]
1480
+ (Zip1)
1481
+ ;; Zip vectors (secondary)
1482
+ (Zip2)
1483
+ ;; Signed saturating rounding doubling multiply returning high half
1484
+ (Sqrdmulh)
1485
+ ;; Unzip vectors (primary)
1486
+ (Uzp1)
1487
+ ;; Unzip vectors (secondary)
1488
+ (Uzp2)
1489
+ ;; Transpose vectors (primary)
1490
+ (Trn1)
1491
+ ;; Transpose vectors (secondary)
1492
+ (Trn2)
1493
+ ))
1494
+
1495
+ ;; A Vector ALU operation which modifies a source register.
1496
+ (type VecALUModOp
1497
+ (enum
1498
+ ;; Bitwise select
1499
+ (Bsl)
1500
+ ;; Floating-point fused multiply-add vectors
1501
+ (Fmla)
1502
+ ;; Floating-point fused multiply-subtract vectors
1503
+ (Fmls)
1504
+ ))
1505
+
1506
+ ;; A Vector miscellaneous operation with two registers.
1507
+ (type VecMisc2
1508
+ (enum
1509
+ ;; Bitwise NOT
1510
+ (Not)
1511
+ ;; Negate
1512
+ (Neg)
1513
+ ;; Absolute value
1514
+ (Abs)
1515
+ ;; Floating-point absolute value
1516
+ (Fabs)
1517
+ ;; Floating-point negate
1518
+ (Fneg)
1519
+ ;; Floating-point square root
1520
+ (Fsqrt)
1521
+ ;; Reverse elements in 16-bit lanes
1522
+ (Rev16)
1523
+ ;; Reverse elements in 32-bit lanes
1524
+ (Rev32)
1525
+ ;; Reverse elements in 64-bit doublewords
1526
+ (Rev64)
1527
+ ;; Floating-point convert to signed integer, rounding toward zero
1528
+ (Fcvtzs)
1529
+ ;; Floating-point convert to unsigned integer, rounding toward zero
1530
+ (Fcvtzu)
1531
+ ;; Signed integer convert to floating-point
1532
+ (Scvtf)
1533
+ ;; Unsigned integer convert to floating-point
1534
+ (Ucvtf)
1535
+ ;; Floating point round to integral, rounding towards nearest
1536
+ (Frintn)
1537
+ ;; Floating point round to integral, rounding towards zero
1538
+ (Frintz)
1539
+ ;; Floating point round to integral, rounding towards minus infinity
1540
+ (Frintm)
1541
+ ;; Floating point round to integral, rounding towards plus infinity
1542
+ (Frintp)
1543
+ ;; Population count per byte
1544
+ (Cnt)
1545
+ ;; Compare bitwise equal to 0
1546
+ (Cmeq0)
1547
+ ;; Compare signed greater than or equal to 0
1548
+ (Cmge0)
1549
+ ;; Compare signed greater than 0
1550
+ (Cmgt0)
1551
+ ;; Compare signed less than or equal to 0
1552
+ (Cmle0)
1553
+ ;; Compare signed less than 0
1554
+ (Cmlt0)
1555
+ ;; Floating point compare equal to 0
1556
+ (Fcmeq0)
1557
+ ;; Floating point compare greater than or equal to 0
1558
+ (Fcmge0)
1559
+ ;; Floating point compare greater than 0
1560
+ (Fcmgt0)
1561
+ ;; Floating point compare less than or equal to 0
1562
+ (Fcmle0)
1563
+ ;; Floating point compare less than 0
1564
+ (Fcmlt0)
1565
+ ))
1566
+
1567
+ ;; A vector widening operation with one argument.
1568
+ (type VecRRLongOp
1569
+ (enum
1570
+ ;; Floating-point convert to higher precision long, 16-bit elements
1571
+ (Fcvtl16)
1572
+ ;; Floating-point convert to higher precision long, 32-bit elements
1573
+ (Fcvtl32)
1574
+ ;; Shift left long (by element size), 8-bit elements
1575
+ (Shll8)
1576
+ ;; Shift left long (by element size), 16-bit elements
1577
+ (Shll16)
1578
+ ;; Shift left long (by element size), 32-bit elements
1579
+ (Shll32)
1580
+ ))
1581
+
1582
+ ;; A vector narrowing operation with one argument.
1583
+ (type VecRRNarrowOp
1584
+ (enum
1585
+ ;; Extract narrow.
1586
+ (Xtn)
1587
+ ;; Signed saturating extract narrow.
1588
+ (Sqxtn)
1589
+ ;; Signed saturating extract unsigned narrow.
1590
+ (Sqxtun)
1591
+ ;; Unsigned saturating extract narrow.
1592
+ (Uqxtn)
1593
+ ;; Floating-point convert to lower precision narrow.
1594
+ (Fcvtn)
1595
+ ))
1596
+
1597
+ (type VecRRRLongOp
1598
+ (enum
1599
+ ;; Signed multiply long.
1600
+ (Smull8)
1601
+ (Smull16)
1602
+ (Smull32)
1603
+ ;; Unsigned multiply long.
1604
+ (Umull8)
1605
+ (Umull16)
1606
+ (Umull32)
1607
+ ))
1608
+
1609
+ (type VecRRRLongModOp
1610
+ (enum
1611
+ ;; Unsigned multiply add long
1612
+ (Umlal8)
1613
+ (Umlal16)
1614
+ (Umlal32)
1615
+ ))
1616
+
1617
+ ;; A vector operation on a pair of elements with one register.
1618
+ (type VecPairOp
1619
+ (enum
1620
+ ;; Add pair of elements
1621
+ (Addp)
1622
+ ))
1623
+
1624
+ ;; 1-operand vector instruction that extends elements of the input register
1625
+ ;; and operates on a pair of elements.
1626
+ (type VecRRPairLongOp
1627
+ (enum
1628
+ ;; Sign extend and add pair of elements
1629
+ (Saddlp8)
1630
+ (Saddlp16)
1631
+ ;; Unsigned extend and add pair of elements
1632
+ (Uaddlp8)
1633
+ (Uaddlp16)
1634
+ ))
1635
+
1636
+ ;; An operation across the lanes of vectors.
1637
+ (type VecLanesOp
1638
+ (enum
1639
+ ;; Integer addition across a vector
1640
+ (Addv)
1641
+ ;; Unsigned minimum across a vector
1642
+ (Uminv)
1643
+ ))
1644
+
1645
+ ;; A shift-by-immediate operation on each lane of a vector.
1646
+ (type VecShiftImmOp
1647
+ (enum
1648
+ ;; Unsigned shift left
1649
+ (Shl)
1650
+ ;; Unsigned shift right
1651
+ (Ushr)
1652
+ ;; Signed shift right
1653
+ (Sshr)
1654
+ ))
1655
+
1656
+ ;; Destructive shift-by-immediate operation on each lane of a vector.
1657
+ (type VecShiftImmModOp
1658
+ (enum
1659
+ ;; Shift left and insert
1660
+ (Sli)
1661
+ ))
1662
+
1663
+ ;; Atomic read-modify-write operations with acquire-release semantics
1664
+ (type AtomicRMWOp
1665
+ (enum
1666
+ (Add)
1667
+ (Clr)
1668
+ (Eor)
1669
+ (Set)
1670
+ (Smax)
1671
+ (Smin)
1672
+ (Umax)
1673
+ (Umin)
1674
+ (Swp)
1675
+ ))
1676
+
1677
+ ;; Atomic read-modify-write operations, with acquire-release semantics,
1678
+ ;; implemented with a loop.
1679
+ (type AtomicRMWLoopOp
1680
+ (enum
1681
+ (Add)
1682
+ (Sub)
1683
+ (And)
1684
+ (Nand)
1685
+ (Eor)
1686
+ (Orr)
1687
+ (Smax)
1688
+ (Smin)
1689
+ (Umax)
1690
+ (Umin)
1691
+ (Xchg)
1692
+ ))
1693
+
1694
+ ;; Keys for instruction address PACs
1695
+ (type APIKey
1696
+ (enum
1697
+ ;; API key A with the modifier of SP
1698
+ (ASP)
1699
+ ;; API key B with the modifier of SP
1700
+ (BSP)
1701
+ ;; API key A with the modifier of zero
1702
+ (AZ)
1703
+ ;; API key B with the modifier of zero
1704
+ (BZ)
1705
+ ))
1706
+
1707
+ ;; Branch target types
1708
+ (type BranchTargetType
1709
+ (enum
1710
+ (None)
1711
+ (C)
1712
+ (J)
1713
+ (JC)
1714
+ ))
1715
+
1716
+ ;; Extractors for target features ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1717
+ (decl pure partial sign_return_address_disabled () Unit)
1718
+ (extern constructor sign_return_address_disabled sign_return_address_disabled)
1719
+
1720
+ (decl use_lse () Inst)
1721
+ (extern extractor use_lse use_lse)
1722
+
1723
+ (decl pure use_fp16 () bool)
1724
+ (extern constructor use_fp16 use_fp16)
1725
+
1726
+ ;; Extractor helpers for various immediate constants ;;;;;;;;;;;;;;;;;;;;;;;;;;
1727
+
1728
+ (decl pure partial move_wide_const_from_u64 (Type u64) MoveWideConst)
1729
+ (extern constructor move_wide_const_from_u64 move_wide_const_from_u64)
1730
+
1731
+ (decl pure partial move_wide_const_from_inverted_u64 (Type u64) MoveWideConst)
1732
+ (extern constructor move_wide_const_from_inverted_u64 move_wide_const_from_inverted_u64)
1733
+
1734
+ (decl pure partial imm_logic_from_u64 (Type u64) ImmLogic)
1735
+ (extern constructor imm_logic_from_u64 imm_logic_from_u64)
1736
+
1737
+ (decl pure partial imm_size_from_type (Type) u16)
1738
+ (extern constructor imm_size_from_type imm_size_from_type)
1739
+
1740
+ (decl pure partial imm_logic_from_imm64 (Type Imm64) ImmLogic)
1741
+ (extern constructor imm_logic_from_imm64 imm_logic_from_imm64)
1742
+
1743
+ (decl pure partial imm_shift_from_imm64 (Type Imm64) ImmShift)
1744
+ (extern constructor imm_shift_from_imm64 imm_shift_from_imm64)
1745
+
1746
+ (decl imm_shift_from_u8 (u8) ImmShift)
1747
+ (extern constructor imm_shift_from_u8 imm_shift_from_u8)
1748
+
1749
+ (decl imm12_from_u64 (Imm12) u64)
1750
+ (extern extractor imm12_from_u64 imm12_from_u64)
1751
+
1752
+ (decl u8_into_uimm5 (u8) UImm5)
1753
+ (extern constructor u8_into_uimm5 u8_into_uimm5)
1754
+
1755
+ (decl u8_into_imm12 (u8) Imm12)
1756
+ (extern constructor u8_into_imm12 u8_into_imm12)
1757
+
1758
+ (decl u64_into_imm_logic (Type u64) ImmLogic)
1759
+ (extern constructor u64_into_imm_logic u64_into_imm_logic)
1760
+
1761
+ (decl branch_target (MachLabel) BranchTarget)
1762
+ (extern constructor branch_target branch_target)
1763
+ (convert MachLabel BranchTarget branch_target)
1764
+
1765
+ (decl targets_jt_space (BoxVecMachLabel) CodeOffset)
1766
+ (extern constructor targets_jt_space targets_jt_space)
1767
+
1768
+ ;; Calculate the minimum floating-point bound for a conversion to floating
1769
+ ;; point from an integer type.
1770
+ ;; Accepts whether the output is signed, the size of the input
1771
+ ;; floating point type in bits, and the size of the output integer type
1772
+ ;; in bits.
1773
+ (decl min_fp_value (bool u8 u8) Reg)
1774
+ (extern constructor min_fp_value min_fp_value)
1775
+
1776
+ ;; Calculate the maximum floating-point bound for a conversion to floating
1777
+ ;; point from an integer type.
1778
+ ;; Accepts whether the output is signed, the size of the input
1779
+ ;; floating point type in bits, and the size of the output integer type
1780
+ ;; in bits.
1781
+ (decl max_fp_value (bool u8 u8) Reg)
1782
+ (extern constructor max_fp_value max_fp_value)
1783
+
1784
+ ;; Constructs an FPUOpRI.Ushr* given the size in bits of the value (or lane)
1785
+ ;; and the amount to shift by.
1786
+ (decl fpu_op_ri_ushr (u8 u8) FPUOpRI)
1787
+ (extern constructor fpu_op_ri_ushr fpu_op_ri_ushr)
1788
+
1789
+ ;; Constructs an FPUOpRIMod.Sli* given the size in bits of the value (or lane)
1790
+ ;; and the amount to shift by.
1791
+ (decl fpu_op_ri_sli (u8 u8) FPUOpRIMod)
1792
+ (extern constructor fpu_op_ri_sli fpu_op_ri_sli)
1793
+
1794
+ (decl pure partial lshr_from_u64 (Type u64) ShiftOpAndAmt)
1795
+ (extern constructor lshr_from_u64 lshr_from_u64)
1796
+
1797
+ (decl pure partial lshl_from_imm64 (Type Imm64) ShiftOpAndAmt)
1798
+ (extern constructor lshl_from_imm64 lshl_from_imm64)
1799
+
1800
+ (decl pure partial lshl_from_u64 (Type u64) ShiftOpAndAmt)
1801
+ (extern constructor lshl_from_u64 lshl_from_u64)
1802
+
1803
+ (decl pure partial ashr_from_u64 (Type u64) ShiftOpAndAmt)
1804
+ (extern constructor ashr_from_u64 ashr_from_u64)
1805
+
1806
+ (decl integral_ty (Type) Type)
1807
+ (extern extractor integral_ty integral_ty)
1808
+
1809
+ (decl valid_atomic_transaction (Type) Type)
1810
+ (extern extractor valid_atomic_transaction valid_atomic_transaction)
1811
+
1812
+ (decl pure partial is_zero_simm9 (SImm9) Unit)
1813
+ (extern constructor is_zero_simm9 is_zero_simm9)
1814
+
1815
+ (decl pure partial is_zero_uimm12 (UImm12Scaled) Unit)
1816
+ (extern constructor is_zero_uimm12 is_zero_uimm12)
1817
+
1818
+ ;; Helper to go directly from a `Value`, when it's an `iconst`, to an `Imm12`.
1819
+ (decl imm12_from_value (Imm12) Value)
1820
+ (extractor
1821
+ (imm12_from_value n)
1822
+ (iconst (u64_from_imm64 (imm12_from_u64 n))))
1823
+
1824
+ ;; Conceptually the same as `imm12_from_value`, but tries negating the constant
1825
+ ;; value (first sign-extending to handle narrow widths).
1826
+ (decl pure partial imm12_from_negated_value (Value) Imm12)
1827
+ (rule
1828
+ (imm12_from_negated_value (has_type ty (iconst n)))
1829
+ (if-let (imm12_from_u64 imm) (i64_as_u64 (i64_neg (i64_sextend_imm64 ty n))))
1830
+ imm)
1831
+
1832
+ ;; Helper type to represent a value and an extend operation fused together.
1833
+ (type ExtendedValue extern (enum))
1834
+ (decl extended_value_from_value (ExtendedValue) Value)
1835
+ (extern extractor extended_value_from_value extended_value_from_value)
1836
+
1837
+ ;; Constructors used to poke at the fields of an `ExtendedValue`.
1838
+ (decl put_extended_in_reg (ExtendedValue) Reg)
1839
+ (extern constructor put_extended_in_reg put_extended_in_reg)
1840
+ (decl get_extended_op (ExtendedValue) ExtendOp)
1841
+ (extern constructor get_extended_op get_extended_op)
1842
+
1843
+ (decl nzcv (bool bool bool bool) NZCV)
1844
+ (extern constructor nzcv nzcv)
1845
+
1846
+ (decl cond_br_zero (Reg) CondBrKind)
1847
+ (extern constructor cond_br_zero cond_br_zero)
1848
+
1849
+ (decl cond_br_not_zero (Reg) CondBrKind)
1850
+ (extern constructor cond_br_not_zero cond_br_not_zero)
1851
+
1852
+ (decl cond_br_cond (Cond) CondBrKind)
1853
+ (extern constructor cond_br_cond cond_br_cond)
1854
+
1855
+ ;; Instruction creation helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1856
+
1857
+ ;; Helper for creating the zero register.
1858
+ (decl zero_reg () Reg)
1859
+ (extern constructor zero_reg zero_reg)
1860
+
1861
+ (decl fp_reg () Reg)
1862
+ (extern constructor fp_reg fp_reg)
1863
+
1864
+ (decl stack_reg () Reg)
1865
+ (extern constructor stack_reg stack_reg)
1866
+
1867
+ (decl writable_link_reg () WritableReg)
1868
+ (extern constructor writable_link_reg writable_link_reg)
1869
+
1870
+ (decl writable_zero_reg () WritableReg)
1871
+ (extern constructor writable_zero_reg writable_zero_reg)
1872
+
1873
+ (decl value_regs_zero () ValueRegs)
1874
+ (rule (value_regs_zero)
1875
+ (value_regs
1876
+ (imm $I64 (ImmExtend.Zero) 0)
1877
+ (imm $I64 (ImmExtend.Zero) 0)))
1878
+
1879
+
1880
+ ;; Helper for emitting `MInst.Mov` instructions.
1881
+ (decl mov (Reg Type) Reg)
1882
+ (rule (mov src ty)
1883
+ (let ((dst WritableReg (temp_writable_reg $I64))
1884
+ (_ Unit (emit (MInst.Mov (operand_size ty) dst src))))
1885
+ dst))
1886
+
1887
+ ;; Helper for emitting `MInst.MovZ` instructions.
1888
+ (decl movz (MoveWideConst OperandSize) Reg)
1889
+ (rule (movz imm size)
1890
+ (let ((dst WritableReg (temp_writable_reg $I64))
1891
+ (_ Unit (emit (MInst.MovWide (MoveWideOp.MovZ) dst imm size))))
1892
+ dst))
1893
+
1894
+ ;; Helper for emitting `MInst.MovN` instructions.
1895
+ (decl movn (MoveWideConst OperandSize) Reg)
1896
+ (rule (movn imm size)
1897
+ (let ((dst WritableReg (temp_writable_reg $I64))
1898
+ (_ Unit (emit (MInst.MovWide (MoveWideOp.MovN) dst imm size))))
1899
+ dst))
1900
+
1901
+ ;; Helper for emitting `MInst.AluRRImmLogic` instructions.
1902
+ (decl alu_rr_imm_logic (ALUOp Type Reg ImmLogic) Reg)
1903
+ (rule (alu_rr_imm_logic op ty src imm)
1904
+ (let ((dst WritableReg (temp_writable_reg $I64))
1905
+ (_ Unit (emit (MInst.AluRRImmLogic op (operand_size ty) dst src imm))))
1906
+ dst))
1907
+
1908
+ ;; Helper for emitting `MInst.AluRRImmShift` instructions.
1909
+ (decl alu_rr_imm_shift (ALUOp Type Reg ImmShift) Reg)
1910
+ (rule (alu_rr_imm_shift op ty src imm)
1911
+ (let ((dst WritableReg (temp_writable_reg $I64))
1912
+ (_ Unit (emit (MInst.AluRRImmShift op (operand_size ty) dst src imm))))
1913
+ dst))
1914
+
1915
+ ;; Helper for emitting `MInst.AluRRR` instructions.
1916
+ (decl alu_rrr (ALUOp Type Reg Reg) Reg)
1917
+ (rule (alu_rrr op ty src1 src2)
1918
+ (let ((dst WritableReg (temp_writable_reg $I64))
1919
+ (_ Unit (emit (MInst.AluRRR op (operand_size ty) dst src1 src2))))
1920
+ dst))
1921
+
1922
+ ;; Helper for emitting `MInst.VecRRR` instructions.
1923
+ (decl vec_rrr (VecALUOp Reg Reg VectorSize) Reg)
1924
+ (rule (vec_rrr op src1 src2 size)
1925
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1926
+ (_ Unit (emit (MInst.VecRRR op dst src1 src2 size))))
1927
+ dst))
1928
+
1929
+ ;; Helper for emitting `MInst.FpuRR` instructions.
1930
+ (decl fpu_rr (FPUOp1 Reg ScalarSize) Reg)
1931
+ (rule (fpu_rr op src size)
1932
+ (let ((dst WritableReg (temp_writable_reg $F64))
1933
+ (_ Unit (emit (MInst.FpuRR op size dst src))))
1934
+ dst))
1935
+
1936
+ ;; Helper for emitting `MInst.VecRRRMod` instructions which use three registers,
1937
+ ;; one of which is both source and output.
1938
+ (decl vec_rrr_mod (VecALUModOp Reg Reg Reg VectorSize) Reg)
1939
+ (rule (vec_rrr_mod op src1 src2 src3 size)
1940
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1941
+ (_1 Unit (emit (MInst.VecRRRMod op dst src1 src2 src3 size))))
1942
+ dst))
1943
+
1944
+ ;; Helper for emitting `MInst.VecFmlaElem` instructions which use three registers,
1945
+ ;; one of which is both source and output.
1946
+ (decl vec_fmla_elem (VecALUModOp Reg Reg Reg VectorSize u8) Reg)
1947
+ (rule (vec_fmla_elem op src1 src2 src3 size idx)
1948
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1949
+ (_1 Unit (emit (MInst.VecFmlaElem op dst src1 src2 src3 size idx))))
1950
+ dst))
1951
+
1952
+ (decl fpu_rri (FPUOpRI Reg) Reg)
1953
+ (rule (fpu_rri op src)
1954
+ (let ((dst WritableReg (temp_writable_reg $F64))
1955
+ (_ Unit (emit (MInst.FpuRRI op dst src))))
1956
+ dst))
1957
+
1958
+ (decl fpu_rri_mod (FPUOpRIMod Reg Reg) Reg)
1959
+ (rule (fpu_rri_mod op dst_src src)
1960
+ (let ((dst WritableReg (temp_writable_reg $F64))
1961
+ (_ Unit (emit (MInst.FpuRRIMod op dst dst_src src))))
1962
+ dst))
1963
+
1964
+ ;; Helper for emitting `MInst.FpuRRR` instructions.
1965
+ (decl fpu_rrr (FPUOp2 Reg Reg ScalarSize) Reg)
1966
+ (rule (fpu_rrr op src1 src2 size)
1967
+ (let ((dst WritableReg (temp_writable_reg $F64))
1968
+ (_ Unit (emit (MInst.FpuRRR op size dst src1 src2))))
1969
+ dst))
1970
+
1971
+ ;; Helper for emitting `MInst.FpuRRRR` instructions.
1972
+ (decl fpu_rrrr (FPUOp3 ScalarSize Reg Reg Reg) Reg)
1973
+ (rule (fpu_rrrr size op src1 src2 src3)
1974
+ (let ((dst WritableReg (temp_writable_reg $F64))
1975
+ (_ Unit (emit (MInst.FpuRRRR size op dst src1 src2 src3))))
1976
+ dst))
1977
+
1978
+ ;; Helper for emitting `MInst.FpuCmp` instructions.
1979
+ (decl fpu_cmp (ScalarSize Reg Reg) ProducesFlags)
1980
+ (rule (fpu_cmp size rn rm)
1981
+ (ProducesFlags.ProducesFlagsSideEffect
1982
+ (MInst.FpuCmp size rn rm)))
1983
+
1984
+ ;; Helper for emitting `MInst.VecLanes` instructions.
1985
+ (decl vec_lanes (VecLanesOp Reg VectorSize) Reg)
1986
+ (rule (vec_lanes op src size)
1987
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1988
+ (_ Unit (emit (MInst.VecLanes op dst src size))))
1989
+ dst))
1990
+
1991
+ ;; Helper for emitting `MInst.VecShiftImm` instructions.
1992
+ (decl vec_shift_imm (VecShiftImmOp u8 Reg VectorSize) Reg)
1993
+ (rule (vec_shift_imm op imm src size)
1994
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1995
+ (_ Unit (emit (MInst.VecShiftImm op dst src size imm))))
1996
+ dst))
1997
+
1998
+ ;; Helper for emitting `MInst.VecDup` instructions.
1999
+ (decl vec_dup (Reg VectorSize) Reg)
2000
+ (rule (vec_dup src size)
2001
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2002
+ (_ Unit (emit (MInst.VecDup dst src size))))
2003
+ dst))
2004
+
2005
+ ;; Helper for emitting `MInst.VecDupFromFpu` instructions.
2006
+ (decl vec_dup_from_fpu (Reg VectorSize u8) Reg)
2007
+ (rule (vec_dup_from_fpu src size lane)
2008
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2009
+ (_ Unit (emit (MInst.VecDupFromFpu dst src size lane))))
2010
+ dst))
2011
+
2012
+ ;; Helper for emitting `MInst.VecDupImm` instructions.
2013
+ (decl vec_dup_imm (ASIMDMovModImm bool VectorSize) Reg)
2014
+ (rule (vec_dup_imm imm invert size)
2015
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2016
+ (_ Unit (emit (MInst.VecDupImm dst imm invert size))))
2017
+ dst))
2018
+
2019
+ ;; Helper for emitting `MInst.AluRRImm12` instructions.
2020
+ (decl alu_rr_imm12 (ALUOp Type Reg Imm12) Reg)
2021
+ (rule (alu_rr_imm12 op ty src imm)
2022
+ (let ((dst WritableReg (temp_writable_reg $I64))
2023
+ (_ Unit (emit (MInst.AluRRImm12 op (operand_size ty) dst src imm))))
2024
+ dst))
2025
+
2026
+ ;; Helper for emitting `MInst.AluRRRShift` instructions.
2027
+ (decl alu_rrr_shift (ALUOp Type Reg Reg ShiftOpAndAmt) Reg)
2028
+ (rule (alu_rrr_shift op ty src1 src2 shift)
2029
+ (let ((dst WritableReg (temp_writable_reg $I64))
2030
+ (_ Unit (emit (MInst.AluRRRShift op (operand_size ty) dst src1 src2 shift))))
2031
+ dst))
2032
+
2033
+ ;; Helper for emitting `cmp` instructions, setting flags, with a right-shifted
2034
+ ;; second operand register.
2035
+ (decl cmp_rr_shift (OperandSize Reg Reg u64) ProducesFlags)
2036
+ (rule (cmp_rr_shift size src1 src2 shift_amount)
2037
+ (if-let shift (lshr_from_u64 $I64 shift_amount))
2038
+ (ProducesFlags.ProducesFlagsSideEffect
2039
+ (MInst.AluRRRShift (ALUOp.SubS) size (writable_zero_reg)
2040
+ src1 src2 shift)))
2041
+
2042
+ ;; Helper for emitting `cmp` instructions, setting flags, with an arithmetic right-shifted
2043
+ ;; second operand register.
2044
+ (decl cmp_rr_shift_asr (OperandSize Reg Reg u64) ProducesFlags)
2045
+ (rule (cmp_rr_shift_asr size src1 src2 shift_amount)
2046
+ (if-let shift (ashr_from_u64 $I64 shift_amount))
2047
+ (ProducesFlags.ProducesFlagsSideEffect
2048
+ (MInst.AluRRRShift (ALUOp.SubS) size (writable_zero_reg)
2049
+ src1 src2 shift)))
2050
+
2051
+ ;; Helper for emitting `MInst.AluRRRExtend` instructions.
2052
+ (decl alu_rrr_extend (ALUOp Type Reg Reg ExtendOp) Reg)
2053
+ (rule (alu_rrr_extend op ty src1 src2 extend)
2054
+ (let ((dst WritableReg (temp_writable_reg $I64))
2055
+ (_ Unit (emit (MInst.AluRRRExtend op (operand_size ty) dst src1 src2 extend))))
2056
+ dst))
2057
+
2058
+ ;; Same as `alu_rrr_extend`, but takes an `ExtendedValue` packed "pair" instead
2059
+ ;; of a `Reg` and an `ExtendOp`.
2060
+ (decl alu_rr_extend_reg (ALUOp Type Reg ExtendedValue) Reg)
2061
+ (rule (alu_rr_extend_reg op ty src1 extended_reg)
2062
+ (let ((src2 Reg (put_extended_in_reg extended_reg))
2063
+ (extend ExtendOp (get_extended_op extended_reg)))
2064
+ (alu_rrr_extend op ty src1 src2 extend)))
2065
+
2066
+ ;; Helper for emitting `MInst.AluRRRR` instructions.
2067
+ (decl alu_rrrr (ALUOp3 Type Reg Reg Reg) Reg)
2068
+ (rule (alu_rrrr op ty src1 src2 src3)
2069
+ (let ((dst WritableReg (temp_writable_reg $I64))
2070
+ (_ Unit (emit (MInst.AluRRRR op (operand_size ty) dst src1 src2 src3))))
2071
+ dst))
2072
+
2073
+ ;; Helper for emitting paired `MInst.AluRRR` instructions
2074
+ (decl alu_rrr_with_flags_paired (Type Reg Reg ALUOp) ProducesFlags)
2075
+ (rule (alu_rrr_with_flags_paired ty src1 src2 alu_op)
2076
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2077
+ (ProducesFlags.ProducesFlagsReturnsResultWithConsumer
2078
+ (MInst.AluRRR alu_op (operand_size ty) dst src1 src2)
2079
+ dst)))
2080
+
2081
+ ;; Should only be used for AdcS and SbcS
2082
+ (decl alu_rrr_with_flags_chained (Type Reg Reg ALUOp) ConsumesAndProducesFlags)
2083
+ (rule (alu_rrr_with_flags_chained ty src1 src2 alu_op)
2084
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2085
+ (ConsumesAndProducesFlags.ReturnsReg
2086
+ (MInst.AluRRR alu_op (operand_size ty) dst src1 src2)
2087
+ dst)))
2088
+
2089
+ ;; Helper for emitting `MInst.BitRR` instructions.
2090
+ (decl bit_rr (BitOp Type Reg) Reg)
2091
+ (rule (bit_rr op ty src)
2092
+ (let ((dst WritableReg (temp_writable_reg $I64))
2093
+ (_ Unit (emit (MInst.BitRR op (operand_size ty) dst src))))
2094
+ dst))
2095
+
2096
+ ;; Helper for emitting `adds` instructions.
2097
+ (decl add_with_flags_paired (Type Reg Reg) ProducesFlags)
2098
+ (rule (add_with_flags_paired ty src1 src2)
2099
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2100
+ (ProducesFlags.ProducesFlagsReturnsResultWithConsumer
2101
+ (MInst.AluRRR (ALUOp.AddS) (operand_size ty) dst src1 src2)
2102
+ dst)))
2103
+
2104
+ ;; Helper for emitting `adc` instructions.
2105
+ (decl adc_paired (Type Reg Reg) ConsumesFlags)
2106
+ (rule (adc_paired ty src1 src2)
2107
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2108
+ (ConsumesFlags.ConsumesFlagsReturnsResultWithProducer
2109
+ (MInst.AluRRR (ALUOp.Adc) (operand_size ty) dst src1 src2)
2110
+ dst)))
2111
+
2112
+ ;; Helper for emitting `subs` instructions.
2113
+ (decl sub_with_flags_paired (Type Reg Reg) ProducesFlags)
2114
+ (rule (sub_with_flags_paired ty src1 src2)
2115
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2116
+ (ProducesFlags.ProducesFlagsReturnsResultWithConsumer
2117
+ (MInst.AluRRR (ALUOp.SubS) (operand_size ty) dst src1 src2)
2118
+ dst)))
2119
+
2120
+ ;; Helper for materializing a boolean value into a register from
2121
+ ;; flags.
2122
+ (decl materialize_bool_result (Cond) ConsumesFlags)
2123
+ (rule (materialize_bool_result cond)
2124
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2125
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2126
+ (MInst.CSet dst cond)
2127
+ dst)))
2128
+
2129
+ (decl cmn_imm (OperandSize Reg Imm12) ProducesFlags)
2130
+ (rule (cmn_imm size src1 src2)
2131
+ (ProducesFlags.ProducesFlagsSideEffect
2132
+ (MInst.AluRRImm12 (ALUOp.AddS) size (writable_zero_reg)
2133
+ src1 src2)))
2134
+
2135
+ (decl cmp (OperandSize Reg Reg) ProducesFlags)
2136
+ (rule (cmp size src1 src2)
2137
+ (ProducesFlags.ProducesFlagsSideEffect
2138
+ (MInst.AluRRR (ALUOp.SubS) size (writable_zero_reg)
2139
+ src1 src2)))
2140
+
2141
+ (decl cmp_imm (OperandSize Reg Imm12) ProducesFlags)
2142
+ (rule (cmp_imm size src1 src2)
2143
+ (ProducesFlags.ProducesFlagsSideEffect
2144
+ (MInst.AluRRImm12 (ALUOp.SubS) size (writable_zero_reg)
2145
+ src1 src2)))
2146
+
2147
+ (decl cmp64_imm (Reg Imm12) ProducesFlags)
2148
+ (rule (cmp64_imm src1 src2)
2149
+ (cmp_imm (OperandSize.Size64) src1 src2))
2150
+
2151
+ (decl cmp_extend (OperandSize Reg Reg ExtendOp) ProducesFlags)
2152
+ (rule (cmp_extend size src1 src2 extend)
2153
+ (ProducesFlags.ProducesFlagsSideEffect
2154
+ (MInst.AluRRRExtend (ALUOp.SubS) size (writable_zero_reg)
2155
+ src1 src2 extend)))
2156
+
2157
+ ;; Helper for emitting `sbc` instructions.
2158
+ (decl sbc_paired (Type Reg Reg) ConsumesFlags)
2159
+ (rule (sbc_paired ty src1 src2)
2160
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2161
+ (ConsumesFlags.ConsumesFlagsReturnsResultWithProducer
2162
+ (MInst.AluRRR (ALUOp.Sbc) (operand_size ty) dst src1 src2)
2163
+ dst)))
2164
+
2165
+ ;; Helper for emitting `MInst.VecMisc` instructions.
2166
+ (decl vec_misc (VecMisc2 Reg VectorSize) Reg)
2167
+ (rule (vec_misc op src size)
2168
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2169
+ (_ Unit (emit (MInst.VecMisc op dst src size))))
2170
+ dst))
2171
+
2172
+ ;; Helper for emitting `MInst.VecTbl` instructions.
2173
+ (decl vec_tbl (Reg Reg) Reg)
2174
+ (rule (vec_tbl rn rm)
2175
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2176
+ (_ Unit (emit (MInst.VecTbl dst rn rm))))
2177
+ dst))
2178
+
2179
+ (decl vec_tbl_ext (Reg Reg Reg) Reg)
2180
+ (rule (vec_tbl_ext ri rn rm)
2181
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2182
+ (_ Unit (emit (MInst.VecTblExt dst ri rn rm))))
2183
+ dst))
2184
+
2185
+ ;; Helper for emitting `MInst.VecTbl2` instructions.
2186
+ (decl vec_tbl2 (Reg Reg Reg Type) Reg)
2187
+ (rule (vec_tbl2 rn rn2 rm ty)
2188
+ (let (
2189
+ (dst WritableReg (temp_writable_reg $I8X16))
2190
+ (_ Unit (emit (MInst.VecTbl2 dst rn rn2 rm)))
2191
+ )
2192
+ dst))
2193
+
2194
+ ;; Helper for emitting `MInst.VecTbl2Ext` instructions.
2195
+ (decl vec_tbl2_ext (Reg Reg Reg Reg Type) Reg)
2196
+ (rule (vec_tbl2_ext ri rn rn2 rm ty)
2197
+ (let (
2198
+ (dst WritableReg (temp_writable_reg $I8X16))
2199
+ (_ Unit (emit (MInst.VecTbl2Ext dst ri rn rn2 rm)))
2200
+ )
2201
+ dst))
2202
+
2203
+ ;; Helper for emitting `MInst.VecRRRLong` instructions.
2204
+ (decl vec_rrr_long (VecRRRLongOp Reg Reg bool) Reg)
2205
+ (rule (vec_rrr_long op src1 src2 high_half)
2206
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2207
+ (_ Unit (emit (MInst.VecRRRLong op dst src1 src2 high_half))))
2208
+ dst))
2209
+
2210
+ ;; Helper for emitting `MInst.VecRRPairLong` instructions.
2211
+ (decl vec_rr_pair_long (VecRRPairLongOp Reg) Reg)
2212
+ (rule (vec_rr_pair_long op src)
2213
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2214
+ (_ Unit (emit (MInst.VecRRPairLong op dst src))))
2215
+ dst))
2216
+
2217
+ ;; Helper for emitting `MInst.VecRRRLongMod` instructions.
2218
+ (decl vec_rrrr_long (VecRRRLongModOp Reg Reg Reg bool) Reg)
2219
+ (rule (vec_rrrr_long op src1 src2 src3 high_half)
2220
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2221
+ (_ Unit (emit (MInst.VecRRRLongMod op dst src1 src2 src3 high_half))))
2222
+ dst))
2223
+
2224
+ ;; Helper for emitting `MInst.VecRRNarrow` instructions.
2225
+ (decl vec_rr_narrow_low (VecRRNarrowOp Reg ScalarSize) Reg)
2226
+ (rule (vec_rr_narrow_low op src size)
2227
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2228
+ (_ Unit (emit (MInst.VecRRNarrowLow op dst src size))))
2229
+ dst))
2230
+
2231
+ ;; Helper for emitting `MInst.VecRRNarrow` instructions which update the
2232
+ ;; high half of the destination register.
2233
+ (decl vec_rr_narrow_high (VecRRNarrowOp Reg Reg ScalarSize) Reg)
2234
+ (rule (vec_rr_narrow_high op mod src size)
2235
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2236
+ (_ Unit (emit (MInst.VecRRNarrowHigh op dst mod src size))))
2237
+ dst))
2238
+
2239
+ ;; Helper for emitting `MInst.VecRRLong` instructions.
2240
+ (decl vec_rr_long (VecRRLongOp Reg bool) Reg)
2241
+ (rule (vec_rr_long op src high_half)
2242
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2243
+ (_ Unit (emit (MInst.VecRRLong op dst src high_half))))
2244
+ dst))
2245
+
2246
+ ;; Helper for emitting `MInst.FpuCSel16` / `MInst.FpuCSel32` / `MInst.FpuCSel64`
2247
+ ;; instructions.
2248
+ (decl fpu_csel (Type Cond Reg Reg) ConsumesFlags)
2249
+ (rule (fpu_csel $F16 cond if_true if_false)
2250
+ (fpu_csel $F32 cond if_true if_false))
2251
+
2252
+ (rule 1 (fpu_csel $F16 cond if_true if_false)
2253
+ (if-let $true (use_fp16))
2254
+ (let ((dst WritableReg (temp_writable_reg $F16)))
2255
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2256
+ (MInst.FpuCSel16 dst if_true if_false cond)
2257
+ dst)))
2258
+
2259
+ (rule (fpu_csel $F32 cond if_true if_false)
2260
+ (let ((dst WritableReg (temp_writable_reg $F32)))
2261
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2262
+ (MInst.FpuCSel32 dst if_true if_false cond)
2263
+ dst)))
2264
+
2265
+ (rule (fpu_csel $F64 cond if_true if_false)
2266
+ (let ((dst WritableReg (temp_writable_reg $F64)))
2267
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2268
+ (MInst.FpuCSel64 dst if_true if_false cond)
2269
+ dst)))
2270
+
2271
+ ;; Helper for emitting `MInst.VecCSel` instructions.
2272
+ (decl vec_csel (Cond Reg Reg) ConsumesFlags)
2273
+ (rule (vec_csel cond if_true if_false)
2274
+ (let ((dst WritableReg (temp_writable_reg $I8X16)))
2275
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2276
+ (MInst.VecCSel dst if_true if_false cond)
2277
+ dst)))
2278
+
2279
+ ;; Helper for emitting `MInst.FpuRound` instructions.
2280
+ (decl fpu_round (FpuRoundMode Reg) Reg)
2281
+ (rule (fpu_round op rn)
2282
+ (let ((dst WritableReg (temp_writable_reg $F64))
2283
+ (_ Unit (emit (MInst.FpuRound op dst rn))))
2284
+ dst))
2285
+
2286
+ ;; Helper for emitting `MInst.FpuMove64` and `MInst.FpuMove128` instructions.
2287
+ (decl fpu_move (Type Reg) Reg)
2288
+ (rule (fpu_move _ src)
2289
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2290
+ (_ Unit (emit (MInst.FpuMove128 dst src))))
2291
+ dst))
2292
+ (rule 1 (fpu_move (fits_in_64 _) src)
2293
+ (let ((dst WritableReg (temp_writable_reg $F64))
2294
+ (_ Unit (emit (MInst.FpuMove64 dst src))))
2295
+ dst))
2296
+
2297
+ ;; Helper for emitting `MInst.MovToFpu` instructions.
2298
+ (decl mov_to_fpu (Reg ScalarSize) Reg)
2299
+ (rule (mov_to_fpu x size)
2300
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2301
+ (_ Unit (emit (MInst.MovToFpu dst x size))))
2302
+ dst))
2303
+ (rule 1 (mov_to_fpu x (ScalarSize.Size16))
2304
+ (if-let $false (use_fp16))
2305
+ (mov_to_fpu x (ScalarSize.Size32)))
2306
+
2307
+ ;; Helper for emitting `MInst.FpuMoveFPImm` instructions.
2308
+ (decl fpu_move_fp_imm (ASIMDFPModImm ScalarSize) Reg)
2309
+ (rule (fpu_move_fp_imm imm size)
2310
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2311
+ (_ Unit (emit (MInst.FpuMoveFPImm dst imm size))))
2312
+ dst))
2313
+
2314
+ ;; Helper for emitting `MInst.MovToVec` instructions.
2315
+ (decl mov_to_vec (Reg Reg u8 VectorSize) Reg)
2316
+ (rule (mov_to_vec src1 src2 lane size)
2317
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2318
+ (_ Unit (emit (MInst.MovToVec dst src1 src2 lane size))))
2319
+ dst))
2320
+
2321
+ ;; Helper for emitting `MInst.VecMovElement` instructions.
2322
+ (decl mov_vec_elem (Reg Reg u8 u8 VectorSize) Reg)
2323
+ (rule (mov_vec_elem src1 src2 dst_idx src_idx size)
2324
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2325
+ (_ Unit (emit (MInst.VecMovElement dst src1 src2 dst_idx src_idx size))))
2326
+ dst))
2327
+
2328
+ ;; Helper for emitting `MInst.MovFromVec` instructions.
2329
+ (decl mov_from_vec (Reg u8 ScalarSize) Reg)
2330
+ (rule (mov_from_vec rn idx size)
2331
+ (let ((dst WritableReg (temp_writable_reg $I64))
2332
+ (_ Unit (emit (MInst.MovFromVec dst rn idx size))))
2333
+ dst))
2334
+
2335
+ ;; Helper for emitting `MInst.MovFromVecSigned` instructions.
2336
+ (decl mov_from_vec_signed (Reg u8 VectorSize OperandSize) Reg)
2337
+ (rule (mov_from_vec_signed rn idx size scalar_size)
2338
+ (let ((dst WritableReg (temp_writable_reg $I64))
2339
+ (_ Unit (emit (MInst.MovFromVecSigned dst rn idx size scalar_size))))
2340
+ dst))
2341
+
2342
+ (decl fpu_move_from_vec (Reg u8 VectorSize) Reg)
2343
+ (rule (fpu_move_from_vec rn idx size)
2344
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2345
+ (_ Unit (emit (MInst.FpuMoveFromVec dst rn idx size))))
2346
+ dst))
2347
+
2348
+ ;; Helper for emitting `MInst.Extend` instructions.
2349
+ (decl extend (Reg bool u8 u8) Reg)
2350
+ (rule (extend rn signed from_bits to_bits)
2351
+ (let ((dst WritableReg (temp_writable_reg $I64))
2352
+ (_ Unit (emit (MInst.Extend dst rn signed from_bits to_bits))))
2353
+ dst))
2354
+
2355
+ ;; Helper for emitting `MInst.FpuExtend` instructions.
2356
+ (decl fpu_extend (Reg ScalarSize) Reg)
2357
+ (rule (fpu_extend src size)
2358
+ (let ((dst WritableReg (temp_writable_reg $F32X4))
2359
+ (_ Unit (emit (MInst.FpuExtend dst src size))))
2360
+ dst))
2361
+
2362
+ ;; Helper for emitting `MInst.VecExtend` instructions.
2363
+ (decl vec_extend (VecExtendOp Reg bool ScalarSize) Reg)
2364
+ (rule (vec_extend op src high_half size)
2365
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2366
+ (_ Unit (emit (MInst.VecExtend op dst src high_half size))))
2367
+ dst))
2368
+
2369
+ ;; Helper for emitting `MInst.VecExtract` instructions.
2370
+ (decl vec_extract (Reg Reg u8) Reg)
2371
+ (rule (vec_extract src1 src2 idx)
2372
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2373
+ (_ Unit (emit (MInst.VecExtract dst src1 src2 idx))))
2374
+ dst))
2375
+
2376
+ ;; Helper for emitting `MInst.LoadAcquire` instructions.
2377
+ (decl load_acquire (Type MemFlags Reg) Reg)
2378
+ (rule (load_acquire ty flags addr)
2379
+ (let ((dst WritableReg (temp_writable_reg $I64))
2380
+ (_ Unit (emit (MInst.LoadAcquire ty dst addr flags))))
2381
+ dst))
2382
+
2383
+ ;; Helper for emitting `MInst.StoreRelease` instructions.
2384
+ (decl store_release (Type MemFlags Reg Reg) SideEffectNoResult)
2385
+ (rule (store_release ty flags src addr)
2386
+ (SideEffectNoResult.Inst (MInst.StoreRelease ty src addr flags)))
2387
+
2388
+ ;; Helper for generating a `tst` instruction.
2389
+ ;;
2390
+ ;; Produces a `ProducesFlags` rather than a register or emitted instruction
2391
+ ;; which must be paired with `with_flags*` helpers.
2392
+ (decl tst_imm (Type Reg ImmLogic) ProducesFlags)
2393
+ (rule (tst_imm ty reg imm)
2394
+ (ProducesFlags.ProducesFlagsSideEffect
2395
+ (MInst.AluRRImmLogic (ALUOp.AndS)
2396
+ (operand_size ty)
2397
+ (writable_zero_reg)
2398
+ reg
2399
+ imm)))
2400
+
2401
+ ;; Helper for generating a `CSel` instruction.
2402
+ ;;
2403
+ ;; Note that this doesn't actually emit anything, instead it produces a
2404
+ ;; `ConsumesFlags` instruction which must be consumed with `with_flags*`
2405
+ ;; helpers.
2406
+ (decl csel (Cond Reg Reg) ConsumesFlags)
2407
+ (rule (csel cond if_true if_false)
2408
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2409
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2410
+ (MInst.CSel dst cond if_true if_false)
2411
+ dst)))
2412
+
2413
+ ;; Helper for constructing `cset` instructions.
2414
+ (decl cset (Cond) ConsumesFlags)
2415
+ (rule (cset cond)
2416
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2417
+ (ConsumesFlags.ConsumesFlagsReturnsReg (MInst.CSet dst cond) dst)))
2418
+
2419
+ ;; Helper for constructing `cset` instructions, when the flags producer will
2420
+ ;; also return a value.
2421
+ (decl cset_paired (Cond) ConsumesFlags)
2422
+ (rule (cset_paired cond)
2423
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2424
+ (ConsumesFlags.ConsumesFlagsReturnsResultWithProducer (MInst.CSet dst cond) dst)))
2425
+
2426
+ ;; Helper for constructing `csetm` instructions.
2427
+ (decl csetm (Cond) ConsumesFlags)
2428
+ (rule (csetm cond)
2429
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2430
+ (ConsumesFlags.ConsumesFlagsReturnsReg (MInst.CSetm dst cond) dst)))
2431
+
2432
+ ;; Helper for generating a `CSNeg` instruction.
2433
+ ;;
2434
+ ;; Note that this doesn't actually emit anything, instead it produces a
2435
+ ;; `ConsumesFlags` instruction which must be consumed with `with_flags*`
2436
+ ;; helpers.
2437
+ (decl csneg (Cond Reg Reg) ConsumesFlags)
2438
+ (rule (csneg cond if_true if_false)
2439
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2440
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2441
+ (MInst.CSNeg dst cond if_true if_false)
2442
+ dst)))
2443
+
2444
+ ;; Helper for generating `MInst.CCmp` instructions.
2445
+ ;; Creates a new `ProducesFlags` from the supplied `ProducesFlags` followed
2446
+ ;; immediately by the `MInst.CCmp` instruction.
2447
+ (decl ccmp (OperandSize Reg Reg NZCV Cond ProducesFlags) ProducesFlags)
2448
+ (rule (ccmp size rn rm nzcv cond inst_input)
2449
+ (produces_flags_concat inst_input (ProducesFlags.ProducesFlagsSideEffect (MInst.CCmp size rn rm nzcv cond))))
2450
+
2451
+ ;; Helper for generating `MInst.CCmpImm` instructions.
2452
+ (decl ccmp_imm (OperandSize Reg UImm5 NZCV Cond) ConsumesFlags)
2453
+ (rule 1 (ccmp_imm size rn imm nzcv cond)
2454
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2455
+ (ConsumesFlags.ConsumesFlagsTwiceReturnsValueRegs
2456
+ (MInst.CCmpImm size rn imm nzcv cond)
2457
+ (MInst.CSet dst cond)
2458
+ (value_reg dst))))
2459
+
2460
+ ;; Helpers for generating `add` instructions.
2461
+
2462
+ (decl add (Type Reg Reg) Reg)
2463
+ (rule (add ty x y) (alu_rrr (ALUOp.Add) ty x y))
2464
+
2465
+ (decl add_imm (Type Reg Imm12) Reg)
2466
+ (rule (add_imm ty x y) (alu_rr_imm12 (ALUOp.Add) ty x y))
2467
+
2468
+ (decl add_extend (Type Reg ExtendedValue) Reg)
2469
+ (rule (add_extend ty x y) (alu_rr_extend_reg (ALUOp.Add) ty x y))
2470
+
2471
+ (decl add_extend_op (Type Reg Reg ExtendOp) Reg)
2472
+ (rule (add_extend_op ty x y extend) (alu_rrr_extend (ALUOp.Add) ty x y extend))
2473
+
2474
+ (decl add_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2475
+ (rule (add_shift ty x y z) (alu_rrr_shift (ALUOp.Add) ty x y z))
2476
+
2477
+ (decl add_vec (Reg Reg VectorSize) Reg)
2478
+ (rule (add_vec x y size) (vec_rrr (VecALUOp.Add) x y size))
2479
+
2480
+ ;; Helpers for generating `sub` instructions.
2481
+
2482
+ (decl sub (Type Reg Reg) Reg)
2483
+ (rule (sub ty x y) (alu_rrr (ALUOp.Sub) ty x y))
2484
+
2485
+ (decl sub_imm (Type Reg Imm12) Reg)
2486
+ (rule (sub_imm ty x y) (alu_rr_imm12 (ALUOp.Sub) ty x y))
2487
+
2488
+ (decl sub_extend (Type Reg ExtendedValue) Reg)
2489
+ (rule (sub_extend ty x y) (alu_rr_extend_reg (ALUOp.Sub) ty x y))
2490
+
2491
+ (decl sub_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2492
+ (rule (sub_shift ty x y z) (alu_rrr_shift (ALUOp.Sub) ty x y z))
2493
+
2494
+ (decl sub_vec (Reg Reg VectorSize) Reg)
2495
+ (rule (sub_vec x y size) (vec_rrr (VecALUOp.Sub) x y size))
2496
+
2497
+ (decl sub_i128 (ValueRegs ValueRegs) ValueRegs)
2498
+ (rule (sub_i128 x y)
2499
+ (let
2500
+ ;; Get the high/low registers for `x`.
2501
+ ((x_regs ValueRegs x)
2502
+ (x_lo Reg (value_regs_get x_regs 0))
2503
+ (x_hi Reg (value_regs_get x_regs 1))
2504
+
2505
+ ;; Get the high/low registers for `y`.
2506
+ (y_regs ValueRegs y)
2507
+ (y_lo Reg (value_regs_get y_regs 0))
2508
+ (y_hi Reg (value_regs_get y_regs 1)))
2509
+ ;; the actual subtraction is `subs` followed by `sbc` which comprises
2510
+ ;; the low/high bits of the result
2511
+ (with_flags
2512
+ (sub_with_flags_paired $I64 x_lo y_lo)
2513
+ (sbc_paired $I64 x_hi y_hi))))
2514
+
2515
+ ;; Helpers for generating `madd` instructions.
2516
+
2517
+ (decl madd (Type Reg Reg Reg) Reg)
2518
+ (rule (madd ty x y z) (alu_rrrr (ALUOp3.MAdd) ty x y z))
2519
+
2520
+ ;; Helpers for generating `msub` instructions.
2521
+
2522
+ (decl msub (Type Reg Reg Reg) Reg)
2523
+ (rule (msub ty x y z) (alu_rrrr (ALUOp3.MSub) ty x y z))
2524
+
2525
+ ;; Helpers for generating `umaddl` instructions
2526
+ (decl umaddl (Reg Reg Reg) Reg)
2527
+ (rule (umaddl x y z) (alu_rrrr (ALUOp3.UMAddL) $I32 x y z))
2528
+
2529
+ ;; Helpers for generating `smaddl` instructions
2530
+ (decl smaddl (Reg Reg Reg) Reg)
2531
+ (rule (smaddl x y z) (alu_rrrr (ALUOp3.SMAddL) $I32 x y z))
2532
+
2533
+ ;; Helper for generating `uqadd` instructions.
2534
+ (decl uqadd (Reg Reg VectorSize) Reg)
2535
+ (rule (uqadd x y size) (vec_rrr (VecALUOp.Uqadd) x y size))
2536
+
2537
+ ;; Helper for generating `sqadd` instructions.
2538
+ (decl sqadd (Reg Reg VectorSize) Reg)
2539
+ (rule (sqadd x y size) (vec_rrr (VecALUOp.Sqadd) x y size))
2540
+
2541
+ ;; Helper for generating `uqsub` instructions.
2542
+ (decl uqsub (Reg Reg VectorSize) Reg)
2543
+ (rule (uqsub x y size) (vec_rrr (VecALUOp.Uqsub) x y size))
2544
+
2545
+ ;; Helper for generating `sqsub` instructions.
2546
+ (decl sqsub (Reg Reg VectorSize) Reg)
2547
+ (rule (sqsub x y size) (vec_rrr (VecALUOp.Sqsub) x y size))
2548
+
2549
+ ;; Helper for generating `umulh` instructions.
2550
+ (decl umulh (Type Reg Reg) Reg)
2551
+ (rule (umulh ty x y) (alu_rrr (ALUOp.UMulH) ty x y))
2552
+
2553
+ ;; Helper for generating `smulh` instructions.
2554
+ (decl smulh (Type Reg Reg) Reg)
2555
+ (rule (smulh ty x y) (alu_rrr (ALUOp.SMulH) ty x y))
2556
+
2557
+ ;; Helper for generating `mul` instructions.
2558
+ (decl mul (Reg Reg VectorSize) Reg)
2559
+ (rule (mul x y size) (vec_rrr (VecALUOp.Mul) x y size))
2560
+
2561
+ ;; Helper for generating `neg` instructions.
2562
+ (decl neg (Reg VectorSize) Reg)
2563
+ (rule (neg x size) (vec_misc (VecMisc2.Neg) x size))
2564
+
2565
+ ;; Helper for generating `rev16` instructions.
2566
+ (decl rev16 (Reg VectorSize) Reg)
2567
+ (rule (rev16 x size) (vec_misc (VecMisc2.Rev16) x size))
2568
+
2569
+ ;; Helper for generating `rev32` instructions.
2570
+ (decl rev32 (Reg VectorSize) Reg)
2571
+ (rule (rev32 x size) (vec_misc (VecMisc2.Rev32) x size))
2572
+
2573
+ ;; Helper for generating `rev64` instructions.
2574
+ (decl rev64 (Reg VectorSize) Reg)
2575
+ (rule (rev64 x size) (vec_misc (VecMisc2.Rev64) x size))
2576
+
2577
+ ;; Helper for generating `xtn` instructions.
2578
+ (decl xtn (Reg ScalarSize) Reg)
2579
+ (rule (xtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Xtn) x size))
2580
+
2581
+ ;; Helper for generating `fcvtn` instructions.
2582
+ (decl fcvtn (Reg ScalarSize) Reg)
2583
+ (rule (fcvtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Fcvtn) x size))
2584
+
2585
+ ;; Helper for generating `sqxtn` instructions.
2586
+ (decl sqxtn (Reg ScalarSize) Reg)
2587
+ (rule (sqxtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Sqxtn) x size))
2588
+
2589
+ ;; Helper for generating `sqxtn2` instructions.
2590
+ (decl sqxtn2 (Reg Reg ScalarSize) Reg)
2591
+ (rule (sqxtn2 x y size) (vec_rr_narrow_high (VecRRNarrowOp.Sqxtn) x y size))
2592
+
2593
+ ;; Helper for generating `sqxtun` instructions.
2594
+ (decl sqxtun (Reg ScalarSize) Reg)
2595
+ (rule (sqxtun x size) (vec_rr_narrow_low (VecRRNarrowOp.Sqxtun) x size))
2596
+
2597
+ ;; Helper for generating `sqxtun2` instructions.
2598
+ (decl sqxtun2 (Reg Reg ScalarSize) Reg)
2599
+ (rule (sqxtun2 x y size) (vec_rr_narrow_high (VecRRNarrowOp.Sqxtun) x y size))
2600
+
2601
+ ;; Helper for generating `uqxtn` instructions.
2602
+ (decl uqxtn (Reg ScalarSize) Reg)
2603
+ (rule (uqxtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Uqxtn) x size))
2604
+
2605
+ ;; Helper for generating `uqxtn2` instructions.
2606
+ (decl uqxtn2 (Reg Reg ScalarSize) Reg)
2607
+ (rule (uqxtn2 x y size) (vec_rr_narrow_high (VecRRNarrowOp.Uqxtn) x y size))
2608
+
2609
+ ;; Helper for generating `fence` instructions.
2610
+ (decl aarch64_fence () SideEffectNoResult)
2611
+ (rule (aarch64_fence)
2612
+ (SideEffectNoResult.Inst (MInst.Fence)))
2613
+
2614
+ ;; Helper for generating `csdb` instructions.
2615
+ (decl csdb () SideEffectNoResult)
2616
+ (rule (csdb)
2617
+ (SideEffectNoResult.Inst (MInst.Csdb)))
2618
+
2619
+ ;; Helper for generating `brk` instructions.
2620
+ (decl brk () SideEffectNoResult)
2621
+ (rule (brk)
2622
+ (SideEffectNoResult.Inst (MInst.Brk)))
2623
+
2624
+ ;; Helper for generating `addp` instructions.
2625
+ (decl addp (Reg Reg VectorSize) Reg)
2626
+ (rule (addp x y size) (vec_rrr (VecALUOp.Addp) x y size))
2627
+
2628
+ ;; Helper for generating `zip1` instructions.
2629
+ (decl zip1 (Reg Reg VectorSize) Reg)
2630
+ (rule (zip1 x y size) (vec_rrr (VecALUOp.Zip1) x y size))
2631
+
2632
+ ;; Helper for generating vector `abs` instructions.
2633
+ (decl vec_abs (Reg VectorSize) Reg)
2634
+ (rule (vec_abs x size) (vec_misc (VecMisc2.Abs) x size))
2635
+
2636
+ ;; Helper for generating instruction sequences to calculate a scalar absolute
2637
+ ;; value.
2638
+ (decl abs (OperandSize Reg) Reg)
2639
+ (rule (abs size x)
2640
+ (value_regs_get (with_flags (cmp_imm size x (u8_into_imm12 0))
2641
+ (csneg (Cond.Gt) x x)) 0))
2642
+
2643
+ ;; Helper for generating `addv` instructions.
2644
+ (decl addv (Reg VectorSize) Reg)
2645
+ (rule (addv x size) (vec_lanes (VecLanesOp.Addv) x size))
2646
+
2647
+ ;; Helper for generating `shll32` instructions.
2648
+ (decl shll32 (Reg bool) Reg)
2649
+ (rule (shll32 x high_half) (vec_rr_long (VecRRLongOp.Shll32) x high_half))
2650
+
2651
+ ;; Helpers for generating `addlp` instructions.
2652
+
2653
+ (decl saddlp8 (Reg) Reg)
2654
+ (rule (saddlp8 x) (vec_rr_pair_long (VecRRPairLongOp.Saddlp8) x))
2655
+
2656
+ (decl saddlp16 (Reg) Reg)
2657
+ (rule (saddlp16 x) (vec_rr_pair_long (VecRRPairLongOp.Saddlp16) x))
2658
+
2659
+ (decl uaddlp8 (Reg) Reg)
2660
+ (rule (uaddlp8 x) (vec_rr_pair_long (VecRRPairLongOp.Uaddlp8) x))
2661
+
2662
+ (decl uaddlp16 (Reg) Reg)
2663
+ (rule (uaddlp16 x) (vec_rr_pair_long (VecRRPairLongOp.Uaddlp16) x))
2664
+
2665
+ ;; Helper for generating `umlal32` instructions.
2666
+ (decl umlal32 (Reg Reg Reg bool) Reg)
2667
+ (rule (umlal32 x y z high_half) (vec_rrrr_long (VecRRRLongModOp.Umlal32) x y z high_half))
2668
+
2669
+ ;; Helper for generating `smull8` instructions.
2670
+ (decl smull8 (Reg Reg bool) Reg)
2671
+ (rule (smull8 x y high_half) (vec_rrr_long (VecRRRLongOp.Smull8) x y high_half))
2672
+
2673
+ ;; Helper for generating `umull8` instructions.
2674
+ (decl umull8 (Reg Reg bool) Reg)
2675
+ (rule (umull8 x y high_half) (vec_rrr_long (VecRRRLongOp.Umull8) x y high_half))
2676
+
2677
+ ;; Helper for generating `smull16` instructions.
2678
+ (decl smull16 (Reg Reg bool) Reg)
2679
+ (rule (smull16 x y high_half) (vec_rrr_long (VecRRRLongOp.Smull16) x y high_half))
2680
+
2681
+ ;; Helper for generating `umull16` instructions.
2682
+ (decl umull16 (Reg Reg bool) Reg)
2683
+ (rule (umull16 x y high_half) (vec_rrr_long (VecRRRLongOp.Umull16) x y high_half))
2684
+
2685
+ ;; Helper for generating `smull32` instructions.
2686
+ (decl smull32 (Reg Reg bool) Reg)
2687
+ (rule (smull32 x y high_half) (vec_rrr_long (VecRRRLongOp.Smull32) x y high_half))
2688
+
2689
+ ;; Helper for generating `umull32` instructions.
2690
+ (decl umull32 (Reg Reg bool) Reg)
2691
+ (rule (umull32 x y high_half) (vec_rrr_long (VecRRRLongOp.Umull32) x y high_half))
2692
+
2693
+ ;; Helper for generating `asr` instructions.
2694
+ (decl asr (Type Reg Reg) Reg)
2695
+ (rule (asr ty x y) (alu_rrr (ALUOp.Asr) ty x y))
2696
+
2697
+ (decl asr_imm (Type Reg ImmShift) Reg)
2698
+ (rule (asr_imm ty x imm) (alu_rr_imm_shift (ALUOp.Asr) ty x imm))
2699
+
2700
+ ;; Helper for generating `lsr` instructions.
2701
+ (decl lsr (Type Reg Reg) Reg)
2702
+ (rule (lsr ty x y) (alu_rrr (ALUOp.Lsr) ty x y))
2703
+
2704
+ (decl lsr_imm (Type Reg ImmShift) Reg)
2705
+ (rule (lsr_imm ty x imm) (alu_rr_imm_shift (ALUOp.Lsr) ty x imm))
2706
+
2707
+ ;; Helper for generating `lsl` instructions.
2708
+ (decl lsl (Type Reg Reg) Reg)
2709
+ (rule (lsl ty x y) (alu_rrr (ALUOp.Lsl) ty x y))
2710
+
2711
+ (decl lsl_imm (Type Reg ImmShift) Reg)
2712
+ (rule (lsl_imm ty x imm) (alu_rr_imm_shift (ALUOp.Lsl) ty x imm))
2713
+
2714
+ ;; Helper for generating `udiv` instructions.
2715
+ (decl a64_udiv (Type Reg Reg) Reg)
2716
+ (rule (a64_udiv ty x y) (alu_rrr (ALUOp.UDiv) ty x y))
2717
+
2718
+ ;; Helper for generating `sdiv` instructions.
2719
+ (decl a64_sdiv (Type Reg Reg) Reg)
2720
+ (rule (a64_sdiv ty x y) (alu_rrr (ALUOp.SDiv) ty x y))
2721
+
2722
+ ;; Helper for generating `not` instructions.
2723
+ (decl not (Reg VectorSize) Reg)
2724
+ (rule (not x size) (vec_misc (VecMisc2.Not) x size))
2725
+
2726
+ ;; Helpers for generating `orr_not` instructions.
2727
+
2728
+ (decl orr_not (Type Reg Reg) Reg)
2729
+ (rule (orr_not ty x y) (alu_rrr (ALUOp.OrrNot) ty x y))
2730
+
2731
+ (decl orr_not_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2732
+ (rule (orr_not_shift ty x y shift) (alu_rrr_shift (ALUOp.OrrNot) ty x y shift))
2733
+
2734
+ ;; Helpers for generating `orr` instructions.
2735
+
2736
+ (decl orr (Type Reg Reg) Reg)
2737
+ (rule (orr ty x y) (alu_rrr (ALUOp.Orr) ty x y))
2738
+
2739
+ (decl orr_imm (Type Reg ImmLogic) Reg)
2740
+ (rule (orr_imm ty x y) (alu_rr_imm_logic (ALUOp.Orr) ty x y))
2741
+
2742
+ (decl orr_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2743
+ (rule (orr_shift ty x y shift) (alu_rrr_shift (ALUOp.Orr) ty x y shift))
2744
+
2745
+ (decl orr_vec (Reg Reg VectorSize) Reg)
2746
+ (rule (orr_vec x y size) (vec_rrr (VecALUOp.Orr) x y size))
2747
+
2748
+ ;; Helpers for generating `and` instructions.
2749
+
2750
+ (decl and_reg (Type Reg Reg) Reg)
2751
+ (rule (and_reg ty x y) (alu_rrr (ALUOp.And) ty x y))
2752
+
2753
+ (decl and_imm (Type Reg ImmLogic) Reg)
2754
+ (rule (and_imm ty x y) (alu_rr_imm_logic (ALUOp.And) ty x y))
2755
+
2756
+ (decl and_vec (Reg Reg VectorSize) Reg)
2757
+ (rule (and_vec x y size) (vec_rrr (VecALUOp.And) x y size))
2758
+
2759
+ ;; Helpers for generating `eor` instructions.
2760
+ (decl eor (Type Reg Reg) Reg)
2761
+ (rule (eor ty x y) (alu_rrr (ALUOp.Eor) ty x y))
2762
+
2763
+ (decl eor_vec (Reg Reg VectorSize) Reg)
2764
+ (rule (eor_vec x y size) (vec_rrr (VecALUOp.Eor) x y size))
2765
+
2766
+ ;; Helpers for generating `bic` instructions.
2767
+
2768
+ (decl bic (Type Reg Reg) Reg)
2769
+ (rule (bic ty x y) (alu_rrr (ALUOp.AndNot) ty x y))
2770
+
2771
+ (decl bic_vec (Reg Reg VectorSize) Reg)
2772
+ (rule (bic_vec x y size) (vec_rrr (VecALUOp.Bic) x y size))
2773
+
2774
+ ;; Helpers for generating `sshl` instructions.
2775
+ (decl sshl (Reg Reg VectorSize) Reg)
2776
+ (rule (sshl x y size) (vec_rrr (VecALUOp.Sshl) x y size))
2777
+
2778
+ ;; Helpers for generating `ushl` instructions.
2779
+ (decl ushl (Reg Reg VectorSize) Reg)
2780
+ (rule (ushl x y size) (vec_rrr (VecALUOp.Ushl) x y size))
2781
+
2782
+ ;; Helpers for generating `ushl` instructions.
2783
+ (decl ushl_vec_imm (Reg u8 VectorSize) Reg)
2784
+ (rule (ushl_vec_imm x amt size) (vec_shift_imm (VecShiftImmOp.Shl) amt x size))
2785
+
2786
+ ;; Helpers for generating `ushr` instructions.
2787
+ (decl ushr_vec_imm (Reg u8 VectorSize) Reg)
2788
+ (rule (ushr_vec_imm x amt size) (vec_shift_imm (VecShiftImmOp.Ushr) amt x size))
2789
+
2790
+ ;; Helpers for generating `sshr` instructions.
2791
+ (decl sshr_vec_imm (Reg u8 VectorSize) Reg)
2792
+ (rule (sshr_vec_imm x amt size) (vec_shift_imm (VecShiftImmOp.Sshr) amt x size))
2793
+
2794
+ ;; Helpers for generating `rotr` instructions.
2795
+
2796
+ (decl a64_rotr (Type Reg Reg) Reg)
2797
+ (rule (a64_rotr ty x y) (alu_rrr (ALUOp.RotR) ty x y))
2798
+
2799
+ (decl a64_rotr_imm (Type Reg ImmShift) Reg)
2800
+ (rule (a64_rotr_imm ty x y) (alu_rr_imm_shift (ALUOp.RotR) ty x y))
2801
+
2802
+ ;; Helpers for generating `rbit` instructions.
2803
+
2804
+ (decl rbit (Type Reg) Reg)
2805
+ (rule (rbit ty x) (bit_rr (BitOp.RBit) ty x))
2806
+
2807
+ ;; Helpers for generating `clz` instructions.
2808
+
2809
+ (decl a64_clz (Type Reg) Reg)
2810
+ (rule (a64_clz ty x) (bit_rr (BitOp.Clz) ty x))
2811
+
2812
+ ;; Helpers for generating `cls` instructions.
2813
+
2814
+ (decl a64_cls (Type Reg) Reg)
2815
+ (rule (a64_cls ty x) (bit_rr (BitOp.Cls) ty x))
2816
+
2817
+ ;; Helpers for generating `rev` instructions
2818
+
2819
+ (decl a64_rev16 (Type Reg) Reg)
2820
+ (rule (a64_rev16 ty x) (bit_rr (BitOp.Rev16) ty x))
2821
+
2822
+ (decl a64_rev32 (Type Reg) Reg)
2823
+ (rule (a64_rev32 ty x) (bit_rr (BitOp.Rev32) ty x))
2824
+
2825
+ (decl a64_rev64 (Type Reg) Reg)
2826
+ (rule (a64_rev64 ty x) (bit_rr (BitOp.Rev64) ty x))
2827
+
2828
+ ;; Helpers for generating `eon` instructions.
2829
+
2830
+ (decl eon (Type Reg Reg) Reg)
2831
+ (rule (eon ty x y) (alu_rrr (ALUOp.EorNot) ty x y))
2832
+
2833
+ ;; Helpers for generating `cnt` instructions.
2834
+
2835
+ (decl vec_cnt (Reg VectorSize) Reg)
2836
+ (rule (vec_cnt x size) (vec_misc (VecMisc2.Cnt) x size))
2837
+
2838
+ ;; Helpers for generating a `bsl` instruction.
2839
+
2840
+ (decl bsl (Type Reg Reg Reg) Reg)
2841
+ (rule (bsl ty c x y)
2842
+ (vec_rrr_mod (VecALUModOp.Bsl) c x y (vector_size ty)))
2843
+
2844
+ ;; Helper for generating a `udf` instruction.
2845
+
2846
+ (decl udf (TrapCode) SideEffectNoResult)
2847
+ (rule (udf trap_code)
2848
+ (SideEffectNoResult.Inst (MInst.Udf trap_code)))
2849
+
2850
+ ;; Helpers for generating various load instructions, with varying
2851
+ ;; widths and sign/zero-extending properties.
2852
+ (decl aarch64_uload8 (AMode MemFlags) Reg)
2853
+ (rule (aarch64_uload8 amode flags)
2854
+ (let ((dst WritableReg (temp_writable_reg $I64))
2855
+ (_ Unit (emit (MInst.ULoad8 dst amode flags))))
2856
+ dst))
2857
+ (decl aarch64_sload8 (AMode MemFlags) Reg)
2858
+ (rule (aarch64_sload8 amode flags)
2859
+ (let ((dst WritableReg (temp_writable_reg $I64))
2860
+ (_ Unit (emit (MInst.SLoad8 dst amode flags))))
2861
+ dst))
2862
+ (decl aarch64_uload16 (AMode MemFlags) Reg)
2863
+ (rule (aarch64_uload16 amode flags)
2864
+ (let ((dst WritableReg (temp_writable_reg $I64))
2865
+ (_ Unit (emit (MInst.ULoad16 dst amode flags))))
2866
+ dst))
2867
+ (decl aarch64_sload16 (AMode MemFlags) Reg)
2868
+ (rule (aarch64_sload16 amode flags)
2869
+ (let ((dst WritableReg (temp_writable_reg $I64))
2870
+ (_ Unit (emit (MInst.SLoad16 dst amode flags))))
2871
+ dst))
2872
+ (decl aarch64_uload32 (AMode MemFlags) Reg)
2873
+ (rule (aarch64_uload32 amode flags)
2874
+ (let ((dst WritableReg (temp_writable_reg $I64))
2875
+ (_ Unit (emit (MInst.ULoad32 dst amode flags))))
2876
+ dst))
2877
+ (decl aarch64_sload32 (AMode MemFlags) Reg)
2878
+ (rule (aarch64_sload32 amode flags)
2879
+ (let ((dst WritableReg (temp_writable_reg $I64))
2880
+ (_ Unit (emit (MInst.SLoad32 dst amode flags))))
2881
+ dst))
2882
+ (decl aarch64_uload64 (AMode MemFlags) Reg)
2883
+ (rule (aarch64_uload64 amode flags)
2884
+ (let ((dst WritableReg (temp_writable_reg $I64))
2885
+ (_ Unit (emit (MInst.ULoad64 dst amode flags))))
2886
+ dst))
2887
+ (decl aarch64_fpuload16 (AMode MemFlags) Reg)
2888
+ (rule (aarch64_fpuload16 amode flags)
2889
+ (let ((dst WritableReg (temp_writable_reg $F64))
2890
+ (_ Unit (emit (MInst.FpuLoad16 dst amode flags))))
2891
+ dst))
2892
+ (decl aarch64_fpuload32 (AMode MemFlags) Reg)
2893
+ (rule (aarch64_fpuload32 amode flags)
2894
+ (let ((dst WritableReg (temp_writable_reg $F64))
2895
+ (_ Unit (emit (MInst.FpuLoad32 dst amode flags))))
2896
+ dst))
2897
+ (decl aarch64_fpuload64 (AMode MemFlags) Reg)
2898
+ (rule (aarch64_fpuload64 amode flags)
2899
+ (let ((dst WritableReg (temp_writable_reg $F64))
2900
+ (_ Unit (emit (MInst.FpuLoad64 dst amode flags))))
2901
+ dst))
2902
+ (decl aarch64_fpuload128 (AMode MemFlags) Reg)
2903
+ (rule (aarch64_fpuload128 amode flags)
2904
+ (let ((dst WritableReg (temp_writable_reg $F64X2))
2905
+ (_ Unit (emit (MInst.FpuLoad128 dst amode flags))))
2906
+ dst))
2907
+ (decl aarch64_loadp64 (PairAMode MemFlags) ValueRegs)
2908
+ (rule (aarch64_loadp64 amode flags)
2909
+ (let ((dst1 WritableReg (temp_writable_reg $I64))
2910
+ (dst2 WritableReg (temp_writable_reg $I64))
2911
+ (_ Unit (emit (MInst.LoadP64 dst1 dst2 amode flags))))
2912
+ (value_regs dst1 dst2)))
2913
+
2914
+ ;; Helpers for generating various store instructions with varying
2915
+ ;; widths.
2916
+ (decl aarch64_store8 (AMode MemFlags Reg) SideEffectNoResult)
2917
+ (rule (aarch64_store8 amode flags val)
2918
+ (SideEffectNoResult.Inst (MInst.Store8 val amode flags)))
2919
+ (decl aarch64_store16 (AMode MemFlags Reg) SideEffectNoResult)
2920
+ (rule (aarch64_store16 amode flags val)
2921
+ (SideEffectNoResult.Inst (MInst.Store16 val amode flags)))
2922
+ (decl aarch64_store32 (AMode MemFlags Reg) SideEffectNoResult)
2923
+ (rule (aarch64_store32 amode flags val)
2924
+ (SideEffectNoResult.Inst (MInst.Store32 val amode flags)))
2925
+ (decl aarch64_store64 (AMode MemFlags Reg) SideEffectNoResult)
2926
+ (rule (aarch64_store64 amode flags val)
2927
+ (SideEffectNoResult.Inst (MInst.Store64 val amode flags)))
2928
+ (decl aarch64_fpustore16 (AMode MemFlags Reg) SideEffectNoResult)
2929
+ (rule (aarch64_fpustore16 amode flags val)
2930
+ (SideEffectNoResult.Inst (MInst.FpuStore16 val amode flags)))
2931
+ (decl aarch64_fpustore32 (AMode MemFlags Reg) SideEffectNoResult)
2932
+ (rule (aarch64_fpustore32 amode flags val)
2933
+ (SideEffectNoResult.Inst (MInst.FpuStore32 val amode flags)))
2934
+ (decl aarch64_fpustore64 (AMode MemFlags Reg) SideEffectNoResult)
2935
+ (rule (aarch64_fpustore64 amode flags val)
2936
+ (SideEffectNoResult.Inst (MInst.FpuStore64 val amode flags)))
2937
+ (decl aarch64_fpustore128 (AMode MemFlags Reg) SideEffectNoResult)
2938
+ (rule (aarch64_fpustore128 amode flags val)
2939
+ (SideEffectNoResult.Inst (MInst.FpuStore128 val amode flags)))
2940
+ (decl aarch64_storep64 (PairAMode MemFlags Reg Reg) SideEffectNoResult)
2941
+ (rule (aarch64_storep64 amode flags val1 val2)
2942
+ (SideEffectNoResult.Inst (MInst.StoreP64 val1 val2 amode flags)))
2943
+
2944
+ ;; Helper for generating a `trapif` instruction.
2945
+
2946
+ (decl trap_if (ProducesFlags TrapCode Cond) InstOutput)
2947
+ (rule (trap_if flags trap_code cond)
2948
+ (side_effect
2949
+ (with_flags_side_effect flags
2950
+ (ConsumesFlags.ConsumesFlagsSideEffect
2951
+ (MInst.TrapIf (cond_br_cond cond) trap_code)))))
2952
+
2953
+ ;; Immediate value helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2954
+
2955
+ ;; Type of extension performed by an immediate helper
2956
+ (type ImmExtend
2957
+ (enum
2958
+ (Sign)
2959
+ (Zero)))
2960
+
2961
+ ;; Arguments:
2962
+ ;; * Immediate type
2963
+ ;; * Way to extend the immediate value to the full width of the destination
2964
+ ;; register
2965
+ ;; * Immediate value - only the bits that fit within the type are used and
2966
+ ;; extended, while the rest are ignored
2967
+ ;;
2968
+ ;; Note that, unlike the convention in the AArch64 backend, this helper leaves
2969
+ ;; all bits in the destination register in a defined state, i.e. smaller types
2970
+ ;; such as `I8` are either sign- or zero-extended.
2971
+ (decl imm (Type ImmExtend u64) Reg)
2972
+
2973
+ ;; Move wide immediate instructions; to simplify, we only match when we
2974
+ ;; are zero-extending the value.
2975
+ (rule 3 (imm (integral_ty ty) (ImmExtend.Zero) k)
2976
+ (if-let n (move_wide_const_from_u64 ty k))
2977
+ (add_range_fact
2978
+ (movz n (operand_size ty))
2979
+ 64 k k))
2980
+ (rule 2 (imm (integral_ty (ty_32_or_64 ty)) (ImmExtend.Zero) k)
2981
+ (if-let n (move_wide_const_from_inverted_u64 ty k))
2982
+ (add_range_fact
2983
+ (movn n (operand_size ty))
2984
+ 64 k k))
2985
+
2986
+ ;; Weird logical-instruction immediate in ORI using zero register; to simplify,
2987
+ ;; we only match when we are zero-extending the value.
2988
+ (rule 1 (imm (integral_ty ty) (ImmExtend.Zero) k)
2989
+ (if-let n (imm_logic_from_u64 ty k))
2990
+ (if-let m (imm_size_from_type ty))
2991
+ (add_range_fact
2992
+ (orr_imm ty (zero_reg) n)
2993
+ m k k))
2994
+
2995
+ (decl load_constant64_full (Type ImmExtend u64) Reg)
2996
+ (extern constructor load_constant64_full load_constant64_full)
2997
+
2998
+ ;; Fallback for integral 64-bit constants
2999
+ (rule (imm (integral_ty ty) extend n)
3000
+ (load_constant64_full ty extend n))
3001
+
3002
+ ;; Sign extension helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3003
+
3004
+ ;; Place a `Value` into a register, sign extending it to 32-bits
3005
+ (decl put_in_reg_sext32 (Value) Reg)
3006
+ (rule -1 (put_in_reg_sext32 val @ (value_type (fits_in_32 ty)))
3007
+ (extend val $true (ty_bits ty) 32))
3008
+
3009
+ ;; 32/64-bit passthrough.
3010
+ (rule (put_in_reg_sext32 val @ (value_type $I32)) val)
3011
+ (rule (put_in_reg_sext32 val @ (value_type $I64)) val)
3012
+
3013
+ ;; Place a `Value` into a register, zero extending it to 32-bits
3014
+ (decl put_in_reg_zext32 (Value) Reg)
3015
+ (rule -1 (put_in_reg_zext32 val @ (value_type (fits_in_32 ty)))
3016
+ (extend val $false (ty_bits ty) 32))
3017
+
3018
+ ;; 32/64-bit passthrough.
3019
+ (rule (put_in_reg_zext32 val @ (value_type $I32)) val)
3020
+ (rule (put_in_reg_zext32 val @ (value_type $I64)) val)
3021
+
3022
+ ;; Place a `Value` into a register, sign extending it to 64-bits
3023
+ (decl put_in_reg_sext64 (Value) Reg)
3024
+ (rule 1 (put_in_reg_sext64 val @ (value_type (fits_in_32 ty)))
3025
+ (extend val $true (ty_bits ty) 64))
3026
+
3027
+ ;; 64-bit passthrough.
3028
+ (rule (put_in_reg_sext64 val @ (value_type $I64)) val)
3029
+
3030
+ ;; Place a `Value` into a register, zero extending it to 64-bits
3031
+ (decl put_in_reg_zext64 (Value) Reg)
3032
+ (rule 1 (put_in_reg_zext64 val @ (value_type (fits_in_32 ty)))
3033
+ (extend val $false (ty_bits ty) 64))
3034
+
3035
+ ;; 64-bit passthrough.
3036
+ (rule (put_in_reg_zext64 val @ (value_type $I64)) val)
3037
+
3038
+ ;; Misc instruction helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3039
+
3040
+ (decl trap_if_zero_divisor (Reg) Reg)
3041
+ (rule (trap_if_zero_divisor reg)
3042
+ (let ((_ Unit (emit (MInst.TrapIf (cond_br_zero reg) (trap_code_division_by_zero)))))
3043
+ reg))
3044
+
3045
+ (decl size_from_ty (Type) OperandSize)
3046
+ (rule 1 (size_from_ty (fits_in_32 _ty)) (OperandSize.Size32))
3047
+ (rule (size_from_ty $I64) (OperandSize.Size64))
3048
+
3049
+ ;; Check for signed overflow. The only case is min_value / -1.
3050
+ ;; The following checks must be done in 32-bit or 64-bit, depending
3051
+ ;; on the input type.
3052
+ (decl trap_if_div_overflow (Type Reg Reg) Reg)
3053
+ (rule (trap_if_div_overflow ty x y)
3054
+ (let (
3055
+ ;; Check RHS is -1.
3056
+ (_ Unit (emit (MInst.AluRRImm12 (ALUOp.AddS) (operand_size ty) (writable_zero_reg) y (u8_into_imm12 1))))
3057
+
3058
+ ;; Check LHS is min_value, by subtracting 1 and branching if
3059
+ ;; there is overflow.
3060
+ (_ Unit (emit (MInst.CCmpImm (size_from_ty ty)
3061
+ x
3062
+ (u8_into_uimm5 1)
3063
+ (nzcv $false $false $false $false)
3064
+ (Cond.Eq))))
3065
+ (_ Unit (emit (MInst.TrapIf (cond_br_cond (Cond.Vs))
3066
+ (trap_code_integer_overflow))))
3067
+ )
3068
+ x))
3069
+
3070
+ ;; Check for unsigned overflow.
3071
+ (decl trap_if_overflow (ProducesFlags TrapCode) Reg)
3072
+ (rule (trap_if_overflow producer tc)
3073
+ (with_flags_reg
3074
+ producer
3075
+ (ConsumesFlags.ConsumesFlagsSideEffect
3076
+ (MInst.TrapIf (cond_br_cond (Cond.Hs)) tc))))
3077
+
3078
+ (decl sink_atomic_load (Inst) Reg)
3079
+ (rule (sink_atomic_load x @ (atomic_load _ addr))
3080
+ (let ((_ Unit (sink_inst x)))
3081
+ (put_in_reg addr)))
3082
+
3083
+ ;; Helper for generating either an `AluRRR`, `AluRRRShift`, or `AluRRImmLogic`
3084
+ ;; instruction depending on the input. Note that this requires that the `ALUOp`
3085
+ ;; specified is commutative.
3086
+ (decl alu_rs_imm_logic_commutative (ALUOp Type Value Value) Reg)
3087
+
3088
+ ;; Base case of operating on registers.
3089
+ (rule -1 (alu_rs_imm_logic_commutative op ty x y)
3090
+ (alu_rrr op ty x y))
3091
+
3092
+ ;; Special cases for when one operand is a constant.
3093
+ (rule (alu_rs_imm_logic_commutative op ty x (iconst k))
3094
+ (if-let imm (imm_logic_from_imm64 ty k))
3095
+ (alu_rr_imm_logic op ty x imm))
3096
+ (rule 1 (alu_rs_imm_logic_commutative op ty (iconst k) x)
3097
+ (if-let imm (imm_logic_from_imm64 ty k))
3098
+ (alu_rr_imm_logic op ty x imm))
3099
+
3100
+ ;; Special cases for when one operand is shifted left by a constant.
3101
+ (rule (alu_rs_imm_logic_commutative op ty x (ishl y (iconst k)))
3102
+ (if-let amt (lshl_from_imm64 ty k))
3103
+ (alu_rrr_shift op ty x y amt))
3104
+ (rule 1 (alu_rs_imm_logic_commutative op ty (ishl x (iconst k)) y)
3105
+ (if-let amt (lshl_from_imm64 ty k))
3106
+ (alu_rrr_shift op ty y x amt))
3107
+
3108
+ ;; Same as `alu_rs_imm_logic_commutative` above, except that it doesn't require
3109
+ ;; that the operation is commutative.
3110
+ (decl alu_rs_imm_logic (ALUOp Type Value Value) Reg)
3111
+ (rule -1 (alu_rs_imm_logic op ty x y)
3112
+ (alu_rrr op ty x y))
3113
+ (rule (alu_rs_imm_logic op ty x (iconst k))
3114
+ (if-let imm (imm_logic_from_imm64 ty k))
3115
+ (alu_rr_imm_logic op ty x imm))
3116
+ (rule (alu_rs_imm_logic op ty x (ishl y (iconst k)))
3117
+ (if-let amt (lshl_from_imm64 ty k))
3118
+ (alu_rrr_shift op ty x y amt))
3119
+
3120
+ ;; Helper for generating i128 bitops which simply do the same operation to the
3121
+ ;; hi/lo registers.
3122
+ ;;
3123
+ ;; TODO: Support immlogic here
3124
+ (decl i128_alu_bitop (ALUOp Type Value Value) ValueRegs)
3125
+ (rule (i128_alu_bitop op ty x y)
3126
+ (let (
3127
+ (x_regs ValueRegs (put_in_regs x))
3128
+ (x_lo Reg (value_regs_get x_regs 0))
3129
+ (x_hi Reg (value_regs_get x_regs 1))
3130
+ (y_regs ValueRegs (put_in_regs y))
3131
+ (y_lo Reg (value_regs_get y_regs 0))
3132
+ (y_hi Reg (value_regs_get y_regs 1))
3133
+ )
3134
+ (value_regs
3135
+ (alu_rrr op ty x_lo y_lo)
3136
+ (alu_rrr op ty x_hi y_hi))))
3137
+
3138
+ ;; Helper for emitting `MInst.VecLoadReplicate` instructions.
3139
+ (decl ld1r (Reg VectorSize MemFlags) Reg)
3140
+ (rule (ld1r src size flags)
3141
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
3142
+ (_ Unit (emit (MInst.VecLoadReplicate dst src size flags))))
3143
+ dst))
3144
+
3145
+ ;; Helper for emitting `MInst.LoadExtName` instructions.
3146
+ (decl load_ext_name (BoxExternalName i64) Reg)
3147
+ (rule (load_ext_name extname offset)
3148
+ (let ((dst WritableReg (temp_writable_reg $I64))
3149
+ (_ Unit (emit (MInst.LoadExtName dst extname offset))))
3150
+ dst))
3151
+
3152
+ ;; Lower the address of a load or a store.
3153
+ ;;
3154
+ ;; This will create an `AMode` representing the address of the `Value` provided
3155
+ ;; at runtime plus the immediate offset `i32` provided. The `Type` here is used
3156
+ ;; to represent the size of the value being loaded or stored for offset scaling
3157
+ ;; if necessary.
3158
+ ;;
3159
+ ;; Note that this is broken up into two phases. In the first phase this attempts
3160
+ ;; to find constants within the `val` provided and fold them in to the `offset`
3161
+ ;; provided. Afterwards though the `amode_no_more_iconst` helper is used at
3162
+ ;; which pointer constants are no longer pattern-matched and instead only
3163
+ ;; various modes are generated. This in theory would not be necessary with
3164
+ ;; mid-end optimizations that fold constants into load/store immediate offsets
3165
+ ;; instead, but for now each backend needs to do this.
3166
+ (decl amode (Type Value i32) AMode)
3167
+ (rule 0 (amode ty val offset)
3168
+ (amode_no_more_iconst ty val offset))
3169
+ (rule 1 (amode ty (iadd x (i32_from_iconst y)) offset)
3170
+ (if-let new_offset (s32_add_fallible y offset))
3171
+ (amode_no_more_iconst ty x new_offset))
3172
+ (rule 2 (amode ty (iadd (i32_from_iconst x) y) offset)
3173
+ (if-let new_offset (s32_add_fallible x offset))
3174
+ (amode_no_more_iconst ty y new_offset))
3175
+
3176
+ (decl amode_no_more_iconst (Type Value i32) AMode)
3177
+ ;; Base case: move the `offset` into a register and add it to `val` via the
3178
+ ;; amode
3179
+ (rule 0 (amode_no_more_iconst ty val offset)
3180
+ (AMode.RegReg val (imm $I64 (ImmExtend.Zero) (i64_as_u64 offset))))
3181
+
3182
+ ;; Optimize cases where the `offset` provided fits into a immediates of
3183
+ ;; various kinds of addressing modes.
3184
+ (rule 1 (amode_no_more_iconst ty val offset)
3185
+ (if-let simm9 (simm9_from_i64 offset))
3186
+ (AMode.Unscaled val simm9))
3187
+ (rule 2 (amode_no_more_iconst ty val offset)
3188
+ (if-let uimm12 (uimm12_scaled_from_i64 offset ty))
3189
+ (AMode.UnsignedOffset val uimm12))
3190
+
3191
+ ;; Optimizations where addition can fold some operations into the `amode`.
3192
+ ;;
3193
+ ;; Note that here these take higher priority than constants because an
3194
+ ;; add-of-extend can be folded into an amode, representing 2 otherwise emitted
3195
+ ;; instructions. Constants on the other hand added to the amode represent only
3196
+ ;; a single instruction folded in, so fewer instructions should be generated
3197
+ ;; with these higher priority than the rules above.
3198
+ (rule 3 (amode_no_more_iconst ty (iadd x y) offset)
3199
+ (AMode.RegReg (amode_add x offset) y))
3200
+ (rule 4 (amode_no_more_iconst ty (iadd x (uextend y @ (value_type $I32))) offset)
3201
+ (AMode.RegExtended (amode_add x offset) y (ExtendOp.UXTW)))
3202
+ (rule 4 (amode_no_more_iconst ty (iadd x (sextend y @ (value_type $I32))) offset)
3203
+ (AMode.RegExtended (amode_add x offset) y (ExtendOp.SXTW)))
3204
+ (rule 5 (amode_no_more_iconst ty (iadd (uextend x @ (value_type $I32)) y) offset)
3205
+ (AMode.RegExtended (amode_add y offset) x (ExtendOp.UXTW)))
3206
+ (rule 5 (amode_no_more_iconst ty (iadd (sextend x @ (value_type $I32)) y) offset)
3207
+ (AMode.RegExtended (amode_add y offset) x (ExtendOp.SXTW)))
3208
+
3209
+ ;; `RegScaled*` rules where this matches an addition of an "index register" to a
3210
+ ;; base register. The index register is shifted by the size of the type loaded
3211
+ ;; in bytes to enable this mode matching.
3212
+ ;;
3213
+ ;; Note that this can additionally bundle an extending operation but the
3214
+ ;; extension must happen before the shift. This will pattern-match the shift
3215
+ ;; first and then if that succeeds afterwards try to find an extend.
3216
+ (rule 6 (amode_no_more_iconst ty (iadd x (ishl y (iconst (u64_from_imm64 n)))) offset)
3217
+ (if-let $true (u64_eq (ty_bytes ty) (u64_shl 1 n)))
3218
+ (amode_reg_scaled (amode_add x offset) y))
3219
+ (rule 7 (amode_no_more_iconst ty (iadd (ishl y (iconst (u64_from_imm64 n))) x) offset)
3220
+ (if-let $true (u64_eq (ty_bytes ty) (u64_shl 1 n)))
3221
+ (amode_reg_scaled (amode_add x offset) y))
3222
+
3223
+ (decl amode_reg_scaled (Reg Value) AMode)
3224
+ (rule 0 (amode_reg_scaled base index)
3225
+ (AMode.RegScaled base index))
3226
+ (rule 1 (amode_reg_scaled base (uextend index @ (value_type $I32)))
3227
+ (AMode.RegScaledExtended base index (ExtendOp.UXTW)))
3228
+ (rule 1 (amode_reg_scaled base (sextend index @ (value_type $I32)))
3229
+ (AMode.RegScaledExtended base index (ExtendOp.SXTW)))
3230
+
3231
+ ;; Helper to add a 32-bit signed immediate to the register provided. This will
3232
+ ;; select an appropriate `add` instruction to use.
3233
+ (decl amode_add (Reg i32) Reg)
3234
+ (rule 0 (amode_add x y)
3235
+ (add $I64 x (imm $I64 (ImmExtend.Zero) (i64_as_u64 y))))
3236
+ (rule 1 (amode_add x y)
3237
+ (if-let (imm12_from_u64 imm12) (i64_as_u64 y))
3238
+ (add_imm $I64 x imm12))
3239
+ (rule 2 (amode_add x 0) x)
3240
+
3241
+ ;; Creates a `PairAMode` for the `Value` provided plus the `i32` constant
3242
+ ;; offset provided.
3243
+ (decl pair_amode (Value i32) PairAMode)
3244
+
3245
+ ;; Base case where `val` and `offset` are combined with an `add`
3246
+ (rule 0 (pair_amode val offset)
3247
+ (if-let simm7 (simm7_scaled_from_i64 0 $I64))
3248
+ (PairAMode.SignedOffset (amode_add val offset) simm7))
3249
+
3250
+ ;; Optimization when `offset` can fit into a `SImm7Scaled`.
3251
+ (rule 1 (pair_amode val offset)
3252
+ (if-let simm7 (simm7_scaled_from_i64 offset $I64))
3253
+ (PairAMode.SignedOffset val simm7))
3254
+
3255
+ (decl pure partial simm7_scaled_from_i64 (i64 Type) SImm7Scaled)
3256
+ (extern constructor simm7_scaled_from_i64 simm7_scaled_from_i64)
3257
+
3258
+ (decl pure partial uimm12_scaled_from_i64 (i64 Type) UImm12Scaled)
3259
+ (extern constructor uimm12_scaled_from_i64 uimm12_scaled_from_i64)
3260
+
3261
+ (decl pure partial simm9_from_i64 (i64) SImm9)
3262
+ (extern constructor simm9_from_i64 simm9_from_i64)
3263
+
3264
+
3265
+ (decl sink_load_into_addr (Type Inst) Reg)
3266
+ (rule (sink_load_into_addr ty x @ (load _ addr (offset32 offset)))
3267
+ (let ((_ Unit (sink_inst x)))
3268
+ (add_imm_to_addr addr (i64_as_u64 offset))))
3269
+
3270
+ (decl add_imm_to_addr (Reg u64) Reg)
3271
+ (rule 2 (add_imm_to_addr val 0) val)
3272
+ (rule 1 (add_imm_to_addr val (imm12_from_u64 imm)) (add_imm $I64 val imm))
3273
+ (rule 0 (add_imm_to_addr val offset) (add $I64 val (imm $I64 (ImmExtend.Zero) offset)))
3274
+
3275
+ ;; Lower a constant f16.
3276
+ ;;
3277
+ ;; Note that we must make sure that all bits outside the lowest 16 are set to 0
3278
+ ;; because this function is also used to load wider constants (that have zeros
3279
+ ;; in their most significant bits).
3280
+ (decl constant_f16 (u16) Reg)
3281
+ (rule 3 (constant_f16 n)
3282
+ (if-let $false (use_fp16))
3283
+ (constant_f32 n))
3284
+ (rule 2 (constant_f16 0)
3285
+ (vec_dup_imm (asimd_mov_mod_imm_zero (ScalarSize.Size32))
3286
+ $false
3287
+ (VectorSize.Size32x2)))
3288
+ (rule 1 (constant_f16 n)
3289
+ (if-let imm (asimd_fp_mod_imm_from_u64 n (ScalarSize.Size16)))
3290
+ (fpu_move_fp_imm imm (ScalarSize.Size16)))
3291
+ (rule (constant_f16 n)
3292
+ (mov_to_fpu (imm $I16 (ImmExtend.Zero) n) (ScalarSize.Size16)))
3293
+
3294
+ ;; Lower a constant f32.
3295
+ ;;
3296
+ ;; Note that we must make sure that all bits outside the lowest 32 are set to 0
3297
+ ;; because this function is also used to load wider constants (that have zeros
3298
+ ;; in their most significant bits).
3299
+ (decl constant_f32 (u32) Reg)
3300
+ (rule 3 (constant_f32 0)
3301
+ (vec_dup_imm (asimd_mov_mod_imm_zero (ScalarSize.Size32))
3302
+ $false
3303
+ (VectorSize.Size32x2)))
3304
+ (rule 2 (constant_f32 n)
3305
+ (if-let imm (asimd_fp_mod_imm_from_u64 n (ScalarSize.Size32)))
3306
+ (fpu_move_fp_imm imm (ScalarSize.Size32)))
3307
+ (rule 1 (constant_f32 (u32_as_u16 n))
3308
+ (if-let $true (use_fp16))
3309
+ (constant_f16 n))
3310
+ (rule (constant_f32 n)
3311
+ (mov_to_fpu (imm $I32 (ImmExtend.Zero) n) (ScalarSize.Size32)))
3312
+
3313
+ ;; Lower a constant f64.
3314
+ ;;
3315
+ ;; Note that we must make sure that all bits outside the lowest 64 are set to 0
3316
+ ;; because this function is also used to load wider constants (that have zeros
3317
+ ;; in their most significant bits).
3318
+ ;; TODO: Treat as half of a 128 bit vector and consider replicated patterns.
3319
+ ;; Scalar MOVI might also be an option.
3320
+ (decl constant_f64 (u64) Reg)
3321
+ (rule 4 (constant_f64 0)
3322
+ (vec_dup_imm (asimd_mov_mod_imm_zero (ScalarSize.Size32))
3323
+ $false
3324
+ (VectorSize.Size32x2)))
3325
+ (rule 3 (constant_f64 n)
3326
+ (if-let imm (asimd_fp_mod_imm_from_u64 n (ScalarSize.Size64)))
3327
+ (fpu_move_fp_imm imm (ScalarSize.Size64)))
3328
+ (rule 2 (constant_f64 (u64_as_u32 n))
3329
+ (constant_f32 n))
3330
+ (rule 1 (constant_f64 (u64_low32_bits_unset n))
3331
+ (mov_to_fpu (imm $I64 (ImmExtend.Zero) n) (ScalarSize.Size64)))
3332
+ (rule (constant_f64 n)
3333
+ (fpu_load64 (AMode.Const (emit_u64_le_const n)) (mem_flags_trusted)))
3334
+
3335
+ ;; Tests whether the low 32 bits in the input are all zero.
3336
+ (decl u64_low32_bits_unset (u64) u64)
3337
+ (extern extractor u64_low32_bits_unset u64_low32_bits_unset)
3338
+
3339
+ ;; Lower a constant f128.
3340
+ (decl constant_f128 (u128) Reg)
3341
+ (rule 3 (constant_f128 0)
3342
+ (vec_dup_imm (asimd_mov_mod_imm_zero (ScalarSize.Size8))
3343
+ $false
3344
+ (VectorSize.Size8x16)))
3345
+
3346
+ ;; If the upper 64-bits are all zero then defer to `constant_f64`.
3347
+ (rule 2 (constant_f128 (u128_as_u64 n)) (constant_f64 n))
3348
+
3349
+ ;; If the low half of the u128 equals the high half then delegate to the splat
3350
+ ;; logic as a splat of a 64-bit value.
3351
+ (rule 1 (constant_f128 (u128_replicated_u64 n))
3352
+ (splat_const n (VectorSize.Size64x2)))
3353
+
3354
+ ;; Base case is to load the constant from memory.
3355
+ (rule (constant_f128 n)
3356
+ (fpu_load128 (AMode.Const (emit_u128_le_const n)) (mem_flags_trusted)))
3357
+
3358
+ ;; Lower a vector splat with a constant parameter.
3359
+ ;;
3360
+ ;; The 64-bit input here only uses the low bits for the lane size in
3361
+ ;; `VectorSize` and all other bits are ignored.
3362
+ (decl splat_const (u64 VectorSize) Reg)
3363
+
3364
+ ;; If the splat'd constant can itself be reduced in size then attempt to do so
3365
+ ;; as it will make it easier to create the immediates in the instructions below.
3366
+ (rule 5 (splat_const (u64_replicated_u32 n) (VectorSize.Size64x2))
3367
+ (splat_const n (VectorSize.Size32x4)))
3368
+ (rule 5 (splat_const (u32_replicated_u16 n) (VectorSize.Size32x4))
3369
+ (splat_const n (VectorSize.Size16x8)))
3370
+ (rule 5 (splat_const (u32_replicated_u16 n) (VectorSize.Size32x2))
3371
+ (splat_const n (VectorSize.Size16x4)))
3372
+ (rule 5 (splat_const (u16_replicated_u8 n) (VectorSize.Size16x8))
3373
+ (splat_const n (VectorSize.Size8x16)))
3374
+ (rule 5 (splat_const (u16_replicated_u8 n) (VectorSize.Size16x4))
3375
+ (splat_const n (VectorSize.Size8x8)))
3376
+
3377
+ ;; Special cases for `vec_dup_imm` instructions where the input is either
3378
+ ;; negated or not.
3379
+ (rule 4 (splat_const n size)
3380
+ (if-let imm (asimd_mov_mod_imm_from_u64 n (vector_lane_size size)))
3381
+ (vec_dup_imm imm $false size))
3382
+ (rule 3 (splat_const n size)
3383
+ (if-let imm (asimd_mov_mod_imm_from_u64 (u64_not n) (vector_lane_size size)))
3384
+ (vec_dup_imm imm $true size))
3385
+
3386
+ ;; Special case a 32-bit splat where an immediate can be created by
3387
+ ;; concatenating the 32-bit constant into a 64-bit value
3388
+ (rule 2 (splat_const n (VectorSize.Size32x4))
3389
+ (if-let imm (asimd_mov_mod_imm_from_u64 (u64_or n (u64_shl n 32)) (ScalarSize.Size64)))
3390
+ (vec_dup_imm imm $false (VectorSize.Size64x2)))
3391
+ (rule 2 (splat_const n (VectorSize.Size32x2))
3392
+ (if-let imm (asimd_mov_mod_imm_from_u64 (u64_or n (u64_shl n 32)) (ScalarSize.Size64)))
3393
+ (fpu_extend (vec_dup_imm imm $false (VectorSize.Size64x2)) (ScalarSize.Size64)))
3394
+
3395
+ (rule 1 (splat_const n size)
3396
+ (if-let imm (asimd_fp_mod_imm_from_u64 n (vector_lane_size size)))
3397
+ (vec_dup_fp_imm imm size))
3398
+
3399
+ ;; The base case for splat is to use `vec_dup` with the immediate loaded into a
3400
+ ;; register.
3401
+ (rule (splat_const n size)
3402
+ (vec_dup (imm $I64 (ImmExtend.Zero) n) size))
3403
+
3404
+ ;; Lower a FloatCC to a Cond.
3405
+ (decl fp_cond_code (FloatCC) Cond)
3406
+ ;; TODO: Port lower_fp_condcode() to ISLE.
3407
+ (extern constructor fp_cond_code fp_cond_code)
3408
+
3409
+ ;; Lower an integer cond code.
3410
+ (decl cond_code (IntCC) Cond)
3411
+ ;; TODO: Port lower_condcode() to ISLE.
3412
+ (extern constructor cond_code cond_code)
3413
+
3414
+ ;; Invert a condition code.
3415
+ (decl invert_cond (Cond) Cond)
3416
+ ;; TODO: Port cond.invert() to ISLE.
3417
+ (extern constructor invert_cond invert_cond)
3418
+
3419
+ ;; Generate comparison to zero operator from input condition code
3420
+ (decl float_cc_cmp_zero_to_vec_misc_op (FloatCC) VecMisc2)
3421
+ (extern constructor float_cc_cmp_zero_to_vec_misc_op float_cc_cmp_zero_to_vec_misc_op)
3422
+
3423
+ (decl float_cc_cmp_zero_to_vec_misc_op_swap (FloatCC) VecMisc2)
3424
+ (extern constructor float_cc_cmp_zero_to_vec_misc_op_swap float_cc_cmp_zero_to_vec_misc_op_swap)
3425
+
3426
+ ;; Match valid generic compare to zero cases
3427
+ (decl fcmp_zero_cond (FloatCC) FloatCC)
3428
+ (extern extractor fcmp_zero_cond fcmp_zero_cond)
3429
+
3430
+ ;; Match not equal compare to zero separately as it requires two output instructions
3431
+ (decl fcmp_zero_cond_not_eq (FloatCC) FloatCC)
3432
+ (extern extractor fcmp_zero_cond_not_eq fcmp_zero_cond_not_eq)
3433
+
3434
+ ;; Helper for generating float compare to zero instructions where 2nd argument is zero
3435
+ (decl float_cmp_zero (FloatCC Reg VectorSize) Reg)
3436
+ (rule (float_cmp_zero cond rn size)
3437
+ (vec_misc (float_cc_cmp_zero_to_vec_misc_op cond) rn size))
3438
+
3439
+ ;; Helper for generating float compare to zero instructions in case where 1st argument is zero
3440
+ (decl float_cmp_zero_swap (FloatCC Reg VectorSize) Reg)
3441
+ (rule (float_cmp_zero_swap cond rn size)
3442
+ (vec_misc (float_cc_cmp_zero_to_vec_misc_op_swap cond) rn size))
3443
+
3444
+ ;; Helper for generating float compare equal to zero instruction
3445
+ (decl fcmeq0 (Reg VectorSize) Reg)
3446
+ (rule (fcmeq0 rn size)
3447
+ (vec_misc (VecMisc2.Fcmeq0) rn size))
3448
+
3449
+ ;; Generate comparison to zero operator from input condition code
3450
+ (decl int_cc_cmp_zero_to_vec_misc_op (IntCC) VecMisc2)
3451
+ (extern constructor int_cc_cmp_zero_to_vec_misc_op int_cc_cmp_zero_to_vec_misc_op)
3452
+
3453
+ (decl int_cc_cmp_zero_to_vec_misc_op_swap (IntCC) VecMisc2)
3454
+ (extern constructor int_cc_cmp_zero_to_vec_misc_op_swap int_cc_cmp_zero_to_vec_misc_op_swap)
3455
+
3456
+ ;; Match valid generic compare to zero cases
3457
+ (decl icmp_zero_cond (IntCC) IntCC)
3458
+ (extern extractor icmp_zero_cond icmp_zero_cond)
3459
+
3460
+ ;; Match not equal compare to zero separately as it requires two output instructions
3461
+ (decl icmp_zero_cond_not_eq (IntCC) IntCC)
3462
+ (extern extractor icmp_zero_cond_not_eq icmp_zero_cond_not_eq)
3463
+
3464
+ ;; Helper for generating int compare to zero instructions where 2nd argument is zero
3465
+ (decl int_cmp_zero (IntCC Reg VectorSize) Reg)
3466
+ (rule (int_cmp_zero cond rn size)
3467
+ (vec_misc (int_cc_cmp_zero_to_vec_misc_op cond) rn size))
3468
+
3469
+ ;; Helper for generating int compare to zero instructions in case where 1st argument is zero
3470
+ (decl int_cmp_zero_swap (IntCC Reg VectorSize) Reg)
3471
+ (rule (int_cmp_zero_swap cond rn size)
3472
+ (vec_misc (int_cc_cmp_zero_to_vec_misc_op_swap cond) rn size))
3473
+
3474
+ ;; Helper for generating int compare equal to zero instruction
3475
+ (decl cmeq0 (Reg VectorSize) Reg)
3476
+ (rule (cmeq0 rn size)
3477
+ (vec_misc (VecMisc2.Cmeq0) rn size))
3478
+
3479
+ ;; Helper for emitting `MInst.AtomicRMW` instructions.
3480
+ (decl lse_atomic_rmw (AtomicRMWOp Value Reg Type MemFlags) Reg)
3481
+ (rule (lse_atomic_rmw op p r_arg2 ty flags)
3482
+ (let (
3483
+ (r_addr Reg p)
3484
+ (dst WritableReg (temp_writable_reg ty))
3485
+ (_ Unit (emit (MInst.AtomicRMW op r_arg2 dst r_addr ty flags)))
3486
+ )
3487
+ dst))
3488
+
3489
+ ;; Helper for emitting `MInst.AtomicCAS` instructions.
3490
+ (decl lse_atomic_cas (Reg Reg Reg Type MemFlags) Reg)
3491
+ (rule (lse_atomic_cas addr expect replace ty flags)
3492
+ (let (
3493
+ (dst WritableReg (temp_writable_reg ty))
3494
+ (_ Unit (emit (MInst.AtomicCAS dst expect replace addr ty flags)))
3495
+ )
3496
+ dst))
3497
+
3498
+ ;; Helper for emitting `MInst.AtomicRMWLoop` instructions.
3499
+ ;; - Make sure that both args are in virtual regs, since in effect
3500
+ ;; we have to do a parallel copy to get them safely to the AtomicRMW input
3501
+ ;; regs, and that's not guaranteed safe if either is in a real reg.
3502
+ ;; - Move the args to the preordained AtomicRMW input regs
3503
+ ;; - And finally, copy the preordained AtomicRMW output reg to its destination.
3504
+ (decl atomic_rmw_loop (AtomicRMWLoopOp Reg Reg Type MemFlags) Reg)
3505
+ (rule (atomic_rmw_loop op addr operand ty flags)
3506
+ (let ((dst WritableReg (temp_writable_reg $I64))
3507
+ (scratch1 WritableReg (temp_writable_reg $I64))
3508
+ (scratch2 WritableReg (temp_writable_reg $I64))
3509
+ (_ Unit (emit (MInst.AtomicRMWLoop ty op flags addr operand dst scratch1 scratch2))))
3510
+ dst))
3511
+
3512
+ ;; Helper for emitting `MInst.AtomicCASLoop` instructions.
3513
+ ;; This is very similar to, but not identical to, the AtomicRmw case. Note
3514
+ ;; that the AtomicCASLoop sequence does its own masking, so we don't need to worry
3515
+ ;; about zero-extending narrow (I8/I16/I32) values here.
3516
+ ;; Make sure that all three args are in virtual regs. See corresponding comment
3517
+ ;; for `atomic_rmw_loop` above.
3518
+ (decl atomic_cas_loop (Reg Reg Reg Type MemFlags) Reg)
3519
+ (rule (atomic_cas_loop addr expect replace ty flags)
3520
+ (let ((dst WritableReg (temp_writable_reg $I64))
3521
+ (scratch WritableReg (temp_writable_reg $I64))
3522
+ (_ Unit (emit (MInst.AtomicCASLoop ty flags addr expect replace dst scratch))))
3523
+ dst))
3524
+
3525
+ ;; Helper for emitting `MInst.MovPReg` instructions.
3526
+ (decl mov_from_preg (PReg) Reg)
3527
+ (rule (mov_from_preg src)
3528
+ (let ((dst WritableReg (temp_writable_reg $I64))
3529
+ (_ Unit (emit (MInst.MovFromPReg dst src))))
3530
+ dst))
3531
+
3532
+ (decl mov_to_preg (PReg Reg) SideEffectNoResult)
3533
+ (rule (mov_to_preg dst src)
3534
+ (SideEffectNoResult.Inst (MInst.MovToPReg dst src)))
3535
+
3536
+ (decl preg_sp () PReg)
3537
+ (extern constructor preg_sp preg_sp)
3538
+
3539
+ (decl preg_fp () PReg)
3540
+ (extern constructor preg_fp preg_fp)
3541
+
3542
+ (decl preg_link () PReg)
3543
+ (extern constructor preg_link preg_link)
3544
+
3545
+ (decl preg_pinned () PReg)
3546
+ (extern constructor preg_pinned preg_pinned)
3547
+
3548
+ (decl aarch64_sp () Reg)
3549
+ (rule (aarch64_sp)
3550
+ (mov_from_preg (preg_sp)))
3551
+
3552
+ (decl aarch64_fp () Reg)
3553
+ (rule (aarch64_fp)
3554
+ (mov_from_preg (preg_fp)))
3555
+
3556
+ (decl aarch64_link () Reg)
3557
+ (rule 1 (aarch64_link)
3558
+ (if (preserve_frame_pointers))
3559
+ (if (sign_return_address_disabled))
3560
+ (let ((dst WritableReg (temp_writable_reg $I64))
3561
+ ;; Even though LR is not an allocatable register, whether it
3562
+ ;; contains the return address for the current function is
3563
+ ;; unknown at this point. For example, this operation may come
3564
+ ;; immediately after a call, in which case LR would not have a
3565
+ ;; valid value. That's why we must obtain the return address from
3566
+ ;; the frame record that corresponds to the current subroutine on
3567
+ ;; the stack; the presence of the record is guaranteed by the
3568
+ ;; `preserve_frame_pointers` setting.
3569
+ (addr AMode (AMode.FPOffset 8))
3570
+ (_ Unit (emit (MInst.ULoad64 dst addr (mem_flags_trusted)))))
3571
+ dst))
3572
+
3573
+ (rule (aarch64_link)
3574
+ (if (preserve_frame_pointers))
3575
+ ;; Similarly to the rule above, we must load the return address from the
3576
+ ;; the frame record. Furthermore, we can use LR as a scratch register
3577
+ ;; because the function will set it to the return address immediately
3578
+ ;; before returning.
3579
+ (let ((addr AMode (AMode.FPOffset 8))
3580
+ (lr WritableReg (writable_link_reg))
3581
+ (_ Unit (emit (MInst.ULoad64 lr addr (mem_flags_trusted))))
3582
+ (_ Unit (emit (MInst.Xpaclri))))
3583
+ (mov_from_preg (preg_link))))
3584
+
3585
+ ;; Helper for getting the maximum shift amount for a type.
3586
+
3587
+ (decl max_shift (Type) u8)
3588
+ (rule (max_shift $F64) 63)
3589
+ (rule (max_shift $F32) 31)
3590
+
3591
+ ;; Helper for generating `fcopysign` instruction sequences.
3592
+
3593
+ (decl fcopy_sign (Reg Reg Type) Reg)
3594
+ (rule 1 (fcopy_sign x y (ty_scalar_float ty))
3595
+ (let ((dst WritableReg (temp_writable_reg $F64))
3596
+ (tmp Reg (fpu_rri (fpu_op_ri_ushr (ty_bits ty) (max_shift ty)) y))
3597
+ (_ Unit (emit (MInst.FpuRRIMod (fpu_op_ri_sli (ty_bits ty) (max_shift ty)) dst x tmp))))
3598
+ dst))
3599
+ (rule (fcopy_sign x y ty @ (multi_lane _ _))
3600
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
3601
+ (tmp Reg (ushr_vec_imm y (max_shift (lane_type ty)) (vector_size ty)))
3602
+ (_ Unit (emit (MInst.VecShiftImmMod (VecShiftImmModOp.Sli) dst x tmp (vector_size ty) (max_shift (lane_type ty))))))
3603
+ dst))
3604
+
3605
+ ;; Helpers for generating `MInst.FpuToInt` instructions.
3606
+
3607
+ (decl fpu_to_int_nan_check (ScalarSize Reg) Reg)
3608
+ (rule (fpu_to_int_nan_check size src)
3609
+ (let ((r ValueRegs
3610
+ (with_flags (fpu_cmp size src src)
3611
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3612
+ (MInst.TrapIf (cond_br_cond (Cond.Vs))
3613
+ (trap_code_bad_conversion_to_integer))
3614
+ src))))
3615
+ (value_regs_get r 0)))
3616
+
3617
+ ;; Checks that the value is not less than the minimum bound,
3618
+ ;; accepting a boolean (whether the type is signed), input type,
3619
+ ;; output type, and registers containing the source and minimum bound.
3620
+ (decl fpu_to_int_underflow_check (bool Type Type Reg Reg) Reg)
3621
+ (rule (fpu_to_int_underflow_check $true $F32 (fits_in_16 out_ty) src min)
3622
+ (let ((r ValueRegs
3623
+ (with_flags (fpu_cmp (ScalarSize.Size32) src min)
3624
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3625
+ (MInst.TrapIf (cond_br_cond (Cond.Le))
3626
+ (trap_code_integer_overflow))
3627
+ src))))
3628
+ (value_regs_get r 0)))
3629
+ (rule (fpu_to_int_underflow_check $true $F64 (fits_in_32 out_ty) src min)
3630
+ (let ((r ValueRegs
3631
+ (with_flags (fpu_cmp (ScalarSize.Size64) src min)
3632
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3633
+ (MInst.TrapIf (cond_br_cond (Cond.Le))
3634
+ (trap_code_integer_overflow))
3635
+ src))))
3636
+ (value_regs_get r 0)))
3637
+ (rule -1 (fpu_to_int_underflow_check $true in_ty _out_ty src min)
3638
+ (let ((r ValueRegs
3639
+ (with_flags (fpu_cmp (scalar_size in_ty) src min)
3640
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3641
+ (MInst.TrapIf (cond_br_cond (Cond.Lt))
3642
+ (trap_code_integer_overflow))
3643
+ src))))
3644
+ (value_regs_get r 0)))
3645
+ (rule (fpu_to_int_underflow_check $false in_ty _out_ty src min)
3646
+ (let ((r ValueRegs
3647
+ (with_flags (fpu_cmp (scalar_size in_ty) src min)
3648
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3649
+ (MInst.TrapIf (cond_br_cond (Cond.Le))
3650
+ (trap_code_integer_overflow))
3651
+ src))))
3652
+ (value_regs_get r 0)))
3653
+
3654
+ (decl fpu_to_int_overflow_check (ScalarSize Reg Reg) Reg)
3655
+ (rule (fpu_to_int_overflow_check size src max)
3656
+ (let ((r ValueRegs
3657
+ (with_flags (fpu_cmp size src max)
3658
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3659
+ (MInst.TrapIf (cond_br_cond (Cond.Ge))
3660
+ (trap_code_integer_overflow))
3661
+ src))))
3662
+ (value_regs_get r 0)))
3663
+
3664
+ ;; Emits the appropriate instruction sequence to convert a
3665
+ ;; floating-point value to an integer, trapping if the value
3666
+ ;; is a NaN or does not fit in the target type.
3667
+ ;; Accepts the specific conversion op, the source register,
3668
+ ;; whether the input is signed, and finally the input and output
3669
+ ;; types.
3670
+ (decl fpu_to_int_cvt (FpuToIntOp Reg bool Type Type) Reg)
3671
+ (rule (fpu_to_int_cvt op src signed in_ty out_ty)
3672
+ (let ((size ScalarSize (scalar_size in_ty))
3673
+ (in_bits u8 (ty_bits in_ty))
3674
+ (out_bits u8 (ty_bits out_ty))
3675
+ (src Reg (fpu_to_int_nan_check size src))
3676
+ (min Reg (min_fp_value signed in_bits out_bits))
3677
+ (src Reg (fpu_to_int_underflow_check signed in_ty out_ty src min))
3678
+ (max Reg (max_fp_value signed in_bits out_bits))
3679
+ (src Reg (fpu_to_int_overflow_check size src max)))
3680
+ (fpu_to_int op src)))
3681
+
3682
+ ;; Emits the appropriate instruction sequence to convert a
3683
+ ;; floating-point value to an integer, saturating if the value
3684
+ ;; does not fit in the target type.
3685
+ ;; Accepts the specific conversion op, the source register,
3686
+ ;; whether the input is signed, and finally the output type.
3687
+ (decl fpu_to_int_cvt_sat (FpuToIntOp Reg bool Type) Reg)
3688
+ (rule 1 (fpu_to_int_cvt_sat op src _ $I64)
3689
+ (fpu_to_int op src))
3690
+ (rule 1 (fpu_to_int_cvt_sat op src _ $I32)
3691
+ (fpu_to_int op src))
3692
+ (rule (fpu_to_int_cvt_sat op src $false (fits_in_16 out_ty))
3693
+ (let ((result Reg (fpu_to_int op src))
3694
+ (max Reg (imm out_ty (ImmExtend.Zero) (ty_mask out_ty))))
3695
+ (with_flags_reg
3696
+ (cmp (OperandSize.Size32) result max)
3697
+ (csel (Cond.Hi) max result))))
3698
+ (rule (fpu_to_int_cvt_sat op src $true (fits_in_16 out_ty))
3699
+ (let ((result Reg (fpu_to_int op src))
3700
+ (max Reg (signed_max out_ty))
3701
+ (min Reg (signed_min out_ty))
3702
+ (result Reg (with_flags_reg
3703
+ (cmp (operand_size out_ty) result max)
3704
+ (csel (Cond.Gt) max result)))
3705
+ (result Reg (with_flags_reg
3706
+ (cmp (operand_size out_ty) result min)
3707
+ (csel (Cond.Lt) min result))))
3708
+ result))
3709
+
3710
+ (decl signed_min (Type) Reg)
3711
+ (rule (signed_min $I8) (imm $I8 (ImmExtend.Sign) 0x80))
3712
+ (rule (signed_min $I16) (imm $I16 (ImmExtend.Sign) 0x8000))
3713
+
3714
+ (decl signed_max (Type) Reg)
3715
+ (rule (signed_max $I8) (imm $I8 (ImmExtend.Sign) 0x7F))
3716
+ (rule (signed_max $I16) (imm $I16 (ImmExtend.Sign) 0x7FFF))
3717
+
3718
+ (decl fpu_to_int (FpuToIntOp Reg) Reg)
3719
+ (rule (fpu_to_int op src)
3720
+ (let ((dst WritableReg (temp_writable_reg $I64))
3721
+ (_ Unit (emit (MInst.FpuToInt op dst src))))
3722
+ dst))
3723
+
3724
+ ;; Helper for generating `MInst.IntToFpu` instructions.
3725
+
3726
+ (decl int_to_fpu (IntToFpuOp Reg) Reg)
3727
+ (rule (int_to_fpu op src)
3728
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
3729
+ (_ Unit (emit (MInst.IntToFpu op dst src))))
3730
+ dst))
3731
+
3732
+ ;;;; Helpers for Emitting Calls ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3733
+
3734
+ (decl gen_call (SigRef ExternalName RelocDistance ValueSlice) InstOutput)
3735
+ (extern constructor gen_call gen_call)
3736
+
3737
+ (decl gen_call_indirect (SigRef Value ValueSlice) InstOutput)
3738
+ (extern constructor gen_call_indirect gen_call_indirect)
3739
+
3740
+ ;; Helpers for pinned register manipulation.
3741
+
3742
+ (decl write_pinned_reg (Reg) SideEffectNoResult)
3743
+ (rule (write_pinned_reg val)
3744
+ (mov_to_preg (preg_pinned) val))
3745
+
3746
+ ;; Helpers for stackslot effective address generation.
3747
+
3748
+ (decl compute_stack_addr (StackSlot Offset32) Reg)
3749
+ (rule (compute_stack_addr stack_slot offset)
3750
+ (let ((dst WritableReg (temp_writable_reg $I64))
3751
+ (_ Unit (emit (abi_stackslot_addr dst stack_slot offset))))
3752
+ dst))
3753
+
3754
+ ;; Helper for emitting instruction sequences to perform a vector comparison.
3755
+
3756
+ (decl vec_cmp_vc (Reg Reg VectorSize) Reg)
3757
+ (rule (vec_cmp_vc rn rm size)
3758
+ (let ((dst Reg (vec_rrr (VecALUOp.Fcmeq) rn rn size))
3759
+ (tmp Reg (vec_rrr (VecALUOp.Fcmeq) rm rm size))
3760
+ (dst Reg (vec_rrr (VecALUOp.And) dst tmp size)))
3761
+ dst))
3762
+
3763
+ (decl vec_cmp (Reg Reg Type Cond) Reg)
3764
+
3765
+ ;; Floating point Vs / Vc
3766
+ (rule (vec_cmp rn rm ty (Cond.Vc))
3767
+ (if (ty_vector_float ty))
3768
+ (vec_cmp_vc rn rm (vector_size ty)))
3769
+ (rule (vec_cmp rn rm ty (Cond.Vs))
3770
+ (if (ty_vector_float ty))
3771
+ (let ((tmp Reg (vec_cmp_vc rn rm (vector_size ty))))
3772
+ (vec_misc (VecMisc2.Not) tmp (vector_size ty))))
3773
+
3774
+ ;; 'Less than' operations are implemented by swapping the order of
3775
+ ;; operands and using the 'greater than' instructions.
3776
+ ;; 'Not equal' is implemented with 'equal' and inverting the result.
3777
+
3778
+ ;; Floating-point
3779
+ (rule (vec_cmp rn rm ty (Cond.Eq))
3780
+ (if (ty_vector_float ty))
3781
+ (vec_rrr (VecALUOp.Fcmeq) rn rm (vector_size ty)))
3782
+ (rule (vec_cmp rn rm ty (Cond.Ne))
3783
+ (if (ty_vector_float ty))
3784
+ (let ((tmp Reg (vec_rrr (VecALUOp.Fcmeq) rn rm (vector_size ty))))
3785
+ (vec_misc (VecMisc2.Not) tmp (vector_size ty))))
3786
+ (rule (vec_cmp rn rm ty (Cond.Ge))
3787
+ (if (ty_vector_float ty))
3788
+ (vec_rrr (VecALUOp.Fcmge) rn rm (vector_size ty)))
3789
+ (rule (vec_cmp rn rm ty (Cond.Gt))
3790
+ (if (ty_vector_float ty))
3791
+ (vec_rrr (VecALUOp.Fcmgt) rn rm (vector_size ty)))
3792
+ ;; Floating-point swapped-operands
3793
+ (rule (vec_cmp rn rm ty (Cond.Mi))
3794
+ (if (ty_vector_float ty))
3795
+ (vec_rrr (VecALUOp.Fcmgt) rm rn (vector_size ty)))
3796
+ (rule (vec_cmp rn rm ty (Cond.Ls))
3797
+ (if (ty_vector_float ty))
3798
+ (vec_rrr (VecALUOp.Fcmge) rm rn (vector_size ty)))
3799
+
3800
+ ;; Integer
3801
+ (rule 1 (vec_cmp rn rm ty (Cond.Eq))
3802
+ (if (ty_vector_not_float ty))
3803
+ (vec_rrr (VecALUOp.Cmeq) rn rm (vector_size ty)))
3804
+ (rule 1 (vec_cmp rn rm ty (Cond.Ne))
3805
+ (if (ty_vector_not_float ty))
3806
+ (let ((tmp Reg (vec_rrr (VecALUOp.Cmeq) rn rm (vector_size ty))))
3807
+ (vec_misc (VecMisc2.Not) tmp (vector_size ty))))
3808
+ (rule 1 (vec_cmp rn rm ty (Cond.Ge))
3809
+ (if (ty_vector_not_float ty))
3810
+ (vec_rrr (VecALUOp.Cmge) rn rm (vector_size ty)))
3811
+ (rule 1 (vec_cmp rn rm ty (Cond.Gt))
3812
+ (if (ty_vector_not_float ty))
3813
+ (vec_rrr (VecALUOp.Cmgt) rn rm (vector_size ty)))
3814
+ (rule (vec_cmp rn rm ty (Cond.Hs))
3815
+ (if (ty_vector_not_float ty))
3816
+ (vec_rrr (VecALUOp.Cmhs) rn rm (vector_size ty)))
3817
+ (rule (vec_cmp rn rm ty (Cond.Hi))
3818
+ (if (ty_vector_not_float ty))
3819
+ (vec_rrr (VecALUOp.Cmhi) rn rm (vector_size ty)))
3820
+ ;; Integer swapped-operands
3821
+ (rule (vec_cmp rn rm ty (Cond.Le))
3822
+ (if (ty_vector_not_float ty))
3823
+ (vec_rrr (VecALUOp.Cmge) rm rn (vector_size ty)))
3824
+ (rule (vec_cmp rn rm ty (Cond.Lt))
3825
+ (if (ty_vector_not_float ty))
3826
+ (vec_rrr (VecALUOp.Cmgt) rm rn (vector_size ty)))
3827
+ (rule 1 (vec_cmp rn rm ty (Cond.Ls))
3828
+ (if (ty_vector_not_float ty))
3829
+ (vec_rrr (VecALUOp.Cmhs) rm rn (vector_size ty)))
3830
+ (rule (vec_cmp rn rm ty (Cond.Lo))
3831
+ (if (ty_vector_not_float ty))
3832
+ (vec_rrr (VecALUOp.Cmhi) rm rn (vector_size ty)))
3833
+
3834
+ ;; Helper for determining if any value in a vector is true.
3835
+ ;; This operation is implemented by using umaxp to create a scalar value, which
3836
+ ;; is then compared against zero.
3837
+ ;;
3838
+ ;; umaxp vn.4s, vm.4s, vm.4s
3839
+ ;; mov xm, vn.d[0]
3840
+ ;; cmp xm, #0
3841
+ (decl vanytrue (Reg Type) ProducesFlags)
3842
+ (rule 1 (vanytrue src (ty_vec128 ty))
3843
+ (let ((src Reg (vec_rrr (VecALUOp.Umaxp) src src (VectorSize.Size32x4)))
3844
+ (src Reg (mov_from_vec src 0 (ScalarSize.Size64))))
3845
+ (cmp_imm (OperandSize.Size64) src (u8_into_imm12 0))))
3846
+ (rule (vanytrue src ty)
3847
+ (if (ty_vec64 ty))
3848
+ (let ((src Reg (mov_from_vec src 0 (ScalarSize.Size64))))
3849
+ (cmp_imm (OperandSize.Size64) src (u8_into_imm12 0))))
3850
+
3851
+ ;;;; TLS Values ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3852
+
3853
+ ;; Helper for emitting ElfTlsGetAddr.
3854
+ (decl elf_tls_get_addr (ExternalName) Reg)
3855
+ (rule (elf_tls_get_addr name)
3856
+ (let ((dst WritableReg (temp_writable_reg $I64))
3857
+ (tmp WritableReg (temp_writable_reg $I64))
3858
+ (_ Unit (emit (MInst.ElfTlsGetAddr (box_external_name name) dst tmp))))
3859
+ dst))
3860
+
3861
+ (decl macho_tls_get_addr (ExternalName) Reg)
3862
+ (rule (macho_tls_get_addr name)
3863
+ (let ((dst WritableReg (temp_writable_reg $I64))
3864
+ (_ Unit (emit (MInst.MachOTlsGetAddr name dst))))
3865
+ dst))
3866
+
3867
+ ;; A tuple of `ProducesFlags` and `IntCC`.
3868
+ (type FlagsAndCC (enum (FlagsAndCC (flags ProducesFlags)
3869
+ (cc IntCC))))
3870
+
3871
+ ;; Helper constructor for `FlagsAndCC`.
3872
+ (decl flags_and_cc (ProducesFlags IntCC) FlagsAndCC)
3873
+ (rule (flags_and_cc flags cc) (FlagsAndCC.FlagsAndCC flags cc))
3874
+
3875
+ ;; Materialize a `FlagsAndCC` into a boolean `ValueRegs`.
3876
+ (decl flags_and_cc_to_bool (FlagsAndCC) ValueRegs)
3877
+ (rule (flags_and_cc_to_bool (FlagsAndCC.FlagsAndCC flags cc))
3878
+ (with_flags flags (materialize_bool_result (cond_code cc))))
3879
+
3880
+ ;; Get the `ProducesFlags` out of a `FlagsAndCC`.
3881
+ (decl flags_and_cc_flags (FlagsAndCC) ProducesFlags)
3882
+ (rule (flags_and_cc_flags (FlagsAndCC.FlagsAndCC flags _cc)) flags)
3883
+
3884
+ ;; Get the `IntCC` out of a `FlagsAndCC`.
3885
+ (decl flags_and_cc_cc (FlagsAndCC) IntCC)
3886
+ (rule (flags_and_cc_cc (FlagsAndCC.FlagsAndCC _flags cc)) cc)
3887
+
3888
+ ;; Helpers for lowering `icmp` sequences.
3889
+ ;; `lower_icmp` contains shared functionality for lowering `icmp`
3890
+ ;; sequences, which `lower_icmp_into_{reg,flags}` extend from.
3891
+ (decl lower_icmp (IntCC Value Value Type) FlagsAndCC)
3892
+ (decl lower_icmp_into_reg (IntCC Value Value Type Type) ValueRegs)
3893
+ (decl lower_icmp_into_flags (IntCC Value Value Type) FlagsAndCC)
3894
+ (decl lower_icmp_const (IntCC Value u64 Type) FlagsAndCC)
3895
+ ;; For most cases, `lower_icmp_into_flags` is the same as `lower_icmp`,
3896
+ ;; except for some I128 cases (see below).
3897
+ (rule -1 (lower_icmp_into_flags cond x y ty) (lower_icmp cond x y ty))
3898
+
3899
+ ;; Vectors.
3900
+ ;; `icmp` into flags for vectors is invalid.
3901
+ (rule 1 (lower_icmp_into_reg cond x y in_ty @ (multi_lane _ _) _out_ty)
3902
+ (let ((cond Cond (cond_code cond))
3903
+ (rn Reg (put_in_reg x))
3904
+ (rm Reg (put_in_reg y)))
3905
+ (vec_cmp rn rm in_ty cond)))
3906
+
3907
+ ;; Determines the appropriate extend op given the value type and the given ArgumentExtension.
3908
+ (decl lower_extend_op (Type ArgumentExtension) ExtendOp)
3909
+ (rule (lower_extend_op $I8 (ArgumentExtension.Sext)) (ExtendOp.SXTB))
3910
+ (rule (lower_extend_op $I16 (ArgumentExtension.Sext)) (ExtendOp.SXTH))
3911
+ (rule (lower_extend_op $I8 (ArgumentExtension.Uext)) (ExtendOp.UXTB))
3912
+ (rule (lower_extend_op $I16 (ArgumentExtension.Uext)) (ExtendOp.UXTH))
3913
+
3914
+ ;; Integers <= 64-bits.
3915
+ (rule -2 (lower_icmp_into_reg cond rn rm in_ty out_ty)
3916
+ (if (ty_int_ref_scalar_64 in_ty))
3917
+ (let ((cc Cond (cond_code cond)))
3918
+ (flags_and_cc_to_bool (lower_icmp cond rn rm in_ty))))
3919
+
3920
+ (rule 1 (lower_icmp cond rn rm (fits_in_16 ty))
3921
+ (if (signed_cond_code cond))
3922
+ (let ((rn Reg (put_in_reg_sext32 rn)))
3923
+ (flags_and_cc (cmp_extend (operand_size ty) rn rm (lower_extend_op ty (ArgumentExtension.Sext))) cond)))
3924
+ (rule -1 (lower_icmp cond rn (imm12_from_value rm) (fits_in_16 ty))
3925
+ (let ((rn Reg (put_in_reg_zext32 rn)))
3926
+ (flags_and_cc (cmp_imm (operand_size ty) rn rm) cond)))
3927
+ (rule -2 (lower_icmp cond rn rm (fits_in_16 ty))
3928
+ (let ((rn Reg (put_in_reg_zext32 rn)))
3929
+ (flags_and_cc (cmp_extend (operand_size ty) rn rm (lower_extend_op ty (ArgumentExtension.Uext))) cond)))
3930
+ (rule -3 (lower_icmp cond rn (u64_from_iconst c) ty)
3931
+ (if (ty_int_ref_scalar_64 ty))
3932
+ (lower_icmp_const cond rn c ty))
3933
+ (rule -4 (lower_icmp cond rn rm ty)
3934
+ (if (ty_int_ref_scalar_64 ty))
3935
+ (flags_and_cc (cmp (operand_size ty) rn rm) cond))
3936
+
3937
+ ;; We get better encodings when testing against an immediate that's even instead
3938
+ ;; of odd, so rewrite comparisons to use even immediates:
3939
+ ;;
3940
+ ;; A >= B + 1
3941
+ ;; ==> A - 1 >= B
3942
+ ;; ==> A > B
3943
+ (rule (lower_icmp_const (IntCC.UnsignedGreaterThanOrEqual) a b ty)
3944
+ (if (ty_int_ref_scalar_64 ty))
3945
+ (if-let $true (u64_is_odd b))
3946
+ (if-let (imm12_from_u64 imm) (u64_sub b 1))
3947
+ (flags_and_cc (cmp_imm (operand_size ty) a imm) (IntCC.UnsignedGreaterThan)))
3948
+ (rule (lower_icmp_const (IntCC.SignedGreaterThanOrEqual) a b ty)
3949
+ (if (ty_int_ref_scalar_64 ty))
3950
+ (if-let $true (u64_is_odd b))
3951
+ (if-let (imm12_from_u64 imm) (u64_sub b 1))
3952
+ (flags_and_cc (cmp_imm (operand_size ty) a imm) (IntCC.SignedGreaterThan)))
3953
+
3954
+ (rule -1 (lower_icmp_const cond rn (imm12_from_u64 c) ty)
3955
+ (if (ty_int_ref_scalar_64 ty))
3956
+ (flags_and_cc (cmp_imm (operand_size ty) rn c) cond))
3957
+ (rule -2 (lower_icmp_const cond rn c ty)
3958
+ (if (ty_int_ref_scalar_64 ty))
3959
+ (flags_and_cc (cmp (operand_size ty) rn (imm ty (ImmExtend.Zero) c)) cond))
3960
+
3961
+
3962
+ ;; 128-bit integers.
3963
+ (rule (lower_icmp_into_reg cond @ (IntCC.Equal) rn rm $I128 $I8)
3964
+ (let ((cc Cond (cond_code cond)))
3965
+ (flags_and_cc_to_bool
3966
+ (lower_icmp cond rn rm $I128))))
3967
+ (rule (lower_icmp_into_reg cond @ (IntCC.NotEqual) rn rm $I128 $I8)
3968
+ (let ((cc Cond (cond_code cond)))
3969
+ (flags_and_cc_to_bool
3970
+ (lower_icmp cond rn rm $I128))))
3971
+
3972
+ ;; cmp lhs_lo, rhs_lo
3973
+ ;; ccmp lhs_hi, rhs_hi, #0, eq
3974
+ (decl lower_icmp_i128_eq_ne (Value Value) ProducesFlags)
3975
+ (rule (lower_icmp_i128_eq_ne lhs rhs)
3976
+ (let ((lhs ValueRegs (put_in_regs lhs))
3977
+ (rhs ValueRegs (put_in_regs rhs))
3978
+ (lhs_lo Reg (value_regs_get lhs 0))
3979
+ (lhs_hi Reg (value_regs_get lhs 1))
3980
+ (rhs_lo Reg (value_regs_get rhs 0))
3981
+ (rhs_hi Reg (value_regs_get rhs 1))
3982
+ (cmp_inst ProducesFlags (cmp (OperandSize.Size64) lhs_lo rhs_lo)))
3983
+ (ccmp (OperandSize.Size64) lhs_hi rhs_hi
3984
+ (nzcv $false $false $false $false) (Cond.Eq) cmp_inst)))
3985
+
3986
+ (rule (lower_icmp (IntCC.Equal) lhs rhs $I128)
3987
+ (flags_and_cc (lower_icmp_i128_eq_ne lhs rhs) (IntCC.Equal)))
3988
+ (rule (lower_icmp (IntCC.NotEqual) lhs rhs $I128)
3989
+ (flags_and_cc (lower_icmp_i128_eq_ne lhs rhs) (IntCC.NotEqual)))
3990
+
3991
+ ;; cmp lhs_lo, rhs_lo
3992
+ ;; cset tmp1, unsigned_cond
3993
+ ;; cmp lhs_hi, rhs_hi
3994
+ ;; cset tmp2, cond
3995
+ ;; csel dst, tmp1, tmp2, eq
3996
+ (rule -1 (lower_icmp_into_reg cond lhs rhs $I128 $I8)
3997
+ (let ((unsigned_cond Cond (cond_code (intcc_unsigned cond)))
3998
+ (cond Cond (cond_code cond))
3999
+ (lhs ValueRegs (put_in_regs lhs))
4000
+ (rhs ValueRegs (put_in_regs rhs))
4001
+ (lhs_lo Reg (value_regs_get lhs 0))
4002
+ (lhs_hi Reg (value_regs_get lhs 1))
4003
+ (rhs_lo Reg (value_regs_get rhs 0))
4004
+ (rhs_hi Reg (value_regs_get rhs 1))
4005
+ (tmp1 Reg (with_flags_reg (cmp (OperandSize.Size64) lhs_lo rhs_lo)
4006
+ (materialize_bool_result unsigned_cond))))
4007
+ (with_flags (cmp (OperandSize.Size64) lhs_hi rhs_hi)
4008
+ (lower_icmp_i128_consumer cond tmp1))))
4009
+
4010
+ (decl lower_icmp_i128_consumer (Cond Reg) ConsumesFlags)
4011
+ (rule (lower_icmp_i128_consumer cond tmp1)
4012
+ (let ((tmp2 WritableReg (temp_writable_reg $I64))
4013
+ (dst WritableReg (temp_writable_reg $I64)))
4014
+ (ConsumesFlags.ConsumesFlagsTwiceReturnsValueRegs
4015
+ (MInst.CSet tmp2 cond)
4016
+ (MInst.CSel dst (Cond.Eq) tmp1 tmp2)
4017
+ (value_reg dst))))
4018
+
4019
+ (decl lower_bmask (Type Type ValueRegs) ValueRegs)
4020
+
4021
+
4022
+ ;; For conversions that exactly fit a register, we can use csetm.
4023
+ ;;
4024
+ ;; cmp val, #0
4025
+ ;; csetm res, ne
4026
+ (rule 0
4027
+ (lower_bmask (fits_in_64 _) (ty_32_or_64 in_ty) val)
4028
+ (with_flags_reg
4029
+ (cmp_imm (operand_size in_ty) (value_regs_get val 0) (u8_into_imm12 0))
4030
+ (csetm (Cond.Ne))))
4031
+
4032
+ ;; For conversions from a 128-bit value into a 64-bit or smaller one, we or the
4033
+ ;; two registers of the 128-bit value together, and then recurse with the
4034
+ ;; combined value as a 64-bit test.
4035
+ ;;
4036
+ ;; orr val, lo, hi
4037
+ ;; cmp val, #0
4038
+ ;; csetm res, ne
4039
+ (rule 1
4040
+ (lower_bmask (fits_in_64 ty) $I128 val)
4041
+ (let ((lo Reg (value_regs_get val 0))
4042
+ (hi Reg (value_regs_get val 1))
4043
+ (combined Reg (orr $I64 lo hi)))
4044
+ (lower_bmask ty $I64 (value_reg combined))))
4045
+
4046
+ ;; For converting from any type into i128, duplicate the result of
4047
+ ;; converting to i64.
4048
+ (rule 2
4049
+ (lower_bmask $I128 in_ty val)
4050
+ (let ((res ValueRegs (lower_bmask $I64 in_ty val))
4051
+ (res Reg (value_regs_get res 0)))
4052
+ (value_regs res res)))
4053
+
4054
+ ;; For conversions smaller than a register, we need to mask off the high bits, and then
4055
+ ;; we can recurse into the general case.
4056
+ ;;
4057
+ ;; and tmp, val, #ty_mask
4058
+ ;; cmp tmp, #0
4059
+ ;; csetm res, ne
4060
+ (rule 3
4061
+ (lower_bmask out_ty (fits_in_16 in_ty) val)
4062
+ ; This if-let can't fail due to ty_mask always producing 8/16 consecutive 1s.
4063
+ (if-let mask_bits (imm_logic_from_u64 $I32 (ty_mask in_ty)))
4064
+ (let ((masked Reg (and_imm $I32 (value_regs_get val 0) mask_bits)))
4065
+ (lower_bmask out_ty $I32 masked)))
4066
+
4067
+ ;; Exceptional `lower_icmp_into_flags` rules.
4068
+ ;; We need to guarantee that the flags for `cond` are correct, so we
4069
+ ;; compare `dst` with 1.
4070
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedGreaterThanOrEqual) lhs rhs $I128)
4071
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4072
+ (dst Reg (value_regs_get dst 0))
4073
+ (tmp Reg (imm $I64 (ImmExtend.Sign) 1))) ;; mov tmp, #1
4074
+ (flags_and_cc (cmp (OperandSize.Size64) dst tmp) cond)))
4075
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedGreaterThanOrEqual) lhs rhs $I128)
4076
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4077
+ (dst Reg (value_regs_get dst 0))
4078
+ (tmp Reg (imm $I64 (ImmExtend.Zero) 1)))
4079
+ (flags_and_cc (cmp (OperandSize.Size64) dst tmp) cond)))
4080
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedLessThanOrEqual) lhs rhs $I128)
4081
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4082
+ (dst Reg (value_regs_get dst 0))
4083
+ (tmp Reg (imm $I64 (ImmExtend.Sign) 1)))
4084
+ (flags_and_cc (cmp (OperandSize.Size64) tmp dst) cond)))
4085
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedLessThanOrEqual) lhs rhs $I128)
4086
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4087
+ (dst Reg (value_regs_get dst 0))
4088
+ (tmp Reg (imm $I64 (ImmExtend.Zero) 1)))
4089
+ (flags_and_cc (cmp (OperandSize.Size64) tmp dst) cond)))
4090
+ ;; For strict comparisons, we compare with 0.
4091
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedGreaterThan) lhs rhs $I128)
4092
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4093
+ (dst Reg (value_regs_get dst 0)))
4094
+ (flags_and_cc (cmp (OperandSize.Size64) dst (zero_reg)) cond)))
4095
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedGreaterThan) lhs rhs $I128)
4096
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4097
+ (dst Reg (value_regs_get dst 0)))
4098
+ (flags_and_cc (cmp (OperandSize.Size64) dst (zero_reg)) cond)))
4099
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedLessThan) lhs rhs $I128)
4100
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4101
+ (dst Reg (value_regs_get dst 0)))
4102
+ (flags_and_cc (cmp (OperandSize.Size64) (zero_reg) dst) cond)))
4103
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedLessThan) lhs rhs $I128)
4104
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4105
+ (dst Reg (value_regs_get dst 0)))
4106
+ (flags_and_cc (cmp (OperandSize.Size64) (zero_reg) dst) cond)))
4107
+
4108
+ ;; Helpers for generating select instruction sequences.
4109
+ (decl lower_select (ProducesFlags Cond Type Value Value) ValueRegs)
4110
+ (rule 2 (lower_select flags cond (ty_scalar_float (fits_in_64 ty)) rn rm)
4111
+ (with_flags flags (fpu_csel ty cond rn rm)))
4112
+ (rule 4 (lower_select flags cond $F128 rn rm)
4113
+ (with_flags flags (vec_csel cond rn rm)))
4114
+ (rule 3 (lower_select flags cond (ty_vec128 ty) rn rm)
4115
+ (with_flags flags (vec_csel cond rn rm)))
4116
+ (rule (lower_select flags cond ty rn rm)
4117
+ (if (ty_vec64 ty))
4118
+ (with_flags flags (fpu_csel $F64 cond rn rm)))
4119
+ (rule 4 (lower_select flags cond $I128 rn rm)
4120
+ (let ((dst_lo WritableReg (temp_writable_reg $I64))
4121
+ (dst_hi WritableReg (temp_writable_reg $I64))
4122
+ (rn ValueRegs (put_in_regs rn))
4123
+ (rm ValueRegs (put_in_regs rm))
4124
+ (rn_lo Reg (value_regs_get rn 0))
4125
+ (rn_hi Reg (value_regs_get rn 1))
4126
+ (rm_lo Reg (value_regs_get rm 0))
4127
+ (rm_hi Reg (value_regs_get rm 1)))
4128
+ (with_flags flags
4129
+ (ConsumesFlags.ConsumesFlagsTwiceReturnsValueRegs
4130
+ (MInst.CSel dst_lo cond rn_lo rm_lo)
4131
+ (MInst.CSel dst_hi cond rn_hi rm_hi)
4132
+ (value_regs dst_lo dst_hi)))))
4133
+ (rule 1 (lower_select flags cond ty rn rm)
4134
+ (if (ty_int_ref_scalar_64 ty))
4135
+ (with_flags flags (csel cond rn rm)))
4136
+
4137
+ ;; Helper for emitting `MInst.Jump` instructions.
4138
+ (decl aarch64_jump (BranchTarget) SideEffectNoResult)
4139
+ (rule (aarch64_jump target)
4140
+ (SideEffectNoResult.Inst (MInst.Jump target)))
4141
+
4142
+ ;; Helper for emitting `MInst.JTSequence` instructions.
4143
+ ;; Emit the compound instruction that does:
4144
+ ;;
4145
+ ;; b.hs default
4146
+ ;; csel rB, xzr, rIndex, hs
4147
+ ;; csdb
4148
+ ;; adr rA, jt
4149
+ ;; ldrsw rB, [rA, rB, uxtw #2]
4150
+ ;; add rA, rA, rB
4151
+ ;; br rA
4152
+ ;; [jt entries]
4153
+ ;;
4154
+ ;; This must be *one* instruction in the vcode because
4155
+ ;; we cannot allow regalloc to insert any spills/fills
4156
+ ;; in the middle of the sequence; otherwise, the ADR's
4157
+ ;; PC-rel offset to the jumptable would be incorrect.
4158
+ ;; (The alternative is to introduce a relocation pass
4159
+ ;; for inlined jumptables, which is much worse, IMHO.)
4160
+ (decl jt_sequence (Reg MachLabel BoxVecMachLabel) ConsumesFlags)
4161
+ (rule (jt_sequence ridx default targets)
4162
+ (let ((rtmp1 WritableReg (temp_writable_reg $I64))
4163
+ (rtmp2 WritableReg (temp_writable_reg $I64)))
4164
+ (ConsumesFlags.ConsumesFlagsSideEffect
4165
+ (MInst.JTSequence default targets ridx rtmp1 rtmp2))))
4166
+
4167
+ ;; Helper for emitting `MInst.CondBr` instructions.
4168
+ (decl cond_br (BranchTarget BranchTarget CondBrKind) ConsumesFlags)
4169
+ (rule (cond_br taken not_taken kind)
4170
+ (ConsumesFlags.ConsumesFlagsSideEffect
4171
+ (MInst.CondBr taken not_taken kind)))
4172
+
4173
+ ;; Helper for emitting `MInst.TestBitAndBranch` instructions.
4174
+ (decl test_branch (TestBitAndBranchKind BranchTarget BranchTarget Reg u8) SideEffectNoResult)
4175
+ (rule (test_branch kind taken not_taken rn bit)
4176
+ (SideEffectNoResult.Inst (MInst.TestBitAndBranch kind taken not_taken rn bit)))
4177
+
4178
+ ;; Helper for emitting `tbnz` instructions.
4179
+ (decl tbnz (BranchTarget BranchTarget Reg u8) SideEffectNoResult)
4180
+ (rule (tbnz taken not_taken rn bit)
4181
+ (test_branch (TestBitAndBranchKind.NZ) taken not_taken rn bit))
4182
+
4183
+ ;; Helper for emitting `tbz` instructions.
4184
+ (decl tbz (BranchTarget BranchTarget Reg u8) SideEffectNoResult)
4185
+ (rule (tbz taken not_taken rn bit)
4186
+ (test_branch (TestBitAndBranchKind.Z) taken not_taken rn bit))
4187
+
4188
+ ;; Helper for emitting `MInst.MovToNZCV` instructions.
4189
+ (decl mov_to_nzcv (Reg) ProducesFlags)
4190
+ (rule (mov_to_nzcv rn)
4191
+ (ProducesFlags.ProducesFlagsSideEffect
4192
+ (MInst.MovToNZCV rn)))
4193
+
4194
+ ;; Helper for emitting `MInst.EmitIsland` instructions.
4195
+ (decl emit_island (CodeOffset) SideEffectNoResult)
4196
+ (rule (emit_island needed_space)
4197
+ (SideEffectNoResult.Inst
4198
+ (MInst.EmitIsland needed_space)))
4199
+
4200
+ ;; Helper for emitting `br_table` sequences.
4201
+ (decl br_table_impl (u64 Reg MachLabel BoxVecMachLabel) Unit)
4202
+ (rule (br_table_impl (imm12_from_u64 jt_size) ridx default targets)
4203
+ (emit_side_effect (with_flags_side_effect
4204
+ (cmp_imm (OperandSize.Size32) ridx jt_size)
4205
+ (jt_sequence ridx default targets))))
4206
+ (rule -1 (br_table_impl jt_size ridx default targets)
4207
+ (let ((jt_size Reg (imm $I64 (ImmExtend.Zero) jt_size)))
4208
+ (emit_side_effect (with_flags_side_effect
4209
+ (cmp (OperandSize.Size32) ridx jt_size)
4210
+ (jt_sequence ridx default targets)))))
4211
+
4212
+ ;; Helper for emitting the `uzp1` instruction
4213
+ (decl vec_uzp1 (Reg Reg VectorSize) Reg)
4214
+ (rule (vec_uzp1 rn rm size) (vec_rrr (VecALUOp.Uzp1) rn rm size))
4215
+
4216
+ ;; Helper for emitting the `uzp2` instruction
4217
+ (decl vec_uzp2 (Reg Reg VectorSize) Reg)
4218
+ (rule (vec_uzp2 rn rm size) (vec_rrr (VecALUOp.Uzp2) rn rm size))
4219
+
4220
+ ;; Helper for emitting the `zip1` instruction
4221
+ (decl vec_zip1 (Reg Reg VectorSize) Reg)
4222
+ (rule (vec_zip1 rn rm size) (vec_rrr (VecALUOp.Zip1) rn rm size))
4223
+
4224
+ ;; Helper for emitting the `zip2` instruction
4225
+ (decl vec_zip2 (Reg Reg VectorSize) Reg)
4226
+ (rule (vec_zip2 rn rm size) (vec_rrr (VecALUOp.Zip2) rn rm size))
4227
+
4228
+ ;; Helper for emitting the `trn1` instruction
4229
+ (decl vec_trn1 (Reg Reg VectorSize) Reg)
4230
+ (rule (vec_trn1 rn rm size) (vec_rrr (VecALUOp.Trn1) rn rm size))
4231
+
4232
+ ;; Helper for emitting the `trn2` instruction
4233
+ (decl vec_trn2 (Reg Reg VectorSize) Reg)
4234
+ (rule (vec_trn2 rn rm size) (vec_rrr (VecALUOp.Trn2) rn rm size))
4235
+
4236
+ ;; Helper for creating a zero value `ASIMDMovModImm` immediate.
4237
+ (decl asimd_mov_mod_imm_zero (ScalarSize) ASIMDMovModImm)
4238
+ (extern constructor asimd_mov_mod_imm_zero asimd_mov_mod_imm_zero)
4239
+
4240
+ ;; Helper for fallibly creating an `ASIMDMovModImm` immediate from its parts.
4241
+ (decl pure partial asimd_mov_mod_imm_from_u64 (u64 ScalarSize) ASIMDMovModImm)
4242
+ (extern constructor asimd_mov_mod_imm_from_u64 asimd_mov_mod_imm_from_u64)
4243
+
4244
+ ;; Helper for fallibly creating an `ASIMDFPModImm` immediate from its parts.
4245
+ (decl pure partial asimd_fp_mod_imm_from_u64 (u64 ScalarSize) ASIMDFPModImm)
4246
+ (extern constructor asimd_fp_mod_imm_from_u64 asimd_fp_mod_imm_from_u64)
4247
+
4248
+ ;; Helper for creating a `VecDupFPImm` instruction
4249
+ (decl vec_dup_fp_imm (ASIMDFPModImm VectorSize) Reg)
4250
+ (rule (vec_dup_fp_imm imm size)
4251
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
4252
+ (_ Unit (emit (MInst.VecDupFPImm dst imm size))))
4253
+ dst))
4254
+
4255
+ ;; Helper for creating a `FpuLoad64` instruction
4256
+ (decl fpu_load64 (AMode MemFlags) Reg)
4257
+ (rule (fpu_load64 amode flags)
4258
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
4259
+ (_ Unit (emit (MInst.FpuLoad64 dst amode flags))))
4260
+ dst))
4261
+
4262
+ ;; Helper for creating a `FpuLoad128` instruction
4263
+ (decl fpu_load128 (AMode MemFlags) Reg)
4264
+ (rule (fpu_load128 amode flags)
4265
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
4266
+ (_ Unit (emit (MInst.FpuLoad128 dst amode flags))))
4267
+ dst))