wasmtime 22.0.0 → 23.0.2

Sign up to get free protection for your applications and to get access to all the features.
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,4287 +0,0 @@
1
- use crate::ir;
2
- use crate::ir::immediates::{Ieee32, Ieee64};
3
- use crate::ir::KnownSymbol;
4
- use crate::isa::x64::encoding::evex::{EvexInstruction, EvexVectorLength, RegisterOrAmode};
5
- use crate::isa::x64::encoding::rex::{
6
- emit_simm, emit_std_enc_enc, emit_std_enc_mem, emit_std_reg_mem, emit_std_reg_reg, int_reg_enc,
7
- low8_will_sign_extend_to_32, low8_will_sign_extend_to_64, reg_enc, LegacyPrefixes, OpcodeMap,
8
- RexFlags,
9
- };
10
- use crate::isa::x64::encoding::vex::{VexInstruction, VexVectorLength};
11
- use crate::isa::x64::inst::args::*;
12
- use crate::isa::x64::inst::*;
13
-
14
- /// A small helper to generate a signed conversion instruction.
15
- fn emit_signed_cvt(
16
- sink: &mut MachBuffer<Inst>,
17
- info: &EmitInfo,
18
- state: &mut EmitState,
19
- // Required to be RealRegs.
20
- src: Reg,
21
- dst: Writable<Reg>,
22
- to_f64: bool,
23
- ) {
24
- // Handle an unsigned int, which is the "easy" case: a signed conversion will do the
25
- // right thing.
26
- let op = if to_f64 {
27
- SseOpcode::Cvtsi2sd
28
- } else {
29
- SseOpcode::Cvtsi2ss
30
- };
31
- let dst = WritableXmm::from_writable_reg(dst).unwrap();
32
- Inst::CvtIntToFloat {
33
- op,
34
- dst,
35
- src1: dst.to_reg(),
36
- src2: GprMem::new(RegMem::reg(src)).unwrap(),
37
- src2_size: OperandSize::Size64,
38
- }
39
- .emit(sink, info, state);
40
- }
41
-
42
- /// Emits a one way conditional jump if CC is set (true).
43
- fn one_way_jmp(sink: &mut MachBuffer<Inst>, cc: CC, label: MachLabel) {
44
- let cond_start = sink.cur_offset();
45
- let cond_disp_off = cond_start + 2;
46
- sink.use_label_at_offset(cond_disp_off, label, LabelUse::JmpRel32);
47
- sink.put1(0x0F);
48
- sink.put1(0x80 + cc.get_enc());
49
- sink.put4(0x0);
50
- }
51
-
52
- /// Emits a relocation, attaching the current source location as well.
53
- fn emit_reloc(sink: &mut MachBuffer<Inst>, kind: Reloc, name: &ExternalName, addend: Addend) {
54
- sink.add_reloc(kind, name, addend);
55
- }
56
-
57
- /// The top-level emit function.
58
- ///
59
- /// Important! Do not add improved (shortened) encoding cases to existing
60
- /// instructions without also adding tests for those improved encodings. That
61
- /// is a dangerous game that leads to hard-to-track-down errors in the emitted
62
- /// code.
63
- ///
64
- /// For all instructions, make sure to have test coverage for all of the
65
- /// following situations. Do this by creating the cross product resulting from
66
- /// applying the following rules to each operand:
67
- ///
68
- /// (1) for any insn that mentions a register: one test using a register from
69
- /// the group [rax, rcx, rdx, rbx, rsp, rbp, rsi, rdi] and a second one
70
- /// using a register from the group [r8, r9, r10, r11, r12, r13, r14, r15].
71
- /// This helps detect incorrect REX prefix construction.
72
- ///
73
- /// (2) for any insn that mentions a byte register: one test for each of the
74
- /// four encoding groups [al, cl, dl, bl], [spl, bpl, sil, dil],
75
- /// [r8b .. r11b] and [r12b .. r15b]. This checks that
76
- /// apparently-redundant REX prefixes are retained when required.
77
- ///
78
- /// (3) for any insn that contains an immediate field, check the following
79
- /// cases: field is zero, field is in simm8 range (-128 .. 127), field is
80
- /// in simm32 range (-0x8000_0000 .. 0x7FFF_FFFF). This is because some
81
- /// instructions that require a 32-bit immediate have a short-form encoding
82
- /// when the imm is in simm8 range.
83
- ///
84
- /// Rules (1), (2) and (3) don't apply for registers within address expressions
85
- /// (`Addr`s). Those are already pretty well tested, and the registers in them
86
- /// don't have any effect on the containing instruction (apart from possibly
87
- /// require REX prefix bits).
88
- ///
89
- /// When choosing registers for a test, avoid using registers with the same
90
- /// offset within a given group. For example, don't use rax and r8, since they
91
- /// both have the lowest 3 bits as 000, and so the test won't detect errors
92
- /// where those 3-bit register sub-fields are confused by the emitter. Instead
93
- /// use (eg) rax (lo3 = 000) and r9 (lo3 = 001). Similarly, don't use (eg) cl
94
- /// and bpl since they have the same offset in their group; use instead (eg) cl
95
- /// and sil.
96
- ///
97
- /// For all instructions, also add a test that uses only low-half registers
98
- /// (rax .. rdi, xmm0 .. xmm7) etc, so as to check that any redundant REX
99
- /// prefixes are correctly omitted. This low-half restriction must apply to
100
- /// _all_ registers in the insn, even those in address expressions.
101
- ///
102
- /// Following these rules creates large numbers of test cases, but it's the
103
- /// only way to make the emitter reliable.
104
- ///
105
- /// Known possible improvements:
106
- ///
107
- /// * there's a shorter encoding for shl/shr/sar by a 1-bit immediate. (Do we
108
- /// care?)
109
- pub(crate) fn emit(
110
- inst: &Inst,
111
- sink: &mut MachBuffer<Inst>,
112
- info: &EmitInfo,
113
- state: &mut EmitState,
114
- ) {
115
- let matches_isa_flags = |iset_requirement: &InstructionSet| -> bool {
116
- match iset_requirement {
117
- // Cranelift assumes SSE2 at least.
118
- InstructionSet::SSE | InstructionSet::SSE2 => true,
119
- InstructionSet::SSSE3 => info.isa_flags.use_ssse3(),
120
- InstructionSet::SSE41 => info.isa_flags.use_sse41(),
121
- InstructionSet::SSE42 => info.isa_flags.use_sse42(),
122
- InstructionSet::Popcnt => info.isa_flags.use_popcnt(),
123
- InstructionSet::Lzcnt => info.isa_flags.use_lzcnt(),
124
- InstructionSet::BMI1 => info.isa_flags.use_bmi1(),
125
- InstructionSet::BMI2 => info.isa_flags.has_bmi2(),
126
- InstructionSet::FMA => info.isa_flags.has_fma(),
127
- InstructionSet::AVX => info.isa_flags.has_avx(),
128
- InstructionSet::AVX2 => info.isa_flags.has_avx2(),
129
- InstructionSet::AVX512BITALG => info.isa_flags.has_avx512bitalg(),
130
- InstructionSet::AVX512DQ => info.isa_flags.has_avx512dq(),
131
- InstructionSet::AVX512F => info.isa_flags.has_avx512f(),
132
- InstructionSet::AVX512VBMI => info.isa_flags.has_avx512vbmi(),
133
- InstructionSet::AVX512VL => info.isa_flags.has_avx512vl(),
134
- }
135
- };
136
-
137
- // Certain instructions may be present in more than one ISA feature set; we must at least match
138
- // one of them in the target CPU.
139
- let isa_requirements = inst.available_in_any_isa();
140
- if !isa_requirements.is_empty() && !isa_requirements.iter().all(matches_isa_flags) {
141
- panic!(
142
- "Cannot emit inst '{:?}' for target; failed to match ISA requirements: {:?}",
143
- inst, isa_requirements
144
- )
145
- }
146
-
147
- match inst {
148
- Inst::AluRmiR {
149
- size,
150
- op,
151
- src1,
152
- src2,
153
- dst: reg_g,
154
- } => {
155
- let src1 = src1.to_reg();
156
- let reg_g = reg_g.to_reg().to_reg();
157
- debug_assert_eq!(src1, reg_g);
158
- let src2 = src2.clone().to_reg_mem_imm().clone();
159
-
160
- let prefix = if *size == OperandSize::Size16 {
161
- LegacyPrefixes::_66
162
- } else {
163
- LegacyPrefixes::None
164
- };
165
-
166
- let mut rex = RexFlags::from(*size);
167
- let (opcode_r, opcode_m, subopcode_i) = match op {
168
- AluRmiROpcode::Add => (0x01, 0x03, 0),
169
- AluRmiROpcode::Adc => (0x11, 0x03, 0),
170
- AluRmiROpcode::Sub => (0x29, 0x2B, 5),
171
- AluRmiROpcode::Sbb => (0x19, 0x2B, 5),
172
- AluRmiROpcode::And => (0x21, 0x23, 4),
173
- AluRmiROpcode::Or => (0x09, 0x0B, 1),
174
- AluRmiROpcode::Xor => (0x31, 0x33, 6),
175
- };
176
-
177
- let (opcode_r, opcode_m) = if *size == OperandSize::Size8 {
178
- (opcode_r - 1, opcode_m - 1)
179
- } else {
180
- (opcode_r, opcode_m)
181
- };
182
-
183
- if *size == OperandSize::Size8 {
184
- debug_assert!(reg_g.is_real());
185
- rex.always_emit_if_8bit_needed(reg_g);
186
- }
187
-
188
- match src2 {
189
- RegMemImm::Reg { reg: reg_e } => {
190
- if *size == OperandSize::Size8 {
191
- debug_assert!(reg_e.is_real());
192
- rex.always_emit_if_8bit_needed(reg_e);
193
- }
194
-
195
- // GCC/llvm use the swapped operand encoding (viz., the R/RM vs RM/R
196
- // duality). Do this too, so as to be able to compare generated machine
197
- // code easily.
198
- emit_std_reg_reg(sink, prefix, opcode_r, 1, reg_e, reg_g, rex);
199
- }
200
-
201
- RegMemImm::Mem { addr } => {
202
- let amode = addr.finalize(state, sink);
203
- // Here we revert to the "normal" G-E ordering.
204
- emit_std_reg_mem(sink, prefix, opcode_m, 1, reg_g, &amode, rex, 0);
205
- }
206
-
207
- RegMemImm::Imm { simm32 } => {
208
- let imm_size = if *size == OperandSize::Size8 {
209
- 1
210
- } else {
211
- if low8_will_sign_extend_to_32(simm32) {
212
- 1
213
- } else {
214
- if *size == OperandSize::Size16 {
215
- 2
216
- } else {
217
- 4
218
- }
219
- }
220
- };
221
-
222
- let opcode = if *size == OperandSize::Size8 {
223
- 0x80
224
- } else if low8_will_sign_extend_to_32(simm32) {
225
- 0x83
226
- } else {
227
- 0x81
228
- };
229
-
230
- // And also here we use the "normal" G-E ordering.
231
- let enc_g = int_reg_enc(reg_g);
232
- emit_std_enc_enc(sink, prefix, opcode, 1, subopcode_i, enc_g, rex);
233
- emit_simm(sink, imm_size, simm32);
234
- }
235
- }
236
- }
237
-
238
- &Inst::AluConstOp { op, size, dst } => {
239
- let dst = WritableGpr::from_writable_reg(dst.to_writable_reg()).unwrap();
240
- emit(
241
- &Inst::AluRmiR {
242
- size,
243
- op,
244
- dst,
245
- src1: dst.to_reg(),
246
- src2: dst.to_reg().into(),
247
- },
248
- sink,
249
- info,
250
- state,
251
- );
252
- }
253
-
254
- Inst::AluRM {
255
- size,
256
- src1_dst,
257
- src2,
258
- op,
259
- } => {
260
- let src2 = src2.to_reg();
261
- let src1_dst = src1_dst.finalize(state, sink).clone();
262
-
263
- let opcode = match op {
264
- AluRmiROpcode::Add => 0x01,
265
- AluRmiROpcode::Sub => 0x29,
266
- AluRmiROpcode::And => 0x21,
267
- AluRmiROpcode::Or => 0x09,
268
- AluRmiROpcode::Xor => 0x31,
269
- _ => panic!("Unsupported read-modify-write ALU opcode"),
270
- };
271
-
272
- let prefix = if *size == OperandSize::Size16 {
273
- LegacyPrefixes::_66
274
- } else {
275
- LegacyPrefixes::None
276
- };
277
- let opcode = if *size == OperandSize::Size8 {
278
- opcode - 1
279
- } else {
280
- opcode
281
- };
282
-
283
- let mut rex = RexFlags::from(*size);
284
- if *size == OperandSize::Size8 {
285
- debug_assert!(src2.is_real());
286
- rex.always_emit_if_8bit_needed(src2);
287
- }
288
-
289
- let enc_g = int_reg_enc(src2);
290
- emit_std_enc_mem(sink, prefix, opcode, 1, enc_g, &src1_dst, rex, 0);
291
- }
292
-
293
- Inst::AluRmRVex {
294
- size,
295
- op,
296
- dst,
297
- src1,
298
- src2,
299
- } => {
300
- use AluRmROpcode::*;
301
- use LegacyPrefixes as LP;
302
-
303
- let dst = dst.to_reg().to_reg();
304
- let src1 = src1.to_reg();
305
- let src2 = match src2.clone().to_reg_mem().clone() {
306
- RegMem::Reg { reg } => {
307
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
308
- }
309
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
310
- };
311
-
312
- let w = match size {
313
- OperandSize::Size32 => false,
314
- OperandSize::Size64 => true,
315
-
316
- // the other cases would be rejected by isle constructors
317
- _ => unreachable!(),
318
- };
319
-
320
- let (prefix, opcode) = match op {
321
- Andn => (LP::None, 0xf2),
322
- Sarx => (LP::_F3, 0xf7),
323
- Shrx => (LP::_F2, 0xf7),
324
- Shlx => (LP::_66, 0xf7),
325
- Bzhi => (LP::None, 0xf5),
326
- };
327
-
328
- VexInstruction::new()
329
- .prefix(prefix)
330
- .map(OpcodeMap::_0F38)
331
- .w(w)
332
- .reg(dst.to_real_reg().unwrap().hw_enc())
333
- .vvvv(src1.to_real_reg().unwrap().hw_enc())
334
- .rm(src2)
335
- .opcode(opcode)
336
- .encode(sink);
337
- }
338
-
339
- Inst::UnaryRmR { size, op, src, dst } => {
340
- let dst = dst.to_reg().to_reg();
341
- let rex_flags = RexFlags::from(*size);
342
- use UnaryRmROpcode::*;
343
- let prefix = match size {
344
- OperandSize::Size16 => match op {
345
- Bsr | Bsf => LegacyPrefixes::_66,
346
- Lzcnt | Tzcnt | Popcnt => LegacyPrefixes::_66F3,
347
- },
348
- OperandSize::Size32 | OperandSize::Size64 => match op {
349
- Bsr | Bsf => LegacyPrefixes::None,
350
- Lzcnt | Tzcnt | Popcnt => LegacyPrefixes::_F3,
351
- },
352
- _ => unreachable!(),
353
- };
354
-
355
- let (opcode, num_opcodes) = match op {
356
- Bsr => (0x0fbd, 2),
357
- Bsf => (0x0fbc, 2),
358
- Lzcnt => (0x0fbd, 2),
359
- Tzcnt => (0x0fbc, 2),
360
- Popcnt => (0x0fb8, 2),
361
- };
362
-
363
- match src.clone().into() {
364
- RegMem::Reg { reg: src } => {
365
- emit_std_reg_reg(sink, prefix, opcode, num_opcodes, dst, src, rex_flags);
366
- }
367
- RegMem::Mem { addr: src } => {
368
- let amode = src.finalize(state, sink).clone();
369
- emit_std_reg_mem(sink, prefix, opcode, num_opcodes, dst, &amode, rex_flags, 0);
370
- }
371
- }
372
- }
373
-
374
- Inst::UnaryRmRVex { size, op, src, dst } => {
375
- let dst = dst.to_reg().to_reg();
376
- let src = match src.clone().to_reg_mem().clone() {
377
- RegMem::Reg { reg } => {
378
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
379
- }
380
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
381
- };
382
-
383
- let (opcode, opcode_ext) = match op {
384
- UnaryRmRVexOpcode::Blsr => (0xF3, 1),
385
- UnaryRmRVexOpcode::Blsmsk => (0xF3, 2),
386
- UnaryRmRVexOpcode::Blsi => (0xF3, 3),
387
- };
388
-
389
- VexInstruction::new()
390
- .map(OpcodeMap::_0F38)
391
- .w(*size == OperandSize::Size64)
392
- .opcode(opcode)
393
- .reg(opcode_ext)
394
- .vvvv(dst.to_real_reg().unwrap().hw_enc())
395
- .rm(src)
396
- .encode(sink);
397
- }
398
-
399
- Inst::UnaryRmRImmVex {
400
- size,
401
- op,
402
- src,
403
- dst,
404
- imm,
405
- } => {
406
- let dst = dst.to_reg().to_reg();
407
- let src = match src.clone().to_reg_mem().clone() {
408
- RegMem::Reg { reg } => {
409
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
410
- }
411
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
412
- };
413
-
414
- let opcode = match op {
415
- UnaryRmRImmVexOpcode::Rorx => 0xF0,
416
- };
417
-
418
- VexInstruction::new()
419
- .prefix(LegacyPrefixes::_F2)
420
- .map(OpcodeMap::_0F3A)
421
- .w(*size == OperandSize::Size64)
422
- .opcode(opcode)
423
- .reg(dst.to_real_reg().unwrap().hw_enc())
424
- .rm(src)
425
- .imm(*imm)
426
- .encode(sink);
427
- }
428
-
429
- Inst::Not { size, src, dst } => {
430
- let src = src.to_reg();
431
- let dst = dst.to_reg().to_reg();
432
- debug_assert_eq!(src, dst);
433
- let rex_flags = RexFlags::from((*size, dst));
434
- let (opcode, prefix) = match size {
435
- OperandSize::Size8 => (0xF6, LegacyPrefixes::None),
436
- OperandSize::Size16 => (0xF7, LegacyPrefixes::_66),
437
- OperandSize::Size32 => (0xF7, LegacyPrefixes::None),
438
- OperandSize::Size64 => (0xF7, LegacyPrefixes::None),
439
- };
440
-
441
- let subopcode = 2;
442
- let enc_src = int_reg_enc(dst);
443
- emit_std_enc_enc(sink, prefix, opcode, 1, subopcode, enc_src, rex_flags)
444
- }
445
-
446
- Inst::Neg { size, src, dst } => {
447
- let src = src.to_reg();
448
- let dst = dst.to_reg().to_reg();
449
- debug_assert_eq!(src, dst);
450
- let rex_flags = RexFlags::from((*size, dst));
451
- let (opcode, prefix) = match size {
452
- OperandSize::Size8 => (0xF6, LegacyPrefixes::None),
453
- OperandSize::Size16 => (0xF7, LegacyPrefixes::_66),
454
- OperandSize::Size32 => (0xF7, LegacyPrefixes::None),
455
- OperandSize::Size64 => (0xF7, LegacyPrefixes::None),
456
- };
457
-
458
- let subopcode = 3;
459
- let enc_src = int_reg_enc(dst);
460
- emit_std_enc_enc(sink, prefix, opcode, 1, subopcode, enc_src, rex_flags)
461
- }
462
-
463
- Inst::Div {
464
- sign,
465
- trap,
466
- divisor,
467
- ..
468
- }
469
- | Inst::Div8 {
470
- sign,
471
- trap,
472
- divisor,
473
- ..
474
- } => {
475
- let divisor = divisor.clone().to_reg_mem().clone();
476
- let size = match inst {
477
- Inst::Div {
478
- size,
479
- dividend_lo,
480
- dividend_hi,
481
- dst_quotient,
482
- dst_remainder,
483
- ..
484
- } => {
485
- let dividend_lo = dividend_lo.to_reg();
486
- let dividend_hi = dividend_hi.to_reg();
487
- let dst_quotient = dst_quotient.to_reg().to_reg();
488
- let dst_remainder = dst_remainder.to_reg().to_reg();
489
- debug_assert_eq!(dividend_lo, regs::rax());
490
- debug_assert_eq!(dividend_hi, regs::rdx());
491
- debug_assert_eq!(dst_quotient, regs::rax());
492
- debug_assert_eq!(dst_remainder, regs::rdx());
493
- *size
494
- }
495
- Inst::Div8 { dividend, dst, .. } => {
496
- let dividend = dividend.to_reg();
497
- let dst = dst.to_reg().to_reg();
498
- debug_assert_eq!(dividend, regs::rax());
499
- debug_assert_eq!(dst, regs::rax());
500
- OperandSize::Size8
501
- }
502
- _ => unreachable!(),
503
- };
504
-
505
- let (opcode, prefix) = match size {
506
- OperandSize::Size8 => (0xF6, LegacyPrefixes::None),
507
- OperandSize::Size16 => (0xF7, LegacyPrefixes::_66),
508
- OperandSize::Size32 => (0xF7, LegacyPrefixes::None),
509
- OperandSize::Size64 => (0xF7, LegacyPrefixes::None),
510
- };
511
-
512
- sink.add_trap(*trap);
513
-
514
- let subopcode = match sign {
515
- DivSignedness::Signed => 7,
516
- DivSignedness::Unsigned => 6,
517
- };
518
- match divisor {
519
- RegMem::Reg { reg } => {
520
- let src = int_reg_enc(reg);
521
- emit_std_enc_enc(
522
- sink,
523
- prefix,
524
- opcode,
525
- 1,
526
- subopcode,
527
- src,
528
- RexFlags::from((size, reg)),
529
- )
530
- }
531
- RegMem::Mem { addr: src } => {
532
- let amode = src.finalize(state, sink);
533
- emit_std_enc_mem(
534
- sink,
535
- prefix,
536
- opcode,
537
- 1,
538
- subopcode,
539
- &amode,
540
- RexFlags::from(size),
541
- 0,
542
- );
543
- }
544
- }
545
- }
546
-
547
- Inst::Mul {
548
- signed,
549
- size,
550
- src1,
551
- src2,
552
- dst_lo,
553
- dst_hi,
554
- } => {
555
- let src1 = src1.to_reg();
556
- let dst_lo = dst_lo.to_reg().to_reg();
557
- let dst_hi = dst_hi.to_reg().to_reg();
558
- debug_assert_eq!(src1, regs::rax());
559
- debug_assert_eq!(dst_lo, regs::rax());
560
- debug_assert_eq!(dst_hi, regs::rdx());
561
- let src2 = src2.clone().to_reg_mem().clone();
562
-
563
- let rex_flags = RexFlags::from(*size);
564
- let prefix = match size {
565
- OperandSize::Size16 => LegacyPrefixes::_66,
566
- OperandSize::Size32 => LegacyPrefixes::None,
567
- OperandSize::Size64 => LegacyPrefixes::None,
568
- _ => unreachable!(),
569
- };
570
-
571
- let subopcode = if *signed { 5 } else { 4 };
572
- match src2 {
573
- RegMem::Reg { reg } => {
574
- let src = int_reg_enc(reg);
575
- emit_std_enc_enc(sink, prefix, 0xF7, 1, subopcode, src, rex_flags)
576
- }
577
- RegMem::Mem { addr: src } => {
578
- let amode = src.finalize(state, sink);
579
- emit_std_enc_mem(sink, prefix, 0xF7, 1, subopcode, &amode, rex_flags, 0);
580
- }
581
- }
582
- }
583
- Inst::Mul8 {
584
- signed,
585
- src1,
586
- src2,
587
- dst,
588
- } => {
589
- let src1 = src1.to_reg();
590
- let dst = dst.to_reg().to_reg();
591
- debug_assert_eq!(src1, regs::rax());
592
- debug_assert_eq!(dst, regs::rax());
593
- let src2 = src2.clone().to_reg_mem().clone();
594
-
595
- let mut rex_flags = RexFlags::from(OperandSize::Size8);
596
- let prefix = LegacyPrefixes::None;
597
- let subopcode = if *signed { 5 } else { 4 };
598
- match src2 {
599
- RegMem::Reg { reg } => {
600
- // The intel manual states:
601
- //
602
- // > r/m8 can not be encoded to access the following byte
603
- // > registers if a REX prefix is used: AH, BH, CH, DH
604
- //
605
- // And apparently that also means that a REX prefix must be
606
- // used if it's not one of those registers.
607
- if !(reg == regs::rax()
608
- || reg == regs::rbx()
609
- || reg == regs::rcx()
610
- || reg == regs::rdx())
611
- {
612
- rex_flags.always_emit();
613
- }
614
- let src = int_reg_enc(reg);
615
- emit_std_enc_enc(sink, prefix, 0xF6, 1, subopcode, src, rex_flags)
616
- }
617
- RegMem::Mem { addr } => {
618
- let amode = addr.finalize(state, sink);
619
- emit_std_enc_mem(sink, prefix, 0xF6, 1, subopcode, &amode, rex_flags, 0);
620
- }
621
- }
622
- }
623
- Inst::IMul {
624
- size,
625
- src1,
626
- src2,
627
- dst,
628
- } => {
629
- let src1 = src1.to_reg();
630
- let dst = dst.to_reg().to_reg();
631
- debug_assert_eq!(src1, dst);
632
- let src2 = src2.clone().to_reg_mem().clone();
633
-
634
- let rex = RexFlags::from(*size);
635
- let prefix = LegacyPrefixes::None;
636
- match src2 {
637
- RegMem::Reg { reg } => {
638
- emit_std_reg_reg(sink, prefix, 0x0FAF, 2, dst, reg, rex);
639
- }
640
-
641
- RegMem::Mem { addr } => {
642
- let amode = addr.finalize(state, sink);
643
- emit_std_reg_mem(sink, prefix, 0x0FAF, 2, dst, &amode, rex, 0);
644
- }
645
- }
646
- }
647
-
648
- Inst::IMulImm {
649
- size,
650
- src1,
651
- src2,
652
- dst,
653
- } => {
654
- let dst = dst.to_reg().to_reg();
655
- let src1 = src1.clone().to_reg_mem().clone();
656
-
657
- let rex = RexFlags::from(*size);
658
- let prefix = match size {
659
- // NB: the intel manual doesn't seem to mention this prefix as
660
- // being required
661
- OperandSize::Size16 => LegacyPrefixes::_66,
662
- _ => LegacyPrefixes::None,
663
- };
664
- let imm_size = if i8::try_from(*src2).is_ok() {
665
- 1
666
- } else {
667
- if *size == OperandSize::Size16 {
668
- 2
669
- } else {
670
- 4
671
- }
672
- };
673
- let opcode = if imm_size == 1 { 0x6B } else { 0x69 };
674
- match src1 {
675
- RegMem::Reg { reg } => {
676
- emit_std_reg_reg(sink, prefix, opcode, 1, dst, reg, rex);
677
- }
678
-
679
- RegMem::Mem { addr } => {
680
- let amode = addr.finalize(state, sink);
681
- emit_std_reg_mem(sink, prefix, opcode, 1, dst, &amode, rex, imm_size);
682
- }
683
- }
684
- emit_simm(sink, imm_size, *src2 as u32);
685
- }
686
-
687
- Inst::SignExtendData { size, src, dst } => {
688
- let src = src.to_reg();
689
- let dst = dst.to_reg().to_reg();
690
- debug_assert_eq!(src, regs::rax());
691
- if *size == OperandSize::Size8 {
692
- debug_assert_eq!(dst, regs::rax());
693
- } else {
694
- debug_assert_eq!(dst, regs::rdx());
695
- }
696
- match size {
697
- OperandSize::Size8 => {
698
- sink.put1(0x66);
699
- sink.put1(0x98);
700
- }
701
- OperandSize::Size16 => {
702
- sink.put1(0x66);
703
- sink.put1(0x99);
704
- }
705
- OperandSize::Size32 => sink.put1(0x99),
706
- OperandSize::Size64 => {
707
- sink.put1(0x48);
708
- sink.put1(0x99);
709
- }
710
- }
711
- }
712
-
713
- Inst::CheckedSRemSeq { divisor, .. } | Inst::CheckedSRemSeq8 { divisor, .. } => {
714
- let divisor = divisor.to_reg();
715
-
716
- // Validate that the register constraints of the dividend and the
717
- // destination are all as expected.
718
- let (dst, size) = match inst {
719
- Inst::CheckedSRemSeq {
720
- dividend_lo,
721
- dividend_hi,
722
- dst_quotient,
723
- dst_remainder,
724
- size,
725
- ..
726
- } => {
727
- let dividend_lo = dividend_lo.to_reg();
728
- let dividend_hi = dividend_hi.to_reg();
729
- let dst_quotient = dst_quotient.to_reg().to_reg();
730
- let dst_remainder = dst_remainder.to_reg().to_reg();
731
- debug_assert_eq!(dividend_lo, regs::rax());
732
- debug_assert_eq!(dividend_hi, regs::rdx());
733
- debug_assert_eq!(dst_quotient, regs::rax());
734
- debug_assert_eq!(dst_remainder, regs::rdx());
735
- (regs::rdx(), *size)
736
- }
737
- Inst::CheckedSRemSeq8 { dividend, dst, .. } => {
738
- let dividend = dividend.to_reg();
739
- let dst = dst.to_reg().to_reg();
740
- debug_assert_eq!(dividend, regs::rax());
741
- debug_assert_eq!(dst, regs::rax());
742
- (regs::rax(), OperandSize::Size8)
743
- }
744
- _ => unreachable!(),
745
- };
746
-
747
- // Generates the following code sequence:
748
- //
749
- // cmp -1 %divisor
750
- // jnz $do_op
751
- //
752
- // ;; for srem, result is 0
753
- // mov #0, %dst
754
- // j $done
755
- //
756
- // $do_op:
757
- // idiv %divisor
758
- //
759
- // $done:
760
-
761
- let do_op = sink.get_label();
762
- let done_label = sink.get_label();
763
-
764
- // Check if the divisor is -1, and if it isn't then immediately
765
- // go to the `idiv`.
766
- let inst = Inst::cmp_rmi_r(size, divisor, RegMemImm::imm(0xffffffff));
767
- inst.emit(sink, info, state);
768
- one_way_jmp(sink, CC::NZ, do_op);
769
-
770
- // ... otherwise the divisor is -1 and the result is always 0. This
771
- // is written to the destination register which will be %rax for
772
- // 8-bit srem and %rdx otherwise.
773
- //
774
- // Note that for 16-to-64-bit srem operations this leaves the
775
- // second destination, %rax, unchanged. This isn't semantically
776
- // correct if a lowering actually tries to use the `dst_quotient`
777
- // output but for srem only the `dst_remainder` output is used for
778
- // now.
779
- let inst = Inst::imm(OperandSize::Size64, 0, Writable::from_reg(dst));
780
- inst.emit(sink, info, state);
781
- let inst = Inst::jmp_known(done_label);
782
- inst.emit(sink, info, state);
783
-
784
- // Here the `idiv` is executed, which is different depending on the
785
- // size
786
- sink.bind_label(do_op, state.ctrl_plane_mut());
787
- let inst = match size {
788
- OperandSize::Size8 => Inst::div8(
789
- DivSignedness::Signed,
790
- TrapCode::IntegerDivisionByZero,
791
- RegMem::reg(divisor),
792
- Gpr::new(regs::rax()).unwrap(),
793
- Writable::from_reg(Gpr::new(regs::rax()).unwrap()),
794
- ),
795
- _ => Inst::div(
796
- size,
797
- DivSignedness::Signed,
798
- TrapCode::IntegerDivisionByZero,
799
- RegMem::reg(divisor),
800
- Gpr::new(regs::rax()).unwrap(),
801
- Gpr::new(regs::rdx()).unwrap(),
802
- Writable::from_reg(Gpr::new(regs::rax()).unwrap()),
803
- Writable::from_reg(Gpr::new(regs::rdx()).unwrap()),
804
- ),
805
- };
806
- inst.emit(sink, info, state);
807
-
808
- sink.bind_label(done_label, state.ctrl_plane_mut());
809
- }
810
-
811
- Inst::Imm {
812
- dst_size,
813
- simm64,
814
- dst,
815
- } => {
816
- let dst = dst.to_reg().to_reg();
817
- let enc_dst = int_reg_enc(dst);
818
- if *dst_size == OperandSize::Size64 {
819
- if low32_will_sign_extend_to_64(*simm64) {
820
- // Sign-extended move imm32.
821
- emit_std_enc_enc(
822
- sink,
823
- LegacyPrefixes::None,
824
- 0xC7,
825
- 1,
826
- /* subopcode */ 0,
827
- enc_dst,
828
- RexFlags::set_w(),
829
- );
830
- sink.put4(*simm64 as u32);
831
- } else {
832
- sink.put1(0x48 | ((enc_dst >> 3) & 1));
833
- sink.put1(0xB8 | (enc_dst & 7));
834
- sink.put8(*simm64);
835
- }
836
- } else {
837
- if ((enc_dst >> 3) & 1) == 1 {
838
- sink.put1(0x41);
839
- }
840
- sink.put1(0xB8 | (enc_dst & 7));
841
- sink.put4(*simm64 as u32);
842
- }
843
- }
844
-
845
- Inst::MovImmM { size, simm32, dst } => {
846
- let dst = &dst.finalize(state, sink).clone();
847
- let default_rex = RexFlags::clear_w();
848
- let default_opcode = 0xC7;
849
- let bytes = size.to_bytes();
850
- let prefix = LegacyPrefixes::None;
851
-
852
- let (opcode, rex, size, prefix) = match *size {
853
- // In the 8-bit case, we don't need to enforce REX flags via
854
- // `always_emit_if_8bit_needed()` since the destination
855
- // operand is a memory operand, not a possibly 8-bit register.
856
- OperandSize::Size8 => (0xC6, default_rex, bytes, prefix),
857
- OperandSize::Size16 => (0xC7, default_rex, bytes, LegacyPrefixes::_66),
858
- OperandSize::Size64 => (default_opcode, RexFlags::from(*size), bytes, prefix),
859
-
860
- _ => (default_opcode, default_rex, bytes, prefix),
861
- };
862
-
863
- // 8-bit C6 /0 ib
864
- // 16-bit 0x66 C7 /0 iw
865
- // 32-bit C7 /0 id
866
- // 64-bit REX.W C7 /0 id
867
- emit_std_enc_mem(sink, prefix, opcode, 1, /*subopcode*/ 0, dst, rex, 0);
868
- emit_simm(sink, size, *simm32 as u32);
869
- }
870
-
871
- Inst::MovRR { size, src, dst } => {
872
- let src = src.to_reg();
873
- let dst = dst.to_reg().to_reg();
874
- emit_std_reg_reg(
875
- sink,
876
- LegacyPrefixes::None,
877
- 0x89,
878
- 1,
879
- src,
880
- dst,
881
- RexFlags::from(*size),
882
- );
883
- }
884
-
885
- Inst::MovFromPReg { src, dst } => {
886
- let src: Reg = (*src).into();
887
- debug_assert!([regs::rsp(), regs::rbp(), regs::pinned_reg()].contains(&src));
888
- let src = Gpr::new(src).unwrap();
889
- let size = OperandSize::Size64;
890
- let dst = WritableGpr::from_writable_reg(dst.to_writable_reg()).unwrap();
891
- Inst::MovRR { size, src, dst }.emit(sink, info, state);
892
- }
893
-
894
- Inst::MovToPReg { src, dst } => {
895
- let src = src.to_reg();
896
- let src = Gpr::new(src).unwrap();
897
- let dst: Reg = (*dst).into();
898
- debug_assert!([regs::rsp(), regs::rbp(), regs::pinned_reg()].contains(&dst));
899
- let dst = WritableGpr::from_writable_reg(Writable::from_reg(dst)).unwrap();
900
- let size = OperandSize::Size64;
901
- Inst::MovRR { size, src, dst }.emit(sink, info, state);
902
- }
903
-
904
- Inst::MovzxRmR { ext_mode, src, dst } => {
905
- let dst = dst.to_reg().to_reg();
906
- let (opcodes, num_opcodes, mut rex_flags) = match ext_mode {
907
- ExtMode::BL => {
908
- // MOVZBL is (REX.W==0) 0F B6 /r
909
- (0x0FB6, 2, RexFlags::clear_w())
910
- }
911
- ExtMode::BQ => {
912
- // MOVZBQ is (REX.W==1) 0F B6 /r
913
- // I'm not sure why the Intel manual offers different
914
- // encodings for MOVZBQ than for MOVZBL. AIUI they should
915
- // achieve the same, since MOVZBL is just going to zero out
916
- // the upper half of the destination anyway.
917
- (0x0FB6, 2, RexFlags::set_w())
918
- }
919
- ExtMode::WL => {
920
- // MOVZWL is (REX.W==0) 0F B7 /r
921
- (0x0FB7, 2, RexFlags::clear_w())
922
- }
923
- ExtMode::WQ => {
924
- // MOVZWQ is (REX.W==1) 0F B7 /r
925
- (0x0FB7, 2, RexFlags::set_w())
926
- }
927
- ExtMode::LQ => {
928
- // This is just a standard 32 bit load, and we rely on the
929
- // default zero-extension rule to perform the extension.
930
- // Note that in reg/reg mode, gcc seems to use the swapped form R/RM, which we
931
- // don't do here, since it's the same encoding size.
932
- // MOV r/m32, r32 is (REX.W==0) 8B /r
933
- (0x8B, 1, RexFlags::clear_w())
934
- }
935
- };
936
-
937
- match src.clone().to_reg_mem() {
938
- RegMem::Reg { reg: src } => {
939
- match ext_mode {
940
- ExtMode::BL | ExtMode::BQ => {
941
- // A redundant REX prefix must be emitted for certain register inputs.
942
- rex_flags.always_emit_if_8bit_needed(src);
943
- }
944
- _ => {}
945
- }
946
- emit_std_reg_reg(
947
- sink,
948
- LegacyPrefixes::None,
949
- opcodes,
950
- num_opcodes,
951
- dst,
952
- src,
953
- rex_flags,
954
- )
955
- }
956
-
957
- RegMem::Mem { addr: src } => {
958
- let src = &src.finalize(state, sink).clone();
959
-
960
- emit_std_reg_mem(
961
- sink,
962
- LegacyPrefixes::None,
963
- opcodes,
964
- num_opcodes,
965
- dst,
966
- src,
967
- rex_flags,
968
- 0,
969
- )
970
- }
971
- }
972
- }
973
-
974
- Inst::Mov64MR { src, dst } => {
975
- let dst = dst.to_reg().to_reg();
976
- let src = &src.finalize(state, sink).clone();
977
-
978
- emit_std_reg_mem(
979
- sink,
980
- LegacyPrefixes::None,
981
- 0x8B,
982
- 1,
983
- dst,
984
- src,
985
- RexFlags::set_w(),
986
- 0,
987
- )
988
- }
989
-
990
- Inst::LoadEffectiveAddress { addr, dst, size } => {
991
- let dst = dst.to_reg().to_reg();
992
- let amode = addr.finalize(state, sink).clone();
993
-
994
- // If this `lea` can actually get encoded as an `add` then do that
995
- // instead. Currently all candidate `iadd`s become an `lea`
996
- // pseudo-instruction here but maximizing the sue of `lea` is not
997
- // necessarily optimal. The `lea` instruction goes through dedicated
998
- // address units on cores which are finite and disjoint from the
999
- // general ALU, so if everything uses `lea` then those units can get
1000
- // saturated while leaving the ALU idle.
1001
- //
1002
- // To help make use of more parts of a cpu, this attempts to use
1003
- // `add` when it's semantically equivalent to `lea`, or otherwise
1004
- // when the `dst` register is the same as the `base` or `index`
1005
- // register.
1006
- //
1007
- // FIXME: ideally regalloc is informed of this constraint. Register
1008
- // allocation of `lea` should "attempt" to put the `base` in the
1009
- // same register as `dst` but not at the expense of generating a
1010
- // `mov` instruction. Currently that's not possible but perhaps one
1011
- // day it may be worth it.
1012
- match amode {
1013
- // If `base == dst` then this is `add $imm, %dst`, so encode
1014
- // that instead.
1015
- Amode::ImmReg {
1016
- simm32,
1017
- base,
1018
- flags: _,
1019
- } if base == dst => {
1020
- let inst = Inst::alu_rmi_r(
1021
- *size,
1022
- AluRmiROpcode::Add,
1023
- RegMemImm::imm(simm32 as u32),
1024
- Writable::from_reg(dst),
1025
- );
1026
- inst.emit(sink, info, state);
1027
- }
1028
- // If the offset is 0 and the shift is 0 (meaning multiplication
1029
- // by 1) then:
1030
- //
1031
- // * If `base == dst`, then this is `add %index, %base`
1032
- // * If `index == dst`, then this is `add %base, %index`
1033
- //
1034
- // Encode the appropriate instruction here in that case.
1035
- Amode::ImmRegRegShift {
1036
- simm32: 0,
1037
- base,
1038
- index,
1039
- shift: 0,
1040
- flags: _,
1041
- } if base == dst || index == dst => {
1042
- let (dst, operand) = if base == dst {
1043
- (base, index)
1044
- } else {
1045
- (index, base)
1046
- };
1047
- let inst = Inst::alu_rmi_r(
1048
- *size,
1049
- AluRmiROpcode::Add,
1050
- RegMemImm::reg(operand.to_reg()),
1051
- Writable::from_reg(dst.to_reg()),
1052
- );
1053
- inst.emit(sink, info, state);
1054
- }
1055
-
1056
- // If `lea`'s 3-operand mode is leveraged by regalloc, or if
1057
- // it's fancy like imm-plus-shift-plus-base, then `lea` is
1058
- // actually emitted.
1059
- _ => {
1060
- let flags = match size {
1061
- OperandSize::Size32 => RexFlags::clear_w(),
1062
- OperandSize::Size64 => RexFlags::set_w(),
1063
- _ => unreachable!(),
1064
- };
1065
- emit_std_reg_mem(sink, LegacyPrefixes::None, 0x8D, 1, dst, &amode, flags, 0);
1066
- }
1067
- };
1068
- }
1069
-
1070
- Inst::MovsxRmR { ext_mode, src, dst } => {
1071
- let dst = dst.to_reg().to_reg();
1072
- let (opcodes, num_opcodes, mut rex_flags) = match ext_mode {
1073
- ExtMode::BL => {
1074
- // MOVSBL is (REX.W==0) 0F BE /r
1075
- (0x0FBE, 2, RexFlags::clear_w())
1076
- }
1077
- ExtMode::BQ => {
1078
- // MOVSBQ is (REX.W==1) 0F BE /r
1079
- (0x0FBE, 2, RexFlags::set_w())
1080
- }
1081
- ExtMode::WL => {
1082
- // MOVSWL is (REX.W==0) 0F BF /r
1083
- (0x0FBF, 2, RexFlags::clear_w())
1084
- }
1085
- ExtMode::WQ => {
1086
- // MOVSWQ is (REX.W==1) 0F BF /r
1087
- (0x0FBF, 2, RexFlags::set_w())
1088
- }
1089
- ExtMode::LQ => {
1090
- // MOVSLQ is (REX.W==1) 63 /r
1091
- (0x63, 1, RexFlags::set_w())
1092
- }
1093
- };
1094
-
1095
- match src.clone().to_reg_mem() {
1096
- RegMem::Reg { reg: src } => {
1097
- match ext_mode {
1098
- ExtMode::BL | ExtMode::BQ => {
1099
- // A redundant REX prefix must be emitted for certain register inputs.
1100
- rex_flags.always_emit_if_8bit_needed(src);
1101
- }
1102
- _ => {}
1103
- }
1104
- emit_std_reg_reg(
1105
- sink,
1106
- LegacyPrefixes::None,
1107
- opcodes,
1108
- num_opcodes,
1109
- dst,
1110
- src,
1111
- rex_flags,
1112
- )
1113
- }
1114
-
1115
- RegMem::Mem { addr: src } => {
1116
- let src = &src.finalize(state, sink).clone();
1117
-
1118
- emit_std_reg_mem(
1119
- sink,
1120
- LegacyPrefixes::None,
1121
- opcodes,
1122
- num_opcodes,
1123
- dst,
1124
- src,
1125
- rex_flags,
1126
- 0,
1127
- )
1128
- }
1129
- }
1130
- }
1131
-
1132
- Inst::MovRM { size, src, dst } => {
1133
- let src = src.to_reg();
1134
- let dst = &dst.finalize(state, sink).clone();
1135
-
1136
- let prefix = match size {
1137
- OperandSize::Size16 => LegacyPrefixes::_66,
1138
- _ => LegacyPrefixes::None,
1139
- };
1140
-
1141
- let opcode = match size {
1142
- OperandSize::Size8 => 0x88,
1143
- _ => 0x89,
1144
- };
1145
-
1146
- // This is one of the few places where the presence of a
1147
- // redundant REX prefix changes the meaning of the
1148
- // instruction.
1149
- let rex = RexFlags::from((*size, src));
1150
-
1151
- // 8-bit: MOV r8, r/m8 is (REX.W==0) 88 /r
1152
- // 16-bit: MOV r16, r/m16 is 66 (REX.W==0) 89 /r
1153
- // 32-bit: MOV r32, r/m32 is (REX.W==0) 89 /r
1154
- // 64-bit: MOV r64, r/m64 is (REX.W==1) 89 /r
1155
- emit_std_reg_mem(sink, prefix, opcode, 1, src, dst, rex, 0);
1156
- }
1157
-
1158
- Inst::ShiftR {
1159
- size,
1160
- kind,
1161
- src,
1162
- num_bits,
1163
- dst,
1164
- } => {
1165
- let src = src.to_reg();
1166
- let dst = dst.to_reg().to_reg();
1167
- debug_assert_eq!(src, dst);
1168
- let subopcode = match kind {
1169
- ShiftKind::RotateLeft => 0,
1170
- ShiftKind::RotateRight => 1,
1171
- ShiftKind::ShiftLeft => 4,
1172
- ShiftKind::ShiftRightLogical => 5,
1173
- ShiftKind::ShiftRightArithmetic => 7,
1174
- };
1175
- let enc_dst = int_reg_enc(dst);
1176
- let rex_flags = RexFlags::from((*size, dst));
1177
- match num_bits.as_imm8_reg() {
1178
- &Imm8Reg::Reg { reg } => {
1179
- debug_assert_eq!(reg, regs::rcx());
1180
- let (opcode, prefix) = match size {
1181
- OperandSize::Size8 => (0xD2, LegacyPrefixes::None),
1182
- OperandSize::Size16 => (0xD3, LegacyPrefixes::_66),
1183
- OperandSize::Size32 => (0xD3, LegacyPrefixes::None),
1184
- OperandSize::Size64 => (0xD3, LegacyPrefixes::None),
1185
- };
1186
-
1187
- // SHL/SHR/SAR %cl, reg8 is (REX.W==0) D2 /subopcode
1188
- // SHL/SHR/SAR %cl, reg16 is 66 (REX.W==0) D3 /subopcode
1189
- // SHL/SHR/SAR %cl, reg32 is (REX.W==0) D3 /subopcode
1190
- // SHL/SHR/SAR %cl, reg64 is (REX.W==1) D3 /subopcode
1191
- emit_std_enc_enc(sink, prefix, opcode, 1, subopcode, enc_dst, rex_flags);
1192
- }
1193
-
1194
- &Imm8Reg::Imm8 { imm: num_bits } => {
1195
- let (opcode, prefix) = match size {
1196
- OperandSize::Size8 => (0xC0, LegacyPrefixes::None),
1197
- OperandSize::Size16 => (0xC1, LegacyPrefixes::_66),
1198
- OperandSize::Size32 => (0xC1, LegacyPrefixes::None),
1199
- OperandSize::Size64 => (0xC1, LegacyPrefixes::None),
1200
- };
1201
-
1202
- // SHL/SHR/SAR $ib, reg8 is (REX.W==0) C0 /subopcode
1203
- // SHL/SHR/SAR $ib, reg16 is 66 (REX.W==0) C1 /subopcode
1204
- // SHL/SHR/SAR $ib, reg32 is (REX.W==0) C1 /subopcode ib
1205
- // SHL/SHR/SAR $ib, reg64 is (REX.W==1) C1 /subopcode ib
1206
- // When the shift amount is 1, there's an even shorter encoding, but we don't
1207
- // bother with that nicety here.
1208
- emit_std_enc_enc(sink, prefix, opcode, 1, subopcode, enc_dst, rex_flags);
1209
- sink.put1(num_bits);
1210
- }
1211
- }
1212
- }
1213
-
1214
- Inst::XmmRmiReg {
1215
- opcode,
1216
- src1,
1217
- src2,
1218
- dst,
1219
- } => {
1220
- let src1 = src1.to_reg();
1221
- let dst = dst.to_reg().to_reg();
1222
- debug_assert_eq!(src1, dst);
1223
- let rex = RexFlags::clear_w();
1224
- let prefix = LegacyPrefixes::_66;
1225
- let src2 = src2.clone().to_reg_mem_imm();
1226
- if let RegMemImm::Imm { simm32 } = src2 {
1227
- let (opcode_bytes, reg_digit) = match opcode {
1228
- SseOpcode::Psllw => (0x0F71, 6),
1229
- SseOpcode::Pslld => (0x0F72, 6),
1230
- SseOpcode::Psllq => (0x0F73, 6),
1231
- SseOpcode::Psraw => (0x0F71, 4),
1232
- SseOpcode::Psrad => (0x0F72, 4),
1233
- SseOpcode::Psrlw => (0x0F71, 2),
1234
- SseOpcode::Psrld => (0x0F72, 2),
1235
- SseOpcode::Psrlq => (0x0F73, 2),
1236
- _ => panic!("invalid opcode: {}", opcode),
1237
- };
1238
- let dst_enc = reg_enc(dst);
1239
- emit_std_enc_enc(sink, prefix, opcode_bytes, 2, reg_digit, dst_enc, rex);
1240
- let imm = (simm32)
1241
- .try_into()
1242
- .expect("the immediate must be convertible to a u8");
1243
- sink.put1(imm);
1244
- } else {
1245
- let opcode_bytes = match opcode {
1246
- SseOpcode::Psllw => 0x0FF1,
1247
- SseOpcode::Pslld => 0x0FF2,
1248
- SseOpcode::Psllq => 0x0FF3,
1249
- SseOpcode::Psraw => 0x0FE1,
1250
- SseOpcode::Psrad => 0x0FE2,
1251
- SseOpcode::Psrlw => 0x0FD1,
1252
- SseOpcode::Psrld => 0x0FD2,
1253
- SseOpcode::Psrlq => 0x0FD3,
1254
- _ => panic!("invalid opcode: {}", opcode),
1255
- };
1256
-
1257
- match src2 {
1258
- RegMemImm::Reg { reg } => {
1259
- emit_std_reg_reg(sink, prefix, opcode_bytes, 2, dst, reg, rex);
1260
- }
1261
- RegMemImm::Mem { addr } => {
1262
- let addr = &addr.finalize(state, sink).clone();
1263
- emit_std_reg_mem(sink, prefix, opcode_bytes, 2, dst, addr, rex, 0);
1264
- }
1265
- RegMemImm::Imm { .. } => unreachable!(),
1266
- }
1267
- };
1268
- }
1269
-
1270
- Inst::CmpRmiR {
1271
- size,
1272
- src1: reg_g,
1273
- src2: src_e,
1274
- opcode,
1275
- } => {
1276
- let reg_g = reg_g.to_reg();
1277
-
1278
- let is_cmp = match opcode {
1279
- CmpOpcode::Cmp => true,
1280
- CmpOpcode::Test => false,
1281
- };
1282
-
1283
- let mut prefix = LegacyPrefixes::None;
1284
- if *size == OperandSize::Size16 {
1285
- prefix = LegacyPrefixes::_66;
1286
- }
1287
- // A redundant REX prefix can change the meaning of this instruction.
1288
- let mut rex = RexFlags::from((*size, reg_g));
1289
-
1290
- match src_e.clone().to_reg_mem_imm() {
1291
- RegMemImm::Reg { reg: reg_e } => {
1292
- if *size == OperandSize::Size8 {
1293
- // Check whether the E register forces the use of a redundant REX.
1294
- rex.always_emit_if_8bit_needed(reg_e);
1295
- }
1296
-
1297
- // Use the swapped operands encoding for CMP, to stay consistent with the output of
1298
- // gcc/llvm.
1299
- let opcode = match (*size, is_cmp) {
1300
- (OperandSize::Size8, true) => 0x38,
1301
- (_, true) => 0x39,
1302
- (OperandSize::Size8, false) => 0x84,
1303
- (_, false) => 0x85,
1304
- };
1305
- emit_std_reg_reg(sink, prefix, opcode, 1, reg_e, reg_g, rex);
1306
- }
1307
-
1308
- RegMemImm::Mem { addr } => {
1309
- let addr = &addr.finalize(state, sink).clone();
1310
- // Whereas here we revert to the "normal" G-E ordering for CMP.
1311
- let opcode = match (*size, is_cmp) {
1312
- (OperandSize::Size8, true) => 0x3A,
1313
- (_, true) => 0x3B,
1314
- (OperandSize::Size8, false) => 0x84,
1315
- (_, false) => 0x85,
1316
- };
1317
- emit_std_reg_mem(sink, prefix, opcode, 1, reg_g, addr, rex, 0);
1318
- }
1319
-
1320
- RegMemImm::Imm { simm32 } => {
1321
- // FIXME JRS 2020Feb11: there are shorter encodings for
1322
- // cmp $imm, rax/eax/ax/al.
1323
- let use_imm8 = is_cmp && low8_will_sign_extend_to_32(simm32);
1324
-
1325
- // And also here we use the "normal" G-E ordering.
1326
- let opcode = if is_cmp {
1327
- if *size == OperandSize::Size8 {
1328
- 0x80
1329
- } else if use_imm8 {
1330
- 0x83
1331
- } else {
1332
- 0x81
1333
- }
1334
- } else {
1335
- if *size == OperandSize::Size8 {
1336
- 0xF6
1337
- } else {
1338
- 0xF7
1339
- }
1340
- };
1341
- let subopcode = if is_cmp { 7 } else { 0 };
1342
-
1343
- let enc_g = int_reg_enc(reg_g);
1344
- emit_std_enc_enc(sink, prefix, opcode, 1, subopcode, enc_g, rex);
1345
- emit_simm(sink, if use_imm8 { 1 } else { size.to_bytes() }, simm32);
1346
- }
1347
- }
1348
- }
1349
-
1350
- Inst::Setcc { cc, dst } => {
1351
- let dst = dst.to_reg().to_reg();
1352
- let opcode = 0x0f90 + cc.get_enc() as u32;
1353
- let mut rex_flags = RexFlags::clear_w();
1354
- rex_flags.always_emit();
1355
- emit_std_enc_enc(
1356
- sink,
1357
- LegacyPrefixes::None,
1358
- opcode,
1359
- 2,
1360
- 0,
1361
- reg_enc(dst),
1362
- rex_flags,
1363
- );
1364
- }
1365
-
1366
- Inst::Bswap { size, src, dst } => {
1367
- let src = src.to_reg();
1368
- let dst = dst.to_reg().to_reg();
1369
- debug_assert_eq!(src, dst);
1370
- let enc_reg = int_reg_enc(dst);
1371
-
1372
- // BSWAP reg32 is (REX.W==0) 0F C8
1373
- // BSWAP reg64 is (REX.W==1) 0F C8
1374
- let rex_flags = RexFlags::from(*size);
1375
- rex_flags.emit_one_op(sink, enc_reg);
1376
-
1377
- sink.put1(0x0F);
1378
- sink.put1(0xC8 | (enc_reg & 7));
1379
- }
1380
-
1381
- Inst::Cmove {
1382
- size,
1383
- cc,
1384
- consequent,
1385
- alternative,
1386
- dst,
1387
- } => {
1388
- let alternative = alternative.to_reg();
1389
- let dst = dst.to_reg().to_reg();
1390
- debug_assert_eq!(alternative, dst);
1391
- let rex_flags = RexFlags::from(*size);
1392
- let prefix = match size {
1393
- OperandSize::Size16 => LegacyPrefixes::_66,
1394
- OperandSize::Size32 => LegacyPrefixes::None,
1395
- OperandSize::Size64 => LegacyPrefixes::None,
1396
- _ => unreachable!("invalid size spec for cmove"),
1397
- };
1398
- let opcode = 0x0F40 + cc.get_enc() as u32;
1399
- match consequent.clone().to_reg_mem() {
1400
- RegMem::Reg { reg } => {
1401
- emit_std_reg_reg(sink, prefix, opcode, 2, dst, reg, rex_flags);
1402
- }
1403
- RegMem::Mem { addr } => {
1404
- let addr = &addr.finalize(state, sink).clone();
1405
- emit_std_reg_mem(sink, prefix, opcode, 2, dst, addr, rex_flags, 0);
1406
- }
1407
- }
1408
- }
1409
-
1410
- Inst::XmmCmove {
1411
- ty,
1412
- cc,
1413
- consequent,
1414
- alternative,
1415
- dst,
1416
- } => {
1417
- let alternative = alternative.to_reg();
1418
- let dst = dst.to_writable_reg();
1419
- debug_assert_eq!(alternative, dst.to_reg());
1420
- let consequent = consequent.clone().to_reg();
1421
-
1422
- // Lowering of the Select IR opcode when the input is an fcmp relies on the fact that
1423
- // this doesn't clobber flags. Make sure to not do so here.
1424
- let next = sink.get_label();
1425
-
1426
- // Jump if cc is *not* set.
1427
- one_way_jmp(sink, cc.invert(), next);
1428
-
1429
- let op = match *ty {
1430
- types::F64 => SseOpcode::Movsd,
1431
- types::F32 => SseOpcode::Movsd,
1432
- types::F32X4 => SseOpcode::Movaps,
1433
- types::F64X2 => SseOpcode::Movapd,
1434
- ty => {
1435
- debug_assert!(ty.is_vector() && ty.bytes() == 16);
1436
- SseOpcode::Movdqa
1437
- }
1438
- };
1439
- let inst = Inst::xmm_unary_rm_r(op, consequent.into(), dst);
1440
- inst.emit(sink, info, state);
1441
-
1442
- sink.bind_label(next, state.ctrl_plane_mut());
1443
- }
1444
-
1445
- Inst::Push64 { src } => {
1446
- let src = src.clone().to_reg_mem_imm().clone();
1447
-
1448
- match src {
1449
- RegMemImm::Reg { reg } => {
1450
- let enc_reg = int_reg_enc(reg);
1451
- let rex = 0x40 | ((enc_reg >> 3) & 1);
1452
- if rex != 0x40 {
1453
- sink.put1(rex);
1454
- }
1455
- sink.put1(0x50 | (enc_reg & 7));
1456
- }
1457
-
1458
- RegMemImm::Mem { addr } => {
1459
- let addr = &addr.finalize(state, sink);
1460
- emit_std_enc_mem(
1461
- sink,
1462
- LegacyPrefixes::None,
1463
- 0xFF,
1464
- 1,
1465
- 6, /*subopcode*/
1466
- addr,
1467
- RexFlags::clear_w(),
1468
- 0,
1469
- );
1470
- }
1471
-
1472
- RegMemImm::Imm { simm32 } => {
1473
- if low8_will_sign_extend_to_64(simm32) {
1474
- sink.put1(0x6A);
1475
- sink.put1(simm32 as u8);
1476
- } else {
1477
- sink.put1(0x68);
1478
- sink.put4(simm32);
1479
- }
1480
- }
1481
- }
1482
- }
1483
-
1484
- Inst::Pop64 { dst } => {
1485
- let dst = dst.to_reg().to_reg();
1486
- let enc_dst = int_reg_enc(dst);
1487
- if enc_dst >= 8 {
1488
- // 0x41 == REX.{W=0, B=1}. It seems that REX.W is irrelevant here.
1489
- sink.put1(0x41);
1490
- }
1491
- sink.put1(0x58 + (enc_dst & 7));
1492
- }
1493
-
1494
- Inst::StackProbeLoop {
1495
- tmp,
1496
- frame_size,
1497
- guard_size,
1498
- } => {
1499
- assert!(info.flags.enable_probestack());
1500
- assert!(guard_size.is_power_of_two());
1501
-
1502
- let tmp = *tmp;
1503
-
1504
- // Number of probes that we need to perform
1505
- let probe_count = align_to(*frame_size, *guard_size) / guard_size;
1506
-
1507
- // The inline stack probe loop has 3 phases:
1508
- //
1509
- // We generate the "guard area" register which is essentially the frame_size aligned to
1510
- // guard_size. We copy the stack pointer and subtract the guard area from it. This
1511
- // gets us a register that we can use to compare when looping.
1512
- //
1513
- // After that we emit the loop. Essentially we just adjust the stack pointer one guard_size'd
1514
- // distance at a time and then touch the stack by writing anything to it. We use the previously
1515
- // created "guard area" register to know when to stop looping.
1516
- //
1517
- // When we have touched all the pages that we need, we have to restore the stack pointer
1518
- // to where it was before.
1519
- //
1520
- // Generate the following code:
1521
- // mov tmp_reg, rsp
1522
- // sub tmp_reg, guard_size * probe_count
1523
- // .loop_start:
1524
- // sub rsp, guard_size
1525
- // mov [rsp], rsp
1526
- // cmp rsp, tmp_reg
1527
- // jne .loop_start
1528
- // add rsp, guard_size * probe_count
1529
-
1530
- // Create the guard bound register
1531
- // mov tmp_reg, rsp
1532
- let inst = Inst::gen_move(tmp, regs::rsp(), types::I64);
1533
- inst.emit(sink, info, state);
1534
-
1535
- // sub tmp_reg, GUARD_SIZE * probe_count
1536
- let inst = Inst::alu_rmi_r(
1537
- OperandSize::Size64,
1538
- AluRmiROpcode::Sub,
1539
- RegMemImm::imm(guard_size * probe_count),
1540
- tmp,
1541
- );
1542
- inst.emit(sink, info, state);
1543
-
1544
- // Emit the main loop!
1545
- let loop_start = sink.get_label();
1546
- sink.bind_label(loop_start, state.ctrl_plane_mut());
1547
-
1548
- // sub rsp, GUARD_SIZE
1549
- let inst = Inst::alu_rmi_r(
1550
- OperandSize::Size64,
1551
- AluRmiROpcode::Sub,
1552
- RegMemImm::imm(*guard_size),
1553
- Writable::from_reg(regs::rsp()),
1554
- );
1555
- inst.emit(sink, info, state);
1556
-
1557
- // TODO: `mov [rsp], 0` would be better, but we don't have that instruction
1558
- // Probe the stack! We don't use Inst::gen_store_stack here because we need a predictable
1559
- // instruction size.
1560
- // mov [rsp], rsp
1561
- let inst = Inst::mov_r_m(
1562
- OperandSize::Size32, // Use Size32 since it saves us one byte
1563
- regs::rsp(),
1564
- SyntheticAmode::Real(Amode::imm_reg(0, regs::rsp())),
1565
- );
1566
- inst.emit(sink, info, state);
1567
-
1568
- // Compare and jump if we are not done yet
1569
- // cmp rsp, tmp_reg
1570
- let inst = Inst::cmp_rmi_r(
1571
- OperandSize::Size64,
1572
- tmp.to_reg(),
1573
- RegMemImm::reg(regs::rsp()),
1574
- );
1575
- inst.emit(sink, info, state);
1576
-
1577
- // jne .loop_start
1578
- // TODO: Encoding the JmpIf as a short jump saves us 4 bytes here.
1579
- one_way_jmp(sink, CC::NZ, loop_start);
1580
-
1581
- // The regular prologue code is going to emit a `sub` after this, so we need to
1582
- // reset the stack pointer
1583
- //
1584
- // TODO: It would be better if we could avoid the `add` + `sub` that is generated here
1585
- // and in the stack adj portion of the prologue
1586
- //
1587
- // add rsp, GUARD_SIZE * probe_count
1588
- let inst = Inst::alu_rmi_r(
1589
- OperandSize::Size64,
1590
- AluRmiROpcode::Add,
1591
- RegMemImm::imm(guard_size * probe_count),
1592
- Writable::from_reg(regs::rsp()),
1593
- );
1594
- inst.emit(sink, info, state);
1595
- }
1596
-
1597
- Inst::CallKnown {
1598
- dest,
1599
- opcode,
1600
- info: call_info,
1601
- } => {
1602
- if let Some(s) = state.take_stack_map() {
1603
- sink.add_stack_map(StackMapExtent::UpcomingBytes(5), s);
1604
- }
1605
- sink.put1(0xE8);
1606
- // The addend adjusts for the difference between the end of the instruction and the
1607
- // beginning of the immediate field.
1608
- emit_reloc(sink, Reloc::X86CallPCRel4, &dest, -4);
1609
- sink.put4(0);
1610
- if opcode.is_call() {
1611
- sink.add_call_site(*opcode);
1612
- }
1613
-
1614
- // Reclaim the outgoing argument area that was released by the callee, to ensure that
1615
- // StackAMode values are always computed from a consistent SP.
1616
- if let Some(call_info) = call_info {
1617
- if call_info.callee_pop_size > 0 {
1618
- Inst::alu_rmi_r(
1619
- OperandSize::Size64,
1620
- AluRmiROpcode::Sub,
1621
- RegMemImm::imm(call_info.callee_pop_size),
1622
- Writable::from_reg(regs::rsp()),
1623
- )
1624
- .emit(sink, info, state);
1625
- }
1626
- }
1627
- }
1628
-
1629
- Inst::ReturnCallKnown {
1630
- callee,
1631
- info: call_info,
1632
- } => {
1633
- emit_return_call_common_sequence(sink, info, state, &call_info);
1634
-
1635
- // Finally, jump to the callee!
1636
- //
1637
- // Note: this is not `Inst::Jmp { .. }.emit(..)` because we have
1638
- // different metadata in this case: we don't have a label for the
1639
- // target, but rather a function relocation.
1640
- sink.put1(0xE9);
1641
- // The addend adjusts for the difference between the end of the instruction and the
1642
- // beginning of the immediate field.
1643
- emit_reloc(sink, Reloc::X86CallPCRel4, &callee, -4);
1644
- sink.put4(0);
1645
- sink.add_call_site(ir::Opcode::ReturnCall);
1646
- }
1647
-
1648
- Inst::ReturnCallUnknown {
1649
- callee,
1650
- info: call_info,
1651
- } => {
1652
- let callee = *callee;
1653
-
1654
- emit_return_call_common_sequence(sink, info, state, &call_info);
1655
-
1656
- Inst::JmpUnknown {
1657
- target: RegMem::reg(callee),
1658
- }
1659
- .emit(sink, info, state);
1660
- sink.add_call_site(ir::Opcode::ReturnCallIndirect);
1661
- }
1662
-
1663
- Inst::CallUnknown {
1664
- dest,
1665
- opcode,
1666
- info: call_info,
1667
- } => {
1668
- let dest = dest.clone();
1669
-
1670
- let start_offset = sink.cur_offset();
1671
- match dest {
1672
- RegMem::Reg { reg } => {
1673
- let reg_enc = int_reg_enc(reg);
1674
- emit_std_enc_enc(
1675
- sink,
1676
- LegacyPrefixes::None,
1677
- 0xFF,
1678
- 1,
1679
- 2, /*subopcode*/
1680
- reg_enc,
1681
- RexFlags::clear_w(),
1682
- );
1683
- }
1684
-
1685
- RegMem::Mem { addr } => {
1686
- let addr = &addr.finalize(state, sink);
1687
- emit_std_enc_mem(
1688
- sink,
1689
- LegacyPrefixes::None,
1690
- 0xFF,
1691
- 1,
1692
- 2, /*subopcode*/
1693
- addr,
1694
- RexFlags::clear_w(),
1695
- 0,
1696
- );
1697
- }
1698
- }
1699
- if let Some(s) = state.take_stack_map() {
1700
- sink.add_stack_map(StackMapExtent::StartedAtOffset(start_offset), s);
1701
- }
1702
- if opcode.is_call() {
1703
- sink.add_call_site(*opcode);
1704
- }
1705
-
1706
- // Reclaim the outgoing argument area that was released by the callee, to ensure that
1707
- // StackAMode values are always computed from a consistent SP.
1708
- if let Some(call_info) = call_info {
1709
- if call_info.callee_pop_size > 0 {
1710
- Inst::alu_rmi_r(
1711
- OperandSize::Size64,
1712
- AluRmiROpcode::Sub,
1713
- RegMemImm::imm(call_info.callee_pop_size),
1714
- Writable::from_reg(regs::rsp()),
1715
- )
1716
- .emit(sink, info, state);
1717
- }
1718
- }
1719
- }
1720
-
1721
- Inst::Args { .. } => {}
1722
- Inst::Rets { .. } => {}
1723
-
1724
- Inst::Ret {
1725
- stack_bytes_to_pop: 0,
1726
- } => sink.put1(0xC3),
1727
-
1728
- Inst::Ret { stack_bytes_to_pop } => {
1729
- sink.put1(0xC2);
1730
- sink.put2(u16::try_from(*stack_bytes_to_pop).unwrap());
1731
- }
1732
-
1733
- Inst::JmpKnown { dst } => {
1734
- let br_start = sink.cur_offset();
1735
- let br_disp_off = br_start + 1;
1736
- let br_end = br_start + 5;
1737
-
1738
- sink.use_label_at_offset(br_disp_off, *dst, LabelUse::JmpRel32);
1739
- sink.add_uncond_branch(br_start, br_end, *dst);
1740
-
1741
- sink.put1(0xE9);
1742
- // Placeholder for the label value.
1743
- sink.put4(0x0);
1744
- }
1745
-
1746
- Inst::JmpIf { cc, taken } => {
1747
- let cond_start = sink.cur_offset();
1748
- let cond_disp_off = cond_start + 2;
1749
-
1750
- sink.use_label_at_offset(cond_disp_off, *taken, LabelUse::JmpRel32);
1751
- // Since this is not a terminator, don't enroll in the branch inversion mechanism.
1752
-
1753
- sink.put1(0x0F);
1754
- sink.put1(0x80 + cc.get_enc());
1755
- // Placeholder for the label value.
1756
- sink.put4(0x0);
1757
- }
1758
-
1759
- Inst::JmpCond {
1760
- cc,
1761
- taken,
1762
- not_taken,
1763
- } => {
1764
- // If taken.
1765
- let cond_start = sink.cur_offset();
1766
- let cond_disp_off = cond_start + 2;
1767
- let cond_end = cond_start + 6;
1768
-
1769
- sink.use_label_at_offset(cond_disp_off, *taken, LabelUse::JmpRel32);
1770
- let inverted: [u8; 6] = [0x0F, 0x80 + (cc.invert().get_enc()), 0x00, 0x00, 0x00, 0x00];
1771
- sink.add_cond_branch(cond_start, cond_end, *taken, &inverted[..]);
1772
-
1773
- sink.put1(0x0F);
1774
- sink.put1(0x80 + cc.get_enc());
1775
- // Placeholder for the label value.
1776
- sink.put4(0x0);
1777
-
1778
- // If not taken.
1779
- let uncond_start = sink.cur_offset();
1780
- let uncond_disp_off = uncond_start + 1;
1781
- let uncond_end = uncond_start + 5;
1782
-
1783
- sink.use_label_at_offset(uncond_disp_off, *not_taken, LabelUse::JmpRel32);
1784
- sink.add_uncond_branch(uncond_start, uncond_end, *not_taken);
1785
-
1786
- sink.put1(0xE9);
1787
- // Placeholder for the label value.
1788
- sink.put4(0x0);
1789
- }
1790
-
1791
- Inst::JmpUnknown { target } => {
1792
- let target = target.clone();
1793
-
1794
- match target {
1795
- RegMem::Reg { reg } => {
1796
- let reg_enc = int_reg_enc(reg);
1797
- emit_std_enc_enc(
1798
- sink,
1799
- LegacyPrefixes::None,
1800
- 0xFF,
1801
- 1,
1802
- 4, /*subopcode*/
1803
- reg_enc,
1804
- RexFlags::clear_w(),
1805
- );
1806
- }
1807
-
1808
- RegMem::Mem { addr } => {
1809
- let addr = &addr.finalize(state, sink);
1810
- emit_std_enc_mem(
1811
- sink,
1812
- LegacyPrefixes::None,
1813
- 0xFF,
1814
- 1,
1815
- 4, /*subopcode*/
1816
- addr,
1817
- RexFlags::clear_w(),
1818
- 0,
1819
- );
1820
- }
1821
- }
1822
- }
1823
-
1824
- &Inst::JmpTableSeq {
1825
- idx,
1826
- tmp1,
1827
- tmp2,
1828
- ref targets,
1829
- ref default_target,
1830
- ..
1831
- } => {
1832
- // This sequence is *one* instruction in the vcode, and is expanded only here at
1833
- // emission time, because we cannot allow the regalloc to insert spills/reloads in
1834
- // the middle; we depend on hardcoded PC-rel addressing below.
1835
- //
1836
- // We don't have to worry about emitting islands, because the only label-use type has a
1837
- // maximum range of 2 GB. If we later consider using shorter-range label references,
1838
- // this will need to be revisited.
1839
-
1840
- // We generate the following sequence. Note that the only read of %idx is before the
1841
- // write to %tmp2, so regalloc may use the same register for both; fix x64/inst/mod.rs
1842
- // if you change this.
1843
- // lea start_of_jump_table_offset(%rip), %tmp1
1844
- // movslq [%tmp1, %idx, 4], %tmp2 ;; shift of 2, viz. multiply index by 4
1845
- // addq %tmp2, %tmp1
1846
- // j *%tmp1
1847
- // $start_of_jump_table:
1848
- // -- jump table entries
1849
-
1850
- // Load base address of jump table.
1851
- let start_of_jumptable = sink.get_label();
1852
- let inst = Inst::lea(Amode::rip_relative(start_of_jumptable), tmp1);
1853
- inst.emit(sink, info, state);
1854
-
1855
- // Load value out of the jump table. It's a relative offset to the target block, so it
1856
- // might be negative; use a sign-extension.
1857
- let inst = Inst::movsx_rm_r(
1858
- ExtMode::LQ,
1859
- RegMem::mem(Amode::imm_reg_reg_shift(
1860
- 0,
1861
- Gpr::new(tmp1.to_reg()).unwrap(),
1862
- Gpr::new(idx).unwrap(),
1863
- 2,
1864
- )),
1865
- tmp2,
1866
- );
1867
- inst.emit(sink, info, state);
1868
-
1869
- // Add base of jump table to jump-table-sourced block offset.
1870
- let inst = Inst::alu_rmi_r(
1871
- OperandSize::Size64,
1872
- AluRmiROpcode::Add,
1873
- RegMemImm::reg(tmp2.to_reg()),
1874
- tmp1,
1875
- );
1876
- inst.emit(sink, info, state);
1877
-
1878
- // Branch to computed address.
1879
- let inst = Inst::jmp_unknown(RegMem::reg(tmp1.to_reg()));
1880
- inst.emit(sink, info, state);
1881
-
1882
- // Emit jump table (table of 32-bit offsets).
1883
- sink.bind_label(start_of_jumptable, state.ctrl_plane_mut());
1884
- let jt_off = sink.cur_offset();
1885
- for &target in targets.iter().chain(std::iter::once(default_target)) {
1886
- let word_off = sink.cur_offset();
1887
- // off_into_table is an addend here embedded in the label to be later patched at
1888
- // the end of codegen. The offset is initially relative to this jump table entry;
1889
- // with the extra addend, it'll be relative to the jump table's start, after
1890
- // patching.
1891
- let off_into_table = word_off - jt_off;
1892
- sink.use_label_at_offset(word_off, target, LabelUse::PCRel32);
1893
- sink.put4(off_into_table);
1894
- }
1895
- }
1896
-
1897
- Inst::TrapIf { cc, trap_code } => {
1898
- let trap_label = sink.defer_trap(*trap_code, state.take_stack_map());
1899
- one_way_jmp(sink, *cc, trap_label);
1900
- }
1901
-
1902
- Inst::TrapIfAnd {
1903
- cc1,
1904
- cc2,
1905
- trap_code,
1906
- } => {
1907
- let trap_label = sink.defer_trap(*trap_code, state.take_stack_map());
1908
- let else_label = sink.get_label();
1909
-
1910
- // Jump to the end if the first condition isn't true, and then if
1911
- // the second condition is true go to the trap.
1912
- one_way_jmp(sink, cc1.invert(), else_label);
1913
- one_way_jmp(sink, *cc2, trap_label);
1914
-
1915
- sink.bind_label(else_label, state.ctrl_plane_mut());
1916
- }
1917
-
1918
- Inst::TrapIfOr {
1919
- cc1,
1920
- cc2,
1921
- trap_code,
1922
- } => {
1923
- let trap_label = sink.defer_trap(*trap_code, state.take_stack_map());
1924
-
1925
- // Emit two jumps to the same trap if either condition code is true.
1926
- one_way_jmp(sink, *cc1, trap_label);
1927
- one_way_jmp(sink, *cc2, trap_label);
1928
- }
1929
-
1930
- Inst::XmmUnaryRmR { op, src, dst } => {
1931
- emit(
1932
- &Inst::XmmUnaryRmRUnaligned {
1933
- op: *op,
1934
- src: XmmMem::new(src.clone().into()).unwrap(),
1935
- dst: *dst,
1936
- },
1937
- sink,
1938
- info,
1939
- state,
1940
- );
1941
- }
1942
-
1943
- Inst::XmmUnaryRmRUnaligned {
1944
- op,
1945
- src: src_e,
1946
- dst: reg_g,
1947
- } => {
1948
- let reg_g = reg_g.to_reg().to_reg();
1949
- let src_e = src_e.clone().to_reg_mem().clone();
1950
-
1951
- let rex = RexFlags::clear_w();
1952
-
1953
- let (prefix, opcode, num_opcodes) = match op {
1954
- SseOpcode::Cvtdq2pd => (LegacyPrefixes::_F3, 0x0FE6, 2),
1955
- SseOpcode::Cvtpd2ps => (LegacyPrefixes::_66, 0x0F5A, 2),
1956
- SseOpcode::Cvtps2pd => (LegacyPrefixes::None, 0x0F5A, 2),
1957
- SseOpcode::Cvtdq2ps => (LegacyPrefixes::None, 0x0F5B, 2),
1958
- SseOpcode::Cvttpd2dq => (LegacyPrefixes::_66, 0x0FE6, 2),
1959
- SseOpcode::Cvttps2dq => (LegacyPrefixes::_F3, 0x0F5B, 2),
1960
- SseOpcode::Movaps => (LegacyPrefixes::None, 0x0F28, 2),
1961
- SseOpcode::Movapd => (LegacyPrefixes::_66, 0x0F28, 2),
1962
- SseOpcode::Movdqa => (LegacyPrefixes::_66, 0x0F6F, 2),
1963
- SseOpcode::Movdqu => (LegacyPrefixes::_F3, 0x0F6F, 2),
1964
- SseOpcode::Movsd => (LegacyPrefixes::_F2, 0x0F10, 2),
1965
- SseOpcode::Movss => (LegacyPrefixes::_F3, 0x0F10, 2),
1966
- SseOpcode::Movups => (LegacyPrefixes::None, 0x0F10, 2),
1967
- SseOpcode::Movupd => (LegacyPrefixes::_66, 0x0F10, 2),
1968
- SseOpcode::Pabsb => (LegacyPrefixes::_66, 0x0F381C, 3),
1969
- SseOpcode::Pabsw => (LegacyPrefixes::_66, 0x0F381D, 3),
1970
- SseOpcode::Pabsd => (LegacyPrefixes::_66, 0x0F381E, 3),
1971
- SseOpcode::Pmovsxbd => (LegacyPrefixes::_66, 0x0F3821, 3),
1972
- SseOpcode::Pmovsxbw => (LegacyPrefixes::_66, 0x0F3820, 3),
1973
- SseOpcode::Pmovsxbq => (LegacyPrefixes::_66, 0x0F3822, 3),
1974
- SseOpcode::Pmovsxwd => (LegacyPrefixes::_66, 0x0F3823, 3),
1975
- SseOpcode::Pmovsxwq => (LegacyPrefixes::_66, 0x0F3824, 3),
1976
- SseOpcode::Pmovsxdq => (LegacyPrefixes::_66, 0x0F3825, 3),
1977
- SseOpcode::Pmovzxbd => (LegacyPrefixes::_66, 0x0F3831, 3),
1978
- SseOpcode::Pmovzxbw => (LegacyPrefixes::_66, 0x0F3830, 3),
1979
- SseOpcode::Pmovzxbq => (LegacyPrefixes::_66, 0x0F3832, 3),
1980
- SseOpcode::Pmovzxwd => (LegacyPrefixes::_66, 0x0F3833, 3),
1981
- SseOpcode::Pmovzxwq => (LegacyPrefixes::_66, 0x0F3834, 3),
1982
- SseOpcode::Pmovzxdq => (LegacyPrefixes::_66, 0x0F3835, 3),
1983
- SseOpcode::Sqrtps => (LegacyPrefixes::None, 0x0F51, 2),
1984
- SseOpcode::Sqrtpd => (LegacyPrefixes::_66, 0x0F51, 2),
1985
- SseOpcode::Movddup => (LegacyPrefixes::_F2, 0x0F12, 2),
1986
- _ => unimplemented!("Opcode {:?} not implemented", op),
1987
- };
1988
-
1989
- match src_e {
1990
- RegMem::Reg { reg: reg_e } => {
1991
- emit_std_reg_reg(sink, prefix, opcode, num_opcodes, reg_g, reg_e, rex);
1992
- }
1993
- RegMem::Mem { addr } => {
1994
- let addr = &addr.finalize(state, sink);
1995
- emit_std_reg_mem(sink, prefix, opcode, num_opcodes, reg_g, addr, rex, 0);
1996
- }
1997
- };
1998
- }
1999
-
2000
- Inst::XmmUnaryRmRImm { op, src, dst, imm } => {
2001
- let dst = dst.to_reg().to_reg();
2002
- let src = src.clone().to_reg_mem().clone();
2003
- let rex = RexFlags::clear_w();
2004
-
2005
- let (prefix, opcode, len) = match op {
2006
- SseOpcode::Roundps => (LegacyPrefixes::_66, 0x0F3A08, 3),
2007
- SseOpcode::Roundss => (LegacyPrefixes::_66, 0x0F3A0A, 3),
2008
- SseOpcode::Roundpd => (LegacyPrefixes::_66, 0x0F3A09, 3),
2009
- SseOpcode::Roundsd => (LegacyPrefixes::_66, 0x0F3A0B, 3),
2010
- SseOpcode::Pshufd => (LegacyPrefixes::_66, 0x0F70, 2),
2011
- SseOpcode::Pshuflw => (LegacyPrefixes::_F2, 0x0F70, 2),
2012
- SseOpcode::Pshufhw => (LegacyPrefixes::_F3, 0x0F70, 2),
2013
- _ => unimplemented!("Opcode {:?} not implemented", op),
2014
- };
2015
- match src {
2016
- RegMem::Reg { reg } => {
2017
- emit_std_reg_reg(sink, prefix, opcode, len, dst, reg, rex);
2018
- }
2019
- RegMem::Mem { addr } => {
2020
- let addr = &addr.finalize(state, sink);
2021
- // N.B.: bytes_at_end == 1, because of the `imm` byte below.
2022
- emit_std_reg_mem(sink, prefix, opcode, len, dst, addr, rex, 1);
2023
- }
2024
- }
2025
- sink.put1(*imm);
2026
- }
2027
-
2028
- Inst::XmmUnaryRmREvex { op, src, dst } => {
2029
- let dst = dst.to_reg().to_reg();
2030
- let src = match src.clone().to_reg_mem().clone() {
2031
- RegMem::Reg { reg } => {
2032
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2033
- }
2034
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2035
- };
2036
-
2037
- let (prefix, map, w, opcode) = match op {
2038
- Avx512Opcode::Vcvtudq2ps => (LegacyPrefixes::_F2, OpcodeMap::_0F, false, 0x7a),
2039
- Avx512Opcode::Vpabsq => (LegacyPrefixes::_66, OpcodeMap::_0F38, true, 0x1f),
2040
- Avx512Opcode::Vpopcntb => (LegacyPrefixes::_66, OpcodeMap::_0F38, false, 0x54),
2041
- _ => unimplemented!("Opcode {:?} not implemented", op),
2042
- };
2043
- EvexInstruction::new()
2044
- .length(EvexVectorLength::V128)
2045
- .prefix(prefix)
2046
- .map(map)
2047
- .w(w)
2048
- .opcode(opcode)
2049
- .tuple_type(op.tuple_type())
2050
- .reg(dst.to_real_reg().unwrap().hw_enc())
2051
- .rm(src)
2052
- .encode(sink);
2053
- }
2054
-
2055
- Inst::XmmUnaryRmRImmEvex { op, src, dst, imm } => {
2056
- let dst = dst.to_reg().to_reg();
2057
- let src = match src.clone().to_reg_mem().clone() {
2058
- RegMem::Reg { reg } => {
2059
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2060
- }
2061
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2062
- };
2063
-
2064
- let (opcode, opcode_ext, w) = match op {
2065
- Avx512Opcode::VpsraqImm => (0x72, 4, true),
2066
- _ => unimplemented!("Opcode {:?} not implemented", op),
2067
- };
2068
- EvexInstruction::new()
2069
- .length(EvexVectorLength::V128)
2070
- .prefix(LegacyPrefixes::_66)
2071
- .map(OpcodeMap::_0F)
2072
- .w(w)
2073
- .opcode(opcode)
2074
- .reg(opcode_ext)
2075
- .vvvvv(dst.to_real_reg().unwrap().hw_enc())
2076
- .tuple_type(op.tuple_type())
2077
- .rm(src)
2078
- .imm(*imm)
2079
- .encode(sink);
2080
- }
2081
-
2082
- Inst::XmmRmR {
2083
- op,
2084
- src1,
2085
- src2,
2086
- dst,
2087
- } => emit(
2088
- &Inst::XmmRmRUnaligned {
2089
- op: *op,
2090
- dst: *dst,
2091
- src1: *src1,
2092
- src2: XmmMem::new(src2.clone().to_reg_mem()).unwrap(),
2093
- },
2094
- sink,
2095
- info,
2096
- state,
2097
- ),
2098
-
2099
- Inst::XmmRmRUnaligned {
2100
- op,
2101
- src1,
2102
- src2: src_e,
2103
- dst: reg_g,
2104
- } => {
2105
- let src1 = src1.to_reg();
2106
- let reg_g = reg_g.to_reg().to_reg();
2107
- let src_e = src_e.clone().to_reg_mem().clone();
2108
- debug_assert_eq!(src1, reg_g);
2109
-
2110
- let rex = RexFlags::clear_w();
2111
- let (prefix, opcode, length) = match op {
2112
- SseOpcode::Addps => (LegacyPrefixes::None, 0x0F58, 2),
2113
- SseOpcode::Addpd => (LegacyPrefixes::_66, 0x0F58, 2),
2114
- SseOpcode::Addss => (LegacyPrefixes::_F3, 0x0F58, 2),
2115
- SseOpcode::Addsd => (LegacyPrefixes::_F2, 0x0F58, 2),
2116
- SseOpcode::Andps => (LegacyPrefixes::None, 0x0F54, 2),
2117
- SseOpcode::Andpd => (LegacyPrefixes::_66, 0x0F54, 2),
2118
- SseOpcode::Andnps => (LegacyPrefixes::None, 0x0F55, 2),
2119
- SseOpcode::Andnpd => (LegacyPrefixes::_66, 0x0F55, 2),
2120
- SseOpcode::Divps => (LegacyPrefixes::None, 0x0F5E, 2),
2121
- SseOpcode::Divpd => (LegacyPrefixes::_66, 0x0F5E, 2),
2122
- SseOpcode::Divss => (LegacyPrefixes::_F3, 0x0F5E, 2),
2123
- SseOpcode::Divsd => (LegacyPrefixes::_F2, 0x0F5E, 2),
2124
- SseOpcode::Maxps => (LegacyPrefixes::None, 0x0F5F, 2),
2125
- SseOpcode::Maxpd => (LegacyPrefixes::_66, 0x0F5F, 2),
2126
- SseOpcode::Maxss => (LegacyPrefixes::_F3, 0x0F5F, 2),
2127
- SseOpcode::Maxsd => (LegacyPrefixes::_F2, 0x0F5F, 2),
2128
- SseOpcode::Minps => (LegacyPrefixes::None, 0x0F5D, 2),
2129
- SseOpcode::Minpd => (LegacyPrefixes::_66, 0x0F5D, 2),
2130
- SseOpcode::Minss => (LegacyPrefixes::_F3, 0x0F5D, 2),
2131
- SseOpcode::Minsd => (LegacyPrefixes::_F2, 0x0F5D, 2),
2132
- SseOpcode::Movlhps => (LegacyPrefixes::None, 0x0F16, 2),
2133
- SseOpcode::Movsd => (LegacyPrefixes::_F2, 0x0F10, 2),
2134
- SseOpcode::Mulps => (LegacyPrefixes::None, 0x0F59, 2),
2135
- SseOpcode::Mulpd => (LegacyPrefixes::_66, 0x0F59, 2),
2136
- SseOpcode::Mulss => (LegacyPrefixes::_F3, 0x0F59, 2),
2137
- SseOpcode::Mulsd => (LegacyPrefixes::_F2, 0x0F59, 2),
2138
- SseOpcode::Orpd => (LegacyPrefixes::_66, 0x0F56, 2),
2139
- SseOpcode::Orps => (LegacyPrefixes::None, 0x0F56, 2),
2140
- SseOpcode::Packssdw => (LegacyPrefixes::_66, 0x0F6B, 2),
2141
- SseOpcode::Packsswb => (LegacyPrefixes::_66, 0x0F63, 2),
2142
- SseOpcode::Packusdw => (LegacyPrefixes::_66, 0x0F382B, 3),
2143
- SseOpcode::Packuswb => (LegacyPrefixes::_66, 0x0F67, 2),
2144
- SseOpcode::Paddb => (LegacyPrefixes::_66, 0x0FFC, 2),
2145
- SseOpcode::Paddd => (LegacyPrefixes::_66, 0x0FFE, 2),
2146
- SseOpcode::Paddq => (LegacyPrefixes::_66, 0x0FD4, 2),
2147
- SseOpcode::Paddw => (LegacyPrefixes::_66, 0x0FFD, 2),
2148
- SseOpcode::Paddsb => (LegacyPrefixes::_66, 0x0FEC, 2),
2149
- SseOpcode::Paddsw => (LegacyPrefixes::_66, 0x0FED, 2),
2150
- SseOpcode::Paddusb => (LegacyPrefixes::_66, 0x0FDC, 2),
2151
- SseOpcode::Paddusw => (LegacyPrefixes::_66, 0x0FDD, 2),
2152
- SseOpcode::Pmaddubsw => (LegacyPrefixes::_66, 0x0F3804, 3),
2153
- SseOpcode::Pand => (LegacyPrefixes::_66, 0x0FDB, 2),
2154
- SseOpcode::Pandn => (LegacyPrefixes::_66, 0x0FDF, 2),
2155
- SseOpcode::Pavgb => (LegacyPrefixes::_66, 0x0FE0, 2),
2156
- SseOpcode::Pavgw => (LegacyPrefixes::_66, 0x0FE3, 2),
2157
- SseOpcode::Pcmpeqb => (LegacyPrefixes::_66, 0x0F74, 2),
2158
- SseOpcode::Pcmpeqw => (LegacyPrefixes::_66, 0x0F75, 2),
2159
- SseOpcode::Pcmpeqd => (LegacyPrefixes::_66, 0x0F76, 2),
2160
- SseOpcode::Pcmpeqq => (LegacyPrefixes::_66, 0x0F3829, 3),
2161
- SseOpcode::Pcmpgtb => (LegacyPrefixes::_66, 0x0F64, 2),
2162
- SseOpcode::Pcmpgtw => (LegacyPrefixes::_66, 0x0F65, 2),
2163
- SseOpcode::Pcmpgtd => (LegacyPrefixes::_66, 0x0F66, 2),
2164
- SseOpcode::Pcmpgtq => (LegacyPrefixes::_66, 0x0F3837, 3),
2165
- SseOpcode::Pmaddwd => (LegacyPrefixes::_66, 0x0FF5, 2),
2166
- SseOpcode::Pmaxsb => (LegacyPrefixes::_66, 0x0F383C, 3),
2167
- SseOpcode::Pmaxsw => (LegacyPrefixes::_66, 0x0FEE, 2),
2168
- SseOpcode::Pmaxsd => (LegacyPrefixes::_66, 0x0F383D, 3),
2169
- SseOpcode::Pmaxub => (LegacyPrefixes::_66, 0x0FDE, 2),
2170
- SseOpcode::Pmaxuw => (LegacyPrefixes::_66, 0x0F383E, 3),
2171
- SseOpcode::Pmaxud => (LegacyPrefixes::_66, 0x0F383F, 3),
2172
- SseOpcode::Pminsb => (LegacyPrefixes::_66, 0x0F3838, 3),
2173
- SseOpcode::Pminsw => (LegacyPrefixes::_66, 0x0FEA, 2),
2174
- SseOpcode::Pminsd => (LegacyPrefixes::_66, 0x0F3839, 3),
2175
- SseOpcode::Pminub => (LegacyPrefixes::_66, 0x0FDA, 2),
2176
- SseOpcode::Pminuw => (LegacyPrefixes::_66, 0x0F383A, 3),
2177
- SseOpcode::Pminud => (LegacyPrefixes::_66, 0x0F383B, 3),
2178
- SseOpcode::Pmuldq => (LegacyPrefixes::_66, 0x0F3828, 3),
2179
- SseOpcode::Pmulhw => (LegacyPrefixes::_66, 0x0FE5, 2),
2180
- SseOpcode::Pmulhrsw => (LegacyPrefixes::_66, 0x0F380B, 3),
2181
- SseOpcode::Pmulhuw => (LegacyPrefixes::_66, 0x0FE4, 2),
2182
- SseOpcode::Pmulld => (LegacyPrefixes::_66, 0x0F3840, 3),
2183
- SseOpcode::Pmullw => (LegacyPrefixes::_66, 0x0FD5, 2),
2184
- SseOpcode::Pmuludq => (LegacyPrefixes::_66, 0x0FF4, 2),
2185
- SseOpcode::Por => (LegacyPrefixes::_66, 0x0FEB, 2),
2186
- SseOpcode::Pshufb => (LegacyPrefixes::_66, 0x0F3800, 3),
2187
- SseOpcode::Psubb => (LegacyPrefixes::_66, 0x0FF8, 2),
2188
- SseOpcode::Psubd => (LegacyPrefixes::_66, 0x0FFA, 2),
2189
- SseOpcode::Psubq => (LegacyPrefixes::_66, 0x0FFB, 2),
2190
- SseOpcode::Psubw => (LegacyPrefixes::_66, 0x0FF9, 2),
2191
- SseOpcode::Psubsb => (LegacyPrefixes::_66, 0x0FE8, 2),
2192
- SseOpcode::Psubsw => (LegacyPrefixes::_66, 0x0FE9, 2),
2193
- SseOpcode::Psubusb => (LegacyPrefixes::_66, 0x0FD8, 2),
2194
- SseOpcode::Psubusw => (LegacyPrefixes::_66, 0x0FD9, 2),
2195
- SseOpcode::Punpckhbw => (LegacyPrefixes::_66, 0x0F68, 2),
2196
- SseOpcode::Punpckhwd => (LegacyPrefixes::_66, 0x0F69, 2),
2197
- SseOpcode::Punpcklbw => (LegacyPrefixes::_66, 0x0F60, 2),
2198
- SseOpcode::Punpcklwd => (LegacyPrefixes::_66, 0x0F61, 2),
2199
- SseOpcode::Punpckldq => (LegacyPrefixes::_66, 0x0F62, 2),
2200
- SseOpcode::Punpcklqdq => (LegacyPrefixes::_66, 0x0F6C, 2),
2201
- SseOpcode::Punpckhdq => (LegacyPrefixes::_66, 0x0F6A, 2),
2202
- SseOpcode::Punpckhqdq => (LegacyPrefixes::_66, 0x0F6D, 2),
2203
- SseOpcode::Pxor => (LegacyPrefixes::_66, 0x0FEF, 2),
2204
- SseOpcode::Subps => (LegacyPrefixes::None, 0x0F5C, 2),
2205
- SseOpcode::Subpd => (LegacyPrefixes::_66, 0x0F5C, 2),
2206
- SseOpcode::Subss => (LegacyPrefixes::_F3, 0x0F5C, 2),
2207
- SseOpcode::Subsd => (LegacyPrefixes::_F2, 0x0F5C, 2),
2208
- SseOpcode::Unpcklps => (LegacyPrefixes::None, 0x0F14, 2),
2209
- SseOpcode::Unpckhps => (LegacyPrefixes::None, 0x0F15, 2),
2210
- SseOpcode::Xorps => (LegacyPrefixes::None, 0x0F57, 2),
2211
- SseOpcode::Xorpd => (LegacyPrefixes::_66, 0x0F57, 2),
2212
- SseOpcode::Phaddw => (LegacyPrefixes::_66, 0x0F3801, 3),
2213
- SseOpcode::Phaddd => (LegacyPrefixes::_66, 0x0F3802, 3),
2214
- SseOpcode::Movss => (LegacyPrefixes::_F3, 0x0F10, 2),
2215
- SseOpcode::Cvtss2sd => (LegacyPrefixes::_F3, 0x0F5A, 2),
2216
- SseOpcode::Cvtsd2ss => (LegacyPrefixes::_F2, 0x0F5A, 2),
2217
- SseOpcode::Sqrtss => (LegacyPrefixes::_F3, 0x0F51, 2),
2218
- SseOpcode::Sqrtsd => (LegacyPrefixes::_F2, 0x0F51, 2),
2219
- SseOpcode::Unpcklpd => (LegacyPrefixes::_66, 0x0F14, 2),
2220
- _ => unimplemented!("Opcode {:?} not implemented", op),
2221
- };
2222
-
2223
- match src_e {
2224
- RegMem::Reg { reg: reg_e } => {
2225
- emit_std_reg_reg(sink, prefix, opcode, length, reg_g, reg_e, rex);
2226
- }
2227
- RegMem::Mem { addr } => {
2228
- let addr = &addr.finalize(state, sink);
2229
- emit_std_reg_mem(sink, prefix, opcode, length, reg_g, addr, rex, 0);
2230
- }
2231
- }
2232
- }
2233
-
2234
- Inst::XmmRmRBlend {
2235
- op,
2236
- src1,
2237
- src2,
2238
- dst,
2239
- mask,
2240
- } => {
2241
- let src1 = src1.to_reg();
2242
- let mask = mask.to_reg();
2243
- debug_assert_eq!(mask, regs::xmm0());
2244
- let reg_g = dst.to_reg().to_reg();
2245
- debug_assert_eq!(src1, reg_g);
2246
- let src_e = src2.clone().to_reg_mem().clone();
2247
-
2248
- let rex = RexFlags::clear_w();
2249
- let (prefix, opcode, length) = match op {
2250
- SseOpcode::Blendvps => (LegacyPrefixes::_66, 0x0F3814, 3),
2251
- SseOpcode::Blendvpd => (LegacyPrefixes::_66, 0x0F3815, 3),
2252
- SseOpcode::Pblendvb => (LegacyPrefixes::_66, 0x0F3810, 3),
2253
- _ => unimplemented!("Opcode {:?} not implemented", op),
2254
- };
2255
-
2256
- match src_e {
2257
- RegMem::Reg { reg: reg_e } => {
2258
- emit_std_reg_reg(sink, prefix, opcode, length, reg_g, reg_e, rex);
2259
- }
2260
- RegMem::Mem { addr } => {
2261
- let addr = &addr.finalize(state, sink);
2262
- emit_std_reg_mem(sink, prefix, opcode, length, reg_g, addr, rex, 0);
2263
- }
2264
- }
2265
- }
2266
-
2267
- Inst::XmmRmiRVex {
2268
- op,
2269
- src1,
2270
- src2,
2271
- dst,
2272
- } => {
2273
- use LegacyPrefixes as LP;
2274
- use OpcodeMap as OM;
2275
-
2276
- let dst = dst.to_reg().to_reg();
2277
- let src1 = src1.to_reg();
2278
- let src2 = src2.clone().to_reg_mem_imm().clone();
2279
-
2280
- // When the opcode is commutative, src1 is xmm{0..7}, and src2 is
2281
- // xmm{8..15}, then we can swap the operands to save one byte on the
2282
- // instruction's encoding.
2283
- let (src1, src2) = match (src1, src2) {
2284
- (src1, RegMemImm::Reg { reg: src2 })
2285
- if op.is_commutative()
2286
- && src1.to_real_reg().unwrap().hw_enc() < 8
2287
- && src2.to_real_reg().unwrap().hw_enc() >= 8 =>
2288
- {
2289
- (src2, RegMemImm::Reg { reg: src1 })
2290
- }
2291
- (src1, src2) => (src1, src2),
2292
- };
2293
-
2294
- let src2 = match src2 {
2295
- // For opcodes where one of the operands is an immediate the
2296
- // encoding is a bit different, notably the usage of
2297
- // `opcode_ext`, so handle that specially here.
2298
- RegMemImm::Imm { simm32 } => {
2299
- let (opcode, opcode_ext, prefix) = match op {
2300
- AvxOpcode::Vpsrlw => (0x71, 2, LegacyPrefixes::_66),
2301
- AvxOpcode::Vpsrld => (0x72, 2, LegacyPrefixes::_66),
2302
- AvxOpcode::Vpsrlq => (0x73, 2, LegacyPrefixes::_66),
2303
- AvxOpcode::Vpsllw => (0x71, 6, LegacyPrefixes::_66),
2304
- AvxOpcode::Vpslld => (0x72, 6, LegacyPrefixes::_66),
2305
- AvxOpcode::Vpsllq => (0x73, 6, LegacyPrefixes::_66),
2306
- AvxOpcode::Vpsraw => (0x71, 4, LegacyPrefixes::_66),
2307
- AvxOpcode::Vpsrad => (0x72, 4, LegacyPrefixes::_66),
2308
- _ => panic!("unexpected rmi_r_vex opcode with immediate {op:?}"),
2309
- };
2310
- VexInstruction::new()
2311
- .length(VexVectorLength::V128)
2312
- .prefix(prefix)
2313
- .map(OpcodeMap::_0F)
2314
- .opcode(opcode)
2315
- .opcode_ext(opcode_ext)
2316
- .vvvv(dst.to_real_reg().unwrap().hw_enc())
2317
- .prefix(LegacyPrefixes::_66)
2318
- .rm(src1.to_real_reg().unwrap().hw_enc())
2319
- .imm(simm32.try_into().unwrap())
2320
- .encode(sink);
2321
- return;
2322
- }
2323
- RegMemImm::Reg { reg } => {
2324
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2325
- }
2326
- RegMemImm::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2327
- };
2328
-
2329
- let (prefix, map, opcode) = match op {
2330
- AvxOpcode::Vminps => (LP::None, OM::_0F, 0x5D),
2331
- AvxOpcode::Vminpd => (LP::_66, OM::_0F, 0x5D),
2332
- AvxOpcode::Vmaxps => (LP::None, OM::_0F, 0x5F),
2333
- AvxOpcode::Vmaxpd => (LP::_66, OM::_0F, 0x5F),
2334
- AvxOpcode::Vandnps => (LP::None, OM::_0F, 0x55),
2335
- AvxOpcode::Vandnpd => (LP::_66, OM::_0F, 0x55),
2336
- AvxOpcode::Vpandn => (LP::_66, OM::_0F, 0xDF),
2337
- AvxOpcode::Vpsrlw => (LP::_66, OM::_0F, 0xD1),
2338
- AvxOpcode::Vpsrld => (LP::_66, OM::_0F, 0xD2),
2339
- AvxOpcode::Vpsrlq => (LP::_66, OM::_0F, 0xD3),
2340
- AvxOpcode::Vpaddb => (LP::_66, OM::_0F, 0xFC),
2341
- AvxOpcode::Vpaddw => (LP::_66, OM::_0F, 0xFD),
2342
- AvxOpcode::Vpaddd => (LP::_66, OM::_0F, 0xFE),
2343
- AvxOpcode::Vpaddq => (LP::_66, OM::_0F, 0xD4),
2344
- AvxOpcode::Vpaddsb => (LP::_66, OM::_0F, 0xEC),
2345
- AvxOpcode::Vpaddsw => (LP::_66, OM::_0F, 0xED),
2346
- AvxOpcode::Vpaddusb => (LP::_66, OM::_0F, 0xDC),
2347
- AvxOpcode::Vpaddusw => (LP::_66, OM::_0F, 0xDD),
2348
- AvxOpcode::Vpsubb => (LP::_66, OM::_0F, 0xF8),
2349
- AvxOpcode::Vpsubw => (LP::_66, OM::_0F, 0xF9),
2350
- AvxOpcode::Vpsubd => (LP::_66, OM::_0F, 0xFA),
2351
- AvxOpcode::Vpsubq => (LP::_66, OM::_0F, 0xFB),
2352
- AvxOpcode::Vpsubsb => (LP::_66, OM::_0F, 0xE8),
2353
- AvxOpcode::Vpsubsw => (LP::_66, OM::_0F, 0xE9),
2354
- AvxOpcode::Vpsubusb => (LP::_66, OM::_0F, 0xD8),
2355
- AvxOpcode::Vpsubusw => (LP::_66, OM::_0F, 0xD9),
2356
- AvxOpcode::Vpavgb => (LP::_66, OM::_0F, 0xE0),
2357
- AvxOpcode::Vpavgw => (LP::_66, OM::_0F, 0xE3),
2358
- AvxOpcode::Vpand => (LP::_66, OM::_0F, 0xDB),
2359
- AvxOpcode::Vandps => (LP::None, OM::_0F, 0x54),
2360
- AvxOpcode::Vandpd => (LP::_66, OM::_0F, 0x54),
2361
- AvxOpcode::Vpor => (LP::_66, OM::_0F, 0xEB),
2362
- AvxOpcode::Vorps => (LP::None, OM::_0F, 0x56),
2363
- AvxOpcode::Vorpd => (LP::_66, OM::_0F, 0x56),
2364
- AvxOpcode::Vpxor => (LP::_66, OM::_0F, 0xEF),
2365
- AvxOpcode::Vxorps => (LP::None, OM::_0F, 0x57),
2366
- AvxOpcode::Vxorpd => (LP::_66, OM::_0F, 0x57),
2367
- AvxOpcode::Vpmullw => (LP::_66, OM::_0F, 0xD5),
2368
- AvxOpcode::Vpmulld => (LP::_66, OM::_0F38, 0x40),
2369
- AvxOpcode::Vpmulhw => (LP::_66, OM::_0F, 0xE5),
2370
- AvxOpcode::Vpmulhrsw => (LP::_66, OM::_0F38, 0x0B),
2371
- AvxOpcode::Vpmulhuw => (LP::_66, OM::_0F, 0xE4),
2372
- AvxOpcode::Vpmuldq => (LP::_66, OM::_0F38, 0x28),
2373
- AvxOpcode::Vpmuludq => (LP::_66, OM::_0F, 0xF4),
2374
- AvxOpcode::Vpunpckhwd => (LP::_66, OM::_0F, 0x69),
2375
- AvxOpcode::Vpunpcklwd => (LP::_66, OM::_0F, 0x61),
2376
- AvxOpcode::Vunpcklps => (LP::None, OM::_0F, 0x14),
2377
- AvxOpcode::Vunpckhps => (LP::None, OM::_0F, 0x15),
2378
- AvxOpcode::Vaddps => (LP::None, OM::_0F, 0x58),
2379
- AvxOpcode::Vaddpd => (LP::_66, OM::_0F, 0x58),
2380
- AvxOpcode::Vsubps => (LP::None, OM::_0F, 0x5C),
2381
- AvxOpcode::Vsubpd => (LP::_66, OM::_0F, 0x5C),
2382
- AvxOpcode::Vmulps => (LP::None, OM::_0F, 0x59),
2383
- AvxOpcode::Vmulpd => (LP::_66, OM::_0F, 0x59),
2384
- AvxOpcode::Vdivps => (LP::None, OM::_0F, 0x5E),
2385
- AvxOpcode::Vdivpd => (LP::_66, OM::_0F, 0x5E),
2386
- AvxOpcode::Vpcmpeqb => (LP::_66, OM::_0F, 0x74),
2387
- AvxOpcode::Vpcmpeqw => (LP::_66, OM::_0F, 0x75),
2388
- AvxOpcode::Vpcmpeqd => (LP::_66, OM::_0F, 0x76),
2389
- AvxOpcode::Vpcmpeqq => (LP::_66, OM::_0F38, 0x29),
2390
- AvxOpcode::Vpcmpgtb => (LP::_66, OM::_0F, 0x64),
2391
- AvxOpcode::Vpcmpgtw => (LP::_66, OM::_0F, 0x65),
2392
- AvxOpcode::Vpcmpgtd => (LP::_66, OM::_0F, 0x66),
2393
- AvxOpcode::Vpcmpgtq => (LP::_66, OM::_0F38, 0x37),
2394
- AvxOpcode::Vmovlhps => (LP::None, OM::_0F, 0x16),
2395
- AvxOpcode::Vpminsb => (LP::_66, OM::_0F38, 0x38),
2396
- AvxOpcode::Vpminsw => (LP::_66, OM::_0F, 0xEA),
2397
- AvxOpcode::Vpminsd => (LP::_66, OM::_0F38, 0x39),
2398
- AvxOpcode::Vpmaxsb => (LP::_66, OM::_0F38, 0x3C),
2399
- AvxOpcode::Vpmaxsw => (LP::_66, OM::_0F, 0xEE),
2400
- AvxOpcode::Vpmaxsd => (LP::_66, OM::_0F38, 0x3D),
2401
- AvxOpcode::Vpminub => (LP::_66, OM::_0F, 0xDA),
2402
- AvxOpcode::Vpminuw => (LP::_66, OM::_0F38, 0x3A),
2403
- AvxOpcode::Vpminud => (LP::_66, OM::_0F38, 0x3B),
2404
- AvxOpcode::Vpmaxub => (LP::_66, OM::_0F, 0xDE),
2405
- AvxOpcode::Vpmaxuw => (LP::_66, OM::_0F38, 0x3E),
2406
- AvxOpcode::Vpmaxud => (LP::_66, OM::_0F38, 0x3F),
2407
- AvxOpcode::Vpunpcklbw => (LP::_66, OM::_0F, 0x60),
2408
- AvxOpcode::Vpunpckhbw => (LP::_66, OM::_0F, 0x68),
2409
- AvxOpcode::Vpacksswb => (LP::_66, OM::_0F, 0x63),
2410
- AvxOpcode::Vpackssdw => (LP::_66, OM::_0F, 0x6B),
2411
- AvxOpcode::Vpackuswb => (LP::_66, OM::_0F, 0x67),
2412
- AvxOpcode::Vpackusdw => (LP::_66, OM::_0F38, 0x2B),
2413
- AvxOpcode::Vpmaddwd => (LP::_66, OM::_0F, 0xF5),
2414
- AvxOpcode::Vpmaddubsw => (LP::_66, OM::_0F38, 0x04),
2415
- AvxOpcode::Vpshufb => (LP::_66, OM::_0F38, 0x00),
2416
- AvxOpcode::Vpsllw => (LP::_66, OM::_0F, 0xF1),
2417
- AvxOpcode::Vpslld => (LP::_66, OM::_0F, 0xF2),
2418
- AvxOpcode::Vpsllq => (LP::_66, OM::_0F, 0xF3),
2419
- AvxOpcode::Vpsraw => (LP::_66, OM::_0F, 0xE1),
2420
- AvxOpcode::Vpsrad => (LP::_66, OM::_0F, 0xE2),
2421
- AvxOpcode::Vaddss => (LP::_F3, OM::_0F, 0x58),
2422
- AvxOpcode::Vaddsd => (LP::_F2, OM::_0F, 0x58),
2423
- AvxOpcode::Vmulss => (LP::_F3, OM::_0F, 0x59),
2424
- AvxOpcode::Vmulsd => (LP::_F2, OM::_0F, 0x59),
2425
- AvxOpcode::Vsubss => (LP::_F3, OM::_0F, 0x5C),
2426
- AvxOpcode::Vsubsd => (LP::_F2, OM::_0F, 0x5C),
2427
- AvxOpcode::Vdivss => (LP::_F3, OM::_0F, 0x5E),
2428
- AvxOpcode::Vdivsd => (LP::_F2, OM::_0F, 0x5E),
2429
- AvxOpcode::Vminss => (LP::_F3, OM::_0F, 0x5D),
2430
- AvxOpcode::Vminsd => (LP::_F2, OM::_0F, 0x5D),
2431
- AvxOpcode::Vmaxss => (LP::_F3, OM::_0F, 0x5F),
2432
- AvxOpcode::Vmaxsd => (LP::_F2, OM::_0F, 0x5F),
2433
- AvxOpcode::Vphaddw => (LP::_66, OM::_0F38, 0x01),
2434
- AvxOpcode::Vphaddd => (LP::_66, OM::_0F38, 0x02),
2435
- AvxOpcode::Vpunpckldq => (LP::_66, OM::_0F, 0x62),
2436
- AvxOpcode::Vpunpckhdq => (LP::_66, OM::_0F, 0x6A),
2437
- AvxOpcode::Vpunpcklqdq => (LP::_66, OM::_0F, 0x6C),
2438
- AvxOpcode::Vpunpckhqdq => (LP::_66, OM::_0F, 0x6D),
2439
- AvxOpcode::Vmovsd => (LP::_F2, OM::_0F, 0x10),
2440
- AvxOpcode::Vmovss => (LP::_F3, OM::_0F, 0x10),
2441
- AvxOpcode::Vcvtss2sd => (LP::_F3, OM::_0F, 0x5A),
2442
- AvxOpcode::Vcvtsd2ss => (LP::_F2, OM::_0F, 0x5A),
2443
- AvxOpcode::Vsqrtss => (LP::_F3, OM::_0F, 0x51),
2444
- AvxOpcode::Vsqrtsd => (LP::_F2, OM::_0F, 0x51),
2445
- AvxOpcode::Vunpcklpd => (LP::_66, OM::_0F, 0x14),
2446
- _ => panic!("unexpected rmir vex opcode {op:?}"),
2447
- };
2448
- VexInstruction::new()
2449
- .length(VexVectorLength::V128)
2450
- .prefix(prefix)
2451
- .map(map)
2452
- .opcode(opcode)
2453
- .reg(dst.to_real_reg().unwrap().hw_enc())
2454
- .vvvv(src1.to_real_reg().unwrap().hw_enc())
2455
- .rm(src2)
2456
- .encode(sink);
2457
- }
2458
-
2459
- Inst::XmmRmRImmVex {
2460
- op,
2461
- src1,
2462
- src2,
2463
- dst,
2464
- imm,
2465
- } => {
2466
- let dst = dst.to_reg().to_reg();
2467
- let src1 = src1.to_reg();
2468
- let src2 = match src2.clone().to_reg_mem().clone() {
2469
- RegMem::Reg { reg } => {
2470
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2471
- }
2472
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2473
- };
2474
-
2475
- let (w, prefix, map, opcode) = match op {
2476
- AvxOpcode::Vcmpps => (false, LegacyPrefixes::None, OpcodeMap::_0F, 0xC2),
2477
- AvxOpcode::Vcmppd => (false, LegacyPrefixes::_66, OpcodeMap::_0F, 0xC2),
2478
- AvxOpcode::Vpalignr => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x0F),
2479
- AvxOpcode::Vinsertps => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x21),
2480
- AvxOpcode::Vshufps => (false, LegacyPrefixes::None, OpcodeMap::_0F, 0xC6),
2481
- AvxOpcode::Vpblendw => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x0E),
2482
- _ => panic!("unexpected rmr_imm_vex opcode {op:?}"),
2483
- };
2484
-
2485
- VexInstruction::new()
2486
- .length(VexVectorLength::V128)
2487
- .prefix(prefix)
2488
- .map(map)
2489
- .w(w)
2490
- .opcode(opcode)
2491
- .reg(dst.to_real_reg().unwrap().hw_enc())
2492
- .vvvv(src1.to_real_reg().unwrap().hw_enc())
2493
- .rm(src2)
2494
- .imm(*imm)
2495
- .encode(sink);
2496
- }
2497
-
2498
- Inst::XmmVexPinsr {
2499
- op,
2500
- src1,
2501
- src2,
2502
- dst,
2503
- imm,
2504
- } => {
2505
- let dst = dst.to_reg().to_reg();
2506
- let src1 = src1.to_reg();
2507
- let src2 = match src2.clone().to_reg_mem().clone() {
2508
- RegMem::Reg { reg } => {
2509
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2510
- }
2511
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2512
- };
2513
-
2514
- let (w, map, opcode) = match op {
2515
- AvxOpcode::Vpinsrb => (false, OpcodeMap::_0F3A, 0x20),
2516
- AvxOpcode::Vpinsrw => (false, OpcodeMap::_0F, 0xC4),
2517
- AvxOpcode::Vpinsrd => (false, OpcodeMap::_0F3A, 0x22),
2518
- AvxOpcode::Vpinsrq => (true, OpcodeMap::_0F3A, 0x22),
2519
- _ => panic!("unexpected vex_pinsr opcode {op:?}"),
2520
- };
2521
-
2522
- VexInstruction::new()
2523
- .length(VexVectorLength::V128)
2524
- .prefix(LegacyPrefixes::_66)
2525
- .map(map)
2526
- .w(w)
2527
- .opcode(opcode)
2528
- .reg(dst.to_real_reg().unwrap().hw_enc())
2529
- .vvvv(src1.to_real_reg().unwrap().hw_enc())
2530
- .rm(src2)
2531
- .imm(*imm)
2532
- .encode(sink);
2533
- }
2534
-
2535
- Inst::XmmRmRVex3 {
2536
- op,
2537
- src1,
2538
- src2,
2539
- src3,
2540
- dst,
2541
- } => {
2542
- let src1 = src1.to_reg();
2543
- let dst = dst.to_reg().to_reg();
2544
- debug_assert_eq!(src1, dst);
2545
- let src2 = src2.to_reg();
2546
- let src3 = match src3.clone().to_reg_mem().clone() {
2547
- RegMem::Reg { reg } => {
2548
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2549
- }
2550
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2551
- };
2552
-
2553
- let (w, map, opcode) = match op {
2554
- AvxOpcode::Vfmadd132ss => (false, OpcodeMap::_0F38, 0x99),
2555
- AvxOpcode::Vfmadd213ss => (false, OpcodeMap::_0F38, 0xA9),
2556
- AvxOpcode::Vfnmadd132ss => (false, OpcodeMap::_0F38, 0x9D),
2557
- AvxOpcode::Vfnmadd213ss => (false, OpcodeMap::_0F38, 0xAD),
2558
- AvxOpcode::Vfmadd132sd => (true, OpcodeMap::_0F38, 0x99),
2559
- AvxOpcode::Vfmadd213sd => (true, OpcodeMap::_0F38, 0xA9),
2560
- AvxOpcode::Vfnmadd132sd => (true, OpcodeMap::_0F38, 0x9D),
2561
- AvxOpcode::Vfnmadd213sd => (true, OpcodeMap::_0F38, 0xAD),
2562
- AvxOpcode::Vfmadd132ps => (false, OpcodeMap::_0F38, 0x98),
2563
- AvxOpcode::Vfmadd213ps => (false, OpcodeMap::_0F38, 0xA8),
2564
- AvxOpcode::Vfnmadd132ps => (false, OpcodeMap::_0F38, 0x9C),
2565
- AvxOpcode::Vfnmadd213ps => (false, OpcodeMap::_0F38, 0xAC),
2566
- AvxOpcode::Vfmadd132pd => (true, OpcodeMap::_0F38, 0x98),
2567
- AvxOpcode::Vfmadd213pd => (true, OpcodeMap::_0F38, 0xA8),
2568
- AvxOpcode::Vfnmadd132pd => (true, OpcodeMap::_0F38, 0x9C),
2569
- AvxOpcode::Vfnmadd213pd => (true, OpcodeMap::_0F38, 0xAC),
2570
- AvxOpcode::Vblendvps => (false, OpcodeMap::_0F3A, 0x4A),
2571
- AvxOpcode::Vblendvpd => (false, OpcodeMap::_0F3A, 0x4B),
2572
- AvxOpcode::Vpblendvb => (false, OpcodeMap::_0F3A, 0x4C),
2573
- _ => unreachable!(),
2574
- };
2575
-
2576
- VexInstruction::new()
2577
- .length(VexVectorLength::V128)
2578
- .prefix(LegacyPrefixes::_66)
2579
- .map(map)
2580
- .w(w)
2581
- .opcode(opcode)
2582
- .reg(dst.to_real_reg().unwrap().hw_enc())
2583
- .rm(src3)
2584
- .vvvv(src2.to_real_reg().unwrap().hw_enc())
2585
- .encode(sink);
2586
- }
2587
-
2588
- Inst::XmmRmRBlendVex {
2589
- op,
2590
- src1,
2591
- src2,
2592
- mask,
2593
- dst,
2594
- } => {
2595
- let dst = dst.to_reg().to_reg();
2596
- let src1 = src1.to_reg();
2597
- let src2 = match src2.clone().to_reg_mem().clone() {
2598
- RegMem::Reg { reg } => {
2599
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2600
- }
2601
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2602
- };
2603
- let mask = mask.to_reg();
2604
-
2605
- let opcode = match op {
2606
- AvxOpcode::Vblendvps => 0x4A,
2607
- AvxOpcode::Vblendvpd => 0x4B,
2608
- AvxOpcode::Vpblendvb => 0x4C,
2609
- _ => unreachable!(),
2610
- };
2611
-
2612
- VexInstruction::new()
2613
- .length(VexVectorLength::V128)
2614
- .prefix(LegacyPrefixes::_66)
2615
- .map(OpcodeMap::_0F3A)
2616
- .opcode(opcode)
2617
- .reg(dst.to_real_reg().unwrap().hw_enc())
2618
- .vvvv(src1.to_real_reg().unwrap().hw_enc())
2619
- .rm(src2)
2620
- .imm(mask.to_real_reg().unwrap().hw_enc() << 4)
2621
- .encode(sink);
2622
- }
2623
-
2624
- Inst::XmmUnaryRmRVex { op, src, dst } => {
2625
- let dst = dst.to_reg().to_reg();
2626
- let src = match src.clone().to_reg_mem().clone() {
2627
- RegMem::Reg { reg } => {
2628
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2629
- }
2630
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2631
- };
2632
-
2633
- let (prefix, map, opcode) = match op {
2634
- AvxOpcode::Vpmovsxbw => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x20),
2635
- AvxOpcode::Vpmovzxbw => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x30),
2636
- AvxOpcode::Vpmovsxwd => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x23),
2637
- AvxOpcode::Vpmovzxwd => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x33),
2638
- AvxOpcode::Vpmovsxdq => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x25),
2639
- AvxOpcode::Vpmovzxdq => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x35),
2640
- AvxOpcode::Vpabsb => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x1C),
2641
- AvxOpcode::Vpabsw => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x1D),
2642
- AvxOpcode::Vpabsd => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x1E),
2643
- AvxOpcode::Vsqrtps => (LegacyPrefixes::None, OpcodeMap::_0F, 0x51),
2644
- AvxOpcode::Vsqrtpd => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x51),
2645
- AvxOpcode::Vcvtdq2pd => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0xE6),
2646
- AvxOpcode::Vcvtdq2ps => (LegacyPrefixes::None, OpcodeMap::_0F, 0x5B),
2647
- AvxOpcode::Vcvtpd2ps => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x5A),
2648
- AvxOpcode::Vcvtps2pd => (LegacyPrefixes::None, OpcodeMap::_0F, 0x5A),
2649
- AvxOpcode::Vcvttpd2dq => (LegacyPrefixes::_66, OpcodeMap::_0F, 0xE6),
2650
- AvxOpcode::Vcvttps2dq => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0x5B),
2651
- AvxOpcode::Vmovdqu => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0x6F),
2652
- AvxOpcode::Vmovups => (LegacyPrefixes::None, OpcodeMap::_0F, 0x10),
2653
- AvxOpcode::Vmovupd => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x10),
2654
-
2655
- // Note that for `vmov{s,d}` the `inst.isle` rules should
2656
- // statically ensure that only `Amode` operands are used here.
2657
- // Otherwise the other encodings of `vmovss` are more like
2658
- // 2-operand instructions which this unary encoding does not
2659
- // have.
2660
- AvxOpcode::Vmovss => match &src {
2661
- RegisterOrAmode::Amode(_) => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0x10),
2662
- _ => unreachable!(),
2663
- },
2664
- AvxOpcode::Vmovsd => match &src {
2665
- RegisterOrAmode::Amode(_) => (LegacyPrefixes::_F2, OpcodeMap::_0F, 0x10),
2666
- _ => unreachable!(),
2667
- },
2668
-
2669
- AvxOpcode::Vpbroadcastb => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x78),
2670
- AvxOpcode::Vpbroadcastw => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x79),
2671
- AvxOpcode::Vpbroadcastd => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x58),
2672
- AvxOpcode::Vbroadcastss => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x18),
2673
- AvxOpcode::Vmovddup => (LegacyPrefixes::_F2, OpcodeMap::_0F, 0x12),
2674
-
2675
- _ => panic!("unexpected rmr_imm_vex opcode {op:?}"),
2676
- };
2677
-
2678
- VexInstruction::new()
2679
- .length(VexVectorLength::V128)
2680
- .prefix(prefix)
2681
- .map(map)
2682
- .opcode(opcode)
2683
- .reg(dst.to_real_reg().unwrap().hw_enc())
2684
- .rm(src)
2685
- .encode(sink);
2686
- }
2687
-
2688
- Inst::XmmUnaryRmRImmVex { op, src, dst, imm } => {
2689
- let dst = dst.to_reg().to_reg();
2690
- let src = match src.clone().to_reg_mem().clone() {
2691
- RegMem::Reg { reg } => {
2692
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2693
- }
2694
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2695
- };
2696
-
2697
- let (prefix, map, opcode) = match op {
2698
- AvxOpcode::Vroundps => (LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x08),
2699
- AvxOpcode::Vroundpd => (LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x09),
2700
- AvxOpcode::Vpshuflw => (LegacyPrefixes::_F2, OpcodeMap::_0F, 0x70),
2701
- AvxOpcode::Vpshufhw => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0x70),
2702
- AvxOpcode::Vpshufd => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x70),
2703
- AvxOpcode::Vroundss => (LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x0A),
2704
- AvxOpcode::Vroundsd => (LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x0B),
2705
- _ => panic!("unexpected rmr_imm_vex opcode {op:?}"),
2706
- };
2707
-
2708
- let vex = VexInstruction::new()
2709
- .length(VexVectorLength::V128)
2710
- .prefix(prefix)
2711
- .map(map)
2712
- .opcode(opcode)
2713
- .reg(dst.to_real_reg().unwrap().hw_enc())
2714
- .rm(src)
2715
- .imm(*imm);
2716
-
2717
- // See comments in similar block above in `XmmUnaryRmRVex` for what
2718
- // this is doing.
2719
- let vex = match op {
2720
- AvxOpcode::Vroundss | AvxOpcode::Vroundsd => {
2721
- vex.vvvv(dst.to_real_reg().unwrap().hw_enc())
2722
- }
2723
- _ => vex,
2724
- };
2725
- vex.encode(sink);
2726
- }
2727
-
2728
- Inst::XmmMovRMVex { op, src, dst } => {
2729
- let src = src.to_reg();
2730
- let dst = dst.clone().finalize(state, sink);
2731
-
2732
- let (prefix, map, opcode) = match op {
2733
- AvxOpcode::Vmovdqu => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0x7F),
2734
- AvxOpcode::Vmovss => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0x11),
2735
- AvxOpcode::Vmovsd => (LegacyPrefixes::_F2, OpcodeMap::_0F, 0x11),
2736
- AvxOpcode::Vmovups => (LegacyPrefixes::None, OpcodeMap::_0F, 0x11),
2737
- AvxOpcode::Vmovupd => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x11),
2738
- _ => unimplemented!("Opcode {:?} not implemented", op),
2739
- };
2740
- VexInstruction::new()
2741
- .length(VexVectorLength::V128)
2742
- .prefix(prefix)
2743
- .map(map)
2744
- .opcode(opcode)
2745
- .rm(dst)
2746
- .reg(src.to_real_reg().unwrap().hw_enc())
2747
- .encode(sink);
2748
- }
2749
-
2750
- Inst::XmmMovRMImmVex { op, src, dst, imm } => {
2751
- let src = src.to_reg();
2752
- let dst = dst.clone().finalize(state, sink);
2753
-
2754
- let (w, prefix, map, opcode) = match op {
2755
- AvxOpcode::Vpextrb => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x14),
2756
- AvxOpcode::Vpextrw => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x15),
2757
- AvxOpcode::Vpextrd => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x16),
2758
- AvxOpcode::Vpextrq => (true, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x16),
2759
- _ => unimplemented!("Opcode {:?} not implemented", op),
2760
- };
2761
- VexInstruction::new()
2762
- .length(VexVectorLength::V128)
2763
- .w(w)
2764
- .prefix(prefix)
2765
- .map(map)
2766
- .opcode(opcode)
2767
- .rm(dst)
2768
- .reg(src.to_real_reg().unwrap().hw_enc())
2769
- .imm(*imm)
2770
- .encode(sink);
2771
- }
2772
-
2773
- Inst::XmmToGprImmVex { op, src, dst, imm } => {
2774
- let src = src.to_reg();
2775
- let dst = dst.to_reg().to_reg();
2776
-
2777
- let (w, prefix, map, opcode) = match op {
2778
- AvxOpcode::Vpextrb => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x14),
2779
- AvxOpcode::Vpextrw => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x15),
2780
- AvxOpcode::Vpextrd => (false, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x16),
2781
- AvxOpcode::Vpextrq => (true, LegacyPrefixes::_66, OpcodeMap::_0F3A, 0x16),
2782
- _ => unimplemented!("Opcode {:?} not implemented", op),
2783
- };
2784
- VexInstruction::new()
2785
- .length(VexVectorLength::V128)
2786
- .w(w)
2787
- .prefix(prefix)
2788
- .map(map)
2789
- .opcode(opcode)
2790
- .rm(dst.to_real_reg().unwrap().hw_enc())
2791
- .reg(src.to_real_reg().unwrap().hw_enc())
2792
- .imm(*imm)
2793
- .encode(sink);
2794
- }
2795
-
2796
- Inst::XmmToGprVex {
2797
- op,
2798
- src,
2799
- dst,
2800
- dst_size,
2801
- } => {
2802
- let src = src.to_reg();
2803
- let dst = dst.to_reg().to_reg();
2804
-
2805
- let (prefix, map, opcode) = match op {
2806
- // vmovd/vmovq are differentiated by `w`
2807
- AvxOpcode::Vmovd | AvxOpcode::Vmovq => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x7E),
2808
- AvxOpcode::Vmovmskps => (LegacyPrefixes::None, OpcodeMap::_0F, 0x50),
2809
- AvxOpcode::Vmovmskpd => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x50),
2810
- AvxOpcode::Vpmovmskb => (LegacyPrefixes::_66, OpcodeMap::_0F, 0xD7),
2811
- _ => unimplemented!("Opcode {:?} not implemented", op),
2812
- };
2813
- let w = match dst_size {
2814
- OperandSize::Size64 => true,
2815
- _ => false,
2816
- };
2817
- let mut vex = VexInstruction::new()
2818
- .length(VexVectorLength::V128)
2819
- .w(w)
2820
- .prefix(prefix)
2821
- .map(map)
2822
- .opcode(opcode);
2823
- vex = match op {
2824
- // The `vmovq/vmovd` reverse the order of the destination/source
2825
- // relative to other opcodes using this shape of instruction.
2826
- AvxOpcode::Vmovd | AvxOpcode::Vmovq => vex
2827
- .rm(dst.to_real_reg().unwrap().hw_enc())
2828
- .reg(src.to_real_reg().unwrap().hw_enc()),
2829
- _ => vex
2830
- .rm(src.to_real_reg().unwrap().hw_enc())
2831
- .reg(dst.to_real_reg().unwrap().hw_enc()),
2832
- };
2833
- vex.encode(sink);
2834
- }
2835
-
2836
- Inst::GprToXmmVex {
2837
- op,
2838
- src,
2839
- dst,
2840
- src_size,
2841
- } => {
2842
- let dst = dst.to_reg().to_reg();
2843
- let src = match src.clone().to_reg_mem().clone() {
2844
- RegMem::Reg { reg } => {
2845
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2846
- }
2847
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2848
- };
2849
-
2850
- let (prefix, map, opcode) = match op {
2851
- // vmovd/vmovq are differentiated by `w`
2852
- AvxOpcode::Vmovd | AvxOpcode::Vmovq => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x6E),
2853
- _ => unimplemented!("Opcode {:?} not implemented", op),
2854
- };
2855
- let w = match src_size {
2856
- OperandSize::Size64 => true,
2857
- _ => false,
2858
- };
2859
- VexInstruction::new()
2860
- .length(VexVectorLength::V128)
2861
- .w(w)
2862
- .prefix(prefix)
2863
- .map(map)
2864
- .opcode(opcode)
2865
- .rm(src)
2866
- .reg(dst.to_real_reg().unwrap().hw_enc())
2867
- .encode(sink);
2868
- }
2869
-
2870
- Inst::XmmCmpRmRVex { op, src1, src2 } => {
2871
- let src1 = src1.to_reg();
2872
- let src2 = match src2.clone().to_reg_mem().clone() {
2873
- RegMem::Reg { reg } => {
2874
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2875
- }
2876
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2877
- };
2878
-
2879
- let (prefix, map, opcode) = match op {
2880
- AvxOpcode::Vucomiss => (LegacyPrefixes::None, OpcodeMap::_0F, 0x2E),
2881
- AvxOpcode::Vucomisd => (LegacyPrefixes::_66, OpcodeMap::_0F, 0x2E),
2882
- AvxOpcode::Vptest => (LegacyPrefixes::_66, OpcodeMap::_0F38, 0x17),
2883
- _ => unimplemented!("Opcode {:?} not implemented", op),
2884
- };
2885
-
2886
- VexInstruction::new()
2887
- .length(VexVectorLength::V128)
2888
- .prefix(prefix)
2889
- .map(map)
2890
- .opcode(opcode)
2891
- .rm(src2)
2892
- .reg(src1.to_real_reg().unwrap().hw_enc())
2893
- .encode(sink);
2894
- }
2895
-
2896
- Inst::XmmRmREvex {
2897
- op,
2898
- src1,
2899
- src2,
2900
- dst,
2901
- }
2902
- | Inst::XmmRmREvex3 {
2903
- op,
2904
- src1: _, // `dst` reuses `src1`.
2905
- src2: src1,
2906
- src3: src2,
2907
- dst,
2908
- } => {
2909
- let reused_src = match inst {
2910
- Inst::XmmRmREvex3 { src1, .. } => Some(src1.to_reg()),
2911
- _ => None,
2912
- };
2913
- let src1 = src1.to_reg();
2914
- let src2 = match src2.clone().to_reg_mem().clone() {
2915
- RegMem::Reg { reg } => {
2916
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
2917
- }
2918
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
2919
- };
2920
- let dst = dst.to_reg().to_reg();
2921
- if let Some(src1) = reused_src {
2922
- debug_assert_eq!(src1, dst);
2923
- }
2924
-
2925
- let (w, opcode, map) = match op {
2926
- Avx512Opcode::Vpermi2b => (false, 0x75, OpcodeMap::_0F38),
2927
- Avx512Opcode::Vpmullq => (true, 0x40, OpcodeMap::_0F38),
2928
- Avx512Opcode::Vpsraq => (true, 0xE2, OpcodeMap::_0F),
2929
- _ => unimplemented!("Opcode {:?} not implemented", op),
2930
- };
2931
- EvexInstruction::new()
2932
- .length(EvexVectorLength::V128)
2933
- .prefix(LegacyPrefixes::_66)
2934
- .map(map)
2935
- .w(w)
2936
- .opcode(opcode)
2937
- .tuple_type(op.tuple_type())
2938
- .reg(dst.to_real_reg().unwrap().hw_enc())
2939
- .vvvvv(src1.to_real_reg().unwrap().hw_enc())
2940
- .rm(src2)
2941
- .encode(sink);
2942
- }
2943
-
2944
- Inst::XmmMinMaxSeq {
2945
- size,
2946
- is_min,
2947
- lhs,
2948
- rhs,
2949
- dst,
2950
- } => {
2951
- let rhs = rhs.to_reg();
2952
- let lhs = lhs.to_reg();
2953
- let dst = dst.to_writable_reg();
2954
- debug_assert_eq!(rhs, dst.to_reg());
2955
-
2956
- // Generates the following sequence:
2957
- // cmpss/cmpsd %lhs, %rhs_dst
2958
- // jnz do_min_max
2959
- // jp propagate_nan
2960
- //
2961
- // ;; ordered and equal: propagate the sign bit (for -0 vs 0):
2962
- // {and,or}{ss,sd} %lhs, %rhs_dst
2963
- // j done
2964
- //
2965
- // ;; to get the desired NaN behavior (signalling NaN transformed into a quiet NaN, the
2966
- // ;; NaN value is returned), we add both inputs.
2967
- // propagate_nan:
2968
- // add{ss,sd} %lhs, %rhs_dst
2969
- // j done
2970
- //
2971
- // do_min_max:
2972
- // {min,max}{ss,sd} %lhs, %rhs_dst
2973
- //
2974
- // done:
2975
- let done = sink.get_label();
2976
- let propagate_nan = sink.get_label();
2977
- let do_min_max = sink.get_label();
2978
-
2979
- let (add_op, cmp_op, and_op, or_op, min_max_op) = match size {
2980
- OperandSize::Size32 => (
2981
- SseOpcode::Addss,
2982
- SseOpcode::Ucomiss,
2983
- SseOpcode::Andps,
2984
- SseOpcode::Orps,
2985
- if *is_min {
2986
- SseOpcode::Minss
2987
- } else {
2988
- SseOpcode::Maxss
2989
- },
2990
- ),
2991
- OperandSize::Size64 => (
2992
- SseOpcode::Addsd,
2993
- SseOpcode::Ucomisd,
2994
- SseOpcode::Andpd,
2995
- SseOpcode::Orpd,
2996
- if *is_min {
2997
- SseOpcode::Minsd
2998
- } else {
2999
- SseOpcode::Maxsd
3000
- },
3001
- ),
3002
- _ => unreachable!(),
3003
- };
3004
-
3005
- let inst = Inst::xmm_cmp_rm_r(cmp_op, dst.to_reg(), RegMem::reg(lhs));
3006
- inst.emit(sink, info, state);
3007
-
3008
- one_way_jmp(sink, CC::NZ, do_min_max);
3009
- one_way_jmp(sink, CC::P, propagate_nan);
3010
-
3011
- // Ordered and equal. The operands are bit-identical unless they are zero
3012
- // and negative zero. These instructions merge the sign bits in that
3013
- // case, and are no-ops otherwise.
3014
- let op = if *is_min { or_op } else { and_op };
3015
- let inst = Inst::xmm_rm_r(op, RegMem::reg(lhs), dst);
3016
- inst.emit(sink, info, state);
3017
-
3018
- let inst = Inst::jmp_known(done);
3019
- inst.emit(sink, info, state);
3020
-
3021
- // x86's min/max are not symmetric; if either operand is a NaN, they return the
3022
- // read-only operand: perform an addition between the two operands, which has the
3023
- // desired NaN propagation effects.
3024
- sink.bind_label(propagate_nan, state.ctrl_plane_mut());
3025
- let inst = Inst::xmm_rm_r(add_op, RegMem::reg(lhs), dst);
3026
- inst.emit(sink, info, state);
3027
-
3028
- one_way_jmp(sink, CC::P, done);
3029
-
3030
- sink.bind_label(do_min_max, state.ctrl_plane_mut());
3031
-
3032
- let inst = Inst::xmm_rm_r(min_max_op, RegMem::reg(lhs), dst);
3033
- inst.emit(sink, info, state);
3034
-
3035
- sink.bind_label(done, state.ctrl_plane_mut());
3036
- }
3037
-
3038
- Inst::XmmRmRImm {
3039
- op,
3040
- src1,
3041
- src2,
3042
- dst,
3043
- imm,
3044
- size,
3045
- } => {
3046
- let src1 = *src1;
3047
- let dst = dst.to_reg();
3048
- let src2 = src2.clone();
3049
- debug_assert_eq!(src1, dst);
3050
-
3051
- let (prefix, opcode, len) = match op {
3052
- SseOpcode::Cmpps => (LegacyPrefixes::None, 0x0FC2, 2),
3053
- SseOpcode::Cmppd => (LegacyPrefixes::_66, 0x0FC2, 2),
3054
- SseOpcode::Cmpss => (LegacyPrefixes::_F3, 0x0FC2, 2),
3055
- SseOpcode::Cmpsd => (LegacyPrefixes::_F2, 0x0FC2, 2),
3056
- SseOpcode::Insertps => (LegacyPrefixes::_66, 0x0F3A21, 3),
3057
- SseOpcode::Palignr => (LegacyPrefixes::_66, 0x0F3A0F, 3),
3058
- SseOpcode::Pinsrb => (LegacyPrefixes::_66, 0x0F3A20, 3),
3059
- SseOpcode::Pinsrw => (LegacyPrefixes::_66, 0x0FC4, 2),
3060
- SseOpcode::Pinsrd => (LegacyPrefixes::_66, 0x0F3A22, 3),
3061
- SseOpcode::Shufps => (LegacyPrefixes::None, 0x0FC6, 2),
3062
- SseOpcode::Pblendw => (LegacyPrefixes::_66, 0x0F3A0E, 3),
3063
- _ => unimplemented!("Opcode {:?} not implemented", op),
3064
- };
3065
- let rex = RexFlags::from(*size);
3066
- let regs_swapped = match *op {
3067
- // These opcodes (and not the SSE2 version of PEXTRW) flip the operand
3068
- // encoding: `dst` in ModRM's r/m, `src` in ModRM's reg field.
3069
- SseOpcode::Pextrb | SseOpcode::Pextrd => true,
3070
- // The rest of the opcodes have the customary encoding: `dst` in ModRM's reg,
3071
- // `src` in ModRM's r/m field.
3072
- _ => false,
3073
- };
3074
- match src2 {
3075
- RegMem::Reg { reg } => {
3076
- if regs_swapped {
3077
- emit_std_reg_reg(sink, prefix, opcode, len, reg, dst, rex);
3078
- } else {
3079
- emit_std_reg_reg(sink, prefix, opcode, len, dst, reg, rex);
3080
- }
3081
- }
3082
- RegMem::Mem { addr } => {
3083
- let addr = &addr.finalize(state, sink);
3084
- assert!(
3085
- !regs_swapped,
3086
- "No existing way to encode a mem argument in the ModRM r/m field."
3087
- );
3088
- // N.B.: bytes_at_end == 1, because of the `imm` byte below.
3089
- emit_std_reg_mem(sink, prefix, opcode, len, dst, addr, rex, 1);
3090
- }
3091
- }
3092
- sink.put1(*imm);
3093
- }
3094
-
3095
- Inst::XmmUninitializedValue { .. } => {
3096
- // This instruction format only exists to declare a register as a `def`; no code is
3097
- // emitted.
3098
- }
3099
-
3100
- Inst::XmmMovRM { op, src, dst } => {
3101
- let src = src.to_reg();
3102
- let dst = dst.clone();
3103
-
3104
- let (prefix, opcode) = match op {
3105
- SseOpcode::Movaps => (LegacyPrefixes::None, 0x0F29),
3106
- SseOpcode::Movapd => (LegacyPrefixes::_66, 0x0F29),
3107
- SseOpcode::Movdqu => (LegacyPrefixes::_F3, 0x0F7F),
3108
- SseOpcode::Movss => (LegacyPrefixes::_F3, 0x0F11),
3109
- SseOpcode::Movsd => (LegacyPrefixes::_F2, 0x0F11),
3110
- SseOpcode::Movups => (LegacyPrefixes::None, 0x0F11),
3111
- SseOpcode::Movupd => (LegacyPrefixes::_66, 0x0F11),
3112
- _ => unimplemented!("Opcode {:?} not implemented", op),
3113
- };
3114
- let dst = &dst.finalize(state, sink);
3115
- emit_std_reg_mem(sink, prefix, opcode, 2, src, dst, RexFlags::clear_w(), 0);
3116
- }
3117
-
3118
- Inst::XmmMovRMImm { op, src, dst, imm } => {
3119
- let src = src.to_reg();
3120
- let dst = dst.clone();
3121
-
3122
- let (w, prefix, opcode) = match op {
3123
- SseOpcode::Pextrb => (false, LegacyPrefixes::_66, 0x0F3A14),
3124
- SseOpcode::Pextrw => (false, LegacyPrefixes::_66, 0x0F3A15),
3125
- SseOpcode::Pextrd => (false, LegacyPrefixes::_66, 0x0F3A16),
3126
- SseOpcode::Pextrq => (true, LegacyPrefixes::_66, 0x0F3A16),
3127
- _ => unimplemented!("Opcode {:?} not implemented", op),
3128
- };
3129
- let rex = if w {
3130
- RexFlags::set_w()
3131
- } else {
3132
- RexFlags::clear_w()
3133
- };
3134
- let dst = &dst.finalize(state, sink);
3135
- emit_std_reg_mem(sink, prefix, opcode, 3, src, dst, rex, 1);
3136
- sink.put1(*imm);
3137
- }
3138
-
3139
- Inst::XmmToGpr {
3140
- op,
3141
- src,
3142
- dst,
3143
- dst_size,
3144
- } => {
3145
- let src = src.to_reg();
3146
- let dst = dst.to_reg().to_reg();
3147
-
3148
- let (prefix, opcode, dst_first) = match op {
3149
- SseOpcode::Cvttss2si => (LegacyPrefixes::_F3, 0x0F2C, true),
3150
- SseOpcode::Cvttsd2si => (LegacyPrefixes::_F2, 0x0F2C, true),
3151
- // Movd and movq use the same opcode; the presence of the REX prefix (set below)
3152
- // actually determines which is used.
3153
- SseOpcode::Movd | SseOpcode::Movq => (LegacyPrefixes::_66, 0x0F7E, false),
3154
- SseOpcode::Movmskps => (LegacyPrefixes::None, 0x0F50, true),
3155
- SseOpcode::Movmskpd => (LegacyPrefixes::_66, 0x0F50, true),
3156
- SseOpcode::Pmovmskb => (LegacyPrefixes::_66, 0x0FD7, true),
3157
- _ => panic!("unexpected opcode {:?}", op),
3158
- };
3159
- let rex = RexFlags::from(*dst_size);
3160
- let (src, dst) = if dst_first { (dst, src) } else { (src, dst) };
3161
-
3162
- emit_std_reg_reg(sink, prefix, opcode, 2, src, dst, rex);
3163
- }
3164
-
3165
- Inst::XmmToGprImm { op, src, dst, imm } => {
3166
- use OperandSize as OS;
3167
-
3168
- let src = src.to_reg();
3169
- let dst = dst.to_reg().to_reg();
3170
-
3171
- let (prefix, opcode, opcode_bytes, dst_size, dst_first) = match op {
3172
- SseOpcode::Pextrb => (LegacyPrefixes::_66, 0x0F3A14, 3, OS::Size32, false),
3173
- SseOpcode::Pextrw => (LegacyPrefixes::_66, 0x0FC5, 2, OS::Size32, true),
3174
- SseOpcode::Pextrd => (LegacyPrefixes::_66, 0x0F3A16, 3, OS::Size32, false),
3175
- SseOpcode::Pextrq => (LegacyPrefixes::_66, 0x0F3A16, 3, OS::Size64, false),
3176
- _ => panic!("unexpected opcode {:?}", op),
3177
- };
3178
- let rex = RexFlags::from(dst_size);
3179
- let (src, dst) = if dst_first { (dst, src) } else { (src, dst) };
3180
-
3181
- emit_std_reg_reg(sink, prefix, opcode, opcode_bytes, src, dst, rex);
3182
- sink.put1(*imm);
3183
- }
3184
-
3185
- Inst::GprToXmm {
3186
- op,
3187
- src: src_e,
3188
- dst: reg_g,
3189
- src_size,
3190
- } => {
3191
- let reg_g = reg_g.to_reg().to_reg();
3192
- let src_e = src_e.clone().to_reg_mem().clone();
3193
-
3194
- let (prefix, opcode) = match op {
3195
- // Movd and movq use the same opcode; the presence of the REX prefix (set below)
3196
- // actually determines which is used.
3197
- SseOpcode::Movd | SseOpcode::Movq => (LegacyPrefixes::_66, 0x0F6E),
3198
- _ => panic!("unexpected opcode {:?}", op),
3199
- };
3200
- let rex = RexFlags::from(*src_size);
3201
- match src_e {
3202
- RegMem::Reg { reg: reg_e } => {
3203
- emit_std_reg_reg(sink, prefix, opcode, 2, reg_g, reg_e, rex);
3204
- }
3205
- RegMem::Mem { addr } => {
3206
- let addr = &addr.finalize(state, sink);
3207
- emit_std_reg_mem(sink, prefix, opcode, 2, reg_g, addr, rex, 0);
3208
- }
3209
- }
3210
- }
3211
-
3212
- Inst::XmmCmpRmR { op, src1, src2 } => {
3213
- let src1 = src1.to_reg();
3214
- let src2 = src2.clone().to_reg_mem().clone();
3215
-
3216
- let rex = RexFlags::clear_w();
3217
- let (prefix, opcode, len) = match op {
3218
- SseOpcode::Ptest => (LegacyPrefixes::_66, 0x0F3817, 3),
3219
- SseOpcode::Ucomisd => (LegacyPrefixes::_66, 0x0F2E, 2),
3220
- SseOpcode::Ucomiss => (LegacyPrefixes::None, 0x0F2E, 2),
3221
- _ => unimplemented!("Emit xmm cmp rm r"),
3222
- };
3223
-
3224
- match src2 {
3225
- RegMem::Reg { reg } => {
3226
- emit_std_reg_reg(sink, prefix, opcode, len, src1, reg, rex);
3227
- }
3228
- RegMem::Mem { addr } => {
3229
- let addr = &addr.finalize(state, sink);
3230
- emit_std_reg_mem(sink, prefix, opcode, len, src1, addr, rex, 0);
3231
- }
3232
- }
3233
- }
3234
-
3235
- Inst::CvtIntToFloat {
3236
- op,
3237
- src1,
3238
- src2,
3239
- dst,
3240
- src2_size,
3241
- } => {
3242
- let src1 = src1.to_reg();
3243
- let dst = dst.to_reg().to_reg();
3244
- assert_eq!(src1, dst);
3245
- let src2 = src2.clone().to_reg_mem().clone();
3246
-
3247
- let (prefix, opcode) = match op {
3248
- SseOpcode::Cvtsi2ss => (LegacyPrefixes::_F3, 0x0F2A),
3249
- SseOpcode::Cvtsi2sd => (LegacyPrefixes::_F2, 0x0F2A),
3250
- _ => panic!("unexpected opcode {:?}", op),
3251
- };
3252
- let rex = RexFlags::from(*src2_size);
3253
- match src2 {
3254
- RegMem::Reg { reg: src2 } => {
3255
- emit_std_reg_reg(sink, prefix, opcode, 2, dst, src2, rex);
3256
- }
3257
- RegMem::Mem { addr } => {
3258
- let addr = &addr.finalize(state, sink);
3259
- emit_std_reg_mem(sink, prefix, opcode, 2, dst, addr, rex, 0);
3260
- }
3261
- }
3262
- }
3263
-
3264
- Inst::CvtIntToFloatVex {
3265
- op,
3266
- src1,
3267
- src2,
3268
- dst,
3269
- src2_size,
3270
- } => {
3271
- let dst = dst.to_reg().to_reg();
3272
- let src1 = src1.to_reg();
3273
- let src2 = match src2.clone().to_reg_mem().clone() {
3274
- RegMem::Reg { reg } => {
3275
- RegisterOrAmode::Register(reg.to_real_reg().unwrap().hw_enc().into())
3276
- }
3277
- RegMem::Mem { addr } => RegisterOrAmode::Amode(addr.finalize(state, sink)),
3278
- };
3279
-
3280
- let (prefix, map, opcode) = match op {
3281
- AvxOpcode::Vcvtsi2ss => (LegacyPrefixes::_F3, OpcodeMap::_0F, 0x2A),
3282
- AvxOpcode::Vcvtsi2sd => (LegacyPrefixes::_F2, OpcodeMap::_0F, 0x2A),
3283
- _ => unimplemented!("Opcode {:?} not implemented", op),
3284
- };
3285
- let w = match src2_size {
3286
- OperandSize::Size64 => true,
3287
- _ => false,
3288
- };
3289
- VexInstruction::new()
3290
- .length(VexVectorLength::V128)
3291
- .w(w)
3292
- .prefix(prefix)
3293
- .map(map)
3294
- .opcode(opcode)
3295
- .rm(src2)
3296
- .reg(dst.to_real_reg().unwrap().hw_enc())
3297
- .vvvv(src1.to_real_reg().unwrap().hw_enc())
3298
- .encode(sink);
3299
- }
3300
-
3301
- Inst::CvtUint64ToFloatSeq {
3302
- dst_size,
3303
- src,
3304
- dst,
3305
- tmp_gpr1,
3306
- tmp_gpr2,
3307
- } => {
3308
- let src = src.to_reg();
3309
- let dst = dst.to_writable_reg();
3310
- let tmp_gpr1 = tmp_gpr1.to_writable_reg();
3311
- let tmp_gpr2 = tmp_gpr2.to_writable_reg();
3312
-
3313
- // Note: this sequence is specific to 64-bit mode; a 32-bit mode would require a
3314
- // different sequence.
3315
- //
3316
- // Emit the following sequence:
3317
- //
3318
- // cmp 0, %src
3319
- // jl handle_negative
3320
- //
3321
- // ;; handle positive, which can't overflow
3322
- // cvtsi2sd/cvtsi2ss %src, %dst
3323
- // j done
3324
- //
3325
- // ;; handle negative: see below for an explanation of what it's doing.
3326
- // handle_negative:
3327
- // mov %src, %tmp_gpr1
3328
- // shr $1, %tmp_gpr1
3329
- // mov %src, %tmp_gpr2
3330
- // and $1, %tmp_gpr2
3331
- // or %tmp_gpr1, %tmp_gpr2
3332
- // cvtsi2sd/cvtsi2ss %tmp_gpr2, %dst
3333
- // addsd/addss %dst, %dst
3334
- //
3335
- // done:
3336
-
3337
- assert_ne!(src, tmp_gpr1.to_reg());
3338
- assert_ne!(src, tmp_gpr2.to_reg());
3339
-
3340
- let handle_negative = sink.get_label();
3341
- let done = sink.get_label();
3342
-
3343
- // If x seen as a signed int64 is not negative, a signed-conversion will do the right
3344
- // thing.
3345
- // TODO use tst src, src here.
3346
- let inst = Inst::cmp_rmi_r(OperandSize::Size64, src, RegMemImm::imm(0));
3347
- inst.emit(sink, info, state);
3348
-
3349
- one_way_jmp(sink, CC::L, handle_negative);
3350
-
3351
- // Handle a positive int64, which is the "easy" case: a signed conversion will do the
3352
- // right thing.
3353
- emit_signed_cvt(
3354
- sink,
3355
- info,
3356
- state,
3357
- src,
3358
- dst,
3359
- *dst_size == OperandSize::Size64,
3360
- );
3361
-
3362
- let inst = Inst::jmp_known(done);
3363
- inst.emit(sink, info, state);
3364
-
3365
- sink.bind_label(handle_negative, state.ctrl_plane_mut());
3366
-
3367
- // Divide x by two to get it in range for the signed conversion, keep the LSB, and
3368
- // scale it back up on the FP side.
3369
- let inst = Inst::gen_move(tmp_gpr1, src, types::I64);
3370
- inst.emit(sink, info, state);
3371
-
3372
- // tmp_gpr1 := src >> 1
3373
- let inst = Inst::shift_r(
3374
- OperandSize::Size64,
3375
- ShiftKind::ShiftRightLogical,
3376
- Imm8Gpr::new(Imm8Reg::Imm8 { imm: 1 }).unwrap(),
3377
- tmp_gpr1.to_reg(),
3378
- tmp_gpr1,
3379
- );
3380
- inst.emit(sink, info, state);
3381
-
3382
- let inst = Inst::gen_move(tmp_gpr2, src, types::I64);
3383
- inst.emit(sink, info, state);
3384
-
3385
- let inst = Inst::alu_rmi_r(
3386
- OperandSize::Size64,
3387
- AluRmiROpcode::And,
3388
- RegMemImm::imm(1),
3389
- tmp_gpr2,
3390
- );
3391
- inst.emit(sink, info, state);
3392
-
3393
- let inst = Inst::alu_rmi_r(
3394
- OperandSize::Size64,
3395
- AluRmiROpcode::Or,
3396
- RegMemImm::reg(tmp_gpr1.to_reg()),
3397
- tmp_gpr2,
3398
- );
3399
- inst.emit(sink, info, state);
3400
-
3401
- emit_signed_cvt(
3402
- sink,
3403
- info,
3404
- state,
3405
- tmp_gpr2.to_reg(),
3406
- dst,
3407
- *dst_size == OperandSize::Size64,
3408
- );
3409
-
3410
- let add_op = if *dst_size == OperandSize::Size64 {
3411
- SseOpcode::Addsd
3412
- } else {
3413
- SseOpcode::Addss
3414
- };
3415
- let inst = Inst::xmm_rm_r(add_op, RegMem::reg(dst.to_reg()), dst);
3416
- inst.emit(sink, info, state);
3417
-
3418
- sink.bind_label(done, state.ctrl_plane_mut());
3419
- }
3420
-
3421
- Inst::CvtFloatToSintSeq {
3422
- src_size,
3423
- dst_size,
3424
- is_saturating,
3425
- src,
3426
- dst,
3427
- tmp_gpr,
3428
- tmp_xmm,
3429
- } => {
3430
- let src = src.to_reg();
3431
- let dst = dst.to_writable_reg();
3432
- let tmp_gpr = tmp_gpr.to_writable_reg();
3433
- let tmp_xmm = tmp_xmm.to_writable_reg();
3434
-
3435
- // Emits the following common sequence:
3436
- //
3437
- // cvttss2si/cvttsd2si %src, %dst
3438
- // cmp %dst, 1
3439
- // jno done
3440
- //
3441
- // Then, for saturating conversions:
3442
- //
3443
- // ;; check for NaN
3444
- // cmpss/cmpsd %src, %src
3445
- // jnp not_nan
3446
- // xor %dst, %dst
3447
- //
3448
- // ;; positive inputs get saturated to INT_MAX; negative ones to INT_MIN, which is
3449
- // ;; already in %dst.
3450
- // xorpd %tmp_xmm, %tmp_xmm
3451
- // cmpss/cmpsd %src, %tmp_xmm
3452
- // jnb done
3453
- // mov/movaps $INT_MAX, %dst
3454
- //
3455
- // done:
3456
- //
3457
- // Then, for non-saturating conversions:
3458
- //
3459
- // ;; check for NaN
3460
- // cmpss/cmpsd %src, %src
3461
- // jnp not_nan
3462
- // ud2 trap BadConversionToInteger
3463
- //
3464
- // ;; check if INT_MIN was the correct result, against a magic constant:
3465
- // not_nan:
3466
- // movaps/mov $magic, %tmp_gpr
3467
- // movq/movd %tmp_gpr, %tmp_xmm
3468
- // cmpss/cmpsd %tmp_xmm, %src
3469
- // jnb/jnbe $check_positive
3470
- // ud2 trap IntegerOverflow
3471
- //
3472
- // ;; if positive, it was a real overflow
3473
- // check_positive:
3474
- // xorpd %tmp_xmm, %tmp_xmm
3475
- // cmpss/cmpsd %src, %tmp_xmm
3476
- // jnb done
3477
- // ud2 trap IntegerOverflow
3478
- //
3479
- // done:
3480
-
3481
- let (cast_op, cmp_op, trunc_op) = match src_size {
3482
- OperandSize::Size64 => (SseOpcode::Movq, SseOpcode::Ucomisd, SseOpcode::Cvttsd2si),
3483
- OperandSize::Size32 => (SseOpcode::Movd, SseOpcode::Ucomiss, SseOpcode::Cvttss2si),
3484
- _ => unreachable!(),
3485
- };
3486
-
3487
- let done = sink.get_label();
3488
-
3489
- // The truncation.
3490
- let inst = Inst::xmm_to_gpr(trunc_op, src, dst, *dst_size);
3491
- inst.emit(sink, info, state);
3492
-
3493
- // Compare against 1, in case of overflow the dst operand was INT_MIN.
3494
- let inst = Inst::cmp_rmi_r(*dst_size, dst.to_reg(), RegMemImm::imm(1));
3495
- inst.emit(sink, info, state);
3496
-
3497
- one_way_jmp(sink, CC::NO, done); // no overflow => done
3498
-
3499
- // Check for NaN.
3500
-
3501
- let inst = Inst::xmm_cmp_rm_r(cmp_op, src, RegMem::reg(src));
3502
- inst.emit(sink, info, state);
3503
-
3504
- if *is_saturating {
3505
- let not_nan = sink.get_label();
3506
- one_way_jmp(sink, CC::NP, not_nan); // go to not_nan if not a NaN
3507
-
3508
- // For NaN, emit 0.
3509
- let inst = Inst::alu_rmi_r(
3510
- *dst_size,
3511
- AluRmiROpcode::Xor,
3512
- RegMemImm::reg(dst.to_reg()),
3513
- dst,
3514
- );
3515
- inst.emit(sink, info, state);
3516
-
3517
- let inst = Inst::jmp_known(done);
3518
- inst.emit(sink, info, state);
3519
-
3520
- sink.bind_label(not_nan, state.ctrl_plane_mut());
3521
-
3522
- // If the input was positive, saturate to INT_MAX.
3523
-
3524
- // Zero out tmp_xmm.
3525
- let inst = Inst::xmm_rm_r(SseOpcode::Xorpd, RegMem::reg(tmp_xmm.to_reg()), tmp_xmm);
3526
- inst.emit(sink, info, state);
3527
-
3528
- let inst = Inst::xmm_cmp_rm_r(cmp_op, tmp_xmm.to_reg(), RegMem::reg(src));
3529
- inst.emit(sink, info, state);
3530
-
3531
- // Jump if >= to done.
3532
- one_way_jmp(sink, CC::NB, done);
3533
-
3534
- // Otherwise, put INT_MAX.
3535
- if *dst_size == OperandSize::Size64 {
3536
- let inst = Inst::imm(OperandSize::Size64, 0x7fffffffffffffff, dst);
3537
- inst.emit(sink, info, state);
3538
- } else {
3539
- let inst = Inst::imm(OperandSize::Size32, 0x7fffffff, dst);
3540
- inst.emit(sink, info, state);
3541
- }
3542
- } else {
3543
- let inst = Inst::trap_if(CC::P, TrapCode::BadConversionToInteger);
3544
- inst.emit(sink, info, state);
3545
-
3546
- // Check if INT_MIN was the correct result: determine the smallest floating point
3547
- // number that would convert to INT_MIN, put it in a temporary register, and compare
3548
- // against the src register.
3549
- // If the src register is less (or in some cases, less-or-equal) than the threshold,
3550
- // trap!
3551
-
3552
- let mut no_overflow_cc = CC::NB; // >=
3553
- let output_bits = dst_size.to_bits();
3554
- match *src_size {
3555
- OperandSize::Size32 => {
3556
- let cst = Ieee32::pow2(output_bits - 1).neg().bits();
3557
- let inst = Inst::imm(OperandSize::Size32, cst as u64, tmp_gpr);
3558
- inst.emit(sink, info, state);
3559
- }
3560
- OperandSize::Size64 => {
3561
- // An f64 can represent `i32::min_value() - 1` exactly with precision to spare,
3562
- // so there are values less than -2^(N-1) that convert correctly to INT_MIN.
3563
- let cst = if output_bits < 64 {
3564
- no_overflow_cc = CC::NBE; // >
3565
- Ieee64::fcvt_to_sint_negative_overflow(output_bits)
3566
- } else {
3567
- Ieee64::pow2(output_bits - 1).neg()
3568
- };
3569
- let inst = Inst::imm(OperandSize::Size64, cst.bits(), tmp_gpr);
3570
- inst.emit(sink, info, state);
3571
- }
3572
- _ => unreachable!(),
3573
- }
3574
-
3575
- let inst =
3576
- Inst::gpr_to_xmm(cast_op, RegMem::reg(tmp_gpr.to_reg()), *src_size, tmp_xmm);
3577
- inst.emit(sink, info, state);
3578
-
3579
- let inst = Inst::xmm_cmp_rm_r(cmp_op, src, RegMem::reg(tmp_xmm.to_reg()));
3580
- inst.emit(sink, info, state);
3581
-
3582
- // no trap if src >= or > threshold
3583
- let inst = Inst::trap_if(no_overflow_cc.invert(), TrapCode::IntegerOverflow);
3584
- inst.emit(sink, info, state);
3585
-
3586
- // If positive, it was a real overflow.
3587
-
3588
- // Zero out the tmp_xmm register.
3589
- let inst = Inst::xmm_rm_r(SseOpcode::Xorpd, RegMem::reg(tmp_xmm.to_reg()), tmp_xmm);
3590
- inst.emit(sink, info, state);
3591
-
3592
- let inst = Inst::xmm_cmp_rm_r(cmp_op, tmp_xmm.to_reg(), RegMem::reg(src));
3593
- inst.emit(sink, info, state);
3594
-
3595
- // no trap if 0 >= src
3596
- let inst = Inst::trap_if(CC::B, TrapCode::IntegerOverflow);
3597
- inst.emit(sink, info, state);
3598
- }
3599
-
3600
- sink.bind_label(done, state.ctrl_plane_mut());
3601
- }
3602
-
3603
- Inst::CvtFloatToUintSeq {
3604
- src_size,
3605
- dst_size,
3606
- is_saturating,
3607
- src,
3608
- dst,
3609
- tmp_gpr,
3610
- tmp_xmm,
3611
- tmp_xmm2,
3612
- } => {
3613
- let src = src.to_reg();
3614
- let dst = dst.to_writable_reg();
3615
- let tmp_gpr = tmp_gpr.to_writable_reg();
3616
- let tmp_xmm = tmp_xmm.to_writable_reg();
3617
- let tmp_xmm2 = tmp_xmm2.to_writable_reg();
3618
-
3619
- // The only difference in behavior between saturating and non-saturating is how we
3620
- // handle errors. Emits the following sequence:
3621
- //
3622
- // movaps/mov 2**(int_width - 1), %tmp_gpr
3623
- // movq/movd %tmp_gpr, %tmp_xmm
3624
- // cmpss/cmpsd %tmp_xmm, %src
3625
- // jnb is_large
3626
- //
3627
- // ;; check for NaN inputs
3628
- // jnp not_nan
3629
- // -- non-saturating: ud2 trap BadConversionToInteger
3630
- // -- saturating: xor %dst, %dst; j done
3631
- //
3632
- // not_nan:
3633
- // cvttss2si/cvttsd2si %src, %dst
3634
- // cmp 0, %dst
3635
- // jnl done
3636
- // -- non-saturating: ud2 trap IntegerOverflow
3637
- // -- saturating: xor %dst, %dst; j done
3638
- //
3639
- // is_large:
3640
- // mov %src, %tmp_xmm2
3641
- // subss/subsd %tmp_xmm, %tmp_xmm2
3642
- // cvttss2si/cvttss2sd %tmp_x, %dst
3643
- // cmp 0, %dst
3644
- // jnl next_is_large
3645
- // -- non-saturating: ud2 trap IntegerOverflow
3646
- // -- saturating: movaps $UINT_MAX, %dst; j done
3647
- //
3648
- // next_is_large:
3649
- // add 2**(int_width -1), %dst ;; 2 instructions for 64-bits integers
3650
- //
3651
- // done:
3652
-
3653
- assert_ne!(tmp_xmm.to_reg(), src, "tmp_xmm clobbers src!");
3654
-
3655
- let (sub_op, cast_op, cmp_op, trunc_op) = match src_size {
3656
- OperandSize::Size32 => (
3657
- SseOpcode::Subss,
3658
- SseOpcode::Movd,
3659
- SseOpcode::Ucomiss,
3660
- SseOpcode::Cvttss2si,
3661
- ),
3662
- OperandSize::Size64 => (
3663
- SseOpcode::Subsd,
3664
- SseOpcode::Movq,
3665
- SseOpcode::Ucomisd,
3666
- SseOpcode::Cvttsd2si,
3667
- ),
3668
- _ => unreachable!(),
3669
- };
3670
-
3671
- let done = sink.get_label();
3672
-
3673
- let cst = match src_size {
3674
- OperandSize::Size32 => Ieee32::pow2(dst_size.to_bits() - 1).bits() as u64,
3675
- OperandSize::Size64 => Ieee64::pow2(dst_size.to_bits() - 1).bits(),
3676
- _ => unreachable!(),
3677
- };
3678
-
3679
- let inst = Inst::imm(*src_size, cst, tmp_gpr);
3680
- inst.emit(sink, info, state);
3681
-
3682
- let inst = Inst::gpr_to_xmm(cast_op, RegMem::reg(tmp_gpr.to_reg()), *src_size, tmp_xmm);
3683
- inst.emit(sink, info, state);
3684
-
3685
- let inst = Inst::xmm_cmp_rm_r(cmp_op, src, RegMem::reg(tmp_xmm.to_reg()));
3686
- inst.emit(sink, info, state);
3687
-
3688
- let handle_large = sink.get_label();
3689
- one_way_jmp(sink, CC::NB, handle_large); // jump to handle_large if src >= large_threshold
3690
-
3691
- if *is_saturating {
3692
- // If not NaN jump over this 0-return, otherwise return 0
3693
- let not_nan = sink.get_label();
3694
- one_way_jmp(sink, CC::NP, not_nan);
3695
- let inst = Inst::alu_rmi_r(
3696
- *dst_size,
3697
- AluRmiROpcode::Xor,
3698
- RegMemImm::reg(dst.to_reg()),
3699
- dst,
3700
- );
3701
- inst.emit(sink, info, state);
3702
-
3703
- let inst = Inst::jmp_known(done);
3704
- inst.emit(sink, info, state);
3705
- sink.bind_label(not_nan, state.ctrl_plane_mut());
3706
- } else {
3707
- // Trap.
3708
- let inst = Inst::trap_if(CC::P, TrapCode::BadConversionToInteger);
3709
- inst.emit(sink, info, state);
3710
- }
3711
-
3712
- // Actual truncation for small inputs: if the result is not positive, then we had an
3713
- // overflow.
3714
-
3715
- let inst = Inst::xmm_to_gpr(trunc_op, src, dst, *dst_size);
3716
- inst.emit(sink, info, state);
3717
-
3718
- let inst = Inst::cmp_rmi_r(*dst_size, dst.to_reg(), RegMemImm::imm(0));
3719
- inst.emit(sink, info, state);
3720
-
3721
- one_way_jmp(sink, CC::NL, done); // if dst >= 0, jump to done
3722
-
3723
- if *is_saturating {
3724
- // The input was "small" (< 2**(width -1)), so the only way to get an integer
3725
- // overflow is because the input was too small: saturate to the min value, i.e. 0.
3726
- let inst = Inst::alu_rmi_r(
3727
- *dst_size,
3728
- AluRmiROpcode::Xor,
3729
- RegMemImm::reg(dst.to_reg()),
3730
- dst,
3731
- );
3732
- inst.emit(sink, info, state);
3733
-
3734
- let inst = Inst::jmp_known(done);
3735
- inst.emit(sink, info, state);
3736
- } else {
3737
- // Trap.
3738
- let inst = Inst::trap(TrapCode::IntegerOverflow);
3739
- inst.emit(sink, info, state);
3740
- }
3741
-
3742
- // Now handle large inputs.
3743
-
3744
- sink.bind_label(handle_large, state.ctrl_plane_mut());
3745
-
3746
- let inst = Inst::gen_move(tmp_xmm2, src, types::F64);
3747
- inst.emit(sink, info, state);
3748
-
3749
- let inst = Inst::xmm_rm_r(sub_op, RegMem::reg(tmp_xmm.to_reg()), tmp_xmm2);
3750
- inst.emit(sink, info, state);
3751
-
3752
- let inst = Inst::xmm_to_gpr(trunc_op, tmp_xmm2.to_reg(), dst, *dst_size);
3753
- inst.emit(sink, info, state);
3754
-
3755
- let inst = Inst::cmp_rmi_r(*dst_size, dst.to_reg(), RegMemImm::imm(0));
3756
- inst.emit(sink, info, state);
3757
-
3758
- if *is_saturating {
3759
- let next_is_large = sink.get_label();
3760
- one_way_jmp(sink, CC::NL, next_is_large); // if dst >= 0, jump to next_is_large
3761
-
3762
- // The input was "large" (>= 2**(width -1)), so the only way to get an integer
3763
- // overflow is because the input was too large: saturate to the max value.
3764
- let inst = Inst::imm(
3765
- OperandSize::Size64,
3766
- if *dst_size == OperandSize::Size64 {
3767
- u64::max_value()
3768
- } else {
3769
- u32::max_value() as u64
3770
- },
3771
- dst,
3772
- );
3773
- inst.emit(sink, info, state);
3774
-
3775
- let inst = Inst::jmp_known(done);
3776
- inst.emit(sink, info, state);
3777
- sink.bind_label(next_is_large, state.ctrl_plane_mut());
3778
- } else {
3779
- let inst = Inst::trap_if(CC::L, TrapCode::IntegerOverflow);
3780
- inst.emit(sink, info, state);
3781
- }
3782
-
3783
- if *dst_size == OperandSize::Size64 {
3784
- let inst = Inst::imm(OperandSize::Size64, 1 << 63, tmp_gpr);
3785
- inst.emit(sink, info, state);
3786
-
3787
- let inst = Inst::alu_rmi_r(
3788
- OperandSize::Size64,
3789
- AluRmiROpcode::Add,
3790
- RegMemImm::reg(tmp_gpr.to_reg()),
3791
- dst,
3792
- );
3793
- inst.emit(sink, info, state);
3794
- } else {
3795
- let inst = Inst::alu_rmi_r(
3796
- OperandSize::Size32,
3797
- AluRmiROpcode::Add,
3798
- RegMemImm::imm(1 << 31),
3799
- dst,
3800
- );
3801
- inst.emit(sink, info, state);
3802
- }
3803
-
3804
- sink.bind_label(done, state.ctrl_plane_mut());
3805
- }
3806
-
3807
- Inst::LoadExtName {
3808
- dst,
3809
- name,
3810
- offset,
3811
- distance,
3812
- } => {
3813
- let dst = dst.to_reg();
3814
-
3815
- if info.flags.is_pic() {
3816
- // Generates: movq symbol@GOTPCREL(%rip), %dst
3817
- let enc_dst = int_reg_enc(dst);
3818
- sink.put1(0x48 | ((enc_dst >> 3) & 1) << 2);
3819
- sink.put1(0x8B);
3820
- sink.put1(0x05 | ((enc_dst & 7) << 3));
3821
- emit_reloc(sink, Reloc::X86GOTPCRel4, name, -4);
3822
- sink.put4(0);
3823
- // Offset in the relocation above applies to the address of the *GOT entry*, not
3824
- // the loaded address; so we emit a separate add or sub instruction if needed.
3825
- if *offset < 0 {
3826
- assert!(*offset >= -i32::MAX as i64);
3827
- sink.put1(0x48 | ((enc_dst >> 3) & 1));
3828
- sink.put1(0x81);
3829
- sink.put1(0xe8 | (enc_dst & 7));
3830
- sink.put4((-*offset) as u32);
3831
- } else if *offset > 0 {
3832
- assert!(*offset <= i32::MAX as i64);
3833
- sink.put1(0x48 | ((enc_dst >> 3) & 1));
3834
- sink.put1(0x81);
3835
- sink.put1(0xc0 | (enc_dst & 7));
3836
- sink.put4(*offset as u32);
3837
- }
3838
- } else if distance == &RelocDistance::Near {
3839
- // If we know the distance to the name is within 2GB (e.g., a module-local function),
3840
- // we can generate a RIP-relative address, with a relocation.
3841
- // Generates: lea $name(%rip), $dst
3842
- let enc_dst = int_reg_enc(dst);
3843
- sink.put1(0x48 | ((enc_dst >> 3) & 1) << 2);
3844
- sink.put1(0x8D);
3845
- sink.put1(0x05 | ((enc_dst & 7) << 3));
3846
- emit_reloc(sink, Reloc::X86CallPCRel4, name, -4);
3847
- sink.put4(0);
3848
- } else {
3849
- // The full address can be encoded in the register, with a relocation.
3850
- // Generates: movabsq $name, %dst
3851
- let enc_dst = int_reg_enc(dst);
3852
- sink.put1(0x48 | ((enc_dst >> 3) & 1));
3853
- sink.put1(0xB8 | (enc_dst & 7));
3854
- emit_reloc(sink, Reloc::Abs8, name, *offset);
3855
- sink.put8(0);
3856
- }
3857
- }
3858
-
3859
- Inst::LockCmpxchg {
3860
- ty,
3861
- replacement,
3862
- expected,
3863
- mem,
3864
- dst_old,
3865
- } => {
3866
- let replacement = *replacement;
3867
- let expected = *expected;
3868
- let dst_old = dst_old.to_reg();
3869
- let mem = mem.clone();
3870
-
3871
- debug_assert_eq!(expected, regs::rax());
3872
- debug_assert_eq!(dst_old, regs::rax());
3873
-
3874
- // lock cmpxchg{b,w,l,q} %replacement, (mem)
3875
- // Note that 0xF0 is the Lock prefix.
3876
- let (prefix, opcodes) = match *ty {
3877
- types::I8 => (LegacyPrefixes::_F0, 0x0FB0),
3878
- types::I16 => (LegacyPrefixes::_66F0, 0x0FB1),
3879
- types::I32 => (LegacyPrefixes::_F0, 0x0FB1),
3880
- types::I64 => (LegacyPrefixes::_F0, 0x0FB1),
3881
- _ => unreachable!(),
3882
- };
3883
- let rex = RexFlags::from((OperandSize::from_ty(*ty), replacement));
3884
- let amode = mem.finalize(state, sink);
3885
- emit_std_reg_mem(sink, prefix, opcodes, 2, replacement, &amode, rex, 0);
3886
- }
3887
-
3888
- Inst::AtomicRmwSeq {
3889
- ty,
3890
- op,
3891
- mem,
3892
- operand,
3893
- temp,
3894
- dst_old,
3895
- } => {
3896
- let operand = *operand;
3897
- let temp = *temp;
3898
- let dst_old = *dst_old;
3899
- debug_assert_eq!(dst_old.to_reg(), regs::rax());
3900
- let mem = mem.finalize(state, sink).clone();
3901
-
3902
- // Emit this:
3903
- // mov{zbq,zwq,zlq,q} (%r_address), %rax // rax = old value
3904
- // again:
3905
- // movq %rax, %r_temp // rax = old value, r_temp = old value
3906
- // `op`q %r_operand, %r_temp // rax = old value, r_temp = new value
3907
- // lock cmpxchg{b,w,l,q} %r_temp, (%r_address) // try to store new value
3908
- // jnz again // If this is taken, rax will have a "revised" old value
3909
- //
3910
- // Operand conventions: IN: %r_address, %r_operand OUT: %rax (old
3911
- // value), %r_temp (trashed), %rflags (trashed)
3912
- //
3913
- // In the case where the operation is 'xchg', the "`op`q"
3914
- // instruction is instead: movq %r_operand,
3915
- // %r_temp so that we simply write in the destination, the "2nd
3916
- // arg for `op`".
3917
- //
3918
- // TODO: this sequence can be significantly improved (e.g., to `lock
3919
- // <op>`) when it is known that `dst_old` is not used later, see
3920
- // https://github.com/bytecodealliance/wasmtime/issues/2153.
3921
- let again_label = sink.get_label();
3922
-
3923
- // mov{zbq,zwq,zlq,q} (%r_address), %rax
3924
- // No need to call `add_trap` here, since the `i1` emit will do that.
3925
- let i1 = Inst::load(*ty, mem.clone(), dst_old, ExtKind::ZeroExtend);
3926
- i1.emit(sink, info, state);
3927
-
3928
- // again:
3929
- sink.bind_label(again_label, state.ctrl_plane_mut());
3930
-
3931
- // movq %rax, %r_temp
3932
- let i2 = Inst::mov_r_r(OperandSize::Size64, dst_old.to_reg(), temp);
3933
- i2.emit(sink, info, state);
3934
-
3935
- let operand_rmi = RegMemImm::reg(operand);
3936
- use inst_common::MachAtomicRmwOp as RmwOp;
3937
- match op {
3938
- RmwOp::Xchg => {
3939
- // movq %r_operand, %r_temp
3940
- let i3 = Inst::mov_r_r(OperandSize::Size64, operand, temp);
3941
- i3.emit(sink, info, state);
3942
- }
3943
- RmwOp::Nand => {
3944
- // andq %r_operand, %r_temp
3945
- let i3 =
3946
- Inst::alu_rmi_r(OperandSize::Size64, AluRmiROpcode::And, operand_rmi, temp);
3947
- i3.emit(sink, info, state);
3948
-
3949
- // notq %r_temp
3950
- let i4 = Inst::not(OperandSize::Size64, temp);
3951
- i4.emit(sink, info, state);
3952
- }
3953
- RmwOp::Umin | RmwOp::Umax | RmwOp::Smin | RmwOp::Smax => {
3954
- // cmp %r_temp, %r_operand
3955
- let i3 = Inst::cmp_rmi_r(
3956
- OperandSize::from_ty(*ty),
3957
- operand,
3958
- RegMemImm::reg(temp.to_reg()),
3959
- );
3960
- i3.emit(sink, info, state);
3961
-
3962
- // cmovcc %r_operand, %r_temp
3963
- let cc = match op {
3964
- RmwOp::Umin => CC::BE,
3965
- RmwOp::Umax => CC::NB,
3966
- RmwOp::Smin => CC::LE,
3967
- RmwOp::Smax => CC::NL,
3968
- _ => unreachable!(),
3969
- };
3970
- let i4 = Inst::cmove(OperandSize::Size64, cc, RegMem::reg(operand), temp);
3971
- i4.emit(sink, info, state);
3972
- }
3973
- _ => {
3974
- // opq %r_operand, %r_temp
3975
- let alu_op = match op {
3976
- RmwOp::Add => AluRmiROpcode::Add,
3977
- RmwOp::Sub => AluRmiROpcode::Sub,
3978
- RmwOp::And => AluRmiROpcode::And,
3979
- RmwOp::Or => AluRmiROpcode::Or,
3980
- RmwOp::Xor => AluRmiROpcode::Xor,
3981
- RmwOp::Xchg
3982
- | RmwOp::Nand
3983
- | RmwOp::Umin
3984
- | RmwOp::Umax
3985
- | RmwOp::Smin
3986
- | RmwOp::Smax => unreachable!(),
3987
- };
3988
- let i3 = Inst::alu_rmi_r(OperandSize::Size64, alu_op, operand_rmi, temp);
3989
- i3.emit(sink, info, state);
3990
- }
3991
- }
3992
-
3993
- // lock cmpxchg{b,w,l,q} %r_temp, (%r_address)
3994
- // No need to call `add_trap` here, since the `i4` emit will do that.
3995
- let i4 = Inst::LockCmpxchg {
3996
- ty: *ty,
3997
- replacement: temp.to_reg(),
3998
- expected: dst_old.to_reg(),
3999
- mem: mem.into(),
4000
- dst_old,
4001
- };
4002
- i4.emit(sink, info, state);
4003
-
4004
- // jnz again
4005
- one_way_jmp(sink, CC::NZ, again_label);
4006
- }
4007
-
4008
- Inst::Fence { kind } => {
4009
- sink.put1(0x0F);
4010
- sink.put1(0xAE);
4011
- match kind {
4012
- FenceKind::MFence => sink.put1(0xF0), // mfence = 0F AE F0
4013
- FenceKind::LFence => sink.put1(0xE8), // lfence = 0F AE E8
4014
- FenceKind::SFence => sink.put1(0xF8), // sfence = 0F AE F8
4015
- }
4016
- }
4017
-
4018
- Inst::Hlt => {
4019
- sink.put1(0xcc);
4020
- }
4021
-
4022
- Inst::Ud2 { trap_code } => {
4023
- sink.add_trap(*trap_code);
4024
- if let Some(s) = state.take_stack_map() {
4025
- sink.add_stack_map(StackMapExtent::UpcomingBytes(2), s);
4026
- }
4027
- sink.put_data(Inst::TRAP_OPCODE);
4028
- }
4029
-
4030
- Inst::Nop { len } => {
4031
- // These encodings can all be found in Intel's architecture manual, at the NOP
4032
- // instruction description.
4033
- let mut len = *len;
4034
- while len != 0 {
4035
- let emitted = u8::min(len, 9);
4036
- match emitted {
4037
- 0 => {}
4038
- 1 => sink.put1(0x90), // NOP
4039
- 2 => {
4040
- // 66 NOP
4041
- sink.put1(0x66);
4042
- sink.put1(0x90);
4043
- }
4044
- 3 => {
4045
- // NOP [EAX]
4046
- sink.put1(0x0F);
4047
- sink.put1(0x1F);
4048
- sink.put1(0x00);
4049
- }
4050
- 4 => {
4051
- // NOP 0(EAX), with 0 a 1-byte immediate.
4052
- sink.put1(0x0F);
4053
- sink.put1(0x1F);
4054
- sink.put1(0x40);
4055
- sink.put1(0x00);
4056
- }
4057
- 5 => {
4058
- // NOP [EAX, EAX, 1]
4059
- sink.put1(0x0F);
4060
- sink.put1(0x1F);
4061
- sink.put1(0x44);
4062
- sink.put1(0x00);
4063
- sink.put1(0x00);
4064
- }
4065
- 6 => {
4066
- // 66 NOP [EAX, EAX, 1]
4067
- sink.put1(0x66);
4068
- sink.put1(0x0F);
4069
- sink.put1(0x1F);
4070
- sink.put1(0x44);
4071
- sink.put1(0x00);
4072
- sink.put1(0x00);
4073
- }
4074
- 7 => {
4075
- // NOP 0[EAX], but 0 is a 4 bytes immediate.
4076
- sink.put1(0x0F);
4077
- sink.put1(0x1F);
4078
- sink.put1(0x80);
4079
- sink.put1(0x00);
4080
- sink.put1(0x00);
4081
- sink.put1(0x00);
4082
- sink.put1(0x00);
4083
- }
4084
- 8 => {
4085
- // NOP 0[EAX, EAX, 1], with 0 a 4 bytes immediate.
4086
- sink.put1(0x0F);
4087
- sink.put1(0x1F);
4088
- sink.put1(0x84);
4089
- sink.put1(0x00);
4090
- sink.put1(0x00);
4091
- sink.put1(0x00);
4092
- sink.put1(0x00);
4093
- sink.put1(0x00);
4094
- }
4095
- 9 => {
4096
- // 66 NOP 0[EAX, EAX, 1], with 0 a 4 bytes immediate.
4097
- sink.put1(0x66);
4098
- sink.put1(0x0F);
4099
- sink.put1(0x1F);
4100
- sink.put1(0x84);
4101
- sink.put1(0x00);
4102
- sink.put1(0x00);
4103
- sink.put1(0x00);
4104
- sink.put1(0x00);
4105
- sink.put1(0x00);
4106
- }
4107
- _ => unreachable!(),
4108
- }
4109
- len -= emitted;
4110
- }
4111
- }
4112
-
4113
- Inst::ElfTlsGetAddr { ref symbol, dst } => {
4114
- let dst = dst.to_reg().to_reg();
4115
- debug_assert_eq!(dst, regs::rax());
4116
-
4117
- // N.B.: Must be exactly this byte sequence; the linker requires it,
4118
- // because it must know how to rewrite the bytes.
4119
-
4120
- // data16 lea gv@tlsgd(%rip),%rdi
4121
- sink.put1(0x66); // data16
4122
- sink.put1(0b01001000); // REX.W
4123
- sink.put1(0x8d); // LEA
4124
- sink.put1(0x3d); // ModRM byte
4125
- emit_reloc(sink, Reloc::ElfX86_64TlsGd, symbol, -4);
4126
- sink.put4(0); // offset
4127
-
4128
- // data16 data16 callq __tls_get_addr-4
4129
- sink.put1(0x66); // data16
4130
- sink.put1(0x66); // data16
4131
- sink.put1(0b01001000); // REX.W
4132
- sink.put1(0xe8); // CALL
4133
- emit_reloc(
4134
- sink,
4135
- Reloc::X86CallPLTRel4,
4136
- &ExternalName::LibCall(LibCall::ElfTlsGetAddr),
4137
- -4,
4138
- );
4139
- sink.put4(0); // offset
4140
- }
4141
-
4142
- Inst::MachOTlsGetAddr { ref symbol, dst } => {
4143
- let dst = dst.to_reg().to_reg();
4144
- debug_assert_eq!(dst, regs::rax());
4145
-
4146
- // movq gv@tlv(%rip), %rdi
4147
- sink.put1(0x48); // REX.w
4148
- sink.put1(0x8b); // MOV
4149
- sink.put1(0x3d); // ModRM byte
4150
- emit_reloc(sink, Reloc::MachOX86_64Tlv, symbol, -4);
4151
- sink.put4(0); // offset
4152
-
4153
- // callq *(%rdi)
4154
- sink.put1(0xff);
4155
- sink.put1(0x17);
4156
- }
4157
-
4158
- Inst::CoffTlsGetAddr {
4159
- ref symbol,
4160
- dst,
4161
- tmp,
4162
- } => {
4163
- let dst = dst.to_reg().to_reg();
4164
- debug_assert_eq!(dst, regs::rax());
4165
-
4166
- // tmp is used below directly as %rcx
4167
- let tmp = tmp.to_reg().to_reg();
4168
- debug_assert_eq!(tmp, regs::rcx());
4169
-
4170
- // See: https://gcc.godbolt.org/z/M8or9x6ss
4171
- // And: https://github.com/bjorn3/rustc_codegen_cranelift/issues/388#issuecomment-532930282
4172
-
4173
- // Emit the following sequence
4174
- // movl (%rip), %eax ; IMAGE_REL_AMD64_REL32 _tls_index
4175
- // movq %gs:88, %rcx
4176
- // movq (%rcx,%rax,8), %rax
4177
- // leaq (%rax), %rax ; Reloc: IMAGE_REL_AMD64_SECREL symbol
4178
-
4179
- // Load TLS index for current thread
4180
- // movl (%rip), %eax
4181
- sink.put1(0x8b); // mov
4182
- sink.put1(0x05);
4183
- emit_reloc(
4184
- sink,
4185
- Reloc::X86PCRel4,
4186
- &ExternalName::KnownSymbol(KnownSymbol::CoffTlsIndex),
4187
- -4,
4188
- );
4189
- sink.put4(0); // offset
4190
-
4191
- // movq %gs:88, %rcx
4192
- // Load the TLS Storage Array pointer
4193
- // The gs segment register refers to the base address of the TEB on x64.
4194
- // 0x58 is the offset in the TEB for the ThreadLocalStoragePointer member on x64:
4195
- sink.put_data(&[
4196
- 0x65, 0x48, // REX.W
4197
- 0x8b, // MOV
4198
- 0x0c, 0x25, 0x58, // 0x58 - ThreadLocalStoragePointer offset
4199
- 0x00, 0x00, 0x00,
4200
- ]);
4201
-
4202
- // movq (%rcx,%rax,8), %rax
4203
- // Load the actual TLS entry for this thread.
4204
- // Computes ThreadLocalStoragePointer + _tls_index*8
4205
- sink.put_data(&[0x48, 0x8b, 0x04, 0xc1]);
4206
-
4207
- // leaq (%rax), %rax
4208
- sink.put1(0x48);
4209
- sink.put1(0x8d);
4210
- sink.put1(0x80);
4211
- emit_reloc(sink, Reloc::X86SecRel, symbol, 0);
4212
- sink.put4(0); // offset
4213
- }
4214
-
4215
- Inst::Unwind { ref inst } => {
4216
- sink.add_unwind(inst.clone());
4217
- }
4218
-
4219
- Inst::DummyUse { .. } => {
4220
- // Nothing.
4221
- }
4222
- }
4223
-
4224
- state.clear_post_insn();
4225
- }
4226
-
4227
- /// Emit the common sequence used for both direct and indirect tail calls:
4228
- ///
4229
- /// * Copy the new frame's stack arguments over the top of our current frame.
4230
- ///
4231
- /// * Restore the old frame pointer.
4232
- ///
4233
- /// * Initialize the tail callee's stack pointer (simultaneously deallocating
4234
- /// the temporary stack space we allocated when creating the new frame's stack
4235
- /// arguments).
4236
- ///
4237
- /// * Move the return address into its stack slot.
4238
- fn emit_return_call_common_sequence(
4239
- sink: &mut MachBuffer<Inst>,
4240
- info: &EmitInfo,
4241
- state: &mut EmitState,
4242
- call_info: &ReturnCallInfo,
4243
- ) {
4244
- assert!(
4245
- info.flags.preserve_frame_pointers(),
4246
- "frame pointers aren't fundamentally required for tail calls, \
4247
- but the current implementation relies on them being present"
4248
- );
4249
-
4250
- let tmp = call_info.tmp.to_writable_reg();
4251
-
4252
- for inst in
4253
- X64ABIMachineSpec::gen_clobber_restore(CallConv::Tail, &info.flags, state.frame_layout())
4254
- {
4255
- inst.emit(sink, info, state);
4256
- }
4257
-
4258
- for inst in X64ABIMachineSpec::gen_epilogue_frame_restore(
4259
- CallConv::Tail,
4260
- &info.flags,
4261
- &info.isa_flags,
4262
- state.frame_layout(),
4263
- ) {
4264
- inst.emit(sink, info, state);
4265
- }
4266
-
4267
- let incoming_args_diff = state.frame_layout().tail_args_size - call_info.new_stack_arg_size;
4268
- if incoming_args_diff > 0 {
4269
- // Move the saved return address up by `incoming_args_diff`
4270
- Inst::mov64_m_r(Amode::imm_reg(0, regs::rsp()), tmp).emit(sink, info, state);
4271
- Inst::mov_r_m(
4272
- OperandSize::Size64,
4273
- tmp.to_reg(),
4274
- Amode::imm_reg(i32::try_from(incoming_args_diff).unwrap(), regs::rsp()),
4275
- )
4276
- .emit(sink, info, state);
4277
-
4278
- // Increment the stack pointer to shrink the argument area for the new call.
4279
- Inst::alu_rmi_r(
4280
- OperandSize::Size64,
4281
- AluRmiROpcode::Add,
4282
- RegMemImm::imm(incoming_args_diff),
4283
- Writable::from_reg(regs::rsp()),
4284
- )
4285
- .emit(sink, info, state);
4286
- }
4287
- }