wasmtime 22.0.0 → 23.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2164) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +127 -90
  3. data/ext/Cargo.toml +5 -5
  4. data/ext/cargo-vendor/cranelift-bforest-0.110.2/.cargo-checksum.json +1 -0
  5. data/ext/cargo-vendor/cranelift-bforest-0.110.2/Cargo.toml +50 -0
  6. data/ext/cargo-vendor/cranelift-bitset-0.110.2/.cargo-checksum.json +1 -0
  7. data/ext/cargo-vendor/cranelift-bitset-0.110.2/Cargo.toml +60 -0
  8. data/ext/cargo-vendor/cranelift-bitset-0.110.2/src/compound.rs +508 -0
  9. data/ext/cargo-vendor/cranelift-bitset-0.110.2/src/lib.rs +19 -0
  10. data/ext/cargo-vendor/cranelift-bitset-0.110.2/src/scalar.rs +575 -0
  11. data/ext/cargo-vendor/cranelift-bitset-0.110.2/tests/bitset.rs +78 -0
  12. data/ext/cargo-vendor/cranelift-codegen-0.110.2/.cargo-checksum.json +1 -0
  13. data/ext/cargo-vendor/cranelift-codegen-0.110.2/Cargo.toml +206 -0
  14. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/binemit/stack_map.rs +141 -0
  15. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/context.rs +390 -0
  16. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/data_value.rs +410 -0
  17. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/dfg.rs +1806 -0
  18. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/globalvalue.rs +147 -0
  19. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/immediates.rs +2109 -0
  20. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/instructions.rs +1015 -0
  21. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/jumptable.rs +168 -0
  22. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/mod.rs +110 -0
  23. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/trapcode.rs +148 -0
  24. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/types.rs +643 -0
  25. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/ir/user_stack_maps.rs +101 -0
  26. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/aarch64/inst/emit.rs +3605 -0
  27. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/aarch64/inst/emit_tests.rs +7927 -0
  28. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/aarch64/inst/mod.rs +3058 -0
  29. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/aarch64/inst.isle +4221 -0
  30. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/aarch64/lower.isle +2969 -0
  31. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/aarch64/mod.rs +259 -0
  32. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/mod.rs +462 -0
  33. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/riscv64/inst/emit.rs +2741 -0
  34. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/riscv64/inst/emit_tests.rs +2219 -0
  35. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/riscv64/inst/mod.rs +1935 -0
  36. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/riscv64/inst.isle +3153 -0
  37. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/riscv64/lower/isle.rs +654 -0
  38. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/riscv64/lower.isle +2953 -0
  39. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/riscv64/mod.rs +265 -0
  40. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/s390x/inst/emit.rs +3421 -0
  41. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/s390x/inst/mod.rs +3395 -0
  42. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/s390x/lower.isle +3983 -0
  43. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/s390x/mod.rs +220 -0
  44. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/x64/inst/emit.rs +4297 -0
  45. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/x64/inst/emit_state.rs +65 -0
  46. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/x64/inst/mod.rs +2818 -0
  47. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/x64/inst.isle +5299 -0
  48. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/x64/lower.isle +4819 -0
  49. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isa/x64/mod.rs +239 -0
  50. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/isle_prelude.rs +965 -0
  51. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/legalizer/mod.rs +343 -0
  52. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/lib.rs +106 -0
  53. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/machinst/abi.rs +2427 -0
  54. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/machinst/buffer.rs +2544 -0
  55. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/machinst/helpers.rs +23 -0
  56. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/machinst/isle.rs +908 -0
  57. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/machinst/lower.rs +1462 -0
  58. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/machinst/mod.rs +564 -0
  59. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/machinst/vcode.rs +1840 -0
  60. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/prelude.isle +654 -0
  61. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/prelude_lower.isle +1070 -0
  62. data/ext/cargo-vendor/cranelift-codegen-0.110.2/src/write.rs +660 -0
  63. data/ext/cargo-vendor/cranelift-codegen-meta-0.110.2/.cargo-checksum.json +1 -0
  64. data/ext/cargo-vendor/cranelift-codegen-meta-0.110.2/Cargo.toml +45 -0
  65. data/ext/cargo-vendor/cranelift-codegen-meta-0.110.2/src/cdsl/types.rs +512 -0
  66. data/ext/cargo-vendor/cranelift-codegen-meta-0.110.2/src/cdsl/typevar.rs +980 -0
  67. data/ext/cargo-vendor/cranelift-codegen-meta-0.110.2/src/gen_inst.rs +1278 -0
  68. data/ext/cargo-vendor/cranelift-codegen-meta-0.110.2/src/shared/instructions.rs +3760 -0
  69. data/ext/cargo-vendor/cranelift-codegen-meta-0.110.2/src/shared/types.rs +143 -0
  70. data/ext/cargo-vendor/cranelift-codegen-shared-0.110.2/.cargo-checksum.json +1 -0
  71. data/ext/cargo-vendor/cranelift-codegen-shared-0.110.2/Cargo.toml +31 -0
  72. data/ext/cargo-vendor/cranelift-control-0.110.2/.cargo-checksum.json +1 -0
  73. data/ext/cargo-vendor/cranelift-control-0.110.2/Cargo.toml +39 -0
  74. data/ext/cargo-vendor/cranelift-entity-0.110.2/.cargo-checksum.json +1 -0
  75. data/ext/cargo-vendor/cranelift-entity-0.110.2/Cargo.toml +66 -0
  76. data/ext/cargo-vendor/cranelift-entity-0.110.2/src/set.rs +193 -0
  77. data/ext/cargo-vendor/cranelift-frontend-0.110.2/.cargo-checksum.json +1 -0
  78. data/ext/cargo-vendor/cranelift-frontend-0.110.2/Cargo.toml +87 -0
  79. data/ext/cargo-vendor/cranelift-frontend-0.110.2/src/frontend.rs +2867 -0
  80. data/ext/cargo-vendor/cranelift-isle-0.110.2/.cargo-checksum.json +1 -0
  81. data/ext/cargo-vendor/cranelift-isle-0.110.2/Cargo.toml +60 -0
  82. data/ext/cargo-vendor/cranelift-isle-0.110.2/src/codegen.rs +920 -0
  83. data/ext/cargo-vendor/cranelift-isle-0.110.2/src/parser.rs +562 -0
  84. data/ext/cargo-vendor/cranelift-isle-0.110.2/src/sema.rs +2503 -0
  85. data/ext/cargo-vendor/cranelift-isle-0.110.2/src/trie_again.rs +695 -0
  86. data/ext/cargo-vendor/cranelift-native-0.110.2/.cargo-checksum.json +1 -0
  87. data/ext/cargo-vendor/cranelift-native-0.110.2/Cargo.toml +52 -0
  88. data/ext/cargo-vendor/cranelift-native-0.110.2/src/lib.rs +188 -0
  89. data/ext/cargo-vendor/cranelift-wasm-0.110.2/.cargo-checksum.json +1 -0
  90. data/ext/cargo-vendor/cranelift-wasm-0.110.2/Cargo.toml +119 -0
  91. data/ext/cargo-vendor/cranelift-wasm-0.110.2/src/code_translator/bounds_checks.rs +731 -0
  92. data/ext/cargo-vendor/cranelift-wasm-0.110.2/src/code_translator.rs +3694 -0
  93. data/ext/cargo-vendor/cranelift-wasm-0.110.2/src/heap.rs +119 -0
  94. data/ext/cargo-vendor/cranelift-wasm-0.110.2/src/sections_translator.rs +333 -0
  95. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.23/.cargo-checksum.json +1 -0
  96. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.23/Cargo.toml +69 -0
  97. data/ext/cargo-vendor/termcolor-1.4.1/.cargo-checksum.json +1 -0
  98. data/ext/cargo-vendor/termcolor-1.4.1/COPYING +3 -0
  99. data/ext/cargo-vendor/termcolor-1.4.1/Cargo.toml +40 -0
  100. data/ext/cargo-vendor/termcolor-1.4.1/LICENSE-MIT +21 -0
  101. data/ext/cargo-vendor/termcolor-1.4.1/README.md +110 -0
  102. data/ext/cargo-vendor/termcolor-1.4.1/UNLICENSE +24 -0
  103. data/ext/cargo-vendor/termcolor-1.4.1/rustfmt.toml +2 -0
  104. data/ext/cargo-vendor/termcolor-1.4.1/src/lib.rs +2572 -0
  105. data/ext/cargo-vendor/wasi-common-23.0.2/.cargo-checksum.json +1 -0
  106. data/ext/cargo-vendor/wasi-common-23.0.2/Cargo.toml +234 -0
  107. data/ext/cargo-vendor/wasi-common-23.0.2/src/tokio/mod.rs +135 -0
  108. data/ext/cargo-vendor/wasi-common-23.0.2/tests/all/async_.rs +295 -0
  109. data/ext/cargo-vendor/wasi-common-23.0.2/tests/all/sync.rs +284 -0
  110. data/ext/cargo-vendor/wasm-encoder-0.212.0/.cargo-checksum.json +1 -0
  111. data/ext/cargo-vendor/wasm-encoder-0.212.0/Cargo.toml +49 -0
  112. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/component/types.rs +771 -0
  113. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/code.rs +3571 -0
  114. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/exports.rs +85 -0
  115. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/globals.rs +100 -0
  116. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/imports.rs +143 -0
  117. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/memories.rs +115 -0
  118. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/tables.rs +121 -0
  119. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/tags.rs +85 -0
  120. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/core/types.rs +663 -0
  121. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/lib.rs +218 -0
  122. data/ext/cargo-vendor/wasm-encoder-0.212.0/src/reencode.rs +1804 -0
  123. data/ext/cargo-vendor/wasm-encoder-0.215.0/.cargo-checksum.json +1 -0
  124. data/ext/cargo-vendor/wasm-encoder-0.215.0/Cargo.toml +65 -0
  125. data/ext/cargo-vendor/wasm-encoder-0.215.0/README.md +80 -0
  126. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/aliases.rs +160 -0
  127. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/builder.rs +455 -0
  128. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/canonicals.rs +159 -0
  129. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/components.rs +29 -0
  130. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/exports.rs +124 -0
  131. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/imports.rs +175 -0
  132. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/instances.rs +200 -0
  133. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/modules.rs +29 -0
  134. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/names.rs +149 -0
  135. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/start.rs +52 -0
  136. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component/types.rs +802 -0
  137. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/component.rs +168 -0
  138. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/code.rs +3947 -0
  139. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/custom.rs +73 -0
  140. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/data.rs +186 -0
  141. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/dump.rs +627 -0
  142. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/elements.rs +222 -0
  143. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/exports.rs +85 -0
  144. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/functions.rs +63 -0
  145. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/globals.rs +100 -0
  146. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/imports.rs +143 -0
  147. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/linking.rs +263 -0
  148. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/memories.rs +115 -0
  149. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/names.rs +298 -0
  150. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/producers.rs +181 -0
  151. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/start.rs +39 -0
  152. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/tables.rs +129 -0
  153. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/tags.rs +85 -0
  154. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core/types.rs +678 -0
  155. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/core.rs +168 -0
  156. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/lib.rs +218 -0
  157. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/raw.rs +30 -0
  158. data/ext/cargo-vendor/wasm-encoder-0.215.0/src/reencode.rs +2002 -0
  159. data/ext/cargo-vendor/wasmparser-0.212.0/.cargo-checksum.json +1 -0
  160. data/ext/cargo-vendor/wasmparser-0.212.0/Cargo.lock +669 -0
  161. data/ext/cargo-vendor/wasmparser-0.212.0/Cargo.toml +112 -0
  162. data/ext/cargo-vendor/wasmparser-0.212.0/src/binary_reader.rs +1968 -0
  163. data/ext/cargo-vendor/wasmparser-0.212.0/src/features.rs +166 -0
  164. data/ext/cargo-vendor/wasmparser-0.212.0/src/lib.rs +814 -0
  165. data/ext/cargo-vendor/wasmparser-0.212.0/src/parser.rs +1682 -0
  166. data/ext/cargo-vendor/wasmparser-0.212.0/src/readers/core/operators.rs +453 -0
  167. data/ext/cargo-vendor/wasmparser-0.212.0/src/readers/core/tables.rs +93 -0
  168. data/ext/cargo-vendor/wasmparser-0.212.0/src/readers/core/types.rs +1941 -0
  169. data/ext/cargo-vendor/wasmparser-0.212.0/src/resources.rs +234 -0
  170. data/ext/cargo-vendor/wasmparser-0.212.0/src/validator/component.rs +3252 -0
  171. data/ext/cargo-vendor/wasmparser-0.212.0/src/validator/core.rs +1454 -0
  172. data/ext/cargo-vendor/wasmparser-0.212.0/src/validator/operators.rs +4230 -0
  173. data/ext/cargo-vendor/wasmparser-0.212.0/src/validator/types.rs +4598 -0
  174. data/ext/cargo-vendor/wasmparser-0.212.0/src/validator.rs +1632 -0
  175. data/ext/cargo-vendor/wasmprinter-0.212.0/.cargo-checksum.json +1 -0
  176. data/ext/cargo-vendor/wasmprinter-0.212.0/Cargo.toml +54 -0
  177. data/ext/cargo-vendor/wasmprinter-0.212.0/src/lib.rs +3221 -0
  178. data/ext/cargo-vendor/wasmprinter-0.212.0/src/operator.rs +1189 -0
  179. data/ext/cargo-vendor/wasmprinter-0.212.0/src/print.rs +190 -0
  180. data/ext/cargo-vendor/wasmprinter-0.212.0/tests/all.rs +48 -0
  181. data/ext/cargo-vendor/wasmtime-23.0.2/.cargo-checksum.json +1 -0
  182. data/ext/cargo-vendor/wasmtime-23.0.2/Cargo.toml +399 -0
  183. data/ext/cargo-vendor/wasmtime-23.0.2/build.rs +38 -0
  184. data/ext/cargo-vendor/wasmtime-23.0.2/src/compile/code_builder.rs +274 -0
  185. data/ext/cargo-vendor/wasmtime-23.0.2/src/compile/runtime.rs +167 -0
  186. data/ext/cargo-vendor/wasmtime-23.0.2/src/compile.rs +881 -0
  187. data/ext/cargo-vendor/wasmtime-23.0.2/src/config.rs +2902 -0
  188. data/ext/cargo-vendor/wasmtime-23.0.2/src/engine/serialization.rs +893 -0
  189. data/ext/cargo-vendor/wasmtime-23.0.2/src/engine.rs +719 -0
  190. data/ext/cargo-vendor/wasmtime-23.0.2/src/lib.rs +406 -0
  191. data/ext/cargo-vendor/wasmtime-23.0.2/src/profiling_agent/jitdump.rs +65 -0
  192. data/ext/cargo-vendor/wasmtime-23.0.2/src/profiling_agent/perfmap.rs +47 -0
  193. data/ext/cargo-vendor/wasmtime-23.0.2/src/profiling_agent/vtune.rs +80 -0
  194. data/ext/cargo-vendor/wasmtime-23.0.2/src/profiling_agent.rs +104 -0
  195. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/code_memory.rs +337 -0
  196. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/bindgen_examples/mod.rs +488 -0
  197. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/component.rs +811 -0
  198. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/func/host.rs +439 -0
  199. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/func/options.rs +552 -0
  200. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/func/typed.rs +2497 -0
  201. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/func.rs +688 -0
  202. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/instance.rs +846 -0
  203. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/linker.rs +673 -0
  204. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/matching.rs +216 -0
  205. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/mod.rs +663 -0
  206. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/resources.rs +1132 -0
  207. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/component/values.rs +979 -0
  208. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/coredump.rs +339 -0
  209. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/debug.rs +165 -0
  210. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/externals/global.rs +310 -0
  211. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/externals/table.rs +480 -0
  212. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/func/typed.rs +788 -0
  213. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/func.rs +2593 -0
  214. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/gc/disabled/rooting.rs +224 -0
  215. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/gc/enabled/externref.rs +591 -0
  216. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/gc/enabled/rooting.rs +1590 -0
  217. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/instance.rs +989 -0
  218. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/instantiate.rs +332 -0
  219. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/limits.rs +398 -0
  220. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/linker.rs +1498 -0
  221. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/memory.rs +1101 -0
  222. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/module/registry.rs +353 -0
  223. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/module.rs +1179 -0
  224. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/profiling.rs +280 -0
  225. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/stack.rs +72 -0
  226. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/store/data.rs +301 -0
  227. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/store.rs +2873 -0
  228. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/trampoline/func.rs +93 -0
  229. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/trampoline/memory.rs +295 -0
  230. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/trampoline/table.rs +28 -0
  231. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/trampoline.rs +75 -0
  232. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/trap.rs +642 -0
  233. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/types/matching.rs +428 -0
  234. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/types.rs +2771 -0
  235. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/values.rs +966 -0
  236. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/arch/riscv64.rs +41 -0
  237. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/component/libcalls.rs +571 -0
  238. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/component/resources.rs +351 -0
  239. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/component.rs +857 -0
  240. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/const_expr.rs +102 -0
  241. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/cow.rs +988 -0
  242. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/gc/disabled.rs +23 -0
  243. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/gc/enabled/drc.rs +964 -0
  244. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/gc/enabled/free_list.rs +770 -0
  245. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/gc/gc_ref.rs +490 -0
  246. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/gc/gc_runtime.rs +505 -0
  247. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/gc.rs +244 -0
  248. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/on_demand.rs +219 -0
  249. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling/decommit_queue.rs +199 -0
  250. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling/gc_heap_pool.rs +93 -0
  251. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling/generic_stack_pool.rs +78 -0
  252. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling/index_allocator.rs +703 -0
  253. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling/memory_pool.rs +990 -0
  254. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling/table_pool.rs +245 -0
  255. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling/unix_stack_pool.rs +279 -0
  256. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator/pooling.rs +793 -0
  257. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance/allocator.rs +808 -0
  258. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/instance.rs +1518 -0
  259. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/libcalls.rs +832 -0
  260. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/memory.rs +815 -0
  261. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/mmap.rs +217 -0
  262. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/mmap_vec.rs +159 -0
  263. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/module_id.rs +19 -0
  264. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/mpk/disabled.rs +43 -0
  265. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/mpk/enabled.rs +213 -0
  266. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/mpk/mod.rs +59 -0
  267. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/mpk/sys.rs +113 -0
  268. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/custom/mmap.rs +112 -0
  269. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/custom/mod.rs +34 -0
  270. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/custom/unwind.rs +17 -0
  271. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/custom/vm.rs +105 -0
  272. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/miri/mmap.rs +98 -0
  273. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/miri/unwind.rs +17 -0
  274. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/unix/mmap.rs +159 -0
  275. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/unix/signals.rs +407 -0
  276. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/unix/unwind.rs +149 -0
  277. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/windows/mmap.rs +220 -0
  278. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/sys/windows/unwind.rs +46 -0
  279. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/table.rs +898 -0
  280. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/threads/shared_memory.rs +235 -0
  281. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/threads/shared_memory_disabled.rs +104 -0
  282. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/traphandlers.rs +767 -0
  283. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/vmcontext/vm_host_func_context.rs +79 -0
  284. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm/vmcontext.rs +1246 -0
  285. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime/vm.rs +403 -0
  286. data/ext/cargo-vendor/wasmtime-23.0.2/src/runtime.rs +113 -0
  287. data/ext/cargo-vendor/wasmtime-asm-macros-23.0.2/.cargo-checksum.json +1 -0
  288. data/ext/cargo-vendor/wasmtime-asm-macros-23.0.2/Cargo.toml +32 -0
  289. data/ext/cargo-vendor/wasmtime-cache-23.0.2/.cargo-checksum.json +1 -0
  290. data/ext/cargo-vendor/wasmtime-cache-23.0.2/Cargo.toml +103 -0
  291. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/.cargo-checksum.json +1 -0
  292. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/Cargo.toml +106 -0
  293. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/src/bindgen.rs +500 -0
  294. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/codegen.rs +698 -0
  295. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/char.rs +268 -0
  296. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/char_async.rs +291 -0
  297. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/conventions.rs +706 -0
  298. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/conventions_async.rs +757 -0
  299. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/dead-code.rs +194 -0
  300. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/dead-code_async.rs +213 -0
  301. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/direct-import.rs +120 -0
  302. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/direct-import_async.rs +132 -0
  303. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/empty.rs +74 -0
  304. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/empty_async.rs +80 -0
  305. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/flags.rs +743 -0
  306. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/flags_async.rs +791 -0
  307. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/floats.rs +343 -0
  308. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/floats_async.rs +376 -0
  309. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/function-new.rs +94 -0
  310. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/function-new_async.rs +103 -0
  311. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/integers.rs +873 -0
  312. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/integers_async.rs +976 -0
  313. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/lists.rs +1924 -0
  314. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/lists_async.rs +2114 -0
  315. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/many-arguments.rs +614 -0
  316. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/many-arguments_async.rs +638 -0
  317. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/multi-return.rs +357 -0
  318. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/multi-return_async.rs +391 -0
  319. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/multiversion.rs +354 -0
  320. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/multiversion_async.rs +379 -0
  321. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/records.rs +940 -0
  322. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/records_async.rs +1008 -0
  323. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/rename.rs +183 -0
  324. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/rename_async.rs +202 -0
  325. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/resources-export.rs +657 -0
  326. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/resources-export_async.rs +712 -0
  327. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/resources-import.rs +1088 -0
  328. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/resources-import_async.rs +1166 -0
  329. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/share-types.rs +315 -0
  330. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/share-types_async.rs +337 -0
  331. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/simple-functions.rs +399 -0
  332. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/simple-functions_async.rs +439 -0
  333. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/simple-lists.rs +427 -0
  334. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/simple-lists_async.rs +464 -0
  335. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/simple-wasi.rs +245 -0
  336. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/simple-wasi_async.rs +264 -0
  337. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/small-anonymous.rs +338 -0
  338. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/small-anonymous_async.rs +356 -0
  339. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/smoke-default.rs +94 -0
  340. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/smoke-default_async.rs +103 -0
  341. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/smoke-export.rs +149 -0
  342. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/smoke-export_async.rs +158 -0
  343. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/smoke.rs +133 -0
  344. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/smoke_async.rs +146 -0
  345. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/strings.rs +316 -0
  346. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/strings_async.rs +344 -0
  347. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/unversioned-foo.rs +165 -0
  348. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/unversioned-foo_async.rs +178 -0
  349. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/use-paths.rs +317 -0
  350. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/use-paths_async.rs +349 -0
  351. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/variants.rs +1896 -0
  352. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/variants_async.rs +2019 -0
  353. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/wat.rs +145 -0
  354. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/wat_async.rs +151 -0
  355. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/worlds-with-types.rs +175 -0
  356. data/ext/cargo-vendor/wasmtime-component-macro-23.0.2/tests/expanded/worlds-with-types_async.rs +191 -0
  357. data/ext/cargo-vendor/wasmtime-component-util-23.0.2/.cargo-checksum.json +1 -0
  358. data/ext/cargo-vendor/wasmtime-component-util-23.0.2/Cargo.toml +35 -0
  359. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/.cargo-checksum.json +1 -0
  360. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/Cargo.toml +125 -0
  361. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/compiler.rs +1029 -0
  362. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/gc.rs +257 -0
  363. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/address_transform.rs +841 -0
  364. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/attr.rs +328 -0
  365. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/expression.rs +1264 -0
  366. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/line_program.rs +287 -0
  367. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/mod.rs +273 -0
  368. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/range_info_builder.rs +234 -0
  369. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/simulate.rs +423 -0
  370. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/unit.rs +520 -0
  371. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/transform/utils.rs +165 -0
  372. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug/write_debuginfo.rs +176 -0
  373. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/debug.rs +178 -0
  374. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/func_environ.rs +2721 -0
  375. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/gc/enabled.rs +648 -0
  376. data/ext/cargo-vendor/wasmtime-cranelift-23.0.2/src/lib.rs +458 -0
  377. data/ext/cargo-vendor/wasmtime-environ-23.0.2/.cargo-checksum.json +1 -0
  378. data/ext/cargo-vendor/wasmtime-environ-23.0.2/Cargo.lock +792 -0
  379. data/ext/cargo-vendor/wasmtime-environ-23.0.2/Cargo.toml +185 -0
  380. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/compile/mod.rs +379 -0
  381. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/compile/module_environ.rs +1264 -0
  382. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component/dfg.rs +718 -0
  383. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component/info.rs +683 -0
  384. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component/names.rs +275 -0
  385. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component/translate/inline.rs +1333 -0
  386. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component/translate.rs +993 -0
  387. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component/types.rs +1041 -0
  388. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component/types_builder.rs +976 -0
  389. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/component.rs +109 -0
  390. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/lib.rs +64 -0
  391. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/module.rs +702 -0
  392. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/stack_map.rs +31 -0
  393. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/tunables.rs +165 -0
  394. data/ext/cargo-vendor/wasmtime-environ-23.0.2/src/vmoffsets.rs +897 -0
  395. data/ext/cargo-vendor/wasmtime-fiber-23.0.2/.cargo-checksum.json +1 -0
  396. data/ext/cargo-vendor/wasmtime-fiber-23.0.2/Cargo.toml +75 -0
  397. data/ext/cargo-vendor/wasmtime-jit-debug-23.0.2/.cargo-checksum.json +1 -0
  398. data/ext/cargo-vendor/wasmtime-jit-debug-23.0.2/Cargo.toml +77 -0
  399. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-23.0.2/.cargo-checksum.json +1 -0
  400. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-23.0.2/Cargo.toml +62 -0
  401. data/ext/cargo-vendor/wasmtime-slab-23.0.2/.cargo-checksum.json +1 -0
  402. data/ext/cargo-vendor/wasmtime-slab-23.0.2/Cargo.toml +31 -0
  403. data/ext/cargo-vendor/wasmtime-types-23.0.2/.cargo-checksum.json +1 -0
  404. data/ext/cargo-vendor/wasmtime-types-23.0.2/Cargo.toml +71 -0
  405. data/ext/cargo-vendor/wasmtime-types-23.0.2/src/lib.rs +1760 -0
  406. data/ext/cargo-vendor/wasmtime-types-23.0.2/src/prelude.rs +86 -0
  407. data/ext/cargo-vendor/wasmtime-versioned-export-macros-23.0.2/.cargo-checksum.json +1 -0
  408. data/ext/cargo-vendor/wasmtime-versioned-export-macros-23.0.2/Cargo.toml +40 -0
  409. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/.cargo-checksum.json +1 -0
  410. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/Cargo.toml +215 -0
  411. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/src/bindings.rs +561 -0
  412. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/src/filesystem.rs +448 -0
  413. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/src/host/filesystem.rs +1091 -0
  414. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/src/host/io.rs +391 -0
  415. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/src/lib.rs +419 -0
  416. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/src/preview1.rs +2801 -0
  417. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/src/stdio.rs +596 -0
  418. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/tests/all/api.rs +197 -0
  419. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/tests/all/async_.rs +397 -0
  420. data/ext/cargo-vendor/wasmtime-wasi-23.0.2/tests/all/sync.rs +331 -0
  421. data/ext/cargo-vendor/wasmtime-winch-23.0.2/.cargo-checksum.json +1 -0
  422. data/ext/cargo-vendor/wasmtime-winch-23.0.2/Cargo.toml +92 -0
  423. data/ext/cargo-vendor/wasmtime-winch-23.0.2/src/compiler.rs +242 -0
  424. data/ext/cargo-vendor/wasmtime-wit-bindgen-23.0.2/.cargo-checksum.json +1 -0
  425. data/ext/cargo-vendor/wasmtime-wit-bindgen-23.0.2/Cargo.toml +57 -0
  426. data/ext/cargo-vendor/wasmtime-wit-bindgen-23.0.2/src/lib.rs +2777 -0
  427. data/ext/cargo-vendor/wast-215.0.0/.cargo-checksum.json +1 -0
  428. data/ext/cargo-vendor/wast-215.0.0/Cargo.toml +101 -0
  429. data/ext/cargo-vendor/wast-215.0.0/src/component/binary.rs +1014 -0
  430. data/ext/cargo-vendor/wast-215.0.0/src/component/component.rs +320 -0
  431. data/ext/cargo-vendor/wast-215.0.0/src/component/expand.rs +875 -0
  432. data/ext/cargo-vendor/wast-215.0.0/src/component/resolve.rs +988 -0
  433. data/ext/cargo-vendor/wast-215.0.0/src/component.rs +28 -0
  434. data/ext/cargo-vendor/wast-215.0.0/src/core/binary/dwarf.rs +610 -0
  435. data/ext/cargo-vendor/wast-215.0.0/src/core/binary/dwarf_disabled.rs +41 -0
  436. data/ext/cargo-vendor/wast-215.0.0/src/core/binary.rs +1542 -0
  437. data/ext/cargo-vendor/wast-215.0.0/src/core/expr.rs +2110 -0
  438. data/ext/cargo-vendor/wast-215.0.0/src/core/memory.rs +279 -0
  439. data/ext/cargo-vendor/wast-215.0.0/src/core/module.rs +215 -0
  440. data/ext/cargo-vendor/wast-215.0.0/src/core/resolve/deinline_import_export.rs +232 -0
  441. data/ext/cargo-vendor/wast-215.0.0/src/core/resolve/names.rs +791 -0
  442. data/ext/cargo-vendor/wast-215.0.0/src/core/resolve/types.rs +270 -0
  443. data/ext/cargo-vendor/wast-215.0.0/src/core/table.rs +308 -0
  444. data/ext/cargo-vendor/wast-215.0.0/src/core/types.rs +1057 -0
  445. data/ext/cargo-vendor/wast-215.0.0/src/core.rs +30 -0
  446. data/ext/cargo-vendor/wast-215.0.0/src/lib.rs +556 -0
  447. data/ext/cargo-vendor/wast-215.0.0/src/parser.rs +1434 -0
  448. data/ext/cargo-vendor/wast-215.0.0/src/wat.rs +68 -0
  449. data/ext/cargo-vendor/wat-1.215.0/.cargo-checksum.json +1 -0
  450. data/ext/cargo-vendor/wat-1.215.0/Cargo.toml +56 -0
  451. data/ext/cargo-vendor/wat-1.215.0/src/lib.rs +469 -0
  452. data/ext/cargo-vendor/wiggle-23.0.2/.cargo-checksum.json +1 -0
  453. data/ext/cargo-vendor/wiggle-23.0.2/Cargo.toml +110 -0
  454. data/ext/cargo-vendor/wiggle-generate-23.0.2/.cargo-checksum.json +1 -0
  455. data/ext/cargo-vendor/wiggle-generate-23.0.2/Cargo.toml +76 -0
  456. data/ext/cargo-vendor/wiggle-macro-23.0.2/.cargo-checksum.json +1 -0
  457. data/ext/cargo-vendor/wiggle-macro-23.0.2/Cargo.toml +59 -0
  458. data/ext/cargo-vendor/winapi-util-0.1.9/.cargo-checksum.json +1 -0
  459. data/ext/cargo-vendor/winapi-util-0.1.9/COPYING +3 -0
  460. data/ext/cargo-vendor/winapi-util-0.1.9/Cargo.toml +53 -0
  461. data/ext/cargo-vendor/winapi-util-0.1.9/LICENSE-MIT +21 -0
  462. data/ext/cargo-vendor/winapi-util-0.1.9/README.md +64 -0
  463. data/ext/cargo-vendor/winapi-util-0.1.9/UNLICENSE +24 -0
  464. data/ext/cargo-vendor/winapi-util-0.1.9/rustfmt.toml +2 -0
  465. data/ext/cargo-vendor/winapi-util-0.1.9/src/console.rs +407 -0
  466. data/ext/cargo-vendor/winapi-util-0.1.9/src/file.rs +166 -0
  467. data/ext/cargo-vendor/winapi-util-0.1.9/src/lib.rs +35 -0
  468. data/ext/cargo-vendor/winapi-util-0.1.9/src/sysinfo.rs +161 -0
  469. data/ext/cargo-vendor/winapi-util-0.1.9/src/win.rs +246 -0
  470. data/ext/cargo-vendor/winch-codegen-0.21.2/.cargo-checksum.json +1 -0
  471. data/ext/cargo-vendor/winch-codegen-0.21.2/Cargo.toml +87 -0
  472. data/ext/cargo-vendor/winch-codegen-0.21.2/src/codegen/env.rs +449 -0
  473. data/ext/cargo-vendor/winch-codegen-0.21.2/src/codegen/mod.rs +878 -0
  474. data/ext/cargo-vendor/winch-codegen-0.21.2/src/visitor.rs +2154 -0
  475. data/ext/cargo-vendor/wit-parser-0.212.0/.cargo-checksum.json +1 -0
  476. data/ext/cargo-vendor/wit-parser-0.212.0/Cargo.toml +112 -0
  477. data/ext/cargo-vendor/wit-parser-0.212.0/src/ast/lex.rs +751 -0
  478. data/ext/cargo-vendor/wit-parser-0.212.0/src/ast/resolve.rs +1539 -0
  479. data/ext/cargo-vendor/wit-parser-0.212.0/src/ast.rs +1851 -0
  480. data/ext/cargo-vendor/wit-parser-0.212.0/src/decoding.rs +1798 -0
  481. data/ext/cargo-vendor/wit-parser-0.212.0/src/lib.rs +888 -0
  482. data/ext/cargo-vendor/wit-parser-0.212.0/src/resolve.rs +2740 -0
  483. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/feature-gates.wit.json +308 -0
  484. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-file-multi-package/a.wit +23 -0
  485. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-file-multi-package/b.wit +23 -0
  486. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-file-multi-package.wit.json +250 -0
  487. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-shared-deps/deps/dep1/types.wit +2 -0
  488. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-shared-deps/deps/dep2/types.wit +2 -0
  489. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-shared-deps/packages.wit +13 -0
  490. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-shared-deps.wit.json +83 -0
  491. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-transitive-deps/deps/dep1/types.wit +9 -0
  492. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-transitive-deps/deps/dep2/types.wit +5 -0
  493. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-transitive-deps/packages.wit +11 -0
  494. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/multi-package-transitive-deps.wit.json +116 -0
  495. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-explicit-colliding-decl-names.wit +23 -0
  496. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-explicit-colliding-decl-names.wit.json +130 -0
  497. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-explicit-internal-references.wit +15 -0
  498. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-explicit-internal-references.wit.json +87 -0
  499. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-explicit-with-semver.wit +23 -0
  500. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-explicit-with-semver.wit.json +130 -0
  501. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-multiple-explicit.wit +23 -0
  502. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-multiple-explicit.wit.json +130 -0
  503. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-single-explicit.wit +11 -0
  504. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/packages-single-explicit.wit.json +70 -0
  505. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/explicit-packages-colliding-names.wit +3 -0
  506. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/explicit-packages-colliding-names.wit.result +1 -0
  507. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/explicit-packages-with-error.wit +13 -0
  508. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/explicit-packages-with-error.wit.result +8 -0
  509. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/mix-explicit-then-implicit-package.wit +23 -0
  510. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/mix-explicit-then-implicit-package.wit.result +1 -0
  511. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/mix-implicit-then-explicit-package.wit +23 -0
  512. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/mix-implicit-then-explicit-package.wit.result +5 -0
  513. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/multi-file-missing-delimiter/observe.wit +5 -0
  514. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/multi-file-missing-delimiter/world.wit +5 -0
  515. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/multi-file-missing-delimiter.wit.result +9 -0
  516. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/multiple-package-inline-cycle.wit +11 -0
  517. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/multiple-package-inline-cycle.wit.result +5 -0
  518. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/multiple-packages-no-scope-blocks.wit +15 -0
  519. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/parse-fail/multiple-packages-no-scope-blocks.wit.result +5 -0
  520. data/ext/cargo-vendor/wit-parser-0.212.0/tests/ui/since-and-unstable.wit.json +583 -0
  521. data/ext/src/ruby_api/memory.rs +2 -1
  522. data/lib/wasmtime/version.rb +1 -1
  523. metadata +1736 -1643
  524. data/ext/cargo-vendor/cranelift-bforest-0.109.0/.cargo-checksum.json +0 -1
  525. data/ext/cargo-vendor/cranelift-bforest-0.109.0/Cargo.toml +0 -41
  526. data/ext/cargo-vendor/cranelift-codegen-0.109.0/.cargo-checksum.json +0 -1
  527. data/ext/cargo-vendor/cranelift-codegen-0.109.0/Cargo.toml +0 -193
  528. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/binemit/stack_map.rs +0 -155
  529. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/bitset.rs +0 -187
  530. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/context.rs +0 -384
  531. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/data_value.rs +0 -385
  532. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/dfg.rs +0 -1777
  533. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/globalvalue.rs +0 -147
  534. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/immediates.rs +0 -1612
  535. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/instructions.rs +0 -1020
  536. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/jumptable.rs +0 -168
  537. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/mod.rs +0 -108
  538. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/trapcode.rs +0 -149
  539. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/ir/types.rs +0 -627
  540. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/aarch64/inst/emit.rs +0 -3584
  541. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/aarch64/inst/emit_tests.rs +0 -7901
  542. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/aarch64/inst/mod.rs +0 -3060
  543. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/aarch64/inst.isle +0 -4218
  544. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/aarch64/lower.isle +0 -2933
  545. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/aarch64/mod.rs +0 -242
  546. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/mod.rs +0 -449
  547. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/riscv64/inst/emit.rs +0 -2682
  548. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/riscv64/inst/emit_tests.rs +0 -2215
  549. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/riscv64/inst/mod.rs +0 -1938
  550. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/riscv64/inst.isle +0 -3127
  551. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/riscv64/lower/isle.rs +0 -649
  552. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/riscv64/lower.isle +0 -2923
  553. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/riscv64/mod.rs +0 -260
  554. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/s390x/inst/emit.rs +0 -3401
  555. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/s390x/inst/mod.rs +0 -3401
  556. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/s390x/lower.isle +0 -3995
  557. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/s390x/mod.rs +0 -215
  558. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/x64/inst/emit.rs +0 -4287
  559. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/x64/inst/emit_state.rs +0 -52
  560. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/x64/inst/mod.rs +0 -2821
  561. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/x64/inst.isle +0 -5289
  562. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/x64/lower.isle +0 -4810
  563. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isa/x64/mod.rs +0 -234
  564. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/isle_prelude.rs +0 -986
  565. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/legalizer/mod.rs +0 -348
  566. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/lib.rs +0 -106
  567. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/machinst/abi.rs +0 -2419
  568. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/machinst/buffer.rs +0 -2508
  569. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/machinst/helpers.rs +0 -33
  570. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/machinst/isle.rs +0 -909
  571. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/machinst/lower.rs +0 -1432
  572. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/machinst/mod.rs +0 -551
  573. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/machinst/vcode.rs +0 -1741
  574. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/prelude.isle +0 -664
  575. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/prelude_lower.isle +0 -1073
  576. data/ext/cargo-vendor/cranelift-codegen-0.109.0/src/write.rs +0 -638
  577. data/ext/cargo-vendor/cranelift-codegen-meta-0.109.0/.cargo-checksum.json +0 -1
  578. data/ext/cargo-vendor/cranelift-codegen-meta-0.109.0/Cargo.toml +0 -36
  579. data/ext/cargo-vendor/cranelift-codegen-meta-0.109.0/src/cdsl/types.rs +0 -496
  580. data/ext/cargo-vendor/cranelift-codegen-meta-0.109.0/src/cdsl/typevar.rs +0 -980
  581. data/ext/cargo-vendor/cranelift-codegen-meta-0.109.0/src/gen_inst.rs +0 -1278
  582. data/ext/cargo-vendor/cranelift-codegen-meta-0.109.0/src/shared/instructions.rs +0 -3791
  583. data/ext/cargo-vendor/cranelift-codegen-meta-0.109.0/src/shared/types.rs +0 -137
  584. data/ext/cargo-vendor/cranelift-codegen-shared-0.109.0/.cargo-checksum.json +0 -1
  585. data/ext/cargo-vendor/cranelift-codegen-shared-0.109.0/Cargo.toml +0 -22
  586. data/ext/cargo-vendor/cranelift-control-0.109.0/.cargo-checksum.json +0 -1
  587. data/ext/cargo-vendor/cranelift-control-0.109.0/Cargo.toml +0 -30
  588. data/ext/cargo-vendor/cranelift-entity-0.109.0/.cargo-checksum.json +0 -1
  589. data/ext/cargo-vendor/cranelift-entity-0.109.0/Cargo.toml +0 -53
  590. data/ext/cargo-vendor/cranelift-entity-0.109.0/src/set.rs +0 -290
  591. data/ext/cargo-vendor/cranelift-frontend-0.109.0/.cargo-checksum.json +0 -1
  592. data/ext/cargo-vendor/cranelift-frontend-0.109.0/Cargo.toml +0 -68
  593. data/ext/cargo-vendor/cranelift-frontend-0.109.0/src/frontend.rs +0 -1857
  594. data/ext/cargo-vendor/cranelift-isle-0.109.0/.cargo-checksum.json +0 -1
  595. data/ext/cargo-vendor/cranelift-isle-0.109.0/Cargo.toml +0 -47
  596. data/ext/cargo-vendor/cranelift-isle-0.109.0/src/codegen.rs +0 -886
  597. data/ext/cargo-vendor/cranelift-isle-0.109.0/src/parser.rs +0 -562
  598. data/ext/cargo-vendor/cranelift-isle-0.109.0/src/sema.rs +0 -2492
  599. data/ext/cargo-vendor/cranelift-isle-0.109.0/src/trie_again.rs +0 -684
  600. data/ext/cargo-vendor/cranelift-native-0.109.0/.cargo-checksum.json +0 -1
  601. data/ext/cargo-vendor/cranelift-native-0.109.0/Cargo.toml +0 -43
  602. data/ext/cargo-vendor/cranelift-native-0.109.0/src/lib.rs +0 -188
  603. data/ext/cargo-vendor/cranelift-wasm-0.109.0/.cargo-checksum.json +0 -1
  604. data/ext/cargo-vendor/cranelift-wasm-0.109.0/Cargo.toml +0 -110
  605. data/ext/cargo-vendor/cranelift-wasm-0.109.0/src/code_translator/bounds_checks.rs +0 -713
  606. data/ext/cargo-vendor/cranelift-wasm-0.109.0/src/code_translator.rs +0 -3695
  607. data/ext/cargo-vendor/cranelift-wasm-0.109.0/src/heap.rs +0 -116
  608. data/ext/cargo-vendor/cranelift-wasm-0.109.0/src/sections_translator.rs +0 -343
  609. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.22/.cargo-checksum.json +0 -1
  610. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.22/Cargo.toml +0 -48
  611. data/ext/cargo-vendor/memoffset-0.9.0/.cargo-checksum.json +0 -1
  612. data/ext/cargo-vendor/memoffset-0.9.0/Cargo.toml +0 -37
  613. data/ext/cargo-vendor/memoffset-0.9.0/LICENSE +0 -19
  614. data/ext/cargo-vendor/memoffset-0.9.0/README.md +0 -85
  615. data/ext/cargo-vendor/memoffset-0.9.0/build.rs +0 -25
  616. data/ext/cargo-vendor/memoffset-0.9.0/src/lib.rs +0 -94
  617. data/ext/cargo-vendor/memoffset-0.9.0/src/offset_of.rs +0 -400
  618. data/ext/cargo-vendor/memoffset-0.9.0/src/raw_field.rs +0 -226
  619. data/ext/cargo-vendor/memoffset-0.9.0/src/span_of.rs +0 -263
  620. data/ext/cargo-vendor/wasi-common-22.0.0/.cargo-checksum.json +0 -1
  621. data/ext/cargo-vendor/wasi-common-22.0.0/Cargo.toml +0 -224
  622. data/ext/cargo-vendor/wasi-common-22.0.0/src/tokio/mod.rs +0 -137
  623. data/ext/cargo-vendor/wasi-common-22.0.0/tests/all/async_.rs +0 -293
  624. data/ext/cargo-vendor/wasi-common-22.0.0/tests/all/sync.rs +0 -279
  625. data/ext/cargo-vendor/wasm-encoder-0.209.1/.cargo-checksum.json +0 -1
  626. data/ext/cargo-vendor/wasm-encoder-0.209.1/Cargo.toml +0 -46
  627. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/component/types.rs +0 -792
  628. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/code.rs +0 -3595
  629. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/exports.rs +0 -98
  630. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/globals.rs +0 -112
  631. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/imports.rs +0 -157
  632. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/memories.rs +0 -128
  633. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/tables.rs +0 -134
  634. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/tags.rs +0 -104
  635. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/core/types.rs +0 -678
  636. data/ext/cargo-vendor/wasm-encoder-0.209.1/src/lib.rs +0 -215
  637. data/ext/cargo-vendor/wasmparser-0.209.1/.cargo-checksum.json +0 -1
  638. data/ext/cargo-vendor/wasmparser-0.209.1/Cargo.lock +0 -662
  639. data/ext/cargo-vendor/wasmparser-0.209.1/Cargo.toml +0 -109
  640. data/ext/cargo-vendor/wasmparser-0.209.1/src/binary_reader.rs +0 -1929
  641. data/ext/cargo-vendor/wasmparser-0.209.1/src/features.rs +0 -164
  642. data/ext/cargo-vendor/wasmparser-0.209.1/src/lib.rs +0 -814
  643. data/ext/cargo-vendor/wasmparser-0.209.1/src/parser.rs +0 -1682
  644. data/ext/cargo-vendor/wasmparser-0.209.1/src/readers/core/operators.rs +0 -423
  645. data/ext/cargo-vendor/wasmparser-0.209.1/src/readers/core/tables.rs +0 -93
  646. data/ext/cargo-vendor/wasmparser-0.209.1/src/readers/core/types.rs +0 -1788
  647. data/ext/cargo-vendor/wasmparser-0.209.1/src/resources.rs +0 -235
  648. data/ext/cargo-vendor/wasmparser-0.209.1/src/validator/component.rs +0 -3236
  649. data/ext/cargo-vendor/wasmparser-0.209.1/src/validator/core.rs +0 -1464
  650. data/ext/cargo-vendor/wasmparser-0.209.1/src/validator/operators.rs +0 -4231
  651. data/ext/cargo-vendor/wasmparser-0.209.1/src/validator/types.rs +0 -4550
  652. data/ext/cargo-vendor/wasmparser-0.209.1/src/validator.rs +0 -1633
  653. data/ext/cargo-vendor/wasmprinter-0.209.1/.cargo-checksum.json +0 -1
  654. data/ext/cargo-vendor/wasmprinter-0.209.1/Cargo.toml +0 -51
  655. data/ext/cargo-vendor/wasmprinter-0.209.1/src/lib.rs +0 -3225
  656. data/ext/cargo-vendor/wasmprinter-0.209.1/src/operator.rs +0 -1171
  657. data/ext/cargo-vendor/wasmprinter-0.209.1/tests/all.rs +0 -293
  658. data/ext/cargo-vendor/wasmtime-22.0.0/.cargo-checksum.json +0 -1
  659. data/ext/cargo-vendor/wasmtime-22.0.0/Cargo.toml +0 -387
  660. data/ext/cargo-vendor/wasmtime-22.0.0/build.rs +0 -42
  661. data/ext/cargo-vendor/wasmtime-22.0.0/src/compile/code_builder.rs +0 -275
  662. data/ext/cargo-vendor/wasmtime-22.0.0/src/compile/runtime.rs +0 -167
  663. data/ext/cargo-vendor/wasmtime-22.0.0/src/compile.rs +0 -917
  664. data/ext/cargo-vendor/wasmtime-22.0.0/src/config.rs +0 -2943
  665. data/ext/cargo-vendor/wasmtime-22.0.0/src/engine/serialization.rs +0 -890
  666. data/ext/cargo-vendor/wasmtime-22.0.0/src/engine.rs +0 -728
  667. data/ext/cargo-vendor/wasmtime-22.0.0/src/lib.rs +0 -389
  668. data/ext/cargo-vendor/wasmtime-22.0.0/src/profiling_agent/jitdump.rs +0 -67
  669. data/ext/cargo-vendor/wasmtime-22.0.0/src/profiling_agent/perfmap.rs +0 -48
  670. data/ext/cargo-vendor/wasmtime-22.0.0/src/profiling_agent/vtune.rs +0 -81
  671. data/ext/cargo-vendor/wasmtime-22.0.0/src/profiling_agent.rs +0 -106
  672. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/code_memory.rs +0 -338
  673. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/bindgen_examples/mod.rs +0 -489
  674. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/component.rs +0 -656
  675. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/func/host.rs +0 -440
  676. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/func/options.rs +0 -555
  677. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/func/typed.rs +0 -2498
  678. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/func.rs +0 -689
  679. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/instance.rs +0 -810
  680. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/linker.rs +0 -854
  681. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/matching.rs +0 -217
  682. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/mod.rs +0 -657
  683. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/resources.rs +0 -1133
  684. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/component/values.rs +0 -980
  685. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/coredump.rs +0 -342
  686. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/debug.rs +0 -166
  687. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/externals/global.rs +0 -310
  688. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/externals/table.rs +0 -481
  689. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/func/typed.rs +0 -780
  690. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/func.rs +0 -2564
  691. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/gc/disabled/rooting.rs +0 -224
  692. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/gc/enabled/externref.rs +0 -592
  693. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/gc/enabled/rooting.rs +0 -1588
  694. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/instance.rs +0 -992
  695. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/instantiate.rs +0 -337
  696. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/limits.rs +0 -399
  697. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/linker.rs +0 -1499
  698. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/memory.rs +0 -998
  699. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/module/registry.rs +0 -353
  700. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/module.rs +0 -1322
  701. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/profiling.rs +0 -221
  702. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/stack.rs +0 -73
  703. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/store/data.rs +0 -301
  704. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/store.rs +0 -2824
  705. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/trampoline/func.rs +0 -94
  706. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/trampoline/memory.rs +0 -287
  707. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/trampoline/table.rs +0 -29
  708. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/trampoline.rs +0 -78
  709. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/trap.rs +0 -642
  710. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/types/matching.rs +0 -421
  711. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/types.rs +0 -2580
  712. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/values.rs +0 -966
  713. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/arch/riscv64.rs +0 -41
  714. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/component/libcalls.rs +0 -571
  715. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/component/resources.rs +0 -352
  716. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/component.rs +0 -857
  717. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/const_expr.rs +0 -102
  718. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/cow.rs +0 -972
  719. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/gc/disabled.rs +0 -24
  720. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/gc/enabled/drc.rs +0 -968
  721. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/gc/enabled/free_list.rs +0 -771
  722. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/gc/gc_ref.rs +0 -491
  723. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/gc/gc_runtime.rs +0 -506
  724. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/gc.rs +0 -245
  725. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/on_demand.rs +0 -220
  726. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling/decommit_queue.rs +0 -194
  727. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling/gc_heap_pool.rs +0 -94
  728. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling/generic_stack_pool.rs +0 -78
  729. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling/index_allocator.rs +0 -707
  730. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling/memory_pool.rs +0 -975
  731. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling/table_pool.rs +0 -245
  732. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling/unix_stack_pool.rs +0 -278
  733. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator/pooling.rs +0 -794
  734. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance/allocator.rs +0 -801
  735. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/instance.rs +0 -1514
  736. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/libcalls.rs +0 -834
  737. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/memory.rs +0 -736
  738. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/mmap.rs +0 -220
  739. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/mmap_vec.rs +0 -162
  740. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/module_id.rs +0 -43
  741. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/mpk/disabled.rs +0 -43
  742. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/mpk/enabled.rs +0 -214
  743. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/mpk/mod.rs +0 -54
  744. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/mpk/sys.rs +0 -114
  745. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/custom/mmap.rs +0 -112
  746. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/custom/mod.rs +0 -34
  747. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/custom/unwind.rs +0 -17
  748. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/custom/vm.rs +0 -105
  749. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/miri/mmap.rs +0 -95
  750. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/miri/unwind.rs +0 -17
  751. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/unix/mmap.rs +0 -162
  752. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/unix/signals.rs +0 -407
  753. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/unix/unwind.rs +0 -150
  754. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/windows/mmap.rs +0 -221
  755. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/sys/windows/unwind.rs +0 -46
  756. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/table.rs +0 -899
  757. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/threads/shared_memory.rs +0 -233
  758. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/threads/shared_memory_disabled.rs +0 -101
  759. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/traphandlers.rs +0 -768
  760. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/vmcontext/vm_host_func_context.rs +0 -79
  761. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm/vmcontext.rs +0 -1302
  762. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime/vm.rs +0 -277
  763. data/ext/cargo-vendor/wasmtime-22.0.0/src/runtime.rs +0 -113
  764. data/ext/cargo-vendor/wasmtime-asm-macros-22.0.0/.cargo-checksum.json +0 -1
  765. data/ext/cargo-vendor/wasmtime-asm-macros-22.0.0/Cargo.toml +0 -22
  766. data/ext/cargo-vendor/wasmtime-cache-22.0.0/.cargo-checksum.json +0 -1
  767. data/ext/cargo-vendor/wasmtime-cache-22.0.0/Cargo.toml +0 -89
  768. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/.cargo-checksum.json +0 -1
  769. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/Cargo.toml +0 -86
  770. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/src/bindgen.rs +0 -493
  771. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/codegen.rs +0 -651
  772. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/char.rs +0 -198
  773. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/char_async.rs +0 -215
  774. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/conventions.rs +0 -586
  775. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/conventions_async.rs +0 -631
  776. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/dead-code.rs +0 -165
  777. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/dead-code_async.rs +0 -178
  778. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/direct-import.rs +0 -91
  779. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/direct-import_async.rs +0 -97
  780. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/empty.rs +0 -45
  781. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/empty_async.rs +0 -45
  782. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/flags.rs +0 -637
  783. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/flags_async.rs +0 -679
  784. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/floats.rs +0 -255
  785. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/floats_async.rs +0 -282
  786. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/function-new.rs +0 -59
  787. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/function-new_async.rs +0 -62
  788. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/integers.rs +0 -722
  789. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/integers_async.rs +0 -819
  790. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/lists.rs +0 -1743
  791. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/lists_async.rs +0 -1927
  792. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/many-arguments.rs +0 -543
  793. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/many-arguments_async.rs +0 -561
  794. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/multi-return.rs +0 -270
  795. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/multi-return_async.rs +0 -298
  796. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/multiversion.rs +0 -251
  797. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/multiversion_async.rs +0 -270
  798. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/records.rs +0 -815
  799. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/records_async.rs +0 -877
  800. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/rename.rs +0 -154
  801. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/rename_async.rs +0 -167
  802. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/resources-export.rs +0 -467
  803. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/resources-export_async.rs +0 -516
  804. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/resources-import.rs +0 -1014
  805. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/resources-import_async.rs +0 -1086
  806. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/share-types.rs +0 -249
  807. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/share-types_async.rs +0 -265
  808. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/simple-functions.rs +0 -313
  809. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/simple-functions_async.rs +0 -347
  810. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/simple-lists.rs +0 -350
  811. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/simple-lists_async.rs +0 -381
  812. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/simple-wasi.rs +0 -216
  813. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/simple-wasi_async.rs +0 -229
  814. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/small-anonymous.rs +0 -275
  815. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/small-anonymous_async.rs +0 -287
  816. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/smoke-default.rs +0 -59
  817. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/smoke-default_async.rs +0 -62
  818. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/smoke-export.rs +0 -86
  819. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/smoke-export_async.rs +0 -89
  820. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/smoke.rs +0 -104
  821. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/smoke_async.rs +0 -111
  822. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/strings.rs +0 -247
  823. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/strings_async.rs +0 -269
  824. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/unversioned-foo.rs +0 -136
  825. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/unversioned-foo_async.rs +0 -143
  826. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/use-paths.rs +0 -288
  827. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/use-paths_async.rs +0 -314
  828. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/variants.rs +0 -1750
  829. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/variants_async.rs +0 -1867
  830. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/wat.rs +0 -84
  831. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/wat_async.rs +0 -84
  832. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/worlds-with-types.rs +0 -138
  833. data/ext/cargo-vendor/wasmtime-component-macro-22.0.0/tests/expanded/worlds-with-types_async.rs +0 -148
  834. data/ext/cargo-vendor/wasmtime-component-util-22.0.0/.cargo-checksum.json +0 -1
  835. data/ext/cargo-vendor/wasmtime-component-util-22.0.0/Cargo.toml +0 -25
  836. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/.cargo-checksum.json +0 -1
  837. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/Cargo.toml +0 -115
  838. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/compiler.rs +0 -1067
  839. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/gc.rs +0 -252
  840. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/address_transform.rs +0 -783
  841. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/attr.rs +0 -320
  842. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/expression.rs +0 -1248
  843. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/line_program.rs +0 -287
  844. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/mod.rs +0 -256
  845. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/range_info_builder.rs +0 -221
  846. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/simulate.rs +0 -411
  847. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/unit.rs +0 -529
  848. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/transform/utils.rs +0 -186
  849. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug/write_debuginfo.rs +0 -196
  850. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/debug.rs +0 -18
  851. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/func_environ.rs +0 -2910
  852. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/gc/enabled.rs +0 -648
  853. data/ext/cargo-vendor/wasmtime-cranelift-22.0.0/src/lib.rs +0 -462
  854. data/ext/cargo-vendor/wasmtime-environ-22.0.0/.cargo-checksum.json +0 -1
  855. data/ext/cargo-vendor/wasmtime-environ-22.0.0/Cargo.lock +0 -774
  856. data/ext/cargo-vendor/wasmtime-environ-22.0.0/Cargo.toml +0 -161
  857. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/compile/mod.rs +0 -374
  858. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/compile/module_environ.rs +0 -1348
  859. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/component/dfg.rs +0 -691
  860. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/component/info.rs +0 -672
  861. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/component/translate/inline.rs +0 -1332
  862. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/component/translate.rs +0 -985
  863. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/component/types.rs +0 -1038
  864. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/component/types_builder.rs +0 -1004
  865. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/component.rs +0 -107
  866. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/lib.rs +0 -151
  867. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/module.rs +0 -704
  868. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/stack_map.rs +0 -37
  869. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/tunables.rs +0 -175
  870. data/ext/cargo-vendor/wasmtime-environ-22.0.0/src/vmoffsets.rs +0 -989
  871. data/ext/cargo-vendor/wasmtime-fiber-22.0.0/.cargo-checksum.json +0 -1
  872. data/ext/cargo-vendor/wasmtime-fiber-22.0.0/Cargo.toml +0 -65
  873. data/ext/cargo-vendor/wasmtime-jit-debug-22.0.0/.cargo-checksum.json +0 -1
  874. data/ext/cargo-vendor/wasmtime-jit-debug-22.0.0/Cargo.toml +0 -68
  875. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-22.0.0/.cargo-checksum.json +0 -1
  876. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-22.0.0/Cargo.toml +0 -52
  877. data/ext/cargo-vendor/wasmtime-slab-22.0.0/.cargo-checksum.json +0 -1
  878. data/ext/cargo-vendor/wasmtime-slab-22.0.0/Cargo.toml +0 -21
  879. data/ext/cargo-vendor/wasmtime-types-22.0.0/.cargo-checksum.json +0 -1
  880. data/ext/cargo-vendor/wasmtime-types-22.0.0/Cargo.toml +0 -56
  881. data/ext/cargo-vendor/wasmtime-types-22.0.0/src/lib.rs +0 -1737
  882. data/ext/cargo-vendor/wasmtime-versioned-export-macros-22.0.0/.cargo-checksum.json +0 -1
  883. data/ext/cargo-vendor/wasmtime-versioned-export-macros-22.0.0/Cargo.toml +0 -32
  884. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/.cargo-checksum.json +0 -1
  885. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/Cargo.toml +0 -201
  886. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/src/bindings.rs +0 -289
  887. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/src/filesystem.rs +0 -446
  888. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/src/host/filesystem.rs +0 -1091
  889. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/src/host/io.rs +0 -388
  890. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/src/lib.rs +0 -417
  891. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/src/preview1.rs +0 -2801
  892. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/src/stdio.rs +0 -533
  893. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/tests/all/api.rs +0 -198
  894. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/tests/all/async_.rs +0 -397
  895. data/ext/cargo-vendor/wasmtime-wasi-22.0.0/tests/all/sync.rs +0 -331
  896. data/ext/cargo-vendor/wasmtime-winch-22.0.0/.cargo-checksum.json +0 -1
  897. data/ext/cargo-vendor/wasmtime-winch-22.0.0/Cargo.toml +0 -82
  898. data/ext/cargo-vendor/wasmtime-winch-22.0.0/src/compiler.rs +0 -239
  899. data/ext/cargo-vendor/wasmtime-wit-bindgen-22.0.0/.cargo-checksum.json +0 -1
  900. data/ext/cargo-vendor/wasmtime-wit-bindgen-22.0.0/Cargo.toml +0 -47
  901. data/ext/cargo-vendor/wasmtime-wit-bindgen-22.0.0/src/lib.rs +0 -2639
  902. data/ext/cargo-vendor/wast-209.0.1/.cargo-checksum.json +0 -1
  903. data/ext/cargo-vendor/wast-209.0.1/Cargo.toml +0 -60
  904. data/ext/cargo-vendor/wast-209.0.1/src/component/binary.rs +0 -1000
  905. data/ext/cargo-vendor/wast-209.0.1/src/component/component.rs +0 -321
  906. data/ext/cargo-vendor/wast-209.0.1/src/component/expand.rs +0 -875
  907. data/ext/cargo-vendor/wast-209.0.1/src/component/resolve.rs +0 -999
  908. data/ext/cargo-vendor/wast-209.0.1/src/component.rs +0 -28
  909. data/ext/cargo-vendor/wast-209.0.1/src/core/binary.rs +0 -1396
  910. data/ext/cargo-vendor/wast-209.0.1/src/core/expr.rs +0 -2016
  911. data/ext/cargo-vendor/wast-209.0.1/src/core/memory.rs +0 -284
  912. data/ext/cargo-vendor/wast-209.0.1/src/core/module.rs +0 -218
  913. data/ext/cargo-vendor/wast-209.0.1/src/core/resolve/deinline_import_export.rs +0 -235
  914. data/ext/cargo-vendor/wast-209.0.1/src/core/resolve/names.rs +0 -751
  915. data/ext/cargo-vendor/wast-209.0.1/src/core/resolve/types.rs +0 -267
  916. data/ext/cargo-vendor/wast-209.0.1/src/core/table.rs +0 -302
  917. data/ext/cargo-vendor/wast-209.0.1/src/core/types.rs +0 -901
  918. data/ext/cargo-vendor/wast-209.0.1/src/core.rs +0 -29
  919. data/ext/cargo-vendor/wast-209.0.1/src/lib.rs +0 -551
  920. data/ext/cargo-vendor/wast-209.0.1/src/parser.rs +0 -1414
  921. data/ext/cargo-vendor/wast-209.0.1/src/wat.rs +0 -71
  922. data/ext/cargo-vendor/wat-1.209.1/.cargo-checksum.json +0 -1
  923. data/ext/cargo-vendor/wat-1.209.1/Cargo.toml +0 -34
  924. data/ext/cargo-vendor/wat-1.209.1/src/lib.rs +0 -401
  925. data/ext/cargo-vendor/wiggle-22.0.0/.cargo-checksum.json +0 -1
  926. data/ext/cargo-vendor/wiggle-22.0.0/Cargo.toml +0 -124
  927. data/ext/cargo-vendor/wiggle-generate-22.0.0/.cargo-checksum.json +0 -1
  928. data/ext/cargo-vendor/wiggle-generate-22.0.0/Cargo.toml +0 -67
  929. data/ext/cargo-vendor/wiggle-generate-22.0.0/LICENSE +0 -220
  930. data/ext/cargo-vendor/wiggle-macro-22.0.0/.cargo-checksum.json +0 -1
  931. data/ext/cargo-vendor/wiggle-macro-22.0.0/Cargo.toml +0 -51
  932. data/ext/cargo-vendor/wiggle-macro-22.0.0/LICENSE +0 -220
  933. data/ext/cargo-vendor/winch-codegen-0.20.0/.cargo-checksum.json +0 -1
  934. data/ext/cargo-vendor/winch-codegen-0.20.0/Cargo.toml +0 -77
  935. data/ext/cargo-vendor/winch-codegen-0.20.0/src/codegen/env.rs +0 -448
  936. data/ext/cargo-vendor/winch-codegen-0.20.0/src/codegen/mod.rs +0 -882
  937. data/ext/cargo-vendor/winch-codegen-0.20.0/src/visitor.rs +0 -2149
  938. data/ext/cargo-vendor/wit-parser-0.209.1/.cargo-checksum.json +0 -1
  939. data/ext/cargo-vendor/wit-parser-0.209.1/Cargo.toml +0 -112
  940. data/ext/cargo-vendor/wit-parser-0.209.1/src/ast/lex.rs +0 -747
  941. data/ext/cargo-vendor/wit-parser-0.209.1/src/ast/resolve.rs +0 -1524
  942. data/ext/cargo-vendor/wit-parser-0.209.1/src/ast.rs +0 -1668
  943. data/ext/cargo-vendor/wit-parser-0.209.1/src/decoding.rs +0 -1795
  944. data/ext/cargo-vendor/wit-parser-0.209.1/src/lib.rs +0 -873
  945. data/ext/cargo-vendor/wit-parser-0.209.1/src/resolve.rs +0 -2498
  946. data/ext/cargo-vendor/wit-parser-0.209.1/tests/ui/feature-gates.wit.json +0 -288
  947. data/ext/cargo-vendor/wit-parser-0.209.1/tests/ui/since-and-unstable.wit.json +0 -549
  948. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/LICENSE +0 -0
  949. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/README.md +0 -0
  950. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/src/lib.rs +0 -0
  951. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/src/map.rs +0 -0
  952. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/src/node.rs +0 -0
  953. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/src/path.rs +0 -0
  954. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/src/pool.rs +0 -0
  955. /data/ext/cargo-vendor/{cranelift-bforest-0.109.0 → cranelift-bforest-0.110.2}/src/set.rs +0 -0
  956. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/LICENSE +0 -0
  957. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/README.md +0 -0
  958. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/benches/x64-evex-encoding.rs +0 -0
  959. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/build.rs +0 -0
  960. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/alias_analysis.rs +0 -0
  961. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/binemit/mod.rs +0 -0
  962. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/cfg_printer.rs +0 -0
  963. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/constant_hash.rs +0 -0
  964. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ctxhash.rs +0 -0
  965. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/cursor.rs +0 -0
  966. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/dbg.rs +0 -0
  967. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/dominator_tree.rs +0 -0
  968. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/egraph/cost.rs +0 -0
  969. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/egraph/elaborate.rs +0 -0
  970. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/egraph.rs +0 -0
  971. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/flowgraph.rs +0 -0
  972. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/incremental_cache.rs +0 -0
  973. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/inst_predicates.rs +0 -0
  974. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/atomic_rmw_op.rs +0 -0
  975. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/builder.rs +0 -0
  976. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/condcodes.rs +0 -0
  977. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/constant.rs +0 -0
  978. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/dynamic_type.rs +0 -0
  979. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/entities.rs +0 -0
  980. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/extfunc.rs +0 -0
  981. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/extname.rs +0 -0
  982. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/function.rs +0 -0
  983. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/known_symbol.rs +0 -0
  984. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/layout.rs +0 -0
  985. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/libcall.rs +0 -0
  986. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/memflags.rs +0 -0
  987. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/memtype.rs +0 -0
  988. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/pcc.rs +0 -0
  989. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/progpoint.rs +0 -0
  990. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/sourceloc.rs +0 -0
  991. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ir/stackslot.rs +0 -0
  992. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/abi.rs +0 -0
  993. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/inst/args.rs +0 -0
  994. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/inst/imms.rs +0 -0
  995. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/inst/regs.rs +0 -0
  996. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/inst/unwind/systemv.rs +0 -0
  997. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/inst/unwind.rs +0 -0
  998. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/inst_neon.isle +0 -0
  999. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
  1000. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/lower/isle.rs +0 -0
  1001. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/lower.rs +0 -0
  1002. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
  1003. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/pcc.rs +0 -0
  1004. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/aarch64/settings.rs +0 -0
  1005. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/call_conv.rs +0 -0
  1006. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/abi.rs +0 -0
  1007. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst/args.rs +0 -0
  1008. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst/encode.rs +0 -0
  1009. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst/imms.rs +0 -0
  1010. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst/regs.rs +0 -0
  1011. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst/unwind/systemv.rs +0 -0
  1012. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst/unwind.rs +0 -0
  1013. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst/vector.rs +0 -0
  1014. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/inst_vector.isle +0 -0
  1015. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
  1016. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/lower.rs +0 -0
  1017. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/riscv64/settings.rs +0 -0
  1018. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/abi.rs +0 -0
  1019. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/inst/args.rs +0 -0
  1020. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/inst/emit_tests.rs +0 -0
  1021. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/inst/imms.rs +0 -0
  1022. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/inst/regs.rs +0 -0
  1023. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/inst/unwind/systemv.rs +0 -0
  1024. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/inst/unwind.rs +0 -0
  1025. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/inst.isle +0 -0
  1026. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
  1027. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/lower/isle.rs +0 -0
  1028. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/lower.rs +0 -0
  1029. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/s390x/settings.rs +0 -0
  1030. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/unwind/systemv.rs +0 -0
  1031. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/unwind/winx64.rs +0 -0
  1032. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/unwind.rs +0 -0
  1033. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/abi.rs +0 -0
  1034. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/encoding/evex.rs +0 -0
  1035. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/encoding/mod.rs +0 -0
  1036. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/encoding/rex.rs +0 -0
  1037. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/encoding/vex.rs +0 -0
  1038. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/inst/args.rs +0 -0
  1039. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/inst/emit_tests.rs +0 -0
  1040. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/inst/regs.rs +0 -0
  1041. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/inst/unwind/systemv.rs +0 -0
  1042. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/inst/unwind/winx64.rs +0 -0
  1043. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/inst/unwind.rs +0 -0
  1044. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/lower/isle/generated_code.rs +0 -0
  1045. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/lower/isle.rs +0 -0
  1046. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/lower.rs +0 -0
  1047. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/pcc.rs +0 -0
  1048. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/isa/x64/settings.rs +0 -0
  1049. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/iterators.rs +0 -0
  1050. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/legalizer/globalvalue.rs +0 -0
  1051. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/loop_analysis.rs +0 -0
  1052. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/machinst/blockorder.rs +0 -0
  1053. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/machinst/compile.rs +0 -0
  1054. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/machinst/inst_common.rs +0 -0
  1055. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/machinst/pcc.rs +0 -0
  1056. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/machinst/reg.rs +0 -0
  1057. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/machinst/valueregs.rs +0 -0
  1058. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/nan_canonicalization.rs +0 -0
  1059. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/README.md +0 -0
  1060. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/arithmetic.isle +0 -0
  1061. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/bitops.isle +0 -0
  1062. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/cprop.isle +0 -0
  1063. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/extends.isle +0 -0
  1064. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/generated_code.rs +0 -0
  1065. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/icmp.isle +0 -0
  1066. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/remat.isle +0 -0
  1067. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/selects.isle +0 -0
  1068. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/shifts.isle +0 -0
  1069. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/spaceship.isle +0 -0
  1070. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/spectre.isle +0 -0
  1071. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts/vector.isle +0 -0
  1072. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/opts.rs +0 -0
  1073. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/prelude_opt.isle +0 -0
  1074. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/print_errors.rs +0 -0
  1075. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/ranges.rs +0 -0
  1076. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/remove_constant_phis.rs +0 -0
  1077. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/result.rs +0 -0
  1078. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/scoped_hash_map.rs +0 -0
  1079. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/settings.rs +0 -0
  1080. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/souper_harvest.rs +0 -0
  1081. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/timing.rs +0 -0
  1082. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/traversals.rs +0 -0
  1083. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/unionfind.rs +0 -0
  1084. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/unreachable_code.rs +0 -0
  1085. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/value_label.rs +0 -0
  1086. /data/ext/cargo-vendor/{cranelift-codegen-0.109.0 → cranelift-codegen-0.110.2}/src/verifier/mod.rs +0 -0
  1087. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/LICENSE +0 -0
  1088. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/README.md +0 -0
  1089. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/cdsl/formats.rs +0 -0
  1090. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/cdsl/instructions.rs +0 -0
  1091. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/cdsl/isa.rs +0 -0
  1092. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/cdsl/mod.rs +0 -0
  1093. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/cdsl/operands.rs +0 -0
  1094. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/cdsl/settings.rs +0 -0
  1095. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/constant_hash.rs +0 -0
  1096. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/error.rs +0 -0
  1097. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/gen_isle.rs +0 -0
  1098. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/gen_settings.rs +0 -0
  1099. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/gen_types.rs +0 -0
  1100. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/isa/arm64.rs +0 -0
  1101. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/isa/mod.rs +0 -0
  1102. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/isa/riscv64.rs +0 -0
  1103. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/isa/s390x.rs +0 -0
  1104. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/isa/x86.rs +0 -0
  1105. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/isle.rs +0 -0
  1106. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/lib.rs +0 -0
  1107. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/shared/entities.rs +0 -0
  1108. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/shared/formats.rs +0 -0
  1109. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/shared/immediates.rs +0 -0
  1110. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/shared/mod.rs +0 -0
  1111. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/shared/settings.rs +0 -0
  1112. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/srcgen.rs +0 -0
  1113. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.109.0 → cranelift-codegen-meta-0.110.2}/src/unique_table.rs +0 -0
  1114. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.109.0 → cranelift-codegen-shared-0.110.2}/LICENSE +0 -0
  1115. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.109.0 → cranelift-codegen-shared-0.110.2}/README.md +0 -0
  1116. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.109.0 → cranelift-codegen-shared-0.110.2}/src/constant_hash.rs +0 -0
  1117. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.109.0 → cranelift-codegen-shared-0.110.2}/src/constants.rs +0 -0
  1118. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.109.0 → cranelift-codegen-shared-0.110.2}/src/lib.rs +0 -0
  1119. /data/ext/cargo-vendor/{cranelift-control-0.109.0 → cranelift-control-0.110.2}/LICENSE +0 -0
  1120. /data/ext/cargo-vendor/{cranelift-control-0.109.0 → cranelift-control-0.110.2}/README.md +0 -0
  1121. /data/ext/cargo-vendor/{cranelift-control-0.109.0 → cranelift-control-0.110.2}/src/chaos.rs +0 -0
  1122. /data/ext/cargo-vendor/{cranelift-control-0.109.0 → cranelift-control-0.110.2}/src/lib.rs +0 -0
  1123. /data/ext/cargo-vendor/{cranelift-control-0.109.0 → cranelift-control-0.110.2}/src/zero_sized.rs +0 -0
  1124. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/LICENSE +0 -0
  1125. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/README.md +0 -0
  1126. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/boxed_slice.rs +0 -0
  1127. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/iter.rs +0 -0
  1128. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/keys.rs +0 -0
  1129. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/lib.rs +0 -0
  1130. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/list.rs +0 -0
  1131. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/map.rs +0 -0
  1132. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/packed_option.rs +0 -0
  1133. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/primary.rs +0 -0
  1134. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/sparse.rs +0 -0
  1135. /data/ext/cargo-vendor/{cranelift-entity-0.109.0 → cranelift-entity-0.110.2}/src/unsigned.rs +0 -0
  1136. /data/ext/cargo-vendor/{cranelift-frontend-0.109.0 → cranelift-frontend-0.110.2}/LICENSE +0 -0
  1137. /data/ext/cargo-vendor/{cranelift-frontend-0.109.0 → cranelift-frontend-0.110.2}/README.md +0 -0
  1138. /data/ext/cargo-vendor/{cranelift-frontend-0.109.0 → cranelift-frontend-0.110.2}/src/lib.rs +0 -0
  1139. /data/ext/cargo-vendor/{cranelift-frontend-0.109.0 → cranelift-frontend-0.110.2}/src/ssa.rs +0 -0
  1140. /data/ext/cargo-vendor/{cranelift-frontend-0.109.0 → cranelift-frontend-0.110.2}/src/switch.rs +0 -0
  1141. /data/ext/cargo-vendor/{cranelift-frontend-0.109.0 → cranelift-frontend-0.110.2}/src/variable.rs +0 -0
  1142. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/README.md +0 -0
  1143. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/build.rs +0 -0
  1144. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/bad_converters.isle +0 -0
  1145. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
  1146. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
  1147. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/error1.isle +0 -0
  1148. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/extra_parens.isle +0 -0
  1149. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/impure_expression.isle +0 -0
  1150. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/impure_rhs.isle +0 -0
  1151. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/multi_internal_etor.isle +0 -0
  1152. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/fail/multi_prio.isle +0 -0
  1153. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/borrows.isle +0 -0
  1154. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/borrows_main.rs +0 -0
  1155. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/iflets.isle +0 -0
  1156. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/iflets_main.rs +0 -0
  1157. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/multi_constructor.isle +0 -0
  1158. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/multi_constructor_main.rs +0 -0
  1159. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/multi_extractor.isle +0 -0
  1160. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/multi_extractor_main.rs +0 -0
  1161. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/test.isle +0 -0
  1162. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/link/test_main.rs +0 -0
  1163. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/bound_var.isle +0 -0
  1164. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/construct_and_extract.isle +0 -0
  1165. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/conversions.isle +0 -0
  1166. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/conversions_extern.isle +0 -0
  1167. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/let.isle +0 -0
  1168. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/nodebug.isle +0 -0
  1169. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/prio_trie_bug.isle +0 -0
  1170. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/test2.isle +0 -0
  1171. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/test3.isle +0 -0
  1172. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/test4.isle +0 -0
  1173. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/pass/tutorial.isle +0 -0
  1174. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/run/iconst.isle +0 -0
  1175. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/run/iconst_main.rs +0 -0
  1176. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/run/let_shadowing.isle +0 -0
  1177. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/isle_examples/run/let_shadowing_main.rs +0 -0
  1178. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/ast.rs +0 -0
  1179. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/compile.rs +0 -0
  1180. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/disjointsets.rs +0 -0
  1181. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/error.rs +0 -0
  1182. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/lexer.rs +0 -0
  1183. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/lib.rs +0 -0
  1184. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/log.rs +0 -0
  1185. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/overlap.rs +0 -0
  1186. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/serialize.rs +0 -0
  1187. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/src/stablemapset.rs +0 -0
  1188. /data/ext/cargo-vendor/{cranelift-isle-0.109.0 → cranelift-isle-0.110.2}/tests/run_tests.rs +0 -0
  1189. /data/ext/cargo-vendor/{cranelift-native-0.109.0 → cranelift-native-0.110.2}/LICENSE +0 -0
  1190. /data/ext/cargo-vendor/{cranelift-native-0.109.0 → cranelift-native-0.110.2}/README.md +0 -0
  1191. /data/ext/cargo-vendor/{cranelift-native-0.109.0 → cranelift-native-0.110.2}/src/riscv.rs +0 -0
  1192. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/LICENSE +0 -0
  1193. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/README.md +0 -0
  1194. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/environ/dummy.rs +0 -0
  1195. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/environ/mod.rs +0 -0
  1196. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/environ/spec.rs +0 -0
  1197. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/func_translator.rs +0 -0
  1198. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/lib.rs +0 -0
  1199. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/module_translator.rs +0 -0
  1200. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/state.rs +0 -0
  1201. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/table.rs +0 -0
  1202. /data/ext/cargo-vendor/{cranelift-wasm-0.109.0 → cranelift-wasm-0.110.2}/src/translation_utils.rs +0 -0
  1203. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/README.md +0 -0
  1204. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/src/clocks.rs +0 -0
  1205. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/src/lib.rs +0 -0
  1206. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/src/noop_scheduler.rs +0 -0
  1207. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/tests/clocks.rs +0 -0
  1208. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/tests/common/mod.rs +0 -0
  1209. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/tests/random.rs +0 -0
  1210. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.22 → deterministic-wasi-ctx-0.1.23}/tests/scheduler.rs +0 -0
  1211. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/LICENSE +0 -0
  1212. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/README.md +0 -0
  1213. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/clocks.rs +0 -0
  1214. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/ctx.rs +0 -0
  1215. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/dir.rs +0 -0
  1216. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/error.rs +0 -0
  1217. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/file.rs +0 -0
  1218. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/lib.rs +0 -0
  1219. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/pipe.rs +0 -0
  1220. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/random.rs +0 -0
  1221. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sched/subscription.rs +0 -0
  1222. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sched.rs +0 -0
  1223. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/snapshots/mod.rs +0 -0
  1224. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/snapshots/preview_0.rs +0 -0
  1225. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/snapshots/preview_1/error.rs +0 -0
  1226. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/snapshots/preview_1.rs +0 -0
  1227. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/string_array.rs +0 -0
  1228. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/clocks.rs +0 -0
  1229. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/dir.rs +0 -0
  1230. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/file.rs +0 -0
  1231. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/mod.rs +0 -0
  1232. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/net.rs +0 -0
  1233. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/sched/unix.rs +0 -0
  1234. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/sched/windows.rs +0 -0
  1235. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/sched.rs +0 -0
  1236. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/sync/stdio.rs +0 -0
  1237. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/table.rs +0 -0
  1238. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/tokio/dir.rs +0 -0
  1239. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/tokio/file.rs +0 -0
  1240. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/tokio/net.rs +0 -0
  1241. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/tokio/sched/unix.rs +0 -0
  1242. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/tokio/sched/windows.rs +0 -0
  1243. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/tokio/sched.rs +0 -0
  1244. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/src/tokio/stdio.rs +0 -0
  1245. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/tests/all/main.rs +0 -0
  1246. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/witx/preview0/typenames.witx +0 -0
  1247. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/witx/preview0/wasi_unstable.witx +0 -0
  1248. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/witx/preview1/typenames.witx +0 -0
  1249. /data/ext/cargo-vendor/{wasi-common-22.0.0 → wasi-common-23.0.2}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1250. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/LICENSE +0 -0
  1251. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/README.md +0 -0
  1252. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/aliases.rs +0 -0
  1253. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/builder.rs +0 -0
  1254. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/canonicals.rs +0 -0
  1255. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/components.rs +0 -0
  1256. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/exports.rs +0 -0
  1257. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/imports.rs +0 -0
  1258. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/instances.rs +0 -0
  1259. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/modules.rs +0 -0
  1260. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/names.rs +0 -0
  1261. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component/start.rs +0 -0
  1262. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/component.rs +0 -0
  1263. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/custom.rs +0 -0
  1264. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/data.rs +0 -0
  1265. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/dump.rs +0 -0
  1266. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/elements.rs +0 -0
  1267. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/functions.rs +0 -0
  1268. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/linking.rs +0 -0
  1269. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/names.rs +0 -0
  1270. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/producers.rs +0 -0
  1271. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core/start.rs +0 -0
  1272. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/core.rs +0 -0
  1273. /data/ext/cargo-vendor/{wasm-encoder-0.209.1 → wasm-encoder-0.212.0}/src/raw.rs +0 -0
  1274. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/README.md +0 -0
  1275. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/benches/benchmark.rs +0 -0
  1276. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/examples/simple.rs +0 -0
  1277. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/hash.rs +0 -0
  1278. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/index_map/detail.rs +0 -0
  1279. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/index_map/tests.rs +0 -0
  1280. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/index_map.rs +0 -0
  1281. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/index_set.rs +0 -0
  1282. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/map.rs +0 -0
  1283. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/mod.rs +0 -0
  1284. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/collections/set.rs +0 -0
  1285. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/limits.rs +0 -0
  1286. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/aliases.rs +0 -0
  1287. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/canonicals.rs +0 -0
  1288. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/exports.rs +0 -0
  1289. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/imports.rs +0 -0
  1290. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/instances.rs +0 -0
  1291. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/names.rs +0 -0
  1292. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/start.rs +0 -0
  1293. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component/types.rs +0 -0
  1294. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/component.rs +0 -0
  1295. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/branch_hinting.rs +0 -0
  1296. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/code.rs +0 -0
  1297. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/coredumps.rs +0 -0
  1298. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/custom.rs +0 -0
  1299. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/data.rs +0 -0
  1300. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/dylink0.rs +0 -0
  1301. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/elements.rs +0 -0
  1302. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/exports.rs +0 -0
  1303. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/functions.rs +0 -0
  1304. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/globals.rs +0 -0
  1305. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/imports.rs +0 -0
  1306. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/init.rs +0 -0
  1307. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/linking.rs +0 -0
  1308. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/memories.rs +0 -0
  1309. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/names.rs +0 -0
  1310. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/producers.rs +0 -0
  1311. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/reloc.rs +0 -0
  1312. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/tags.rs +0 -0
  1313. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core/types/matches.rs +0 -0
  1314. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers/core.rs +0 -0
  1315. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/readers.rs +0 -0
  1316. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/validator/core/canonical.rs +0 -0
  1317. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/validator/func.rs +0 -0
  1318. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/src/validator/names.rs +0 -0
  1319. /data/ext/cargo-vendor/{wasmparser-0.209.1 → wasmparser-0.212.0}/tests/big-module.rs +0 -0
  1320. /data/ext/cargo-vendor/{wasmprinter-0.209.1 → wasmprinter-0.212.0}/LICENSE +0 -0
  1321. /data/ext/cargo-vendor/{wasmprinter-0.209.1 → wasmprinter-0.212.0}/README.md +0 -0
  1322. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/LICENSE +0 -0
  1323. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/README.md +0 -0
  1324. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/proptest-regressions/runtime/vm/instance/allocator/pooling/memory_pool.txt +0 -0
  1325. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/code.rs +0 -0
  1326. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/bindgen_examples/_0_hello_world.rs +0 -0
  1327. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/bindgen_examples/_1_world_imports.rs +0 -0
  1328. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/bindgen_examples/_2_world_exports.rs +0 -0
  1329. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/bindgen_examples/_3_interface_imports.rs +0 -0
  1330. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/bindgen_examples/_4_imported_resources.rs +0 -0
  1331. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/bindgen_examples/_5_all_world_export_kinds.rs +0 -0
  1332. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/bindgen_examples/_6_exported_resources.rs +0 -0
  1333. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/resource_table.rs +0 -0
  1334. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/storage.rs +0 -0
  1335. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/store.rs +0 -0
  1336. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/component/types.rs +0 -0
  1337. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/externals.rs +0 -0
  1338. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/disabled/anyref.rs +0 -0
  1339. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/disabled/externref.rs +0 -0
  1340. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/disabled/i31.rs +0 -0
  1341. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/disabled.rs +0 -0
  1342. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/enabled/anyref.rs +0 -0
  1343. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/enabled/i31.rs +0 -0
  1344. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/enabled.rs +0 -0
  1345. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc/noextern.rs +0 -0
  1346. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/gc.rs +0 -0
  1347. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/resources.rs +0 -0
  1348. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/signatures.rs +0 -0
  1349. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/store/context.rs +0 -0
  1350. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/store/func_refs.rs +0 -0
  1351. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/trampoline/global.rs +0 -0
  1352. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/type_registry.rs +0 -0
  1353. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/uninhabited.rs +0 -0
  1354. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/unix.rs +0 -0
  1355. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/v128.rs +0 -0
  1356. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/arch/aarch64.rs +0 -0
  1357. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/arch/mod.rs +0 -0
  1358. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/arch/s390x.S +0 -0
  1359. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/arch/s390x.rs +0 -0
  1360. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/arch/x86_64.rs +0 -0
  1361. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/async_yield.rs +0 -0
  1362. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/debug_builtins.rs +0 -0
  1363. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/export.rs +0 -0
  1364. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/gc/enabled/externref.rs +0 -0
  1365. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/gc/enabled.rs +0 -0
  1366. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/gc/host_data.rs +0 -0
  1367. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/gc/i31.rs +0 -0
  1368. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/helpers.c +0 -0
  1369. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/imports.rs +0 -0
  1370. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/mpk/pkru.rs +0 -0
  1371. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/send_sync_ptr.rs +0 -0
  1372. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/store_box.rs +0 -0
  1373. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/custom/capi.rs +0 -0
  1374. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/custom/traphandlers.rs +0 -0
  1375. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/miri/mod.rs +0 -0
  1376. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/miri/traphandlers.rs +0 -0
  1377. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/miri/vm.rs +0 -0
  1378. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/mod.rs +0 -0
  1379. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/unix/machports.rs +0 -0
  1380. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/unix/macos_traphandlers.rs +0 -0
  1381. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/unix/mod.rs +0 -0
  1382. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/unix/vm.rs +0 -0
  1383. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/windows/mod.rs +0 -0
  1384. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/windows/traphandlers.rs +0 -0
  1385. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/sys/windows/vm.rs +0 -0
  1386. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/threads/mod.rs +0 -0
  1387. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/threads/parking_spot.rs +0 -0
  1388. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/traphandlers/backtrace.rs +0 -0
  1389. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/traphandlers/coredump_disabled.rs +0 -0
  1390. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/vm/traphandlers/coredump_enabled.rs +0 -0
  1391. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/runtime/windows.rs +0 -0
  1392. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/sync_nostd.rs +0 -0
  1393. /data/ext/cargo-vendor/{wasmtime-22.0.0 → wasmtime-23.0.2}/src/sync_std.rs +0 -0
  1394. /data/ext/cargo-vendor/{wasmtime-asm-macros-22.0.0 → wasmtime-asm-macros-23.0.2}/src/lib.rs +0 -0
  1395. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/LICENSE +0 -0
  1396. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/build.rs +0 -0
  1397. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/src/config/tests.rs +0 -0
  1398. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/src/config.rs +0 -0
  1399. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/src/lib.rs +0 -0
  1400. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/src/tests.rs +0 -0
  1401. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/src/worker/tests/system_time_stub.rs +0 -0
  1402. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/src/worker/tests.rs +0 -0
  1403. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/src/worker.rs +0 -0
  1404. /data/ext/cargo-vendor/{wasmtime-cache-22.0.0 → wasmtime-cache-23.0.2}/tests/cache_write_default_config.rs +0 -0
  1405. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/build.rs +0 -0
  1406. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/src/component.rs +0 -0
  1407. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/src/lib.rs +0 -0
  1408. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/char.wit +0 -0
  1409. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/conventions.wit +0 -0
  1410. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/dead-code.wit +0 -0
  1411. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/direct-import.wit +0 -0
  1412. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/empty.wit +0 -0
  1413. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/flags.wit +0 -0
  1414. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/floats.wit +0 -0
  1415. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/function-new.wit +0 -0
  1416. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/integers.wit +0 -0
  1417. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/lists.wit +0 -0
  1418. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/many-arguments.wit +0 -0
  1419. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/multi-return.wit +0 -0
  1420. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/multiversion/deps/v1/root.wit +0 -0
  1421. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/multiversion/deps/v2/root.wit +0 -0
  1422. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/multiversion/root.wit +0 -0
  1423. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/records.wit +0 -0
  1424. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/rename.wit +0 -0
  1425. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/resources-export.wit +0 -0
  1426. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/resources-import.wit +0 -0
  1427. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/share-types.wit +0 -0
  1428. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/simple-functions.wit +0 -0
  1429. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/simple-lists.wit +0 -0
  1430. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/simple-wasi.wit +0 -0
  1431. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/small-anonymous.wit +0 -0
  1432. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/smoke-default.wit +0 -0
  1433. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/smoke-export.wit +0 -0
  1434. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/smoke.wit +0 -0
  1435. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/strings.wit +0 -0
  1436. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/unversioned-foo.wit +0 -0
  1437. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/use-paths.wit +0 -0
  1438. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/variants.wit +0 -0
  1439. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/wat.wit +0 -0
  1440. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen/worlds-with-types.wit +0 -0
  1441. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/codegen_no_std.rs +0 -0
  1442. /data/ext/cargo-vendor/{wasmtime-component-macro-22.0.0 → wasmtime-component-macro-23.0.2}/tests/expanded.rs +0 -0
  1443. /data/ext/cargo-vendor/{wasmtime-component-util-22.0.0 → wasmtime-component-util-23.0.2}/src/lib.rs +0 -0
  1444. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/LICENSE +0 -0
  1445. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/SECURITY.md +0 -0
  1446. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/builder.rs +0 -0
  1447. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/compiled_function.rs +0 -0
  1448. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/compiler/component.rs +0 -0
  1449. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/debug/transform/refs.rs +0 -0
  1450. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/gc/disabled.rs +0 -0
  1451. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/gc.rs +0 -0
  1452. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/isa_builder.rs +0 -0
  1453. /data/ext/cargo-vendor/{wasmtime-cranelift-22.0.0 → wasmtime-cranelift-23.0.2}/src/obj.rs +0 -0
  1454. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/LICENSE +0 -0
  1455. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/examples/factc.rs +0 -0
  1456. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/address_map.rs +0 -0
  1457. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/builtin.rs +0 -0
  1458. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/compile/address_map.rs +0 -0
  1459. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/compile/module_artifacts.rs +0 -0
  1460. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/compile/module_types.rs +0 -0
  1461. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/compile/trap_encoding.rs +0 -0
  1462. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/component/artifacts.rs +0 -0
  1463. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/component/compiler.rs +0 -0
  1464. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/component/translate/adapt.rs +0 -0
  1465. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/component/types_builder/resources.rs +0 -0
  1466. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/component/vmcomponent_offsets.rs +0 -0
  1467. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/demangling.rs +0 -0
  1468. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/fact/core_types.rs +0 -0
  1469. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/fact/signature.rs +0 -0
  1470. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/fact/trampoline.rs +0 -0
  1471. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/fact/transcode.rs +0 -0
  1472. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/fact/traps.rs +0 -0
  1473. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/fact.rs +0 -0
  1474. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/gc.rs +0 -0
  1475. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/module_artifacts.rs +0 -0
  1476. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/module_types.rs +0 -0
  1477. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/obj.rs +0 -0
  1478. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/ref_bits.rs +0 -0
  1479. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/scopevec.rs +0 -0
  1480. /data/ext/cargo-vendor/{wasmtime-environ-22.0.0 → wasmtime-environ-23.0.2}/src/trap_encoding.rs +0 -0
  1481. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/LICENSE +0 -0
  1482. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/build.rs +0 -0
  1483. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/lib.rs +0 -0
  1484. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/unix/aarch64.rs +0 -0
  1485. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/unix/arm.rs +0 -0
  1486. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/unix/riscv64.rs +0 -0
  1487. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/unix/s390x.S +0 -0
  1488. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/unix/x86.rs +0 -0
  1489. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/unix/x86_64.rs +0 -0
  1490. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/unix.rs +0 -0
  1491. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/windows.c +0 -0
  1492. /data/ext/cargo-vendor/{wasmtime-fiber-22.0.0 → wasmtime-fiber-23.0.2}/src/windows.rs +0 -0
  1493. /data/ext/cargo-vendor/{wasmtime-jit-debug-22.0.0 → wasmtime-jit-debug-23.0.2}/README.md +0 -0
  1494. /data/ext/cargo-vendor/{wasmtime-jit-debug-22.0.0 → wasmtime-jit-debug-23.0.2}/src/gdb_jit_int.rs +0 -0
  1495. /data/ext/cargo-vendor/{wasmtime-jit-debug-22.0.0 → wasmtime-jit-debug-23.0.2}/src/lib.rs +0 -0
  1496. /data/ext/cargo-vendor/{wasmtime-jit-debug-22.0.0 → wasmtime-jit-debug-23.0.2}/src/perf_jitdump.rs +0 -0
  1497. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-22.0.0 → wasmtime-jit-icache-coherence-23.0.2}/src/lib.rs +0 -0
  1498. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-22.0.0 → wasmtime-jit-icache-coherence-23.0.2}/src/libc.rs +0 -0
  1499. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-22.0.0 → wasmtime-jit-icache-coherence-23.0.2}/src/miri.rs +0 -0
  1500. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-22.0.0 → wasmtime-jit-icache-coherence-23.0.2}/src/win.rs +0 -0
  1501. /data/ext/cargo-vendor/{wasmtime-slab-22.0.0 → wasmtime-slab-23.0.2}/src/lib.rs +0 -0
  1502. /data/ext/cargo-vendor/{wasmtime-types-22.0.0 → wasmtime-types-23.0.2}/LICENSE +0 -0
  1503. /data/ext/cargo-vendor/{wasmtime-types-22.0.0 → wasmtime-types-23.0.2}/src/error.rs +0 -0
  1504. /data/ext/cargo-vendor/{wasmtime-versioned-export-macros-22.0.0 → wasmtime-versioned-export-macros-23.0.2}/src/lib.rs +0 -0
  1505. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/LICENSE +0 -0
  1506. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/README.md +0 -0
  1507. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/clocks/host.rs +0 -0
  1508. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/clocks.rs +0 -0
  1509. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/ctx.rs +0 -0
  1510. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/error.rs +0 -0
  1511. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/clocks.rs +0 -0
  1512. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/env.rs +0 -0
  1513. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/exit.rs +0 -0
  1514. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/filesystem/sync.rs +0 -0
  1515. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/instance_network.rs +0 -0
  1516. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/mod.rs +0 -0
  1517. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/network.rs +0 -0
  1518. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/random.rs +0 -0
  1519. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/tcp.rs +0 -0
  1520. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/tcp_create_socket.rs +0 -0
  1521. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/udp.rs +0 -0
  1522. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/host/udp_create_socket.rs +0 -0
  1523. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/ip_name_lookup.rs +0 -0
  1524. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/network.rs +0 -0
  1525. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/pipe.rs +0 -0
  1526. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/poll.rs +0 -0
  1527. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/preview0.rs +0 -0
  1528. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/random.rs +0 -0
  1529. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/runtime.rs +0 -0
  1530. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/stdio/worker_thread_stdin.rs +0 -0
  1531. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/stream.rs +0 -0
  1532. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/tcp.rs +0 -0
  1533. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/udp.rs +0 -0
  1534. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/src/write_stream.rs +0 -0
  1535. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/tests/all/main.rs +0 -0
  1536. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/tests/all/preview1.rs +0 -0
  1537. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/tests/process_stdin.rs +0 -0
  1538. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/command-extended.wit +0 -0
  1539. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/cli/command.wit +0 -0
  1540. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/cli/environment.wit +0 -0
  1541. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/cli/exit.wit +0 -0
  1542. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/cli/imports.wit +0 -0
  1543. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/cli/run.wit +0 -0
  1544. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/cli/stdio.wit +0 -0
  1545. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/cli/terminal.wit +0 -0
  1546. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/clocks/monotonic-clock.wit +0 -0
  1547. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/clocks/wall-clock.wit +0 -0
  1548. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/clocks/world.wit +0 -0
  1549. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/filesystem/preopens.wit +0 -0
  1550. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/filesystem/types.wit +0 -0
  1551. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/filesystem/world.wit +0 -0
  1552. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/http/handler.wit +0 -0
  1553. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/http/proxy.wit +0 -0
  1554. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/http/types.wit +0 -0
  1555. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/io/error.wit +0 -0
  1556. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/io/poll.wit +0 -0
  1557. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/io/streams.wit +0 -0
  1558. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/io/world.wit +0 -0
  1559. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/random/insecure-seed.wit +0 -0
  1560. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/random/insecure.wit +0 -0
  1561. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/random/random.wit +0 -0
  1562. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/random/world.wit +0 -0
  1563. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/instance-network.wit +0 -0
  1564. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/ip-name-lookup.wit +0 -0
  1565. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/network.wit +0 -0
  1566. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/tcp-create-socket.wit +0 -0
  1567. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/tcp.wit +0 -0
  1568. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/udp-create-socket.wit +0 -0
  1569. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/udp.wit +0 -0
  1570. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/deps/sockets/world.wit +0 -0
  1571. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/wit/test.wit +0 -0
  1572. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/witx/preview0/typenames.witx +0 -0
  1573. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/witx/preview0/wasi_unstable.witx +0 -0
  1574. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/witx/preview1/typenames.witx +0 -0
  1575. /data/ext/cargo-vendor/{wasmtime-wasi-22.0.0 → wasmtime-wasi-23.0.2}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1576. /data/ext/cargo-vendor/{wasmtime-winch-22.0.0 → wasmtime-winch-23.0.2}/LICENSE +0 -0
  1577. /data/ext/cargo-vendor/{wasmtime-winch-22.0.0 → wasmtime-winch-23.0.2}/src/builder.rs +0 -0
  1578. /data/ext/cargo-vendor/{wasmtime-winch-22.0.0 → wasmtime-winch-23.0.2}/src/lib.rs +0 -0
  1579. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-22.0.0 → wasmtime-wit-bindgen-23.0.2}/src/rust.rs +0 -0
  1580. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-22.0.0 → wasmtime-wit-bindgen-23.0.2}/src/source.rs +0 -0
  1581. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-22.0.0 → wasmtime-wit-bindgen-23.0.2}/src/types.rs +0 -0
  1582. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/README.md +0 -0
  1583. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/alias.rs +0 -0
  1584. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/custom.rs +0 -0
  1585. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/export.rs +0 -0
  1586. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/func.rs +0 -0
  1587. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/import.rs +0 -0
  1588. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/instance.rs +0 -0
  1589. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/item_ref.rs +0 -0
  1590. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/module.rs +0 -0
  1591. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/types.rs +0 -0
  1592. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/component/wast.rs +0 -0
  1593. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/custom.rs +0 -0
  1594. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/export.rs +0 -0
  1595. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/func.rs +0 -0
  1596. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/global.rs +0 -0
  1597. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/import.rs +0 -0
  1598. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/resolve/mod.rs +0 -0
  1599. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/tag.rs +0 -0
  1600. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/core/wast.rs +0 -0
  1601. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/encode.rs +0 -0
  1602. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/error.rs +0 -0
  1603. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/gensym.rs +0 -0
  1604. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/lexer.rs +0 -0
  1605. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/names.rs +0 -0
  1606. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/token.rs +0 -0
  1607. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/src/wast.rs +0 -0
  1608. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/annotations.rs +0 -0
  1609. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/comments.rs +0 -0
  1610. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-core-func-alias.wat +0 -0
  1611. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-core-func-alias.wat.err +0 -0
  1612. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-func-alias.wat +0 -0
  1613. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-func-alias.wat.err +0 -0
  1614. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-index.wat +0 -0
  1615. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-index.wat.err +0 -0
  1616. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-name.wat +0 -0
  1617. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-name.wat.err +0 -0
  1618. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-name2.wat +0 -0
  1619. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-name2.wat.err +0 -0
  1620. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-name3.wat +0 -0
  1621. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/bad-name3.wat.err +0 -0
  1622. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/block1.wat +0 -0
  1623. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/block1.wat.err +0 -0
  1624. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/block2.wat +0 -0
  1625. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/block2.wat.err +0 -0
  1626. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/block3.wat +0 -0
  1627. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/block3.wat.err +0 -0
  1628. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment0.wat +0 -0
  1629. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment0.wat.err +0 -0
  1630. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment1.wat +0 -0
  1631. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment1.wat.err +0 -0
  1632. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment2.wat +0 -0
  1633. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment2.wat.err +0 -0
  1634. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment3.wat +0 -0
  1635. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment3.wat.err +0 -0
  1636. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment4.wat +0 -0
  1637. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment4.wat.err +0 -0
  1638. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment5.wat +0 -0
  1639. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment5.wat.err +0 -0
  1640. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment6.wat +0 -0
  1641. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment6.wat.err +0 -0
  1642. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment7.wat +0 -0
  1643. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment7.wat.err +0 -0
  1644. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment8.wat +0 -0
  1645. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-block-comment8.wat.err +0 -0
  1646. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment0.wat +0 -0
  1647. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment0.wat.err +0 -0
  1648. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment1.wat +0 -0
  1649. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment1.wat.err +0 -0
  1650. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment2.wat +0 -0
  1651. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment2.wat.err +0 -0
  1652. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment3.wat +0 -0
  1653. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment3.wat.err +0 -0
  1654. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment4.wat +0 -0
  1655. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment4.wat.err +0 -0
  1656. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment5.wat +0 -0
  1657. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment5.wat.err +0 -0
  1658. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment6.wat +0 -0
  1659. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment6.wat.err +0 -0
  1660. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment7.wat +0 -0
  1661. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment7.wat.err +0 -0
  1662. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment8.wat +0 -0
  1663. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-line-comment8.wat.err +0 -0
  1664. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string0.wat +0 -0
  1665. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string0.wat.err +0 -0
  1666. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string1.wat +0 -0
  1667. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string1.wat.err +0 -0
  1668. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string2.wat +0 -0
  1669. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string2.wat.err +0 -0
  1670. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string3.wat +0 -0
  1671. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string3.wat.err +0 -0
  1672. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string4.wat +0 -0
  1673. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string4.wat.err +0 -0
  1674. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string5.wat +0 -0
  1675. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string5.wat.err +0 -0
  1676. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string6.wat +0 -0
  1677. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string6.wat.err +0 -0
  1678. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string7.wat +0 -0
  1679. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string7.wat.err +0 -0
  1680. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string8.wat +0 -0
  1681. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/confusing-string8.wat.err +0 -0
  1682. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/inline1.wat +0 -0
  1683. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/inline1.wat.err +0 -0
  1684. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/newline-in-string.wat +0 -0
  1685. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/newline-in-string.wat.err +0 -0
  1686. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string1.wat +0 -0
  1687. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string1.wat.err +0 -0
  1688. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string10.wat +0 -0
  1689. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string10.wat.err +0 -0
  1690. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string11.wat +0 -0
  1691. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string11.wat.err +0 -0
  1692. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string12.wat +0 -0
  1693. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string12.wat.err +0 -0
  1694. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string13.wat +0 -0
  1695. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string13.wat.err +0 -0
  1696. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string14.wat +0 -0
  1697. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string14.wat.err +0 -0
  1698. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string15.wat +0 -0
  1699. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string15.wat.err +0 -0
  1700. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string16.wat +0 -0
  1701. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string16.wat.err +0 -0
  1702. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string2.wat +0 -0
  1703. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string2.wat.err +0 -0
  1704. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string3.wat +0 -0
  1705. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string3.wat.err +0 -0
  1706. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string4.wat +0 -0
  1707. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string4.wat.err +0 -0
  1708. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string5.wat +0 -0
  1709. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string5.wat.err +0 -0
  1710. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string6.wat +0 -0
  1711. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string6.wat.err +0 -0
  1712. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string7.wat +0 -0
  1713. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string7.wat.err +0 -0
  1714. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string8.wat +0 -0
  1715. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string8.wat.err +0 -0
  1716. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string9.wat +0 -0
  1717. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/string9.wat.err +0 -0
  1718. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/unbalanced.wat +0 -0
  1719. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail/unbalanced.wat.err +0 -0
  1720. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/parse-fail.rs +0 -0
  1721. /data/ext/cargo-vendor/{wast-209.0.1 → wast-215.0.0}/tests/recursive.rs +0 -0
  1722. /data/ext/cargo-vendor/{wat-1.209.1 → wat-1.215.0}/README.md +0 -0
  1723. /data/ext/cargo-vendor/{wast-209.0.1 → wiggle-23.0.2}/LICENSE +0 -0
  1724. /data/ext/cargo-vendor/{wiggle-22.0.0 → wiggle-23.0.2}/README.md +0 -0
  1725. /data/ext/cargo-vendor/{wiggle-22.0.0 → wiggle-23.0.2}/src/error.rs +0 -0
  1726. /data/ext/cargo-vendor/{wiggle-22.0.0 → wiggle-23.0.2}/src/guest_type.rs +0 -0
  1727. /data/ext/cargo-vendor/{wiggle-22.0.0 → wiggle-23.0.2}/src/lib.rs +0 -0
  1728. /data/ext/cargo-vendor/{wiggle-22.0.0 → wiggle-23.0.2}/src/region.rs +0 -0
  1729. /data/ext/cargo-vendor/{wat-1.209.1 → wiggle-generate-23.0.2}/LICENSE +0 -0
  1730. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/README.md +0 -0
  1731. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/codegen_settings.rs +0 -0
  1732. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/config.rs +0 -0
  1733. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/funcs.rs +0 -0
  1734. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/lib.rs +0 -0
  1735. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/lifetimes.rs +0 -0
  1736. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/module_trait.rs +0 -0
  1737. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/names.rs +0 -0
  1738. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/types/error.rs +0 -0
  1739. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/types/flags.rs +0 -0
  1740. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/types/handle.rs +0 -0
  1741. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/types/mod.rs +0 -0
  1742. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/types/record.rs +0 -0
  1743. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/types/variant.rs +0 -0
  1744. /data/ext/cargo-vendor/{wiggle-generate-22.0.0 → wiggle-generate-23.0.2}/src/wasmtime.rs +0 -0
  1745. /data/ext/cargo-vendor/{wiggle-22.0.0 → wiggle-macro-23.0.2}/LICENSE +0 -0
  1746. /data/ext/cargo-vendor/{wiggle-macro-22.0.0 → wiggle-macro-23.0.2}/build.rs +0 -0
  1747. /data/ext/cargo-vendor/{wiggle-macro-22.0.0 → wiggle-macro-23.0.2}/src/lib.rs +0 -0
  1748. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/LICENSE +0 -0
  1749. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/build.rs +0 -0
  1750. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/abi/local.rs +0 -0
  1751. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/abi/mod.rs +0 -0
  1752. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/codegen/bounds.rs +0 -0
  1753. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/codegen/builtin.rs +0 -0
  1754. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/codegen/call.rs +0 -0
  1755. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/codegen/context.rs +0 -0
  1756. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/codegen/control.rs +0 -0
  1757. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/frame/mod.rs +0 -0
  1758. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/aarch64/abi.rs +0 -0
  1759. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/aarch64/address.rs +0 -0
  1760. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/aarch64/asm.rs +0 -0
  1761. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/aarch64/masm.rs +0 -0
  1762. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/aarch64/mod.rs +0 -0
  1763. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/aarch64/regs.rs +0 -0
  1764. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/mod.rs +0 -0
  1765. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/reg.rs +0 -0
  1766. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/x64/abi.rs +0 -0
  1767. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/x64/address.rs +0 -0
  1768. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/x64/asm.rs +0 -0
  1769. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/x64/masm.rs +0 -0
  1770. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/x64/mod.rs +0 -0
  1771. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/isa/x64/regs.rs +0 -0
  1772. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/lib.rs +0 -0
  1773. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/masm.rs +0 -0
  1774. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/regalloc.rs +0 -0
  1775. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/regset.rs +0 -0
  1776. /data/ext/cargo-vendor/{winch-codegen-0.20.0 → winch-codegen-0.21.2}/src/stack.rs +0 -0
  1777. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/README.md +0 -0
  1778. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/src/abi.rs +0 -0
  1779. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/src/ast/toposort.rs +0 -0
  1780. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/src/live.rs +0 -0
  1781. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/src/metadata.rs +0 -0
  1782. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/src/serde_.rs +0 -0
  1783. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/src/sizealign.rs +0 -0
  1784. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/all.rs +0 -0
  1785. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/comments.wit +0 -0
  1786. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/comments.wit.json +0 -0
  1787. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/complex-include/deps/bar/root.wit +0 -0
  1788. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/complex-include/deps/baz/root.wit +0 -0
  1789. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/complex-include/root.wit +0 -0
  1790. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/complex-include.wit.json +0 -0
  1791. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/cross-package-resource/deps/foo/foo.wit +0 -0
  1792. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/cross-package-resource/foo.wit +0 -0
  1793. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/cross-package-resource.wit.json +0 -0
  1794. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/diamond1/deps/dep1/types.wit +0 -0
  1795. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/diamond1/deps/dep2/types.wit +0 -0
  1796. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/diamond1/join.wit +0 -0
  1797. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/diamond1.wit.json +0 -0
  1798. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/disambiguate-diamond/shared1.wit +0 -0
  1799. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/disambiguate-diamond/shared2.wit +0 -0
  1800. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/disambiguate-diamond/world.wit +0 -0
  1801. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/disambiguate-diamond.wit.json +0 -0
  1802. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/empty.wit +0 -0
  1803. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/empty.wit.json +0 -0
  1804. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/feature-gates.wit +0 -0
  1805. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +0 -0
  1806. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/deps/corp/saas.wit +0 -0
  1807. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +0 -0
  1808. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +0 -0
  1809. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +0 -0
  1810. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/deps/wasi/clocks.wit +0 -0
  1811. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/deps/wasi/filesystem.wit +0 -0
  1812. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps/root.wit +0 -0
  1813. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/another-pkg/other-doc.wit +0 -0
  1814. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/corp/saas.wit +0 -0
  1815. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/different-pkg/the-doc.wit +0 -0
  1816. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/foreign-pkg/the-doc.wit +0 -0
  1817. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/some-pkg/some-doc.wit +0 -0
  1818. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/wasi/clocks.wit +0 -0
  1819. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/wasi/filesystem.wit +0 -0
  1820. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/deps/wasi/wasi.wit +0 -0
  1821. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union/root.wit +0 -0
  1822. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps-union.wit.json +0 -0
  1823. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/foreign-deps.wit.json +0 -0
  1824. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/functions.wit +0 -0
  1825. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/functions.wit.json +0 -0
  1826. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/ignore-files-deps/deps/bar/types.wit +0 -0
  1827. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/ignore-files-deps/deps/ignore-me.txt +0 -0
  1828. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/ignore-files-deps/world.wit +0 -0
  1829. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/ignore-files-deps.wit.json +0 -0
  1830. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/import-export-overlap1.wit +0 -0
  1831. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/import-export-overlap1.wit.json +0 -0
  1832. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/import-export-overlap2.wit +0 -0
  1833. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/import-export-overlap2.wit.json +0 -0
  1834. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/include-reps.wit +0 -0
  1835. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/include-reps.wit.json +0 -0
  1836. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kebab-name-include-with.wit +0 -0
  1837. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kebab-name-include-with.wit.json +0 -0
  1838. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kinds-of-deps/a.wit +0 -0
  1839. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kinds-of-deps/deps/b/root.wit +0 -0
  1840. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kinds-of-deps/deps/c.wit +0 -0
  1841. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kinds-of-deps/deps/d.wat +0 -0
  1842. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kinds-of-deps/deps/e.wasm +0 -0
  1843. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/kinds-of-deps.wit.json +0 -0
  1844. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/many-names/a.wit +0 -0
  1845. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/many-names/b.wit +0 -0
  1846. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/many-names.wit.json +0 -0
  1847. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/multi-file/bar.wit +0 -0
  1848. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/multi-file/cycle-a.wit +0 -0
  1849. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/multi-file/cycle-b.wit +0 -0
  1850. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/multi-file/foo.wit +0 -0
  1851. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/multi-file.wit.json +0 -0
  1852. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/name-both-resource-and-type/deps/dep/foo.wit +0 -0
  1853. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/name-both-resource-and-type/foo.wit +0 -0
  1854. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/name-both-resource-and-type.wit.json +0 -0
  1855. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/package-syntax1.wit +0 -0
  1856. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/package-syntax1.wit.json +0 -0
  1857. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/package-syntax3.wit +0 -0
  1858. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/package-syntax3.wit.json +0 -0
  1859. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/package-syntax4.wit +0 -0
  1860. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/package-syntax4.wit.json +0 -0
  1861. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/alias-no-type.wit +0 -0
  1862. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/alias-no-type.wit.result +0 -0
  1863. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/async.wit.result +0 -0
  1864. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/async1.wit.result +0 -0
  1865. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-function.wit +0 -0
  1866. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-function.wit.result +0 -0
  1867. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-function2.wit +0 -0
  1868. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-function2.wit.result +0 -0
  1869. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate1.wit +0 -0
  1870. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate1.wit.result +0 -0
  1871. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate2.wit +0 -0
  1872. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate2.wit.result +0 -0
  1873. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate3.wit +0 -0
  1874. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate3.wit.result +0 -0
  1875. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate4.wit +0 -0
  1876. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate4.wit.result +0 -0
  1877. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate5.wit +0 -0
  1878. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-gate5.wit.result +0 -0
  1879. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-include1.wit +0 -0
  1880. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-include1.wit.result +0 -0
  1881. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-include2.wit +0 -0
  1882. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-include2.wit.result +0 -0
  1883. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-include3.wit +0 -0
  1884. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-include3.wit.result +0 -0
  1885. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-list.wit +0 -0
  1886. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-list.wit.result +0 -0
  1887. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg1/root.wit +0 -0
  1888. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg1.wit.result +0 -0
  1889. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg2/deps/bar/empty.wit +0 -0
  1890. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg2/root.wit +0 -0
  1891. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg2.wit.result +0 -0
  1892. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +0 -0
  1893. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg3/root.wit +0 -0
  1894. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg3.wit.result +0 -0
  1895. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +0 -0
  1896. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg4/root.wit +0 -0
  1897. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg4.wit.result +0 -0
  1898. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +0 -0
  1899. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg5/root.wit +0 -0
  1900. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg5.wit.result +0 -0
  1901. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +0 -0
  1902. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg6/root.wit +0 -0
  1903. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-pkg6.wit.result +0 -0
  1904. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource1.wit +0 -0
  1905. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource1.wit.result +0 -0
  1906. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource10.wit +0 -0
  1907. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource10.wit.result +0 -0
  1908. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource11.wit +0 -0
  1909. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource11.wit.result +0 -0
  1910. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource12.wit +0 -0
  1911. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource12.wit.result +0 -0
  1912. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource13.wit +0 -0
  1913. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource13.wit.result +0 -0
  1914. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource14.wit +0 -0
  1915. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource14.wit.result +0 -0
  1916. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource15/deps/foo/foo.wit +0 -0
  1917. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource15/foo.wit +0 -0
  1918. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource15.wit.result +0 -0
  1919. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource2.wit +0 -0
  1920. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource2.wit.result +0 -0
  1921. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource3.wit +0 -0
  1922. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource3.wit.result +0 -0
  1923. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource4.wit +0 -0
  1924. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource4.wit.result +0 -0
  1925. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource5.wit +0 -0
  1926. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource5.wit.result +0 -0
  1927. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource6.wit +0 -0
  1928. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource6.wit.result +0 -0
  1929. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource7.wit +0 -0
  1930. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource7.wit.result +0 -0
  1931. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource8.wit +0 -0
  1932. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource8.wit.result +0 -0
  1933. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource9.wit +0 -0
  1934. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-resource9.wit.result +0 -0
  1935. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-since1.wit +0 -0
  1936. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-since1.wit.result +0 -0
  1937. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-since3.wit +0 -0
  1938. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-since3.wit.result +0 -0
  1939. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-world-type1.wit +0 -0
  1940. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/bad-world-type1.wit.result +0 -0
  1941. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/conflicting-package/a.wit +0 -0
  1942. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/conflicting-package/b.wit +0 -0
  1943. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/conflicting-package.wit.result +0 -0
  1944. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle.wit +0 -0
  1945. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle.wit.result +0 -0
  1946. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle2.wit +0 -0
  1947. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle2.wit.result +0 -0
  1948. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle3.wit +0 -0
  1949. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle3.wit.result +0 -0
  1950. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle4.wit +0 -0
  1951. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle4.wit.result +0 -0
  1952. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle5.wit +0 -0
  1953. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/cycle5.wit.result +0 -0
  1954. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/dangling-type.wit +0 -0
  1955. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/dangling-type.wit.result +0 -0
  1956. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-function-params.wit +0 -0
  1957. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-function-params.wit.result +0 -0
  1958. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-functions.wit +0 -0
  1959. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-functions.wit.result +0 -0
  1960. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-interface.wit +0 -0
  1961. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-interface.wit.result +0 -0
  1962. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-interface2/foo.wit +0 -0
  1963. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-interface2/foo2.wit +0 -0
  1964. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-interface2.wit.result +0 -0
  1965. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-type.wit +0 -0
  1966. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/duplicate-type.wit.result +0 -0
  1967. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/empty-enum.wit +0 -0
  1968. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/empty-enum.wit.result +0 -0
  1969. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/empty-variant1.wit +0 -0
  1970. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/empty-variant1.wit.result +0 -0
  1971. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/export-twice.wit +0 -0
  1972. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/export-twice.wit.result +0 -0
  1973. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export1.wit +0 -0
  1974. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export1.wit.result +0 -0
  1975. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export2.wit +0 -0
  1976. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export2.wit.result +0 -0
  1977. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export3.wit +0 -0
  1978. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export3.wit.result +0 -0
  1979. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export4.wit +0 -0
  1980. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export4.wit.result +0 -0
  1981. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export5.wit +0 -0
  1982. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-and-export5.wit.result +0 -0
  1983. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-twice.wit +0 -0
  1984. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/import-twice.wit.result +0 -0
  1985. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-cycle.wit +0 -0
  1986. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-cycle.wit.result +0 -0
  1987. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-foreign/deps/bar/empty.wit +0 -0
  1988. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-foreign/root.wit +0 -0
  1989. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-foreign.wit.result +0 -0
  1990. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-with-id.wit +0 -0
  1991. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-with-id.wit.result +0 -0
  1992. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-with-on-id.wit +0 -0
  1993. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/include-with-on-id.wit.result +0 -0
  1994. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/invalid-toplevel.wit +0 -0
  1995. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/invalid-toplevel.wit.result +0 -0
  1996. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/invalid-type-reference.wit +0 -0
  1997. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/invalid-type-reference.wit.result +0 -0
  1998. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/invalid-type-reference2.wit +0 -0
  1999. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/invalid-type-reference2.wit.result +0 -0
  2000. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit +0 -0
  2001. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit.result +0 -0
  2002. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/kebab-name-include.wit +0 -0
  2003. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/kebab-name-include.wit.result +0 -0
  2004. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/keyword.wit +0 -0
  2005. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/keyword.wit.result +0 -0
  2006. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/missing-package.wit +0 -0
  2007. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/missing-package.wit.result +0 -0
  2008. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/multiple-package-docs/a.wit +0 -0
  2009. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/multiple-package-docs/b.wit +0 -0
  2010. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/multiple-package-docs.wit.result +0 -0
  2011. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/no-access-to-sibling-use/bar.wit +0 -0
  2012. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/no-access-to-sibling-use/foo.wit +0 -0
  2013. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +0 -0
  2014. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/non-existance-world-include/deps/bar/baz.wit +0 -0
  2015. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/non-existance-world-include/root.wit +0 -0
  2016. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/non-existance-world-include.wit.result +0 -0
  2017. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +0 -0
  2018. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/pkg-cycle/root.wit +0 -0
  2019. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/pkg-cycle.wit.result +0 -0
  2020. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +0 -0
  2021. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +0 -0
  2022. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/pkg-cycle2/root.wit +0 -0
  2023. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/pkg-cycle2.wit.result +0 -0
  2024. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/resources-multiple-returns-borrow.wit +0 -0
  2025. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/resources-multiple-returns-borrow.wit.result +0 -0
  2026. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/resources-return-borrow.wit +0 -0
  2027. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/resources-return-borrow.wit.result +0 -0
  2028. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow1.wit +0 -0
  2029. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow1.wit.result +0 -0
  2030. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow2.wit +0 -0
  2031. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow2.wit.result +0 -0
  2032. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow3.wit +0 -0
  2033. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow3.wit.result +0 -0
  2034. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow4.wit +0 -0
  2035. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow4.wit.result +0 -0
  2036. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow5.wit +0 -0
  2037. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow5.wit.result +0 -0
  2038. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow6.wit +0 -0
  2039. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow6.wit.result +0 -0
  2040. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow7.wit +0 -0
  2041. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow7.wit.result +0 -0
  2042. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow8/deps/baz.wit +0 -0
  2043. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow8/foo.wit +0 -0
  2044. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/return-borrow8.wit.result +0 -0
  2045. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/type-and-resource-same-name/deps/dep/foo.wit +0 -0
  2046. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/type-and-resource-same-name/foo.wit +0 -0
  2047. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/type-and-resource-same-name.wit.result +0 -0
  2048. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/undefined-typed.wit +0 -0
  2049. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/undefined-typed.wit.result +0 -0
  2050. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unknown-interface.wit +0 -0
  2051. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unknown-interface.wit.result +0 -0
  2052. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface1.wit +0 -0
  2053. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface1.wit.result +0 -0
  2054. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface2.wit +0 -0
  2055. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface2.wit.result +0 -0
  2056. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface3.wit +0 -0
  2057. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface3.wit.result +0 -0
  2058. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface4.wit +0 -0
  2059. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-interface4.wit.result +0 -0
  2060. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use1.wit +0 -0
  2061. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use1.wit.result +0 -0
  2062. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use10/bar.wit +0 -0
  2063. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use10/foo.wit +0 -0
  2064. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use10.wit.result +0 -0
  2065. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use2.wit +0 -0
  2066. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use2.wit.result +0 -0
  2067. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use3.wit +0 -0
  2068. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use3.wit.result +0 -0
  2069. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use7.wit +0 -0
  2070. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use7.wit.result +0 -0
  2071. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use8.wit +0 -0
  2072. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use8.wit.result +0 -0
  2073. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use9.wit +0 -0
  2074. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unresolved-use9.wit.result +0 -0
  2075. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/unterminated-string.wit.result +0 -0
  2076. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-and-include-world/deps/bar/baz.wit +0 -0
  2077. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-and-include-world/root.wit +0 -0
  2078. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-and-include-world.wit.result +0 -0
  2079. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-conflict.wit +0 -0
  2080. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-conflict.wit.result +0 -0
  2081. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-conflict2.wit +0 -0
  2082. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-conflict2.wit.result +0 -0
  2083. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-conflict3.wit +0 -0
  2084. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-conflict3.wit.result +0 -0
  2085. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-cycle1.wit +0 -0
  2086. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-cycle1.wit.result +0 -0
  2087. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-cycle4.wit +0 -0
  2088. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-cycle4.wit.result +0 -0
  2089. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-shadow1.wit +0 -0
  2090. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-shadow1.wit.result +0 -0
  2091. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-world/deps/bar/baz.wit +0 -0
  2092. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-world/root.wit +0 -0
  2093. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/use-world.wit.result +0 -0
  2094. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-interface-clash.wit +0 -0
  2095. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-interface-clash.wit.result +0 -0
  2096. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-same-fields2.wit +0 -0
  2097. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-same-fields2.wit.result +0 -0
  2098. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-same-fields3.wit +0 -0
  2099. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-same-fields3.wit.result +0 -0
  2100. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-top-level-func.wit +0 -0
  2101. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-top-level-func.wit.result +0 -0
  2102. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-top-level-func2.wit +0 -0
  2103. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/parse-fail/world-top-level-func2.wit.result +0 -0
  2104. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/random.wit +0 -0
  2105. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/random.wit.json +0 -0
  2106. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-empty.wit +0 -0
  2107. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-empty.wit.json +0 -0
  2108. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-multiple-returns-own.wit +0 -0
  2109. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-multiple-returns-own.wit.json +0 -0
  2110. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-multiple.wit +0 -0
  2111. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-multiple.wit.json +0 -0
  2112. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-return-own.wit +0 -0
  2113. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources-return-own.wit.json +0 -0
  2114. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources.wit +0 -0
  2115. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources.wit.json +0 -0
  2116. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources1.wit +0 -0
  2117. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/resources1.wit.json +0 -0
  2118. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/same-name-import-export.wit +0 -0
  2119. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/same-name-import-export.wit.json +0 -0
  2120. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/shared-types.wit +0 -0
  2121. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/shared-types.wit.json +0 -0
  2122. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/simple-wasm-text.wat +0 -0
  2123. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/simple-wasm-text.wit.json +0 -0
  2124. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/since-and-unstable.wit +0 -0
  2125. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/stress-export-elaborate.wit +0 -0
  2126. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/stress-export-elaborate.wit.json +0 -0
  2127. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/type-then-eof.wit +0 -0
  2128. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/type-then-eof.wit.json +0 -0
  2129. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/types.wit +0 -0
  2130. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/types.wit.json +0 -0
  2131. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/union-fuzz-1.wit +0 -0
  2132. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/union-fuzz-1.wit.json +0 -0
  2133. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/union-fuzz-2.wit +0 -0
  2134. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/union-fuzz-2.wit.json +0 -0
  2135. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/use-chain.wit +0 -0
  2136. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/use-chain.wit.json +0 -0
  2137. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/use.wit +0 -0
  2138. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/use.wit.json +0 -0
  2139. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/versions/deps/a1/foo.wit +0 -0
  2140. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/versions/deps/a2/foo.wit +0 -0
  2141. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/versions/foo.wit +0 -0
  2142. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/versions.wit.json +0 -0
  2143. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/wasi.wit +0 -0
  2144. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/wasi.wit.json +0 -0
  2145. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-diamond.wit +0 -0
  2146. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-diamond.wit.json +0 -0
  2147. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-iface-no-collide.wit +0 -0
  2148. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-iface-no-collide.wit.json +0 -0
  2149. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-implicit-import1.wit +0 -0
  2150. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-implicit-import1.wit.json +0 -0
  2151. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-implicit-import2.wit +0 -0
  2152. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-implicit-import2.wit.json +0 -0
  2153. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-implicit-import3.wit +0 -0
  2154. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-implicit-import3.wit.json +0 -0
  2155. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-same-fields4.wit +0 -0
  2156. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-same-fields4.wit.json +0 -0
  2157. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-top-level-funcs.wit +0 -0
  2158. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-top-level-funcs.wit.json +0 -0
  2159. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-top-level-resources.wit +0 -0
  2160. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/world-top-level-resources.wit.json +0 -0
  2161. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/worlds-union-dedup.wit +0 -0
  2162. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/worlds-union-dedup.wit.json +0 -0
  2163. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/worlds-with-types.wit +0 -0
  2164. /data/ext/cargo-vendor/{wit-parser-0.209.1 → wit-parser-0.212.0}/tests/ui/worlds-with-types.wit.json +0 -0
@@ -1,3695 +0,0 @@
1
- //! This module contains the bulk of the interesting code performing the translation between
2
- //! WebAssembly and Cranelift IR.
3
- //!
4
- //! The translation is done in one pass, opcode by opcode. Two main data structures are used during
5
- //! code translations: the value stack and the control stack. The value stack mimics the execution
6
- //! of the WebAssembly stack machine: each instruction result is pushed onto the stack and
7
- //! instruction arguments are popped off the stack. Similarly, when encountering a control flow
8
- //! block, it is pushed onto the control stack and popped off when encountering the corresponding
9
- //! `End`.
10
- //!
11
- //! Another data structure, the translation state, records information concerning unreachable code
12
- //! status and about if inserting a return at the end of the function is necessary.
13
- //!
14
- //! Some of the WebAssembly instructions need information about the environment for which they
15
- //! are being translated:
16
- //!
17
- //! - the loads and stores need the memory base address;
18
- //! - the `get_global` and `set_global` instructions depend on how the globals are implemented;
19
- //! - `memory.size` and `memory.grow` are runtime functions;
20
- //! - `call_indirect` has to translate the function index into the address of where this
21
- //! is;
22
- //!
23
- //! That is why `translate_function_body` takes an object having the `WasmRuntime` trait as
24
- //! argument.
25
- //!
26
- //! There is extra complexity associated with translation of 128-bit SIMD instructions.
27
- //! Wasm only considers there to be a single 128-bit vector type. But CLIF's type system
28
- //! distinguishes different lane configurations, so considers 8X16, 16X8, 32X4 and 64X2 to be
29
- //! different types. The result is that, in wasm, it's perfectly OK to take the output of (eg)
30
- //! an `add.16x8` and use that as an operand of a `sub.32x4`, without using any cast. But when
31
- //! translated into CLIF, that will cause a verifier error due to the apparent type mismatch.
32
- //!
33
- //! This file works around that problem by liberally inserting `bitcast` instructions in many
34
- //! places -- mostly, before the use of vector values, either as arguments to CLIF instructions
35
- //! or as block actual parameters. These are no-op casts which nevertheless have different
36
- //! input and output types, and are used (mostly) to "convert" 16X8, 32X4 and 64X2-typed vectors
37
- //! to the "canonical" type, 8X16. Hence the functions `optionally_bitcast_vector`,
38
- //! `bitcast_arguments`, `pop*_with_bitcast`, `canonicalise_then_jump`,
39
- //! `canonicalise_then_br{z,nz}`, `is_non_canonical_v128` and `canonicalise_v128_values`.
40
- //! Note that the `bitcast*` functions are occasionally used to convert to some type other than
41
- //! 8X16, but the `canonicalise*` functions always convert to type 8X16.
42
- //!
43
- //! Be careful when adding support for new vector instructions. And when adding new jumps, even
44
- //! if they are apparently don't have any connection to vectors. Never generate any kind of
45
- //! (inter-block) jump directly. Instead use `canonicalise_then_jump` and
46
- //! `canonicalise_then_br{z,nz}`.
47
- //!
48
- //! The use of bitcasts is ugly and inefficient, but currently unavoidable:
49
- //!
50
- //! * they make the logic in this file fragile: miss out a bitcast for any reason, and there is
51
- //! the risk of the system failing in the verifier. At least for debug builds.
52
- //!
53
- //! * in the new backends, they potentially interfere with pattern matching on CLIF -- the
54
- //! patterns need to take into account the presence of bitcast nodes.
55
- //!
56
- //! * in the new backends, they get translated into machine-level vector-register-copy
57
- //! instructions, none of which are actually necessary. We then depend on the register
58
- //! allocator to coalesce them all out.
59
- //!
60
- //! * they increase the total number of CLIF nodes that have to be processed, hence slowing down
61
- //! the compilation pipeline. Also, the extra coalescing work generates a slowdown.
62
- //!
63
- //! A better solution which would avoid all four problems would be to remove the 8X16, 16X8,
64
- //! 32X4 and 64X2 types from CLIF and instead have a single V128 type.
65
- //!
66
- //! For further background see also:
67
- //! <https://github.com/bytecodealliance/wasmtime/issues/1147>
68
- //! ("Too many raw_bitcasts in SIMD code")
69
- //! <https://github.com/bytecodealliance/cranelift/pull/1251>
70
- //! ("Add X128 type to represent WebAssembly's V128 type")
71
- //! <https://github.com/bytecodealliance/cranelift/pull/1236>
72
- //! ("Relax verification to allow I8X16 to act as a default vector type")
73
-
74
- mod bounds_checks;
75
-
76
- use super::{hash_map, HashMap};
77
- use crate::environ::{FuncEnvironment, GlobalVariable};
78
- use crate::state::{ControlStackFrame, ElseData, FuncTranslationState};
79
- use crate::translation_utils::{
80
- block_with_params, blocktype_params_results, f32_translation, f64_translation,
81
- };
82
- use crate::wasm_unsupported;
83
- use crate::{FuncIndex, GlobalIndex, MemoryIndex, TableIndex, TypeIndex, WasmResult};
84
- use core::{i32, u32};
85
- use cranelift_codegen::ir::condcodes::{FloatCC, IntCC};
86
- use cranelift_codegen::ir::immediates::Offset32;
87
- use cranelift_codegen::ir::types::*;
88
- use cranelift_codegen::ir::{
89
- self, AtomicRmwOp, ConstantData, InstBuilder, JumpTableData, MemFlags, Value, ValueLabel,
90
- };
91
- use cranelift_codegen::packed_option::ReservedValue;
92
- use cranelift_frontend::{FunctionBuilder, Variable};
93
- use itertools::Itertools;
94
- use smallvec::SmallVec;
95
- use std::vec::Vec;
96
- use wasmparser::{FuncValidator, MemArg, Operator, WasmModuleResources};
97
-
98
- /// Given a `Reachability<T>`, unwrap the inner `T` or, when unreachable, set
99
- /// `state.reachable = false` and return.
100
- ///
101
- /// Used in combination with calling `prepare_addr` and `prepare_atomic_addr`
102
- /// when we can statically determine that a Wasm access will unconditionally
103
- /// trap.
104
- macro_rules! unwrap_or_return_unreachable_state {
105
- ($state:ident, $value:expr) => {
106
- match $value {
107
- Reachability::Reachable(x) => x,
108
- Reachability::Unreachable => {
109
- $state.reachable = false;
110
- return Ok(());
111
- }
112
- }
113
- };
114
- }
115
-
116
- /// Translates wasm operators into Cranelift IR instructions.
117
- pub fn translate_operator<FE: FuncEnvironment + ?Sized>(
118
- validator: &mut FuncValidator<impl WasmModuleResources>,
119
- op: &Operator,
120
- builder: &mut FunctionBuilder,
121
- state: &mut FuncTranslationState,
122
- environ: &mut FE,
123
- ) -> WasmResult<()> {
124
- if !state.reachable {
125
- translate_unreachable_operator(validator, &op, builder, state, environ)?;
126
- return Ok(());
127
- }
128
-
129
- // Given that we believe the current block is reachable, the FunctionBuilder ought to agree.
130
- debug_assert!(!builder.is_unreachable());
131
-
132
- // This big match treats all Wasm code operators.
133
- match op {
134
- /********************************** Locals ****************************************
135
- * `get_local` and `set_local` are treated as non-SSA variables and will completely
136
- * disappear in the Cranelift Code
137
- ***********************************************************************************/
138
- Operator::LocalGet { local_index } => {
139
- let val = builder.use_var(Variable::from_u32(*local_index));
140
- state.push1(val);
141
- let label = ValueLabel::from_u32(*local_index);
142
- builder.set_val_label(val, label);
143
- }
144
- Operator::LocalSet { local_index } => {
145
- let mut val = state.pop1();
146
-
147
- // Ensure SIMD values are cast to their default Cranelift type, I8x16.
148
- let ty = builder.func.dfg.value_type(val);
149
- if ty.is_vector() {
150
- val = optionally_bitcast_vector(val, I8X16, builder);
151
- }
152
-
153
- builder.def_var(Variable::from_u32(*local_index), val);
154
- let label = ValueLabel::from_u32(*local_index);
155
- builder.set_val_label(val, label);
156
- }
157
- Operator::LocalTee { local_index } => {
158
- let mut val = state.peek1();
159
-
160
- // Ensure SIMD values are cast to their default Cranelift type, I8x16.
161
- let ty = builder.func.dfg.value_type(val);
162
- if ty.is_vector() {
163
- val = optionally_bitcast_vector(val, I8X16, builder);
164
- }
165
-
166
- builder.def_var(Variable::from_u32(*local_index), val);
167
- let label = ValueLabel::from_u32(*local_index);
168
- builder.set_val_label(val, label);
169
- }
170
- /********************************** Globals ****************************************
171
- * `get_global` and `set_global` are handled by the environment.
172
- ***********************************************************************************/
173
- Operator::GlobalGet { global_index } => {
174
- let val = match state.get_global(builder.func, *global_index, environ)? {
175
- GlobalVariable::Const(val) => val,
176
- GlobalVariable::Memory { gv, offset, ty } => {
177
- let addr = builder.ins().global_value(environ.pointer_type(), gv);
178
- let mut flags = ir::MemFlags::trusted();
179
- // Put globals in the "table" abstract heap category as well.
180
- flags.set_alias_region(Some(ir::AliasRegion::Table));
181
- builder.ins().load(ty, flags, addr, offset)
182
- }
183
- GlobalVariable::Custom => environ.translate_custom_global_get(
184
- builder.cursor(),
185
- GlobalIndex::from_u32(*global_index),
186
- )?,
187
- };
188
- state.push1(val);
189
- }
190
- Operator::GlobalSet { global_index } => {
191
- match state.get_global(builder.func, *global_index, environ)? {
192
- GlobalVariable::Const(_) => panic!("global #{} is a constant", *global_index),
193
- GlobalVariable::Memory { gv, offset, ty } => {
194
- let addr = builder.ins().global_value(environ.pointer_type(), gv);
195
- let mut flags = ir::MemFlags::trusted();
196
- // Put globals in the "table" abstract heap category as well.
197
- flags.set_alias_region(Some(ir::AliasRegion::Table));
198
- let mut val = state.pop1();
199
- // Ensure SIMD values are cast to their default Cranelift type, I8x16.
200
- if ty.is_vector() {
201
- val = optionally_bitcast_vector(val, I8X16, builder);
202
- }
203
- debug_assert_eq!(ty, builder.func.dfg.value_type(val));
204
- builder.ins().store(flags, val, addr, offset);
205
- environ.update_global(builder, *global_index, val);
206
- }
207
- GlobalVariable::Custom => {
208
- let val = state.pop1();
209
- environ.translate_custom_global_set(
210
- builder.cursor(),
211
- GlobalIndex::from_u32(*global_index),
212
- val,
213
- )?;
214
- }
215
- }
216
- }
217
- /********************************* Stack misc ***************************************
218
- * `drop`, `nop`, `unreachable` and `select`.
219
- ***********************************************************************************/
220
- Operator::Drop => {
221
- state.pop1();
222
- }
223
- Operator::Select => {
224
- let (mut arg1, mut arg2, cond) = state.pop3();
225
- if builder.func.dfg.value_type(arg1).is_vector() {
226
- arg1 = optionally_bitcast_vector(arg1, I8X16, builder);
227
- }
228
- if builder.func.dfg.value_type(arg2).is_vector() {
229
- arg2 = optionally_bitcast_vector(arg2, I8X16, builder);
230
- }
231
- state.push1(builder.ins().select(cond, arg1, arg2));
232
- }
233
- Operator::TypedSelect { ty: _ } => {
234
- // We ignore the explicit type parameter as it is only needed for
235
- // validation, which we require to have been performed before
236
- // translation.
237
- let (mut arg1, mut arg2, cond) = state.pop3();
238
- if builder.func.dfg.value_type(arg1).is_vector() {
239
- arg1 = optionally_bitcast_vector(arg1, I8X16, builder);
240
- }
241
- if builder.func.dfg.value_type(arg2).is_vector() {
242
- arg2 = optionally_bitcast_vector(arg2, I8X16, builder);
243
- }
244
- state.push1(builder.ins().select(cond, arg1, arg2));
245
- }
246
- Operator::Nop => {
247
- // We do nothing
248
- }
249
- Operator::Unreachable => {
250
- builder.ins().trap(ir::TrapCode::UnreachableCodeReached);
251
- state.reachable = false;
252
- }
253
- /***************************** Control flow blocks **********************************
254
- * When starting a control flow block, we create a new `Block` that will hold the code
255
- * after the block, and we push a frame on the control stack. Depending on the type
256
- * of block, we create a new `Block` for the body of the block with an associated
257
- * jump instruction.
258
- *
259
- * The `End` instruction pops the last control frame from the control stack, seals
260
- * the destination block (since `br` instructions targeting it only appear inside the
261
- * block and have already been translated) and modify the value stack to use the
262
- * possible `Block`'s arguments values.
263
- ***********************************************************************************/
264
- Operator::Block { blockty } => {
265
- let (params, results) = blocktype_params_results(validator, *blockty)?;
266
- let next = block_with_params(builder, results.clone(), environ)?;
267
- state.push_block(next, params.len(), results.len());
268
- }
269
- Operator::Loop { blockty } => {
270
- let (params, results) = blocktype_params_results(validator, *blockty)?;
271
- let loop_body = block_with_params(builder, params.clone(), environ)?;
272
- let next = block_with_params(builder, results.clone(), environ)?;
273
- canonicalise_then_jump(builder, loop_body, state.peekn(params.len()));
274
- state.push_loop(loop_body, next, params.len(), results.len());
275
-
276
- // Pop the initial `Block` actuals and replace them with the `Block`'s
277
- // params since control flow joins at the top of the loop.
278
- state.popn(params.len());
279
- state
280
- .stack
281
- .extend_from_slice(builder.block_params(loop_body));
282
-
283
- builder.switch_to_block(loop_body);
284
- environ.translate_loop_header(builder)?;
285
- }
286
- Operator::If { blockty } => {
287
- let val = state.pop1();
288
-
289
- let next_block = builder.create_block();
290
- let (params, results) = blocktype_params_results(validator, *blockty)?;
291
- let (destination, else_data) = if params.clone().eq(results.clone()) {
292
- // It is possible there is no `else` block, so we will only
293
- // allocate a block for it if/when we find the `else`. For now,
294
- // we if the condition isn't true, then we jump directly to the
295
- // destination block following the whole `if...end`. If we do end
296
- // up discovering an `else`, then we will allocate a block for it
297
- // and go back and patch the jump.
298
- let destination = block_with_params(builder, results.clone(), environ)?;
299
- let branch_inst = canonicalise_brif(
300
- builder,
301
- val,
302
- next_block,
303
- &[],
304
- destination,
305
- state.peekn(params.len()),
306
- );
307
- (
308
- destination,
309
- ElseData::NoElse {
310
- branch_inst,
311
- placeholder: destination,
312
- },
313
- )
314
- } else {
315
- // The `if` type signature is not valid without an `else` block,
316
- // so we eagerly allocate the `else` block here.
317
- let destination = block_with_params(builder, results.clone(), environ)?;
318
- let else_block = block_with_params(builder, params.clone(), environ)?;
319
- canonicalise_brif(
320
- builder,
321
- val,
322
- next_block,
323
- &[],
324
- else_block,
325
- state.peekn(params.len()),
326
- );
327
- builder.seal_block(else_block);
328
- (destination, ElseData::WithElse { else_block })
329
- };
330
-
331
- builder.seal_block(next_block); // Only predecessor is the current block.
332
- builder.switch_to_block(next_block);
333
-
334
- // Here we append an argument to a Block targeted by an argumentless jump instruction
335
- // But in fact there are two cases:
336
- // - either the If does not have a Else clause, in that case ty = EmptyBlock
337
- // and we add nothing;
338
- // - either the If have an Else clause, in that case the destination of this jump
339
- // instruction will be changed later when we translate the Else operator.
340
- state.push_if(
341
- destination,
342
- else_data,
343
- params.len(),
344
- results.len(),
345
- *blockty,
346
- );
347
- }
348
- Operator::Else => {
349
- let i = state.control_stack.len() - 1;
350
- match state.control_stack[i] {
351
- ControlStackFrame::If {
352
- ref else_data,
353
- head_is_reachable,
354
- ref mut consequent_ends_reachable,
355
- num_return_values,
356
- blocktype,
357
- destination,
358
- ..
359
- } => {
360
- // We finished the consequent, so record its final
361
- // reachability state.
362
- debug_assert!(consequent_ends_reachable.is_none());
363
- *consequent_ends_reachable = Some(state.reachable);
364
-
365
- if head_is_reachable {
366
- // We have a branch from the head of the `if` to the `else`.
367
- state.reachable = true;
368
-
369
- // Ensure we have a block for the `else` block (it may have
370
- // already been pre-allocated, see `ElseData` for details).
371
- let else_block = match *else_data {
372
- ElseData::NoElse {
373
- branch_inst,
374
- placeholder,
375
- } => {
376
- let (params, _results) =
377
- blocktype_params_results(validator, blocktype)?;
378
- debug_assert_eq!(params.len(), num_return_values);
379
- let else_block =
380
- block_with_params(builder, params.clone(), environ)?;
381
- canonicalise_then_jump(
382
- builder,
383
- destination,
384
- state.peekn(params.len()),
385
- );
386
- state.popn(params.len());
387
-
388
- builder.change_jump_destination(
389
- branch_inst,
390
- placeholder,
391
- else_block,
392
- );
393
- builder.seal_block(else_block);
394
- else_block
395
- }
396
- ElseData::WithElse { else_block } => {
397
- canonicalise_then_jump(
398
- builder,
399
- destination,
400
- state.peekn(num_return_values),
401
- );
402
- state.popn(num_return_values);
403
- else_block
404
- }
405
- };
406
-
407
- // You might be expecting that we push the parameters for this
408
- // `else` block here, something like this:
409
- //
410
- // state.pushn(&control_stack_frame.params);
411
- //
412
- // We don't do that because they are already on the top of the stack
413
- // for us: we pushed the parameters twice when we saw the initial
414
- // `if` so that we wouldn't have to save the parameters in the
415
- // `ControlStackFrame` as another `Vec` allocation.
416
-
417
- builder.switch_to_block(else_block);
418
-
419
- // We don't bother updating the control frame's `ElseData`
420
- // to `WithElse` because nothing else will read it.
421
- }
422
- }
423
- _ => unreachable!(),
424
- }
425
- }
426
- Operator::End => {
427
- let frame = state.control_stack.pop().unwrap();
428
- let next_block = frame.following_code();
429
- let return_count = frame.num_return_values();
430
- let return_args = state.peekn_mut(return_count);
431
-
432
- canonicalise_then_jump(builder, next_block, return_args);
433
- // You might expect that if we just finished an `if` block that
434
- // didn't have a corresponding `else` block, then we would clean
435
- // up our duplicate set of parameters that we pushed earlier
436
- // right here. However, we don't have to explicitly do that,
437
- // since we truncate the stack back to the original height
438
- // below.
439
-
440
- builder.switch_to_block(next_block);
441
- builder.seal_block(next_block);
442
-
443
- // If it is a loop we also have to seal the body loop block
444
- if let ControlStackFrame::Loop { header, .. } = frame {
445
- builder.seal_block(header)
446
- }
447
-
448
- frame.truncate_value_stack_to_original_size(&mut state.stack);
449
- state
450
- .stack
451
- .extend_from_slice(builder.block_params(next_block));
452
- }
453
- /**************************** Branch instructions *********************************
454
- * The branch instructions all have as arguments a target nesting level, which
455
- * corresponds to how many control stack frames do we have to pop to get the
456
- * destination `Block`.
457
- *
458
- * Once the destination `Block` is found, we sometimes have to declare a certain depth
459
- * of the stack unreachable, because some branch instructions are terminator.
460
- *
461
- * The `br_table` case is much more complicated because Cranelift's `br_table` instruction
462
- * does not support jump arguments like all the other branch instructions. That is why, in
463
- * the case where we would use jump arguments for every other branch instruction, we
464
- * need to split the critical edges leaving the `br_tables` by creating one `Block` per
465
- * table destination; the `br_table` will point to these newly created `Blocks` and these
466
- * `Block`s contain only a jump instruction pointing to the final destination, this time with
467
- * jump arguments.
468
- *
469
- * This system is also implemented in Cranelift's SSA construction algorithm, because
470
- * `use_var` located in a destination `Block` of a `br_table` might trigger the addition
471
- * of jump arguments in each predecessor branch instruction, one of which might be a
472
- * `br_table`.
473
- ***********************************************************************************/
474
- Operator::Br { relative_depth } => {
475
- let i = state.control_stack.len() - 1 - (*relative_depth as usize);
476
- let (return_count, br_destination) = {
477
- let frame = &mut state.control_stack[i];
478
- // We signal that all the code that follows until the next End is unreachable
479
- frame.set_branched_to_exit();
480
- let return_count = if frame.is_loop() {
481
- frame.num_param_values()
482
- } else {
483
- frame.num_return_values()
484
- };
485
- (return_count, frame.br_destination())
486
- };
487
- let destination_args = state.peekn_mut(return_count);
488
- canonicalise_then_jump(builder, br_destination, destination_args);
489
- state.popn(return_count);
490
- state.reachable = false;
491
- }
492
- Operator::BrIf { relative_depth } => translate_br_if(*relative_depth, builder, state),
493
- Operator::BrTable { targets } => {
494
- let default = targets.default();
495
- let mut min_depth = default;
496
- for depth in targets.targets() {
497
- let depth = depth?;
498
- if depth < min_depth {
499
- min_depth = depth;
500
- }
501
- }
502
- let jump_args_count = {
503
- let i = state.control_stack.len() - 1 - (min_depth as usize);
504
- let min_depth_frame = &state.control_stack[i];
505
- if min_depth_frame.is_loop() {
506
- min_depth_frame.num_param_values()
507
- } else {
508
- min_depth_frame.num_return_values()
509
- }
510
- };
511
- let val = state.pop1();
512
- let mut data = Vec::with_capacity(targets.len() as usize);
513
- if jump_args_count == 0 {
514
- // No jump arguments
515
- for depth in targets.targets() {
516
- let depth = depth?;
517
- let block = {
518
- let i = state.control_stack.len() - 1 - (depth as usize);
519
- let frame = &mut state.control_stack[i];
520
- frame.set_branched_to_exit();
521
- frame.br_destination()
522
- };
523
- data.push(builder.func.dfg.block_call(block, &[]));
524
- }
525
- let block = {
526
- let i = state.control_stack.len() - 1 - (default as usize);
527
- let frame = &mut state.control_stack[i];
528
- frame.set_branched_to_exit();
529
- frame.br_destination()
530
- };
531
- let block = builder.func.dfg.block_call(block, &[]);
532
- let jt = builder.create_jump_table(JumpTableData::new(block, &data));
533
- builder.ins().br_table(val, jt);
534
- } else {
535
- // Here we have jump arguments, but Cranelift's br_table doesn't support them
536
- // We then proceed to split the edges going out of the br_table
537
- let return_count = jump_args_count;
538
- let mut dest_block_sequence = vec![];
539
- let mut dest_block_map = HashMap::new();
540
- for depth in targets.targets() {
541
- let depth = depth?;
542
- let branch_block = match dest_block_map.entry(depth as usize) {
543
- hash_map::Entry::Occupied(entry) => *entry.get(),
544
- hash_map::Entry::Vacant(entry) => {
545
- let block = builder.create_block();
546
- dest_block_sequence.push((depth as usize, block));
547
- *entry.insert(block)
548
- }
549
- };
550
- data.push(builder.func.dfg.block_call(branch_block, &[]));
551
- }
552
- let default_branch_block = match dest_block_map.entry(default as usize) {
553
- hash_map::Entry::Occupied(entry) => *entry.get(),
554
- hash_map::Entry::Vacant(entry) => {
555
- let block = builder.create_block();
556
- dest_block_sequence.push((default as usize, block));
557
- *entry.insert(block)
558
- }
559
- };
560
- let default_branch_block = builder.func.dfg.block_call(default_branch_block, &[]);
561
- let jt = builder.create_jump_table(JumpTableData::new(default_branch_block, &data));
562
- builder.ins().br_table(val, jt);
563
- for (depth, dest_block) in dest_block_sequence {
564
- builder.switch_to_block(dest_block);
565
- builder.seal_block(dest_block);
566
- let real_dest_block = {
567
- let i = state.control_stack.len() - 1 - depth;
568
- let frame = &mut state.control_stack[i];
569
- frame.set_branched_to_exit();
570
- frame.br_destination()
571
- };
572
- let destination_args = state.peekn_mut(return_count);
573
- canonicalise_then_jump(builder, real_dest_block, destination_args);
574
- }
575
- state.popn(return_count);
576
- }
577
- state.reachable = false;
578
- }
579
- Operator::Return => {
580
- let return_count = {
581
- let frame = &mut state.control_stack[0];
582
- frame.num_return_values()
583
- };
584
- {
585
- let return_args = state.peekn_mut(return_count);
586
- environ.handle_before_return(&return_args, builder);
587
- bitcast_wasm_returns(environ, return_args, builder);
588
- builder.ins().return_(return_args);
589
- }
590
- state.popn(return_count);
591
- state.reachable = false;
592
- }
593
- /********************************** Exception handing **********************************/
594
- Operator::Try { .. }
595
- | Operator::Catch { .. }
596
- | Operator::Throw { .. }
597
- | Operator::Rethrow { .. }
598
- | Operator::Delegate { .. }
599
- | Operator::CatchAll => {
600
- return Err(wasm_unsupported!(
601
- "proposed exception handling operator {:?}",
602
- op
603
- ));
604
- }
605
- /************************************ Calls ****************************************
606
- * The call instructions pop off their arguments from the stack and append their
607
- * return values to it. `call_indirect` needs environment support because there is an
608
- * argument referring to an index in the external functions table of the module.
609
- ************************************************************************************/
610
- Operator::Call { function_index } => {
611
- let (fref, num_args) = state.get_direct_func(builder.func, *function_index, environ)?;
612
-
613
- // Bitcast any vector arguments to their default type, I8X16, before calling.
614
- let args = state.peekn_mut(num_args);
615
- bitcast_wasm_params(
616
- environ,
617
- builder.func.dfg.ext_funcs[fref].signature,
618
- args,
619
- builder,
620
- );
621
-
622
- let call = environ.translate_call(
623
- builder,
624
- FuncIndex::from_u32(*function_index),
625
- fref,
626
- args,
627
- )?;
628
- let inst_results = builder.inst_results(call);
629
- debug_assert_eq!(
630
- inst_results.len(),
631
- builder.func.dfg.signatures[builder.func.dfg.ext_funcs[fref].signature]
632
- .returns
633
- .len(),
634
- "translate_call results should match the call signature"
635
- );
636
- state.popn(num_args);
637
- state.pushn(inst_results);
638
- }
639
- Operator::CallIndirect {
640
- type_index,
641
- table_index,
642
- table_byte: _,
643
- } => {
644
- // `type_index` is the index of the function's signature and
645
- // `table_index` is the index of the table to search the function
646
- // in.
647
- let (sigref, num_args) = state.get_indirect_sig(builder.func, *type_index, environ)?;
648
- let callee = state.pop1();
649
-
650
- // Bitcast any vector arguments to their default type, I8X16, before calling.
651
- let args = state.peekn_mut(num_args);
652
- bitcast_wasm_params(environ, sigref, args, builder);
653
-
654
- let call = environ.translate_call_indirect(
655
- builder,
656
- TableIndex::from_u32(*table_index),
657
- TypeIndex::from_u32(*type_index),
658
- sigref,
659
- callee,
660
- state.peekn(num_args),
661
- )?;
662
- let call = match call {
663
- Some(call) => call,
664
- None => {
665
- state.reachable = false;
666
- return Ok(());
667
- }
668
- };
669
- let inst_results = builder.inst_results(call);
670
- debug_assert_eq!(
671
- inst_results.len(),
672
- builder.func.dfg.signatures[sigref].returns.len(),
673
- "translate_call_indirect results should match the call signature"
674
- );
675
- state.popn(num_args);
676
- state.pushn(inst_results);
677
- }
678
- /******************************* Tail Calls ******************************************
679
- * The tail call instructions pop their arguments from the stack and
680
- * then permanently transfer control to their callee. The indirect
681
- * version requires environment support (while the direct version can
682
- * optionally be hooked but doesn't require it) it interacts with the
683
- * VM's runtime state via tables.
684
- ************************************************************************************/
685
- Operator::ReturnCall { function_index } => {
686
- let (fref, num_args) = state.get_direct_func(builder.func, *function_index, environ)?;
687
-
688
- // Bitcast any vector arguments to their default type, I8X16, before calling.
689
- let args = state.peekn_mut(num_args);
690
- bitcast_wasm_params(
691
- environ,
692
- builder.func.dfg.ext_funcs[fref].signature,
693
- args,
694
- builder,
695
- );
696
-
697
- environ.translate_return_call(
698
- builder,
699
- FuncIndex::from_u32(*function_index),
700
- fref,
701
- args,
702
- )?;
703
-
704
- state.popn(num_args);
705
- state.reachable = false;
706
- }
707
- Operator::ReturnCallIndirect {
708
- type_index,
709
- table_index,
710
- } => {
711
- // `type_index` is the index of the function's signature and
712
- // `table_index` is the index of the table to search the function
713
- // in.
714
- let (sigref, num_args) = state.get_indirect_sig(builder.func, *type_index, environ)?;
715
- let callee = state.pop1();
716
-
717
- // Bitcast any vector arguments to their default type, I8X16, before calling.
718
- let args = state.peekn_mut(num_args);
719
- bitcast_wasm_params(environ, sigref, args, builder);
720
-
721
- environ.translate_return_call_indirect(
722
- builder,
723
- TableIndex::from_u32(*table_index),
724
- TypeIndex::from_u32(*type_index),
725
- sigref,
726
- callee,
727
- state.peekn(num_args),
728
- )?;
729
-
730
- state.popn(num_args);
731
- state.reachable = false;
732
- }
733
- Operator::ReturnCallRef { type_index } => {
734
- // Get function signature
735
- // `index` is the index of the function's signature and `table_index` is the index of
736
- // the table to search the function in.
737
- let (sigref, num_args) = state.get_indirect_sig(builder.func, *type_index, environ)?;
738
- let callee = state.pop1();
739
-
740
- // Bitcast any vector arguments to their default type, I8X16, before calling.
741
- let args = state.peekn_mut(num_args);
742
- bitcast_wasm_params(environ, sigref, args, builder);
743
-
744
- environ.translate_return_call_ref(builder, sigref, callee, state.peekn(num_args))?;
745
-
746
- state.popn(num_args);
747
- state.reachable = false;
748
- }
749
- /******************************* Memory management ***********************************
750
- * Memory management is handled by environment. It is usually translated into calls to
751
- * special functions.
752
- ************************************************************************************/
753
- Operator::MemoryGrow { mem, mem_byte: _ } => {
754
- // The WebAssembly MVP only supports one linear memory, but we expect the reserved
755
- // argument to be a memory index.
756
- let heap_index = MemoryIndex::from_u32(*mem);
757
- let heap = state.get_heap(builder.func, *mem, environ)?;
758
- let val = state.pop1();
759
- environ.before_memory_grow(builder, val, heap_index);
760
- state.push1(environ.translate_memory_grow(builder.cursor(), heap_index, heap, val)?)
761
- }
762
- Operator::MemorySize { mem, mem_byte: _ } => {
763
- let heap_index = MemoryIndex::from_u32(*mem);
764
- let heap = state.get_heap(builder.func, *mem, environ)?;
765
- state.push1(environ.translate_memory_size(builder.cursor(), heap_index, heap)?);
766
- }
767
- /******************************* Load instructions ***********************************
768
- * Wasm specifies an integer alignment flag but we drop it in Cranelift.
769
- * The memory base address is provided by the environment.
770
- ************************************************************************************/
771
- Operator::I32Load8U { memarg } => {
772
- unwrap_or_return_unreachable_state!(
773
- state,
774
- translate_load(memarg, ir::Opcode::Uload8, I32, builder, state, environ)?
775
- );
776
- }
777
- Operator::I32Load16U { memarg } => {
778
- unwrap_or_return_unreachable_state!(
779
- state,
780
- translate_load(memarg, ir::Opcode::Uload16, I32, builder, state, environ)?
781
- );
782
- }
783
- Operator::I32Load8S { memarg } => {
784
- unwrap_or_return_unreachable_state!(
785
- state,
786
- translate_load(memarg, ir::Opcode::Sload8, I32, builder, state, environ)?
787
- );
788
- }
789
- Operator::I32Load16S { memarg } => {
790
- unwrap_or_return_unreachable_state!(
791
- state,
792
- translate_load(memarg, ir::Opcode::Sload16, I32, builder, state, environ)?
793
- );
794
- }
795
- Operator::I64Load8U { memarg } => {
796
- unwrap_or_return_unreachable_state!(
797
- state,
798
- translate_load(memarg, ir::Opcode::Uload8, I64, builder, state, environ)?
799
- );
800
- }
801
- Operator::I64Load16U { memarg } => {
802
- unwrap_or_return_unreachable_state!(
803
- state,
804
- translate_load(memarg, ir::Opcode::Uload16, I64, builder, state, environ)?
805
- );
806
- }
807
- Operator::I64Load8S { memarg } => {
808
- unwrap_or_return_unreachable_state!(
809
- state,
810
- translate_load(memarg, ir::Opcode::Sload8, I64, builder, state, environ)?
811
- );
812
- }
813
- Operator::I64Load16S { memarg } => {
814
- unwrap_or_return_unreachable_state!(
815
- state,
816
- translate_load(memarg, ir::Opcode::Sload16, I64, builder, state, environ)?
817
- );
818
- }
819
- Operator::I64Load32S { memarg } => {
820
- unwrap_or_return_unreachable_state!(
821
- state,
822
- translate_load(memarg, ir::Opcode::Sload32, I64, builder, state, environ)?
823
- );
824
- }
825
- Operator::I64Load32U { memarg } => {
826
- unwrap_or_return_unreachable_state!(
827
- state,
828
- translate_load(memarg, ir::Opcode::Uload32, I64, builder, state, environ)?
829
- );
830
- }
831
- Operator::I32Load { memarg } => {
832
- unwrap_or_return_unreachable_state!(
833
- state,
834
- translate_load(memarg, ir::Opcode::Load, I32, builder, state, environ)?
835
- );
836
- }
837
- Operator::F32Load { memarg } => {
838
- unwrap_or_return_unreachable_state!(
839
- state,
840
- translate_load(memarg, ir::Opcode::Load, F32, builder, state, environ)?
841
- );
842
- }
843
- Operator::I64Load { memarg } => {
844
- unwrap_or_return_unreachable_state!(
845
- state,
846
- translate_load(memarg, ir::Opcode::Load, I64, builder, state, environ)?
847
- );
848
- }
849
- Operator::F64Load { memarg } => {
850
- unwrap_or_return_unreachable_state!(
851
- state,
852
- translate_load(memarg, ir::Opcode::Load, F64, builder, state, environ)?
853
- );
854
- }
855
- Operator::V128Load { memarg } => {
856
- unwrap_or_return_unreachable_state!(
857
- state,
858
- translate_load(memarg, ir::Opcode::Load, I8X16, builder, state, environ)?
859
- );
860
- }
861
- Operator::V128Load8x8S { memarg } => {
862
- //TODO(#6829): add before_load() and before_store() hooks for SIMD loads and stores.
863
- let (flags, _, base) = unwrap_or_return_unreachable_state!(
864
- state,
865
- prepare_addr(memarg, 8, builder, state, environ)?
866
- );
867
- let loaded = builder.ins().sload8x8(flags, base, 0);
868
- state.push1(loaded);
869
- }
870
- Operator::V128Load8x8U { memarg } => {
871
- let (flags, _, base) = unwrap_or_return_unreachable_state!(
872
- state,
873
- prepare_addr(memarg, 8, builder, state, environ)?
874
- );
875
- let loaded = builder.ins().uload8x8(flags, base, 0);
876
- state.push1(loaded);
877
- }
878
- Operator::V128Load16x4S { memarg } => {
879
- let (flags, _, base) = unwrap_or_return_unreachable_state!(
880
- state,
881
- prepare_addr(memarg, 8, builder, state, environ)?
882
- );
883
- let loaded = builder.ins().sload16x4(flags, base, 0);
884
- state.push1(loaded);
885
- }
886
- Operator::V128Load16x4U { memarg } => {
887
- let (flags, _, base) = unwrap_or_return_unreachable_state!(
888
- state,
889
- prepare_addr(memarg, 8, builder, state, environ)?
890
- );
891
- let loaded = builder.ins().uload16x4(flags, base, 0);
892
- state.push1(loaded);
893
- }
894
- Operator::V128Load32x2S { memarg } => {
895
- let (flags, _, base) = unwrap_or_return_unreachable_state!(
896
- state,
897
- prepare_addr(memarg, 8, builder, state, environ)?
898
- );
899
- let loaded = builder.ins().sload32x2(flags, base, 0);
900
- state.push1(loaded);
901
- }
902
- Operator::V128Load32x2U { memarg } => {
903
- let (flags, _, base) = unwrap_or_return_unreachable_state!(
904
- state,
905
- prepare_addr(memarg, 8, builder, state, environ)?
906
- );
907
- let loaded = builder.ins().uload32x2(flags, base, 0);
908
- state.push1(loaded);
909
- }
910
- /****************************** Store instructions ***********************************
911
- * Wasm specifies an integer alignment flag but we drop it in Cranelift.
912
- * The memory base address is provided by the environment.
913
- ************************************************************************************/
914
- Operator::I32Store { memarg }
915
- | Operator::I64Store { memarg }
916
- | Operator::F32Store { memarg }
917
- | Operator::F64Store { memarg } => {
918
- translate_store(memarg, ir::Opcode::Store, builder, state, environ)?;
919
- }
920
- Operator::I32Store8 { memarg } | Operator::I64Store8 { memarg } => {
921
- translate_store(memarg, ir::Opcode::Istore8, builder, state, environ)?;
922
- }
923
- Operator::I32Store16 { memarg } | Operator::I64Store16 { memarg } => {
924
- translate_store(memarg, ir::Opcode::Istore16, builder, state, environ)?;
925
- }
926
- Operator::I64Store32 { memarg } => {
927
- translate_store(memarg, ir::Opcode::Istore32, builder, state, environ)?;
928
- }
929
- Operator::V128Store { memarg } => {
930
- translate_store(memarg, ir::Opcode::Store, builder, state, environ)?;
931
- }
932
- /****************************** Nullary Operators ************************************/
933
- Operator::I32Const { value } => {
934
- state.push1(builder.ins().iconst(I32, *value as u32 as i64))
935
- }
936
- Operator::I64Const { value } => state.push1(builder.ins().iconst(I64, *value)),
937
- Operator::F32Const { value } => {
938
- state.push1(builder.ins().f32const(f32_translation(*value)));
939
- }
940
- Operator::F64Const { value } => {
941
- state.push1(builder.ins().f64const(f64_translation(*value)));
942
- }
943
- /******************************* Unary Operators *************************************/
944
- Operator::I32Clz | Operator::I64Clz => {
945
- let arg = state.pop1();
946
- state.push1(builder.ins().clz(arg));
947
- }
948
- Operator::I32Ctz | Operator::I64Ctz => {
949
- let arg = state.pop1();
950
- state.push1(builder.ins().ctz(arg));
951
- }
952
- Operator::I32Popcnt | Operator::I64Popcnt => {
953
- let arg = state.pop1();
954
- state.push1(builder.ins().popcnt(arg));
955
- }
956
- Operator::I64ExtendI32S => {
957
- let val = state.pop1();
958
- state.push1(builder.ins().sextend(I64, val));
959
- }
960
- Operator::I64ExtendI32U => {
961
- let val = state.pop1();
962
- state.push1(builder.ins().uextend(I64, val));
963
- }
964
- Operator::I32WrapI64 => {
965
- let val = state.pop1();
966
- state.push1(builder.ins().ireduce(I32, val));
967
- }
968
- Operator::F32Sqrt | Operator::F64Sqrt => {
969
- let arg = state.pop1();
970
- state.push1(builder.ins().sqrt(arg));
971
- }
972
- Operator::F32Ceil | Operator::F64Ceil => {
973
- let arg = state.pop1();
974
- state.push1(builder.ins().ceil(arg));
975
- }
976
- Operator::F32Floor | Operator::F64Floor => {
977
- let arg = state.pop1();
978
- state.push1(builder.ins().floor(arg));
979
- }
980
- Operator::F32Trunc | Operator::F64Trunc => {
981
- let arg = state.pop1();
982
- state.push1(builder.ins().trunc(arg));
983
- }
984
- Operator::F32Nearest | Operator::F64Nearest => {
985
- let arg = state.pop1();
986
- state.push1(builder.ins().nearest(arg));
987
- }
988
- Operator::F32Abs | Operator::F64Abs => {
989
- let val = state.pop1();
990
- state.push1(builder.ins().fabs(val));
991
- }
992
- Operator::F32Neg | Operator::F64Neg => {
993
- let arg = state.pop1();
994
- state.push1(builder.ins().fneg(arg));
995
- }
996
- Operator::F64ConvertI64U | Operator::F64ConvertI32U => {
997
- let val = state.pop1();
998
- state.push1(builder.ins().fcvt_from_uint(F64, val));
999
- }
1000
- Operator::F64ConvertI64S | Operator::F64ConvertI32S => {
1001
- let val = state.pop1();
1002
- state.push1(builder.ins().fcvt_from_sint(F64, val));
1003
- }
1004
- Operator::F32ConvertI64S | Operator::F32ConvertI32S => {
1005
- let val = state.pop1();
1006
- state.push1(builder.ins().fcvt_from_sint(F32, val));
1007
- }
1008
- Operator::F32ConvertI64U | Operator::F32ConvertI32U => {
1009
- let val = state.pop1();
1010
- state.push1(builder.ins().fcvt_from_uint(F32, val));
1011
- }
1012
- Operator::F64PromoteF32 => {
1013
- let val = state.pop1();
1014
- state.push1(builder.ins().fpromote(F64, val));
1015
- }
1016
- Operator::F32DemoteF64 => {
1017
- let val = state.pop1();
1018
- state.push1(builder.ins().fdemote(F32, val));
1019
- }
1020
- Operator::I64TruncF64S | Operator::I64TruncF32S => {
1021
- let val = state.pop1();
1022
- state.push1(builder.ins().fcvt_to_sint(I64, val));
1023
- }
1024
- Operator::I32TruncF64S | Operator::I32TruncF32S => {
1025
- let val = state.pop1();
1026
- state.push1(builder.ins().fcvt_to_sint(I32, val));
1027
- }
1028
- Operator::I64TruncF64U | Operator::I64TruncF32U => {
1029
- let val = state.pop1();
1030
- state.push1(builder.ins().fcvt_to_uint(I64, val));
1031
- }
1032
- Operator::I32TruncF64U | Operator::I32TruncF32U => {
1033
- let val = state.pop1();
1034
- state.push1(builder.ins().fcvt_to_uint(I32, val));
1035
- }
1036
- Operator::I64TruncSatF64S | Operator::I64TruncSatF32S => {
1037
- let val = state.pop1();
1038
- state.push1(builder.ins().fcvt_to_sint_sat(I64, val));
1039
- }
1040
- Operator::I32TruncSatF64S | Operator::I32TruncSatF32S => {
1041
- let val = state.pop1();
1042
- state.push1(builder.ins().fcvt_to_sint_sat(I32, val));
1043
- }
1044
- Operator::I64TruncSatF64U | Operator::I64TruncSatF32U => {
1045
- let val = state.pop1();
1046
- state.push1(builder.ins().fcvt_to_uint_sat(I64, val));
1047
- }
1048
- Operator::I32TruncSatF64U | Operator::I32TruncSatF32U => {
1049
- let val = state.pop1();
1050
- state.push1(builder.ins().fcvt_to_uint_sat(I32, val));
1051
- }
1052
- Operator::F32ReinterpretI32 => {
1053
- let val = state.pop1();
1054
- state.push1(builder.ins().bitcast(F32, MemFlags::new(), val));
1055
- }
1056
- Operator::F64ReinterpretI64 => {
1057
- let val = state.pop1();
1058
- state.push1(builder.ins().bitcast(F64, MemFlags::new(), val));
1059
- }
1060
- Operator::I32ReinterpretF32 => {
1061
- let val = state.pop1();
1062
- state.push1(builder.ins().bitcast(I32, MemFlags::new(), val));
1063
- }
1064
- Operator::I64ReinterpretF64 => {
1065
- let val = state.pop1();
1066
- state.push1(builder.ins().bitcast(I64, MemFlags::new(), val));
1067
- }
1068
- Operator::I32Extend8S => {
1069
- let val = state.pop1();
1070
- state.push1(builder.ins().ireduce(I8, val));
1071
- let val = state.pop1();
1072
- state.push1(builder.ins().sextend(I32, val));
1073
- }
1074
- Operator::I32Extend16S => {
1075
- let val = state.pop1();
1076
- state.push1(builder.ins().ireduce(I16, val));
1077
- let val = state.pop1();
1078
- state.push1(builder.ins().sextend(I32, val));
1079
- }
1080
- Operator::I64Extend8S => {
1081
- let val = state.pop1();
1082
- state.push1(builder.ins().ireduce(I8, val));
1083
- let val = state.pop1();
1084
- state.push1(builder.ins().sextend(I64, val));
1085
- }
1086
- Operator::I64Extend16S => {
1087
- let val = state.pop1();
1088
- state.push1(builder.ins().ireduce(I16, val));
1089
- let val = state.pop1();
1090
- state.push1(builder.ins().sextend(I64, val));
1091
- }
1092
- Operator::I64Extend32S => {
1093
- let val = state.pop1();
1094
- state.push1(builder.ins().ireduce(I32, val));
1095
- let val = state.pop1();
1096
- state.push1(builder.ins().sextend(I64, val));
1097
- }
1098
- /****************************** Binary Operators ************************************/
1099
- Operator::I32Add | Operator::I64Add => {
1100
- let (arg1, arg2) = state.pop2();
1101
- state.push1(builder.ins().iadd(arg1, arg2));
1102
- }
1103
- Operator::I32And | Operator::I64And => {
1104
- let (arg1, arg2) = state.pop2();
1105
- state.push1(builder.ins().band(arg1, arg2));
1106
- }
1107
- Operator::I32Or | Operator::I64Or => {
1108
- let (arg1, arg2) = state.pop2();
1109
- state.push1(builder.ins().bor(arg1, arg2));
1110
- }
1111
- Operator::I32Xor | Operator::I64Xor => {
1112
- let (arg1, arg2) = state.pop2();
1113
- state.push1(builder.ins().bxor(arg1, arg2));
1114
- }
1115
- Operator::I32Shl | Operator::I64Shl => {
1116
- let (arg1, arg2) = state.pop2();
1117
- state.push1(builder.ins().ishl(arg1, arg2));
1118
- }
1119
- Operator::I32ShrS | Operator::I64ShrS => {
1120
- let (arg1, arg2) = state.pop2();
1121
- state.push1(builder.ins().sshr(arg1, arg2));
1122
- }
1123
- Operator::I32ShrU | Operator::I64ShrU => {
1124
- let (arg1, arg2) = state.pop2();
1125
- state.push1(builder.ins().ushr(arg1, arg2));
1126
- }
1127
- Operator::I32Rotl | Operator::I64Rotl => {
1128
- let (arg1, arg2) = state.pop2();
1129
- state.push1(builder.ins().rotl(arg1, arg2));
1130
- }
1131
- Operator::I32Rotr | Operator::I64Rotr => {
1132
- let (arg1, arg2) = state.pop2();
1133
- state.push1(builder.ins().rotr(arg1, arg2));
1134
- }
1135
- Operator::F32Add | Operator::F64Add => {
1136
- let (arg1, arg2) = state.pop2();
1137
- state.push1(builder.ins().fadd(arg1, arg2));
1138
- }
1139
- Operator::I32Sub | Operator::I64Sub => {
1140
- let (arg1, arg2) = state.pop2();
1141
- state.push1(builder.ins().isub(arg1, arg2));
1142
- }
1143
- Operator::F32Sub | Operator::F64Sub => {
1144
- let (arg1, arg2) = state.pop2();
1145
- state.push1(builder.ins().fsub(arg1, arg2));
1146
- }
1147
- Operator::I32Mul | Operator::I64Mul => {
1148
- let (arg1, arg2) = state.pop2();
1149
- state.push1(builder.ins().imul(arg1, arg2));
1150
- }
1151
- Operator::F32Mul | Operator::F64Mul => {
1152
- let (arg1, arg2) = state.pop2();
1153
- state.push1(builder.ins().fmul(arg1, arg2));
1154
- }
1155
- Operator::F32Div | Operator::F64Div => {
1156
- let (arg1, arg2) = state.pop2();
1157
- state.push1(builder.ins().fdiv(arg1, arg2));
1158
- }
1159
- Operator::I32DivS | Operator::I64DivS => {
1160
- let (arg1, arg2) = state.pop2();
1161
- state.push1(builder.ins().sdiv(arg1, arg2));
1162
- }
1163
- Operator::I32DivU | Operator::I64DivU => {
1164
- let (arg1, arg2) = state.pop2();
1165
- state.push1(builder.ins().udiv(arg1, arg2));
1166
- }
1167
- Operator::I32RemS | Operator::I64RemS => {
1168
- let (arg1, arg2) = state.pop2();
1169
- state.push1(builder.ins().srem(arg1, arg2));
1170
- }
1171
- Operator::I32RemU | Operator::I64RemU => {
1172
- let (arg1, arg2) = state.pop2();
1173
- state.push1(builder.ins().urem(arg1, arg2));
1174
- }
1175
- Operator::F32Min | Operator::F64Min => {
1176
- let (arg1, arg2) = state.pop2();
1177
- state.push1(builder.ins().fmin(arg1, arg2));
1178
- }
1179
- Operator::F32Max | Operator::F64Max => {
1180
- let (arg1, arg2) = state.pop2();
1181
- state.push1(builder.ins().fmax(arg1, arg2));
1182
- }
1183
- Operator::F32Copysign | Operator::F64Copysign => {
1184
- let (arg1, arg2) = state.pop2();
1185
- state.push1(builder.ins().fcopysign(arg1, arg2));
1186
- }
1187
- /**************************** Comparison Operators **********************************/
1188
- Operator::I32LtS | Operator::I64LtS => {
1189
- translate_icmp(IntCC::SignedLessThan, builder, state)
1190
- }
1191
- Operator::I32LtU | Operator::I64LtU => {
1192
- translate_icmp(IntCC::UnsignedLessThan, builder, state)
1193
- }
1194
- Operator::I32LeS | Operator::I64LeS => {
1195
- translate_icmp(IntCC::SignedLessThanOrEqual, builder, state)
1196
- }
1197
- Operator::I32LeU | Operator::I64LeU => {
1198
- translate_icmp(IntCC::UnsignedLessThanOrEqual, builder, state)
1199
- }
1200
- Operator::I32GtS | Operator::I64GtS => {
1201
- translate_icmp(IntCC::SignedGreaterThan, builder, state)
1202
- }
1203
- Operator::I32GtU | Operator::I64GtU => {
1204
- translate_icmp(IntCC::UnsignedGreaterThan, builder, state)
1205
- }
1206
- Operator::I32GeS | Operator::I64GeS => {
1207
- translate_icmp(IntCC::SignedGreaterThanOrEqual, builder, state)
1208
- }
1209
- Operator::I32GeU | Operator::I64GeU => {
1210
- translate_icmp(IntCC::UnsignedGreaterThanOrEqual, builder, state)
1211
- }
1212
- Operator::I32Eqz | Operator::I64Eqz => {
1213
- let arg = state.pop1();
1214
- let val = builder.ins().icmp_imm(IntCC::Equal, arg, 0);
1215
- state.push1(builder.ins().uextend(I32, val));
1216
- }
1217
- Operator::I32Eq | Operator::I64Eq => translate_icmp(IntCC::Equal, builder, state),
1218
- Operator::F32Eq | Operator::F64Eq => translate_fcmp(FloatCC::Equal, builder, state),
1219
- Operator::I32Ne | Operator::I64Ne => translate_icmp(IntCC::NotEqual, builder, state),
1220
- Operator::F32Ne | Operator::F64Ne => translate_fcmp(FloatCC::NotEqual, builder, state),
1221
- Operator::F32Gt | Operator::F64Gt => translate_fcmp(FloatCC::GreaterThan, builder, state),
1222
- Operator::F32Ge | Operator::F64Ge => {
1223
- translate_fcmp(FloatCC::GreaterThanOrEqual, builder, state)
1224
- }
1225
- Operator::F32Lt | Operator::F64Lt => translate_fcmp(FloatCC::LessThan, builder, state),
1226
- Operator::F32Le | Operator::F64Le => {
1227
- translate_fcmp(FloatCC::LessThanOrEqual, builder, state)
1228
- }
1229
- Operator::RefNull { hty } => {
1230
- let hty = environ.convert_heap_type(*hty);
1231
- state.push1(environ.translate_ref_null(builder.cursor(), hty)?)
1232
- }
1233
- Operator::RefIsNull => {
1234
- let value = state.pop1();
1235
- state.push1(environ.translate_ref_is_null(builder.cursor(), value)?);
1236
- }
1237
- Operator::RefFunc { function_index } => {
1238
- let index = FuncIndex::from_u32(*function_index);
1239
- state.push1(environ.translate_ref_func(builder.cursor(), index)?);
1240
- }
1241
- Operator::MemoryAtomicWait32 { memarg } | Operator::MemoryAtomicWait64 { memarg } => {
1242
- // The WebAssembly MVP only supports one linear memory and
1243
- // wasmparser will ensure that the memory indices specified are
1244
- // zero.
1245
- let implied_ty = match op {
1246
- Operator::MemoryAtomicWait64 { .. } => I64,
1247
- Operator::MemoryAtomicWait32 { .. } => I32,
1248
- _ => unreachable!(),
1249
- };
1250
- let heap_index = MemoryIndex::from_u32(memarg.memory);
1251
- let heap = state.get_heap(builder.func, memarg.memory, environ)?;
1252
- let timeout = state.pop1(); // 64 (fixed)
1253
- let expected = state.pop1(); // 32 or 64 (per the `Ixx` in `IxxAtomicWait`)
1254
- assert!(builder.func.dfg.value_type(expected) == implied_ty);
1255
- let addr = state.pop1();
1256
- let effective_addr = if memarg.offset == 0 {
1257
- addr
1258
- } else {
1259
- let index_type = environ.heaps()[heap].index_type;
1260
- let offset = builder.ins().iconst(index_type, memarg.offset as i64);
1261
- builder
1262
- .ins()
1263
- .uadd_overflow_trap(addr, offset, ir::TrapCode::HeapOutOfBounds)
1264
- };
1265
- // `fn translate_atomic_wait` can inspect the type of `expected` to figure out what
1266
- // code it needs to generate, if it wants.
1267
- let res = environ.translate_atomic_wait(
1268
- builder.cursor(),
1269
- heap_index,
1270
- heap,
1271
- effective_addr,
1272
- expected,
1273
- timeout,
1274
- )?;
1275
- state.push1(res);
1276
- }
1277
- Operator::MemoryAtomicNotify { memarg } => {
1278
- let heap_index = MemoryIndex::from_u32(memarg.memory);
1279
- let heap = state.get_heap(builder.func, memarg.memory, environ)?;
1280
- let count = state.pop1(); // 32 (fixed)
1281
- let addr = state.pop1();
1282
- let effective_addr = if memarg.offset == 0 {
1283
- addr
1284
- } else {
1285
- let index_type = environ.heaps()[heap].index_type;
1286
- let offset = builder.ins().iconst(index_type, memarg.offset as i64);
1287
- builder
1288
- .ins()
1289
- .uadd_overflow_trap(addr, offset, ir::TrapCode::HeapOutOfBounds)
1290
- };
1291
- let res = environ.translate_atomic_notify(
1292
- builder.cursor(),
1293
- heap_index,
1294
- heap,
1295
- effective_addr,
1296
- count,
1297
- )?;
1298
- state.push1(res);
1299
- }
1300
- Operator::I32AtomicLoad { memarg } => {
1301
- translate_atomic_load(I32, I32, memarg, builder, state, environ)?
1302
- }
1303
- Operator::I64AtomicLoad { memarg } => {
1304
- translate_atomic_load(I64, I64, memarg, builder, state, environ)?
1305
- }
1306
- Operator::I32AtomicLoad8U { memarg } => {
1307
- translate_atomic_load(I32, I8, memarg, builder, state, environ)?
1308
- }
1309
- Operator::I32AtomicLoad16U { memarg } => {
1310
- translate_atomic_load(I32, I16, memarg, builder, state, environ)?
1311
- }
1312
- Operator::I64AtomicLoad8U { memarg } => {
1313
- translate_atomic_load(I64, I8, memarg, builder, state, environ)?
1314
- }
1315
- Operator::I64AtomicLoad16U { memarg } => {
1316
- translate_atomic_load(I64, I16, memarg, builder, state, environ)?
1317
- }
1318
- Operator::I64AtomicLoad32U { memarg } => {
1319
- translate_atomic_load(I64, I32, memarg, builder, state, environ)?
1320
- }
1321
-
1322
- Operator::I32AtomicStore { memarg } => {
1323
- translate_atomic_store(I32, memarg, builder, state, environ)?
1324
- }
1325
- Operator::I64AtomicStore { memarg } => {
1326
- translate_atomic_store(I64, memarg, builder, state, environ)?
1327
- }
1328
- Operator::I32AtomicStore8 { memarg } => {
1329
- translate_atomic_store(I8, memarg, builder, state, environ)?
1330
- }
1331
- Operator::I32AtomicStore16 { memarg } => {
1332
- translate_atomic_store(I16, memarg, builder, state, environ)?
1333
- }
1334
- Operator::I64AtomicStore8 { memarg } => {
1335
- translate_atomic_store(I8, memarg, builder, state, environ)?
1336
- }
1337
- Operator::I64AtomicStore16 { memarg } => {
1338
- translate_atomic_store(I16, memarg, builder, state, environ)?
1339
- }
1340
- Operator::I64AtomicStore32 { memarg } => {
1341
- translate_atomic_store(I32, memarg, builder, state, environ)?
1342
- }
1343
-
1344
- Operator::I32AtomicRmwAdd { memarg } => {
1345
- translate_atomic_rmw(I32, I32, AtomicRmwOp::Add, memarg, builder, state, environ)?
1346
- }
1347
- Operator::I64AtomicRmwAdd { memarg } => {
1348
- translate_atomic_rmw(I64, I64, AtomicRmwOp::Add, memarg, builder, state, environ)?
1349
- }
1350
- Operator::I32AtomicRmw8AddU { memarg } => {
1351
- translate_atomic_rmw(I32, I8, AtomicRmwOp::Add, memarg, builder, state, environ)?
1352
- }
1353
- Operator::I32AtomicRmw16AddU { memarg } => {
1354
- translate_atomic_rmw(I32, I16, AtomicRmwOp::Add, memarg, builder, state, environ)?
1355
- }
1356
- Operator::I64AtomicRmw8AddU { memarg } => {
1357
- translate_atomic_rmw(I64, I8, AtomicRmwOp::Add, memarg, builder, state, environ)?
1358
- }
1359
- Operator::I64AtomicRmw16AddU { memarg } => {
1360
- translate_atomic_rmw(I64, I16, AtomicRmwOp::Add, memarg, builder, state, environ)?
1361
- }
1362
- Operator::I64AtomicRmw32AddU { memarg } => {
1363
- translate_atomic_rmw(I64, I32, AtomicRmwOp::Add, memarg, builder, state, environ)?
1364
- }
1365
-
1366
- Operator::I32AtomicRmwSub { memarg } => {
1367
- translate_atomic_rmw(I32, I32, AtomicRmwOp::Sub, memarg, builder, state, environ)?
1368
- }
1369
- Operator::I64AtomicRmwSub { memarg } => {
1370
- translate_atomic_rmw(I64, I64, AtomicRmwOp::Sub, memarg, builder, state, environ)?
1371
- }
1372
- Operator::I32AtomicRmw8SubU { memarg } => {
1373
- translate_atomic_rmw(I32, I8, AtomicRmwOp::Sub, memarg, builder, state, environ)?
1374
- }
1375
- Operator::I32AtomicRmw16SubU { memarg } => {
1376
- translate_atomic_rmw(I32, I16, AtomicRmwOp::Sub, memarg, builder, state, environ)?
1377
- }
1378
- Operator::I64AtomicRmw8SubU { memarg } => {
1379
- translate_atomic_rmw(I64, I8, AtomicRmwOp::Sub, memarg, builder, state, environ)?
1380
- }
1381
- Operator::I64AtomicRmw16SubU { memarg } => {
1382
- translate_atomic_rmw(I64, I16, AtomicRmwOp::Sub, memarg, builder, state, environ)?
1383
- }
1384
- Operator::I64AtomicRmw32SubU { memarg } => {
1385
- translate_atomic_rmw(I64, I32, AtomicRmwOp::Sub, memarg, builder, state, environ)?
1386
- }
1387
-
1388
- Operator::I32AtomicRmwAnd { memarg } => {
1389
- translate_atomic_rmw(I32, I32, AtomicRmwOp::And, memarg, builder, state, environ)?
1390
- }
1391
- Operator::I64AtomicRmwAnd { memarg } => {
1392
- translate_atomic_rmw(I64, I64, AtomicRmwOp::And, memarg, builder, state, environ)?
1393
- }
1394
- Operator::I32AtomicRmw8AndU { memarg } => {
1395
- translate_atomic_rmw(I32, I8, AtomicRmwOp::And, memarg, builder, state, environ)?
1396
- }
1397
- Operator::I32AtomicRmw16AndU { memarg } => {
1398
- translate_atomic_rmw(I32, I16, AtomicRmwOp::And, memarg, builder, state, environ)?
1399
- }
1400
- Operator::I64AtomicRmw8AndU { memarg } => {
1401
- translate_atomic_rmw(I64, I8, AtomicRmwOp::And, memarg, builder, state, environ)?
1402
- }
1403
- Operator::I64AtomicRmw16AndU { memarg } => {
1404
- translate_atomic_rmw(I64, I16, AtomicRmwOp::And, memarg, builder, state, environ)?
1405
- }
1406
- Operator::I64AtomicRmw32AndU { memarg } => {
1407
- translate_atomic_rmw(I64, I32, AtomicRmwOp::And, memarg, builder, state, environ)?
1408
- }
1409
-
1410
- Operator::I32AtomicRmwOr { memarg } => {
1411
- translate_atomic_rmw(I32, I32, AtomicRmwOp::Or, memarg, builder, state, environ)?
1412
- }
1413
- Operator::I64AtomicRmwOr { memarg } => {
1414
- translate_atomic_rmw(I64, I64, AtomicRmwOp::Or, memarg, builder, state, environ)?
1415
- }
1416
- Operator::I32AtomicRmw8OrU { memarg } => {
1417
- translate_atomic_rmw(I32, I8, AtomicRmwOp::Or, memarg, builder, state, environ)?
1418
- }
1419
- Operator::I32AtomicRmw16OrU { memarg } => {
1420
- translate_atomic_rmw(I32, I16, AtomicRmwOp::Or, memarg, builder, state, environ)?
1421
- }
1422
- Operator::I64AtomicRmw8OrU { memarg } => {
1423
- translate_atomic_rmw(I64, I8, AtomicRmwOp::Or, memarg, builder, state, environ)?
1424
- }
1425
- Operator::I64AtomicRmw16OrU { memarg } => {
1426
- translate_atomic_rmw(I64, I16, AtomicRmwOp::Or, memarg, builder, state, environ)?
1427
- }
1428
- Operator::I64AtomicRmw32OrU { memarg } => {
1429
- translate_atomic_rmw(I64, I32, AtomicRmwOp::Or, memarg, builder, state, environ)?
1430
- }
1431
-
1432
- Operator::I32AtomicRmwXor { memarg } => {
1433
- translate_atomic_rmw(I32, I32, AtomicRmwOp::Xor, memarg, builder, state, environ)?
1434
- }
1435
- Operator::I64AtomicRmwXor { memarg } => {
1436
- translate_atomic_rmw(I64, I64, AtomicRmwOp::Xor, memarg, builder, state, environ)?
1437
- }
1438
- Operator::I32AtomicRmw8XorU { memarg } => {
1439
- translate_atomic_rmw(I32, I8, AtomicRmwOp::Xor, memarg, builder, state, environ)?
1440
- }
1441
- Operator::I32AtomicRmw16XorU { memarg } => {
1442
- translate_atomic_rmw(I32, I16, AtomicRmwOp::Xor, memarg, builder, state, environ)?
1443
- }
1444
- Operator::I64AtomicRmw8XorU { memarg } => {
1445
- translate_atomic_rmw(I64, I8, AtomicRmwOp::Xor, memarg, builder, state, environ)?
1446
- }
1447
- Operator::I64AtomicRmw16XorU { memarg } => {
1448
- translate_atomic_rmw(I64, I16, AtomicRmwOp::Xor, memarg, builder, state, environ)?
1449
- }
1450
- Operator::I64AtomicRmw32XorU { memarg } => {
1451
- translate_atomic_rmw(I64, I32, AtomicRmwOp::Xor, memarg, builder, state, environ)?
1452
- }
1453
-
1454
- Operator::I32AtomicRmwXchg { memarg } => {
1455
- translate_atomic_rmw(I32, I32, AtomicRmwOp::Xchg, memarg, builder, state, environ)?
1456
- }
1457
- Operator::I64AtomicRmwXchg { memarg } => {
1458
- translate_atomic_rmw(I64, I64, AtomicRmwOp::Xchg, memarg, builder, state, environ)?
1459
- }
1460
- Operator::I32AtomicRmw8XchgU { memarg } => {
1461
- translate_atomic_rmw(I32, I8, AtomicRmwOp::Xchg, memarg, builder, state, environ)?
1462
- }
1463
- Operator::I32AtomicRmw16XchgU { memarg } => {
1464
- translate_atomic_rmw(I32, I16, AtomicRmwOp::Xchg, memarg, builder, state, environ)?
1465
- }
1466
- Operator::I64AtomicRmw8XchgU { memarg } => {
1467
- translate_atomic_rmw(I64, I8, AtomicRmwOp::Xchg, memarg, builder, state, environ)?
1468
- }
1469
- Operator::I64AtomicRmw16XchgU { memarg } => {
1470
- translate_atomic_rmw(I64, I16, AtomicRmwOp::Xchg, memarg, builder, state, environ)?
1471
- }
1472
- Operator::I64AtomicRmw32XchgU { memarg } => {
1473
- translate_atomic_rmw(I64, I32, AtomicRmwOp::Xchg, memarg, builder, state, environ)?
1474
- }
1475
-
1476
- Operator::I32AtomicRmwCmpxchg { memarg } => {
1477
- translate_atomic_cas(I32, I32, memarg, builder, state, environ)?
1478
- }
1479
- Operator::I64AtomicRmwCmpxchg { memarg } => {
1480
- translate_atomic_cas(I64, I64, memarg, builder, state, environ)?
1481
- }
1482
- Operator::I32AtomicRmw8CmpxchgU { memarg } => {
1483
- translate_atomic_cas(I32, I8, memarg, builder, state, environ)?
1484
- }
1485
- Operator::I32AtomicRmw16CmpxchgU { memarg } => {
1486
- translate_atomic_cas(I32, I16, memarg, builder, state, environ)?
1487
- }
1488
- Operator::I64AtomicRmw8CmpxchgU { memarg } => {
1489
- translate_atomic_cas(I64, I8, memarg, builder, state, environ)?
1490
- }
1491
- Operator::I64AtomicRmw16CmpxchgU { memarg } => {
1492
- translate_atomic_cas(I64, I16, memarg, builder, state, environ)?
1493
- }
1494
- Operator::I64AtomicRmw32CmpxchgU { memarg } => {
1495
- translate_atomic_cas(I64, I32, memarg, builder, state, environ)?
1496
- }
1497
-
1498
- Operator::AtomicFence { .. } => {
1499
- builder.ins().fence();
1500
- }
1501
- Operator::MemoryCopy { src_mem, dst_mem } => {
1502
- let src_index = MemoryIndex::from_u32(*src_mem);
1503
- let dst_index = MemoryIndex::from_u32(*dst_mem);
1504
- let src_heap = state.get_heap(builder.func, *src_mem, environ)?;
1505
- let dst_heap = state.get_heap(builder.func, *dst_mem, environ)?;
1506
- let len = state.pop1();
1507
- let src_pos = state.pop1();
1508
- let dst_pos = state.pop1();
1509
- environ.translate_memory_copy(
1510
- builder.cursor(),
1511
- src_index,
1512
- src_heap,
1513
- dst_index,
1514
- dst_heap,
1515
- dst_pos,
1516
- src_pos,
1517
- len,
1518
- )?;
1519
- }
1520
- Operator::MemoryFill { mem } => {
1521
- let heap_index = MemoryIndex::from_u32(*mem);
1522
- let heap = state.get_heap(builder.func, *mem, environ)?;
1523
- let len = state.pop1();
1524
- let val = state.pop1();
1525
- let dest = state.pop1();
1526
- environ.translate_memory_fill(builder.cursor(), heap_index, heap, dest, val, len)?;
1527
- }
1528
- Operator::MemoryInit { data_index, mem } => {
1529
- let heap_index = MemoryIndex::from_u32(*mem);
1530
- let heap = state.get_heap(builder.func, *mem, environ)?;
1531
- let len = state.pop1();
1532
- let src = state.pop1();
1533
- let dest = state.pop1();
1534
- environ.translate_memory_init(
1535
- builder.cursor(),
1536
- heap_index,
1537
- heap,
1538
- *data_index,
1539
- dest,
1540
- src,
1541
- len,
1542
- )?;
1543
- }
1544
- Operator::DataDrop { data_index } => {
1545
- environ.translate_data_drop(builder.cursor(), *data_index)?;
1546
- }
1547
- Operator::TableSize { table: index } => {
1548
- state.push1(
1549
- environ.translate_table_size(builder.cursor(), TableIndex::from_u32(*index))?,
1550
- );
1551
- }
1552
- Operator::TableGrow { table: index } => {
1553
- let table_index = TableIndex::from_u32(*index);
1554
- let delta = state.pop1();
1555
- let init_value = state.pop1();
1556
- state.push1(environ.translate_table_grow(
1557
- builder.cursor(),
1558
- table_index,
1559
- delta,
1560
- init_value,
1561
- )?);
1562
- }
1563
- Operator::TableGet { table: index } => {
1564
- let table_index = TableIndex::from_u32(*index);
1565
- let index = state.pop1();
1566
- state.push1(environ.translate_table_get(builder, table_index, index)?);
1567
- }
1568
- Operator::TableSet { table: index } => {
1569
- let table_index = TableIndex::from_u32(*index);
1570
- let value = state.pop1();
1571
- let index = state.pop1();
1572
- environ.translate_table_set(builder, table_index, value, index)?;
1573
- }
1574
- Operator::TableCopy {
1575
- dst_table: dst_table_index,
1576
- src_table: src_table_index,
1577
- } => {
1578
- let len = state.pop1();
1579
- let src = state.pop1();
1580
- let dest = state.pop1();
1581
- environ.translate_table_copy(
1582
- builder.cursor(),
1583
- TableIndex::from_u32(*dst_table_index),
1584
- TableIndex::from_u32(*src_table_index),
1585
- dest,
1586
- src,
1587
- len,
1588
- )?;
1589
- }
1590
- Operator::TableFill { table } => {
1591
- let table_index = TableIndex::from_u32(*table);
1592
- let len = state.pop1();
1593
- let val = state.pop1();
1594
- let dest = state.pop1();
1595
- environ.translate_table_fill(builder.cursor(), table_index, dest, val, len)?;
1596
- }
1597
- Operator::TableInit {
1598
- elem_index,
1599
- table: table_index,
1600
- } => {
1601
- let len = state.pop1();
1602
- let src = state.pop1();
1603
- let dest = state.pop1();
1604
- environ.translate_table_init(
1605
- builder.cursor(),
1606
- *elem_index,
1607
- TableIndex::from_u32(*table_index),
1608
- dest,
1609
- src,
1610
- len,
1611
- )?;
1612
- }
1613
- Operator::ElemDrop { elem_index } => {
1614
- environ.translate_elem_drop(builder.cursor(), *elem_index)?;
1615
- }
1616
- Operator::V128Const { value } => {
1617
- let data = value.bytes().to_vec().into();
1618
- let handle = builder.func.dfg.constants.insert(data);
1619
- let value = builder.ins().vconst(I8X16, handle);
1620
- // the v128.const is typed in CLIF as a I8x16 but bitcast to a different type
1621
- // before use
1622
- state.push1(value)
1623
- }
1624
- Operator::I8x16Splat | Operator::I16x8Splat => {
1625
- let reduced = builder.ins().ireduce(type_of(op).lane_type(), state.pop1());
1626
- let splatted = builder.ins().splat(type_of(op), reduced);
1627
- state.push1(splatted)
1628
- }
1629
- Operator::I32x4Splat
1630
- | Operator::I64x2Splat
1631
- | Operator::F32x4Splat
1632
- | Operator::F64x2Splat => {
1633
- let splatted = builder.ins().splat(type_of(op), state.pop1());
1634
- state.push1(splatted)
1635
- }
1636
- Operator::V128Load8Splat { memarg }
1637
- | Operator::V128Load16Splat { memarg }
1638
- | Operator::V128Load32Splat { memarg }
1639
- | Operator::V128Load64Splat { memarg } => {
1640
- unwrap_or_return_unreachable_state!(
1641
- state,
1642
- translate_load(
1643
- memarg,
1644
- ir::Opcode::Load,
1645
- type_of(op).lane_type(),
1646
- builder,
1647
- state,
1648
- environ,
1649
- )?
1650
- );
1651
- let splatted = builder.ins().splat(type_of(op), state.pop1());
1652
- state.push1(splatted)
1653
- }
1654
- Operator::V128Load32Zero { memarg } | Operator::V128Load64Zero { memarg } => {
1655
- unwrap_or_return_unreachable_state!(
1656
- state,
1657
- translate_load(
1658
- memarg,
1659
- ir::Opcode::Load,
1660
- type_of(op).lane_type(),
1661
- builder,
1662
- state,
1663
- environ,
1664
- )?
1665
- );
1666
- let as_vector = builder.ins().scalar_to_vector(type_of(op), state.pop1());
1667
- state.push1(as_vector)
1668
- }
1669
- Operator::V128Load8Lane { memarg, lane }
1670
- | Operator::V128Load16Lane { memarg, lane }
1671
- | Operator::V128Load32Lane { memarg, lane }
1672
- | Operator::V128Load64Lane { memarg, lane } => {
1673
- let vector = pop1_with_bitcast(state, type_of(op), builder);
1674
- unwrap_or_return_unreachable_state!(
1675
- state,
1676
- translate_load(
1677
- memarg,
1678
- ir::Opcode::Load,
1679
- type_of(op).lane_type(),
1680
- builder,
1681
- state,
1682
- environ,
1683
- )?
1684
- );
1685
- let replacement = state.pop1();
1686
- state.push1(builder.ins().insertlane(vector, replacement, *lane))
1687
- }
1688
- Operator::V128Store8Lane { memarg, lane }
1689
- | Operator::V128Store16Lane { memarg, lane }
1690
- | Operator::V128Store32Lane { memarg, lane }
1691
- | Operator::V128Store64Lane { memarg, lane } => {
1692
- let vector = pop1_with_bitcast(state, type_of(op), builder);
1693
- state.push1(builder.ins().extractlane(vector, lane.clone()));
1694
- translate_store(memarg, ir::Opcode::Store, builder, state, environ)?;
1695
- }
1696
- Operator::I8x16ExtractLaneS { lane } | Operator::I16x8ExtractLaneS { lane } => {
1697
- let vector = pop1_with_bitcast(state, type_of(op), builder);
1698
- let extracted = builder.ins().extractlane(vector, lane.clone());
1699
- state.push1(builder.ins().sextend(I32, extracted))
1700
- }
1701
- Operator::I8x16ExtractLaneU { lane } | Operator::I16x8ExtractLaneU { lane } => {
1702
- let vector = pop1_with_bitcast(state, type_of(op), builder);
1703
- let extracted = builder.ins().extractlane(vector, lane.clone());
1704
- state.push1(builder.ins().uextend(I32, extracted));
1705
- // On x86, PEXTRB zeroes the upper bits of the destination register of extractlane so
1706
- // uextend could be elided; for now, uextend is needed for Cranelift's type checks to
1707
- // work.
1708
- }
1709
- Operator::I32x4ExtractLane { lane }
1710
- | Operator::I64x2ExtractLane { lane }
1711
- | Operator::F32x4ExtractLane { lane }
1712
- | Operator::F64x2ExtractLane { lane } => {
1713
- let vector = pop1_with_bitcast(state, type_of(op), builder);
1714
- state.push1(builder.ins().extractlane(vector, lane.clone()))
1715
- }
1716
- Operator::I8x16ReplaceLane { lane } | Operator::I16x8ReplaceLane { lane } => {
1717
- let (vector, replacement) = state.pop2();
1718
- let ty = type_of(op);
1719
- let reduced = builder.ins().ireduce(ty.lane_type(), replacement);
1720
- let vector = optionally_bitcast_vector(vector, ty, builder);
1721
- state.push1(builder.ins().insertlane(vector, reduced, *lane))
1722
- }
1723
- Operator::I32x4ReplaceLane { lane }
1724
- | Operator::I64x2ReplaceLane { lane }
1725
- | Operator::F32x4ReplaceLane { lane }
1726
- | Operator::F64x2ReplaceLane { lane } => {
1727
- let (vector, replacement) = state.pop2();
1728
- let vector = optionally_bitcast_vector(vector, type_of(op), builder);
1729
- state.push1(builder.ins().insertlane(vector, replacement, *lane))
1730
- }
1731
- Operator::I8x16Shuffle { lanes, .. } => {
1732
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
1733
- let lanes = ConstantData::from(lanes.as_ref());
1734
- let mask = builder.func.dfg.immediates.push(lanes);
1735
- let shuffled = builder.ins().shuffle(a, b, mask);
1736
- state.push1(shuffled)
1737
- // At this point the original types of a and b are lost; users of this value (i.e. this
1738
- // WASM-to-CLIF translator) may need to bitcast for type-correctness. This is due
1739
- // to WASM using the less specific v128 type for certain operations and more specific
1740
- // types (e.g. i8x16) for others.
1741
- }
1742
- Operator::I8x16Swizzle => {
1743
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
1744
- state.push1(builder.ins().swizzle(a, b))
1745
- }
1746
- Operator::I8x16Add | Operator::I16x8Add | Operator::I32x4Add | Operator::I64x2Add => {
1747
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1748
- state.push1(builder.ins().iadd(a, b))
1749
- }
1750
- Operator::I8x16AddSatS | Operator::I16x8AddSatS => {
1751
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1752
- state.push1(builder.ins().sadd_sat(a, b))
1753
- }
1754
- Operator::I8x16AddSatU | Operator::I16x8AddSatU => {
1755
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1756
- state.push1(builder.ins().uadd_sat(a, b))
1757
- }
1758
- Operator::I8x16Sub | Operator::I16x8Sub | Operator::I32x4Sub | Operator::I64x2Sub => {
1759
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1760
- state.push1(builder.ins().isub(a, b))
1761
- }
1762
- Operator::I8x16SubSatS | Operator::I16x8SubSatS => {
1763
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1764
- state.push1(builder.ins().ssub_sat(a, b))
1765
- }
1766
- Operator::I8x16SubSatU | Operator::I16x8SubSatU => {
1767
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1768
- state.push1(builder.ins().usub_sat(a, b))
1769
- }
1770
- Operator::I8x16MinS | Operator::I16x8MinS | Operator::I32x4MinS => {
1771
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1772
- state.push1(builder.ins().smin(a, b))
1773
- }
1774
- Operator::I8x16MinU | Operator::I16x8MinU | Operator::I32x4MinU => {
1775
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1776
- state.push1(builder.ins().umin(a, b))
1777
- }
1778
- Operator::I8x16MaxS | Operator::I16x8MaxS | Operator::I32x4MaxS => {
1779
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1780
- state.push1(builder.ins().smax(a, b))
1781
- }
1782
- Operator::I8x16MaxU | Operator::I16x8MaxU | Operator::I32x4MaxU => {
1783
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1784
- state.push1(builder.ins().umax(a, b))
1785
- }
1786
- Operator::I8x16AvgrU | Operator::I16x8AvgrU => {
1787
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1788
- state.push1(builder.ins().avg_round(a, b))
1789
- }
1790
- Operator::I8x16Neg | Operator::I16x8Neg | Operator::I32x4Neg | Operator::I64x2Neg => {
1791
- let a = pop1_with_bitcast(state, type_of(op), builder);
1792
- state.push1(builder.ins().ineg(a))
1793
- }
1794
- Operator::I8x16Abs | Operator::I16x8Abs | Operator::I32x4Abs | Operator::I64x2Abs => {
1795
- let a = pop1_with_bitcast(state, type_of(op), builder);
1796
- state.push1(builder.ins().iabs(a))
1797
- }
1798
- Operator::I16x8Mul | Operator::I32x4Mul | Operator::I64x2Mul => {
1799
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1800
- state.push1(builder.ins().imul(a, b))
1801
- }
1802
- Operator::V128Or => {
1803
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1804
- state.push1(builder.ins().bor(a, b))
1805
- }
1806
- Operator::V128Xor => {
1807
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1808
- state.push1(builder.ins().bxor(a, b))
1809
- }
1810
- Operator::V128And => {
1811
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1812
- state.push1(builder.ins().band(a, b))
1813
- }
1814
- Operator::V128AndNot => {
1815
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1816
- state.push1(builder.ins().band_not(a, b))
1817
- }
1818
- Operator::V128Not => {
1819
- let a = state.pop1();
1820
- state.push1(builder.ins().bnot(a));
1821
- }
1822
- Operator::I8x16Shl | Operator::I16x8Shl | Operator::I32x4Shl | Operator::I64x2Shl => {
1823
- let (a, b) = state.pop2();
1824
- let bitcast_a = optionally_bitcast_vector(a, type_of(op), builder);
1825
- // The spec expects to shift with `b mod lanewidth`; This is directly compatible
1826
- // with cranelift's instruction.
1827
- state.push1(builder.ins().ishl(bitcast_a, b))
1828
- }
1829
- Operator::I8x16ShrU | Operator::I16x8ShrU | Operator::I32x4ShrU | Operator::I64x2ShrU => {
1830
- let (a, b) = state.pop2();
1831
- let bitcast_a = optionally_bitcast_vector(a, type_of(op), builder);
1832
- // The spec expects to shift with `b mod lanewidth`; This is directly compatible
1833
- // with cranelift's instruction.
1834
- state.push1(builder.ins().ushr(bitcast_a, b))
1835
- }
1836
- Operator::I8x16ShrS | Operator::I16x8ShrS | Operator::I32x4ShrS | Operator::I64x2ShrS => {
1837
- let (a, b) = state.pop2();
1838
- let bitcast_a = optionally_bitcast_vector(a, type_of(op), builder);
1839
- // The spec expects to shift with `b mod lanewidth`; This is directly compatible
1840
- // with cranelift's instruction.
1841
- state.push1(builder.ins().sshr(bitcast_a, b))
1842
- }
1843
- Operator::V128Bitselect => {
1844
- let (a, b, c) = pop3_with_bitcast(state, I8X16, builder);
1845
- // The CLIF operand ordering is slightly different and the types of all three
1846
- // operands must match (hence the bitcast).
1847
- state.push1(builder.ins().bitselect(c, a, b))
1848
- }
1849
- Operator::V128AnyTrue => {
1850
- let a = pop1_with_bitcast(state, type_of(op), builder);
1851
- let bool_result = builder.ins().vany_true(a);
1852
- state.push1(builder.ins().uextend(I32, bool_result))
1853
- }
1854
- Operator::I8x16AllTrue
1855
- | Operator::I16x8AllTrue
1856
- | Operator::I32x4AllTrue
1857
- | Operator::I64x2AllTrue => {
1858
- let a = pop1_with_bitcast(state, type_of(op), builder);
1859
- let bool_result = builder.ins().vall_true(a);
1860
- state.push1(builder.ins().uextend(I32, bool_result))
1861
- }
1862
- Operator::I8x16Bitmask
1863
- | Operator::I16x8Bitmask
1864
- | Operator::I32x4Bitmask
1865
- | Operator::I64x2Bitmask => {
1866
- let a = pop1_with_bitcast(state, type_of(op), builder);
1867
- state.push1(builder.ins().vhigh_bits(I32, a));
1868
- }
1869
- Operator::I8x16Eq | Operator::I16x8Eq | Operator::I32x4Eq | Operator::I64x2Eq => {
1870
- translate_vector_icmp(IntCC::Equal, type_of(op), builder, state)
1871
- }
1872
- Operator::I8x16Ne | Operator::I16x8Ne | Operator::I32x4Ne | Operator::I64x2Ne => {
1873
- translate_vector_icmp(IntCC::NotEqual, type_of(op), builder, state)
1874
- }
1875
- Operator::I8x16GtS | Operator::I16x8GtS | Operator::I32x4GtS | Operator::I64x2GtS => {
1876
- translate_vector_icmp(IntCC::SignedGreaterThan, type_of(op), builder, state)
1877
- }
1878
- Operator::I8x16LtS | Operator::I16x8LtS | Operator::I32x4LtS | Operator::I64x2LtS => {
1879
- translate_vector_icmp(IntCC::SignedLessThan, type_of(op), builder, state)
1880
- }
1881
- Operator::I8x16GtU | Operator::I16x8GtU | Operator::I32x4GtU => {
1882
- translate_vector_icmp(IntCC::UnsignedGreaterThan, type_of(op), builder, state)
1883
- }
1884
- Operator::I8x16LtU | Operator::I16x8LtU | Operator::I32x4LtU => {
1885
- translate_vector_icmp(IntCC::UnsignedLessThan, type_of(op), builder, state)
1886
- }
1887
- Operator::I8x16GeS | Operator::I16x8GeS | Operator::I32x4GeS | Operator::I64x2GeS => {
1888
- translate_vector_icmp(IntCC::SignedGreaterThanOrEqual, type_of(op), builder, state)
1889
- }
1890
- Operator::I8x16LeS | Operator::I16x8LeS | Operator::I32x4LeS | Operator::I64x2LeS => {
1891
- translate_vector_icmp(IntCC::SignedLessThanOrEqual, type_of(op), builder, state)
1892
- }
1893
- Operator::I8x16GeU | Operator::I16x8GeU | Operator::I32x4GeU => translate_vector_icmp(
1894
- IntCC::UnsignedGreaterThanOrEqual,
1895
- type_of(op),
1896
- builder,
1897
- state,
1898
- ),
1899
- Operator::I8x16LeU | Operator::I16x8LeU | Operator::I32x4LeU => {
1900
- translate_vector_icmp(IntCC::UnsignedLessThanOrEqual, type_of(op), builder, state)
1901
- }
1902
- Operator::F32x4Eq | Operator::F64x2Eq => {
1903
- translate_vector_fcmp(FloatCC::Equal, type_of(op), builder, state)
1904
- }
1905
- Operator::F32x4Ne | Operator::F64x2Ne => {
1906
- translate_vector_fcmp(FloatCC::NotEqual, type_of(op), builder, state)
1907
- }
1908
- Operator::F32x4Lt | Operator::F64x2Lt => {
1909
- translate_vector_fcmp(FloatCC::LessThan, type_of(op), builder, state)
1910
- }
1911
- Operator::F32x4Gt | Operator::F64x2Gt => {
1912
- translate_vector_fcmp(FloatCC::GreaterThan, type_of(op), builder, state)
1913
- }
1914
- Operator::F32x4Le | Operator::F64x2Le => {
1915
- translate_vector_fcmp(FloatCC::LessThanOrEqual, type_of(op), builder, state)
1916
- }
1917
- Operator::F32x4Ge | Operator::F64x2Ge => {
1918
- translate_vector_fcmp(FloatCC::GreaterThanOrEqual, type_of(op), builder, state)
1919
- }
1920
- Operator::F32x4Add | Operator::F64x2Add => {
1921
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1922
- state.push1(builder.ins().fadd(a, b))
1923
- }
1924
- Operator::F32x4Sub | Operator::F64x2Sub => {
1925
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1926
- state.push1(builder.ins().fsub(a, b))
1927
- }
1928
- Operator::F32x4Mul | Operator::F64x2Mul => {
1929
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1930
- state.push1(builder.ins().fmul(a, b))
1931
- }
1932
- Operator::F32x4Div | Operator::F64x2Div => {
1933
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1934
- state.push1(builder.ins().fdiv(a, b))
1935
- }
1936
- Operator::F32x4Max | Operator::F64x2Max => {
1937
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1938
- state.push1(builder.ins().fmax(a, b))
1939
- }
1940
- Operator::F32x4Min | Operator::F64x2Min => {
1941
- let (a, b) = pop2_with_bitcast(state, type_of(op), builder);
1942
- state.push1(builder.ins().fmin(a, b))
1943
- }
1944
- Operator::F32x4PMax | Operator::F64x2PMax => {
1945
- // Note the careful ordering here with respect to `fcmp` and
1946
- // `bitselect`. This matches the spec definition of:
1947
- //
1948
- // fpmax(z1, z2) =
1949
- // * If z1 is less than z2 then return z2.
1950
- // * Else return z1.
1951
- let ty = type_of(op);
1952
- let (a, b) = pop2_with_bitcast(state, ty, builder);
1953
- let cmp = builder.ins().fcmp(FloatCC::LessThan, a, b);
1954
- let cmp = optionally_bitcast_vector(cmp, ty, builder);
1955
- state.push1(builder.ins().bitselect(cmp, b, a))
1956
- }
1957
- Operator::F32x4PMin | Operator::F64x2PMin => {
1958
- // Note the careful ordering here which is similar to `pmax` above:
1959
- //
1960
- // fpmin(z1, z2) =
1961
- // * If z2 is less than z1 then return z2.
1962
- // * Else return z1.
1963
- let ty = type_of(op);
1964
- let (a, b) = pop2_with_bitcast(state, ty, builder);
1965
- let cmp = builder.ins().fcmp(FloatCC::LessThan, b, a);
1966
- let cmp = optionally_bitcast_vector(cmp, ty, builder);
1967
- state.push1(builder.ins().bitselect(cmp, b, a))
1968
- }
1969
- Operator::F32x4Sqrt | Operator::F64x2Sqrt => {
1970
- let a = pop1_with_bitcast(state, type_of(op), builder);
1971
- state.push1(builder.ins().sqrt(a))
1972
- }
1973
- Operator::F32x4Neg | Operator::F64x2Neg => {
1974
- let a = pop1_with_bitcast(state, type_of(op), builder);
1975
- state.push1(builder.ins().fneg(a))
1976
- }
1977
- Operator::F32x4Abs | Operator::F64x2Abs => {
1978
- let a = pop1_with_bitcast(state, type_of(op), builder);
1979
- state.push1(builder.ins().fabs(a))
1980
- }
1981
- Operator::F32x4ConvertI32x4S => {
1982
- let a = pop1_with_bitcast(state, I32X4, builder);
1983
- state.push1(builder.ins().fcvt_from_sint(F32X4, a))
1984
- }
1985
- Operator::F32x4ConvertI32x4U => {
1986
- let a = pop1_with_bitcast(state, I32X4, builder);
1987
- state.push1(builder.ins().fcvt_from_uint(F32X4, a))
1988
- }
1989
- Operator::F64x2ConvertLowI32x4S => {
1990
- let a = pop1_with_bitcast(state, I32X4, builder);
1991
- let widened_a = builder.ins().swiden_low(a);
1992
- state.push1(builder.ins().fcvt_from_sint(F64X2, widened_a));
1993
- }
1994
- Operator::F64x2ConvertLowI32x4U => {
1995
- let a = pop1_with_bitcast(state, I32X4, builder);
1996
- let widened_a = builder.ins().uwiden_low(a);
1997
- state.push1(builder.ins().fcvt_from_uint(F64X2, widened_a));
1998
- }
1999
- Operator::F64x2PromoteLowF32x4 => {
2000
- let a = pop1_with_bitcast(state, F32X4, builder);
2001
- state.push1(builder.ins().fvpromote_low(a));
2002
- }
2003
- Operator::F32x4DemoteF64x2Zero => {
2004
- let a = pop1_with_bitcast(state, F64X2, builder);
2005
- state.push1(builder.ins().fvdemote(a));
2006
- }
2007
- Operator::I32x4TruncSatF32x4S => {
2008
- let a = pop1_with_bitcast(state, F32X4, builder);
2009
- state.push1(builder.ins().fcvt_to_sint_sat(I32X4, a))
2010
- }
2011
- Operator::I32x4TruncSatF64x2SZero => {
2012
- let a = pop1_with_bitcast(state, F64X2, builder);
2013
- let converted_a = builder.ins().fcvt_to_sint_sat(I64X2, a);
2014
- let handle = builder.func.dfg.constants.insert(vec![0u8; 16].into());
2015
- let zero = builder.ins().vconst(I64X2, handle);
2016
-
2017
- state.push1(builder.ins().snarrow(converted_a, zero));
2018
- }
2019
-
2020
- // FIXME(#5913): the relaxed instructions here are translated the same
2021
- // as the saturating instructions, even when the code generator
2022
- // configuration allow for different semantics across hosts. On x86,
2023
- // however, it's theoretically possible to have a slightly more optimal
2024
- // lowering which accounts for NaN differently, although the lowering is
2025
- // still not trivial (e.g. one instruction). At this time the
2026
- // more-optimal-but-still-large lowering for x86 is not implemented so
2027
- // the relaxed instructions are listed here instead of down below with
2028
- // the other relaxed instructions. An x86-specific implementation (or
2029
- // perhaps for other backends too) should be added and the codegen for
2030
- // the relaxed instruction should conditionally be different.
2031
- Operator::I32x4RelaxedTruncF32x4U | Operator::I32x4TruncSatF32x4U => {
2032
- let a = pop1_with_bitcast(state, F32X4, builder);
2033
- state.push1(builder.ins().fcvt_to_uint_sat(I32X4, a))
2034
- }
2035
- Operator::I32x4RelaxedTruncF64x2UZero | Operator::I32x4TruncSatF64x2UZero => {
2036
- let a = pop1_with_bitcast(state, F64X2, builder);
2037
- let converted_a = builder.ins().fcvt_to_uint_sat(I64X2, a);
2038
- let handle = builder.func.dfg.constants.insert(vec![0u8; 16].into());
2039
- let zero = builder.ins().vconst(I64X2, handle);
2040
-
2041
- state.push1(builder.ins().uunarrow(converted_a, zero));
2042
- }
2043
-
2044
- Operator::I8x16NarrowI16x8S => {
2045
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2046
- state.push1(builder.ins().snarrow(a, b))
2047
- }
2048
- Operator::I16x8NarrowI32x4S => {
2049
- let (a, b) = pop2_with_bitcast(state, I32X4, builder);
2050
- state.push1(builder.ins().snarrow(a, b))
2051
- }
2052
- Operator::I8x16NarrowI16x8U => {
2053
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2054
- state.push1(builder.ins().unarrow(a, b))
2055
- }
2056
- Operator::I16x8NarrowI32x4U => {
2057
- let (a, b) = pop2_with_bitcast(state, I32X4, builder);
2058
- state.push1(builder.ins().unarrow(a, b))
2059
- }
2060
- Operator::I16x8ExtendLowI8x16S => {
2061
- let a = pop1_with_bitcast(state, I8X16, builder);
2062
- state.push1(builder.ins().swiden_low(a))
2063
- }
2064
- Operator::I16x8ExtendHighI8x16S => {
2065
- let a = pop1_with_bitcast(state, I8X16, builder);
2066
- state.push1(builder.ins().swiden_high(a))
2067
- }
2068
- Operator::I16x8ExtendLowI8x16U => {
2069
- let a = pop1_with_bitcast(state, I8X16, builder);
2070
- state.push1(builder.ins().uwiden_low(a))
2071
- }
2072
- Operator::I16x8ExtendHighI8x16U => {
2073
- let a = pop1_with_bitcast(state, I8X16, builder);
2074
- state.push1(builder.ins().uwiden_high(a))
2075
- }
2076
- Operator::I32x4ExtendLowI16x8S => {
2077
- let a = pop1_with_bitcast(state, I16X8, builder);
2078
- state.push1(builder.ins().swiden_low(a))
2079
- }
2080
- Operator::I32x4ExtendHighI16x8S => {
2081
- let a = pop1_with_bitcast(state, I16X8, builder);
2082
- state.push1(builder.ins().swiden_high(a))
2083
- }
2084
- Operator::I32x4ExtendLowI16x8U => {
2085
- let a = pop1_with_bitcast(state, I16X8, builder);
2086
- state.push1(builder.ins().uwiden_low(a))
2087
- }
2088
- Operator::I32x4ExtendHighI16x8U => {
2089
- let a = pop1_with_bitcast(state, I16X8, builder);
2090
- state.push1(builder.ins().uwiden_high(a))
2091
- }
2092
- Operator::I64x2ExtendLowI32x4S => {
2093
- let a = pop1_with_bitcast(state, I32X4, builder);
2094
- state.push1(builder.ins().swiden_low(a))
2095
- }
2096
- Operator::I64x2ExtendHighI32x4S => {
2097
- let a = pop1_with_bitcast(state, I32X4, builder);
2098
- state.push1(builder.ins().swiden_high(a))
2099
- }
2100
- Operator::I64x2ExtendLowI32x4U => {
2101
- let a = pop1_with_bitcast(state, I32X4, builder);
2102
- state.push1(builder.ins().uwiden_low(a))
2103
- }
2104
- Operator::I64x2ExtendHighI32x4U => {
2105
- let a = pop1_with_bitcast(state, I32X4, builder);
2106
- state.push1(builder.ins().uwiden_high(a))
2107
- }
2108
- Operator::I16x8ExtAddPairwiseI8x16S => {
2109
- let a = pop1_with_bitcast(state, I8X16, builder);
2110
- let widen_low = builder.ins().swiden_low(a);
2111
- let widen_high = builder.ins().swiden_high(a);
2112
- state.push1(builder.ins().iadd_pairwise(widen_low, widen_high));
2113
- }
2114
- Operator::I32x4ExtAddPairwiseI16x8S => {
2115
- let a = pop1_with_bitcast(state, I16X8, builder);
2116
- let widen_low = builder.ins().swiden_low(a);
2117
- let widen_high = builder.ins().swiden_high(a);
2118
- state.push1(builder.ins().iadd_pairwise(widen_low, widen_high));
2119
- }
2120
- Operator::I16x8ExtAddPairwiseI8x16U => {
2121
- let a = pop1_with_bitcast(state, I8X16, builder);
2122
- let widen_low = builder.ins().uwiden_low(a);
2123
- let widen_high = builder.ins().uwiden_high(a);
2124
- state.push1(builder.ins().iadd_pairwise(widen_low, widen_high));
2125
- }
2126
- Operator::I32x4ExtAddPairwiseI16x8U => {
2127
- let a = pop1_with_bitcast(state, I16X8, builder);
2128
- let widen_low = builder.ins().uwiden_low(a);
2129
- let widen_high = builder.ins().uwiden_high(a);
2130
- state.push1(builder.ins().iadd_pairwise(widen_low, widen_high));
2131
- }
2132
- Operator::F32x4Ceil | Operator::F64x2Ceil => {
2133
- // This is something of a misuse of `type_of`, because that produces the return type
2134
- // of `op`. In this case we want the arg type, but we know it's the same as the
2135
- // return type. Same for the 3 cases below.
2136
- let arg = pop1_with_bitcast(state, type_of(op), builder);
2137
- state.push1(builder.ins().ceil(arg));
2138
- }
2139
- Operator::F32x4Floor | Operator::F64x2Floor => {
2140
- let arg = pop1_with_bitcast(state, type_of(op), builder);
2141
- state.push1(builder.ins().floor(arg));
2142
- }
2143
- Operator::F32x4Trunc | Operator::F64x2Trunc => {
2144
- let arg = pop1_with_bitcast(state, type_of(op), builder);
2145
- state.push1(builder.ins().trunc(arg));
2146
- }
2147
- Operator::F32x4Nearest | Operator::F64x2Nearest => {
2148
- let arg = pop1_with_bitcast(state, type_of(op), builder);
2149
- state.push1(builder.ins().nearest(arg));
2150
- }
2151
- Operator::I32x4DotI16x8S => {
2152
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2153
- let alow = builder.ins().swiden_low(a);
2154
- let blow = builder.ins().swiden_low(b);
2155
- let low = builder.ins().imul(alow, blow);
2156
- let ahigh = builder.ins().swiden_high(a);
2157
- let bhigh = builder.ins().swiden_high(b);
2158
- let high = builder.ins().imul(ahigh, bhigh);
2159
- state.push1(builder.ins().iadd_pairwise(low, high));
2160
- }
2161
- Operator::I8x16Popcnt => {
2162
- let arg = pop1_with_bitcast(state, type_of(op), builder);
2163
- state.push1(builder.ins().popcnt(arg));
2164
- }
2165
- Operator::I16x8Q15MulrSatS => {
2166
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2167
- state.push1(builder.ins().sqmul_round_sat(a, b))
2168
- }
2169
- Operator::I16x8ExtMulLowI8x16S => {
2170
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
2171
- let a_low = builder.ins().swiden_low(a);
2172
- let b_low = builder.ins().swiden_low(b);
2173
- state.push1(builder.ins().imul(a_low, b_low));
2174
- }
2175
- Operator::I16x8ExtMulHighI8x16S => {
2176
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
2177
- let a_high = builder.ins().swiden_high(a);
2178
- let b_high = builder.ins().swiden_high(b);
2179
- state.push1(builder.ins().imul(a_high, b_high));
2180
- }
2181
- Operator::I16x8ExtMulLowI8x16U => {
2182
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
2183
- let a_low = builder.ins().uwiden_low(a);
2184
- let b_low = builder.ins().uwiden_low(b);
2185
- state.push1(builder.ins().imul(a_low, b_low));
2186
- }
2187
- Operator::I16x8ExtMulHighI8x16U => {
2188
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
2189
- let a_high = builder.ins().uwiden_high(a);
2190
- let b_high = builder.ins().uwiden_high(b);
2191
- state.push1(builder.ins().imul(a_high, b_high));
2192
- }
2193
- Operator::I32x4ExtMulLowI16x8S => {
2194
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2195
- let a_low = builder.ins().swiden_low(a);
2196
- let b_low = builder.ins().swiden_low(b);
2197
- state.push1(builder.ins().imul(a_low, b_low));
2198
- }
2199
- Operator::I32x4ExtMulHighI16x8S => {
2200
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2201
- let a_high = builder.ins().swiden_high(a);
2202
- let b_high = builder.ins().swiden_high(b);
2203
- state.push1(builder.ins().imul(a_high, b_high));
2204
- }
2205
- Operator::I32x4ExtMulLowI16x8U => {
2206
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2207
- let a_low = builder.ins().uwiden_low(a);
2208
- let b_low = builder.ins().uwiden_low(b);
2209
- state.push1(builder.ins().imul(a_low, b_low));
2210
- }
2211
- Operator::I32x4ExtMulHighI16x8U => {
2212
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2213
- let a_high = builder.ins().uwiden_high(a);
2214
- let b_high = builder.ins().uwiden_high(b);
2215
- state.push1(builder.ins().imul(a_high, b_high));
2216
- }
2217
- Operator::I64x2ExtMulLowI32x4S => {
2218
- let (a, b) = pop2_with_bitcast(state, I32X4, builder);
2219
- let a_low = builder.ins().swiden_low(a);
2220
- let b_low = builder.ins().swiden_low(b);
2221
- state.push1(builder.ins().imul(a_low, b_low));
2222
- }
2223
- Operator::I64x2ExtMulHighI32x4S => {
2224
- let (a, b) = pop2_with_bitcast(state, I32X4, builder);
2225
- let a_high = builder.ins().swiden_high(a);
2226
- let b_high = builder.ins().swiden_high(b);
2227
- state.push1(builder.ins().imul(a_high, b_high));
2228
- }
2229
- Operator::I64x2ExtMulLowI32x4U => {
2230
- let (a, b) = pop2_with_bitcast(state, I32X4, builder);
2231
- let a_low = builder.ins().uwiden_low(a);
2232
- let b_low = builder.ins().uwiden_low(b);
2233
- state.push1(builder.ins().imul(a_low, b_low));
2234
- }
2235
- Operator::I64x2ExtMulHighI32x4U => {
2236
- let (a, b) = pop2_with_bitcast(state, I32X4, builder);
2237
- let a_high = builder.ins().uwiden_high(a);
2238
- let b_high = builder.ins().uwiden_high(b);
2239
- state.push1(builder.ins().imul(a_high, b_high));
2240
- }
2241
- Operator::MemoryDiscard { .. } => {
2242
- return Err(wasm_unsupported!(
2243
- "proposed memory-control operator {:?}",
2244
- op
2245
- ));
2246
- }
2247
-
2248
- Operator::F32x4RelaxedMax | Operator::F64x2RelaxedMax => {
2249
- let ty = type_of(op);
2250
- let (a, b) = pop2_with_bitcast(state, ty, builder);
2251
- state.push1(
2252
- if environ.relaxed_simd_deterministic() || !environ.is_x86() {
2253
- // Deterministic semantics match the `fmax` instruction, or
2254
- // the `fAAxBB.max` wasm instruction.
2255
- builder.ins().fmax(a, b)
2256
- } else {
2257
- // Note that this matches the `pmax` translation which has
2258
- // careful ordering of its operands to trigger
2259
- // pattern-matches in the x86 backend.
2260
- let cmp = builder.ins().fcmp(FloatCC::LessThan, a, b);
2261
- let cmp = optionally_bitcast_vector(cmp, ty, builder);
2262
- builder.ins().bitselect(cmp, b, a)
2263
- },
2264
- )
2265
- }
2266
-
2267
- Operator::F32x4RelaxedMin | Operator::F64x2RelaxedMin => {
2268
- let ty = type_of(op);
2269
- let (a, b) = pop2_with_bitcast(state, ty, builder);
2270
- state.push1(
2271
- if environ.relaxed_simd_deterministic() || !environ.is_x86() {
2272
- // Deterministic semantics match the `fmin` instruction, or
2273
- // the `fAAxBB.min` wasm instruction.
2274
- builder.ins().fmin(a, b)
2275
- } else {
2276
- // Note that this matches the `pmin` translation which has
2277
- // careful ordering of its operands to trigger
2278
- // pattern-matches in the x86 backend.
2279
- let cmp = builder.ins().fcmp(FloatCC::LessThan, b, a);
2280
- let cmp = optionally_bitcast_vector(cmp, ty, builder);
2281
- builder.ins().bitselect(cmp, b, a)
2282
- },
2283
- );
2284
- }
2285
-
2286
- Operator::I8x16RelaxedSwizzle => {
2287
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
2288
- state.push1(
2289
- if environ.relaxed_simd_deterministic()
2290
- || !environ.use_x86_pshufb_for_relaxed_swizzle()
2291
- {
2292
- // Deterministic semantics match the `i8x16.swizzle`
2293
- // instruction which is the CLIF `swizzle`.
2294
- builder.ins().swizzle(a, b)
2295
- } else {
2296
- builder.ins().x86_pshufb(a, b)
2297
- },
2298
- );
2299
- }
2300
-
2301
- Operator::F32x4RelaxedMadd | Operator::F64x2RelaxedMadd => {
2302
- let (a, b, c) = pop3_with_bitcast(state, type_of(op), builder);
2303
- state.push1(
2304
- if environ.relaxed_simd_deterministic() || environ.has_native_fma() {
2305
- // Deterministic semantics are "fused multiply and add"
2306
- // which the CLIF `fma` guarantees.
2307
- builder.ins().fma(a, b, c)
2308
- } else {
2309
- let mul = builder.ins().fmul(a, b);
2310
- builder.ins().fadd(mul, c)
2311
- },
2312
- );
2313
- }
2314
- Operator::F32x4RelaxedNmadd | Operator::F64x2RelaxedNmadd => {
2315
- let (a, b, c) = pop3_with_bitcast(state, type_of(op), builder);
2316
- let a = builder.ins().fneg(a);
2317
- state.push1(
2318
- if environ.relaxed_simd_deterministic() || environ.has_native_fma() {
2319
- // Deterministic semantics are "fused multiply and add"
2320
- // which the CLIF `fma` guarantees.
2321
- builder.ins().fma(a, b, c)
2322
- } else {
2323
- let mul = builder.ins().fmul(a, b);
2324
- builder.ins().fadd(mul, c)
2325
- },
2326
- );
2327
- }
2328
-
2329
- Operator::I8x16RelaxedLaneselect
2330
- | Operator::I16x8RelaxedLaneselect
2331
- | Operator::I32x4RelaxedLaneselect
2332
- | Operator::I64x2RelaxedLaneselect => {
2333
- let ty = type_of(op);
2334
- let (a, b, c) = pop3_with_bitcast(state, ty, builder);
2335
- // Note that the variable swaps here are intentional due to
2336
- // the difference of the order of the wasm op and the clif
2337
- // op.
2338
- state.push1(
2339
- if environ.relaxed_simd_deterministic()
2340
- || !environ.use_x86_blendv_for_relaxed_laneselect(ty)
2341
- {
2342
- // Deterministic semantics are a `bitselect` along the lines
2343
- // of the wasm `v128.bitselect` instruction.
2344
- builder.ins().bitselect(c, a, b)
2345
- } else {
2346
- builder.ins().x86_blendv(c, a, b)
2347
- },
2348
- );
2349
- }
2350
-
2351
- Operator::I32x4RelaxedTruncF32x4S => {
2352
- let a = pop1_with_bitcast(state, F32X4, builder);
2353
- state.push1(
2354
- if environ.relaxed_simd_deterministic() || !environ.is_x86() {
2355
- // Deterministic semantics are to match the
2356
- // `i32x4.trunc_sat_f32x4_s` instruction.
2357
- builder.ins().fcvt_to_sint_sat(I32X4, a)
2358
- } else {
2359
- builder.ins().x86_cvtt2dq(I32X4, a)
2360
- },
2361
- )
2362
- }
2363
- Operator::I32x4RelaxedTruncF64x2SZero => {
2364
- let a = pop1_with_bitcast(state, F64X2, builder);
2365
- let converted_a = if environ.relaxed_simd_deterministic() || !environ.is_x86() {
2366
- // Deterministic semantics are to match the
2367
- // `i32x4.trunc_sat_f64x2_s_zero` instruction.
2368
- builder.ins().fcvt_to_sint_sat(I64X2, a)
2369
- } else {
2370
- builder.ins().x86_cvtt2dq(I64X2, a)
2371
- };
2372
- let handle = builder.func.dfg.constants.insert(vec![0u8; 16].into());
2373
- let zero = builder.ins().vconst(I64X2, handle);
2374
-
2375
- state.push1(builder.ins().snarrow(converted_a, zero));
2376
- }
2377
- Operator::I16x8RelaxedQ15mulrS => {
2378
- let (a, b) = pop2_with_bitcast(state, I16X8, builder);
2379
- state.push1(
2380
- if environ.relaxed_simd_deterministic()
2381
- || !environ.use_x86_pmulhrsw_for_relaxed_q15mul()
2382
- {
2383
- // Deterministic semantics are to match the
2384
- // `i16x8.q15mulr_sat_s` instruction.
2385
- builder.ins().sqmul_round_sat(a, b)
2386
- } else {
2387
- builder.ins().x86_pmulhrsw(a, b)
2388
- },
2389
- );
2390
- }
2391
- Operator::I16x8RelaxedDotI8x16I7x16S => {
2392
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
2393
- state.push1(
2394
- if environ.relaxed_simd_deterministic() || !environ.use_x86_pmaddubsw_for_dot() {
2395
- // Deterministic semantics are to treat both operands as
2396
- // signed integers and perform the dot product.
2397
- let alo = builder.ins().swiden_low(a);
2398
- let blo = builder.ins().swiden_low(b);
2399
- let lo = builder.ins().imul(alo, blo);
2400
- let ahi = builder.ins().swiden_high(a);
2401
- let bhi = builder.ins().swiden_high(b);
2402
- let hi = builder.ins().imul(ahi, bhi);
2403
- builder.ins().iadd_pairwise(lo, hi)
2404
- } else {
2405
- builder.ins().x86_pmaddubsw(a, b)
2406
- },
2407
- );
2408
- }
2409
-
2410
- Operator::I32x4RelaxedDotI8x16I7x16AddS => {
2411
- let c = pop1_with_bitcast(state, I32X4, builder);
2412
- let (a, b) = pop2_with_bitcast(state, I8X16, builder);
2413
- let dot =
2414
- if environ.relaxed_simd_deterministic() || !environ.use_x86_pmaddubsw_for_dot() {
2415
- // Deterministic semantics are to treat both operands as
2416
- // signed integers and perform the dot product.
2417
- let alo = builder.ins().swiden_low(a);
2418
- let blo = builder.ins().swiden_low(b);
2419
- let lo = builder.ins().imul(alo, blo);
2420
- let ahi = builder.ins().swiden_high(a);
2421
- let bhi = builder.ins().swiden_high(b);
2422
- let hi = builder.ins().imul(ahi, bhi);
2423
- builder.ins().iadd_pairwise(lo, hi)
2424
- } else {
2425
- builder.ins().x86_pmaddubsw(a, b)
2426
- };
2427
- let dotlo = builder.ins().swiden_low(dot);
2428
- let dothi = builder.ins().swiden_high(dot);
2429
- let dot32 = builder.ins().iadd_pairwise(dotlo, dothi);
2430
- state.push1(builder.ins().iadd(dot32, c));
2431
- }
2432
-
2433
- Operator::BrOnNull { relative_depth } => {
2434
- let r = state.pop1();
2435
- let (br_destination, inputs) = translate_br_if_args(*relative_depth, state);
2436
- let is_null = environ.translate_ref_is_null(builder.cursor(), r)?;
2437
- let else_block = builder.create_block();
2438
- canonicalise_brif(builder, is_null, br_destination, inputs, else_block, &[]);
2439
-
2440
- builder.seal_block(else_block); // The only predecessor is the current block.
2441
- builder.switch_to_block(else_block);
2442
- state.push1(r);
2443
- }
2444
- Operator::BrOnNonNull { relative_depth } => {
2445
- // We write this a bit differently from the spec to avoid an extra
2446
- // block/branch and the typed accounting thereof. Instead of the
2447
- // spec's approach, it's described as such:
2448
- // Peek the value val from the stack.
2449
- // If val is ref.null ht, then: pop the value val from the stack.
2450
- // Else: Execute the instruction (br relative_depth).
2451
- let is_null = environ.translate_ref_is_null(builder.cursor(), state.peek1())?;
2452
- let (br_destination, inputs) = translate_br_if_args(*relative_depth, state);
2453
- let else_block = builder.create_block();
2454
- canonicalise_brif(builder, is_null, else_block, &[], br_destination, inputs);
2455
-
2456
- // In the null case, pop the ref
2457
- state.pop1();
2458
-
2459
- builder.seal_block(else_block); // The only predecessor is the current block.
2460
-
2461
- // The rest of the translation operates on our is null case, which is
2462
- // currently an empty block
2463
- builder.switch_to_block(else_block);
2464
- }
2465
- Operator::CallRef { type_index } => {
2466
- // Get function signature
2467
- // `index` is the index of the function's signature and `table_index` is the index of
2468
- // the table to search the function in.
2469
- let (sigref, num_args) = state.get_indirect_sig(builder.func, *type_index, environ)?;
2470
- let callee = state.pop1();
2471
-
2472
- // Bitcast any vector arguments to their default type, I8X16, before calling.
2473
- let args = state.peekn_mut(num_args);
2474
- bitcast_wasm_params(environ, sigref, args, builder);
2475
-
2476
- let call =
2477
- environ.translate_call_ref(builder, sigref, callee, state.peekn(num_args))?;
2478
-
2479
- let inst_results = builder.inst_results(call);
2480
- debug_assert_eq!(
2481
- inst_results.len(),
2482
- builder.func.dfg.signatures[sigref].returns.len(),
2483
- "translate_call_ref results should match the call signature"
2484
- );
2485
- state.popn(num_args);
2486
- state.pushn(inst_results);
2487
- }
2488
- Operator::RefAsNonNull => {
2489
- let r = state.pop1();
2490
- let is_null = environ.translate_ref_is_null(builder.cursor(), r)?;
2491
- builder.ins().trapnz(is_null, ir::TrapCode::NullReference);
2492
- state.push1(r);
2493
- }
2494
-
2495
- Operator::RefI31 => {
2496
- let val = state.pop1();
2497
- let i31ref = environ.translate_ref_i31(builder.cursor(), val)?;
2498
- state.push1(i31ref);
2499
- }
2500
- Operator::I31GetS => {
2501
- let i31ref = state.pop1();
2502
- let val = environ.translate_i31_get_s(builder.cursor(), i31ref)?;
2503
- state.push1(val);
2504
- }
2505
- Operator::I31GetU => {
2506
- let i31ref = state.pop1();
2507
- let val = environ.translate_i31_get_u(builder.cursor(), i31ref)?;
2508
- state.push1(val);
2509
- }
2510
-
2511
- Operator::TryTable { .. } | Operator::ThrowRef => {
2512
- unimplemented!("exception operators not yet implemented")
2513
- }
2514
-
2515
- Operator::RefEq
2516
- | Operator::RefTestNonNull { .. }
2517
- | Operator::RefTestNullable { .. }
2518
- | Operator::RefCastNonNull { .. }
2519
- | Operator::RefCastNullable { .. }
2520
- | Operator::BrOnCast { .. }
2521
- | Operator::BrOnCastFail { .. }
2522
- | Operator::AnyConvertExtern
2523
- | Operator::ExternConvertAny
2524
- | Operator::ArrayNew { .. }
2525
- | Operator::ArrayNewDefault { .. }
2526
- | Operator::ArrayNewFixed { .. }
2527
- | Operator::ArrayNewData { .. }
2528
- | Operator::ArrayNewElem { .. }
2529
- | Operator::ArrayGet { .. }
2530
- | Operator::ArrayGetU { .. }
2531
- | Operator::ArrayGetS { .. }
2532
- | Operator::ArraySet { .. }
2533
- | Operator::ArrayLen { .. }
2534
- | Operator::ArrayFill { .. }
2535
- | Operator::ArrayCopy { .. }
2536
- | Operator::ArrayInitData { .. }
2537
- | Operator::ArrayInitElem { .. }
2538
- | Operator::StructNew { .. }
2539
- | Operator::StructNewDefault { .. }
2540
- | Operator::StructGetS { .. }
2541
- | Operator::StructGetU { .. }
2542
- | Operator::StructSet { .. }
2543
- | Operator::StructGet { .. } => {
2544
- unimplemented!("GC operators not yet implemented")
2545
- }
2546
-
2547
- Operator::GlobalAtomicGet { .. }
2548
- | Operator::GlobalAtomicSet { .. }
2549
- | Operator::GlobalAtomicRmwAdd { .. }
2550
- | Operator::GlobalAtomicRmwSub { .. }
2551
- | Operator::GlobalAtomicRmwOr { .. }
2552
- | Operator::GlobalAtomicRmwXor { .. }
2553
- | Operator::GlobalAtomicRmwAnd { .. }
2554
- | Operator::GlobalAtomicRmwXchg { .. }
2555
- | Operator::GlobalAtomicRmwCmpxchg { .. } => {
2556
- unimplemented!("shared-everything-threads not yet implemented")
2557
- }
2558
- };
2559
- Ok(())
2560
- }
2561
-
2562
- /// Deals with a Wasm instruction located in an unreachable portion of the code. Most of them
2563
- /// are dropped but special ones like `End` or `Else` signal the potential end of the unreachable
2564
- /// portion so the translation state must be updated accordingly.
2565
- fn translate_unreachable_operator<FE: FuncEnvironment + ?Sized>(
2566
- validator: &FuncValidator<impl WasmModuleResources>,
2567
- op: &Operator,
2568
- builder: &mut FunctionBuilder,
2569
- state: &mut FuncTranslationState,
2570
- environ: &mut FE,
2571
- ) -> WasmResult<()> {
2572
- debug_assert!(!state.reachable);
2573
- match *op {
2574
- Operator::If { blockty } => {
2575
- // Push a placeholder control stack entry. The if isn't reachable,
2576
- // so we don't have any branches anywhere.
2577
- state.push_if(
2578
- ir::Block::reserved_value(),
2579
- ElseData::NoElse {
2580
- branch_inst: ir::Inst::reserved_value(),
2581
- placeholder: ir::Block::reserved_value(),
2582
- },
2583
- 0,
2584
- 0,
2585
- blockty,
2586
- );
2587
- }
2588
- Operator::Loop { blockty: _ } | Operator::Block { blockty: _ } => {
2589
- state.push_block(ir::Block::reserved_value(), 0, 0);
2590
- }
2591
- Operator::Else => {
2592
- let i = state.control_stack.len() - 1;
2593
- match state.control_stack[i] {
2594
- ControlStackFrame::If {
2595
- ref else_data,
2596
- head_is_reachable,
2597
- ref mut consequent_ends_reachable,
2598
- blocktype,
2599
- ..
2600
- } => {
2601
- debug_assert!(consequent_ends_reachable.is_none());
2602
- *consequent_ends_reachable = Some(state.reachable);
2603
-
2604
- if head_is_reachable {
2605
- // We have a branch from the head of the `if` to the `else`.
2606
- state.reachable = true;
2607
-
2608
- let else_block = match *else_data {
2609
- ElseData::NoElse {
2610
- branch_inst,
2611
- placeholder,
2612
- } => {
2613
- let (params, _results) =
2614
- blocktype_params_results(validator, blocktype)?;
2615
- let else_block = block_with_params(builder, params, environ)?;
2616
- let frame = state.control_stack.last().unwrap();
2617
- frame.truncate_value_stack_to_else_params(&mut state.stack);
2618
-
2619
- // We change the target of the branch instruction.
2620
- builder.change_jump_destination(
2621
- branch_inst,
2622
- placeholder,
2623
- else_block,
2624
- );
2625
- builder.seal_block(else_block);
2626
- else_block
2627
- }
2628
- ElseData::WithElse { else_block } => {
2629
- let frame = state.control_stack.last().unwrap();
2630
- frame.truncate_value_stack_to_else_params(&mut state.stack);
2631
- else_block
2632
- }
2633
- };
2634
-
2635
- builder.switch_to_block(else_block);
2636
-
2637
- // Again, no need to push the parameters for the `else`,
2638
- // since we already did when we saw the original `if`. See
2639
- // the comment for translating `Operator::Else` in
2640
- // `translate_operator` for details.
2641
- }
2642
- }
2643
- _ => unreachable!(),
2644
- }
2645
- }
2646
- Operator::End => {
2647
- let stack = &mut state.stack;
2648
- let control_stack = &mut state.control_stack;
2649
- let frame = control_stack.pop().unwrap();
2650
-
2651
- // Pop unused parameters from stack.
2652
- frame.truncate_value_stack_to_original_size(stack);
2653
-
2654
- let reachable_anyway = match frame {
2655
- // If it is a loop we also have to seal the body loop block
2656
- ControlStackFrame::Loop { header, .. } => {
2657
- builder.seal_block(header);
2658
- // And loops can't have branches to the end.
2659
- false
2660
- }
2661
- // If we never set `consequent_ends_reachable` then that means
2662
- // we are finishing the consequent now, and there was no
2663
- // `else`. Whether the following block is reachable depends only
2664
- // on if the head was reachable.
2665
- ControlStackFrame::If {
2666
- head_is_reachable,
2667
- consequent_ends_reachable: None,
2668
- ..
2669
- } => head_is_reachable,
2670
- // Since we are only in this function when in unreachable code,
2671
- // we know that the alternative just ended unreachable. Whether
2672
- // the following block is reachable depends on if the consequent
2673
- // ended reachable or not.
2674
- ControlStackFrame::If {
2675
- head_is_reachable,
2676
- consequent_ends_reachable: Some(consequent_ends_reachable),
2677
- ..
2678
- } => head_is_reachable && consequent_ends_reachable,
2679
- // All other control constructs are already handled.
2680
- _ => false,
2681
- };
2682
-
2683
- if frame.exit_is_branched_to() || reachable_anyway {
2684
- builder.switch_to_block(frame.following_code());
2685
- builder.seal_block(frame.following_code());
2686
-
2687
- // And add the return values of the block but only if the next block is reachable
2688
- // (which corresponds to testing if the stack depth is 1)
2689
- stack.extend_from_slice(builder.block_params(frame.following_code()));
2690
- state.reachable = true;
2691
- }
2692
- }
2693
- _ => {
2694
- // We don't translate because this is unreachable code
2695
- }
2696
- }
2697
-
2698
- Ok(())
2699
- }
2700
-
2701
- /// This function is a generalized helper for validating that a wasm-supplied
2702
- /// heap address is in-bounds.
2703
- ///
2704
- /// This function takes a litany of parameters and requires that the *Wasm*
2705
- /// address to be verified is at the top of the stack in `state`. This will
2706
- /// generate necessary IR to validate that the heap address is correctly
2707
- /// in-bounds, and various parameters are returned describing the valid *native*
2708
- /// heap address if execution reaches that point.
2709
- ///
2710
- /// Returns `None` when the Wasm access will unconditionally trap.
2711
- ///
2712
- /// Returns `(flags, wasm_addr, native_addr)`.
2713
- fn prepare_addr<FE>(
2714
- memarg: &MemArg,
2715
- access_size: u8,
2716
- builder: &mut FunctionBuilder,
2717
- state: &mut FuncTranslationState,
2718
- environ: &mut FE,
2719
- ) -> WasmResult<Reachability<(MemFlags, Value, Value)>>
2720
- where
2721
- FE: FuncEnvironment + ?Sized,
2722
- {
2723
- let index = state.pop1();
2724
- let heap = state.get_heap(builder.func, memarg.memory, environ)?;
2725
-
2726
- // How exactly the bounds check is performed here and what it's performed
2727
- // on is a bit tricky. Generally we want to rely on access violations (e.g.
2728
- // segfaults) to generate traps since that means we don't have to bounds
2729
- // check anything explicitly.
2730
- //
2731
- // (1) If we don't have a guard page of unmapped memory, though, then we
2732
- // can't rely on this trapping behavior through segfaults. Instead we need
2733
- // to bounds-check the entire memory access here which is everything from
2734
- // `addr32 + offset` to `addr32 + offset + width` (not inclusive). In this
2735
- // scenario our adjusted offset that we're checking is `memarg.offset +
2736
- // access_size`. Note that we do saturating arithmetic here to avoid
2737
- // overflow. The addition here is in the 64-bit space, which means that
2738
- // we'll never overflow for 32-bit wasm but for 64-bit this is an issue. If
2739
- // our effective offset is u64::MAX though then it's impossible for for
2740
- // that to actually be a valid offset because otherwise the wasm linear
2741
- // memory would take all of the host memory!
2742
- //
2743
- // (2) If we have a guard page, however, then we can perform a further
2744
- // optimization of the generated code by only checking multiples of the
2745
- // offset-guard size to be more CSE-friendly. Knowing that we have at least
2746
- // 1 page of a guard page we're then able to disregard the `width` since we
2747
- // know it's always less than one page. Our bounds check will be for the
2748
- // first byte which will either succeed and be guaranteed to fault if it's
2749
- // actually out of bounds, or the bounds check itself will fail. In any case
2750
- // we assert that the width is reasonably small for now so this assumption
2751
- // can be adjusted in the future if we get larger widths.
2752
- //
2753
- // Put another way we can say, where `y < offset_guard_size`:
2754
- //
2755
- // n * offset_guard_size + y = offset
2756
- //
2757
- // We'll then pass `n * offset_guard_size` as the bounds check value. If
2758
- // this traps then our `offset` would have trapped anyway. If this check
2759
- // passes we know
2760
- //
2761
- // addr32 + n * offset_guard_size < bound
2762
- //
2763
- // which means
2764
- //
2765
- // addr32 + n * offset_guard_size + y < bound + offset_guard_size
2766
- //
2767
- // because `y < offset_guard_size`, which then means:
2768
- //
2769
- // addr32 + offset < bound + offset_guard_size
2770
- //
2771
- // Since we know that that guard size bytes are all unmapped we're
2772
- // guaranteed that `offset` and the `width` bytes after it are either
2773
- // in-bounds or will hit the guard page, meaning we'll get the desired
2774
- // semantics we want.
2775
- //
2776
- // ---
2777
- //
2778
- // With all that in mind remember that the goal is to bounds check as few
2779
- // things as possible. To facilitate this the "fast path" is expected to be
2780
- // hit like so:
2781
- //
2782
- // * For wasm32, wasmtime defaults to 4gb "static" memories with 2gb guard
2783
- // regions. This means that for all offsets <=2gb, we hit the optimized
2784
- // case for `heap_addr` on static memories 4gb in size in cranelift's
2785
- // legalization of `heap_addr`, eliding the bounds check entirely.
2786
- //
2787
- // * For wasm64 offsets <=2gb will generate a single `heap_addr`
2788
- // instruction, but at this time all heaps are "dynamic" which means that
2789
- // a single bounds check is forced. Ideally we'd do better here, but
2790
- // that's the current state of affairs.
2791
- //
2792
- // Basically we assume that most configurations have a guard page and most
2793
- // offsets in `memarg` are <=2gb, which means we get the fast path of one
2794
- // `heap_addr` instruction plus a hardcoded i32-offset in memory-related
2795
- // instructions.
2796
- let heap = environ.heaps()[heap].clone();
2797
- let addr = match u32::try_from(memarg.offset) {
2798
- // If our offset fits within a u32, then we can place the it into the
2799
- // offset immediate of the `heap_addr` instruction.
2800
- Ok(offset) => bounds_checks::bounds_check_and_compute_addr(
2801
- builder,
2802
- environ,
2803
- &heap,
2804
- index,
2805
- offset,
2806
- access_size,
2807
- )?,
2808
-
2809
- // If the offset doesn't fit within a u32, then we can't pass it
2810
- // directly into `heap_addr`.
2811
- //
2812
- // One reasonable question you might ask is "why not?". There's no
2813
- // fundamental reason why `heap_addr` *must* take a 32-bit offset. The
2814
- // reason this isn't done, though, is that blindly changing the offset
2815
- // to a 64-bit offset increases the size of the `InstructionData` enum
2816
- // in cranelift by 8 bytes (16 to 24). This can have significant
2817
- // performance implications so the conclusion when this was written was
2818
- // that we shouldn't do that.
2819
- //
2820
- // Without the ability to put the whole offset into the `heap_addr`
2821
- // instruction we need to fold the offset into the address itself with
2822
- // an unsigned addition. In doing so though we need to check for
2823
- // overflow because that would mean the address is out-of-bounds (wasm
2824
- // bounds checks happen on the effective 33 or 65 bit address once the
2825
- // offset is factored in).
2826
- //
2827
- // Once we have the effective address, offset already folded in, then
2828
- // `heap_addr` is used to verify that the address is indeed in-bounds.
2829
- //
2830
- // Note that this is generating what's likely to be at least two
2831
- // branches, one for the overflow and one for the bounds check itself.
2832
- // For now though that should hopefully be ok since 4gb+ offsets are
2833
- // relatively odd/rare. In the future if needed we can look into
2834
- // optimizing this more.
2835
- Err(_) => {
2836
- let offset = builder.ins().iconst(heap.index_type, memarg.offset as i64);
2837
- let adjusted_index =
2838
- builder
2839
- .ins()
2840
- .uadd_overflow_trap(index, offset, ir::TrapCode::HeapOutOfBounds);
2841
- bounds_checks::bounds_check_and_compute_addr(
2842
- builder,
2843
- environ,
2844
- &heap,
2845
- adjusted_index,
2846
- 0,
2847
- access_size,
2848
- )?
2849
- }
2850
- };
2851
- let addr = match addr {
2852
- Reachability::Unreachable => return Ok(Reachability::Unreachable),
2853
- Reachability::Reachable(a) => a,
2854
- };
2855
-
2856
- // Note that we don't set `is_aligned` here, even if the load instruction's
2857
- // alignment immediate may says it's aligned, because WebAssembly's
2858
- // immediate field is just a hint, while Cranelift's aligned flag needs a
2859
- // guarantee. WebAssembly memory accesses are always little-endian.
2860
- let mut flags = MemFlags::new();
2861
- flags.set_endianness(ir::Endianness::Little);
2862
-
2863
- if heap.memory_type.is_some() {
2864
- // Proof-carrying code is enabled; check this memory access.
2865
- flags.set_checked();
2866
- }
2867
-
2868
- // The access occurs to the `heap` disjoint category of abstract
2869
- // state. This may allow alias analysis to merge redundant loads,
2870
- // etc. when heap accesses occur interleaved with other (table,
2871
- // vmctx, stack) accesses.
2872
- flags.set_alias_region(Some(ir::AliasRegion::Heap));
2873
-
2874
- Ok(Reachability::Reachable((flags, index, addr)))
2875
- }
2876
-
2877
- fn align_atomic_addr(
2878
- memarg: &MemArg,
2879
- loaded_bytes: u8,
2880
- builder: &mut FunctionBuilder,
2881
- state: &mut FuncTranslationState,
2882
- ) {
2883
- // Atomic addresses must all be aligned correctly, and for now we check
2884
- // alignment before we check out-of-bounds-ness. The order of this check may
2885
- // need to be updated depending on the outcome of the official threads
2886
- // proposal itself.
2887
- //
2888
- // Note that with an offset>0 we generate an `iadd_imm` where the result is
2889
- // thrown away after the offset check. This may truncate the offset and the
2890
- // result may overflow as well, but those conditions won't affect the
2891
- // alignment check itself. This can probably be optimized better and we
2892
- // should do so in the future as well.
2893
- if loaded_bytes > 1 {
2894
- let addr = state.pop1(); // "peek" via pop then push
2895
- state.push1(addr);
2896
- let effective_addr = if memarg.offset == 0 {
2897
- addr
2898
- } else {
2899
- builder
2900
- .ins()
2901
- .iadd_imm(addr, i64::from(memarg.offset as i32))
2902
- };
2903
- debug_assert!(loaded_bytes.is_power_of_two());
2904
- let misalignment = builder
2905
- .ins()
2906
- .band_imm(effective_addr, i64::from(loaded_bytes - 1));
2907
- let f = builder.ins().icmp_imm(IntCC::NotEqual, misalignment, 0);
2908
- builder.ins().trapnz(f, ir::TrapCode::HeapMisaligned);
2909
- }
2910
- }
2911
-
2912
- /// Like `prepare_addr` but for atomic accesses.
2913
- ///
2914
- /// Returns `None` when the Wasm access will unconditionally trap.
2915
- fn prepare_atomic_addr<FE: FuncEnvironment + ?Sized>(
2916
- memarg: &MemArg,
2917
- loaded_bytes: u8,
2918
- builder: &mut FunctionBuilder,
2919
- state: &mut FuncTranslationState,
2920
- environ: &mut FE,
2921
- ) -> WasmResult<Reachability<(MemFlags, Value, Value)>> {
2922
- align_atomic_addr(memarg, loaded_bytes, builder, state);
2923
- prepare_addr(memarg, loaded_bytes, builder, state, environ)
2924
- }
2925
-
2926
- /// Like `Option<T>` but specifically for passing information about transitions
2927
- /// from reachable to unreachable state and the like from callees to callers.
2928
- ///
2929
- /// Marked `must_use` to force callers to update
2930
- /// `FuncTranslationState::reachable` as necessary.
2931
- #[derive(PartialEq, Eq)]
2932
- #[must_use]
2933
- pub enum Reachability<T> {
2934
- /// The Wasm execution state is reachable, here is a `T`.
2935
- Reachable(T),
2936
- /// The Wasm execution state has been determined to be statically
2937
- /// unreachable. It is the receiver of this value's responsibility to update
2938
- /// `FuncTranslationState::reachable` as necessary.
2939
- Unreachable,
2940
- }
2941
-
2942
- /// Translate a load instruction.
2943
- ///
2944
- /// Returns the execution state's reachability after the load is translated.
2945
- fn translate_load<FE: FuncEnvironment + ?Sized>(
2946
- memarg: &MemArg,
2947
- opcode: ir::Opcode,
2948
- result_ty: Type,
2949
- builder: &mut FunctionBuilder,
2950
- state: &mut FuncTranslationState,
2951
- environ: &mut FE,
2952
- ) -> WasmResult<Reachability<()>> {
2953
- let mem_op_size = mem_op_size(opcode, result_ty);
2954
- let (flags, wasm_index, base) =
2955
- match prepare_addr(memarg, mem_op_size, builder, state, environ)? {
2956
- Reachability::Unreachable => return Ok(Reachability::Unreachable),
2957
- Reachability::Reachable((f, i, b)) => (f, i, b),
2958
- };
2959
-
2960
- environ.before_load(builder, mem_op_size, wasm_index, memarg.offset);
2961
-
2962
- let (load, dfg) = builder
2963
- .ins()
2964
- .Load(opcode, result_ty, flags, Offset32::new(0), base);
2965
- state.push1(dfg.first_result(load));
2966
- Ok(Reachability::Reachable(()))
2967
- }
2968
-
2969
- /// Translate a store instruction.
2970
- fn translate_store<FE: FuncEnvironment + ?Sized>(
2971
- memarg: &MemArg,
2972
- opcode: ir::Opcode,
2973
- builder: &mut FunctionBuilder,
2974
- state: &mut FuncTranslationState,
2975
- environ: &mut FE,
2976
- ) -> WasmResult<()> {
2977
- let val = state.pop1();
2978
- let val_ty = builder.func.dfg.value_type(val);
2979
- let mem_op_size = mem_op_size(opcode, val_ty);
2980
-
2981
- let (flags, wasm_index, base) = unwrap_or_return_unreachable_state!(
2982
- state,
2983
- prepare_addr(memarg, mem_op_size, builder, state, environ)?
2984
- );
2985
-
2986
- environ.before_store(builder, mem_op_size, wasm_index, memarg.offset);
2987
-
2988
- builder
2989
- .ins()
2990
- .Store(opcode, val_ty, flags, Offset32::new(0), val, base);
2991
- Ok(())
2992
- }
2993
-
2994
- fn mem_op_size(opcode: ir::Opcode, ty: Type) -> u8 {
2995
- match opcode {
2996
- ir::Opcode::Istore8 | ir::Opcode::Sload8 | ir::Opcode::Uload8 => 1,
2997
- ir::Opcode::Istore16 | ir::Opcode::Sload16 | ir::Opcode::Uload16 => 2,
2998
- ir::Opcode::Istore32 | ir::Opcode::Sload32 | ir::Opcode::Uload32 => 4,
2999
- ir::Opcode::Store | ir::Opcode::Load => u8::try_from(ty.bytes()).unwrap(),
3000
- _ => panic!("unknown size of mem op for {:?}", opcode),
3001
- }
3002
- }
3003
-
3004
- fn translate_icmp(cc: IntCC, builder: &mut FunctionBuilder, state: &mut FuncTranslationState) {
3005
- let (arg0, arg1) = state.pop2();
3006
- let val = builder.ins().icmp(cc, arg0, arg1);
3007
- state.push1(builder.ins().uextend(I32, val));
3008
- }
3009
-
3010
- fn translate_atomic_rmw<FE: FuncEnvironment + ?Sized>(
3011
- widened_ty: Type,
3012
- access_ty: Type,
3013
- op: AtomicRmwOp,
3014
- memarg: &MemArg,
3015
- builder: &mut FunctionBuilder,
3016
- state: &mut FuncTranslationState,
3017
- environ: &mut FE,
3018
- ) -> WasmResult<()> {
3019
- let mut arg2 = state.pop1();
3020
- let arg2_ty = builder.func.dfg.value_type(arg2);
3021
-
3022
- // The operation is performed at type `access_ty`, and the old value is zero-extended
3023
- // to type `widened_ty`.
3024
- match access_ty {
3025
- I8 | I16 | I32 | I64 => {}
3026
- _ => {
3027
- return Err(wasm_unsupported!(
3028
- "atomic_rmw: unsupported access type {:?}",
3029
- access_ty
3030
- ))
3031
- }
3032
- };
3033
- let w_ty_ok = match widened_ty {
3034
- I32 | I64 => true,
3035
- _ => false,
3036
- };
3037
- assert!(w_ty_ok && widened_ty.bytes() >= access_ty.bytes());
3038
-
3039
- assert!(arg2_ty.bytes() >= access_ty.bytes());
3040
- if arg2_ty.bytes() > access_ty.bytes() {
3041
- arg2 = builder.ins().ireduce(access_ty, arg2);
3042
- }
3043
-
3044
- let (flags, _, addr) = unwrap_or_return_unreachable_state!(
3045
- state,
3046
- prepare_atomic_addr(
3047
- memarg,
3048
- u8::try_from(access_ty.bytes()).unwrap(),
3049
- builder,
3050
- state,
3051
- environ,
3052
- )?
3053
- );
3054
-
3055
- let mut res = builder.ins().atomic_rmw(access_ty, flags, op, addr, arg2);
3056
- if access_ty != widened_ty {
3057
- res = builder.ins().uextend(widened_ty, res);
3058
- }
3059
- state.push1(res);
3060
- Ok(())
3061
- }
3062
-
3063
- fn translate_atomic_cas<FE: FuncEnvironment + ?Sized>(
3064
- widened_ty: Type,
3065
- access_ty: Type,
3066
- memarg: &MemArg,
3067
- builder: &mut FunctionBuilder,
3068
- state: &mut FuncTranslationState,
3069
- environ: &mut FE,
3070
- ) -> WasmResult<()> {
3071
- let (mut expected, mut replacement) = state.pop2();
3072
- let expected_ty = builder.func.dfg.value_type(expected);
3073
- let replacement_ty = builder.func.dfg.value_type(replacement);
3074
-
3075
- // The compare-and-swap is performed at type `access_ty`, and the old value is zero-extended
3076
- // to type `widened_ty`.
3077
- match access_ty {
3078
- I8 | I16 | I32 | I64 => {}
3079
- _ => {
3080
- return Err(wasm_unsupported!(
3081
- "atomic_cas: unsupported access type {:?}",
3082
- access_ty
3083
- ))
3084
- }
3085
- };
3086
- let w_ty_ok = match widened_ty {
3087
- I32 | I64 => true,
3088
- _ => false,
3089
- };
3090
- assert!(w_ty_ok && widened_ty.bytes() >= access_ty.bytes());
3091
-
3092
- assert!(expected_ty.bytes() >= access_ty.bytes());
3093
- if expected_ty.bytes() > access_ty.bytes() {
3094
- expected = builder.ins().ireduce(access_ty, expected);
3095
- }
3096
- assert!(replacement_ty.bytes() >= access_ty.bytes());
3097
- if replacement_ty.bytes() > access_ty.bytes() {
3098
- replacement = builder.ins().ireduce(access_ty, replacement);
3099
- }
3100
-
3101
- let (flags, _, addr) = unwrap_or_return_unreachable_state!(
3102
- state,
3103
- prepare_atomic_addr(
3104
- memarg,
3105
- u8::try_from(access_ty.bytes()).unwrap(),
3106
- builder,
3107
- state,
3108
- environ,
3109
- )?
3110
- );
3111
- let mut res = builder.ins().atomic_cas(flags, addr, expected, replacement);
3112
- if access_ty != widened_ty {
3113
- res = builder.ins().uextend(widened_ty, res);
3114
- }
3115
- state.push1(res);
3116
- Ok(())
3117
- }
3118
-
3119
- fn translate_atomic_load<FE: FuncEnvironment + ?Sized>(
3120
- widened_ty: Type,
3121
- access_ty: Type,
3122
- memarg: &MemArg,
3123
- builder: &mut FunctionBuilder,
3124
- state: &mut FuncTranslationState,
3125
- environ: &mut FE,
3126
- ) -> WasmResult<()> {
3127
- // The load is performed at type `access_ty`, and the loaded value is zero extended
3128
- // to `widened_ty`.
3129
- match access_ty {
3130
- I8 | I16 | I32 | I64 => {}
3131
- _ => {
3132
- return Err(wasm_unsupported!(
3133
- "atomic_load: unsupported access type {:?}",
3134
- access_ty
3135
- ))
3136
- }
3137
- };
3138
- let w_ty_ok = match widened_ty {
3139
- I32 | I64 => true,
3140
- _ => false,
3141
- };
3142
- assert!(w_ty_ok && widened_ty.bytes() >= access_ty.bytes());
3143
-
3144
- let (flags, _, addr) = unwrap_or_return_unreachable_state!(
3145
- state,
3146
- prepare_atomic_addr(
3147
- memarg,
3148
- u8::try_from(access_ty.bytes()).unwrap(),
3149
- builder,
3150
- state,
3151
- environ,
3152
- )?
3153
- );
3154
- let mut res = builder.ins().atomic_load(access_ty, flags, addr);
3155
- if access_ty != widened_ty {
3156
- res = builder.ins().uextend(widened_ty, res);
3157
- }
3158
- state.push1(res);
3159
- Ok(())
3160
- }
3161
-
3162
- fn translate_atomic_store<FE: FuncEnvironment + ?Sized>(
3163
- access_ty: Type,
3164
- memarg: &MemArg,
3165
- builder: &mut FunctionBuilder,
3166
- state: &mut FuncTranslationState,
3167
- environ: &mut FE,
3168
- ) -> WasmResult<()> {
3169
- let mut data = state.pop1();
3170
- let data_ty = builder.func.dfg.value_type(data);
3171
-
3172
- // The operation is performed at type `access_ty`, and the data to be stored may first
3173
- // need to be narrowed accordingly.
3174
- match access_ty {
3175
- I8 | I16 | I32 | I64 => {}
3176
- _ => {
3177
- return Err(wasm_unsupported!(
3178
- "atomic_store: unsupported access type {:?}",
3179
- access_ty
3180
- ))
3181
- }
3182
- };
3183
- let d_ty_ok = match data_ty {
3184
- I32 | I64 => true,
3185
- _ => false,
3186
- };
3187
- assert!(d_ty_ok && data_ty.bytes() >= access_ty.bytes());
3188
-
3189
- if data_ty.bytes() > access_ty.bytes() {
3190
- data = builder.ins().ireduce(access_ty, data);
3191
- }
3192
-
3193
- let (flags, _, addr) = unwrap_or_return_unreachable_state!(
3194
- state,
3195
- prepare_atomic_addr(
3196
- memarg,
3197
- u8::try_from(access_ty.bytes()).unwrap(),
3198
- builder,
3199
- state,
3200
- environ,
3201
- )?
3202
- );
3203
- builder.ins().atomic_store(flags, data, addr);
3204
- Ok(())
3205
- }
3206
-
3207
- fn translate_vector_icmp(
3208
- cc: IntCC,
3209
- needed_type: Type,
3210
- builder: &mut FunctionBuilder,
3211
- state: &mut FuncTranslationState,
3212
- ) {
3213
- let (a, b) = state.pop2();
3214
- let bitcast_a = optionally_bitcast_vector(a, needed_type, builder);
3215
- let bitcast_b = optionally_bitcast_vector(b, needed_type, builder);
3216
- state.push1(builder.ins().icmp(cc, bitcast_a, bitcast_b))
3217
- }
3218
-
3219
- fn translate_fcmp(cc: FloatCC, builder: &mut FunctionBuilder, state: &mut FuncTranslationState) {
3220
- let (arg0, arg1) = state.pop2();
3221
- let val = builder.ins().fcmp(cc, arg0, arg1);
3222
- state.push1(builder.ins().uextend(I32, val));
3223
- }
3224
-
3225
- fn translate_vector_fcmp(
3226
- cc: FloatCC,
3227
- needed_type: Type,
3228
- builder: &mut FunctionBuilder,
3229
- state: &mut FuncTranslationState,
3230
- ) {
3231
- let (a, b) = state.pop2();
3232
- let bitcast_a = optionally_bitcast_vector(a, needed_type, builder);
3233
- let bitcast_b = optionally_bitcast_vector(b, needed_type, builder);
3234
- state.push1(builder.ins().fcmp(cc, bitcast_a, bitcast_b))
3235
- }
3236
-
3237
- fn translate_br_if(
3238
- relative_depth: u32,
3239
- builder: &mut FunctionBuilder,
3240
- state: &mut FuncTranslationState,
3241
- ) {
3242
- let val = state.pop1();
3243
- let (br_destination, inputs) = translate_br_if_args(relative_depth, state);
3244
- let next_block = builder.create_block();
3245
- canonicalise_brif(builder, val, br_destination, inputs, next_block, &[]);
3246
-
3247
- builder.seal_block(next_block); // The only predecessor is the current block.
3248
- builder.switch_to_block(next_block);
3249
- }
3250
-
3251
- fn translate_br_if_args(
3252
- relative_depth: u32,
3253
- state: &mut FuncTranslationState,
3254
- ) -> (ir::Block, &mut [ir::Value]) {
3255
- let i = state.control_stack.len() - 1 - (relative_depth as usize);
3256
- let (return_count, br_destination) = {
3257
- let frame = &mut state.control_stack[i];
3258
- // The values returned by the branch are still available for the reachable
3259
- // code that comes after it
3260
- frame.set_branched_to_exit();
3261
- let return_count = if frame.is_loop() {
3262
- frame.num_param_values()
3263
- } else {
3264
- frame.num_return_values()
3265
- };
3266
- (return_count, frame.br_destination())
3267
- };
3268
- let inputs = state.peekn_mut(return_count);
3269
- (br_destination, inputs)
3270
- }
3271
-
3272
- /// Determine the returned value type of a WebAssembly operator
3273
- fn type_of(operator: &Operator) -> Type {
3274
- match operator {
3275
- Operator::V128Load { .. }
3276
- | Operator::V128Store { .. }
3277
- | Operator::V128Const { .. }
3278
- | Operator::V128Not
3279
- | Operator::V128And
3280
- | Operator::V128AndNot
3281
- | Operator::V128Or
3282
- | Operator::V128Xor
3283
- | Operator::V128AnyTrue
3284
- | Operator::V128Bitselect => I8X16, // default type representing V128
3285
-
3286
- Operator::I8x16Shuffle { .. }
3287
- | Operator::I8x16Splat
3288
- | Operator::V128Load8Splat { .. }
3289
- | Operator::V128Load8Lane { .. }
3290
- | Operator::V128Store8Lane { .. }
3291
- | Operator::I8x16ExtractLaneS { .. }
3292
- | Operator::I8x16ExtractLaneU { .. }
3293
- | Operator::I8x16ReplaceLane { .. }
3294
- | Operator::I8x16Eq
3295
- | Operator::I8x16Ne
3296
- | Operator::I8x16LtS
3297
- | Operator::I8x16LtU
3298
- | Operator::I8x16GtS
3299
- | Operator::I8x16GtU
3300
- | Operator::I8x16LeS
3301
- | Operator::I8x16LeU
3302
- | Operator::I8x16GeS
3303
- | Operator::I8x16GeU
3304
- | Operator::I8x16Neg
3305
- | Operator::I8x16Abs
3306
- | Operator::I8x16AllTrue
3307
- | Operator::I8x16Shl
3308
- | Operator::I8x16ShrS
3309
- | Operator::I8x16ShrU
3310
- | Operator::I8x16Add
3311
- | Operator::I8x16AddSatS
3312
- | Operator::I8x16AddSatU
3313
- | Operator::I8x16Sub
3314
- | Operator::I8x16SubSatS
3315
- | Operator::I8x16SubSatU
3316
- | Operator::I8x16MinS
3317
- | Operator::I8x16MinU
3318
- | Operator::I8x16MaxS
3319
- | Operator::I8x16MaxU
3320
- | Operator::I8x16AvgrU
3321
- | Operator::I8x16Bitmask
3322
- | Operator::I8x16Popcnt
3323
- | Operator::I8x16RelaxedLaneselect => I8X16,
3324
-
3325
- Operator::I16x8Splat
3326
- | Operator::V128Load16Splat { .. }
3327
- | Operator::V128Load16Lane { .. }
3328
- | Operator::V128Store16Lane { .. }
3329
- | Operator::I16x8ExtractLaneS { .. }
3330
- | Operator::I16x8ExtractLaneU { .. }
3331
- | Operator::I16x8ReplaceLane { .. }
3332
- | Operator::I16x8Eq
3333
- | Operator::I16x8Ne
3334
- | Operator::I16x8LtS
3335
- | Operator::I16x8LtU
3336
- | Operator::I16x8GtS
3337
- | Operator::I16x8GtU
3338
- | Operator::I16x8LeS
3339
- | Operator::I16x8LeU
3340
- | Operator::I16x8GeS
3341
- | Operator::I16x8GeU
3342
- | Operator::I16x8Neg
3343
- | Operator::I16x8Abs
3344
- | Operator::I16x8AllTrue
3345
- | Operator::I16x8Shl
3346
- | Operator::I16x8ShrS
3347
- | Operator::I16x8ShrU
3348
- | Operator::I16x8Add
3349
- | Operator::I16x8AddSatS
3350
- | Operator::I16x8AddSatU
3351
- | Operator::I16x8Sub
3352
- | Operator::I16x8SubSatS
3353
- | Operator::I16x8SubSatU
3354
- | Operator::I16x8MinS
3355
- | Operator::I16x8MinU
3356
- | Operator::I16x8MaxS
3357
- | Operator::I16x8MaxU
3358
- | Operator::I16x8AvgrU
3359
- | Operator::I16x8Mul
3360
- | Operator::I16x8Bitmask
3361
- | Operator::I16x8RelaxedLaneselect => I16X8,
3362
-
3363
- Operator::I32x4Splat
3364
- | Operator::V128Load32Splat { .. }
3365
- | Operator::V128Load32Lane { .. }
3366
- | Operator::V128Store32Lane { .. }
3367
- | Operator::I32x4ExtractLane { .. }
3368
- | Operator::I32x4ReplaceLane { .. }
3369
- | Operator::I32x4Eq
3370
- | Operator::I32x4Ne
3371
- | Operator::I32x4LtS
3372
- | Operator::I32x4LtU
3373
- | Operator::I32x4GtS
3374
- | Operator::I32x4GtU
3375
- | Operator::I32x4LeS
3376
- | Operator::I32x4LeU
3377
- | Operator::I32x4GeS
3378
- | Operator::I32x4GeU
3379
- | Operator::I32x4Neg
3380
- | Operator::I32x4Abs
3381
- | Operator::I32x4AllTrue
3382
- | Operator::I32x4Shl
3383
- | Operator::I32x4ShrS
3384
- | Operator::I32x4ShrU
3385
- | Operator::I32x4Add
3386
- | Operator::I32x4Sub
3387
- | Operator::I32x4Mul
3388
- | Operator::I32x4MinS
3389
- | Operator::I32x4MinU
3390
- | Operator::I32x4MaxS
3391
- | Operator::I32x4MaxU
3392
- | Operator::I32x4Bitmask
3393
- | Operator::I32x4TruncSatF32x4S
3394
- | Operator::I32x4TruncSatF32x4U
3395
- | Operator::I32x4RelaxedLaneselect
3396
- | Operator::V128Load32Zero { .. } => I32X4,
3397
-
3398
- Operator::I64x2Splat
3399
- | Operator::V128Load64Splat { .. }
3400
- | Operator::V128Load64Lane { .. }
3401
- | Operator::V128Store64Lane { .. }
3402
- | Operator::I64x2ExtractLane { .. }
3403
- | Operator::I64x2ReplaceLane { .. }
3404
- | Operator::I64x2Eq
3405
- | Operator::I64x2Ne
3406
- | Operator::I64x2LtS
3407
- | Operator::I64x2GtS
3408
- | Operator::I64x2LeS
3409
- | Operator::I64x2GeS
3410
- | Operator::I64x2Neg
3411
- | Operator::I64x2Abs
3412
- | Operator::I64x2AllTrue
3413
- | Operator::I64x2Shl
3414
- | Operator::I64x2ShrS
3415
- | Operator::I64x2ShrU
3416
- | Operator::I64x2Add
3417
- | Operator::I64x2Sub
3418
- | Operator::I64x2Mul
3419
- | Operator::I64x2Bitmask
3420
- | Operator::I64x2RelaxedLaneselect
3421
- | Operator::V128Load64Zero { .. } => I64X2,
3422
-
3423
- Operator::F32x4Splat
3424
- | Operator::F32x4ExtractLane { .. }
3425
- | Operator::F32x4ReplaceLane { .. }
3426
- | Operator::F32x4Eq
3427
- | Operator::F32x4Ne
3428
- | Operator::F32x4Lt
3429
- | Operator::F32x4Gt
3430
- | Operator::F32x4Le
3431
- | Operator::F32x4Ge
3432
- | Operator::F32x4Abs
3433
- | Operator::F32x4Neg
3434
- | Operator::F32x4Sqrt
3435
- | Operator::F32x4Add
3436
- | Operator::F32x4Sub
3437
- | Operator::F32x4Mul
3438
- | Operator::F32x4Div
3439
- | Operator::F32x4Min
3440
- | Operator::F32x4Max
3441
- | Operator::F32x4PMin
3442
- | Operator::F32x4PMax
3443
- | Operator::F32x4ConvertI32x4S
3444
- | Operator::F32x4ConvertI32x4U
3445
- | Operator::F32x4Ceil
3446
- | Operator::F32x4Floor
3447
- | Operator::F32x4Trunc
3448
- | Operator::F32x4Nearest
3449
- | Operator::F32x4RelaxedMax
3450
- | Operator::F32x4RelaxedMin
3451
- | Operator::F32x4RelaxedMadd
3452
- | Operator::F32x4RelaxedNmadd => F32X4,
3453
-
3454
- Operator::F64x2Splat
3455
- | Operator::F64x2ExtractLane { .. }
3456
- | Operator::F64x2ReplaceLane { .. }
3457
- | Operator::F64x2Eq
3458
- | Operator::F64x2Ne
3459
- | Operator::F64x2Lt
3460
- | Operator::F64x2Gt
3461
- | Operator::F64x2Le
3462
- | Operator::F64x2Ge
3463
- | Operator::F64x2Abs
3464
- | Operator::F64x2Neg
3465
- | Operator::F64x2Sqrt
3466
- | Operator::F64x2Add
3467
- | Operator::F64x2Sub
3468
- | Operator::F64x2Mul
3469
- | Operator::F64x2Div
3470
- | Operator::F64x2Min
3471
- | Operator::F64x2Max
3472
- | Operator::F64x2PMin
3473
- | Operator::F64x2PMax
3474
- | Operator::F64x2Ceil
3475
- | Operator::F64x2Floor
3476
- | Operator::F64x2Trunc
3477
- | Operator::F64x2Nearest
3478
- | Operator::F64x2RelaxedMax
3479
- | Operator::F64x2RelaxedMin
3480
- | Operator::F64x2RelaxedMadd
3481
- | Operator::F64x2RelaxedNmadd => F64X2,
3482
-
3483
- _ => unimplemented!(
3484
- "Currently only SIMD instructions are mapped to their return type; the \
3485
- following instruction is not mapped: {:?}",
3486
- operator
3487
- ),
3488
- }
3489
- }
3490
-
3491
- /// Some SIMD operations only operate on I8X16 in CLIF; this will convert them to that type by
3492
- /// adding a bitcast if necessary.
3493
- fn optionally_bitcast_vector(
3494
- value: Value,
3495
- needed_type: Type,
3496
- builder: &mut FunctionBuilder,
3497
- ) -> Value {
3498
- if builder.func.dfg.value_type(value) != needed_type {
3499
- let mut flags = MemFlags::new();
3500
- flags.set_endianness(ir::Endianness::Little);
3501
- builder.ins().bitcast(needed_type, flags, value)
3502
- } else {
3503
- value
3504
- }
3505
- }
3506
-
3507
- #[inline(always)]
3508
- fn is_non_canonical_v128(ty: ir::Type) -> bool {
3509
- match ty {
3510
- I64X2 | I32X4 | I16X8 | F32X4 | F64X2 => true,
3511
- _ => false,
3512
- }
3513
- }
3514
-
3515
- /// Cast to I8X16, any vector values in `values` that are of "non-canonical" type (meaning, not
3516
- /// I8X16), and return them in a slice. A pre-scan is made to determine whether any casts are
3517
- /// actually necessary, and if not, the original slice is returned. Otherwise the cast values
3518
- /// are returned in a slice that belongs to the caller-supplied `SmallVec`.
3519
- fn canonicalise_v128_values<'a>(
3520
- tmp_canonicalised: &'a mut SmallVec<[ir::Value; 16]>,
3521
- builder: &mut FunctionBuilder,
3522
- values: &'a [ir::Value],
3523
- ) -> &'a [ir::Value] {
3524
- debug_assert!(tmp_canonicalised.is_empty());
3525
- // First figure out if any of the parameters need to be cast. Mostly they don't need to be.
3526
- let any_non_canonical = values
3527
- .iter()
3528
- .any(|v| is_non_canonical_v128(builder.func.dfg.value_type(*v)));
3529
- // Hopefully we take this exit most of the time, hence doing no heap allocation.
3530
- if !any_non_canonical {
3531
- return values;
3532
- }
3533
- // Otherwise we'll have to cast, and push the resulting `Value`s into `canonicalised`.
3534
- for v in values {
3535
- tmp_canonicalised.push(if is_non_canonical_v128(builder.func.dfg.value_type(*v)) {
3536
- let mut flags = MemFlags::new();
3537
- flags.set_endianness(ir::Endianness::Little);
3538
- builder.ins().bitcast(I8X16, flags, *v)
3539
- } else {
3540
- *v
3541
- });
3542
- }
3543
- tmp_canonicalised.as_slice()
3544
- }
3545
-
3546
- /// Generate a `jump` instruction, but first cast all 128-bit vector values to I8X16 if they
3547
- /// don't have that type. This is done in somewhat roundabout way so as to ensure that we
3548
- /// almost never have to do any heap allocation.
3549
- fn canonicalise_then_jump(
3550
- builder: &mut FunctionBuilder,
3551
- destination: ir::Block,
3552
- params: &[ir::Value],
3553
- ) -> ir::Inst {
3554
- let mut tmp_canonicalised = SmallVec::<[ir::Value; 16]>::new();
3555
- let canonicalised = canonicalise_v128_values(&mut tmp_canonicalised, builder, params);
3556
- builder.ins().jump(destination, canonicalised)
3557
- }
3558
-
3559
- /// The same but for a `brif` instruction.
3560
- fn canonicalise_brif(
3561
- builder: &mut FunctionBuilder,
3562
- cond: ir::Value,
3563
- block_then: ir::Block,
3564
- params_then: &[ir::Value],
3565
- block_else: ir::Block,
3566
- params_else: &[ir::Value],
3567
- ) -> ir::Inst {
3568
- let mut tmp_canonicalised_then = SmallVec::<[ir::Value; 16]>::new();
3569
- let canonicalised_then =
3570
- canonicalise_v128_values(&mut tmp_canonicalised_then, builder, params_then);
3571
- let mut tmp_canonicalised_else = SmallVec::<[ir::Value; 16]>::new();
3572
- let canonicalised_else =
3573
- canonicalise_v128_values(&mut tmp_canonicalised_else, builder, params_else);
3574
- builder.ins().brif(
3575
- cond,
3576
- block_then,
3577
- canonicalised_then,
3578
- block_else,
3579
- canonicalised_else,
3580
- )
3581
- }
3582
-
3583
- /// A helper for popping and bitcasting a single value; since SIMD values can lose their type by
3584
- /// using v128 (i.e. CLIF's I8x16) we must re-type the values using a bitcast to avoid CLIF
3585
- /// typing issues.
3586
- fn pop1_with_bitcast(
3587
- state: &mut FuncTranslationState,
3588
- needed_type: Type,
3589
- builder: &mut FunctionBuilder,
3590
- ) -> Value {
3591
- optionally_bitcast_vector(state.pop1(), needed_type, builder)
3592
- }
3593
-
3594
- /// A helper for popping and bitcasting two values; since SIMD values can lose their type by
3595
- /// using v128 (i.e. CLIF's I8x16) we must re-type the values using a bitcast to avoid CLIF
3596
- /// typing issues.
3597
- fn pop2_with_bitcast(
3598
- state: &mut FuncTranslationState,
3599
- needed_type: Type,
3600
- builder: &mut FunctionBuilder,
3601
- ) -> (Value, Value) {
3602
- let (a, b) = state.pop2();
3603
- let bitcast_a = optionally_bitcast_vector(a, needed_type, builder);
3604
- let bitcast_b = optionally_bitcast_vector(b, needed_type, builder);
3605
- (bitcast_a, bitcast_b)
3606
- }
3607
-
3608
- fn pop3_with_bitcast(
3609
- state: &mut FuncTranslationState,
3610
- needed_type: Type,
3611
- builder: &mut FunctionBuilder,
3612
- ) -> (Value, Value, Value) {
3613
- let (a, b, c) = state.pop3();
3614
- let bitcast_a = optionally_bitcast_vector(a, needed_type, builder);
3615
- let bitcast_b = optionally_bitcast_vector(b, needed_type, builder);
3616
- let bitcast_c = optionally_bitcast_vector(c, needed_type, builder);
3617
- (bitcast_a, bitcast_b, bitcast_c)
3618
- }
3619
-
3620
- fn bitcast_arguments<'a>(
3621
- builder: &FunctionBuilder,
3622
- arguments: &'a mut [Value],
3623
- params: &[ir::AbiParam],
3624
- param_predicate: impl Fn(usize) -> bool,
3625
- ) -> Vec<(Type, &'a mut Value)> {
3626
- let filtered_param_types = params
3627
- .iter()
3628
- .enumerate()
3629
- .filter(|(i, _)| param_predicate(*i))
3630
- .map(|(_, param)| param.value_type);
3631
-
3632
- // zip_eq, from the itertools::Itertools trait, is like Iterator::zip but panics if one
3633
- // iterator ends before the other. The `param_predicate` is required to select exactly as many
3634
- // elements of `params` as there are elements in `arguments`.
3635
- let pairs = filtered_param_types.zip_eq(arguments.iter_mut());
3636
-
3637
- // The arguments which need to be bitcasted are those which have some vector type but the type
3638
- // expected by the parameter is not the same vector type as that of the provided argument.
3639
- pairs
3640
- .filter(|(param_type, _)| param_type.is_vector())
3641
- .filter(|(param_type, arg)| {
3642
- let arg_type = builder.func.dfg.value_type(**arg);
3643
- assert!(
3644
- arg_type.is_vector(),
3645
- "unexpected type mismatch: expected {}, argument {} was actually of type {}",
3646
- param_type,
3647
- *arg,
3648
- arg_type
3649
- );
3650
-
3651
- // This is the same check that would be done by `optionally_bitcast_vector`, except we
3652
- // can't take a mutable borrow of the FunctionBuilder here, so we defer inserting the
3653
- // bitcast instruction to the caller.
3654
- arg_type != *param_type
3655
- })
3656
- .collect()
3657
- }
3658
-
3659
- /// A helper for bitcasting a sequence of return values for the function currently being built. If
3660
- /// a value is a vector type that does not match its expected type, this will modify the value in
3661
- /// place to point to the result of a `bitcast`. This conversion is necessary to translate Wasm
3662
- /// code that uses `V128` as function parameters (or implicitly in block parameters) and still use
3663
- /// specific CLIF types (e.g. `I32X4`) in the function body.
3664
- pub fn bitcast_wasm_returns<FE: FuncEnvironment + ?Sized>(
3665
- environ: &mut FE,
3666
- arguments: &mut [Value],
3667
- builder: &mut FunctionBuilder,
3668
- ) {
3669
- let changes = bitcast_arguments(builder, arguments, &builder.func.signature.returns, |i| {
3670
- environ.is_wasm_return(&builder.func.signature, i)
3671
- });
3672
- for (t, arg) in changes {
3673
- let mut flags = MemFlags::new();
3674
- flags.set_endianness(ir::Endianness::Little);
3675
- *arg = builder.ins().bitcast(t, flags, *arg);
3676
- }
3677
- }
3678
-
3679
- /// Like `bitcast_wasm_returns`, but for the parameters being passed to a specified callee.
3680
- fn bitcast_wasm_params<FE: FuncEnvironment + ?Sized>(
3681
- environ: &mut FE,
3682
- callee_signature: ir::SigRef,
3683
- arguments: &mut [Value],
3684
- builder: &mut FunctionBuilder,
3685
- ) {
3686
- let callee_signature = &builder.func.dfg.signatures[callee_signature];
3687
- let changes = bitcast_arguments(builder, arguments, &callee_signature.params, |i| {
3688
- environ.is_wasm_parameter(&callee_signature, i)
3689
- });
3690
- for (t, arg) in changes {
3691
- let mut flags = MemFlags::new();
3692
- flags.set_endianness(ir::Endianness::Little);
3693
- *arg = builder.ins().bitcast(t, flags, *arg);
3694
- }
3695
- }