wasmtime 19.0.2 → 20.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (2232) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +116 -120
  3. data/ext/Cargo.toml +6 -6
  4. data/ext/cargo-vendor/anyhow-1.0.83/.cargo-checksum.json +1 -0
  5. data/ext/cargo-vendor/anyhow-1.0.83/Cargo.toml +130 -0
  6. data/ext/cargo-vendor/anyhow-1.0.83/README.md +181 -0
  7. data/ext/cargo-vendor/anyhow-1.0.83/build.rs +179 -0
  8. data/ext/cargo-vendor/anyhow-1.0.83/src/backtrace.rs +406 -0
  9. data/ext/cargo-vendor/anyhow-1.0.83/src/chain.rs +102 -0
  10. data/ext/cargo-vendor/anyhow-1.0.83/src/fmt.rs +158 -0
  11. data/ext/cargo-vendor/anyhow-1.0.83/src/kind.rs +121 -0
  12. data/ext/cargo-vendor/anyhow-1.0.83/src/lib.rs +702 -0
  13. data/ext/cargo-vendor/anyhow-1.0.83/src/macros.rs +241 -0
  14. data/ext/cargo-vendor/anyhow-1.0.83/src/wrapper.rs +84 -0
  15. data/ext/cargo-vendor/anyhow-1.0.83/tests/test_ensure.rs +724 -0
  16. data/ext/cargo-vendor/anyhow-1.0.83/tests/test_macros.rs +81 -0
  17. data/ext/cargo-vendor/anyhow-1.0.83/tests/test_repr.rs +30 -0
  18. data/ext/cargo-vendor/anyhow-1.0.83/tests/ui/no-impl.stderr +32 -0
  19. data/ext/cargo-vendor/cranelift-bforest-0.107.2/.cargo-checksum.json +1 -0
  20. data/ext/cargo-vendor/cranelift-bforest-0.107.2/Cargo.toml +40 -0
  21. data/ext/cargo-vendor/cranelift-codegen-0.107.2/.cargo-checksum.json +1 -0
  22. data/ext/cargo-vendor/cranelift-codegen-0.107.2/Cargo.toml +178 -0
  23. data/ext/cargo-vendor/cranelift-codegen-0.107.2/build.rs +396 -0
  24. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/alias_analysis.rs +403 -0
  25. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/binemit/mod.rs +171 -0
  26. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/bitset.rs +187 -0
  27. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/context.rs +386 -0
  28. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/egraph/elaborate.rs +835 -0
  29. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/egraph.rs +838 -0
  30. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/inst_predicates.rs +236 -0
  31. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/constant.rs +462 -0
  32. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/dfg.rs +1777 -0
  33. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/entities.rs +562 -0
  34. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/function.rs +490 -0
  35. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/instructions.rs +1019 -0
  36. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/memflags.rs +452 -0
  37. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/mod.rs +108 -0
  38. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/trapcode.rs +149 -0
  39. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/types.rs +629 -0
  40. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/abi.rs +1707 -0
  41. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/emit.rs +3932 -0
  42. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/mod.rs +3083 -0
  43. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst.isle +4218 -0
  44. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/lower/isle.rs +884 -0
  45. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/lower.isle +2933 -0
  46. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/mod.rs +242 -0
  47. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/pcc.rs +565 -0
  48. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/call_conv.rs +127 -0
  49. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/abi.rs +1109 -0
  50. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/args.rs +1968 -0
  51. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/emit.rs +3466 -0
  52. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/encode.rs +654 -0
  53. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst.isle +2944 -0
  54. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/lower/isle.rs +625 -0
  55. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/lower.isle +2872 -0
  56. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/abi.rs +1047 -0
  57. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/args.rs +347 -0
  58. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/emit.rs +3646 -0
  59. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst.isle +5033 -0
  60. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/lower.isle +3995 -0
  61. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/abi.rs +1369 -0
  62. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/encoding/evex.rs +748 -0
  63. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/encoding/rex.rs +596 -0
  64. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/encoding/vex.rs +491 -0
  65. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/args.rs +2289 -0
  66. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/emit.rs +4383 -0
  67. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/emit_state.rs +74 -0
  68. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/mod.rs +2798 -0
  69. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst.isle +5304 -0
  70. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower/isle.rs +1066 -0
  71. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower.isle +4809 -0
  72. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower.rs +339 -0
  73. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/mod.rs +234 -0
  74. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/pcc.rs +1003 -0
  75. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/legalizer/mod.rs +348 -0
  76. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/abi.rs +2594 -0
  77. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/buffer.rs +2512 -0
  78. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/inst_common.rs +75 -0
  79. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/isle.rs +914 -0
  80. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/lower.rs +1452 -0
  81. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/mod.rs +555 -0
  82. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/pcc.rs +169 -0
  83. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/vcode.rs +1807 -0
  84. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/nan_canonicalization.rs +110 -0
  85. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/opts/cprop.isle +281 -0
  86. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/opts/spectre.isle +14 -0
  87. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/opts.rs +295 -0
  88. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/prelude.isle +646 -0
  89. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/result.rs +111 -0
  90. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/settings.rs +591 -0
  91. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/verifier/mod.rs +1957 -0
  92. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/write.rs +631 -0
  93. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/.cargo-checksum.json +1 -0
  94. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/Cargo.toml +35 -0
  95. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/shared/entities.rs +101 -0
  96. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/shared/formats.rs +205 -0
  97. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/shared/instructions.rs +3791 -0
  98. data/ext/cargo-vendor/cranelift-codegen-shared-0.107.2/.cargo-checksum.json +1 -0
  99. data/ext/cargo-vendor/cranelift-codegen-shared-0.107.2/Cargo.toml +22 -0
  100. data/ext/cargo-vendor/cranelift-control-0.107.2/.cargo-checksum.json +1 -0
  101. data/ext/cargo-vendor/cranelift-control-0.107.2/Cargo.toml +30 -0
  102. data/ext/cargo-vendor/cranelift-entity-0.107.2/.cargo-checksum.json +1 -0
  103. data/ext/cargo-vendor/cranelift-entity-0.107.2/Cargo.toml +50 -0
  104. data/ext/cargo-vendor/cranelift-frontend-0.107.2/.cargo-checksum.json +1 -0
  105. data/ext/cargo-vendor/cranelift-frontend-0.107.2/Cargo.toml +69 -0
  106. data/ext/cargo-vendor/cranelift-isle-0.107.2/.cargo-checksum.json +1 -0
  107. data/ext/cargo-vendor/cranelift-isle-0.107.2/Cargo.toml +46 -0
  108. data/ext/cargo-vendor/cranelift-native-0.107.2/.cargo-checksum.json +1 -0
  109. data/ext/cargo-vendor/cranelift-native-0.107.2/Cargo.toml +45 -0
  110. data/ext/cargo-vendor/cranelift-wasm-0.107.2/.cargo-checksum.json +1 -0
  111. data/ext/cargo-vendor/cranelift-wasm-0.107.2/Cargo.toml +107 -0
  112. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/code_translator.rs +3683 -0
  113. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/environ/dummy.rs +912 -0
  114. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/environ/mod.rs +8 -0
  115. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/environ/spec.rs +945 -0
  116. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/func_translator.rs +296 -0
  117. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/lib.rs +58 -0
  118. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/state.rs +522 -0
  119. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/table.rs +104 -0
  120. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.21/.cargo-checksum.json +1 -0
  121. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.21/Cargo.toml +48 -0
  122. data/ext/cargo-vendor/mach2-0.4.2/.cargo-checksum.json +1 -0
  123. data/ext/cargo-vendor/mach2-0.4.2/Cargo.toml +49 -0
  124. data/ext/cargo-vendor/mach2-0.4.2/LICENSE-APACHE +176 -0
  125. data/ext/cargo-vendor/mach2-0.4.2/LICENSE-BSD +23 -0
  126. data/ext/cargo-vendor/mach2-0.4.2/LICENSE-MIT +25 -0
  127. data/ext/cargo-vendor/mach2-0.4.2/README.md +116 -0
  128. data/ext/cargo-vendor/mach2-0.4.2/src/exc.rs +73 -0
  129. data/ext/cargo-vendor/mach2-0.4.2/src/kern_return.rs +59 -0
  130. data/ext/cargo-vendor/mach2-0.4.2/src/lib.rs +59 -0
  131. data/ext/cargo-vendor/mach2-0.4.2/src/mach_port.rs +50 -0
  132. data/ext/cargo-vendor/mach2-0.4.2/src/message.rs +345 -0
  133. data/ext/cargo-vendor/mach2-0.4.2/src/ndr.rs +19 -0
  134. data/ext/cargo-vendor/mach2-0.4.2/src/port.rs +67 -0
  135. data/ext/cargo-vendor/mach2-0.4.2/src/semaphore.rs +22 -0
  136. data/ext/cargo-vendor/mach2-0.4.2/src/structs.rs +66 -0
  137. data/ext/cargo-vendor/mach2-0.4.2/src/sync_policy.rs +9 -0
  138. data/ext/cargo-vendor/mach2-0.4.2/src/task.rs +46 -0
  139. data/ext/cargo-vendor/mach2-0.4.2/src/task_info.rs +49 -0
  140. data/ext/cargo-vendor/mach2-0.4.2/src/thread_act.rs +36 -0
  141. data/ext/cargo-vendor/mach2-0.4.2/src/thread_policy.rs +121 -0
  142. data/ext/cargo-vendor/mach2-0.4.2/src/thread_status.rs +53 -0
  143. data/ext/cargo-vendor/mach2-0.4.2/src/traps.rs +37 -0
  144. data/ext/cargo-vendor/mach2-0.4.2/src/vm.rs +248 -0
  145. data/ext/cargo-vendor/mach2-0.4.2/src/vm_attributes.rs +18 -0
  146. data/ext/cargo-vendor/mach2-0.4.2/src/vm_page_size.rs +40 -0
  147. data/ext/cargo-vendor/mach2-0.4.2/src/vm_prot.rs +13 -0
  148. data/ext/cargo-vendor/mach2-0.4.2/src/vm_purgable.rs +42 -0
  149. data/ext/cargo-vendor/mach2-0.4.2/src/vm_region.rs +238 -0
  150. data/ext/cargo-vendor/mach2-0.4.2/src/vm_statistics.rs +58 -0
  151. data/ext/cargo-vendor/mach2-0.4.2/src/vm_sync.rs +11 -0
  152. data/ext/cargo-vendor/mach2-0.4.2/src/vm_types.rs +19 -0
  153. data/ext/cargo-vendor/object-0.33.0/.cargo-checksum.json +1 -0
  154. data/ext/cargo-vendor/object-0.33.0/CHANGELOG.md +797 -0
  155. data/ext/cargo-vendor/object-0.33.0/Cargo.toml +179 -0
  156. data/ext/cargo-vendor/object-0.33.0/LICENSE-APACHE +201 -0
  157. data/ext/cargo-vendor/object-0.33.0/LICENSE-MIT +25 -0
  158. data/ext/cargo-vendor/object-0.33.0/README.md +56 -0
  159. data/ext/cargo-vendor/object-0.33.0/src/archive.rs +91 -0
  160. data/ext/cargo-vendor/object-0.33.0/src/build/bytes.rs +141 -0
  161. data/ext/cargo-vendor/object-0.33.0/src/build/elf.rs +3033 -0
  162. data/ext/cargo-vendor/object-0.33.0/src/build/error.rs +41 -0
  163. data/ext/cargo-vendor/object-0.33.0/src/build/mod.rs +18 -0
  164. data/ext/cargo-vendor/object-0.33.0/src/build/table.rs +128 -0
  165. data/ext/cargo-vendor/object-0.33.0/src/common.rs +568 -0
  166. data/ext/cargo-vendor/object-0.33.0/src/elf.rs +6291 -0
  167. data/ext/cargo-vendor/object-0.33.0/src/endian.rs +831 -0
  168. data/ext/cargo-vendor/object-0.33.0/src/lib.rs +107 -0
  169. data/ext/cargo-vendor/object-0.33.0/src/macho.rs +3309 -0
  170. data/ext/cargo-vendor/object-0.33.0/src/pe.rs +3056 -0
  171. data/ext/cargo-vendor/object-0.33.0/src/pod.rs +239 -0
  172. data/ext/cargo-vendor/object-0.33.0/src/read/any.rs +1328 -0
  173. data/ext/cargo-vendor/object-0.33.0/src/read/archive.rs +759 -0
  174. data/ext/cargo-vendor/object-0.33.0/src/read/coff/comdat.rs +211 -0
  175. data/ext/cargo-vendor/object-0.33.0/src/read/coff/file.rs +383 -0
  176. data/ext/cargo-vendor/object-0.33.0/src/read/coff/import.rs +223 -0
  177. data/ext/cargo-vendor/object-0.33.0/src/read/coff/mod.rs +66 -0
  178. data/ext/cargo-vendor/object-0.33.0/src/read/coff/relocation.rs +108 -0
  179. data/ext/cargo-vendor/object-0.33.0/src/read/coff/section.rs +585 -0
  180. data/ext/cargo-vendor/object-0.33.0/src/read/coff/symbol.rs +635 -0
  181. data/ext/cargo-vendor/object-0.33.0/src/read/elf/attributes.rs +306 -0
  182. data/ext/cargo-vendor/object-0.33.0/src/read/elf/comdat.rs +162 -0
  183. data/ext/cargo-vendor/object-0.33.0/src/read/elf/compression.rs +56 -0
  184. data/ext/cargo-vendor/object-0.33.0/src/read/elf/dynamic.rs +117 -0
  185. data/ext/cargo-vendor/object-0.33.0/src/read/elf/file.rs +918 -0
  186. data/ext/cargo-vendor/object-0.33.0/src/read/elf/hash.rs +224 -0
  187. data/ext/cargo-vendor/object-0.33.0/src/read/elf/mod.rs +78 -0
  188. data/ext/cargo-vendor/object-0.33.0/src/read/elf/note.rs +271 -0
  189. data/ext/cargo-vendor/object-0.33.0/src/read/elf/relocation.rs +629 -0
  190. data/ext/cargo-vendor/object-0.33.0/src/read/elf/section.rs +1150 -0
  191. data/ext/cargo-vendor/object-0.33.0/src/read/elf/segment.rs +356 -0
  192. data/ext/cargo-vendor/object-0.33.0/src/read/elf/symbol.rs +595 -0
  193. data/ext/cargo-vendor/object-0.33.0/src/read/elf/version.rs +424 -0
  194. data/ext/cargo-vendor/object-0.33.0/src/read/macho/dyld_cache.rs +345 -0
  195. data/ext/cargo-vendor/object-0.33.0/src/read/macho/fat.rs +140 -0
  196. data/ext/cargo-vendor/object-0.33.0/src/read/macho/file.rs +783 -0
  197. data/ext/cargo-vendor/object-0.33.0/src/read/macho/load_command.rs +386 -0
  198. data/ext/cargo-vendor/object-0.33.0/src/read/macho/mod.rs +72 -0
  199. data/ext/cargo-vendor/object-0.33.0/src/read/macho/relocation.rs +149 -0
  200. data/ext/cargo-vendor/object-0.33.0/src/read/macho/section.rs +389 -0
  201. data/ext/cargo-vendor/object-0.33.0/src/read/macho/segment.rs +303 -0
  202. data/ext/cargo-vendor/object-0.33.0/src/read/macho/symbol.rs +492 -0
  203. data/ext/cargo-vendor/object-0.33.0/src/read/mod.rs +880 -0
  204. data/ext/cargo-vendor/object-0.33.0/src/read/pe/data_directory.rs +214 -0
  205. data/ext/cargo-vendor/object-0.33.0/src/read/pe/export.rs +334 -0
  206. data/ext/cargo-vendor/object-0.33.0/src/read/pe/file.rs +1053 -0
  207. data/ext/cargo-vendor/object-0.33.0/src/read/pe/import.rs +339 -0
  208. data/ext/cargo-vendor/object-0.33.0/src/read/pe/mod.rs +68 -0
  209. data/ext/cargo-vendor/object-0.33.0/src/read/pe/relocation.rs +92 -0
  210. data/ext/cargo-vendor/object-0.33.0/src/read/pe/resource.rs +210 -0
  211. data/ext/cargo-vendor/object-0.33.0/src/read/pe/rich.rs +92 -0
  212. data/ext/cargo-vendor/object-0.33.0/src/read/pe/section.rs +440 -0
  213. data/ext/cargo-vendor/object-0.33.0/src/read/read_cache.rs +213 -0
  214. data/ext/cargo-vendor/object-0.33.0/src/read/read_ref.rs +149 -0
  215. data/ext/cargo-vendor/object-0.33.0/src/read/traits.rs +551 -0
  216. data/ext/cargo-vendor/object-0.33.0/src/read/util.rs +425 -0
  217. data/ext/cargo-vendor/object-0.33.0/src/read/wasm.rs +966 -0
  218. data/ext/cargo-vendor/object-0.33.0/src/read/xcoff/comdat.rs +134 -0
  219. data/ext/cargo-vendor/object-0.33.0/src/read/xcoff/file.rs +697 -0
  220. data/ext/cargo-vendor/object-0.33.0/src/read/xcoff/mod.rs +63 -0
  221. data/ext/cargo-vendor/object-0.33.0/src/read/xcoff/relocation.rs +134 -0
  222. data/ext/cargo-vendor/object-0.33.0/src/read/xcoff/section.rs +433 -0
  223. data/ext/cargo-vendor/object-0.33.0/src/read/xcoff/segment.rs +117 -0
  224. data/ext/cargo-vendor/object-0.33.0/src/read/xcoff/symbol.rs +784 -0
  225. data/ext/cargo-vendor/object-0.33.0/src/write/coff/mod.rs +10 -0
  226. data/ext/cargo-vendor/object-0.33.0/src/write/coff/object.rs +678 -0
  227. data/ext/cargo-vendor/object-0.33.0/src/write/coff/writer.rs +518 -0
  228. data/ext/cargo-vendor/object-0.33.0/src/write/elf/mod.rs +9 -0
  229. data/ext/cargo-vendor/object-0.33.0/src/write/elf/object.rs +885 -0
  230. data/ext/cargo-vendor/object-0.33.0/src/write/elf/writer.rs +2309 -0
  231. data/ext/cargo-vendor/object-0.33.0/src/write/macho.rs +1107 -0
  232. data/ext/cargo-vendor/object-0.33.0/src/write/mod.rs +990 -0
  233. data/ext/cargo-vendor/object-0.33.0/src/write/pe.rs +847 -0
  234. data/ext/cargo-vendor/object-0.33.0/src/write/string.rs +186 -0
  235. data/ext/cargo-vendor/object-0.33.0/src/write/util.rs +261 -0
  236. data/ext/cargo-vendor/object-0.33.0/src/write/xcoff.rs +589 -0
  237. data/ext/cargo-vendor/object-0.33.0/src/xcoff.rs +905 -0
  238. data/ext/cargo-vendor/object-0.33.0/tests/integration.rs +2 -0
  239. data/ext/cargo-vendor/object-0.33.0/tests/parse_self.rs +25 -0
  240. data/ext/cargo-vendor/object-0.33.0/tests/read/coff.rs +23 -0
  241. data/ext/cargo-vendor/object-0.33.0/tests/read/elf.rs +47 -0
  242. data/ext/cargo-vendor/object-0.33.0/tests/read/mod.rs +4 -0
  243. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/bss.rs +255 -0
  244. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/coff.rs +58 -0
  245. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/comdat.rs +225 -0
  246. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/common.rs +245 -0
  247. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/elf.rs +289 -0
  248. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/macho.rs +64 -0
  249. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/mod.rs +704 -0
  250. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/section_flags.rs +90 -0
  251. data/ext/cargo-vendor/object-0.33.0/tests/round_trip/tls.rs +316 -0
  252. data/ext/cargo-vendor/wasi-common-20.0.0/.cargo-checksum.json +1 -0
  253. data/ext/cargo-vendor/wasi-common-20.0.0/Cargo.toml +220 -0
  254. data/ext/cargo-vendor/wasi-common-20.0.0/src/ctx.rs +128 -0
  255. data/ext/cargo-vendor/wasi-common-20.0.0/src/lib.rs +193 -0
  256. data/ext/cargo-vendor/wasi-common-20.0.0/src/snapshots/preview_1.rs +1497 -0
  257. data/ext/cargo-vendor/wasi-common-20.0.0/tests/all/async_.rs +293 -0
  258. data/ext/cargo-vendor/wasi-common-20.0.0/tests/all/sync.rs +279 -0
  259. data/ext/cargo-vendor/wasm-encoder-0.202.0/.cargo-checksum.json +1 -0
  260. data/ext/cargo-vendor/wasm-encoder-0.202.0/Cargo.toml +43 -0
  261. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/component/types.rs +792 -0
  262. data/ext/cargo-vendor/wasm-encoder-0.208.1/.cargo-checksum.json +1 -0
  263. data/ext/cargo-vendor/wasm-encoder-0.208.1/Cargo.toml +46 -0
  264. data/ext/cargo-vendor/wasm-encoder-0.208.1/README.md +80 -0
  265. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/aliases.rs +160 -0
  266. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/builder.rs +455 -0
  267. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/canonicals.rs +159 -0
  268. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/components.rs +29 -0
  269. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/exports.rs +124 -0
  270. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/imports.rs +175 -0
  271. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/instances.rs +200 -0
  272. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/modules.rs +29 -0
  273. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/names.rs +149 -0
  274. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/start.rs +52 -0
  275. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component/types.rs +792 -0
  276. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/component.rs +168 -0
  277. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/code.rs +3595 -0
  278. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/custom.rs +73 -0
  279. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/data.rs +186 -0
  280. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/dump.rs +627 -0
  281. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/elements.rs +221 -0
  282. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/exports.rs +98 -0
  283. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/functions.rs +63 -0
  284. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/globals.rs +112 -0
  285. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/imports.rs +157 -0
  286. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/linking.rs +263 -0
  287. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/memories.rs +128 -0
  288. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/names.rs +298 -0
  289. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/producers.rs +181 -0
  290. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/start.rs +39 -0
  291. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/tables.rs +134 -0
  292. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/tags.rs +104 -0
  293. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core/types.rs +678 -0
  294. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/core.rs +168 -0
  295. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/lib.rs +215 -0
  296. data/ext/cargo-vendor/wasm-encoder-0.208.1/src/raw.rs +30 -0
  297. data/ext/cargo-vendor/wasmparser-0.202.0/.cargo-checksum.json +1 -0
  298. data/ext/cargo-vendor/wasmparser-0.202.0/Cargo.lock +744 -0
  299. data/ext/cargo-vendor/wasmparser-0.202.0/Cargo.toml +66 -0
  300. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/types.rs +549 -0
  301. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/operators.rs +4076 -0
  302. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/types.rs +4449 -0
  303. data/ext/cargo-vendor/wasmprinter-0.202.0/.cargo-checksum.json +1 -0
  304. data/ext/cargo-vendor/wasmprinter-0.202.0/Cargo.toml +45 -0
  305. data/ext/cargo-vendor/wasmprinter-0.202.0/src/lib.rs +3202 -0
  306. data/ext/cargo-vendor/wasmprinter-0.202.0/src/operator.rs +1131 -0
  307. data/ext/cargo-vendor/wasmprinter-0.202.0/tests/all.rs +279 -0
  308. data/ext/cargo-vendor/wasmtime-20.0.0/.cargo-checksum.json +1 -0
  309. data/ext/cargo-vendor/wasmtime-20.0.0/Cargo.toml +268 -0
  310. data/ext/cargo-vendor/wasmtime-20.0.0/src/compile/code_builder.rs +201 -0
  311. data/ext/cargo-vendor/wasmtime-20.0.0/src/compile/runtime.rs +175 -0
  312. data/ext/cargo-vendor/wasmtime-20.0.0/src/compile.rs +897 -0
  313. data/ext/cargo-vendor/wasmtime-20.0.0/src/config.rs +2695 -0
  314. data/ext/cargo-vendor/wasmtime-20.0.0/src/engine/serialization.rs +849 -0
  315. data/ext/cargo-vendor/wasmtime-20.0.0/src/engine.rs +741 -0
  316. data/ext/cargo-vendor/wasmtime-20.0.0/src/lib.rs +303 -0
  317. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/code_memory.rs +335 -0
  318. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/component.rs +661 -0
  319. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/func/host.rs +439 -0
  320. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/func/options.rs +554 -0
  321. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/func/typed.rs +2484 -0
  322. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/func.rs +747 -0
  323. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/instance.rs +804 -0
  324. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/linker.rs +786 -0
  325. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/matching.rs +217 -0
  326. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/mod.rs +756 -0
  327. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/resources.rs +1133 -0
  328. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/types.rs +892 -0
  329. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/component/values.rs +978 -0
  330. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/coredump.rs +336 -0
  331. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/externals/global.rs +300 -0
  332. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/externals/table.rs +480 -0
  333. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/func/typed.rs +898 -0
  334. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/func.rs +2633 -0
  335. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/disabled/anyref.rs +46 -0
  336. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/disabled/externref.rs +50 -0
  337. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/disabled/i31.rs +14 -0
  338. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/disabled/rooting.rs +222 -0
  339. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/disabled.rs +17 -0
  340. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/enabled/anyref.rs +472 -0
  341. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/enabled/externref.rs +644 -0
  342. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/enabled/i31.rs +345 -0
  343. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/enabled/rooting.rs +1543 -0
  344. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc/enabled.rs +12 -0
  345. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/gc.rs +87 -0
  346. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/instance.rs +992 -0
  347. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/instantiate.rs +345 -0
  348. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/linker.rs +1521 -0
  349. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/memory.rs +999 -0
  350. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/module/registry.rs +354 -0
  351. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/module.rs +1295 -0
  352. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/profiling.rs +224 -0
  353. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/store/data.rs +289 -0
  354. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/store.rs +2796 -0
  355. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/trampoline/func.rs +138 -0
  356. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/trampoline/global.rs +68 -0
  357. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/trampoline/memory.rs +286 -0
  358. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/trampoline/table.rs +34 -0
  359. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/trap.rs +641 -0
  360. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/type_registry.rs +632 -0
  361. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/types/matching.rs +367 -0
  362. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/types.rs +1378 -0
  363. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/v128.rs +131 -0
  364. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime/values.rs +945 -0
  365. data/ext/cargo-vendor/wasmtime-20.0.0/src/runtime.rs +112 -0
  366. data/ext/cargo-vendor/wasmtime-asm-macros-20.0.0/.cargo-checksum.json +1 -0
  367. data/ext/cargo-vendor/wasmtime-asm-macros-20.0.0/Cargo.toml +22 -0
  368. data/ext/cargo-vendor/wasmtime-cache-20.0.0/.cargo-checksum.json +1 -0
  369. data/ext/cargo-vendor/wasmtime-cache-20.0.0/Cargo.toml +81 -0
  370. data/ext/cargo-vendor/wasmtime-component-macro-20.0.0/.cargo-checksum.json +1 -0
  371. data/ext/cargo-vendor/wasmtime-component-macro-20.0.0/Cargo.toml +67 -0
  372. data/ext/cargo-vendor/wasmtime-component-macro-20.0.0/src/component.rs +1295 -0
  373. data/ext/cargo-vendor/wasmtime-component-macro-20.0.0/tests/codegen/dead-code.wit +27 -0
  374. data/ext/cargo-vendor/wasmtime-component-macro-20.0.0/tests/codegen.rs +342 -0
  375. data/ext/cargo-vendor/wasmtime-component-util-20.0.0/.cargo-checksum.json +1 -0
  376. data/ext/cargo-vendor/wasmtime-component-util-20.0.0/Cargo.toml +25 -0
  377. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/.cargo-checksum.json +1 -0
  378. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/Cargo.toml +114 -0
  379. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/builder.rs +127 -0
  380. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/compiled_function.rs +225 -0
  381. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/compiler/component.rs +962 -0
  382. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/compiler.rs +1369 -0
  383. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/debug/transform/address_transform.rs +783 -0
  384. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/debug/transform/expression.rs +1252 -0
  385. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/func_environ.rs +2672 -0
  386. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/gc/disabled.rs +116 -0
  387. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/gc/enabled.rs +649 -0
  388. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/gc.rs +198 -0
  389. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/lib.rs +505 -0
  390. data/ext/cargo-vendor/wasmtime-cranelift-20.0.0/src/obj.rs +545 -0
  391. data/ext/cargo-vendor/wasmtime-environ-20.0.0/.cargo-checksum.json +1 -0
  392. data/ext/cargo-vendor/wasmtime-environ-20.0.0/Cargo.lock +782 -0
  393. data/ext/cargo-vendor/wasmtime-environ-20.0.0/Cargo.toml +144 -0
  394. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/address_map.rs +125 -0
  395. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/builtin.rs +184 -0
  396. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/compile/address_map.rs +72 -0
  397. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/compile/mod.rs +389 -0
  398. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/compile/module_artifacts.rs +300 -0
  399. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/compile/trap_encoding.rs +69 -0
  400. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/component/artifacts.rs +72 -0
  401. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/component/compiler.rs +19 -0
  402. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/component/info.rs +672 -0
  403. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/component/translate/adapt.rs +459 -0
  404. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/component/translate/inline.rs +1332 -0
  405. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/component/types.rs +1972 -0
  406. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/component.rs +103 -0
  407. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/fact/trampoline.rs +3233 -0
  408. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/fact/transcode.rs +89 -0
  409. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/fact.rs +711 -0
  410. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/gc.rs +60 -0
  411. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/lib.rs +70 -0
  412. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/module.rs +780 -0
  413. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/module_artifacts.rs +145 -0
  414. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/module_environ.rs +1288 -0
  415. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/obj.rs +173 -0
  416. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/trap_encoding.rs +188 -0
  417. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/tunables.rs +158 -0
  418. data/ext/cargo-vendor/wasmtime-environ-20.0.0/src/vmoffsets.rs +952 -0
  419. data/ext/cargo-vendor/wasmtime-fiber-20.0.0/.cargo-checksum.json +1 -0
  420. data/ext/cargo-vendor/wasmtime-fiber-20.0.0/Cargo.toml +63 -0
  421. data/ext/cargo-vendor/wasmtime-fiber-20.0.0/src/unix.rs +265 -0
  422. data/ext/cargo-vendor/wasmtime-jit-debug-20.0.0/.cargo-checksum.json +1 -0
  423. data/ext/cargo-vendor/wasmtime-jit-debug-20.0.0/Cargo.toml +67 -0
  424. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.0/.cargo-checksum.json +1 -0
  425. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.0/Cargo.toml +47 -0
  426. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/.cargo-checksum.json +1 -0
  427. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/Cargo.toml +147 -0
  428. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/build.rs +24 -0
  429. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/arch/aarch64.rs +76 -0
  430. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/arch/riscv64.rs +41 -0
  431. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/arch/s390x.S +70 -0
  432. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/arch/s390x.rs +34 -0
  433. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/arch/x86_64.rs +41 -0
  434. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/async_yield.rs +35 -0
  435. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/component/libcalls.rs +571 -0
  436. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/component.rs +860 -0
  437. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/export.rs +108 -0
  438. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/disabled.rs +23 -0
  439. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/enabled/drc.rs +963 -0
  440. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/enabled/externref.rs +115 -0
  441. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/enabled/free_list.rs +767 -0
  442. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/enabled.rs +18 -0
  443. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/gc_ref.rs +486 -0
  444. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/gc_runtime.rs +503 -0
  445. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/host_data.rs +81 -0
  446. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc/i31.rs +86 -0
  447. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/gc.rs +244 -0
  448. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/instance/allocator/on_demand.rs +217 -0
  449. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/instance/allocator/pooling/gc_heap_pool.rs +92 -0
  450. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/instance/allocator/pooling/table_pool.rs +231 -0
  451. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/instance/allocator/pooling.rs +699 -0
  452. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/instance/allocator.rs +780 -0
  453. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/instance.rs +1566 -0
  454. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/lib.rs +289 -0
  455. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/libcalls.rs +777 -0
  456. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/memory.rs +751 -0
  457. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/send_sync_ptr.rs +106 -0
  458. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/sys/custom/mmap.rs +111 -0
  459. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/sys/custom/traphandlers.rs +55 -0
  460. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/sys/miri/mmap.rs +94 -0
  461. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/sys/unix/machports.rs +416 -0
  462. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/sys/unix/mmap.rs +151 -0
  463. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/sys/unix/signals.rs +401 -0
  464. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/sys/windows/traphandlers.rs +104 -0
  465. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/table.rs +851 -0
  466. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/threads/mod.rs +12 -0
  467. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/threads/shared_memory.rs +230 -0
  468. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/threads/shared_memory_disabled.rs +100 -0
  469. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/traphandlers/coredump_disabled.rs +16 -0
  470. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/traphandlers/coredump_enabled.rs +40 -0
  471. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/traphandlers.rs +785 -0
  472. data/ext/cargo-vendor/wasmtime-runtime-20.0.0/src/vmcontext.rs +1293 -0
  473. data/ext/cargo-vendor/wasmtime-slab-20.0.0/.cargo-checksum.json +1 -0
  474. data/ext/cargo-vendor/wasmtime-slab-20.0.0/Cargo.toml +21 -0
  475. data/ext/cargo-vendor/wasmtime-slab-20.0.0/src/lib.rs +493 -0
  476. data/ext/cargo-vendor/wasmtime-types-20.0.2/.cargo-checksum.json +1 -0
  477. data/ext/cargo-vendor/wasmtime-types-20.0.2/Cargo.toml +36 -0
  478. data/ext/cargo-vendor/wasmtime-types-20.0.2/src/lib.rs +832 -0
  479. data/ext/cargo-vendor/wasmtime-versioned-export-macros-20.0.0/.cargo-checksum.json +1 -0
  480. data/ext/cargo-vendor/wasmtime-versioned-export-macros-20.0.0/Cargo.toml +32 -0
  481. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/.cargo-checksum.json +1 -0
  482. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/Cargo.toml +194 -0
  483. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/bindings.rs +283 -0
  484. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/ctx.rs +659 -0
  485. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/filesystem.rs +433 -0
  486. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/host/filesystem/sync.rs +518 -0
  487. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/host/filesystem.rs +1079 -0
  488. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/host/io.rs +367 -0
  489. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/host/network.rs +539 -0
  490. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/host/tcp.rs +306 -0
  491. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/ip_name_lookup.rs +126 -0
  492. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/lib.rs +404 -0
  493. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/network.rs +107 -0
  494. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/pipe.rs +826 -0
  495. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/poll.rs +233 -0
  496. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/preview0.rs +879 -0
  497. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/preview1.rs +2601 -0
  498. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/runtime.rs +175 -0
  499. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/stdio/worker_thread_stdin.rs +177 -0
  500. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/stdio.rs +507 -0
  501. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/tcp.rs +847 -0
  502. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/udp.rs +125 -0
  503. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/src/write_stream.rs +203 -0
  504. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/tests/all/api.rs +194 -0
  505. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/tests/all/async_.rs +397 -0
  506. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/tests/all/main.rs +91 -0
  507. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/tests/all/preview1.rs +251 -0
  508. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/tests/all/sync.rs +333 -0
  509. data/ext/cargo-vendor/wasmtime-wasi-20.0.0/wit/deps/io/poll.wit +41 -0
  510. data/ext/cargo-vendor/wasmtime-winch-20.0.0/.cargo-checksum.json +1 -0
  511. data/ext/cargo-vendor/wasmtime-winch-20.0.0/Cargo.toml +81 -0
  512. data/ext/cargo-vendor/wasmtime-winch-20.0.0/src/builder.rs +85 -0
  513. data/ext/cargo-vendor/wasmtime-winch-20.0.0/src/compiler.rs +257 -0
  514. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.0/.cargo-checksum.json +1 -0
  515. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.0/Cargo.toml +41 -0
  516. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.0/src/lib.rs +2213 -0
  517. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.0/src/rust.rs +421 -0
  518. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.0/src/types.rs +202 -0
  519. data/ext/cargo-vendor/wast-208.0.1/.cargo-checksum.json +1 -0
  520. data/ext/cargo-vendor/wast-208.0.1/Cargo.toml +60 -0
  521. data/ext/cargo-vendor/wast-208.0.1/src/component/binary.rs +1000 -0
  522. data/ext/cargo-vendor/wast-208.0.1/src/component/resolve.rs +1007 -0
  523. data/ext/cargo-vendor/wast-208.0.1/src/component/types.rs +999 -0
  524. data/ext/cargo-vendor/wast-208.0.1/src/component/wast.rs +160 -0
  525. data/ext/cargo-vendor/wast-208.0.1/src/core/binary.rs +1396 -0
  526. data/ext/cargo-vendor/wast-208.0.1/src/core/expr.rs +2016 -0
  527. data/ext/cargo-vendor/wast-208.0.1/src/core/func.rs +136 -0
  528. data/ext/cargo-vendor/wast-208.0.1/src/core/memory.rs +284 -0
  529. data/ext/cargo-vendor/wast-208.0.1/src/core/resolve/deinline_import_export.rs +235 -0
  530. data/ext/cargo-vendor/wast-208.0.1/src/core/resolve/names.rs +751 -0
  531. data/ext/cargo-vendor/wast-208.0.1/src/core/resolve/types.rs +267 -0
  532. data/ext/cargo-vendor/wast-208.0.1/src/core/table.rs +302 -0
  533. data/ext/cargo-vendor/wast-208.0.1/src/core/types.rs +901 -0
  534. data/ext/cargo-vendor/wast-208.0.1/src/core/wast.rs +256 -0
  535. data/ext/cargo-vendor/wast-208.0.1/src/lib.rs +551 -0
  536. data/ext/cargo-vendor/wast-208.0.1/src/names.rs +67 -0
  537. data/ext/cargo-vendor/wast-208.0.1/src/parser.rs +1377 -0
  538. data/ext/cargo-vendor/wast-208.0.1/src/token.rs +737 -0
  539. data/ext/cargo-vendor/wast-208.0.1/src/wast.rs +459 -0
  540. data/ext/cargo-vendor/wast-208.0.1/src/wat.rs +71 -0
  541. data/ext/cargo-vendor/wast-208.0.1/tests/annotations.rs +200 -0
  542. data/ext/cargo-vendor/wast-208.0.1/tests/parse-fail.rs +80 -0
  543. data/ext/cargo-vendor/wat-1.208.1/.cargo-checksum.json +1 -0
  544. data/ext/cargo-vendor/wat-1.208.1/Cargo.toml +34 -0
  545. data/ext/cargo-vendor/wiggle-20.0.0/.cargo-checksum.json +1 -0
  546. data/ext/cargo-vendor/wiggle-20.0.0/Cargo.toml +122 -0
  547. data/ext/cargo-vendor/wiggle-20.0.0/src/borrow.rs +113 -0
  548. data/ext/cargo-vendor/wiggle-20.0.0/src/guest_type.rs +237 -0
  549. data/ext/cargo-vendor/wiggle-20.0.0/src/lib.rs +1184 -0
  550. data/ext/cargo-vendor/wiggle-20.0.0/src/wasmtime.rs +97 -0
  551. data/ext/cargo-vendor/wiggle-generate-20.0.0/.cargo-checksum.json +1 -0
  552. data/ext/cargo-vendor/wiggle-generate-20.0.0/Cargo.toml +65 -0
  553. data/ext/cargo-vendor/wiggle-macro-20.0.0/.cargo-checksum.json +1 -0
  554. data/ext/cargo-vendor/wiggle-macro-20.0.0/Cargo.toml +55 -0
  555. data/ext/cargo-vendor/wiggle-macro-20.0.0/LICENSE +220 -0
  556. data/ext/cargo-vendor/winch-codegen-0.18.0/.cargo-checksum.json +1 -0
  557. data/ext/cargo-vendor/winch-codegen-0.18.0/Cargo.toml +81 -0
  558. data/ext/cargo-vendor/winch-codegen-0.18.0/src/abi/mod.rs +671 -0
  559. data/ext/cargo-vendor/winch-codegen-0.18.0/src/codegen/bounds.rs +220 -0
  560. data/ext/cargo-vendor/winch-codegen-0.18.0/src/codegen/builtin.rs +263 -0
  561. data/ext/cargo-vendor/winch-codegen-0.18.0/src/codegen/call.rs +413 -0
  562. data/ext/cargo-vendor/winch-codegen-0.18.0/src/codegen/env.rs +435 -0
  563. data/ext/cargo-vendor/winch-codegen-0.18.0/src/codegen/mod.rs +756 -0
  564. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/aarch64/abi.rs +291 -0
  565. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/aarch64/asm.rs +252 -0
  566. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/aarch64/masm.rs +573 -0
  567. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/aarch64/mod.rs +154 -0
  568. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/aarch64/regs.rs +149 -0
  569. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/mod.rs +223 -0
  570. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/x64/abi.rs +517 -0
  571. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/x64/asm.rs +1423 -0
  572. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/x64/masm.rs +1256 -0
  573. data/ext/cargo-vendor/winch-codegen-0.18.0/src/isa/x64/mod.rs +169 -0
  574. data/ext/cargo-vendor/winch-codegen-0.18.0/src/lib.rs +19 -0
  575. data/ext/cargo-vendor/winch-codegen-0.18.0/src/masm.rs +947 -0
  576. data/ext/cargo-vendor/winch-codegen-0.18.0/src/visitor.rs +2149 -0
  577. data/ext/cargo-vendor/wit-parser-0.202.0/.cargo-checksum.json +1 -0
  578. data/ext/cargo-vendor/wit-parser-0.202.0/Cargo.toml +101 -0
  579. data/ext/cargo-vendor/wit-parser-0.202.0/src/abi.rs +309 -0
  580. data/ext/cargo-vendor/wit-parser-0.202.0/src/ast/lex.rs +747 -0
  581. data/ext/cargo-vendor/wit-parser-0.202.0/src/ast/resolve.rs +1443 -0
  582. data/ext/cargo-vendor/wit-parser-0.202.0/src/ast.rs +1348 -0
  583. data/ext/cargo-vendor/wit-parser-0.202.0/src/decoding.rs +1764 -0
  584. data/ext/cargo-vendor/wit-parser-0.202.0/src/lib.rs +765 -0
  585. data/ext/cargo-vendor/wit-parser-0.202.0/src/resolve.rs +2240 -0
  586. data/ext/cargo-vendor/wit-parser-0.202.0/src/serde_.rs +108 -0
  587. data/ext/cargo-vendor/wit-parser-0.202.0/src/sizealign.rs +179 -0
  588. data/ext/cargo-vendor/wit-parser-0.202.0/tests/all.rs +153 -0
  589. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/functions.wit +14 -0
  590. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/functions.wit.json +166 -0
  591. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/resources-multiple.wit +20 -0
  592. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/resources-multiple.wit.json +281 -0
  593. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/types.wit +60 -0
  594. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/types.wit.json +774 -0
  595. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/union-fuzz-2.wit +12 -0
  596. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/union-fuzz-2.wit.json +72 -0
  597. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/wasi.wit +178 -0
  598. data/ext/src/ruby_api/convert.rs +15 -7
  599. data/ext/src/ruby_api/func.rs +2 -2
  600. data/ext/src/ruby_api/global.rs +2 -2
  601. data/ext/src/ruby_api/params.rs +5 -5
  602. data/ext/src/ruby_api/table.rs +3 -3
  603. data/lib/wasmtime/version.rb +1 -1
  604. metadata +1737 -1630
  605. data/ext/cargo-vendor/anyhow-1.0.79/.cargo-checksum.json +0 -1
  606. data/ext/cargo-vendor/anyhow-1.0.79/Cargo.toml +0 -67
  607. data/ext/cargo-vendor/anyhow-1.0.79/README.md +0 -179
  608. data/ext/cargo-vendor/anyhow-1.0.79/build.rs +0 -167
  609. data/ext/cargo-vendor/anyhow-1.0.79/src/backtrace.rs +0 -405
  610. data/ext/cargo-vendor/anyhow-1.0.79/src/chain.rs +0 -102
  611. data/ext/cargo-vendor/anyhow-1.0.79/src/fmt.rs +0 -156
  612. data/ext/cargo-vendor/anyhow-1.0.79/src/kind.rs +0 -119
  613. data/ext/cargo-vendor/anyhow-1.0.79/src/lib.rs +0 -698
  614. data/ext/cargo-vendor/anyhow-1.0.79/src/macros.rs +0 -231
  615. data/ext/cargo-vendor/anyhow-1.0.79/src/wrapper.rs +0 -81
  616. data/ext/cargo-vendor/anyhow-1.0.79/tests/test_ensure.rs +0 -722
  617. data/ext/cargo-vendor/anyhow-1.0.79/tests/test_macros.rs +0 -80
  618. data/ext/cargo-vendor/anyhow-1.0.79/tests/test_repr.rs +0 -31
  619. data/ext/cargo-vendor/anyhow-1.0.79/tests/ui/no-impl.stderr +0 -31
  620. data/ext/cargo-vendor/cranelift-bforest-0.106.2/.cargo-checksum.json +0 -1
  621. data/ext/cargo-vendor/cranelift-bforest-0.106.2/Cargo.toml +0 -40
  622. data/ext/cargo-vendor/cranelift-codegen-0.106.2/.cargo-checksum.json +0 -1
  623. data/ext/cargo-vendor/cranelift-codegen-0.106.2/Cargo.toml +0 -175
  624. data/ext/cargo-vendor/cranelift-codegen-0.106.2/build.rs +0 -395
  625. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/alias_analysis.rs +0 -409
  626. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/binemit/mod.rs +0 -171
  627. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/bitset.rs +0 -165
  628. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/context.rs +0 -384
  629. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/egraph/elaborate.rs +0 -836
  630. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/egraph.rs +0 -702
  631. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/inst_predicates.rs +0 -217
  632. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/constant.rs +0 -462
  633. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/dfg.rs +0 -1734
  634. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/entities.rs +0 -598
  635. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/function.rs +0 -500
  636. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/instructions.rs +0 -1000
  637. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/memflags.rs +0 -310
  638. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/mod.rs +0 -110
  639. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/table.rs +0 -40
  640. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/trapcode.rs +0 -144
  641. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/ir/types.rs +0 -629
  642. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/abi.rs +0 -1707
  643. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/inst/emit.rs +0 -3958
  644. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/inst/mod.rs +0 -3082
  645. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/inst.isle +0 -4197
  646. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/lower/isle.rs +0 -879
  647. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/lower.isle +0 -2917
  648. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/mod.rs +0 -241
  649. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/aarch64/pcc.rs +0 -565
  650. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/call_conv.rs +0 -119
  651. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/riscv64/abi.rs +0 -1097
  652. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/riscv64/inst/args.rs +0 -1974
  653. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/riscv64/inst/emit.rs +0 -3485
  654. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/riscv64/inst/encode.rs +0 -654
  655. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/riscv64/inst.isle +0 -2928
  656. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/riscv64/lower/isle.rs +0 -620
  657. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/riscv64/lower.isle +0 -2864
  658. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/s390x/abi.rs +0 -1041
  659. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/s390x/inst/args.rs +0 -355
  660. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/s390x/inst/emit.rs +0 -3663
  661. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/s390x/inst.isle +0 -5031
  662. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/s390x/lower.isle +0 -3979
  663. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/abi.rs +0 -1303
  664. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/encoding/evex.rs +0 -749
  665. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/encoding/rex.rs +0 -598
  666. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/encoding/vex.rs +0 -492
  667. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/inst/args.rs +0 -2269
  668. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/inst/emit.rs +0 -4390
  669. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/inst/emit_state.rs +0 -72
  670. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/inst/mod.rs +0 -2852
  671. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/inst.isle +0 -5232
  672. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/lower/isle.rs +0 -1065
  673. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/lower.isle +0 -4770
  674. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/lower.rs +0 -353
  675. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/mod.rs +0 -233
  676. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/isa/x64/pcc.rs +0 -939
  677. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/legalizer/mod.rs +0 -356
  678. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/legalizer/table.rs +0 -114
  679. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/abi.rs +0 -2657
  680. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/buffer.rs +0 -2509
  681. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/inst_common.rs +0 -74
  682. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/isle.rs +0 -914
  683. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/lower.rs +0 -1443
  684. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/mod.rs +0 -558
  685. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/pcc.rs +0 -159
  686. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/machinst/vcode.rs +0 -1809
  687. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/nan_canonicalization.rs +0 -106
  688. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/opts/cprop.isle +0 -266
  689. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/opts.rs +0 -284
  690. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/prelude.isle +0 -641
  691. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/result.rs +0 -108
  692. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/settings.rs +0 -602
  693. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/verifier/mod.rs +0 -2033
  694. data/ext/cargo-vendor/cranelift-codegen-0.106.2/src/write.rs +0 -647
  695. data/ext/cargo-vendor/cranelift-codegen-meta-0.106.2/.cargo-checksum.json +0 -1
  696. data/ext/cargo-vendor/cranelift-codegen-meta-0.106.2/Cargo.toml +0 -35
  697. data/ext/cargo-vendor/cranelift-codegen-meta-0.106.2/src/shared/entities.rs +0 -106
  698. data/ext/cargo-vendor/cranelift-codegen-meta-0.106.2/src/shared/formats.rs +0 -213
  699. data/ext/cargo-vendor/cranelift-codegen-meta-0.106.2/src/shared/instructions.rs +0 -3810
  700. data/ext/cargo-vendor/cranelift-codegen-shared-0.106.2/.cargo-checksum.json +0 -1
  701. data/ext/cargo-vendor/cranelift-codegen-shared-0.106.2/Cargo.toml +0 -22
  702. data/ext/cargo-vendor/cranelift-control-0.106.2/.cargo-checksum.json +0 -1
  703. data/ext/cargo-vendor/cranelift-control-0.106.2/Cargo.toml +0 -30
  704. data/ext/cargo-vendor/cranelift-entity-0.106.2/.cargo-checksum.json +0 -1
  705. data/ext/cargo-vendor/cranelift-entity-0.106.2/Cargo.toml +0 -50
  706. data/ext/cargo-vendor/cranelift-frontend-0.106.2/.cargo-checksum.json +0 -1
  707. data/ext/cargo-vendor/cranelift-frontend-0.106.2/Cargo.toml +0 -68
  708. data/ext/cargo-vendor/cranelift-isle-0.106.2/.cargo-checksum.json +0 -1
  709. data/ext/cargo-vendor/cranelift-isle-0.106.2/Cargo.toml +0 -46
  710. data/ext/cargo-vendor/cranelift-native-0.106.2/.cargo-checksum.json +0 -1
  711. data/ext/cargo-vendor/cranelift-native-0.106.2/Cargo.toml +0 -43
  712. data/ext/cargo-vendor/cranelift-wasm-0.106.2/.cargo-checksum.json +0 -1
  713. data/ext/cargo-vendor/cranelift-wasm-0.106.2/Cargo.toml +0 -106
  714. data/ext/cargo-vendor/cranelift-wasm-0.106.2/src/code_translator.rs +0 -3680
  715. data/ext/cargo-vendor/cranelift-wasm-0.106.2/src/environ/dummy.rs +0 -952
  716. data/ext/cargo-vendor/cranelift-wasm-0.106.2/src/environ/mod.rs +0 -12
  717. data/ext/cargo-vendor/cranelift-wasm-0.106.2/src/environ/spec.rs +0 -952
  718. data/ext/cargo-vendor/cranelift-wasm-0.106.2/src/func_translator.rs +0 -432
  719. data/ext/cargo-vendor/cranelift-wasm-0.106.2/src/lib.rs +0 -62
  720. data/ext/cargo-vendor/cranelift-wasm-0.106.2/src/state.rs +0 -542
  721. data/ext/cargo-vendor/cranelift-wasm-0.106.2/tests/wasm_testsuite.rs +0 -153
  722. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/arith.wat +0 -13
  723. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/br_table.wat +0 -30
  724. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/call-simd.wat +0 -14
  725. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/call.wat +0 -10
  726. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/embenchen_fannkuch.wat +0 -12180
  727. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/embenchen_fasta.wat +0 -12056
  728. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/embenchen_ifs.wat +0 -11505
  729. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/embenchen_primes.wat +0 -11185
  730. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/fac-multi-value.wat +0 -19
  731. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/fibonacci.wat +0 -22
  732. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/globals.wat +0 -8
  733. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/icall-simd.wat +0 -7
  734. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/icall.wat +0 -7
  735. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-reachability-translation-0.wat +0 -12
  736. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-reachability-translation-1.wat +0 -12
  737. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-reachability-translation-2.wat +0 -12
  738. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-reachability-translation-3.wat +0 -12
  739. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-reachability-translation-4.wat +0 -12
  740. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-reachability-translation-5.wat +0 -14
  741. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-reachability-translation-6.wat +0 -14
  742. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-unreachable-else-params-2.wat +0 -18
  743. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/if-unreachable-else-params.wat +0 -41
  744. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/issue-1306-name-section-with-u32-max-function-index.wasm +0 -0
  745. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/memory.wat +0 -11
  746. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-0.wat +0 -3
  747. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-1.wat +0 -6
  748. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-10.wat +0 -10
  749. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-11.wat +0 -7
  750. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-12.wat +0 -9
  751. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-13.wat +0 -10
  752. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-14.wat +0 -10
  753. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-15.wat +0 -22
  754. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-16.wat +0 -9
  755. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-17.wat +0 -26
  756. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-2.wat +0 -6
  757. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-3.wat +0 -13
  758. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-4.wat +0 -13
  759. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-5.wat +0 -11
  760. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-6.wat +0 -11
  761. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-7.wat +0 -9
  762. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-8.wat +0 -12
  763. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/multi-9.wat +0 -15
  764. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/nullref.wat +0 -11
  765. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/passive-data.wat +0 -12
  766. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/pr2303.wat +0 -15
  767. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/pr2559.wat +0 -51
  768. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/ref-func-0.wat +0 -12
  769. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/rust_fannkuch.wat +0 -1723
  770. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/select.wat +0 -19
  771. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/simd-store.wat +0 -83
  772. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/simd.wat +0 -29
  773. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/table-copy.wat +0 -22
  774. data/ext/cargo-vendor/cranelift-wasm-0.106.2/wasmtests/unreachable_code.wat +0 -77
  775. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.20/.cargo-checksum.json +0 -1
  776. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.20/Cargo.toml +0 -49
  777. data/ext/cargo-vendor/mach-0.3.2/.cargo-checksum.json +0 -1
  778. data/ext/cargo-vendor/mach-0.3.2/Cargo.toml +0 -46
  779. data/ext/cargo-vendor/mach-0.3.2/LICENSE.md +0 -23
  780. data/ext/cargo-vendor/mach-0.3.2/README.md +0 -55
  781. data/ext/cargo-vendor/mach-0.3.2/ci/build_fail.sh +0 -7
  782. data/ext/cargo-vendor/mach-0.3.2/ci/deploy_and_run_on_ios_simulator.rs +0 -175
  783. data/ext/cargo-vendor/mach-0.3.2/ci/run.sh +0 -57
  784. data/ext/cargo-vendor/mach-0.3.2/examples/dump_process_registers.rs +0 -136
  785. data/ext/cargo-vendor/mach-0.3.2/src/exc.rs +0 -44
  786. data/ext/cargo-vendor/mach-0.3.2/src/kern_return.rs +0 -58
  787. data/ext/cargo-vendor/mach-0.3.2/src/lib.rs +0 -60
  788. data/ext/cargo-vendor/mach-0.3.2/src/mach_port.rs +0 -29
  789. data/ext/cargo-vendor/mach-0.3.2/src/message.rs +0 -248
  790. data/ext/cargo-vendor/mach-0.3.2/src/port.rs +0 -26
  791. data/ext/cargo-vendor/mach-0.3.2/src/structs.rs +0 -62
  792. data/ext/cargo-vendor/mach-0.3.2/src/task.rs +0 -41
  793. data/ext/cargo-vendor/mach-0.3.2/src/task_info.rs +0 -44
  794. data/ext/cargo-vendor/mach-0.3.2/src/thread_act.rs +0 -23
  795. data/ext/cargo-vendor/mach-0.3.2/src/thread_status.rs +0 -23
  796. data/ext/cargo-vendor/mach-0.3.2/src/traps.rs +0 -35
  797. data/ext/cargo-vendor/mach-0.3.2/src/vm.rs +0 -247
  798. data/ext/cargo-vendor/mach-0.3.2/src/vm_attributes.rs +0 -18
  799. data/ext/cargo-vendor/mach-0.3.2/src/vm_page_size.rs +0 -33
  800. data/ext/cargo-vendor/mach-0.3.2/src/vm_prot.rs +0 -14
  801. data/ext/cargo-vendor/mach-0.3.2/src/vm_purgable.rs +0 -42
  802. data/ext/cargo-vendor/mach-0.3.2/src/vm_region.rs +0 -238
  803. data/ext/cargo-vendor/mach-0.3.2/src/vm_statistics.rs +0 -78
  804. data/ext/cargo-vendor/mach-0.3.2/src/vm_sync.rs +0 -11
  805. data/ext/cargo-vendor/mach-0.3.2/src/vm_types.rs +0 -19
  806. data/ext/cargo-vendor/wasi-common-19.0.2/.cargo-checksum.json +0 -1
  807. data/ext/cargo-vendor/wasi-common-19.0.2/Cargo.toml +0 -221
  808. data/ext/cargo-vendor/wasi-common-19.0.2/src/ctx.rs +0 -128
  809. data/ext/cargo-vendor/wasi-common-19.0.2/src/lib.rs +0 -189
  810. data/ext/cargo-vendor/wasi-common-19.0.2/src/snapshots/preview_1.rs +0 -1491
  811. data/ext/cargo-vendor/wasi-common-19.0.2/tests/all/async_.rs +0 -289
  812. data/ext/cargo-vendor/wasi-common-19.0.2/tests/all/sync.rs +0 -275
  813. data/ext/cargo-vendor/wasm-encoder-0.201.0/.cargo-checksum.json +0 -1
  814. data/ext/cargo-vendor/wasm-encoder-0.201.0/Cargo.toml +0 -43
  815. data/ext/cargo-vendor/wasm-encoder-0.201.0/src/component/types.rs +0 -792
  816. data/ext/cargo-vendor/wasmparser-0.201.0/.cargo-checksum.json +0 -1
  817. data/ext/cargo-vendor/wasmparser-0.201.0/Cargo.lock +0 -744
  818. data/ext/cargo-vendor/wasmparser-0.201.0/Cargo.toml +0 -66
  819. data/ext/cargo-vendor/wasmparser-0.201.0/src/readers/component/types.rs +0 -549
  820. data/ext/cargo-vendor/wasmparser-0.201.0/src/validator/operators.rs +0 -4074
  821. data/ext/cargo-vendor/wasmparser-0.201.0/src/validator/types.rs +0 -4449
  822. data/ext/cargo-vendor/wasmprinter-0.201.0/.cargo-checksum.json +0 -1
  823. data/ext/cargo-vendor/wasmprinter-0.201.0/Cargo.toml +0 -45
  824. data/ext/cargo-vendor/wasmprinter-0.201.0/src/lib.rs +0 -3143
  825. data/ext/cargo-vendor/wasmprinter-0.201.0/src/operator.rs +0 -1110
  826. data/ext/cargo-vendor/wasmprinter-0.201.0/tests/all.rs +0 -279
  827. data/ext/cargo-vendor/wasmtime-19.0.2/.cargo-checksum.json +0 -1
  828. data/ext/cargo-vendor/wasmtime-19.0.2/Cargo.toml +0 -261
  829. data/ext/cargo-vendor/wasmtime-19.0.2/src/compile.rs +0 -835
  830. data/ext/cargo-vendor/wasmtime-19.0.2/src/config.rs +0 -2649
  831. data/ext/cargo-vendor/wasmtime-19.0.2/src/engine/serialization.rs +0 -809
  832. data/ext/cargo-vendor/wasmtime-19.0.2/src/engine.rs +0 -735
  833. data/ext/cargo-vendor/wasmtime-19.0.2/src/lib.rs +0 -293
  834. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/code_memory.rs +0 -335
  835. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/component.rs +0 -586
  836. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/func/host.rs +0 -456
  837. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/func/options.rs +0 -541
  838. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/func/typed.rs +0 -2484
  839. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/func.rs +0 -752
  840. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/instance.rs +0 -818
  841. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/linker.rs +0 -788
  842. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/matching.rs +0 -212
  843. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/mod.rs +0 -678
  844. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/resources.rs +0 -1169
  845. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/types.rs +0 -961
  846. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/component/values.rs +0 -1388
  847. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/coredump.rs +0 -321
  848. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/externals/global.rs +0 -249
  849. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/externals/table.rs +0 -416
  850. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/func/typed.rs +0 -985
  851. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/func.rs +0 -2585
  852. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/instance.rs +0 -981
  853. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/instantiate.rs +0 -423
  854. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/linker.rs +0 -1518
  855. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/memory.rs +0 -997
  856. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/module/registry.rs +0 -360
  857. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/module.rs +0 -1367
  858. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/profiling.rs +0 -222
  859. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/ref/gc_ref.rs +0 -110
  860. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/ref/no_gc_ref.rs +0 -60
  861. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/ref.rs +0 -9
  862. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/store/data.rs +0 -289
  863. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/store.rs +0 -2445
  864. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/trampoline/func.rs +0 -144
  865. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/trampoline/global.rs +0 -70
  866. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/trampoline/memory.rs +0 -268
  867. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/trampoline/table.rs +0 -20
  868. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/trap.rs +0 -641
  869. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/type_registry.rs +0 -640
  870. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/types/matching.rs +0 -334
  871. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/types.rs +0 -1236
  872. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/v128.rs +0 -131
  873. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime/values.rs +0 -771
  874. data/ext/cargo-vendor/wasmtime-19.0.2/src/runtime.rs +0 -112
  875. data/ext/cargo-vendor/wasmtime-asm-macros-19.0.2/.cargo-checksum.json +0 -1
  876. data/ext/cargo-vendor/wasmtime-asm-macros-19.0.2/Cargo.toml +0 -22
  877. data/ext/cargo-vendor/wasmtime-cache-19.0.2/.cargo-checksum.json +0 -1
  878. data/ext/cargo-vendor/wasmtime-cache-19.0.2/Cargo.toml +0 -81
  879. data/ext/cargo-vendor/wasmtime-component-macro-19.0.2/.cargo-checksum.json +0 -1
  880. data/ext/cargo-vendor/wasmtime-component-macro-19.0.2/Cargo.toml +0 -67
  881. data/ext/cargo-vendor/wasmtime-component-macro-19.0.2/src/component.rs +0 -1295
  882. data/ext/cargo-vendor/wasmtime-component-macro-19.0.2/tests/codegen.rs +0 -191
  883. data/ext/cargo-vendor/wasmtime-component-util-19.0.2/.cargo-checksum.json +0 -1
  884. data/ext/cargo-vendor/wasmtime-component-util-19.0.2/Cargo.toml +0 -25
  885. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/.cargo-checksum.json +0 -1
  886. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/Cargo.toml +0 -114
  887. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/src/builder.rs +0 -127
  888. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/src/compiler/component.rs +0 -960
  889. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/src/compiler.rs +0 -1316
  890. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/src/debug/transform/address_transform.rs +0 -784
  891. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/src/debug/transform/expression.rs +0 -1252
  892. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/src/func_environ.rs +0 -2846
  893. data/ext/cargo-vendor/wasmtime-cranelift-19.0.2/src/lib.rs +0 -186
  894. data/ext/cargo-vendor/wasmtime-cranelift-shared-19.0.2/.cargo-checksum.json +0 -1
  895. data/ext/cargo-vendor/wasmtime-cranelift-shared-19.0.2/Cargo.toml +0 -71
  896. data/ext/cargo-vendor/wasmtime-cranelift-shared-19.0.2/src/compiled_function.rs +0 -231
  897. data/ext/cargo-vendor/wasmtime-cranelift-shared-19.0.2/src/lib.rs +0 -130
  898. data/ext/cargo-vendor/wasmtime-cranelift-shared-19.0.2/src/obj.rs +0 -564
  899. data/ext/cargo-vendor/wasmtime-environ-19.0.2/.cargo-checksum.json +0 -1
  900. data/ext/cargo-vendor/wasmtime-environ-19.0.2/Cargo.lock +0 -782
  901. data/ext/cargo-vendor/wasmtime-environ-19.0.2/Cargo.toml +0 -141
  902. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/address_map.rs +0 -191
  903. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/builtin.rs +0 -155
  904. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/compilation.rs +0 -402
  905. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/component/artifacts.rs +0 -45
  906. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/component/compiler.rs +0 -47
  907. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/component/info.rs +0 -594
  908. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/component/translate/adapt.rs +0 -457
  909. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/component/translate/inline.rs +0 -1332
  910. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/component/types.rs +0 -1933
  911. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/component.rs +0 -97
  912. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/fact/trampoline.rs +0 -3229
  913. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/fact/transcode.rs +0 -168
  914. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/fact.rs +0 -713
  915. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/lib.rs +0 -66
  916. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/module.rs +0 -1117
  917. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/module_artifacts.rs +0 -377
  918. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/module_environ.rs +0 -903
  919. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/obj.rs +0 -172
  920. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/trap_encoding.rs +0 -245
  921. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/tunables.rs +0 -154
  922. data/ext/cargo-vendor/wasmtime-environ-19.0.2/src/vmoffsets.rs +0 -918
  923. data/ext/cargo-vendor/wasmtime-fiber-19.0.2/.cargo-checksum.json +0 -1
  924. data/ext/cargo-vendor/wasmtime-fiber-19.0.2/Cargo.toml +0 -63
  925. data/ext/cargo-vendor/wasmtime-fiber-19.0.2/src/unix.rs +0 -265
  926. data/ext/cargo-vendor/wasmtime-jit-debug-19.0.2/.cargo-checksum.json +0 -1
  927. data/ext/cargo-vendor/wasmtime-jit-debug-19.0.2/Cargo.toml +0 -67
  928. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-19.0.2/.cargo-checksum.json +0 -1
  929. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-19.0.2/Cargo.toml +0 -46
  930. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/.cargo-checksum.json +0 -1
  931. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/Cargo.toml +0 -140
  932. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/build.rs +0 -28
  933. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/arch/aarch64.rs +0 -120
  934. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/arch/riscv64.rs +0 -88
  935. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/arch/s390x.S +0 -70
  936. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/arch/s390x.rs +0 -61
  937. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/arch/x86_64.rs +0 -104
  938. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/component/libcalls.rs +0 -572
  939. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/component.rs +0 -864
  940. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/export.rs +0 -105
  941. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/externref/gc.rs +0 -1058
  942. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/externref/no_gc.rs +0 -125
  943. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/externref.rs +0 -24
  944. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/instance/allocator/on_demand.rs +0 -196
  945. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/instance/allocator/pooling/table_pool.rs +0 -227
  946. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/instance/allocator/pooling.rs +0 -658
  947. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/instance/allocator.rs +0 -730
  948. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/instance.rs +0 -1527
  949. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/lib.rs +0 -264
  950. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/libcalls.rs +0 -776
  951. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/memory.rs +0 -972
  952. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/send_sync_ptr.rs +0 -93
  953. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/sys/custom/mmap.rs +0 -111
  954. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/sys/custom/traphandlers.rs +0 -51
  955. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/sys/miri/mmap.rs +0 -94
  956. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/sys/unix/machports.rs +0 -488
  957. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/sys/unix/mmap.rs +0 -151
  958. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/sys/unix/signals.rs +0 -402
  959. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/sys/windows/traphandlers.rs +0 -105
  960. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/table.rs +0 -643
  961. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/traphandlers/coredump.rs +0 -38
  962. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/traphandlers.rs +0 -736
  963. data/ext/cargo-vendor/wasmtime-runtime-19.0.2/src/vmcontext.rs +0 -1215
  964. data/ext/cargo-vendor/wasmtime-slab-19.0.2/.cargo-checksum.json +0 -1
  965. data/ext/cargo-vendor/wasmtime-slab-19.0.2/Cargo.toml +0 -21
  966. data/ext/cargo-vendor/wasmtime-slab-19.0.2/src/lib.rs +0 -450
  967. data/ext/cargo-vendor/wasmtime-types-19.0.2/.cargo-checksum.json +0 -1
  968. data/ext/cargo-vendor/wasmtime-types-19.0.2/Cargo.toml +0 -36
  969. data/ext/cargo-vendor/wasmtime-types-19.0.2/src/lib.rs +0 -640
  970. data/ext/cargo-vendor/wasmtime-versioned-export-macros-19.0.2/.cargo-checksum.json +0 -1
  971. data/ext/cargo-vendor/wasmtime-versioned-export-macros-19.0.2/Cargo.toml +0 -32
  972. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/.cargo-checksum.json +0 -1
  973. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/Cargo.toml +0 -194
  974. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/command.rs +0 -122
  975. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/ctx.rs +0 -353
  976. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/filesystem.rs +0 -373
  977. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/host/filesystem/sync.rs +0 -517
  978. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/host/filesystem.rs +0 -1081
  979. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/host/io.rs +0 -366
  980. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/host/network.rs +0 -519
  981. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/host/tcp.rs +0 -677
  982. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/ip_name_lookup.rs +0 -123
  983. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/lib.rs +0 -323
  984. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/network.rs +0 -108
  985. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/p1ctx.rs +0 -37
  986. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/pipe.rs +0 -826
  987. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/poll.rs +0 -179
  988. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/preview0.rs +0 -872
  989. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/preview1.rs +0 -2361
  990. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/stdio/worker_thread_stdin.rs +0 -173
  991. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/stdio.rs +0 -443
  992. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/tcp.rs +0 -350
  993. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/udp.rs +0 -125
  994. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/src/write_stream.rs +0 -203
  995. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/tests/all/api.rs +0 -210
  996. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/tests/all/async_.rs +0 -380
  997. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/tests/all/main.rs +0 -106
  998. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/tests/all/preview1.rs +0 -243
  999. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/tests/all/sync.rs +0 -315
  1000. data/ext/cargo-vendor/wasmtime-wasi-19.0.2/wit/deps/io/poll.wit +0 -42
  1001. data/ext/cargo-vendor/wasmtime-winch-19.0.2/.cargo-checksum.json +0 -1
  1002. data/ext/cargo-vendor/wasmtime-winch-19.0.2/Cargo.toml +0 -77
  1003. data/ext/cargo-vendor/wasmtime-winch-19.0.2/src/builder.rs +0 -65
  1004. data/ext/cargo-vendor/wasmtime-winch-19.0.2/src/compiler.rs +0 -283
  1005. data/ext/cargo-vendor/wasmtime-wit-bindgen-19.0.2/.cargo-checksum.json +0 -1
  1006. data/ext/cargo-vendor/wasmtime-wit-bindgen-19.0.2/Cargo.toml +0 -41
  1007. data/ext/cargo-vendor/wasmtime-wit-bindgen-19.0.2/src/lib.rs +0 -2104
  1008. data/ext/cargo-vendor/wasmtime-wit-bindgen-19.0.2/src/rust.rs +0 -421
  1009. data/ext/cargo-vendor/wasmtime-wit-bindgen-19.0.2/src/types.rs +0 -194
  1010. data/ext/cargo-vendor/wasmtime-wmemcheck-19.0.2/.cargo-checksum.json +0 -1
  1011. data/ext/cargo-vendor/wasmtime-wmemcheck-19.0.2/Cargo.toml +0 -29
  1012. data/ext/cargo-vendor/wasmtime-wmemcheck-19.0.2/src/lib.rs +0 -404
  1013. data/ext/cargo-vendor/wast-201.0.0/.cargo-checksum.json +0 -1
  1014. data/ext/cargo-vendor/wast-201.0.0/Cargo.toml +0 -59
  1015. data/ext/cargo-vendor/wast-201.0.0/src/component/binary.rs +0 -1004
  1016. data/ext/cargo-vendor/wast-201.0.0/src/component/resolve.rs +0 -1006
  1017. data/ext/cargo-vendor/wast-201.0.0/src/component/types.rs +0 -991
  1018. data/ext/cargo-vendor/wast-201.0.0/src/component/wast.rs +0 -160
  1019. data/ext/cargo-vendor/wast-201.0.0/src/core/binary.rs +0 -1365
  1020. data/ext/cargo-vendor/wast-201.0.0/src/core/expr.rs +0 -1993
  1021. data/ext/cargo-vendor/wast-201.0.0/src/core/func.rs +0 -136
  1022. data/ext/cargo-vendor/wast-201.0.0/src/core/memory.rs +0 -281
  1023. data/ext/cargo-vendor/wast-201.0.0/src/core/resolve/deinline_import_export.rs +0 -233
  1024. data/ext/cargo-vendor/wast-201.0.0/src/core/resolve/names.rs +0 -763
  1025. data/ext/cargo-vendor/wast-201.0.0/src/core/resolve/types.rs +0 -271
  1026. data/ext/cargo-vendor/wast-201.0.0/src/core/table.rs +0 -289
  1027. data/ext/cargo-vendor/wast-201.0.0/src/core/types.rs +0 -861
  1028. data/ext/cargo-vendor/wast-201.0.0/src/core/wast.rs +0 -256
  1029. data/ext/cargo-vendor/wast-201.0.0/src/lib.rs +0 -542
  1030. data/ext/cargo-vendor/wast-201.0.0/src/names.rs +0 -89
  1031. data/ext/cargo-vendor/wast-201.0.0/src/parser.rs +0 -1374
  1032. data/ext/cargo-vendor/wast-201.0.0/src/token.rs +0 -718
  1033. data/ext/cargo-vendor/wast-201.0.0/src/wast.rs +0 -420
  1034. data/ext/cargo-vendor/wast-201.0.0/src/wat.rs +0 -63
  1035. data/ext/cargo-vendor/wast-201.0.0/tests/annotations.rs +0 -200
  1036. data/ext/cargo-vendor/wast-201.0.0/tests/parse-fail.rs +0 -98
  1037. data/ext/cargo-vendor/wat-1.201.0/.cargo-checksum.json +0 -1
  1038. data/ext/cargo-vendor/wat-1.201.0/Cargo.toml +0 -33
  1039. data/ext/cargo-vendor/wiggle-19.0.2/.cargo-checksum.json +0 -1
  1040. data/ext/cargo-vendor/wiggle-19.0.2/Cargo.toml +0 -122
  1041. data/ext/cargo-vendor/wiggle-19.0.2/src/borrow.rs +0 -259
  1042. data/ext/cargo-vendor/wiggle-19.0.2/src/guest_type.rs +0 -237
  1043. data/ext/cargo-vendor/wiggle-19.0.2/src/lib.rs +0 -1199
  1044. data/ext/cargo-vendor/wiggle-19.0.2/src/wasmtime.rs +0 -101
  1045. data/ext/cargo-vendor/wiggle-generate-19.0.2/.cargo-checksum.json +0 -1
  1046. data/ext/cargo-vendor/wiggle-generate-19.0.2/Cargo.toml +0 -65
  1047. data/ext/cargo-vendor/wiggle-macro-19.0.2/.cargo-checksum.json +0 -1
  1048. data/ext/cargo-vendor/wiggle-macro-19.0.2/Cargo.toml +0 -55
  1049. data/ext/cargo-vendor/winch-codegen-0.17.2/.cargo-checksum.json +0 -1
  1050. data/ext/cargo-vendor/winch-codegen-0.17.2/Cargo.toml +0 -77
  1051. data/ext/cargo-vendor/winch-codegen-0.17.2/src/abi/mod.rs +0 -737
  1052. data/ext/cargo-vendor/winch-codegen-0.17.2/src/codegen/bounds.rs +0 -220
  1053. data/ext/cargo-vendor/winch-codegen-0.17.2/src/codegen/builtin.rs +0 -272
  1054. data/ext/cargo-vendor/winch-codegen-0.17.2/src/codegen/call.rs +0 -413
  1055. data/ext/cargo-vendor/winch-codegen-0.17.2/src/codegen/env.rs +0 -399
  1056. data/ext/cargo-vendor/winch-codegen-0.17.2/src/codegen/mod.rs +0 -672
  1057. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/aarch64/abi.rs +0 -309
  1058. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/aarch64/asm.rs +0 -247
  1059. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/aarch64/masm.rs +0 -557
  1060. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/aarch64/mod.rs +0 -152
  1061. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/aarch64/regs.rs +0 -183
  1062. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/mod.rs +0 -232
  1063. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/x64/abi.rs +0 -543
  1064. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/x64/asm.rs +0 -1418
  1065. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/x64/masm.rs +0 -1300
  1066. data/ext/cargo-vendor/winch-codegen-0.17.2/src/isa/x64/mod.rs +0 -192
  1067. data/ext/cargo-vendor/winch-codegen-0.17.2/src/lib.rs +0 -21
  1068. data/ext/cargo-vendor/winch-codegen-0.17.2/src/masm.rs +0 -955
  1069. data/ext/cargo-vendor/winch-codegen-0.17.2/src/trampoline.rs +0 -626
  1070. data/ext/cargo-vendor/winch-codegen-0.17.2/src/visitor.rs +0 -2101
  1071. data/ext/cargo-vendor/wit-parser-0.201.0/.cargo-checksum.json +0 -1
  1072. data/ext/cargo-vendor/wit-parser-0.201.0/Cargo.toml +0 -101
  1073. data/ext/cargo-vendor/wit-parser-0.201.0/src/abi.rs +0 -295
  1074. data/ext/cargo-vendor/wit-parser-0.201.0/src/ast/lex.rs +0 -747
  1075. data/ext/cargo-vendor/wit-parser-0.201.0/src/ast/resolve.rs +0 -1427
  1076. data/ext/cargo-vendor/wit-parser-0.201.0/src/ast.rs +0 -1348
  1077. data/ext/cargo-vendor/wit-parser-0.201.0/src/decoding.rs +0 -1764
  1078. data/ext/cargo-vendor/wit-parser-0.201.0/src/lib.rs +0 -747
  1079. data/ext/cargo-vendor/wit-parser-0.201.0/src/resolve.rs +0 -2239
  1080. data/ext/cargo-vendor/wit-parser-0.201.0/src/serde_.rs +0 -108
  1081. data/ext/cargo-vendor/wit-parser-0.201.0/src/sizealign.rs +0 -144
  1082. data/ext/cargo-vendor/wit-parser-0.201.0/tests/all.rs +0 -185
  1083. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/functions.wit +0 -14
  1084. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/functions.wit.json +0 -166
  1085. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/resources-multiple.wit +0 -20
  1086. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/resources-multiple.wit.json +0 -281
  1087. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/types.wit +0 -60
  1088. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/types.wit.json +0 -774
  1089. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/union-fuzz-2.wit +0 -12
  1090. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/union-fuzz-2.wit.json +0 -72
  1091. data/ext/cargo-vendor/wit-parser-0.201.0/tests/ui/wasi.wit +0 -178
  1092. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/LICENSE-APACHE +0 -0
  1093. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/LICENSE-MIT +0 -0
  1094. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/build/probe.rs +0 -0
  1095. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/rust-toolchain.toml +0 -0
  1096. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/src/context.rs +0 -0
  1097. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/src/ensure.rs +0 -0
  1098. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/src/error.rs +0 -0
  1099. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/src/ptr.rs +0 -0
  1100. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/common/mod.rs +0 -0
  1101. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/compiletest.rs +0 -0
  1102. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/drop/mod.rs +0 -0
  1103. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_autotrait.rs +0 -0
  1104. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_backtrace.rs +0 -0
  1105. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_boxed.rs +0 -0
  1106. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_chain.rs +0 -0
  1107. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_context.rs +0 -0
  1108. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_convert.rs +0 -0
  1109. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_downcast.rs +0 -0
  1110. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_ffi.rs +0 -0
  1111. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_fmt.rs +0 -0
  1112. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/test_source.rs +0 -0
  1113. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/chained-comparison.rs +0 -0
  1114. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/chained-comparison.stderr +0 -0
  1115. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/empty-ensure.rs +0 -0
  1116. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/empty-ensure.stderr +0 -0
  1117. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/must-use.rs +0 -0
  1118. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/must-use.stderr +0 -0
  1119. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/no-impl.rs +0 -0
  1120. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/temporary-value.rs +0 -0
  1121. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/temporary-value.stderr +0 -0
  1122. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/wrong-interpolation.rs +0 -0
  1123. /data/ext/cargo-vendor/{anyhow-1.0.79 → anyhow-1.0.83}/tests/ui/wrong-interpolation.stderr +0 -0
  1124. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/LICENSE +0 -0
  1125. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/README.md +0 -0
  1126. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/src/lib.rs +0 -0
  1127. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/src/map.rs +0 -0
  1128. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/src/node.rs +0 -0
  1129. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/src/path.rs +0 -0
  1130. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/src/pool.rs +0 -0
  1131. /data/ext/cargo-vendor/{cranelift-bforest-0.106.2 → cranelift-bforest-0.107.2}/src/set.rs +0 -0
  1132. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/LICENSE +0 -0
  1133. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/README.md +0 -0
  1134. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/benches/x64-evex-encoding.rs +0 -0
  1135. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/binemit/stack_map.rs +0 -0
  1136. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/cfg_printer.rs +0 -0
  1137. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/constant_hash.rs +0 -0
  1138. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ctxhash.rs +0 -0
  1139. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/cursor.rs +0 -0
  1140. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/data_value.rs +0 -0
  1141. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/dbg.rs +0 -0
  1142. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/dce.rs +0 -0
  1143. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/dominator_tree.rs +0 -0
  1144. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/egraph/cost.rs +0 -0
  1145. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/flowgraph.rs +0 -0
  1146. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/fx.rs +0 -0
  1147. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/incremental_cache.rs +0 -0
  1148. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/atomic_rmw_op.rs +0 -0
  1149. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/builder.rs +0 -0
  1150. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/condcodes.rs +0 -0
  1151. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/dynamic_type.rs +0 -0
  1152. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/extfunc.rs +0 -0
  1153. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/extname.rs +0 -0
  1154. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/globalvalue.rs +0 -0
  1155. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/immediates.rs +0 -0
  1156. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/jumptable.rs +0 -0
  1157. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/known_symbol.rs +0 -0
  1158. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/layout.rs +0 -0
  1159. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/libcall.rs +0 -0
  1160. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/memtype.rs +0 -0
  1161. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/pcc.rs +0 -0
  1162. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/progpoint.rs +0 -0
  1163. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/sourceloc.rs +0 -0
  1164. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/ir/stackslot.rs +0 -0
  1165. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/inst/args.rs +0 -0
  1166. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/inst/emit_tests.rs +0 -0
  1167. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/inst/imms.rs +0 -0
  1168. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/inst/regs.rs +0 -0
  1169. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/inst/unwind/systemv.rs +0 -0
  1170. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/inst/unwind.rs +0 -0
  1171. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/inst_neon.isle +0 -0
  1172. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
  1173. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/lower.rs +0 -0
  1174. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
  1175. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/aarch64/settings.rs +0 -0
  1176. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/mod.rs +0 -0
  1177. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst/emit_tests.rs +0 -0
  1178. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst/imms.rs +0 -0
  1179. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst/mod.rs +0 -0
  1180. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst/regs.rs +0 -0
  1181. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst/unwind/systemv.rs +0 -0
  1182. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst/unwind.rs +0 -0
  1183. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst/vector.rs +0 -0
  1184. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/inst_vector.isle +0 -0
  1185. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
  1186. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/lower.rs +0 -0
  1187. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/mod.rs +0 -0
  1188. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/riscv64/settings.rs +0 -0
  1189. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/inst/emit_tests.rs +0 -0
  1190. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/inst/imms.rs +0 -0
  1191. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/inst/mod.rs +0 -0
  1192. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/inst/regs.rs +0 -0
  1193. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/inst/unwind/systemv.rs +0 -0
  1194. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/inst/unwind.rs +0 -0
  1195. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
  1196. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/lower/isle.rs +0 -0
  1197. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/lower.rs +0 -0
  1198. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/mod.rs +0 -0
  1199. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/s390x/settings.rs +0 -0
  1200. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/unwind/systemv.rs +0 -0
  1201. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/unwind/winx64.rs +0 -0
  1202. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/unwind.rs +0 -0
  1203. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/encoding/mod.rs +0 -0
  1204. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/inst/emit_tests.rs +0 -0
  1205. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/inst/regs.rs +0 -0
  1206. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/inst/unwind/systemv.rs +0 -0
  1207. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/inst/unwind/winx64.rs +0 -0
  1208. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/inst/unwind.rs +0 -0
  1209. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/lower/isle/generated_code.rs +0 -0
  1210. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isa/x64/settings.rs +0 -0
  1211. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/isle_prelude.rs +0 -0
  1212. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/iterators.rs +0 -0
  1213. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/legalizer/globalvalue.rs +0 -0
  1214. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/lib.rs +0 -0
  1215. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/loop_analysis.rs +0 -0
  1216. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/machinst/blockorder.rs +0 -0
  1217. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/machinst/compile.rs +0 -0
  1218. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/machinst/helpers.rs +0 -0
  1219. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/machinst/reg.rs +0 -0
  1220. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/machinst/valueregs.rs +0 -0
  1221. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/README.md +0 -0
  1222. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/arithmetic.isle +0 -0
  1223. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/bitops.isle +0 -0
  1224. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/extends.isle +0 -0
  1225. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/generated_code.rs +0 -0
  1226. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/icmp.isle +0 -0
  1227. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/remat.isle +0 -0
  1228. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/selects.isle +0 -0
  1229. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/shifts.isle +0 -0
  1230. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/spaceship.isle +0 -0
  1231. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/opts/vector.isle +0 -0
  1232. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/prelude_lower.isle +0 -0
  1233. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/prelude_opt.isle +0 -0
  1234. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/print_errors.rs +0 -0
  1235. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/remove_constant_phis.rs +0 -0
  1236. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/scoped_hash_map.rs +0 -0
  1237. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/souper_harvest.rs +0 -0
  1238. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/timing.rs +0 -0
  1239. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/unionfind.rs +0 -0
  1240. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/unreachable_code.rs +0 -0
  1241. /data/ext/cargo-vendor/{cranelift-codegen-0.106.2 → cranelift-codegen-0.107.2}/src/value_label.rs +0 -0
  1242. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/LICENSE +0 -0
  1243. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/README.md +0 -0
  1244. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/formats.rs +0 -0
  1245. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/instructions.rs +0 -0
  1246. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/isa.rs +0 -0
  1247. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/mod.rs +0 -0
  1248. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/operands.rs +0 -0
  1249. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/settings.rs +0 -0
  1250. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/types.rs +0 -0
  1251. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/cdsl/typevar.rs +0 -0
  1252. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/constant_hash.rs +0 -0
  1253. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/error.rs +0 -0
  1254. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/gen_inst.rs +0 -0
  1255. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/gen_settings.rs +0 -0
  1256. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/gen_types.rs +0 -0
  1257. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/isa/arm64.rs +0 -0
  1258. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/isa/mod.rs +0 -0
  1259. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/isa/riscv64.rs +0 -0
  1260. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/isa/s390x.rs +0 -0
  1261. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/isa/x86.rs +0 -0
  1262. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/lib.rs +0 -0
  1263. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/shared/immediates.rs +0 -0
  1264. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/shared/mod.rs +0 -0
  1265. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/shared/settings.rs +0 -0
  1266. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/shared/types.rs +0 -0
  1267. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/srcgen.rs +0 -0
  1268. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.106.2 → cranelift-codegen-meta-0.107.2}/src/unique_table.rs +0 -0
  1269. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.106.2 → cranelift-codegen-shared-0.107.2}/LICENSE +0 -0
  1270. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.106.2 → cranelift-codegen-shared-0.107.2}/README.md +0 -0
  1271. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.106.2 → cranelift-codegen-shared-0.107.2}/src/constant_hash.rs +0 -0
  1272. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.106.2 → cranelift-codegen-shared-0.107.2}/src/constants.rs +0 -0
  1273. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.106.2 → cranelift-codegen-shared-0.107.2}/src/lib.rs +0 -0
  1274. /data/ext/cargo-vendor/{cranelift-control-0.106.2 → cranelift-control-0.107.2}/LICENSE +0 -0
  1275. /data/ext/cargo-vendor/{cranelift-control-0.106.2 → cranelift-control-0.107.2}/README.md +0 -0
  1276. /data/ext/cargo-vendor/{cranelift-control-0.106.2 → cranelift-control-0.107.2}/src/chaos.rs +0 -0
  1277. /data/ext/cargo-vendor/{cranelift-control-0.106.2 → cranelift-control-0.107.2}/src/lib.rs +0 -0
  1278. /data/ext/cargo-vendor/{cranelift-control-0.106.2 → cranelift-control-0.107.2}/src/zero_sized.rs +0 -0
  1279. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/LICENSE +0 -0
  1280. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/README.md +0 -0
  1281. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/boxed_slice.rs +0 -0
  1282. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/iter.rs +0 -0
  1283. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/keys.rs +0 -0
  1284. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/lib.rs +0 -0
  1285. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/list.rs +0 -0
  1286. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/map.rs +0 -0
  1287. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/packed_option.rs +0 -0
  1288. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/primary.rs +0 -0
  1289. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/set.rs +0 -0
  1290. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/sparse.rs +0 -0
  1291. /data/ext/cargo-vendor/{cranelift-entity-0.106.2 → cranelift-entity-0.107.2}/src/unsigned.rs +0 -0
  1292. /data/ext/cargo-vendor/{cranelift-frontend-0.106.2 → cranelift-frontend-0.107.2}/LICENSE +0 -0
  1293. /data/ext/cargo-vendor/{cranelift-frontend-0.106.2 → cranelift-frontend-0.107.2}/README.md +0 -0
  1294. /data/ext/cargo-vendor/{cranelift-frontend-0.106.2 → cranelift-frontend-0.107.2}/src/frontend.rs +0 -0
  1295. /data/ext/cargo-vendor/{cranelift-frontend-0.106.2 → cranelift-frontend-0.107.2}/src/lib.rs +0 -0
  1296. /data/ext/cargo-vendor/{cranelift-frontend-0.106.2 → cranelift-frontend-0.107.2}/src/ssa.rs +0 -0
  1297. /data/ext/cargo-vendor/{cranelift-frontend-0.106.2 → cranelift-frontend-0.107.2}/src/switch.rs +0 -0
  1298. /data/ext/cargo-vendor/{cranelift-frontend-0.106.2 → cranelift-frontend-0.107.2}/src/variable.rs +0 -0
  1299. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/README.md +0 -0
  1300. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/build.rs +0 -0
  1301. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/bad_converters.isle +0 -0
  1302. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
  1303. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
  1304. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/error1.isle +0 -0
  1305. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/extra_parens.isle +0 -0
  1306. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/impure_expression.isle +0 -0
  1307. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/impure_rhs.isle +0 -0
  1308. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/multi_internal_etor.isle +0 -0
  1309. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/fail/multi_prio.isle +0 -0
  1310. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/borrows.isle +0 -0
  1311. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/borrows_main.rs +0 -0
  1312. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/iflets.isle +0 -0
  1313. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/iflets_main.rs +0 -0
  1314. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/multi_constructor.isle +0 -0
  1315. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/multi_constructor_main.rs +0 -0
  1316. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/multi_extractor.isle +0 -0
  1317. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/multi_extractor_main.rs +0 -0
  1318. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/test.isle +0 -0
  1319. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/link/test_main.rs +0 -0
  1320. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/bound_var.isle +0 -0
  1321. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/construct_and_extract.isle +0 -0
  1322. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/conversions.isle +0 -0
  1323. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/conversions_extern.isle +0 -0
  1324. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/let.isle +0 -0
  1325. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/nodebug.isle +0 -0
  1326. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/prio_trie_bug.isle +0 -0
  1327. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/test2.isle +0 -0
  1328. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/test3.isle +0 -0
  1329. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/test4.isle +0 -0
  1330. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/pass/tutorial.isle +0 -0
  1331. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/run/iconst.isle +0 -0
  1332. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/run/iconst_main.rs +0 -0
  1333. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/run/let_shadowing.isle +0 -0
  1334. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/isle_examples/run/let_shadowing_main.rs +0 -0
  1335. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/ast.rs +0 -0
  1336. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/codegen.rs +0 -0
  1337. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/compile.rs +0 -0
  1338. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/error.rs +0 -0
  1339. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/lexer.rs +0 -0
  1340. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/lib.rs +0 -0
  1341. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/log.rs +0 -0
  1342. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/overlap.rs +0 -0
  1343. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/parser.rs +0 -0
  1344. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/sema.rs +0 -0
  1345. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/serialize.rs +0 -0
  1346. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/src/trie_again.rs +0 -0
  1347. /data/ext/cargo-vendor/{cranelift-isle-0.106.2 → cranelift-isle-0.107.2}/tests/run_tests.rs +0 -0
  1348. /data/ext/cargo-vendor/{cranelift-native-0.106.2 → cranelift-native-0.107.2}/LICENSE +0 -0
  1349. /data/ext/cargo-vendor/{cranelift-native-0.106.2 → cranelift-native-0.107.2}/README.md +0 -0
  1350. /data/ext/cargo-vendor/{cranelift-native-0.106.2 → cranelift-native-0.107.2}/src/lib.rs +0 -0
  1351. /data/ext/cargo-vendor/{cranelift-native-0.106.2 → cranelift-native-0.107.2}/src/riscv.rs +0 -0
  1352. /data/ext/cargo-vendor/{cranelift-wasm-0.106.2 → cranelift-wasm-0.107.2}/LICENSE +0 -0
  1353. /data/ext/cargo-vendor/{cranelift-wasm-0.106.2 → cranelift-wasm-0.107.2}/README.md +0 -0
  1354. /data/ext/cargo-vendor/{cranelift-wasm-0.106.2 → cranelift-wasm-0.107.2}/src/code_translator/bounds_checks.rs +0 -0
  1355. /data/ext/cargo-vendor/{cranelift-wasm-0.106.2 → cranelift-wasm-0.107.2}/src/heap.rs +0 -0
  1356. /data/ext/cargo-vendor/{cranelift-wasm-0.106.2 → cranelift-wasm-0.107.2}/src/module_translator.rs +0 -0
  1357. /data/ext/cargo-vendor/{cranelift-wasm-0.106.2 → cranelift-wasm-0.107.2}/src/sections_translator.rs +0 -0
  1358. /data/ext/cargo-vendor/{cranelift-wasm-0.106.2 → cranelift-wasm-0.107.2}/src/translation_utils.rs +0 -0
  1359. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/README.md +0 -0
  1360. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/src/clocks.rs +0 -0
  1361. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/src/lib.rs +0 -0
  1362. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/src/noop_scheduler.rs +0 -0
  1363. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/tests/clocks.rs +0 -0
  1364. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/tests/common/mod.rs +0 -0
  1365. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/tests/random.rs +0 -0
  1366. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.20 → deterministic-wasi-ctx-0.1.21}/tests/scheduler.rs +0 -0
  1367. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/boolean.rs +0 -0
  1368. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/bootstrap.rs +0 -0
  1369. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/clock.rs +0 -0
  1370. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/clock_priv.rs +0 -0
  1371. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/clock_reply.rs +0 -0
  1372. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/clock_types.rs +0 -0
  1373. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/dyld_kernel.rs +0 -0
  1374. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/exception_types.rs +0 -0
  1375. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/mach_init.rs +0 -0
  1376. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/mach_time.rs +0 -0
  1377. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/mach_types.rs +0 -0
  1378. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/memory_object_types.rs +0 -0
  1379. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/vm_behavior.rs +0 -0
  1380. /data/ext/cargo-vendor/{mach-0.3.2 → mach2-0.4.2}/src/vm_inherit.rs +0 -0
  1381. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/LICENSE +0 -0
  1382. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/README.md +0 -0
  1383. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/clocks.rs +0 -0
  1384. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/dir.rs +0 -0
  1385. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/error.rs +0 -0
  1386. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/file.rs +0 -0
  1387. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/pipe.rs +0 -0
  1388. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/random.rs +0 -0
  1389. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sched/subscription.rs +0 -0
  1390. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sched.rs +0 -0
  1391. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/snapshots/mod.rs +0 -0
  1392. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/snapshots/preview_0.rs +0 -0
  1393. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/snapshots/preview_1/error.rs +0 -0
  1394. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/string_array.rs +0 -0
  1395. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/clocks.rs +0 -0
  1396. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/dir.rs +0 -0
  1397. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/file.rs +0 -0
  1398. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/mod.rs +0 -0
  1399. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/net.rs +0 -0
  1400. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/sched/unix.rs +0 -0
  1401. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/sched/windows.rs +0 -0
  1402. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/sched.rs +0 -0
  1403. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/sync/stdio.rs +0 -0
  1404. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/table.rs +0 -0
  1405. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/dir.rs +0 -0
  1406. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/file.rs +0 -0
  1407. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/mod.rs +0 -0
  1408. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/net.rs +0 -0
  1409. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/sched/unix.rs +0 -0
  1410. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/sched/windows.rs +0 -0
  1411. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/sched.rs +0 -0
  1412. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/src/tokio/stdio.rs +0 -0
  1413. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/tests/all/main.rs +0 -0
  1414. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/witx/preview0/typenames.witx +0 -0
  1415. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/witx/preview0/wasi_unstable.witx +0 -0
  1416. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/witx/preview1/typenames.witx +0 -0
  1417. /data/ext/cargo-vendor/{wasi-common-19.0.2 → wasi-common-20.0.0}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1418. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/LICENSE +0 -0
  1419. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/README.md +0 -0
  1420. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/aliases.rs +0 -0
  1421. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/builder.rs +0 -0
  1422. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/canonicals.rs +0 -0
  1423. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/components.rs +0 -0
  1424. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/exports.rs +0 -0
  1425. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/imports.rs +0 -0
  1426. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/instances.rs +0 -0
  1427. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/modules.rs +0 -0
  1428. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/names.rs +0 -0
  1429. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component/start.rs +0 -0
  1430. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/component.rs +0 -0
  1431. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/code.rs +0 -0
  1432. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/custom.rs +0 -0
  1433. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/data.rs +0 -0
  1434. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/dump.rs +0 -0
  1435. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/elements.rs +0 -0
  1436. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/exports.rs +0 -0
  1437. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/functions.rs +0 -0
  1438. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/globals.rs +0 -0
  1439. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/imports.rs +0 -0
  1440. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/linking.rs +0 -0
  1441. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/memories.rs +0 -0
  1442. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/names.rs +0 -0
  1443. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/producers.rs +0 -0
  1444. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/start.rs +0 -0
  1445. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/tables.rs +0 -0
  1446. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/tags.rs +0 -0
  1447. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core/types.rs +0 -0
  1448. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/core.rs +0 -0
  1449. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/lib.rs +0 -0
  1450. /data/ext/cargo-vendor/{wasm-encoder-0.201.0 → wasm-encoder-0.202.0}/src/raw.rs +0 -0
  1451. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasm-encoder-0.208.1}/LICENSE +0 -0
  1452. /data/ext/cargo-vendor/{wasmprinter-0.201.0 → wasmparser-0.202.0}/LICENSE +0 -0
  1453. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/README.md +0 -0
  1454. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/benches/benchmark.rs +0 -0
  1455. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/examples/simple.rs +0 -0
  1456. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/binary_reader.rs +0 -0
  1457. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/lib.rs +0 -0
  1458. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/limits.rs +0 -0
  1459. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/parser.rs +0 -0
  1460. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component/aliases.rs +0 -0
  1461. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component/canonicals.rs +0 -0
  1462. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component/exports.rs +0 -0
  1463. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component/imports.rs +0 -0
  1464. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component/instances.rs +0 -0
  1465. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component/names.rs +0 -0
  1466. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component/start.rs +0 -0
  1467. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/component.rs +0 -0
  1468. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/branch_hinting.rs +0 -0
  1469. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/code.rs +0 -0
  1470. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/coredumps.rs +0 -0
  1471. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/custom.rs +0 -0
  1472. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/data.rs +0 -0
  1473. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/dylink0.rs +0 -0
  1474. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/elements.rs +0 -0
  1475. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/exports.rs +0 -0
  1476. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/functions.rs +0 -0
  1477. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/globals.rs +0 -0
  1478. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/imports.rs +0 -0
  1479. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/init.rs +0 -0
  1480. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/linking.rs +0 -0
  1481. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/memories.rs +0 -0
  1482. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/names.rs +0 -0
  1483. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/operators.rs +0 -0
  1484. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/producers.rs +0 -0
  1485. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/tables.rs +0 -0
  1486. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/tags.rs +0 -0
  1487. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/types/matches.rs +0 -0
  1488. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core/types.rs +0 -0
  1489. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers/core.rs +0 -0
  1490. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/readers.rs +0 -0
  1491. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/resources.rs +0 -0
  1492. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/validator/component.rs +0 -0
  1493. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/validator/core/canonical.rs +0 -0
  1494. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/validator/core.rs +0 -0
  1495. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/validator/func.rs +0 -0
  1496. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/validator/names.rs +0 -0
  1497. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/src/validator.rs +0 -0
  1498. /data/ext/cargo-vendor/{wasmparser-0.201.0 → wasmparser-0.202.0}/tests/big-module.rs +0 -0
  1499. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmprinter-0.202.0}/LICENSE +0 -0
  1500. /data/ext/cargo-vendor/{wasmprinter-0.201.0 → wasmprinter-0.202.0}/README.md +0 -0
  1501. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-20.0.0}/LICENSE +0 -0
  1502. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/README.md +0 -0
  1503. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/profiling_agent/jitdump.rs +0 -0
  1504. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/profiling_agent/perfmap.rs +0 -0
  1505. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/profiling_agent/vtune.rs +0 -0
  1506. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/profiling_agent.rs +0 -0
  1507. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/code.rs +0 -0
  1508. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/component/resource_table.rs +0 -0
  1509. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/component/storage.rs +0 -0
  1510. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/component/store.rs +0 -0
  1511. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/debug.rs +0 -0
  1512. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/externals.rs +0 -0
  1513. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/limits.rs +0 -0
  1514. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/resources.rs +0 -0
  1515. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/signatures.rs +0 -0
  1516. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/stack.rs +0 -0
  1517. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/store/context.rs +0 -0
  1518. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/store/func_refs.rs +0 -0
  1519. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/trampoline.rs +0 -0
  1520. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/uninhabited.rs +0 -0
  1521. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/unix.rs +0 -0
  1522. /data/ext/cargo-vendor/{wasmtime-19.0.2 → wasmtime-20.0.0}/src/runtime/windows.rs +0 -0
  1523. /data/ext/cargo-vendor/{wasmtime-asm-macros-19.0.2 → wasmtime-asm-macros-20.0.0}/src/lib.rs +0 -0
  1524. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cache-20.0.0}/LICENSE +0 -0
  1525. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/build.rs +0 -0
  1526. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/src/config/tests.rs +0 -0
  1527. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/src/config.rs +0 -0
  1528. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/src/lib.rs +0 -0
  1529. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/src/tests.rs +0 -0
  1530. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/src/worker/tests/system_time_stub.rs +0 -0
  1531. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/src/worker/tests.rs +0 -0
  1532. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/src/worker.rs +0 -0
  1533. /data/ext/cargo-vendor/{wasmtime-cache-19.0.2 → wasmtime-cache-20.0.0}/tests/cache_write_default_config.rs +0 -0
  1534. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/build.rs +0 -0
  1535. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/src/bindgen.rs +0 -0
  1536. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/src/lib.rs +0 -0
  1537. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/char.wit +0 -0
  1538. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/conventions.wit +0 -0
  1539. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/direct-import.wit +0 -0
  1540. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/empty.wit +0 -0
  1541. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/flags.wit +0 -0
  1542. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/floats.wit +0 -0
  1543. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/function-new.wit +0 -0
  1544. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/integers.wit +0 -0
  1545. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/lists.wit +0 -0
  1546. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/many-arguments.wit +0 -0
  1547. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/multi-return.wit +0 -0
  1548. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/multiversion/deps/v1/root.wit +0 -0
  1549. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/multiversion/deps/v2/root.wit +0 -0
  1550. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/multiversion/root.wit +0 -0
  1551. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/records.wit +0 -0
  1552. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/rename.wit +0 -0
  1553. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/resources-export.wit +0 -0
  1554. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/resources-import.wit +0 -0
  1555. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/share-types.wit +0 -0
  1556. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/simple-functions.wit +0 -0
  1557. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/simple-lists.wit +0 -0
  1558. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/simple-wasi.wit +0 -0
  1559. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/small-anonymous.wit +0 -0
  1560. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/smoke-default.wit +0 -0
  1561. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/smoke-export.wit +0 -0
  1562. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/smoke.wit +0 -0
  1563. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/strings.wit +0 -0
  1564. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/unversioned-foo.wit +0 -0
  1565. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/use-paths.wit +0 -0
  1566. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/variants.wit +0 -0
  1567. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/wat.wit +0 -0
  1568. /data/ext/cargo-vendor/{wasmtime-component-macro-19.0.2 → wasmtime-component-macro-20.0.0}/tests/codegen/worlds-with-types.wit +0 -0
  1569. /data/ext/cargo-vendor/{wasmtime-component-util-19.0.2 → wasmtime-component-util-20.0.0}/src/lib.rs +0 -0
  1570. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-cranelift-20.0.0}/LICENSE +0 -0
  1571. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/SECURITY.md +0 -0
  1572. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/gc.rs +0 -0
  1573. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/attr.rs +0 -0
  1574. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/line_program.rs +0 -0
  1575. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/mod.rs +0 -0
  1576. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/range_info_builder.rs +0 -0
  1577. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/refs.rs +0 -0
  1578. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/simulate.rs +0 -0
  1579. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/unit.rs +0 -0
  1580. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/transform/utils.rs +0 -0
  1581. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug/write_debuginfo.rs +0 -0
  1582. /data/ext/cargo-vendor/{wasmtime-cranelift-19.0.2 → wasmtime-cranelift-20.0.0}/src/debug.rs +0 -0
  1583. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-19.0.2 → wasmtime-cranelift-20.0.0}/src/isa_builder.rs +0 -0
  1584. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-environ-20.0.0}/LICENSE +0 -0
  1585. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/examples/factc.rs +0 -0
  1586. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/component/dfg.rs +0 -0
  1587. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/component/translate.rs +0 -0
  1588. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/component/types/resources.rs +0 -0
  1589. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/component/vmcomponent_offsets.rs +0 -0
  1590. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/demangling.rs +0 -0
  1591. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/fact/core_types.rs +0 -0
  1592. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/fact/signature.rs +0 -0
  1593. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/fact/traps.rs +0 -0
  1594. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/module_types.rs +0 -0
  1595. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/ref_bits.rs +0 -0
  1596. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/scopevec.rs +0 -0
  1597. /data/ext/cargo-vendor/{wasmtime-environ-19.0.2 → wasmtime-environ-20.0.0}/src/stack_map.rs +0 -0
  1598. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-fiber-20.0.0}/LICENSE +0 -0
  1599. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/build.rs +0 -0
  1600. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/lib.rs +0 -0
  1601. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/unix/aarch64.rs +0 -0
  1602. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/unix/arm.rs +0 -0
  1603. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/unix/riscv64.rs +0 -0
  1604. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/unix/s390x.S +0 -0
  1605. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/unix/x86.rs +0 -0
  1606. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/unix/x86_64.rs +0 -0
  1607. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/windows.c +0 -0
  1608. /data/ext/cargo-vendor/{wasmtime-fiber-19.0.2 → wasmtime-fiber-20.0.0}/src/windows.rs +0 -0
  1609. /data/ext/cargo-vendor/{wasmtime-jit-debug-19.0.2 → wasmtime-jit-debug-20.0.0}/README.md +0 -0
  1610. /data/ext/cargo-vendor/{wasmtime-jit-debug-19.0.2 → wasmtime-jit-debug-20.0.0}/src/gdb_jit_int.rs +0 -0
  1611. /data/ext/cargo-vendor/{wasmtime-jit-debug-19.0.2 → wasmtime-jit-debug-20.0.0}/src/lib.rs +0 -0
  1612. /data/ext/cargo-vendor/{wasmtime-jit-debug-19.0.2 → wasmtime-jit-debug-20.0.0}/src/perf_jitdump.rs +0 -0
  1613. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-19.0.2 → wasmtime-jit-icache-coherence-20.0.0}/src/lib.rs +0 -0
  1614. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-19.0.2 → wasmtime-jit-icache-coherence-20.0.0}/src/libc.rs +0 -0
  1615. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-19.0.2 → wasmtime-jit-icache-coherence-20.0.0}/src/miri.rs +0 -0
  1616. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-19.0.2 → wasmtime-jit-icache-coherence-20.0.0}/src/win.rs +0 -0
  1617. /data/ext/cargo-vendor/{wasmtime-types-19.0.2 → wasmtime-runtime-20.0.0}/LICENSE +0 -0
  1618. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/proptest-regressions/instance/allocator/pooling/memory_pool.txt +0 -0
  1619. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/arch/mod.rs +0 -0
  1620. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/component/resources.rs +0 -0
  1621. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/cow.rs +0 -0
  1622. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/debug_builtins.rs +0 -0
  1623. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/helpers.c +0 -0
  1624. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/imports.rs +0 -0
  1625. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/instance/allocator/pooling/index_allocator.rs +0 -0
  1626. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/instance/allocator/pooling/memory_pool.rs +0 -0
  1627. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/instance/allocator/pooling/stack_pool.rs +0 -0
  1628. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/mmap.rs +0 -0
  1629. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/mmap_vec.rs +0 -0
  1630. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/module_id.rs +0 -0
  1631. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/mpk/disabled.rs +0 -0
  1632. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/mpk/enabled.rs +0 -0
  1633. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/mpk/mod.rs +0 -0
  1634. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/mpk/pkru.rs +0 -0
  1635. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/mpk/sys.rs +0 -0
  1636. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/store_box.rs +0 -0
  1637. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/custom/capi.rs +0 -0
  1638. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/custom/mod.rs +0 -0
  1639. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/custom/unwind.rs +0 -0
  1640. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/custom/vm.rs +0 -0
  1641. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/miri/mod.rs +0 -0
  1642. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/miri/traphandlers.rs +0 -0
  1643. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/miri/unwind.rs +0 -0
  1644. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/miri/vm.rs +0 -0
  1645. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/mod.rs +0 -0
  1646. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/unix/macos_traphandlers.rs +0 -0
  1647. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/unix/mod.rs +0 -0
  1648. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/unix/unwind.rs +0 -0
  1649. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/unix/vm.rs +0 -0
  1650. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/windows/mmap.rs +0 -0
  1651. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/windows/mod.rs +0 -0
  1652. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/windows/unwind.rs +0 -0
  1653. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/sys/windows/vm.rs +0 -0
  1654. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2/src → wasmtime-runtime-20.0.0/src/threads}/parking_spot.rs +0 -0
  1655. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/traphandlers/backtrace.rs +0 -0
  1656. /data/ext/cargo-vendor/{wasmtime-runtime-19.0.2 → wasmtime-runtime-20.0.0}/src/vmcontext/vm_host_func_context.rs +0 -0
  1657. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-types-20.0.2}/LICENSE +0 -0
  1658. /data/ext/cargo-vendor/{wasmtime-types-19.0.2 → wasmtime-types-20.0.2}/src/error.rs +0 -0
  1659. /data/ext/cargo-vendor/{wasmtime-versioned-export-macros-19.0.2 → wasmtime-versioned-export-macros-20.0.0}/src/lib.rs +0 -0
  1660. /data/ext/cargo-vendor/{wast-201.0.0 → wasmtime-wasi-20.0.0}/LICENSE +0 -0
  1661. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/README.md +0 -0
  1662. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/clocks/host.rs +0 -0
  1663. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/clocks.rs +0 -0
  1664. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/error.rs +0 -0
  1665. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/clocks.rs +0 -0
  1666. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/env.rs +0 -0
  1667. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/exit.rs +0 -0
  1668. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/instance_network.rs +0 -0
  1669. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/mod.rs +0 -0
  1670. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/random.rs +0 -0
  1671. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/tcp_create_socket.rs +0 -0
  1672. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/udp.rs +0 -0
  1673. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/host/udp_create_socket.rs +0 -0
  1674. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/random.rs +0 -0
  1675. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/src/stream.rs +0 -0
  1676. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/tests/process_stdin.rs +0 -0
  1677. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/command-extended.wit +0 -0
  1678. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/cli/command.wit +0 -0
  1679. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/cli/environment.wit +0 -0
  1680. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/cli/exit.wit +0 -0
  1681. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/cli/imports.wit +0 -0
  1682. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/cli/run.wit +0 -0
  1683. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/cli/stdio.wit +0 -0
  1684. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/cli/terminal.wit +0 -0
  1685. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/clocks/monotonic-clock.wit +0 -0
  1686. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/clocks/wall-clock.wit +0 -0
  1687. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/clocks/world.wit +0 -0
  1688. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/filesystem/preopens.wit +0 -0
  1689. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/filesystem/types.wit +0 -0
  1690. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/filesystem/world.wit +0 -0
  1691. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/http/handler.wit +0 -0
  1692. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/http/proxy.wit +0 -0
  1693. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/http/types.wit +0 -0
  1694. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/io/error.wit +0 -0
  1695. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/io/streams.wit +0 -0
  1696. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/io/world.wit +0 -0
  1697. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/random/insecure-seed.wit +0 -0
  1698. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/random/insecure.wit +0 -0
  1699. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/random/random.wit +0 -0
  1700. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/random/world.wit +0 -0
  1701. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/instance-network.wit +0 -0
  1702. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/ip-name-lookup.wit +0 -0
  1703. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/network.wit +0 -0
  1704. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/tcp-create-socket.wit +0 -0
  1705. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/tcp.wit +0 -0
  1706. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/udp-create-socket.wit +0 -0
  1707. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/udp.wit +0 -0
  1708. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/deps/sockets/world.wit +0 -0
  1709. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/wit/test.wit +0 -0
  1710. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/witx/preview0/typenames.witx +0 -0
  1711. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/witx/preview0/wasi_unstable.witx +0 -0
  1712. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/witx/preview1/typenames.witx +0 -0
  1713. /data/ext/cargo-vendor/{wasmtime-wasi-19.0.2 → wasmtime-wasi-20.0.0}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1714. /data/ext/cargo-vendor/{wasmtime-winch-19.0.2 → wasmtime-winch-20.0.0}/LICENSE +0 -0
  1715. /data/ext/cargo-vendor/{wasmtime-winch-19.0.2 → wasmtime-winch-20.0.0}/src/lib.rs +0 -0
  1716. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-19.0.2 → wasmtime-wit-bindgen-20.0.0}/src/source.rs +0 -0
  1717. /data/ext/cargo-vendor/{wat-1.201.0 → wast-208.0.1}/LICENSE +0 -0
  1718. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/README.md +0 -0
  1719. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/alias.rs +0 -0
  1720. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/component.rs +0 -0
  1721. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/custom.rs +0 -0
  1722. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/expand.rs +0 -0
  1723. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/export.rs +0 -0
  1724. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/func.rs +0 -0
  1725. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/import.rs +0 -0
  1726. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/instance.rs +0 -0
  1727. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/item_ref.rs +0 -0
  1728. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component/module.rs +0 -0
  1729. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/component.rs +0 -0
  1730. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core/custom.rs +0 -0
  1731. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core/export.rs +0 -0
  1732. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core/global.rs +0 -0
  1733. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core/import.rs +0 -0
  1734. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core/module.rs +0 -0
  1735. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core/resolve/mod.rs +0 -0
  1736. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core/tag.rs +0 -0
  1737. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/core.rs +0 -0
  1738. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/encode.rs +0 -0
  1739. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/error.rs +0 -0
  1740. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/gensym.rs +0 -0
  1741. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/src/lexer.rs +0 -0
  1742. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/comments.rs +0 -0
  1743. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-core-func-alias.wat +0 -0
  1744. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-core-func-alias.wat.err +0 -0
  1745. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-func-alias.wat +0 -0
  1746. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-func-alias.wat.err +0 -0
  1747. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-index.wat +0 -0
  1748. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-index.wat.err +0 -0
  1749. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-name.wat +0 -0
  1750. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-name.wat.err +0 -0
  1751. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-name2.wat +0 -0
  1752. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-name2.wat.err +0 -0
  1753. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-name3.wat +0 -0
  1754. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/bad-name3.wat.err +0 -0
  1755. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/block1.wat +0 -0
  1756. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/block1.wat.err +0 -0
  1757. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/block2.wat +0 -0
  1758. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/block2.wat.err +0 -0
  1759. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/block3.wat +0 -0
  1760. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/block3.wat.err +0 -0
  1761. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment0.wat +0 -0
  1762. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment0.wat.err +0 -0
  1763. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment1.wat +0 -0
  1764. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment1.wat.err +0 -0
  1765. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment2.wat +0 -0
  1766. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment2.wat.err +0 -0
  1767. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment3.wat +0 -0
  1768. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment3.wat.err +0 -0
  1769. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment4.wat +0 -0
  1770. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment4.wat.err +0 -0
  1771. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment5.wat +0 -0
  1772. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment5.wat.err +0 -0
  1773. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment6.wat +0 -0
  1774. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment6.wat.err +0 -0
  1775. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment7.wat +0 -0
  1776. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment7.wat.err +0 -0
  1777. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment8.wat +0 -0
  1778. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-block-comment8.wat.err +0 -0
  1779. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment0.wat +0 -0
  1780. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment0.wat.err +0 -0
  1781. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment1.wat +0 -0
  1782. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment1.wat.err +0 -0
  1783. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment2.wat +0 -0
  1784. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment2.wat.err +0 -0
  1785. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment3.wat +0 -0
  1786. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment3.wat.err +0 -0
  1787. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment4.wat +0 -0
  1788. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment4.wat.err +0 -0
  1789. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment5.wat +0 -0
  1790. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment5.wat.err +0 -0
  1791. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment6.wat +0 -0
  1792. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment6.wat.err +0 -0
  1793. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment7.wat +0 -0
  1794. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment7.wat.err +0 -0
  1795. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment8.wat +0 -0
  1796. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-line-comment8.wat.err +0 -0
  1797. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string0.wat +0 -0
  1798. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string0.wat.err +0 -0
  1799. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string1.wat +0 -0
  1800. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string1.wat.err +0 -0
  1801. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string2.wat +0 -0
  1802. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string2.wat.err +0 -0
  1803. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string3.wat +0 -0
  1804. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string3.wat.err +0 -0
  1805. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string4.wat +0 -0
  1806. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string4.wat.err +0 -0
  1807. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string5.wat +0 -0
  1808. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string5.wat.err +0 -0
  1809. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string6.wat +0 -0
  1810. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string6.wat.err +0 -0
  1811. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string7.wat +0 -0
  1812. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string7.wat.err +0 -0
  1813. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string8.wat +0 -0
  1814. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/confusing-string8.wat.err +0 -0
  1815. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/inline1.wat +0 -0
  1816. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/inline1.wat.err +0 -0
  1817. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/newline-in-string.wat +0 -0
  1818. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/newline-in-string.wat.err +0 -0
  1819. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string1.wat +0 -0
  1820. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string1.wat.err +0 -0
  1821. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string10.wat +0 -0
  1822. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string10.wat.err +0 -0
  1823. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string11.wat +0 -0
  1824. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string11.wat.err +0 -0
  1825. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string12.wat +0 -0
  1826. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string12.wat.err +0 -0
  1827. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string13.wat +0 -0
  1828. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string13.wat.err +0 -0
  1829. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string14.wat +0 -0
  1830. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string14.wat.err +0 -0
  1831. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string15.wat +0 -0
  1832. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string15.wat.err +0 -0
  1833. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string16.wat +0 -0
  1834. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string16.wat.err +0 -0
  1835. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string2.wat +0 -0
  1836. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string2.wat.err +0 -0
  1837. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string3.wat +0 -0
  1838. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string3.wat.err +0 -0
  1839. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string4.wat +0 -0
  1840. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string4.wat.err +0 -0
  1841. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string5.wat +0 -0
  1842. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string5.wat.err +0 -0
  1843. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string6.wat +0 -0
  1844. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string6.wat.err +0 -0
  1845. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string7.wat +0 -0
  1846. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string7.wat.err +0 -0
  1847. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string8.wat +0 -0
  1848. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string8.wat.err +0 -0
  1849. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string9.wat +0 -0
  1850. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/string9.wat.err +0 -0
  1851. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/unbalanced.wat +0 -0
  1852. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/parse-fail/unbalanced.wat.err +0 -0
  1853. /data/ext/cargo-vendor/{wast-201.0.0 → wast-208.0.1}/tests/recursive.rs +0 -0
  1854. /data/ext/cargo-vendor/{wiggle-19.0.2 → wat-1.208.1}/LICENSE +0 -0
  1855. /data/ext/cargo-vendor/{wat-1.201.0 → wat-1.208.1}/README.md +0 -0
  1856. /data/ext/cargo-vendor/{wat-1.201.0 → wat-1.208.1}/src/lib.rs +0 -0
  1857. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-20.0.0}/LICENSE +0 -0
  1858. /data/ext/cargo-vendor/{wiggle-19.0.2 → wiggle-20.0.0}/README.md +0 -0
  1859. /data/ext/cargo-vendor/{wiggle-19.0.2 → wiggle-20.0.0}/src/error.rs +0 -0
  1860. /data/ext/cargo-vendor/{wiggle-19.0.2 → wiggle-20.0.0}/src/region.rs +0 -0
  1861. /data/ext/cargo-vendor/{wiggle-macro-19.0.2 → wiggle-generate-20.0.0}/LICENSE +0 -0
  1862. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/README.md +0 -0
  1863. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/codegen_settings.rs +0 -0
  1864. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/config.rs +0 -0
  1865. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/funcs.rs +0 -0
  1866. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/lib.rs +0 -0
  1867. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/lifetimes.rs +0 -0
  1868. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/module_trait.rs +0 -0
  1869. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/names.rs +0 -0
  1870. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/types/error.rs +0 -0
  1871. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/types/flags.rs +0 -0
  1872. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/types/handle.rs +0 -0
  1873. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/types/mod.rs +0 -0
  1874. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/types/record.rs +0 -0
  1875. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/types/variant.rs +0 -0
  1876. /data/ext/cargo-vendor/{wiggle-generate-19.0.2 → wiggle-generate-20.0.0}/src/wasmtime.rs +0 -0
  1877. /data/ext/cargo-vendor/{wiggle-macro-19.0.2 → wiggle-macro-20.0.0}/src/lib.rs +0 -0
  1878. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/LICENSE +0 -0
  1879. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/build.rs +0 -0
  1880. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/abi/local.rs +0 -0
  1881. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/codegen/context.rs +0 -0
  1882. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/codegen/control.rs +0 -0
  1883. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/frame/mod.rs +0 -0
  1884. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/isa/aarch64/address.rs +0 -0
  1885. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/isa/reg.rs +0 -0
  1886. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/isa/x64/address.rs +0 -0
  1887. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/isa/x64/regs.rs +0 -0
  1888. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/regalloc.rs +0 -0
  1889. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/regset.rs +0 -0
  1890. /data/ext/cargo-vendor/{winch-codegen-0.17.2 → winch-codegen-0.18.0}/src/stack.rs +0 -0
  1891. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/README.md +0 -0
  1892. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/src/ast/toposort.rs +0 -0
  1893. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/src/docs.rs +0 -0
  1894. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/src/live.rs +0 -0
  1895. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/comments.wit +0 -0
  1896. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/comments.wit.json +0 -0
  1897. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/complex-include/deps/bar/root.wit +0 -0
  1898. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/complex-include/deps/baz/root.wit +0 -0
  1899. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/complex-include/root.wit +0 -0
  1900. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/complex-include.wit.json +0 -0
  1901. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/cross-package-resource/deps/foo/foo.wit +0 -0
  1902. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/cross-package-resource/foo.wit +0 -0
  1903. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/cross-package-resource.wit.json +0 -0
  1904. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/diamond1/deps/dep1/types.wit +0 -0
  1905. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/diamond1/deps/dep2/types.wit +0 -0
  1906. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/diamond1/join.wit +0 -0
  1907. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/diamond1.wit.json +0 -0
  1908. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/disambiguate-diamond/shared1.wit +0 -0
  1909. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/disambiguate-diamond/shared2.wit +0 -0
  1910. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/disambiguate-diamond/world.wit +0 -0
  1911. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/disambiguate-diamond.wit.json +0 -0
  1912. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/empty.wit +0 -0
  1913. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/empty.wit.json +0 -0
  1914. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +0 -0
  1915. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/deps/corp/saas.wit +0 -0
  1916. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +0 -0
  1917. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +0 -0
  1918. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +0 -0
  1919. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/deps/wasi/clocks.wit +0 -0
  1920. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/deps/wasi/filesystem.wit +0 -0
  1921. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps/root.wit +0 -0
  1922. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/another-pkg/other-doc.wit +0 -0
  1923. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/corp/saas.wit +0 -0
  1924. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/different-pkg/the-doc.wit +0 -0
  1925. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/foreign-pkg/the-doc.wit +0 -0
  1926. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/some-pkg/some-doc.wit +0 -0
  1927. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/wasi/clocks.wit +0 -0
  1928. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/wasi/filesystem.wit +0 -0
  1929. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/deps/wasi/wasi.wit +0 -0
  1930. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union/root.wit +0 -0
  1931. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps-union.wit.json +0 -0
  1932. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/foreign-deps.wit.json +0 -0
  1933. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/ignore-files-deps/deps/bar/types.wit +0 -0
  1934. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/ignore-files-deps/deps/ignore-me.txt +0 -0
  1935. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/ignore-files-deps/world.wit +0 -0
  1936. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/ignore-files-deps.wit.json +0 -0
  1937. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/import-export-overlap1.wit +0 -0
  1938. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/import-export-overlap1.wit.json +0 -0
  1939. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/import-export-overlap2.wit +0 -0
  1940. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/import-export-overlap2.wit.json +0 -0
  1941. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/include-reps.wit +0 -0
  1942. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/include-reps.wit.json +0 -0
  1943. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kebab-name-include-with.wit +0 -0
  1944. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kebab-name-include-with.wit.json +0 -0
  1945. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kinds-of-deps/a.wit +0 -0
  1946. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kinds-of-deps/deps/b/root.wit +0 -0
  1947. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kinds-of-deps/deps/c.wit +0 -0
  1948. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kinds-of-deps/deps/d.wat +0 -0
  1949. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kinds-of-deps/deps/e.wasm +0 -0
  1950. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/kinds-of-deps.wit.json +0 -0
  1951. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/many-names/a.wit +0 -0
  1952. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/many-names/b.wit +0 -0
  1953. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/many-names.wit.json +0 -0
  1954. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/multi-file/bar.wit +0 -0
  1955. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/multi-file/cycle-a.wit +0 -0
  1956. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/multi-file/cycle-b.wit +0 -0
  1957. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/multi-file/foo.wit +0 -0
  1958. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/multi-file.wit.json +0 -0
  1959. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/name-both-resource-and-type/deps/dep/foo.wit +0 -0
  1960. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/name-both-resource-and-type/foo.wit +0 -0
  1961. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/name-both-resource-and-type.wit.json +0 -0
  1962. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/package-syntax1.wit +0 -0
  1963. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/package-syntax1.wit.json +0 -0
  1964. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/package-syntax3.wit +0 -0
  1965. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/package-syntax3.wit.json +0 -0
  1966. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/package-syntax4.wit +0 -0
  1967. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/package-syntax4.wit.json +0 -0
  1968. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/alias-no-type.wit +0 -0
  1969. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/alias-no-type.wit.result +0 -0
  1970. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/async.wit.result +0 -0
  1971. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/async1.wit.result +0 -0
  1972. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-function.wit +0 -0
  1973. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-function.wit.result +0 -0
  1974. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-function2.wit +0 -0
  1975. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-function2.wit.result +0 -0
  1976. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-include1.wit +0 -0
  1977. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-include1.wit.result +0 -0
  1978. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-include2.wit +0 -0
  1979. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-include2.wit.result +0 -0
  1980. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-include3.wit +0 -0
  1981. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-include3.wit.result +0 -0
  1982. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-list.wit +0 -0
  1983. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-list.wit.result +0 -0
  1984. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg1/root.wit +0 -0
  1985. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg1.wit.result +0 -0
  1986. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg2/deps/bar/empty.wit +0 -0
  1987. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg2/root.wit +0 -0
  1988. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg2.wit.result +0 -0
  1989. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +0 -0
  1990. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg3/root.wit +0 -0
  1991. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg3.wit.result +0 -0
  1992. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +0 -0
  1993. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg4/root.wit +0 -0
  1994. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg4.wit.result +0 -0
  1995. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +0 -0
  1996. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg5/root.wit +0 -0
  1997. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg5.wit.result +0 -0
  1998. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +0 -0
  1999. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg6/root.wit +0 -0
  2000. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-pkg6.wit.result +0 -0
  2001. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource1.wit +0 -0
  2002. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource1.wit.result +0 -0
  2003. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource10.wit +0 -0
  2004. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource10.wit.result +0 -0
  2005. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource11.wit +0 -0
  2006. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource11.wit.result +0 -0
  2007. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource12.wit +0 -0
  2008. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource12.wit.result +0 -0
  2009. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource13.wit +0 -0
  2010. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource13.wit.result +0 -0
  2011. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource14.wit +0 -0
  2012. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource14.wit.result +0 -0
  2013. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource15/deps/foo/foo.wit +0 -0
  2014. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource15/foo.wit +0 -0
  2015. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource15.wit.result +0 -0
  2016. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource2.wit +0 -0
  2017. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource2.wit.result +0 -0
  2018. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource3.wit +0 -0
  2019. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource3.wit.result +0 -0
  2020. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource4.wit +0 -0
  2021. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource4.wit.result +0 -0
  2022. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource5.wit +0 -0
  2023. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource5.wit.result +0 -0
  2024. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource6.wit +0 -0
  2025. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource6.wit.result +0 -0
  2026. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource7.wit +0 -0
  2027. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource7.wit.result +0 -0
  2028. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource8.wit +0 -0
  2029. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource8.wit.result +0 -0
  2030. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource9.wit +0 -0
  2031. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-resource9.wit.result +0 -0
  2032. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-world-type1.wit +0 -0
  2033. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/bad-world-type1.wit.result +0 -0
  2034. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/conflicting-package/a.wit +0 -0
  2035. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/conflicting-package/b.wit +0 -0
  2036. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/conflicting-package.wit.result +0 -0
  2037. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle.wit +0 -0
  2038. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle.wit.result +0 -0
  2039. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle2.wit +0 -0
  2040. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle2.wit.result +0 -0
  2041. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle3.wit +0 -0
  2042. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle3.wit.result +0 -0
  2043. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle4.wit +0 -0
  2044. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle4.wit.result +0 -0
  2045. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle5.wit +0 -0
  2046. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/cycle5.wit.result +0 -0
  2047. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/dangling-type.wit +0 -0
  2048. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/dangling-type.wit.result +0 -0
  2049. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-function-params.wit +0 -0
  2050. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-function-params.wit.result +0 -0
  2051. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-functions.wit +0 -0
  2052. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-functions.wit.result +0 -0
  2053. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-interface.wit +0 -0
  2054. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-interface.wit.result +0 -0
  2055. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-interface2/foo.wit +0 -0
  2056. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-interface2/foo2.wit +0 -0
  2057. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-interface2.wit.result +0 -0
  2058. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-type.wit +0 -0
  2059. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/duplicate-type.wit.result +0 -0
  2060. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/empty-enum.wit +0 -0
  2061. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/empty-enum.wit.result +0 -0
  2062. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/empty-variant1.wit +0 -0
  2063. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/empty-variant1.wit.result +0 -0
  2064. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/export-twice.wit +0 -0
  2065. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/export-twice.wit.result +0 -0
  2066. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export1.wit +0 -0
  2067. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export1.wit.result +0 -0
  2068. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export2.wit +0 -0
  2069. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export2.wit.result +0 -0
  2070. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export3.wit +0 -0
  2071. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export3.wit.result +0 -0
  2072. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export4.wit +0 -0
  2073. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export4.wit.result +0 -0
  2074. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export5.wit +0 -0
  2075. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-and-export5.wit.result +0 -0
  2076. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-twice.wit +0 -0
  2077. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/import-twice.wit.result +0 -0
  2078. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-cycle.wit +0 -0
  2079. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-cycle.wit.result +0 -0
  2080. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-foreign/deps/bar/empty.wit +0 -0
  2081. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-foreign/root.wit +0 -0
  2082. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-foreign.wit.result +0 -0
  2083. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-with-id.wit +0 -0
  2084. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-with-id.wit.result +0 -0
  2085. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-with-on-id.wit +0 -0
  2086. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/include-with-on-id.wit.result +0 -0
  2087. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/invalid-toplevel.wit +0 -0
  2088. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/invalid-toplevel.wit.result +0 -0
  2089. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/invalid-type-reference.wit +0 -0
  2090. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/invalid-type-reference.wit.result +0 -0
  2091. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/invalid-type-reference2.wit +0 -0
  2092. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/invalid-type-reference2.wit.result +0 -0
  2093. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit +0 -0
  2094. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit.result +0 -0
  2095. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/kebab-name-include.wit +0 -0
  2096. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/kebab-name-include.wit.result +0 -0
  2097. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/keyword.wit +0 -0
  2098. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/keyword.wit.result +0 -0
  2099. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/missing-package.wit +0 -0
  2100. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/missing-package.wit.result +0 -0
  2101. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/multiple-package-docs/a.wit +0 -0
  2102. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/multiple-package-docs/b.wit +0 -0
  2103. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/multiple-package-docs.wit.result +0 -0
  2104. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/no-access-to-sibling-use/bar.wit +0 -0
  2105. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/no-access-to-sibling-use/foo.wit +0 -0
  2106. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +0 -0
  2107. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/non-existance-world-include/deps/bar/baz.wit +0 -0
  2108. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/non-existance-world-include/root.wit +0 -0
  2109. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/non-existance-world-include.wit.result +0 -0
  2110. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +0 -0
  2111. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/pkg-cycle/root.wit +0 -0
  2112. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/pkg-cycle.wit.result +0 -0
  2113. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +0 -0
  2114. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +0 -0
  2115. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/pkg-cycle2/root.wit +0 -0
  2116. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/pkg-cycle2.wit.result +0 -0
  2117. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/type-and-resource-same-name/deps/dep/foo.wit +0 -0
  2118. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/type-and-resource-same-name/foo.wit +0 -0
  2119. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/type-and-resource-same-name.wit.result +0 -0
  2120. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/undefined-typed.wit +0 -0
  2121. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/undefined-typed.wit.result +0 -0
  2122. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unknown-interface.wit +0 -0
  2123. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unknown-interface.wit.result +0 -0
  2124. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface1.wit +0 -0
  2125. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface1.wit.result +0 -0
  2126. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface2.wit +0 -0
  2127. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface2.wit.result +0 -0
  2128. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface3.wit +0 -0
  2129. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface3.wit.result +0 -0
  2130. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface4.wit +0 -0
  2131. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-interface4.wit.result +0 -0
  2132. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use1.wit +0 -0
  2133. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use1.wit.result +0 -0
  2134. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use10/bar.wit +0 -0
  2135. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use10/foo.wit +0 -0
  2136. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use10.wit.result +0 -0
  2137. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use2.wit +0 -0
  2138. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use2.wit.result +0 -0
  2139. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use3.wit +0 -0
  2140. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use3.wit.result +0 -0
  2141. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use7.wit +0 -0
  2142. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use7.wit.result +0 -0
  2143. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use8.wit +0 -0
  2144. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use8.wit.result +0 -0
  2145. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use9.wit +0 -0
  2146. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unresolved-use9.wit.result +0 -0
  2147. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/unterminated-string.wit.result +0 -0
  2148. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-and-include-world/deps/bar/baz.wit +0 -0
  2149. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-and-include-world/root.wit +0 -0
  2150. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-and-include-world.wit.result +0 -0
  2151. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-conflict.wit +0 -0
  2152. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-conflict.wit.result +0 -0
  2153. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-conflict2.wit +0 -0
  2154. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-conflict2.wit.result +0 -0
  2155. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-conflict3.wit +0 -0
  2156. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-conflict3.wit.result +0 -0
  2157. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-cycle1.wit +0 -0
  2158. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-cycle1.wit.result +0 -0
  2159. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-cycle4.wit +0 -0
  2160. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-cycle4.wit.result +0 -0
  2161. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-shadow1.wit +0 -0
  2162. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-shadow1.wit.result +0 -0
  2163. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-world/deps/bar/baz.wit +0 -0
  2164. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-world/root.wit +0 -0
  2165. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/use-world.wit.result +0 -0
  2166. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-interface-clash.wit +0 -0
  2167. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-interface-clash.wit.result +0 -0
  2168. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-same-fields2.wit +0 -0
  2169. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-same-fields2.wit.result +0 -0
  2170. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-same-fields3.wit +0 -0
  2171. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-same-fields3.wit.result +0 -0
  2172. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-top-level-func.wit +0 -0
  2173. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-top-level-func.wit.result +0 -0
  2174. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-top-level-func2.wit +0 -0
  2175. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/parse-fail/world-top-level-func2.wit.result +0 -0
  2176. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/random.wit +0 -0
  2177. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/random.wit.json +0 -0
  2178. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-empty.wit +0 -0
  2179. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-empty.wit.json +0 -0
  2180. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-multiple-returns-borrow.wit +0 -0
  2181. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-multiple-returns-borrow.wit.json +0 -0
  2182. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-multiple-returns-own.wit +0 -0
  2183. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-multiple-returns-own.wit.json +0 -0
  2184. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-return-borrow.wit +0 -0
  2185. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-return-borrow.wit.json +0 -0
  2186. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-return-own.wit +0 -0
  2187. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources-return-own.wit.json +0 -0
  2188. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources.wit +0 -0
  2189. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources.wit.json +0 -0
  2190. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources1.wit +0 -0
  2191. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/resources1.wit.json +0 -0
  2192. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/same-name-import-export.wit +0 -0
  2193. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/same-name-import-export.wit.json +0 -0
  2194. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/shared-types.wit +0 -0
  2195. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/shared-types.wit.json +0 -0
  2196. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/simple-wasm-text.wat +0 -0
  2197. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/simple-wasm-text.wit.json +0 -0
  2198. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/stress-export-elaborate.wit +0 -0
  2199. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/stress-export-elaborate.wit.json +0 -0
  2200. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/type-then-eof.wit +0 -0
  2201. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/type-then-eof.wit.json +0 -0
  2202. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/union-fuzz-1.wit +0 -0
  2203. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/union-fuzz-1.wit.json +0 -0
  2204. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/use-chain.wit +0 -0
  2205. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/use-chain.wit.json +0 -0
  2206. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/use.wit +0 -0
  2207. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/use.wit.json +0 -0
  2208. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/versions/deps/a1/foo.wit +0 -0
  2209. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/versions/deps/a2/foo.wit +0 -0
  2210. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/versions/foo.wit +0 -0
  2211. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/versions.wit.json +0 -0
  2212. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/wasi.wit.json +0 -0
  2213. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-diamond.wit +0 -0
  2214. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-diamond.wit.json +0 -0
  2215. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-iface-no-collide.wit +0 -0
  2216. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-iface-no-collide.wit.json +0 -0
  2217. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-implicit-import1.wit +0 -0
  2218. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-implicit-import1.wit.json +0 -0
  2219. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-implicit-import2.wit +0 -0
  2220. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-implicit-import2.wit.json +0 -0
  2221. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-implicit-import3.wit +0 -0
  2222. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-implicit-import3.wit.json +0 -0
  2223. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-same-fields4.wit +0 -0
  2224. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-same-fields4.wit.json +0 -0
  2225. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-top-level-funcs.wit +0 -0
  2226. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-top-level-funcs.wit.json +0 -0
  2227. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-top-level-resources.wit +0 -0
  2228. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/world-top-level-resources.wit.json +0 -0
  2229. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/worlds-union-dedup.wit +0 -0
  2230. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/worlds-union-dedup.wit.json +0 -0
  2231. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/worlds-with-types.wit +0 -0
  2232. /data/ext/cargo-vendor/{wit-parser-0.201.0 → wit-parser-0.202.0}/tests/ui/worlds-with-types.wit.json +0 -0
@@ -0,0 +1,3646 @@
1
+ //! S390x ISA: binary code emission.
2
+
3
+ use crate::binemit::StackMap;
4
+ use crate::ir::{MemFlags, TrapCode};
5
+ use crate::isa::s390x::inst::*;
6
+ use crate::isa::s390x::settings as s390x_settings;
7
+ use crate::trace;
8
+ use cranelift_control::ControlPlane;
9
+ use regalloc2::Allocation;
10
+
11
+ /// Debug macro for testing that a regpair is valid: that the high register is even, and the low
12
+ /// register is one higher than the high register.
13
+ macro_rules! debug_assert_valid_regpair {
14
+ ($hi:expr, $lo:expr) => {
15
+ if cfg!(debug_assertions) {
16
+ match ($hi.to_real_reg(), $lo.to_real_reg()) {
17
+ (Some(hi), Some(lo)) => {
18
+ assert!(
19
+ hi.hw_enc() % 2 == 0,
20
+ "High register is not even: {}",
21
+ show_reg($hi)
22
+ );
23
+ assert_eq!(
24
+ hi.hw_enc() + 1,
25
+ lo.hw_enc(),
26
+ "Low register is not valid: {}, {}",
27
+ show_reg($hi),
28
+ show_reg($lo)
29
+ );
30
+ }
31
+
32
+ _ => {
33
+ panic!(
34
+ "Expected real registers for {} {}",
35
+ show_reg($hi),
36
+ show_reg($lo)
37
+ );
38
+ }
39
+ }
40
+ }
41
+ };
42
+ }
43
+
44
+ /// Type(s) of memory instructions available for mem_finalize.
45
+ pub struct MemInstType {
46
+ /// True if 12-bit unsigned displacement is supported.
47
+ pub have_d12: bool,
48
+ /// True if 20-bit signed displacement is supported.
49
+ pub have_d20: bool,
50
+ /// True if PC-relative addressing is supported (memory access).
51
+ pub have_pcrel: bool,
52
+ /// True if PC-relative addressing is supported (load address).
53
+ pub have_unaligned_pcrel: bool,
54
+ /// True if an index register is supported.
55
+ pub have_index: bool,
56
+ }
57
+
58
+ /// Memory addressing mode finalization: convert "special" modes (e.g.,
59
+ /// generic arbitrary stack offset) into real addressing modes, possibly by
60
+ /// emitting some helper instructions that come immediately before the use
61
+ /// of this amode.
62
+ pub fn mem_finalize(
63
+ mem: &MemArg,
64
+ state: &EmitState,
65
+ mi: MemInstType,
66
+ ) -> (SmallVec<[Inst; 4]>, MemArg) {
67
+ let mut insts = SmallVec::new();
68
+
69
+ // Resolve virtual addressing modes.
70
+ let mem = match mem {
71
+ &MemArg::RegOffset { off, .. }
72
+ | &MemArg::InitialSPOffset { off }
73
+ | &MemArg::NominalSPOffset { off } => {
74
+ let base = match mem {
75
+ &MemArg::RegOffset { reg, .. } => reg,
76
+ &MemArg::InitialSPOffset { .. } | &MemArg::NominalSPOffset { .. } => stack_reg(),
77
+ _ => unreachable!(),
78
+ };
79
+ let adj = match mem {
80
+ &MemArg::InitialSPOffset { .. } => {
81
+ state.initial_sp_offset + state.virtual_sp_offset
82
+ }
83
+ &MemArg::NominalSPOffset { .. } => state.virtual_sp_offset,
84
+ _ => 0,
85
+ };
86
+ let off = off + adj;
87
+
88
+ if let Some(disp) = UImm12::maybe_from_u64(off as u64) {
89
+ MemArg::BXD12 {
90
+ base,
91
+ index: zero_reg(),
92
+ disp,
93
+ flags: mem.get_flags(),
94
+ }
95
+ } else if let Some(disp) = SImm20::maybe_from_i64(off) {
96
+ MemArg::BXD20 {
97
+ base,
98
+ index: zero_reg(),
99
+ disp,
100
+ flags: mem.get_flags(),
101
+ }
102
+ } else {
103
+ let tmp = writable_spilltmp_reg();
104
+ assert!(base != tmp.to_reg());
105
+ if let Ok(imm) = i16::try_from(off) {
106
+ insts.push(Inst::Mov64SImm16 { rd: tmp, imm });
107
+ } else if let Ok(imm) = i32::try_from(off) {
108
+ insts.push(Inst::Mov64SImm32 { rd: tmp, imm });
109
+ } else {
110
+ // The offset must be smaller than the stack frame size,
111
+ // which the ABI code limits to 128 MB.
112
+ unreachable!();
113
+ }
114
+ MemArg::reg_plus_reg(base, tmp.to_reg(), mem.get_flags())
115
+ }
116
+ }
117
+ _ => mem.clone(),
118
+ };
119
+
120
+ // If this addressing mode cannot be handled by the instruction, use load-address.
121
+ let need_load_address = match &mem {
122
+ &MemArg::Label { .. } | &MemArg::Symbol { .. } if !mi.have_pcrel => true,
123
+ &MemArg::Symbol { flags, .. } if !mi.have_unaligned_pcrel && !flags.aligned() => true,
124
+ &MemArg::BXD20 { .. } if !mi.have_d20 => true,
125
+ &MemArg::BXD12 { index, .. } | &MemArg::BXD20 { index, .. } if !mi.have_index => {
126
+ index != zero_reg()
127
+ }
128
+ _ => false,
129
+ };
130
+ let mem = if need_load_address {
131
+ let flags = mem.get_flags();
132
+ let tmp = writable_spilltmp_reg();
133
+ insts.push(Inst::LoadAddr { rd: tmp, mem });
134
+ MemArg::reg(tmp.to_reg(), flags)
135
+ } else {
136
+ mem
137
+ };
138
+
139
+ // Convert 12-bit displacement to 20-bit if required.
140
+ let mem = match &mem {
141
+ &MemArg::BXD12 {
142
+ base,
143
+ index,
144
+ disp,
145
+ flags,
146
+ } if !mi.have_d12 => {
147
+ assert!(mi.have_d20);
148
+ MemArg::BXD20 {
149
+ base,
150
+ index,
151
+ disp: SImm20::from_uimm12(disp),
152
+ flags,
153
+ }
154
+ }
155
+ _ => mem,
156
+ };
157
+
158
+ (insts, mem)
159
+ }
160
+
161
+ pub fn mem_emit(
162
+ rd: Reg,
163
+ mem: &MemArg,
164
+ opcode_rx: Option<u16>,
165
+ opcode_rxy: Option<u16>,
166
+ opcode_ril: Option<u16>,
167
+ add_trap: bool,
168
+ sink: &mut MachBuffer<Inst>,
169
+ emit_info: &EmitInfo,
170
+ state: &mut EmitState,
171
+ ) {
172
+ let (mem_insts, mem) = mem_finalize(
173
+ mem,
174
+ state,
175
+ MemInstType {
176
+ have_d12: opcode_rx.is_some(),
177
+ have_d20: opcode_rxy.is_some(),
178
+ have_pcrel: opcode_ril.is_some(),
179
+ have_unaligned_pcrel: opcode_ril.is_some() && !add_trap,
180
+ have_index: true,
181
+ },
182
+ );
183
+ for inst in mem_insts.into_iter() {
184
+ inst.emit(&[], sink, emit_info, state);
185
+ }
186
+
187
+ if add_trap {
188
+ if let Some(trap_code) = mem.get_flags().trap_code() {
189
+ sink.add_trap(trap_code);
190
+ }
191
+ }
192
+
193
+ match &mem {
194
+ &MemArg::BXD12 {
195
+ base, index, disp, ..
196
+ } => {
197
+ put(
198
+ sink,
199
+ &enc_rx(opcode_rx.unwrap(), rd, base, index, disp.bits()),
200
+ );
201
+ }
202
+ &MemArg::BXD20 {
203
+ base, index, disp, ..
204
+ } => {
205
+ put(
206
+ sink,
207
+ &enc_rxy(opcode_rxy.unwrap(), rd, base, index, disp.bits()),
208
+ );
209
+ }
210
+ &MemArg::Label { target } => {
211
+ sink.use_label_at_offset(sink.cur_offset(), target, LabelUse::BranchRIL);
212
+ put(sink, &enc_ril_b(opcode_ril.unwrap(), rd, 0));
213
+ }
214
+ &MemArg::Symbol {
215
+ ref name, offset, ..
216
+ } => {
217
+ sink.add_reloc_at_offset(2, Reloc::S390xPCRel32Dbl, &**name, (offset + 2).into());
218
+ put(sink, &enc_ril_b(opcode_ril.unwrap(), rd, 0));
219
+ }
220
+ _ => unreachable!(),
221
+ }
222
+ }
223
+
224
+ pub fn mem_rs_emit(
225
+ rd: Reg,
226
+ rn: Reg,
227
+ mem: &MemArg,
228
+ opcode_rs: Option<u16>,
229
+ opcode_rsy: Option<u16>,
230
+ add_trap: bool,
231
+ sink: &mut MachBuffer<Inst>,
232
+ emit_info: &EmitInfo,
233
+ state: &mut EmitState,
234
+ ) {
235
+ let (mem_insts, mem) = mem_finalize(
236
+ mem,
237
+ state,
238
+ MemInstType {
239
+ have_d12: opcode_rs.is_some(),
240
+ have_d20: opcode_rsy.is_some(),
241
+ have_pcrel: false,
242
+ have_unaligned_pcrel: false,
243
+ have_index: false,
244
+ },
245
+ );
246
+ for inst in mem_insts.into_iter() {
247
+ inst.emit(&[], sink, emit_info, state);
248
+ }
249
+
250
+ if add_trap {
251
+ if let Some(trap_code) = mem.get_flags().trap_code() {
252
+ sink.add_trap(trap_code);
253
+ }
254
+ }
255
+
256
+ match &mem {
257
+ &MemArg::BXD12 {
258
+ base, index, disp, ..
259
+ } => {
260
+ assert!(index == zero_reg());
261
+ put(sink, &enc_rs(opcode_rs.unwrap(), rd, rn, base, disp.bits()));
262
+ }
263
+ &MemArg::BXD20 {
264
+ base, index, disp, ..
265
+ } => {
266
+ assert!(index == zero_reg());
267
+ put(
268
+ sink,
269
+ &enc_rsy(opcode_rsy.unwrap(), rd, rn, base, disp.bits()),
270
+ );
271
+ }
272
+ _ => unreachable!(),
273
+ }
274
+ }
275
+
276
+ pub fn mem_imm8_emit(
277
+ imm: u8,
278
+ mem: &MemArg,
279
+ opcode_si: u16,
280
+ opcode_siy: u16,
281
+ add_trap: bool,
282
+ sink: &mut MachBuffer<Inst>,
283
+ emit_info: &EmitInfo,
284
+ state: &mut EmitState,
285
+ ) {
286
+ let (mem_insts, mem) = mem_finalize(
287
+ mem,
288
+ state,
289
+ MemInstType {
290
+ have_d12: true,
291
+ have_d20: true,
292
+ have_pcrel: false,
293
+ have_unaligned_pcrel: false,
294
+ have_index: false,
295
+ },
296
+ );
297
+ for inst in mem_insts.into_iter() {
298
+ inst.emit(&[], sink, emit_info, state);
299
+ }
300
+
301
+ if add_trap {
302
+ if let Some(trap_code) = mem.get_flags().trap_code() {
303
+ sink.add_trap(trap_code);
304
+ }
305
+ }
306
+
307
+ match &mem {
308
+ &MemArg::BXD12 {
309
+ base, index, disp, ..
310
+ } => {
311
+ assert!(index == zero_reg());
312
+ put(sink, &enc_si(opcode_si, base, disp.bits(), imm));
313
+ }
314
+ &MemArg::BXD20 {
315
+ base, index, disp, ..
316
+ } => {
317
+ assert!(index == zero_reg());
318
+ put(sink, &enc_siy(opcode_siy, base, disp.bits(), imm));
319
+ }
320
+ _ => unreachable!(),
321
+ }
322
+ }
323
+
324
+ pub fn mem_imm16_emit(
325
+ imm: i16,
326
+ mem: &MemArg,
327
+ opcode_sil: u16,
328
+ add_trap: bool,
329
+ sink: &mut MachBuffer<Inst>,
330
+ emit_info: &EmitInfo,
331
+ state: &mut EmitState,
332
+ ) {
333
+ let (mem_insts, mem) = mem_finalize(
334
+ mem,
335
+ state,
336
+ MemInstType {
337
+ have_d12: true,
338
+ have_d20: false,
339
+ have_pcrel: false,
340
+ have_unaligned_pcrel: false,
341
+ have_index: false,
342
+ },
343
+ );
344
+ for inst in mem_insts.into_iter() {
345
+ inst.emit(&[], sink, emit_info, state);
346
+ }
347
+
348
+ if add_trap {
349
+ if let Some(trap_code) = mem.get_flags().trap_code() {
350
+ sink.add_trap(trap_code);
351
+ }
352
+ }
353
+
354
+ match &mem {
355
+ &MemArg::BXD12 {
356
+ base, index, disp, ..
357
+ } => {
358
+ assert!(index == zero_reg());
359
+ put(sink, &enc_sil(opcode_sil, base, disp.bits(), imm));
360
+ }
361
+ _ => unreachable!(),
362
+ }
363
+ }
364
+
365
+ pub fn mem_mem_emit(
366
+ dst: &MemArgPair,
367
+ src: &MemArgPair,
368
+ len_minus_one: u8,
369
+ opcode_ss: u8,
370
+ add_trap: bool,
371
+ sink: &mut MachBuffer<Inst>,
372
+ _state: &mut EmitState,
373
+ ) {
374
+ if add_trap {
375
+ if let Some(trap_code) = dst.flags.trap_code().or(src.flags.trap_code()) {
376
+ sink.add_trap(trap_code);
377
+ }
378
+ }
379
+
380
+ put(
381
+ sink,
382
+ &enc_ss_a(
383
+ opcode_ss,
384
+ dst.base,
385
+ dst.disp.bits(),
386
+ src.base,
387
+ src.disp.bits(),
388
+ len_minus_one,
389
+ ),
390
+ );
391
+ }
392
+
393
+ pub fn mem_vrx_emit(
394
+ rd: Reg,
395
+ mem: &MemArg,
396
+ opcode: u16,
397
+ m3: u8,
398
+ add_trap: bool,
399
+ sink: &mut MachBuffer<Inst>,
400
+ emit_info: &EmitInfo,
401
+ state: &mut EmitState,
402
+ ) {
403
+ let (mem_insts, mem) = mem_finalize(
404
+ mem,
405
+ state,
406
+ MemInstType {
407
+ have_d12: true,
408
+ have_d20: false,
409
+ have_pcrel: false,
410
+ have_unaligned_pcrel: false,
411
+ have_index: true,
412
+ },
413
+ );
414
+ for inst in mem_insts.into_iter() {
415
+ inst.emit(&[], sink, emit_info, state);
416
+ }
417
+
418
+ if add_trap {
419
+ if let Some(trap_code) = mem.get_flags().trap_code() {
420
+ sink.add_trap(trap_code);
421
+ }
422
+ }
423
+
424
+ match &mem {
425
+ &MemArg::BXD12 {
426
+ base, index, disp, ..
427
+ } => {
428
+ put(sink, &enc_vrx(opcode, rd, base, index, disp.bits(), m3));
429
+ }
430
+ _ => unreachable!(),
431
+ }
432
+ }
433
+
434
+ //=============================================================================
435
+ // Instructions and subcomponents: emission
436
+
437
+ fn machreg_to_gpr(m: Reg) -> u8 {
438
+ assert_eq!(m.class(), RegClass::Int);
439
+ u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap()
440
+ }
441
+
442
+ fn machreg_to_vr(m: Reg) -> u8 {
443
+ assert_eq!(m.class(), RegClass::Float);
444
+ u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap()
445
+ }
446
+
447
+ fn machreg_to_fpr(m: Reg) -> u8 {
448
+ assert!(is_fpr(m));
449
+ u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap()
450
+ }
451
+
452
+ fn machreg_to_gpr_or_fpr(m: Reg) -> u8 {
453
+ let reg = u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap();
454
+ assert!(reg < 16);
455
+ reg
456
+ }
457
+
458
+ fn rxb(v1: Option<Reg>, v2: Option<Reg>, v3: Option<Reg>, v4: Option<Reg>) -> u8 {
459
+ let mut rxb = 0;
460
+
461
+ let is_high_vr = |reg| -> bool {
462
+ if let Some(reg) = reg {
463
+ if !is_fpr(reg) {
464
+ return true;
465
+ }
466
+ }
467
+ false
468
+ };
469
+
470
+ if is_high_vr(v1) {
471
+ rxb = rxb | 8;
472
+ }
473
+ if is_high_vr(v2) {
474
+ rxb = rxb | 4;
475
+ }
476
+ if is_high_vr(v3) {
477
+ rxb = rxb | 2;
478
+ }
479
+ if is_high_vr(v4) {
480
+ rxb = rxb | 1;
481
+ }
482
+
483
+ rxb
484
+ }
485
+
486
+ /// E-type instructions.
487
+ ///
488
+ /// 15
489
+ /// opcode
490
+ /// 0
491
+ ///
492
+ fn enc_e(opcode: u16) -> [u8; 2] {
493
+ let mut enc: [u8; 2] = [0; 2];
494
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
495
+ let opcode2 = (opcode & 0xff) as u8;
496
+
497
+ enc[0] = opcode1;
498
+ enc[1] = opcode2;
499
+ enc
500
+ }
501
+
502
+ /// RIa-type instructions.
503
+ ///
504
+ /// 31 23 19 15
505
+ /// opcode1 r1 opcode2 i2
506
+ /// 24 20 16 0
507
+ ///
508
+ fn enc_ri_a(opcode: u16, r1: Reg, i2: u16) -> [u8; 4] {
509
+ let mut enc: [u8; 4] = [0; 4];
510
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
511
+ let opcode2 = (opcode & 0xf) as u8;
512
+ let r1 = machreg_to_gpr(r1) & 0x0f;
513
+
514
+ enc[0] = opcode1;
515
+ enc[1] = r1 << 4 | opcode2;
516
+ enc[2..].copy_from_slice(&i2.to_be_bytes());
517
+ enc
518
+ }
519
+
520
+ /// RIb-type instructions.
521
+ ///
522
+ /// 31 23 19 15
523
+ /// opcode1 r1 opcode2 ri2
524
+ /// 24 20 16 0
525
+ ///
526
+ fn enc_ri_b(opcode: u16, r1: Reg, ri2: i32) -> [u8; 4] {
527
+ let mut enc: [u8; 4] = [0; 4];
528
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
529
+ let opcode2 = (opcode & 0xf) as u8;
530
+ let r1 = machreg_to_gpr(r1) & 0x0f;
531
+ let ri2 = ((ri2 >> 1) & 0xffff) as u16;
532
+
533
+ enc[0] = opcode1;
534
+ enc[1] = r1 << 4 | opcode2;
535
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
536
+ enc
537
+ }
538
+
539
+ /// RIc-type instructions.
540
+ ///
541
+ /// 31 23 19 15
542
+ /// opcode1 m1 opcode2 ri2
543
+ /// 24 20 16 0
544
+ ///
545
+ fn enc_ri_c(opcode: u16, m1: u8, ri2: i32) -> [u8; 4] {
546
+ let mut enc: [u8; 4] = [0; 4];
547
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
548
+ let opcode2 = (opcode & 0xf) as u8;
549
+ let m1 = m1 & 0x0f;
550
+ let ri2 = ((ri2 >> 1) & 0xffff) as u16;
551
+
552
+ enc[0] = opcode1;
553
+ enc[1] = m1 << 4 | opcode2;
554
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
555
+ enc
556
+ }
557
+
558
+ /// RIEa-type instructions.
559
+ ///
560
+ /// 47 39 35 31 15 11 7
561
+ /// opcode1 r1 -- i2 m3 -- opcode2
562
+ /// 40 36 32 16 12 8 0
563
+ ///
564
+ fn enc_rie_a(opcode: u16, r1: Reg, i2: u16, m3: u8) -> [u8; 6] {
565
+ let mut enc: [u8; 6] = [0; 6];
566
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
567
+ let opcode2 = (opcode & 0xff) as u8;
568
+ let r1 = machreg_to_gpr(r1) & 0x0f;
569
+ let m3 = m3 & 0x0f;
570
+
571
+ enc[0] = opcode1;
572
+ enc[1] = r1 << 4;
573
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
574
+ enc[4] = m3 << 4;
575
+ enc[5] = opcode2;
576
+ enc
577
+ }
578
+
579
+ /// RIEd-type instructions.
580
+ ///
581
+ /// 47 39 35 31 15 7
582
+ /// opcode1 r1 r3 i2 -- opcode2
583
+ /// 40 36 32 16 8 0
584
+ ///
585
+ fn enc_rie_d(opcode: u16, r1: Reg, r3: Reg, i2: u16) -> [u8; 6] {
586
+ let mut enc: [u8; 6] = [0; 6];
587
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
588
+ let opcode2 = (opcode & 0xff) as u8;
589
+ let r1 = machreg_to_gpr(r1) & 0x0f;
590
+ let r3 = machreg_to_gpr(r3) & 0x0f;
591
+
592
+ enc[0] = opcode1;
593
+ enc[1] = r1 << 4 | r3;
594
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
595
+ enc[5] = opcode2;
596
+ enc
597
+ }
598
+
599
+ /// RIEf-type instructions.
600
+ ///
601
+ /// 47 39 35 31 23 15 7
602
+ /// opcode1 r1 r2 i3 i4 i5 opcode2
603
+ /// 40 36 32 24 16 8 0
604
+ ///
605
+ fn enc_rie_f(opcode: u16, r1: Reg, r2: Reg, i3: u8, i4: u8, i5: u8) -> [u8; 6] {
606
+ let mut enc: [u8; 6] = [0; 6];
607
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
608
+ let opcode2 = (opcode & 0xff) as u8;
609
+ let r1 = machreg_to_gpr(r1) & 0x0f;
610
+ let r2 = machreg_to_gpr(r2) & 0x0f;
611
+
612
+ enc[0] = opcode1;
613
+ enc[1] = r1 << 4 | r2;
614
+ enc[2] = i3;
615
+ enc[3] = i4;
616
+ enc[4] = i5;
617
+ enc[5] = opcode2;
618
+ enc
619
+ }
620
+
621
+ /// RIEg-type instructions.
622
+ ///
623
+ /// 47 39 35 31 15 7
624
+ /// opcode1 r1 m3 i2 -- opcode2
625
+ /// 40 36 32 16 8 0
626
+ ///
627
+ fn enc_rie_g(opcode: u16, r1: Reg, i2: u16, m3: u8) -> [u8; 6] {
628
+ let mut enc: [u8; 6] = [0; 6];
629
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
630
+ let opcode2 = (opcode & 0xff) as u8;
631
+ let r1 = machreg_to_gpr(r1) & 0x0f;
632
+ let m3 = m3 & 0x0f;
633
+
634
+ enc[0] = opcode1;
635
+ enc[1] = r1 << 4 | m3;
636
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
637
+ enc[5] = opcode2;
638
+ enc
639
+ }
640
+
641
+ /// RILa-type instructions.
642
+ ///
643
+ /// 47 39 35 31
644
+ /// opcode1 r1 opcode2 i2
645
+ /// 40 36 32 0
646
+ ///
647
+ fn enc_ril_a(opcode: u16, r1: Reg, i2: u32) -> [u8; 6] {
648
+ let mut enc: [u8; 6] = [0; 6];
649
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
650
+ let opcode2 = (opcode & 0xf) as u8;
651
+ let r1 = machreg_to_gpr(r1) & 0x0f;
652
+
653
+ enc[0] = opcode1;
654
+ enc[1] = r1 << 4 | opcode2;
655
+ enc[2..].copy_from_slice(&i2.to_be_bytes());
656
+ enc
657
+ }
658
+
659
+ /// RILb-type instructions.
660
+ ///
661
+ /// 47 39 35 31
662
+ /// opcode1 r1 opcode2 ri2
663
+ /// 40 36 32 0
664
+ ///
665
+ fn enc_ril_b(opcode: u16, r1: Reg, ri2: u32) -> [u8; 6] {
666
+ let mut enc: [u8; 6] = [0; 6];
667
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
668
+ let opcode2 = (opcode & 0xf) as u8;
669
+ let r1 = machreg_to_gpr(r1) & 0x0f;
670
+ let ri2 = ri2 >> 1;
671
+
672
+ enc[0] = opcode1;
673
+ enc[1] = r1 << 4 | opcode2;
674
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
675
+ enc
676
+ }
677
+
678
+ /// RILc-type instructions.
679
+ ///
680
+ /// 47 39 35 31
681
+ /// opcode1 m1 opcode2 i2
682
+ /// 40 36 32 0
683
+ ///
684
+ fn enc_ril_c(opcode: u16, m1: u8, ri2: u32) -> [u8; 6] {
685
+ let mut enc: [u8; 6] = [0; 6];
686
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
687
+ let opcode2 = (opcode & 0xf) as u8;
688
+ let m1 = m1 & 0x0f;
689
+ let ri2 = ri2 >> 1;
690
+
691
+ enc[0] = opcode1;
692
+ enc[1] = m1 << 4 | opcode2;
693
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
694
+ enc
695
+ }
696
+
697
+ /// RR-type instructions.
698
+ ///
699
+ /// 15 7 3
700
+ /// opcode r1 r2
701
+ /// 8 4 0
702
+ ///
703
+ fn enc_rr(opcode: u16, r1: Reg, r2: Reg) -> [u8; 2] {
704
+ let mut enc: [u8; 2] = [0; 2];
705
+ let opcode = (opcode & 0xff) as u8;
706
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
707
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
708
+
709
+ enc[0] = opcode;
710
+ enc[1] = r1 << 4 | r2;
711
+ enc
712
+ }
713
+
714
+ /// RRD-type instructions.
715
+ ///
716
+ /// 31 15 11 7 3
717
+ /// opcode r1 -- r3 r2
718
+ /// 16 12 8 4 0
719
+ ///
720
+ fn enc_rrd(opcode: u16, r1: Reg, r2: Reg, r3: Reg) -> [u8; 4] {
721
+ let mut enc: [u8; 4] = [0; 4];
722
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
723
+ let opcode2 = (opcode & 0xff) as u8;
724
+ let r1 = machreg_to_fpr(r1) & 0x0f;
725
+ let r2 = machreg_to_fpr(r2) & 0x0f;
726
+ let r3 = machreg_to_fpr(r3) & 0x0f;
727
+
728
+ enc[0] = opcode1;
729
+ enc[1] = opcode2;
730
+ enc[2] = r1 << 4;
731
+ enc[3] = r3 << 4 | r2;
732
+ enc
733
+ }
734
+
735
+ /// RRE-type instructions.
736
+ ///
737
+ /// 31 15 7 3
738
+ /// opcode -- r1 r2
739
+ /// 16 8 4 0
740
+ ///
741
+ fn enc_rre(opcode: u16, r1: Reg, r2: Reg) -> [u8; 4] {
742
+ let mut enc: [u8; 4] = [0; 4];
743
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
744
+ let opcode2 = (opcode & 0xff) as u8;
745
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
746
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
747
+
748
+ enc[0] = opcode1;
749
+ enc[1] = opcode2;
750
+ enc[3] = r1 << 4 | r2;
751
+ enc
752
+ }
753
+
754
+ /// RRFa/b-type instructions.
755
+ ///
756
+ /// 31 15 11 7 3
757
+ /// opcode r3 m4 r1 r2
758
+ /// 16 12 8 4 0
759
+ ///
760
+ fn enc_rrf_ab(opcode: u16, r1: Reg, r2: Reg, r3: Reg, m4: u8) -> [u8; 4] {
761
+ let mut enc: [u8; 4] = [0; 4];
762
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
763
+ let opcode2 = (opcode & 0xff) as u8;
764
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
765
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
766
+ let r3 = machreg_to_gpr_or_fpr(r3) & 0x0f;
767
+ let m4 = m4 & 0x0f;
768
+
769
+ enc[0] = opcode1;
770
+ enc[1] = opcode2;
771
+ enc[2] = r3 << 4 | m4;
772
+ enc[3] = r1 << 4 | r2;
773
+ enc
774
+ }
775
+
776
+ /// RRFc/d/e-type instructions.
777
+ ///
778
+ /// 31 15 11 7 3
779
+ /// opcode m3 m4 r1 r2
780
+ /// 16 12 8 4 0
781
+ ///
782
+ fn enc_rrf_cde(opcode: u16, r1: Reg, r2: Reg, m3: u8, m4: u8) -> [u8; 4] {
783
+ let mut enc: [u8; 4] = [0; 4];
784
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
785
+ let opcode2 = (opcode & 0xff) as u8;
786
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
787
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
788
+ let m3 = m3 & 0x0f;
789
+ let m4 = m4 & 0x0f;
790
+
791
+ enc[0] = opcode1;
792
+ enc[1] = opcode2;
793
+ enc[2] = m3 << 4 | m4;
794
+ enc[3] = r1 << 4 | r2;
795
+ enc
796
+ }
797
+
798
+ /// RS-type instructions.
799
+ ///
800
+ /// 31 23 19 15 11
801
+ /// opcode r1 r3 b2 d2
802
+ /// 24 20 16 12 0
803
+ ///
804
+ fn enc_rs(opcode: u16, r1: Reg, r3: Reg, b2: Reg, d2: u32) -> [u8; 4] {
805
+ let opcode = (opcode & 0xff) as u8;
806
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
807
+ let r3 = machreg_to_gpr_or_fpr(r3) & 0x0f;
808
+ let b2 = machreg_to_gpr(b2) & 0x0f;
809
+ let d2_lo = (d2 & 0xff) as u8;
810
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
811
+
812
+ let mut enc: [u8; 4] = [0; 4];
813
+ enc[0] = opcode;
814
+ enc[1] = r1 << 4 | r3;
815
+ enc[2] = b2 << 4 | d2_hi;
816
+ enc[3] = d2_lo;
817
+ enc
818
+ }
819
+
820
+ /// RSY-type instructions.
821
+ ///
822
+ /// 47 39 35 31 27 15 7
823
+ /// opcode1 r1 r3 b2 dl2 dh2 opcode2
824
+ /// 40 36 32 28 16 8 0
825
+ ///
826
+ fn enc_rsy(opcode: u16, r1: Reg, r3: Reg, b2: Reg, d2: u32) -> [u8; 6] {
827
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
828
+ let opcode2 = (opcode & 0xff) as u8;
829
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
830
+ let r3 = machreg_to_gpr_or_fpr(r3) & 0x0f;
831
+ let b2 = machreg_to_gpr(b2) & 0x0f;
832
+ let dl2_lo = (d2 & 0xff) as u8;
833
+ let dl2_hi = ((d2 >> 8) & 0x0f) as u8;
834
+ let dh2 = ((d2 >> 12) & 0xff) as u8;
835
+
836
+ let mut enc: [u8; 6] = [0; 6];
837
+ enc[0] = opcode1;
838
+ enc[1] = r1 << 4 | r3;
839
+ enc[2] = b2 << 4 | dl2_hi;
840
+ enc[3] = dl2_lo;
841
+ enc[4] = dh2;
842
+ enc[5] = opcode2;
843
+ enc
844
+ }
845
+
846
+ /// RX-type instructions.
847
+ ///
848
+ /// 31 23 19 15 11
849
+ /// opcode r1 x2 b2 d2
850
+ /// 24 20 16 12 0
851
+ ///
852
+ fn enc_rx(opcode: u16, r1: Reg, b2: Reg, x2: Reg, d2: u32) -> [u8; 4] {
853
+ let opcode = (opcode & 0xff) as u8;
854
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
855
+ let b2 = machreg_to_gpr(b2) & 0x0f;
856
+ let x2 = machreg_to_gpr(x2) & 0x0f;
857
+ let d2_lo = (d2 & 0xff) as u8;
858
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
859
+
860
+ let mut enc: [u8; 4] = [0; 4];
861
+ enc[0] = opcode;
862
+ enc[1] = r1 << 4 | x2;
863
+ enc[2] = b2 << 4 | d2_hi;
864
+ enc[3] = d2_lo;
865
+ enc
866
+ }
867
+
868
+ /// RXY-type instructions.
869
+ ///
870
+ /// 47 39 35 31 27 15 7
871
+ /// opcode1 r1 x2 b2 dl2 dh2 opcode2
872
+ /// 40 36 32 28 16 8 0
873
+ ///
874
+ fn enc_rxy(opcode: u16, r1: Reg, b2: Reg, x2: Reg, d2: u32) -> [u8; 6] {
875
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
876
+ let opcode2 = (opcode & 0xff) as u8;
877
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
878
+ let b2 = machreg_to_gpr(b2) & 0x0f;
879
+ let x2 = machreg_to_gpr(x2) & 0x0f;
880
+ let dl2_lo = (d2 & 0xff) as u8;
881
+ let dl2_hi = ((d2 >> 8) & 0x0f) as u8;
882
+ let dh2 = ((d2 >> 12) & 0xff) as u8;
883
+
884
+ let mut enc: [u8; 6] = [0; 6];
885
+ enc[0] = opcode1;
886
+ enc[1] = r1 << 4 | x2;
887
+ enc[2] = b2 << 4 | dl2_hi;
888
+ enc[3] = dl2_lo;
889
+ enc[4] = dh2;
890
+ enc[5] = opcode2;
891
+ enc
892
+ }
893
+
894
+ /// SI-type instructions.
895
+ ///
896
+ /// 31 23 15 11
897
+ /// opcode i2 b1 d1
898
+ /// 24 16 12 0
899
+ ///
900
+ fn enc_si(opcode: u16, b1: Reg, d1: u32, i2: u8) -> [u8; 4] {
901
+ let opcode = (opcode & 0xff) as u8;
902
+ let b1 = machreg_to_gpr(b1) & 0x0f;
903
+ let d1_lo = (d1 & 0xff) as u8;
904
+ let d1_hi = ((d1 >> 8) & 0x0f) as u8;
905
+
906
+ let mut enc: [u8; 4] = [0; 4];
907
+ enc[0] = opcode;
908
+ enc[1] = i2;
909
+ enc[2] = b1 << 4 | d1_hi;
910
+ enc[3] = d1_lo;
911
+ enc
912
+ }
913
+
914
+ /// SIL-type instructions.
915
+ ///
916
+ /// 47 31 27 15
917
+ /// opcode b1 d1 i2
918
+ /// 32 28 16 0
919
+ ///
920
+ fn enc_sil(opcode: u16, b1: Reg, d1: u32, i2: i16) -> [u8; 6] {
921
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
922
+ let opcode2 = (opcode & 0xff) as u8;
923
+ let b1 = machreg_to_gpr(b1) & 0x0f;
924
+ let d1_lo = (d1 & 0xff) as u8;
925
+ let d1_hi = ((d1 >> 8) & 0x0f) as u8;
926
+
927
+ let mut enc: [u8; 6] = [0; 6];
928
+ enc[0] = opcode1;
929
+ enc[1] = opcode2;
930
+ enc[2] = b1 << 4 | d1_hi;
931
+ enc[3] = d1_lo;
932
+ enc[4..].copy_from_slice(&i2.to_be_bytes());
933
+ enc
934
+ }
935
+
936
+ /// SIY-type instructions.
937
+ ///
938
+ /// 47 39 31 27 15 7
939
+ /// opcode1 i2 b1 dl1 dh1 opcode2
940
+ /// 40 32 28 16 8 0
941
+ ///
942
+ fn enc_siy(opcode: u16, b1: Reg, d1: u32, i2: u8) -> [u8; 6] {
943
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
944
+ let opcode2 = (opcode & 0xff) as u8;
945
+ let b1 = machreg_to_gpr(b1) & 0x0f;
946
+ let dl1_lo = (d1 & 0xff) as u8;
947
+ let dl1_hi = ((d1 >> 8) & 0x0f) as u8;
948
+ let dh1 = ((d1 >> 12) & 0xff) as u8;
949
+
950
+ let mut enc: [u8; 6] = [0; 6];
951
+ enc[0] = opcode1;
952
+ enc[1] = i2;
953
+ enc[2] = b1 << 4 | dl1_hi;
954
+ enc[3] = dl1_lo;
955
+ enc[4] = dh1;
956
+ enc[5] = opcode2;
957
+ enc
958
+ }
959
+
960
+ /// SSa-type instructions.
961
+ ///
962
+ /// 47 39 31 27 15 11
963
+ /// opcode l b1 d1 b2 d2
964
+ /// 40 32 28 16 12 0
965
+ ///
966
+ ///
967
+ fn enc_ss_a(opcode: u8, b1: Reg, d1: u32, b2: Reg, d2: u32, l: u8) -> [u8; 6] {
968
+ let b1 = machreg_to_gpr(b1) & 0x0f;
969
+ let d1_lo = (d1 & 0xff) as u8;
970
+ let d1_hi = ((d1 >> 8) & 0x0f) as u8;
971
+ let b2 = machreg_to_gpr(b2) & 0x0f;
972
+ let d2_lo = (d2 & 0xff) as u8;
973
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
974
+
975
+ let mut enc: [u8; 6] = [0; 6];
976
+ enc[0] = opcode;
977
+ enc[1] = l;
978
+ enc[2] = b1 << 4 | d1_hi;
979
+ enc[3] = d1_lo;
980
+ enc[4] = b2 << 4 | d2_hi;
981
+ enc[5] = d2_lo;
982
+ enc
983
+ }
984
+
985
+ /// VRIa-type instructions.
986
+ ///
987
+ /// 47 39 35 31 15 11 7
988
+ /// opcode1 v1 - i2 m3 rxb opcode2
989
+ /// 40 36 32 16 12 8 0
990
+ ///
991
+ fn enc_vri_a(opcode: u16, v1: Reg, i2: u16, m3: u8) -> [u8; 6] {
992
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
993
+ let opcode2 = (opcode & 0xff) as u8;
994
+ let rxb = rxb(Some(v1), None, None, None);
995
+ let v1 = machreg_to_vr(v1) & 0x0f;
996
+ let m3 = m3 & 0x0f;
997
+
998
+ let mut enc: [u8; 6] = [0; 6];
999
+ enc[0] = opcode1;
1000
+ enc[1] = v1 << 4;
1001
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
1002
+ enc[4] = m3 << 4 | rxb;
1003
+ enc[5] = opcode2;
1004
+ enc
1005
+ }
1006
+
1007
+ /// VRIb-type instructions.
1008
+ ///
1009
+ /// 47 39 35 31 23 15 11 7
1010
+ /// opcode1 v1 - i2 i3 m4 rxb opcode2
1011
+ /// 40 36 32 24 16 12 8 0
1012
+ ///
1013
+ fn enc_vri_b(opcode: u16, v1: Reg, i2: u8, i3: u8, m4: u8) -> [u8; 6] {
1014
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1015
+ let opcode2 = (opcode & 0xff) as u8;
1016
+ let rxb = rxb(Some(v1), None, None, None);
1017
+ let v1 = machreg_to_vr(v1) & 0x0f;
1018
+ let m4 = m4 & 0x0f;
1019
+
1020
+ let mut enc: [u8; 6] = [0; 6];
1021
+ enc[0] = opcode1;
1022
+ enc[1] = v1 << 4;
1023
+ enc[2] = i2;
1024
+ enc[3] = i3;
1025
+ enc[4] = m4 << 4 | rxb;
1026
+ enc[5] = opcode2;
1027
+ enc
1028
+ }
1029
+
1030
+ /// VRIc-type instructions.
1031
+ ///
1032
+ /// 47 39 35 31 15 11 7
1033
+ /// opcode1 v1 v3 i2 m4 rxb opcode2
1034
+ /// 40 36 32 16 12 8 0
1035
+ ///
1036
+ fn enc_vri_c(opcode: u16, v1: Reg, i2: u16, v3: Reg, m4: u8) -> [u8; 6] {
1037
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1038
+ let opcode2 = (opcode & 0xff) as u8;
1039
+ let rxb = rxb(Some(v1), Some(v3), None, None);
1040
+ let v1 = machreg_to_vr(v1) & 0x0f;
1041
+ let v3 = machreg_to_vr(v3) & 0x0f;
1042
+ let m4 = m4 & 0x0f;
1043
+
1044
+ let mut enc: [u8; 6] = [0; 6];
1045
+ enc[0] = opcode1;
1046
+ enc[1] = v1 << 4 | v3;
1047
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
1048
+ enc[4] = m4 << 4 | rxb;
1049
+ enc[5] = opcode2;
1050
+ enc
1051
+ }
1052
+
1053
+ /// VRRa-type instructions.
1054
+ ///
1055
+ /// 47 39 35 31 23 19 15 11 7
1056
+ /// opcode1 v1 v2 - m5 m3 m2 rxb opcode2
1057
+ /// 40 36 32 24 20 16 12 8 0
1058
+ ///
1059
+ fn enc_vrr_a(opcode: u16, v1: Reg, v2: Reg, m3: u8, m4: u8, m5: u8) -> [u8; 6] {
1060
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1061
+ let opcode2 = (opcode & 0xff) as u8;
1062
+ let rxb = rxb(Some(v1), Some(v2), None, None);
1063
+ let v1 = machreg_to_vr(v1) & 0x0f;
1064
+ let v2 = machreg_to_vr(v2) & 0x0f;
1065
+ let m3 = m3 & 0x0f;
1066
+ let m4 = m4 & 0x0f;
1067
+ let m5 = m5 & 0x0f;
1068
+
1069
+ let mut enc: [u8; 6] = [0; 6];
1070
+ enc[0] = opcode1;
1071
+ enc[1] = v1 << 4 | v2;
1072
+ enc[2] = 0;
1073
+ enc[3] = m5 << 4 | m4;
1074
+ enc[4] = m3 << 4 | rxb;
1075
+ enc[5] = opcode2;
1076
+ enc
1077
+ }
1078
+
1079
+ /// VRRb-type instructions.
1080
+ ///
1081
+ /// 47 39 35 31 27 23 19 15 11 7
1082
+ /// opcode1 v1 v2 v3 - m5 - m4 rxb opcode2
1083
+ /// 40 36 32 28 24 20 16 12 8 0
1084
+ ///
1085
+ fn enc_vrr_b(opcode: u16, v1: Reg, v2: Reg, v3: Reg, m4: u8, m5: u8) -> [u8; 6] {
1086
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1087
+ let opcode2 = (opcode & 0xff) as u8;
1088
+ let rxb = rxb(Some(v1), Some(v2), Some(v3), None);
1089
+ let v1 = machreg_to_vr(v1) & 0x0f;
1090
+ let v2 = machreg_to_vr(v2) & 0x0f;
1091
+ let v3 = machreg_to_vr(v3) & 0x0f;
1092
+ let m4 = m4 & 0x0f;
1093
+ let m5 = m5 & 0x0f;
1094
+
1095
+ let mut enc: [u8; 6] = [0; 6];
1096
+ enc[0] = opcode1;
1097
+ enc[1] = v1 << 4 | v2;
1098
+ enc[2] = v3 << 4;
1099
+ enc[3] = m5 << 4;
1100
+ enc[4] = m4 << 4 | rxb;
1101
+ enc[5] = opcode2;
1102
+ enc
1103
+ }
1104
+
1105
+ /// VRRc-type instructions.
1106
+ ///
1107
+ /// 47 39 35 31 27 23 19 15 11 7
1108
+ /// opcode1 v1 v2 v3 - m6 m5 m4 rxb opcode2
1109
+ /// 40 36 32 28 24 20 16 12 8 0
1110
+ ///
1111
+ fn enc_vrr_c(opcode: u16, v1: Reg, v2: Reg, v3: Reg, m4: u8, m5: u8, m6: u8) -> [u8; 6] {
1112
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1113
+ let opcode2 = (opcode & 0xff) as u8;
1114
+ let rxb = rxb(Some(v1), Some(v2), Some(v3), None);
1115
+ let v1 = machreg_to_vr(v1) & 0x0f;
1116
+ let v2 = machreg_to_vr(v2) & 0x0f;
1117
+ let v3 = machreg_to_vr(v3) & 0x0f;
1118
+ let m4 = m4 & 0x0f;
1119
+ let m5 = m5 & 0x0f;
1120
+ let m6 = m6 & 0x0f;
1121
+
1122
+ let mut enc: [u8; 6] = [0; 6];
1123
+ enc[0] = opcode1;
1124
+ enc[1] = v1 << 4 | v2;
1125
+ enc[2] = v3 << 4;
1126
+ enc[3] = m6 << 4 | m5;
1127
+ enc[4] = m4 << 4 | rxb;
1128
+ enc[5] = opcode2;
1129
+ enc
1130
+ }
1131
+
1132
+ /// VRRe-type instructions.
1133
+ ///
1134
+ /// 47 39 35 31 27 23 19 15 11 7
1135
+ /// opcode1 v1 v2 v3 m6 - m5 v4 rxb opcode2
1136
+ /// 40 36 32 28 24 20 16 12 8 0
1137
+ ///
1138
+ fn enc_vrr_e(opcode: u16, v1: Reg, v2: Reg, v3: Reg, v4: Reg, m5: u8, m6: u8) -> [u8; 6] {
1139
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1140
+ let opcode2 = (opcode & 0xff) as u8;
1141
+ let rxb = rxb(Some(v1), Some(v2), Some(v3), Some(v4));
1142
+ let v1 = machreg_to_vr(v1) & 0x0f;
1143
+ let v2 = machreg_to_vr(v2) & 0x0f;
1144
+ let v3 = machreg_to_vr(v3) & 0x0f;
1145
+ let v4 = machreg_to_vr(v4) & 0x0f;
1146
+ let m5 = m5 & 0x0f;
1147
+ let m6 = m6 & 0x0f;
1148
+
1149
+ let mut enc: [u8; 6] = [0; 6];
1150
+ enc[0] = opcode1;
1151
+ enc[1] = v1 << 4 | v2;
1152
+ enc[2] = v3 << 4 | m6;
1153
+ enc[3] = m5;
1154
+ enc[4] = v4 << 4 | rxb;
1155
+ enc[5] = opcode2;
1156
+ enc
1157
+ }
1158
+
1159
+ /// VRRf-type instructions.
1160
+ ///
1161
+ /// 47 39 35 31 27 11 7
1162
+ /// opcode1 v1 r2 r3 - rxb opcode2
1163
+ /// 40 36 32 28 12 8 0
1164
+ ///
1165
+ fn enc_vrr_f(opcode: u16, v1: Reg, r2: Reg, r3: Reg) -> [u8; 6] {
1166
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1167
+ let opcode2 = (opcode & 0xff) as u8;
1168
+ let rxb = rxb(Some(v1), None, None, None);
1169
+ let v1 = machreg_to_vr(v1) & 0x0f;
1170
+ let r2 = machreg_to_gpr(r2) & 0x0f;
1171
+ let r3 = machreg_to_gpr(r3) & 0x0f;
1172
+
1173
+ let mut enc: [u8; 6] = [0; 6];
1174
+ enc[0] = opcode1;
1175
+ enc[1] = v1 << 4 | r2;
1176
+ enc[2] = r3 << 4;
1177
+ enc[4] = rxb;
1178
+ enc[5] = opcode2;
1179
+ enc
1180
+ }
1181
+
1182
+ /// VRSa-type instructions.
1183
+ ///
1184
+ /// 47 39 35 31 27 15 11 7
1185
+ /// opcode1 v1 v3 b2 d2 m4 rxb opcode2
1186
+ /// 40 36 32 28 16 12 8 0
1187
+ ///
1188
+ fn enc_vrs_a(opcode: u16, v1: Reg, b2: Reg, d2: u32, v3: Reg, m4: u8) -> [u8; 6] {
1189
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1190
+ let opcode2 = (opcode & 0xff) as u8;
1191
+ let rxb = rxb(Some(v1), Some(v3), None, None);
1192
+ let v1 = machreg_to_vr(v1) & 0x0f;
1193
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1194
+ let v3 = machreg_to_vr(v3) & 0x0f;
1195
+ let d2_lo = (d2 & 0xff) as u8;
1196
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1197
+ let m4 = m4 & 0x0f;
1198
+
1199
+ let mut enc: [u8; 6] = [0; 6];
1200
+ enc[0] = opcode1;
1201
+ enc[1] = v1 << 4 | v3;
1202
+ enc[2] = b2 << 4 | d2_hi;
1203
+ enc[3] = d2_lo;
1204
+ enc[4] = m4 << 4 | rxb;
1205
+ enc[5] = opcode2;
1206
+ enc
1207
+ }
1208
+
1209
+ /// VRSb-type instructions.
1210
+ ///
1211
+ /// 47 39 35 31 27 15 11 7
1212
+ /// opcode1 v1 r3 b2 d2 m4 rxb opcode2
1213
+ /// 40 36 32 28 16 12 8 0
1214
+ ///
1215
+ fn enc_vrs_b(opcode: u16, v1: Reg, b2: Reg, d2: u32, r3: Reg, m4: u8) -> [u8; 6] {
1216
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1217
+ let opcode2 = (opcode & 0xff) as u8;
1218
+ let rxb = rxb(Some(v1), None, None, None);
1219
+ let v1 = machreg_to_vr(v1) & 0x0f;
1220
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1221
+ let r3 = machreg_to_gpr(r3) & 0x0f;
1222
+ let d2_lo = (d2 & 0xff) as u8;
1223
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1224
+ let m4 = m4 & 0x0f;
1225
+
1226
+ let mut enc: [u8; 6] = [0; 6];
1227
+ enc[0] = opcode1;
1228
+ enc[1] = v1 << 4 | r3;
1229
+ enc[2] = b2 << 4 | d2_hi;
1230
+ enc[3] = d2_lo;
1231
+ enc[4] = m4 << 4 | rxb;
1232
+ enc[5] = opcode2;
1233
+ enc
1234
+ }
1235
+
1236
+ /// VRSc-type instructions.
1237
+ ///
1238
+ /// 47 39 35 31 27 15 11 7
1239
+ /// opcode1 r1 v3 b2 d2 m4 rxb opcode2
1240
+ /// 40 36 32 28 16 12 8 0
1241
+ ///
1242
+ fn enc_vrs_c(opcode: u16, r1: Reg, b2: Reg, d2: u32, v3: Reg, m4: u8) -> [u8; 6] {
1243
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1244
+ let opcode2 = (opcode & 0xff) as u8;
1245
+ let rxb = rxb(None, Some(v3), None, None);
1246
+ let r1 = machreg_to_gpr(r1) & 0x0f;
1247
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1248
+ let v3 = machreg_to_vr(v3) & 0x0f;
1249
+ let d2_lo = (d2 & 0xff) as u8;
1250
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1251
+ let m4 = m4 & 0x0f;
1252
+
1253
+ let mut enc: [u8; 6] = [0; 6];
1254
+ enc[0] = opcode1;
1255
+ enc[1] = r1 << 4 | v3;
1256
+ enc[2] = b2 << 4 | d2_hi;
1257
+ enc[3] = d2_lo;
1258
+ enc[4] = m4 << 4 | rxb;
1259
+ enc[5] = opcode2;
1260
+ enc
1261
+ }
1262
+
1263
+ /// VRX-type instructions.
1264
+ ///
1265
+ /// 47 39 35 31 27 15 11 7
1266
+ /// opcode1 v1 x2 b2 d2 m3 rxb opcode2
1267
+ /// 40 36 32 28 16 12 8 0
1268
+ ///
1269
+ fn enc_vrx(opcode: u16, v1: Reg, b2: Reg, x2: Reg, d2: u32, m3: u8) -> [u8; 6] {
1270
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1271
+ let opcode2 = (opcode & 0xff) as u8;
1272
+ let rxb = rxb(Some(v1), None, None, None);
1273
+ let v1 = machreg_to_vr(v1) & 0x0f;
1274
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1275
+ let x2 = machreg_to_gpr(x2) & 0x0f;
1276
+ let d2_lo = (d2 & 0xff) as u8;
1277
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1278
+ let m3 = m3 & 0x0f;
1279
+
1280
+ let mut enc: [u8; 6] = [0; 6];
1281
+ enc[0] = opcode1;
1282
+ enc[1] = v1 << 4 | x2;
1283
+ enc[2] = b2 << 4 | d2_hi;
1284
+ enc[3] = d2_lo;
1285
+ enc[4] = m3 << 4 | rxb;
1286
+ enc[5] = opcode2;
1287
+ enc
1288
+ }
1289
+
1290
+ /// Emit encoding to sink.
1291
+ fn put(sink: &mut MachBuffer<Inst>, enc: &[u8]) {
1292
+ for byte in enc {
1293
+ sink.put1(*byte);
1294
+ }
1295
+ }
1296
+
1297
+ /// Emit encoding to sink, adding a trap on the last byte.
1298
+ fn put_with_trap(sink: &mut MachBuffer<Inst>, enc: &[u8], trap_code: TrapCode) {
1299
+ let len = enc.len();
1300
+ for i in 0..len - 1 {
1301
+ sink.put1(enc[i]);
1302
+ }
1303
+ sink.add_trap(trap_code);
1304
+ sink.put1(enc[len - 1]);
1305
+ }
1306
+
1307
+ /// State carried between emissions of a sequence of instructions.
1308
+ #[derive(Default, Clone, Debug)]
1309
+ pub struct EmitState {
1310
+ pub(crate) initial_sp_offset: i64,
1311
+ pub(crate) virtual_sp_offset: i64,
1312
+ /// Safepoint stack map for upcoming instruction, as provided to `pre_safepoint()`.
1313
+ stack_map: Option<StackMap>,
1314
+ /// Only used during fuzz-testing. Otherwise, it is a zero-sized struct and
1315
+ /// optimized away at compiletime. See [cranelift_control].
1316
+ ctrl_plane: ControlPlane,
1317
+ }
1318
+
1319
+ impl MachInstEmitState<Inst> for EmitState {
1320
+ fn new(abi: &Callee<S390xMachineDeps>, ctrl_plane: ControlPlane) -> Self {
1321
+ EmitState {
1322
+ virtual_sp_offset: 0,
1323
+ initial_sp_offset: abi.frame_size() as i64,
1324
+ stack_map: None,
1325
+ ctrl_plane,
1326
+ }
1327
+ }
1328
+
1329
+ fn pre_safepoint(&mut self, stack_map: StackMap) {
1330
+ self.stack_map = Some(stack_map);
1331
+ }
1332
+
1333
+ fn ctrl_plane_mut(&mut self) -> &mut ControlPlane {
1334
+ &mut self.ctrl_plane
1335
+ }
1336
+
1337
+ fn take_ctrl_plane(self) -> ControlPlane {
1338
+ self.ctrl_plane
1339
+ }
1340
+ }
1341
+
1342
+ impl EmitState {
1343
+ fn take_stack_map(&mut self) -> Option<StackMap> {
1344
+ self.stack_map.take()
1345
+ }
1346
+
1347
+ fn clear_post_insn(&mut self) {
1348
+ self.stack_map = None;
1349
+ }
1350
+ }
1351
+
1352
+ /// Constant state used during function compilation.
1353
+ pub struct EmitInfo {
1354
+ isa_flags: s390x_settings::Flags,
1355
+ }
1356
+
1357
+ impl EmitInfo {
1358
+ pub(crate) fn new(isa_flags: s390x_settings::Flags) -> Self {
1359
+ Self { isa_flags }
1360
+ }
1361
+ }
1362
+
1363
+ impl MachInstEmit for Inst {
1364
+ type State = EmitState;
1365
+ type Info = EmitInfo;
1366
+
1367
+ fn emit(
1368
+ &self,
1369
+ allocs: &[Allocation],
1370
+ sink: &mut MachBuffer<Inst>,
1371
+ emit_info: &Self::Info,
1372
+ state: &mut EmitState,
1373
+ ) {
1374
+ let mut allocs = AllocationConsumer::new(allocs);
1375
+ self.emit_with_alloc_consumer(&mut allocs, sink, emit_info, state)
1376
+ }
1377
+
1378
+ fn pretty_print_inst(&self, allocs: &[Allocation], state: &mut EmitState) -> String {
1379
+ let mut allocs = AllocationConsumer::new(allocs);
1380
+ self.print_with_state(state, &mut allocs)
1381
+ }
1382
+ }
1383
+
1384
+ impl Inst {
1385
+ fn emit_with_alloc_consumer(
1386
+ &self,
1387
+ allocs: &mut AllocationConsumer<'_>,
1388
+ sink: &mut MachBuffer<Inst>,
1389
+ emit_info: &EmitInfo,
1390
+ state: &mut EmitState,
1391
+ ) {
1392
+ // Verify that we can emit this Inst in the current ISA
1393
+ let matches_isa_flags = |iset_requirement: &InstructionSet| -> bool {
1394
+ match iset_requirement {
1395
+ // Baseline ISA is z14
1396
+ InstructionSet::Base => true,
1397
+ // Miscellaneous-Instruction-Extensions Facility 2 (z15)
1398
+ InstructionSet::MIE2 => emit_info.isa_flags.has_mie2(),
1399
+ // Vector-Enhancements Facility 2 (z15)
1400
+ InstructionSet::VXRS_EXT2 => emit_info.isa_flags.has_vxrs_ext2(),
1401
+ }
1402
+ };
1403
+ let isa_requirements = self.available_in_isa();
1404
+ if !matches_isa_flags(&isa_requirements) {
1405
+ panic!(
1406
+ "Cannot emit inst '{:?}' for target; failed to match ISA requirements: {:?}",
1407
+ self, isa_requirements
1408
+ )
1409
+ }
1410
+
1411
+ // N.B.: we *must* not exceed the "worst-case size" used to compute
1412
+ // where to insert islands, except when islands are explicitly triggered
1413
+ // (with an `EmitIsland`). We check this in debug builds. This is `mut`
1414
+ // to allow disabling the check for `JTSequence`, which is always
1415
+ // emitted following an `EmitIsland`.
1416
+ let mut start_off = sink.cur_offset();
1417
+
1418
+ match self {
1419
+ &Inst::AluRRR { alu_op, rd, rn, rm } => {
1420
+ let rd = allocs.next_writable(rd);
1421
+ let rn = allocs.next(rn);
1422
+ let rm = allocs.next(rm);
1423
+
1424
+ let (opcode, have_rr) = match alu_op {
1425
+ ALUOp::Add32 => (0xb9f8, true), // ARK
1426
+ ALUOp::Add64 => (0xb9e8, true), // AGRK
1427
+ ALUOp::AddLogical32 => (0xb9fa, true), // ALRK
1428
+ ALUOp::AddLogical64 => (0xb9ea, true), // ALGRK
1429
+ ALUOp::Sub32 => (0xb9f9, true), // SRK
1430
+ ALUOp::Sub64 => (0xb9e9, true), // SGRK
1431
+ ALUOp::SubLogical32 => (0xb9fb, true), // SLRK
1432
+ ALUOp::SubLogical64 => (0xb9eb, true), // SLGRK
1433
+ ALUOp::Mul32 => (0xb9fd, true), // MSRKC
1434
+ ALUOp::Mul64 => (0xb9ed, true), // MSGRKC
1435
+ ALUOp::And32 => (0xb9f4, true), // NRK
1436
+ ALUOp::And64 => (0xb9e4, true), // NGRK
1437
+ ALUOp::Orr32 => (0xb9f6, true), // ORK
1438
+ ALUOp::Orr64 => (0xb9e6, true), // OGRK
1439
+ ALUOp::Xor32 => (0xb9f7, true), // XRK
1440
+ ALUOp::Xor64 => (0xb9e7, true), // XGRK
1441
+ ALUOp::NotAnd32 => (0xb974, false), // NNRK
1442
+ ALUOp::NotAnd64 => (0xb964, false), // NNGRK
1443
+ ALUOp::NotOrr32 => (0xb976, false), // NORK
1444
+ ALUOp::NotOrr64 => (0xb966, false), // NOGRK
1445
+ ALUOp::NotXor32 => (0xb977, false), // NXRK
1446
+ ALUOp::NotXor64 => (0xb967, false), // NXGRK
1447
+ ALUOp::AndNot32 => (0xb9f5, false), // NCRK
1448
+ ALUOp::AndNot64 => (0xb9e5, false), // NCGRK
1449
+ ALUOp::OrrNot32 => (0xb975, false), // OCRK
1450
+ ALUOp::OrrNot64 => (0xb965, false), // OCGRK
1451
+ _ => unreachable!(),
1452
+ };
1453
+ if have_rr && rd.to_reg() == rn {
1454
+ let inst = Inst::AluRR {
1455
+ alu_op,
1456
+ rd,
1457
+ ri: rn,
1458
+ rm,
1459
+ };
1460
+ inst.emit(&[], sink, emit_info, state);
1461
+ } else {
1462
+ put(sink, &enc_rrf_ab(opcode, rd.to_reg(), rn, rm, 0));
1463
+ }
1464
+ }
1465
+ &Inst::AluRRSImm16 {
1466
+ alu_op,
1467
+ rd,
1468
+ rn,
1469
+ imm,
1470
+ } => {
1471
+ let rd = allocs.next_writable(rd);
1472
+ let rn = allocs.next(rn);
1473
+
1474
+ if rd.to_reg() == rn {
1475
+ let inst = Inst::AluRSImm16 {
1476
+ alu_op,
1477
+ rd,
1478
+ ri: rn,
1479
+ imm,
1480
+ };
1481
+ inst.emit(&[], sink, emit_info, state);
1482
+ } else {
1483
+ let opcode = match alu_op {
1484
+ ALUOp::Add32 => 0xecd8, // AHIK
1485
+ ALUOp::Add64 => 0xecd9, // AGHIK
1486
+ _ => unreachable!(),
1487
+ };
1488
+ put(sink, &enc_rie_d(opcode, rd.to_reg(), rn, imm as u16));
1489
+ }
1490
+ }
1491
+ &Inst::AluRR { alu_op, rd, ri, rm } => {
1492
+ let rd = allocs.next_writable(rd);
1493
+ let ri = allocs.next(ri);
1494
+ debug_assert_eq!(rd.to_reg(), ri);
1495
+ let rm = allocs.next(rm);
1496
+
1497
+ let (opcode, is_rre) = match alu_op {
1498
+ ALUOp::Add32 => (0x1a, false), // AR
1499
+ ALUOp::Add64 => (0xb908, true), // AGR
1500
+ ALUOp::Add64Ext32 => (0xb918, true), // AGFR
1501
+ ALUOp::AddLogical32 => (0x1e, false), // ALR
1502
+ ALUOp::AddLogical64 => (0xb90a, true), // ALGR
1503
+ ALUOp::AddLogical64Ext32 => (0xb91a, true), // ALGFR
1504
+ ALUOp::Sub32 => (0x1b, false), // SR
1505
+ ALUOp::Sub64 => (0xb909, true), // SGR
1506
+ ALUOp::Sub64Ext32 => (0xb919, true), // SGFR
1507
+ ALUOp::SubLogical32 => (0x1f, false), // SLR
1508
+ ALUOp::SubLogical64 => (0xb90b, true), // SLGR
1509
+ ALUOp::SubLogical64Ext32 => (0xb91b, true), // SLGFR
1510
+ ALUOp::Mul32 => (0xb252, true), // MSR
1511
+ ALUOp::Mul64 => (0xb90c, true), // MSGR
1512
+ ALUOp::Mul64Ext32 => (0xb91c, true), // MSGFR
1513
+ ALUOp::And32 => (0x14, false), // NR
1514
+ ALUOp::And64 => (0xb980, true), // NGR
1515
+ ALUOp::Orr32 => (0x16, false), // OR
1516
+ ALUOp::Orr64 => (0xb981, true), // OGR
1517
+ ALUOp::Xor32 => (0x17, false), // XR
1518
+ ALUOp::Xor64 => (0xb982, true), // XGR
1519
+ _ => unreachable!(),
1520
+ };
1521
+ if is_rre {
1522
+ put(sink, &enc_rre(opcode, rd.to_reg(), rm));
1523
+ } else {
1524
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
1525
+ }
1526
+ }
1527
+ &Inst::AluRX {
1528
+ alu_op,
1529
+ rd,
1530
+ ri,
1531
+ ref mem,
1532
+ } => {
1533
+ let rd = allocs.next_writable(rd);
1534
+ let ri = allocs.next(ri);
1535
+ debug_assert_eq!(rd.to_reg(), ri);
1536
+ let mem = mem.with_allocs(allocs);
1537
+
1538
+ let (opcode_rx, opcode_rxy) = match alu_op {
1539
+ ALUOp::Add32 => (Some(0x5a), Some(0xe35a)), // A(Y)
1540
+ ALUOp::Add32Ext16 => (Some(0x4a), Some(0xe37a)), // AH(Y)
1541
+ ALUOp::Add64 => (None, Some(0xe308)), // AG
1542
+ ALUOp::Add64Ext16 => (None, Some(0xe338)), // AGH
1543
+ ALUOp::Add64Ext32 => (None, Some(0xe318)), // AGF
1544
+ ALUOp::AddLogical32 => (Some(0x5e), Some(0xe35e)), // AL(Y)
1545
+ ALUOp::AddLogical64 => (None, Some(0xe30a)), // ALG
1546
+ ALUOp::AddLogical64Ext32 => (None, Some(0xe31a)), // ALGF
1547
+ ALUOp::Sub32 => (Some(0x5b), Some(0xe35b)), // S(Y)
1548
+ ALUOp::Sub32Ext16 => (Some(0x4b), Some(0xe37b)), // SH(Y)
1549
+ ALUOp::Sub64 => (None, Some(0xe309)), // SG
1550
+ ALUOp::Sub64Ext16 => (None, Some(0xe339)), // SGH
1551
+ ALUOp::Sub64Ext32 => (None, Some(0xe319)), // SGF
1552
+ ALUOp::SubLogical32 => (Some(0x5f), Some(0xe35f)), // SL(Y)
1553
+ ALUOp::SubLogical64 => (None, Some(0xe30b)), // SLG
1554
+ ALUOp::SubLogical64Ext32 => (None, Some(0xe31b)), // SLGF
1555
+ ALUOp::Mul32 => (Some(0x71), Some(0xe351)), // MS(Y)
1556
+ ALUOp::Mul32Ext16 => (Some(0x4c), Some(0xe37c)), // MH(Y)
1557
+ ALUOp::Mul64 => (None, Some(0xe30c)), // MSG
1558
+ ALUOp::Mul64Ext16 => (None, Some(0xe33c)), // MSH
1559
+ ALUOp::Mul64Ext32 => (None, Some(0xe31c)), // MSGF
1560
+ ALUOp::And32 => (Some(0x54), Some(0xe354)), // N(Y)
1561
+ ALUOp::And64 => (None, Some(0xe380)), // NG
1562
+ ALUOp::Orr32 => (Some(0x56), Some(0xe356)), // O(Y)
1563
+ ALUOp::Orr64 => (None, Some(0xe381)), // OG
1564
+ ALUOp::Xor32 => (Some(0x57), Some(0xe357)), // X(Y)
1565
+ ALUOp::Xor64 => (None, Some(0xe382)), // XG
1566
+ _ => unreachable!(),
1567
+ };
1568
+ let rd = rd.to_reg();
1569
+ mem_emit(
1570
+ rd, &mem, opcode_rx, opcode_rxy, None, true, sink, emit_info, state,
1571
+ );
1572
+ }
1573
+ &Inst::AluRSImm16 {
1574
+ alu_op,
1575
+ rd,
1576
+ ri,
1577
+ imm,
1578
+ } => {
1579
+ let rd = allocs.next_writable(rd);
1580
+ let ri = allocs.next(ri);
1581
+ debug_assert_eq!(rd.to_reg(), ri);
1582
+
1583
+ let opcode = match alu_op {
1584
+ ALUOp::Add32 => 0xa7a, // AHI
1585
+ ALUOp::Add64 => 0xa7b, // AGHI
1586
+ ALUOp::Mul32 => 0xa7c, // MHI
1587
+ ALUOp::Mul64 => 0xa7d, // MGHI
1588
+ _ => unreachable!(),
1589
+ };
1590
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm as u16));
1591
+ }
1592
+ &Inst::AluRSImm32 {
1593
+ alu_op,
1594
+ rd,
1595
+ ri,
1596
+ imm,
1597
+ } => {
1598
+ let rd = allocs.next_writable(rd);
1599
+ let ri = allocs.next(ri);
1600
+ debug_assert_eq!(rd.to_reg(), ri);
1601
+
1602
+ let opcode = match alu_op {
1603
+ ALUOp::Add32 => 0xc29, // AFI
1604
+ ALUOp::Add64 => 0xc28, // AGFI
1605
+ ALUOp::Mul32 => 0xc21, // MSFI
1606
+ ALUOp::Mul64 => 0xc20, // MSGFI
1607
+ _ => unreachable!(),
1608
+ };
1609
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm as u32));
1610
+ }
1611
+ &Inst::AluRUImm32 {
1612
+ alu_op,
1613
+ rd,
1614
+ ri,
1615
+ imm,
1616
+ } => {
1617
+ let rd = allocs.next_writable(rd);
1618
+ let ri = allocs.next(ri);
1619
+ debug_assert_eq!(rd.to_reg(), ri);
1620
+
1621
+ let opcode = match alu_op {
1622
+ ALUOp::AddLogical32 => 0xc2b, // ALFI
1623
+ ALUOp::AddLogical64 => 0xc2a, // ALGFI
1624
+ ALUOp::SubLogical32 => 0xc25, // SLFI
1625
+ ALUOp::SubLogical64 => 0xc24, // SLGFI
1626
+ _ => unreachable!(),
1627
+ };
1628
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm));
1629
+ }
1630
+ &Inst::AluRUImm16Shifted {
1631
+ alu_op,
1632
+ rd,
1633
+ ri,
1634
+ imm,
1635
+ } => {
1636
+ let rd = allocs.next_writable(rd);
1637
+ let ri = allocs.next(ri);
1638
+ debug_assert_eq!(rd.to_reg(), ri);
1639
+
1640
+ let opcode = match (alu_op, imm.shift) {
1641
+ (ALUOp::And32, 0) => 0xa57, // NILL
1642
+ (ALUOp::And32, 1) => 0xa56, // NILH
1643
+ (ALUOp::And64, 0) => 0xa57, // NILL
1644
+ (ALUOp::And64, 1) => 0xa56, // NILH
1645
+ (ALUOp::And64, 2) => 0xa55, // NIHL
1646
+ (ALUOp::And64, 3) => 0xa54, // NIHL
1647
+ (ALUOp::Orr32, 0) => 0xa5b, // OILL
1648
+ (ALUOp::Orr32, 1) => 0xa5a, // OILH
1649
+ (ALUOp::Orr64, 0) => 0xa5b, // OILL
1650
+ (ALUOp::Orr64, 1) => 0xa5a, // OILH
1651
+ (ALUOp::Orr64, 2) => 0xa59, // OIHL
1652
+ (ALUOp::Orr64, 3) => 0xa58, // OIHH
1653
+ _ => unreachable!(),
1654
+ };
1655
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm.bits));
1656
+ }
1657
+ &Inst::AluRUImm32Shifted {
1658
+ alu_op,
1659
+ rd,
1660
+ ri,
1661
+ imm,
1662
+ } => {
1663
+ let rd = allocs.next_writable(rd);
1664
+ let ri = allocs.next(ri);
1665
+ debug_assert_eq!(rd.to_reg(), ri);
1666
+
1667
+ let opcode = match (alu_op, imm.shift) {
1668
+ (ALUOp::And32, 0) => 0xc0b, // NILF
1669
+ (ALUOp::And64, 0) => 0xc0b, // NILF
1670
+ (ALUOp::And64, 1) => 0xc0a, // NIHF
1671
+ (ALUOp::Orr32, 0) => 0xc0d, // OILF
1672
+ (ALUOp::Orr64, 0) => 0xc0d, // OILF
1673
+ (ALUOp::Orr64, 1) => 0xc0c, // OILF
1674
+ (ALUOp::Xor32, 0) => 0xc07, // XILF
1675
+ (ALUOp::Xor64, 0) => 0xc07, // XILF
1676
+ (ALUOp::Xor64, 1) => 0xc06, // XILH
1677
+ _ => unreachable!(),
1678
+ };
1679
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm.bits));
1680
+ }
1681
+
1682
+ &Inst::SMulWide { rd, rn, rm } => {
1683
+ let rn = allocs.next(rn);
1684
+ let rm = allocs.next(rm);
1685
+ let rd1 = allocs.next_writable(rd.hi);
1686
+ let rd2 = allocs.next_writable(rd.lo);
1687
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1688
+
1689
+ let opcode = 0xb9ec; // MGRK
1690
+ put(sink, &enc_rrf_ab(opcode, rd1.to_reg(), rn, rm, 0));
1691
+ }
1692
+ &Inst::UMulWide { rd, ri, rn } => {
1693
+ let rn = allocs.next(rn);
1694
+ let rd1 = allocs.next_writable(rd.hi);
1695
+ let rd2 = allocs.next_writable(rd.lo);
1696
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1697
+ let ri = allocs.next(ri);
1698
+ debug_assert_eq!(rd2.to_reg(), ri);
1699
+
1700
+ let opcode = 0xb986; // MLGR
1701
+ put(sink, &enc_rre(opcode, rd1.to_reg(), rn));
1702
+ }
1703
+ &Inst::SDivMod32 { rd, ri, rn } => {
1704
+ let rn = allocs.next(rn);
1705
+ let rd1 = allocs.next_writable(rd.hi);
1706
+ let rd2 = allocs.next_writable(rd.lo);
1707
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1708
+ let ri = allocs.next(ri);
1709
+ debug_assert_eq!(rd2.to_reg(), ri);
1710
+
1711
+ let opcode = 0xb91d; // DSGFR
1712
+ let trap_code = TrapCode::IntegerDivisionByZero;
1713
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1714
+ }
1715
+ &Inst::SDivMod64 { rd, ri, rn } => {
1716
+ let rn = allocs.next(rn);
1717
+ let rd1 = allocs.next_writable(rd.hi);
1718
+ let rd2 = allocs.next_writable(rd.lo);
1719
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1720
+ let ri = allocs.next(ri);
1721
+ debug_assert_eq!(rd2.to_reg(), ri);
1722
+
1723
+ let opcode = 0xb90d; // DSGR
1724
+ let trap_code = TrapCode::IntegerDivisionByZero;
1725
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1726
+ }
1727
+ &Inst::UDivMod32 { rd, ri, rn } => {
1728
+ let rn = allocs.next(rn);
1729
+ let rd1 = allocs.next_writable(rd.hi);
1730
+ let rd2 = allocs.next_writable(rd.lo);
1731
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1732
+ let ri1 = allocs.next(ri.hi);
1733
+ let ri2 = allocs.next(ri.lo);
1734
+ debug_assert_eq!(rd1.to_reg(), ri1);
1735
+ debug_assert_eq!(rd2.to_reg(), ri2);
1736
+
1737
+ let opcode = 0xb997; // DLR
1738
+ let trap_code = TrapCode::IntegerDivisionByZero;
1739
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1740
+ }
1741
+ &Inst::UDivMod64 { rd, ri, rn } => {
1742
+ let rn = allocs.next(rn);
1743
+ let rd1 = allocs.next_writable(rd.hi);
1744
+ let rd2 = allocs.next_writable(rd.lo);
1745
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1746
+ let ri1 = allocs.next(ri.hi);
1747
+ let ri2 = allocs.next(ri.lo);
1748
+ debug_assert_eq!(rd1.to_reg(), ri1);
1749
+ debug_assert_eq!(rd2.to_reg(), ri2);
1750
+
1751
+ let opcode = 0xb987; // DLGR
1752
+ let trap_code = TrapCode::IntegerDivisionByZero;
1753
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1754
+ }
1755
+ &Inst::Flogr { rd, rn } => {
1756
+ let rn = allocs.next(rn);
1757
+ let rd1 = allocs.next_writable(rd.hi);
1758
+ let rd2 = allocs.next_writable(rd.lo);
1759
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1760
+
1761
+ let opcode = 0xb983; // FLOGR
1762
+ put(sink, &enc_rre(opcode, rd1.to_reg(), rn));
1763
+ }
1764
+
1765
+ &Inst::ShiftRR {
1766
+ shift_op,
1767
+ rd,
1768
+ rn,
1769
+ shift_imm,
1770
+ shift_reg,
1771
+ } => {
1772
+ let rd = allocs.next_writable(rd);
1773
+ let rn = allocs.next(rn);
1774
+ let shift_reg = allocs.next(shift_reg);
1775
+
1776
+ let opcode = match shift_op {
1777
+ ShiftOp::RotL32 => 0xeb1d, // RLL
1778
+ ShiftOp::RotL64 => 0xeb1c, // RLLG
1779
+ ShiftOp::LShL32 => 0xebdf, // SLLK (SLL ?)
1780
+ ShiftOp::LShL64 => 0xeb0d, // SLLG
1781
+ ShiftOp::LShR32 => 0xebde, // SRLK (SRL ?)
1782
+ ShiftOp::LShR64 => 0xeb0c, // SRLG
1783
+ ShiftOp::AShR32 => 0xebdc, // SRAK (SRA ?)
1784
+ ShiftOp::AShR64 => 0xeb0a, // SRAG
1785
+ };
1786
+ put(
1787
+ sink,
1788
+ &enc_rsy(opcode, rd.to_reg(), rn, shift_reg, shift_imm.into()),
1789
+ );
1790
+ }
1791
+
1792
+ &Inst::RxSBG {
1793
+ op,
1794
+ rd,
1795
+ ri,
1796
+ rn,
1797
+ start_bit,
1798
+ end_bit,
1799
+ rotate_amt,
1800
+ } => {
1801
+ let rd = allocs.next_writable(rd);
1802
+ let ri = allocs.next(ri);
1803
+ debug_assert_eq!(rd.to_reg(), ri);
1804
+ let rn = allocs.next(rn);
1805
+
1806
+ let opcode = match op {
1807
+ RxSBGOp::Insert => 0xec59, // RISBGN
1808
+ RxSBGOp::And => 0xec54, // RNSBG
1809
+ RxSBGOp::Or => 0xec56, // ROSBG
1810
+ RxSBGOp::Xor => 0xec57, // RXSBG
1811
+ };
1812
+ put(
1813
+ sink,
1814
+ &enc_rie_f(
1815
+ opcode,
1816
+ rd.to_reg(),
1817
+ rn,
1818
+ start_bit,
1819
+ end_bit,
1820
+ (rotate_amt as u8) & 63,
1821
+ ),
1822
+ );
1823
+ }
1824
+
1825
+ &Inst::RxSBGTest {
1826
+ op,
1827
+ rd,
1828
+ rn,
1829
+ start_bit,
1830
+ end_bit,
1831
+ rotate_amt,
1832
+ } => {
1833
+ let rd = allocs.next(rd);
1834
+ let rn = allocs.next(rn);
1835
+
1836
+ let opcode = match op {
1837
+ RxSBGOp::And => 0xec54, // RNSBG
1838
+ RxSBGOp::Or => 0xec56, // ROSBG
1839
+ RxSBGOp::Xor => 0xec57, // RXSBG
1840
+ _ => unreachable!(),
1841
+ };
1842
+ put(
1843
+ sink,
1844
+ &enc_rie_f(
1845
+ opcode,
1846
+ rd,
1847
+ rn,
1848
+ start_bit | 0x80,
1849
+ end_bit,
1850
+ (rotate_amt as u8) & 63,
1851
+ ),
1852
+ );
1853
+ }
1854
+
1855
+ &Inst::UnaryRR { op, rd, rn } => {
1856
+ let rd = allocs.next_writable(rd);
1857
+ let rn = allocs.next(rn);
1858
+
1859
+ match op {
1860
+ UnaryOp::Abs32 => {
1861
+ let opcode = 0x10; // LPR
1862
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
1863
+ }
1864
+ UnaryOp::Abs64 => {
1865
+ let opcode = 0xb900; // LPGR
1866
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1867
+ }
1868
+ UnaryOp::Abs64Ext32 => {
1869
+ let opcode = 0xb910; // LPGFR
1870
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1871
+ }
1872
+ UnaryOp::Neg32 => {
1873
+ let opcode = 0x13; // LCR
1874
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
1875
+ }
1876
+ UnaryOp::Neg64 => {
1877
+ let opcode = 0xb903; // LCGR
1878
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1879
+ }
1880
+ UnaryOp::Neg64Ext32 => {
1881
+ let opcode = 0xb913; // LCGFR
1882
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1883
+ }
1884
+ UnaryOp::PopcntByte => {
1885
+ let opcode = 0xb9e1; // POPCNT
1886
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rn, 0, 0));
1887
+ }
1888
+ UnaryOp::PopcntReg => {
1889
+ let opcode = 0xb9e1; // POPCNT
1890
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rn, 8, 0));
1891
+ }
1892
+ UnaryOp::BSwap32 => {
1893
+ let opcode = 0xb91f; // LRVR
1894
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1895
+ }
1896
+ UnaryOp::BSwap64 => {
1897
+ let opcode = 0xb90f; // LRVRG
1898
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1899
+ }
1900
+ }
1901
+ }
1902
+
1903
+ &Inst::Extend {
1904
+ rd,
1905
+ rn,
1906
+ signed,
1907
+ from_bits,
1908
+ to_bits,
1909
+ } => {
1910
+ let rd = allocs.next_writable(rd);
1911
+ let rn = allocs.next(rn);
1912
+
1913
+ let opcode = match (signed, from_bits, to_bits) {
1914
+ (_, 1, 32) => 0xb926, // LBR
1915
+ (_, 1, 64) => 0xb906, // LGBR
1916
+ (false, 8, 32) => 0xb994, // LLCR
1917
+ (false, 8, 64) => 0xb984, // LLGCR
1918
+ (true, 8, 32) => 0xb926, // LBR
1919
+ (true, 8, 64) => 0xb906, // LGBR
1920
+ (false, 16, 32) => 0xb995, // LLHR
1921
+ (false, 16, 64) => 0xb985, // LLGHR
1922
+ (true, 16, 32) => 0xb927, // LHR
1923
+ (true, 16, 64) => 0xb907, // LGHR
1924
+ (false, 32, 64) => 0xb916, // LLGFR
1925
+ (true, 32, 64) => 0xb914, // LGFR
1926
+ _ => panic!(
1927
+ "Unsupported extend combination: signed = {}, from_bits = {}, to_bits = {}",
1928
+ signed, from_bits, to_bits
1929
+ ),
1930
+ };
1931
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1932
+ }
1933
+
1934
+ &Inst::CmpRR { op, rn, rm } => {
1935
+ let rn = allocs.next(rn);
1936
+ let rm = allocs.next(rm);
1937
+
1938
+ let (opcode, is_rre) = match op {
1939
+ CmpOp::CmpS32 => (0x19, false), // CR
1940
+ CmpOp::CmpS64 => (0xb920, true), // CGR
1941
+ CmpOp::CmpS64Ext32 => (0xb930, true), // CGFR
1942
+ CmpOp::CmpL32 => (0x15, false), // CLR
1943
+ CmpOp::CmpL64 => (0xb921, true), // CLGR
1944
+ CmpOp::CmpL64Ext32 => (0xb931, true), // CLGFR
1945
+ _ => unreachable!(),
1946
+ };
1947
+ if is_rre {
1948
+ put(sink, &enc_rre(opcode, rn, rm));
1949
+ } else {
1950
+ put(sink, &enc_rr(opcode, rn, rm));
1951
+ }
1952
+ }
1953
+ &Inst::CmpRX { op, rn, ref mem } => {
1954
+ let rn = allocs.next(rn);
1955
+ let mem = mem.with_allocs(allocs);
1956
+
1957
+ let (opcode_rx, opcode_rxy, opcode_ril) = match op {
1958
+ CmpOp::CmpS32 => (Some(0x59), Some(0xe359), Some(0xc6d)), // C(Y), CRL
1959
+ CmpOp::CmpS32Ext16 => (Some(0x49), Some(0xe379), Some(0xc65)), // CH(Y), CHRL
1960
+ CmpOp::CmpS64 => (None, Some(0xe320), Some(0xc68)), // CG, CGRL
1961
+ CmpOp::CmpS64Ext16 => (None, Some(0xe334), Some(0xc64)), // CGH, CGHRL
1962
+ CmpOp::CmpS64Ext32 => (None, Some(0xe330), Some(0xc6c)), // CGF, CGFRL
1963
+ CmpOp::CmpL32 => (Some(0x55), Some(0xe355), Some(0xc6f)), // CL(Y), CLRL
1964
+ CmpOp::CmpL32Ext16 => (None, None, Some(0xc67)), // CLHRL
1965
+ CmpOp::CmpL64 => (None, Some(0xe321), Some(0xc6a)), // CLG, CLGRL
1966
+ CmpOp::CmpL64Ext16 => (None, None, Some(0xc66)), // CLGHRL
1967
+ CmpOp::CmpL64Ext32 => (None, Some(0xe331), Some(0xc6e)), // CLGF, CLGFRL
1968
+ };
1969
+ mem_emit(
1970
+ rn, &mem, opcode_rx, opcode_rxy, opcode_ril, true, sink, emit_info, state,
1971
+ );
1972
+ }
1973
+ &Inst::CmpRSImm16 { op, rn, imm } => {
1974
+ let rn = allocs.next(rn);
1975
+
1976
+ let opcode = match op {
1977
+ CmpOp::CmpS32 => 0xa7e, // CHI
1978
+ CmpOp::CmpS64 => 0xa7f, // CGHI
1979
+ _ => unreachable!(),
1980
+ };
1981
+ put(sink, &enc_ri_a(opcode, rn, imm as u16));
1982
+ }
1983
+ &Inst::CmpRSImm32 { op, rn, imm } => {
1984
+ let rn = allocs.next(rn);
1985
+
1986
+ let opcode = match op {
1987
+ CmpOp::CmpS32 => 0xc2d, // CFI
1988
+ CmpOp::CmpS64 => 0xc2c, // CGFI
1989
+ _ => unreachable!(),
1990
+ };
1991
+ put(sink, &enc_ril_a(opcode, rn, imm as u32));
1992
+ }
1993
+ &Inst::CmpRUImm32 { op, rn, imm } => {
1994
+ let rn = allocs.next(rn);
1995
+
1996
+ let opcode = match op {
1997
+ CmpOp::CmpL32 => 0xc2f, // CLFI
1998
+ CmpOp::CmpL64 => 0xc2e, // CLGFI
1999
+ _ => unreachable!(),
2000
+ };
2001
+ put(sink, &enc_ril_a(opcode, rn, imm));
2002
+ }
2003
+ &Inst::CmpTrapRR {
2004
+ op,
2005
+ rn,
2006
+ rm,
2007
+ cond,
2008
+ trap_code,
2009
+ } => {
2010
+ let rn = allocs.next(rn);
2011
+ let rm = allocs.next(rm);
2012
+
2013
+ let opcode = match op {
2014
+ CmpOp::CmpS32 => 0xb972, // CRT
2015
+ CmpOp::CmpS64 => 0xb960, // CGRT
2016
+ CmpOp::CmpL32 => 0xb973, // CLRT
2017
+ CmpOp::CmpL64 => 0xb961, // CLGRT
2018
+ _ => unreachable!(),
2019
+ };
2020
+ put_with_trap(
2021
+ sink,
2022
+ &enc_rrf_cde(opcode, rn, rm, cond.bits(), 0),
2023
+ trap_code,
2024
+ );
2025
+ }
2026
+ &Inst::CmpTrapRSImm16 {
2027
+ op,
2028
+ rn,
2029
+ imm,
2030
+ cond,
2031
+ trap_code,
2032
+ } => {
2033
+ let rn = allocs.next(rn);
2034
+
2035
+ let opcode = match op {
2036
+ CmpOp::CmpS32 => 0xec72, // CIT
2037
+ CmpOp::CmpS64 => 0xec70, // CGIT
2038
+ _ => unreachable!(),
2039
+ };
2040
+ put_with_trap(
2041
+ sink,
2042
+ &enc_rie_a(opcode, rn, imm as u16, cond.bits()),
2043
+ trap_code,
2044
+ );
2045
+ }
2046
+ &Inst::CmpTrapRUImm16 {
2047
+ op,
2048
+ rn,
2049
+ imm,
2050
+ cond,
2051
+ trap_code,
2052
+ } => {
2053
+ let rn = allocs.next(rn);
2054
+
2055
+ let opcode = match op {
2056
+ CmpOp::CmpL32 => 0xec73, // CLFIT
2057
+ CmpOp::CmpL64 => 0xec71, // CLGIT
2058
+ _ => unreachable!(),
2059
+ };
2060
+ put_with_trap(sink, &enc_rie_a(opcode, rn, imm, cond.bits()), trap_code);
2061
+ }
2062
+
2063
+ &Inst::AtomicRmw {
2064
+ alu_op,
2065
+ rd,
2066
+ rn,
2067
+ ref mem,
2068
+ } => {
2069
+ let rd = allocs.next_writable(rd);
2070
+ let rn = allocs.next(rn);
2071
+ let mem = mem.with_allocs(allocs);
2072
+
2073
+ let opcode = match alu_op {
2074
+ ALUOp::Add32 => 0xebf8, // LAA
2075
+ ALUOp::Add64 => 0xebe8, // LAAG
2076
+ ALUOp::AddLogical32 => 0xebfa, // LAAL
2077
+ ALUOp::AddLogical64 => 0xebea, // LAALG
2078
+ ALUOp::And32 => 0xebf4, // LAN
2079
+ ALUOp::And64 => 0xebe4, // LANG
2080
+ ALUOp::Orr32 => 0xebf6, // LAO
2081
+ ALUOp::Orr64 => 0xebe6, // LAOG
2082
+ ALUOp::Xor32 => 0xebf7, // LAX
2083
+ ALUOp::Xor64 => 0xebe7, // LAXG
2084
+ _ => unreachable!(),
2085
+ };
2086
+
2087
+ let rd = rd.to_reg();
2088
+ mem_rs_emit(
2089
+ rd,
2090
+ rn,
2091
+ &mem,
2092
+ None,
2093
+ Some(opcode),
2094
+ true,
2095
+ sink,
2096
+ emit_info,
2097
+ state,
2098
+ );
2099
+ }
2100
+ &Inst::Loop { ref body, cond } => {
2101
+ // This sequence is *one* instruction in the vcode, and is expanded only here at
2102
+ // emission time, because it requires branching to internal labels.
2103
+ let loop_label = sink.get_label();
2104
+ let done_label = sink.get_label();
2105
+
2106
+ // Emit label at the start of the loop.
2107
+ sink.bind_label(loop_label, &mut state.ctrl_plane);
2108
+
2109
+ for inst in (&body).into_iter() {
2110
+ match &inst {
2111
+ // Replace a CondBreak with a branch to done_label.
2112
+ &Inst::CondBreak { cond } => {
2113
+ let inst = Inst::OneWayCondBr {
2114
+ target: done_label,
2115
+ cond: *cond,
2116
+ };
2117
+ inst.emit_with_alloc_consumer(allocs, sink, emit_info, state);
2118
+ }
2119
+ _ => inst.emit_with_alloc_consumer(allocs, sink, emit_info, state),
2120
+ };
2121
+ }
2122
+
2123
+ let inst = Inst::OneWayCondBr {
2124
+ target: loop_label,
2125
+ cond,
2126
+ };
2127
+ inst.emit(&[], sink, emit_info, state);
2128
+
2129
+ // Emit label at the end of the loop.
2130
+ sink.bind_label(done_label, &mut state.ctrl_plane);
2131
+ }
2132
+ &Inst::CondBreak { .. } => unreachable!(), // Only valid inside a Loop.
2133
+ &Inst::AtomicCas32 {
2134
+ rd,
2135
+ ri,
2136
+ rn,
2137
+ ref mem,
2138
+ }
2139
+ | &Inst::AtomicCas64 {
2140
+ rd,
2141
+ ri,
2142
+ rn,
2143
+ ref mem,
2144
+ } => {
2145
+ let rd = allocs.next_writable(rd);
2146
+ let ri = allocs.next(ri);
2147
+ debug_assert_eq!(rd.to_reg(), ri);
2148
+ let rn = allocs.next(rn);
2149
+ let mem = mem.with_allocs(allocs);
2150
+
2151
+ let (opcode_rs, opcode_rsy) = match self {
2152
+ &Inst::AtomicCas32 { .. } => (Some(0xba), Some(0xeb14)), // CS(Y)
2153
+ &Inst::AtomicCas64 { .. } => (None, Some(0xeb30)), // CSG
2154
+ _ => unreachable!(),
2155
+ };
2156
+
2157
+ let rd = rd.to_reg();
2158
+ mem_rs_emit(
2159
+ rd, rn, &mem, opcode_rs, opcode_rsy, true, sink, emit_info, state,
2160
+ );
2161
+ }
2162
+ &Inst::Fence => {
2163
+ put(sink, &enc_e(0x07e0));
2164
+ }
2165
+
2166
+ &Inst::Load32 { rd, ref mem }
2167
+ | &Inst::Load32ZExt8 { rd, ref mem }
2168
+ | &Inst::Load32SExt8 { rd, ref mem }
2169
+ | &Inst::Load32ZExt16 { rd, ref mem }
2170
+ | &Inst::Load32SExt16 { rd, ref mem }
2171
+ | &Inst::Load64 { rd, ref mem }
2172
+ | &Inst::Load64ZExt8 { rd, ref mem }
2173
+ | &Inst::Load64SExt8 { rd, ref mem }
2174
+ | &Inst::Load64ZExt16 { rd, ref mem }
2175
+ | &Inst::Load64SExt16 { rd, ref mem }
2176
+ | &Inst::Load64ZExt32 { rd, ref mem }
2177
+ | &Inst::Load64SExt32 { rd, ref mem }
2178
+ | &Inst::LoadRev16 { rd, ref mem }
2179
+ | &Inst::LoadRev32 { rd, ref mem }
2180
+ | &Inst::LoadRev64 { rd, ref mem } => {
2181
+ let rd = allocs.next_writable(rd);
2182
+ let mem = mem.with_allocs(allocs);
2183
+
2184
+ let (opcode_rx, opcode_rxy, opcode_ril) = match self {
2185
+ &Inst::Load32 { .. } => (Some(0x58), Some(0xe358), Some(0xc4d)), // L(Y), LRL
2186
+ &Inst::Load32ZExt8 { .. } => (None, Some(0xe394), None), // LLC
2187
+ &Inst::Load32SExt8 { .. } => (None, Some(0xe376), None), // LB
2188
+ &Inst::Load32ZExt16 { .. } => (None, Some(0xe395), Some(0xc42)), // LLH, LLHRL
2189
+ &Inst::Load32SExt16 { .. } => (Some(0x48), Some(0xe378), Some(0xc45)), // LH(Y), LHRL
2190
+ &Inst::Load64 { .. } => (None, Some(0xe304), Some(0xc48)), // LG, LGRL
2191
+ &Inst::Load64ZExt8 { .. } => (None, Some(0xe390), None), // LLGC
2192
+ &Inst::Load64SExt8 { .. } => (None, Some(0xe377), None), // LGB
2193
+ &Inst::Load64ZExt16 { .. } => (None, Some(0xe391), Some(0xc46)), // LLGH, LLGHRL
2194
+ &Inst::Load64SExt16 { .. } => (None, Some(0xe315), Some(0xc44)), // LGH, LGHRL
2195
+ &Inst::Load64ZExt32 { .. } => (None, Some(0xe316), Some(0xc4e)), // LLGF, LLGFRL
2196
+ &Inst::Load64SExt32 { .. } => (None, Some(0xe314), Some(0xc4c)), // LGF, LGFRL
2197
+ &Inst::LoadRev16 { .. } => (None, Some(0xe31f), None), // LRVH
2198
+ &Inst::LoadRev32 { .. } => (None, Some(0xe31e), None), // LRV
2199
+ &Inst::LoadRev64 { .. } => (None, Some(0xe30f), None), // LRVG
2200
+ _ => unreachable!(),
2201
+ };
2202
+ let rd = rd.to_reg();
2203
+ mem_emit(
2204
+ rd, &mem, opcode_rx, opcode_rxy, opcode_ril, true, sink, emit_info, state,
2205
+ );
2206
+ }
2207
+
2208
+ &Inst::Store8 { rd, ref mem }
2209
+ | &Inst::Store16 { rd, ref mem }
2210
+ | &Inst::Store32 { rd, ref mem }
2211
+ | &Inst::Store64 { rd, ref mem }
2212
+ | &Inst::StoreRev16 { rd, ref mem }
2213
+ | &Inst::StoreRev32 { rd, ref mem }
2214
+ | &Inst::StoreRev64 { rd, ref mem } => {
2215
+ let rd = allocs.next(rd);
2216
+ let mem = mem.with_allocs(allocs);
2217
+
2218
+ let (opcode_rx, opcode_rxy, opcode_ril) = match self {
2219
+ &Inst::Store8 { .. } => (Some(0x42), Some(0xe372), None), // STC(Y)
2220
+ &Inst::Store16 { .. } => (Some(0x40), Some(0xe370), Some(0xc47)), // STH(Y), STHRL
2221
+ &Inst::Store32 { .. } => (Some(0x50), Some(0xe350), Some(0xc4f)), // ST(Y), STRL
2222
+ &Inst::Store64 { .. } => (None, Some(0xe324), Some(0xc4b)), // STG, STGRL
2223
+ &Inst::StoreRev16 { .. } => (None, Some(0xe33f), None), // STRVH
2224
+ &Inst::StoreRev32 { .. } => (None, Some(0xe33e), None), // STRV
2225
+ &Inst::StoreRev64 { .. } => (None, Some(0xe32f), None), // STRVG
2226
+ _ => unreachable!(),
2227
+ };
2228
+ mem_emit(
2229
+ rd, &mem, opcode_rx, opcode_rxy, opcode_ril, true, sink, emit_info, state,
2230
+ );
2231
+ }
2232
+ &Inst::StoreImm8 { imm, ref mem } => {
2233
+ let mem = mem.with_allocs(allocs);
2234
+
2235
+ let opcode_si = 0x92; // MVI
2236
+ let opcode_siy = 0xeb52; // MVIY
2237
+ mem_imm8_emit(
2238
+ imm, &mem, opcode_si, opcode_siy, true, sink, emit_info, state,
2239
+ );
2240
+ }
2241
+ &Inst::StoreImm16 { imm, ref mem }
2242
+ | &Inst::StoreImm32SExt16 { imm, ref mem }
2243
+ | &Inst::StoreImm64SExt16 { imm, ref mem } => {
2244
+ let mem = mem.with_allocs(allocs);
2245
+
2246
+ let opcode = match self {
2247
+ &Inst::StoreImm16 { .. } => 0xe544, // MVHHI
2248
+ &Inst::StoreImm32SExt16 { .. } => 0xe54c, // MVHI
2249
+ &Inst::StoreImm64SExt16 { .. } => 0xe548, // MVGHI
2250
+ _ => unreachable!(),
2251
+ };
2252
+ mem_imm16_emit(imm, &mem, opcode, true, sink, emit_info, state);
2253
+ }
2254
+ &Inst::Mvc {
2255
+ ref dst,
2256
+ ref src,
2257
+ len_minus_one,
2258
+ } => {
2259
+ let dst = dst.with_allocs(allocs);
2260
+ let src = src.with_allocs(allocs);
2261
+ let opcode = 0xd2; // MVC
2262
+ mem_mem_emit(&dst, &src, len_minus_one, opcode, true, sink, state);
2263
+ }
2264
+
2265
+ &Inst::LoadMultiple64 { rt, rt2, ref mem } => {
2266
+ let mem = mem.with_allocs(allocs);
2267
+
2268
+ let opcode = 0xeb04; // LMG
2269
+ let rt = rt.to_reg();
2270
+ let rt2 = rt2.to_reg();
2271
+ mem_rs_emit(
2272
+ rt,
2273
+ rt2,
2274
+ &mem,
2275
+ None,
2276
+ Some(opcode),
2277
+ true,
2278
+ sink,
2279
+ emit_info,
2280
+ state,
2281
+ );
2282
+ }
2283
+ &Inst::StoreMultiple64 { rt, rt2, ref mem } => {
2284
+ let mem = mem.with_allocs(allocs);
2285
+
2286
+ let opcode = 0xeb24; // STMG
2287
+ mem_rs_emit(
2288
+ rt,
2289
+ rt2,
2290
+ &mem,
2291
+ None,
2292
+ Some(opcode),
2293
+ true,
2294
+ sink,
2295
+ emit_info,
2296
+ state,
2297
+ );
2298
+ }
2299
+
2300
+ &Inst::LoadAddr { rd, ref mem } => {
2301
+ let rd = allocs.next_writable(rd);
2302
+ let mem = mem.with_allocs(allocs);
2303
+
2304
+ let opcode_rx = Some(0x41); // LA
2305
+ let opcode_rxy = Some(0xe371); // LAY
2306
+ let opcode_ril = Some(0xc00); // LARL
2307
+ let rd = rd.to_reg();
2308
+ mem_emit(
2309
+ rd, &mem, opcode_rx, opcode_rxy, opcode_ril, false, sink, emit_info, state,
2310
+ );
2311
+ }
2312
+
2313
+ &Inst::Mov64 { rd, rm } => {
2314
+ let rd = allocs.next_writable(rd);
2315
+ let rm = allocs.next(rm);
2316
+
2317
+ let opcode = 0xb904; // LGR
2318
+ put(sink, &enc_rre(opcode, rd.to_reg(), rm));
2319
+ }
2320
+ &Inst::MovPReg { rd, rm } => {
2321
+ let rm: Reg = rm.into();
2322
+ debug_assert!([regs::gpr(0), regs::gpr(14), regs::gpr(15)].contains(&rm));
2323
+ let rd = allocs.next_writable(rd);
2324
+ Inst::Mov64 { rd, rm }.emit(&[], sink, emit_info, state);
2325
+ }
2326
+ &Inst::Mov32 { rd, rm } => {
2327
+ let rd = allocs.next_writable(rd);
2328
+ let rm = allocs.next(rm);
2329
+
2330
+ let opcode = 0x18; // LR
2331
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
2332
+ }
2333
+ &Inst::Mov32Imm { rd, imm } => {
2334
+ let rd = allocs.next_writable(rd);
2335
+
2336
+ let opcode = 0xc09; // IILF
2337
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm));
2338
+ }
2339
+ &Inst::Mov32SImm16 { rd, imm } => {
2340
+ let rd = allocs.next_writable(rd);
2341
+
2342
+ let opcode = 0xa78; // LHI
2343
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm as u16));
2344
+ }
2345
+ &Inst::Mov64SImm16 { rd, imm } => {
2346
+ let rd = allocs.next_writable(rd);
2347
+
2348
+ let opcode = 0xa79; // LGHI
2349
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm as u16));
2350
+ }
2351
+ &Inst::Mov64SImm32 { rd, imm } => {
2352
+ let rd = allocs.next_writable(rd);
2353
+
2354
+ let opcode = 0xc01; // LGFI
2355
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm as u32));
2356
+ }
2357
+ &Inst::CMov32 { rd, cond, ri, rm } => {
2358
+ let rd = allocs.next_writable(rd);
2359
+ let ri = allocs.next(ri);
2360
+ debug_assert_eq!(rd.to_reg(), ri);
2361
+ let rm = allocs.next(rm);
2362
+
2363
+ let opcode = 0xb9f2; // LOCR
2364
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rm, cond.bits(), 0));
2365
+ }
2366
+ &Inst::CMov64 { rd, cond, ri, rm } => {
2367
+ let rd = allocs.next_writable(rd);
2368
+ let ri = allocs.next(ri);
2369
+ debug_assert_eq!(rd.to_reg(), ri);
2370
+ let rm = allocs.next(rm);
2371
+
2372
+ let opcode = 0xb9e2; // LOCGR
2373
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rm, cond.bits(), 0));
2374
+ }
2375
+ &Inst::CMov32SImm16 { rd, cond, ri, imm } => {
2376
+ let rd = allocs.next_writable(rd);
2377
+ let ri = allocs.next(ri);
2378
+ debug_assert_eq!(rd.to_reg(), ri);
2379
+
2380
+ let opcode = 0xec42; // LOCHI
2381
+ put(
2382
+ sink,
2383
+ &enc_rie_g(opcode, rd.to_reg(), imm as u16, cond.bits()),
2384
+ );
2385
+ }
2386
+ &Inst::CMov64SImm16 { rd, cond, ri, imm } => {
2387
+ let rd = allocs.next_writable(rd);
2388
+ let ri = allocs.next(ri);
2389
+ debug_assert_eq!(rd.to_reg(), ri);
2390
+
2391
+ let opcode = 0xec46; // LOCGHI
2392
+ put(
2393
+ sink,
2394
+ &enc_rie_g(opcode, rd.to_reg(), imm as u16, cond.bits()),
2395
+ );
2396
+ }
2397
+ &Inst::Mov64UImm16Shifted { rd, imm } => {
2398
+ let rd = allocs.next_writable(rd);
2399
+
2400
+ let opcode = match imm.shift {
2401
+ 0 => 0xa5f, // LLILL
2402
+ 1 => 0xa5e, // LLILH
2403
+ 2 => 0xa5d, // LLIHL
2404
+ 3 => 0xa5c, // LLIHH
2405
+ _ => unreachable!(),
2406
+ };
2407
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm.bits));
2408
+ }
2409
+ &Inst::Mov64UImm32Shifted { rd, imm } => {
2410
+ let rd = allocs.next_writable(rd);
2411
+
2412
+ let opcode = match imm.shift {
2413
+ 0 => 0xc0f, // LLILF
2414
+ 1 => 0xc0e, // LLIHF
2415
+ _ => unreachable!(),
2416
+ };
2417
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm.bits));
2418
+ }
2419
+ &Inst::Insert64UImm16Shifted { rd, ri, imm } => {
2420
+ let rd = allocs.next_writable(rd);
2421
+ let ri = allocs.next(ri);
2422
+ debug_assert_eq!(rd.to_reg(), ri);
2423
+
2424
+ let opcode = match imm.shift {
2425
+ 0 => 0xa53, // IILL
2426
+ 1 => 0xa52, // IILH
2427
+ 2 => 0xa51, // IIHL
2428
+ 3 => 0xa50, // IIHH
2429
+ _ => unreachable!(),
2430
+ };
2431
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm.bits));
2432
+ }
2433
+ &Inst::Insert64UImm32Shifted { rd, ri, imm } => {
2434
+ let rd = allocs.next_writable(rd);
2435
+ let ri = allocs.next(ri);
2436
+ debug_assert_eq!(rd.to_reg(), ri);
2437
+
2438
+ let opcode = match imm.shift {
2439
+ 0 => 0xc09, // IILF
2440
+ 1 => 0xc08, // IIHF
2441
+ _ => unreachable!(),
2442
+ };
2443
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm.bits));
2444
+ }
2445
+ &Inst::LoadAR { rd, ar } => {
2446
+ let rd = allocs.next_writable(rd);
2447
+ let opcode = 0xb24f; // EAR
2448
+ put(sink, &enc_rre(opcode, rd.to_reg(), gpr(ar)));
2449
+ }
2450
+
2451
+ &Inst::InsertAR { rd, ri, ar } => {
2452
+ let rd = allocs.next_writable(rd);
2453
+ let ri = allocs.next(ri);
2454
+ debug_assert_eq!(rd.to_reg(), ri);
2455
+
2456
+ let opcode = 0xb24f; // EAR
2457
+ put(sink, &enc_rre(opcode, rd.to_reg(), gpr(ar)));
2458
+ }
2459
+ &Inst::LoadSymbolReloc {
2460
+ rd,
2461
+ ref symbol_reloc,
2462
+ } => {
2463
+ let rd = allocs.next_writable(rd);
2464
+
2465
+ let opcode = 0xa75; // BRAS
2466
+ let reg = writable_spilltmp_reg().to_reg();
2467
+ put(sink, &enc_ri_b(opcode, reg, 12));
2468
+ let (reloc, name, offset) = match &**symbol_reloc {
2469
+ SymbolReloc::Absolute { name, offset } => (Reloc::Abs8, name, *offset),
2470
+ SymbolReloc::TlsGd { name } => (Reloc::S390xTlsGd64, name, 0),
2471
+ };
2472
+ sink.add_reloc(reloc, name, offset);
2473
+ sink.put8(0);
2474
+ let inst = Inst::Load64 {
2475
+ rd,
2476
+ mem: MemArg::reg(reg, MemFlags::trusted()),
2477
+ };
2478
+ inst.emit(&[], sink, emit_info, state);
2479
+ }
2480
+
2481
+ &Inst::FpuMove32 { rd, rn } => {
2482
+ let rd = allocs.next_writable(rd);
2483
+ let rn = allocs.next(rn);
2484
+
2485
+ if is_fpr(rd.to_reg()) && is_fpr(rn) {
2486
+ let opcode = 0x38; // LER
2487
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
2488
+ } else {
2489
+ let opcode = 0xe756; // VLR
2490
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, 0, 0, 0));
2491
+ }
2492
+ }
2493
+ &Inst::FpuMove64 { rd, rn } => {
2494
+ let rd = allocs.next_writable(rd);
2495
+ let rn = allocs.next(rn);
2496
+
2497
+ if is_fpr(rd.to_reg()) && is_fpr(rn) {
2498
+ let opcode = 0x28; // LDR
2499
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
2500
+ } else {
2501
+ let opcode = 0xe756; // VLR
2502
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, 0, 0, 0));
2503
+ }
2504
+ }
2505
+ &Inst::FpuCMov32 { rd, cond, ri, rm } => {
2506
+ let rd = allocs.next_writable(rd);
2507
+ let ri = allocs.next(ri);
2508
+ debug_assert_eq!(rd.to_reg(), ri);
2509
+ let rm = allocs.next(rm);
2510
+
2511
+ if is_fpr(rd.to_reg()) && is_fpr(rm) {
2512
+ let opcode = 0xa74; // BCR
2513
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 2));
2514
+ let opcode = 0x38; // LER
2515
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
2516
+ } else {
2517
+ let opcode = 0xa74; // BCR
2518
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 6));
2519
+ let opcode = 0xe756; // VLR
2520
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rm, 0, 0, 0));
2521
+ }
2522
+ }
2523
+ &Inst::FpuCMov64 { rd, cond, ri, rm } => {
2524
+ let rd = allocs.next_writable(rd);
2525
+ let ri = allocs.next(ri);
2526
+ debug_assert_eq!(rd.to_reg(), ri);
2527
+ let rm = allocs.next(rm);
2528
+
2529
+ if is_fpr(rd.to_reg()) && is_fpr(rm) {
2530
+ let opcode = 0xa74; // BCR
2531
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 2));
2532
+ let opcode = 0x28; // LDR
2533
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
2534
+ } else {
2535
+ let opcode = 0xa74; // BCR
2536
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 6));
2537
+ let opcode = 0xe756; // VLR
2538
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rm, 0, 0, 0));
2539
+ }
2540
+ }
2541
+ &Inst::LoadFpuConst32 { rd, const_data } => {
2542
+ let rd = allocs.next_writable(rd);
2543
+
2544
+ let opcode = 0xa75; // BRAS
2545
+ let reg = writable_spilltmp_reg().to_reg();
2546
+ put(sink, &enc_ri_b(opcode, reg, 8));
2547
+ sink.put4(const_data.swap_bytes());
2548
+ let inst = Inst::VecLoadLaneUndef {
2549
+ size: 32,
2550
+ rd,
2551
+ mem: MemArg::reg(reg, MemFlags::trusted()),
2552
+ lane_imm: 0,
2553
+ };
2554
+ inst.emit(&[], sink, emit_info, state);
2555
+ }
2556
+ &Inst::LoadFpuConst64 { rd, const_data } => {
2557
+ let rd = allocs.next_writable(rd);
2558
+
2559
+ let opcode = 0xa75; // BRAS
2560
+ let reg = writable_spilltmp_reg().to_reg();
2561
+ put(sink, &enc_ri_b(opcode, reg, 12));
2562
+ sink.put8(const_data.swap_bytes());
2563
+ let inst = Inst::VecLoadLaneUndef {
2564
+ size: 64,
2565
+ rd,
2566
+ mem: MemArg::reg(reg, MemFlags::trusted()),
2567
+ lane_imm: 0,
2568
+ };
2569
+ inst.emit(&[], sink, emit_info, state);
2570
+ }
2571
+ &Inst::FpuRR { fpu_op, rd, rn } => {
2572
+ let rd = allocs.next_writable(rd);
2573
+ let rn = allocs.next(rn);
2574
+
2575
+ let (opcode, m3, m4, m5, opcode_fpr) = match fpu_op {
2576
+ FPUOp1::Abs32 => (0xe7cc, 2, 8, 2, Some(0xb300)), // WFPSO, LPEBR
2577
+ FPUOp1::Abs64 => (0xe7cc, 3, 8, 2, Some(0xb310)), // WFPSO, LPDBR
2578
+ FPUOp1::Abs32x4 => (0xe7cc, 2, 0, 2, None), // VFPSO
2579
+ FPUOp1::Abs64x2 => (0xe7cc, 3, 0, 2, None), // VFPSO
2580
+ FPUOp1::Neg32 => (0xe7cc, 2, 8, 0, Some(0xb303)), // WFPSO, LCEBR
2581
+ FPUOp1::Neg64 => (0xe7cc, 3, 8, 0, Some(0xb313)), // WFPSO, LCDBR
2582
+ FPUOp1::Neg32x4 => (0xe7cc, 2, 0, 0, None), // VFPSO
2583
+ FPUOp1::Neg64x2 => (0xe7cc, 3, 0, 0, None), // VFPSO
2584
+ FPUOp1::NegAbs32 => (0xe7cc, 2, 8, 1, Some(0xb301)), // WFPSO, LNEBR
2585
+ FPUOp1::NegAbs64 => (0xe7cc, 3, 8, 1, Some(0xb311)), // WFPSO, LNDBR
2586
+ FPUOp1::NegAbs32x4 => (0xe7cc, 2, 0, 1, None), // VFPSO
2587
+ FPUOp1::NegAbs64x2 => (0xe7cc, 3, 0, 1, None), // VFPSO
2588
+ FPUOp1::Sqrt32 => (0xe7ce, 2, 8, 0, Some(0xb314)), // WFSQ, SQEBR
2589
+ FPUOp1::Sqrt64 => (0xe7ce, 3, 8, 0, Some(0xb315)), // WFSQ, SQDBR
2590
+ FPUOp1::Sqrt32x4 => (0xe7ce, 2, 0, 0, None), // VFSQ
2591
+ FPUOp1::Sqrt64x2 => (0xe7ce, 3, 0, 0, None), // VFSQ
2592
+ FPUOp1::Cvt32To64 => (0xe7c4, 2, 8, 0, Some(0xb304)), // WFLL, LDEBR
2593
+ FPUOp1::Cvt32x4To64x2 => (0xe7c4, 2, 0, 0, None), // VFLL
2594
+ };
2595
+ if m4 == 8 && is_fpr(rd.to_reg()) && is_fpr(rn) {
2596
+ put(sink, &enc_rre(opcode_fpr.unwrap(), rd.to_reg(), rn));
2597
+ } else {
2598
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, m3, m4, m5));
2599
+ }
2600
+ }
2601
+ &Inst::FpuRRR { fpu_op, rd, rn, rm } => {
2602
+ let rd = allocs.next_writable(rd);
2603
+ let rn = allocs.next(rn);
2604
+ let rm = allocs.next(rm);
2605
+
2606
+ let (opcode, m4, m5, m6, opcode_fpr) = match fpu_op {
2607
+ FPUOp2::Add32 => (0xe7e3, 2, 8, 0, Some(0xb30a)), // WFA, AEBR
2608
+ FPUOp2::Add64 => (0xe7e3, 3, 8, 0, Some(0xb31a)), // WFA, ADBR
2609
+ FPUOp2::Add32x4 => (0xe7e3, 2, 0, 0, None), // VFA
2610
+ FPUOp2::Add64x2 => (0xe7e3, 3, 0, 0, None), // VFA
2611
+ FPUOp2::Sub32 => (0xe7e2, 2, 8, 0, Some(0xb30b)), // WFS, SEBR
2612
+ FPUOp2::Sub64 => (0xe7e2, 3, 8, 0, Some(0xb31b)), // WFS, SDBR
2613
+ FPUOp2::Sub32x4 => (0xe7e2, 2, 0, 0, None), // VFS
2614
+ FPUOp2::Sub64x2 => (0xe7e2, 3, 0, 0, None), // VFS
2615
+ FPUOp2::Mul32 => (0xe7e7, 2, 8, 0, Some(0xb317)), // WFM, MEEBR
2616
+ FPUOp2::Mul64 => (0xe7e7, 3, 8, 0, Some(0xb31c)), // WFM, MDBR
2617
+ FPUOp2::Mul32x4 => (0xe7e7, 2, 0, 0, None), // VFM
2618
+ FPUOp2::Mul64x2 => (0xe7e7, 3, 0, 0, None), // VFM
2619
+ FPUOp2::Div32 => (0xe7e5, 2, 8, 0, Some(0xb30d)), // WFD, DEBR
2620
+ FPUOp2::Div64 => (0xe7e5, 3, 8, 0, Some(0xb31d)), // WFD, DDBR
2621
+ FPUOp2::Div32x4 => (0xe7e5, 2, 0, 0, None), // VFD
2622
+ FPUOp2::Div64x2 => (0xe7e5, 3, 0, 0, None), // VFD
2623
+ FPUOp2::Max32 => (0xe7ef, 2, 8, 1, None), // WFMAX
2624
+ FPUOp2::Max64 => (0xe7ef, 3, 8, 1, None), // WFMAX
2625
+ FPUOp2::Max32x4 => (0xe7ef, 2, 0, 1, None), // VFMAX
2626
+ FPUOp2::Max64x2 => (0xe7ef, 3, 0, 1, None), // VFMAX
2627
+ FPUOp2::Min32 => (0xe7ee, 2, 8, 1, None), // WFMIN
2628
+ FPUOp2::Min64 => (0xe7ee, 3, 8, 1, None), // WFMIN
2629
+ FPUOp2::Min32x4 => (0xe7ee, 2, 0, 1, None), // VFMIN
2630
+ FPUOp2::Min64x2 => (0xe7ee, 3, 0, 1, None), // VFMIN
2631
+ FPUOp2::MaxPseudo32 => (0xe7ef, 2, 8, 3, None), // WFMAX
2632
+ FPUOp2::MaxPseudo64 => (0xe7ef, 3, 8, 3, None), // WFMAX
2633
+ FPUOp2::MaxPseudo32x4 => (0xe7ef, 2, 0, 3, None), // VFMAX
2634
+ FPUOp2::MaxPseudo64x2 => (0xe7ef, 3, 0, 3, None), // VFMAX
2635
+ FPUOp2::MinPseudo32 => (0xe7ee, 2, 8, 3, None), // WFMIN
2636
+ FPUOp2::MinPseudo64 => (0xe7ee, 3, 8, 3, None), // WFMIN
2637
+ FPUOp2::MinPseudo32x4 => (0xe7ee, 2, 0, 3, None), // VFMIN
2638
+ FPUOp2::MinPseudo64x2 => (0xe7ee, 3, 0, 3, None), // VFMIN
2639
+ };
2640
+ if m5 == 8 && opcode_fpr.is_some() && rd.to_reg() == rn && is_fpr(rn) && is_fpr(rm)
2641
+ {
2642
+ put(sink, &enc_rre(opcode_fpr.unwrap(), rd.to_reg(), rm));
2643
+ } else {
2644
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, m5, m6));
2645
+ }
2646
+ }
2647
+ &Inst::FpuRRRR {
2648
+ fpu_op,
2649
+ rd,
2650
+ rn,
2651
+ rm,
2652
+ ra,
2653
+ } => {
2654
+ let rd = allocs.next_writable(rd);
2655
+ let rn = allocs.next(rn);
2656
+ let rm = allocs.next(rm);
2657
+ let ra = allocs.next(ra);
2658
+
2659
+ let (opcode, m5, m6, opcode_fpr) = match fpu_op {
2660
+ FPUOp3::MAdd32 => (0xe78f, 8, 2, Some(0xb30e)), // WFMA, MAEBR
2661
+ FPUOp3::MAdd64 => (0xe78f, 8, 3, Some(0xb31e)), // WFMA, MADBR
2662
+ FPUOp3::MAdd32x4 => (0xe78f, 0, 2, None), // VFMA
2663
+ FPUOp3::MAdd64x2 => (0xe78f, 0, 3, None), // VFMA
2664
+ FPUOp3::MSub32 => (0xe78e, 8, 2, Some(0xb30f)), // WFMS, MSEBR
2665
+ FPUOp3::MSub64 => (0xe78e, 8, 3, Some(0xb31f)), // WFMS, MSDBR
2666
+ FPUOp3::MSub32x4 => (0xe78e, 0, 2, None), // VFMS
2667
+ FPUOp3::MSub64x2 => (0xe78e, 0, 3, None), // VFMS
2668
+ };
2669
+ if m5 == 8 && rd.to_reg() == ra && is_fpr(rn) && is_fpr(rm) && is_fpr(ra) {
2670
+ put(sink, &enc_rrd(opcode_fpr.unwrap(), rd.to_reg(), rm, rn));
2671
+ } else {
2672
+ put(sink, &enc_vrr_e(opcode, rd.to_reg(), rn, rm, ra, m5, m6));
2673
+ }
2674
+ }
2675
+ &Inst::FpuRound { op, mode, rd, rn } => {
2676
+ let rd = allocs.next_writable(rd);
2677
+ let rn = allocs.next(rn);
2678
+
2679
+ let mode = match mode {
2680
+ FpuRoundMode::Current => 0,
2681
+ FpuRoundMode::ToNearest => 1,
2682
+ FpuRoundMode::ShorterPrecision => 3,
2683
+ FpuRoundMode::ToNearestTiesToEven => 4,
2684
+ FpuRoundMode::ToZero => 5,
2685
+ FpuRoundMode::ToPosInfinity => 6,
2686
+ FpuRoundMode::ToNegInfinity => 7,
2687
+ };
2688
+ let (opcode, m3, m4, opcode_fpr) = match op {
2689
+ FpuRoundOp::Cvt64To32 => (0xe7c5, 3, 8, Some(0xb344)), // WFLR, LEDBR(A)
2690
+ FpuRoundOp::Cvt64x2To32x4 => (0xe7c5, 3, 0, None), // VFLR
2691
+ FpuRoundOp::Round32 => (0xe7c7, 2, 8, Some(0xb357)), // WFI, FIEBR
2692
+ FpuRoundOp::Round64 => (0xe7c7, 3, 8, Some(0xb35f)), // WFI, FIDBR
2693
+ FpuRoundOp::Round32x4 => (0xe7c7, 2, 0, None), // VFI
2694
+ FpuRoundOp::Round64x2 => (0xe7c7, 3, 0, None), // VFI
2695
+ FpuRoundOp::ToSInt32 => (0xe7c2, 2, 8, None), // WCSFP
2696
+ FpuRoundOp::ToSInt64 => (0xe7c2, 3, 8, None), // WCSFP
2697
+ FpuRoundOp::ToUInt32 => (0xe7c0, 2, 8, None), // WCLFP
2698
+ FpuRoundOp::ToUInt64 => (0xe7c0, 3, 8, None), // WCLFP
2699
+ FpuRoundOp::ToSInt32x4 => (0xe7c2, 2, 0, None), // VCSFP
2700
+ FpuRoundOp::ToSInt64x2 => (0xe7c2, 3, 0, None), // VCSFP
2701
+ FpuRoundOp::ToUInt32x4 => (0xe7c0, 2, 0, None), // VCLFP
2702
+ FpuRoundOp::ToUInt64x2 => (0xe7c0, 3, 0, None), // VCLFP
2703
+ FpuRoundOp::FromSInt32 => (0xe7c3, 2, 8, None), // WCFPS
2704
+ FpuRoundOp::FromSInt64 => (0xe7c3, 3, 8, None), // WCFPS
2705
+ FpuRoundOp::FromUInt32 => (0xe7c1, 2, 8, None), // WCFPL
2706
+ FpuRoundOp::FromUInt64 => (0xe7c1, 3, 8, None), // WCFPL
2707
+ FpuRoundOp::FromSInt32x4 => (0xe7c3, 2, 0, None), // VCFPS
2708
+ FpuRoundOp::FromSInt64x2 => (0xe7c3, 3, 0, None), // VCFPS
2709
+ FpuRoundOp::FromUInt32x4 => (0xe7c1, 2, 0, None), // VCFPL
2710
+ FpuRoundOp::FromUInt64x2 => (0xe7c1, 3, 0, None), // VCFPL
2711
+ };
2712
+ if m4 == 8 && opcode_fpr.is_some() && is_fpr(rd.to_reg()) && is_fpr(rn) {
2713
+ put(
2714
+ sink,
2715
+ &enc_rrf_cde(opcode_fpr.unwrap(), rd.to_reg(), rn, mode, 0),
2716
+ );
2717
+ } else {
2718
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, m3, m4, mode));
2719
+ }
2720
+ }
2721
+ &Inst::FpuCmp32 { rn, rm } => {
2722
+ let rn = allocs.next(rn);
2723
+ let rm = allocs.next(rm);
2724
+
2725
+ if is_fpr(rn) && is_fpr(rm) {
2726
+ let opcode = 0xb309; // CEBR
2727
+ put(sink, &enc_rre(opcode, rn, rm));
2728
+ } else {
2729
+ let opcode = 0xe7cb; // WFC
2730
+ put(sink, &enc_vrr_a(opcode, rn, rm, 2, 0, 0));
2731
+ }
2732
+ }
2733
+ &Inst::FpuCmp64 { rn, rm } => {
2734
+ let rn = allocs.next(rn);
2735
+ let rm = allocs.next(rm);
2736
+
2737
+ if is_fpr(rn) && is_fpr(rm) {
2738
+ let opcode = 0xb319; // CDBR
2739
+ put(sink, &enc_rre(opcode, rn, rm));
2740
+ } else {
2741
+ let opcode = 0xe7cb; // WFC
2742
+ put(sink, &enc_vrr_a(opcode, rn, rm, 3, 0, 0));
2743
+ }
2744
+ }
2745
+
2746
+ &Inst::VecRRR { op, rd, rn, rm } => {
2747
+ let rd = allocs.next_writable(rd);
2748
+ let rn = allocs.next(rn);
2749
+ let rm = allocs.next(rm);
2750
+
2751
+ let (opcode, m4) = match op {
2752
+ VecBinaryOp::Add8x16 => (0xe7f3, 0), // VAB
2753
+ VecBinaryOp::Add16x8 => (0xe7f3, 1), // VAH
2754
+ VecBinaryOp::Add32x4 => (0xe7f3, 2), // VAF
2755
+ VecBinaryOp::Add64x2 => (0xe7f3, 3), // VAG
2756
+ VecBinaryOp::Add128 => (0xe7f3, 4), // VAQ
2757
+ VecBinaryOp::Sub8x16 => (0xe7f7, 0), // VSB
2758
+ VecBinaryOp::Sub16x8 => (0xe7f7, 1), // VSH
2759
+ VecBinaryOp::Sub32x4 => (0xe7f7, 2), // VSF
2760
+ VecBinaryOp::Sub64x2 => (0xe7f7, 3), // VSG
2761
+ VecBinaryOp::Sub128 => (0xe7f7, 4), // VSQ
2762
+ VecBinaryOp::Mul8x16 => (0xe7a2, 0), // VMLB
2763
+ VecBinaryOp::Mul16x8 => (0xe7a2, 1), // VMLHW
2764
+ VecBinaryOp::Mul32x4 => (0xe7a2, 2), // VMLF
2765
+ VecBinaryOp::UMulHi8x16 => (0xe7a1, 0), // VMLHB
2766
+ VecBinaryOp::UMulHi16x8 => (0xe7a1, 1), // VMLHH
2767
+ VecBinaryOp::UMulHi32x4 => (0xe7a1, 2), // VMLHF
2768
+ VecBinaryOp::SMulHi8x16 => (0xe7a3, 0), // VMHB
2769
+ VecBinaryOp::SMulHi16x8 => (0xe7a3, 1), // VMHH
2770
+ VecBinaryOp::SMulHi32x4 => (0xe7a3, 2), // VMHF
2771
+ VecBinaryOp::UMulEven8x16 => (0xe7a4, 0), // VMLEB
2772
+ VecBinaryOp::UMulEven16x8 => (0xe7a4, 1), // VMLEH
2773
+ VecBinaryOp::UMulEven32x4 => (0xe7a4, 2), // VMLEF
2774
+ VecBinaryOp::SMulEven8x16 => (0xe7a6, 0), // VMEB
2775
+ VecBinaryOp::SMulEven16x8 => (0xe7a6, 1), // VMEH
2776
+ VecBinaryOp::SMulEven32x4 => (0xe7a6, 2), // VMEF
2777
+ VecBinaryOp::UMulOdd8x16 => (0xe7a5, 0), // VMLOB
2778
+ VecBinaryOp::UMulOdd16x8 => (0xe7a5, 1), // VMLOH
2779
+ VecBinaryOp::UMulOdd32x4 => (0xe7a5, 2), // VMLOF
2780
+ VecBinaryOp::SMulOdd8x16 => (0xe7a7, 0), // VMOB
2781
+ VecBinaryOp::SMulOdd16x8 => (0xe7a7, 1), // VMOH
2782
+ VecBinaryOp::SMulOdd32x4 => (0xe7a7, 2), // VMOF
2783
+ VecBinaryOp::UMax8x16 => (0xe7fd, 0), // VMXLB
2784
+ VecBinaryOp::UMax16x8 => (0xe7fd, 1), // VMXLH
2785
+ VecBinaryOp::UMax32x4 => (0xe7fd, 2), // VMXLF
2786
+ VecBinaryOp::UMax64x2 => (0xe7fd, 3), // VMXLG
2787
+ VecBinaryOp::SMax8x16 => (0xe7ff, 0), // VMXB
2788
+ VecBinaryOp::SMax16x8 => (0xe7ff, 1), // VMXH
2789
+ VecBinaryOp::SMax32x4 => (0xe7ff, 2), // VMXF
2790
+ VecBinaryOp::SMax64x2 => (0xe7ff, 3), // VMXG
2791
+ VecBinaryOp::UMin8x16 => (0xe7fc, 0), // VMNLB
2792
+ VecBinaryOp::UMin16x8 => (0xe7fc, 1), // VMNLH
2793
+ VecBinaryOp::UMin32x4 => (0xe7fc, 2), // VMNLF
2794
+ VecBinaryOp::UMin64x2 => (0xe7fc, 3), // VMNLG
2795
+ VecBinaryOp::SMin8x16 => (0xe7fe, 0), // VMNB
2796
+ VecBinaryOp::SMin16x8 => (0xe7fe, 1), // VMNH
2797
+ VecBinaryOp::SMin32x4 => (0xe7fe, 2), // VMNF
2798
+ VecBinaryOp::SMin64x2 => (0xe7fe, 3), // VMNG
2799
+ VecBinaryOp::UAvg8x16 => (0xe7f0, 0), // VAVGLB
2800
+ VecBinaryOp::UAvg16x8 => (0xe7f0, 1), // VAVGLH
2801
+ VecBinaryOp::UAvg32x4 => (0xe7f0, 2), // VAVGLF
2802
+ VecBinaryOp::UAvg64x2 => (0xe7f0, 3), // VAVGLG
2803
+ VecBinaryOp::SAvg8x16 => (0xe7f2, 0), // VAVGB
2804
+ VecBinaryOp::SAvg16x8 => (0xe7f2, 1), // VAVGH
2805
+ VecBinaryOp::SAvg32x4 => (0xe7f2, 2), // VAVGF
2806
+ VecBinaryOp::SAvg64x2 => (0xe7f2, 3), // VAVGG
2807
+ VecBinaryOp::And128 => (0xe768, 0), // VN
2808
+ VecBinaryOp::Orr128 => (0xe76a, 0), // VO
2809
+ VecBinaryOp::Xor128 => (0xe76d, 0), // VX
2810
+ VecBinaryOp::NotAnd128 => (0xe76e, 0), // VNN
2811
+ VecBinaryOp::NotOrr128 => (0xe76b, 0), // VNO
2812
+ VecBinaryOp::NotXor128 => (0xe76c, 0), // VNX
2813
+ VecBinaryOp::AndNot128 => (0xe769, 0), // VNC
2814
+ VecBinaryOp::OrrNot128 => (0xe76f, 0), // VOC
2815
+ VecBinaryOp::BitPermute128 => (0xe785, 0), // VBPERM
2816
+ VecBinaryOp::LShLByByte128 => (0xe775, 0), // VSLB
2817
+ VecBinaryOp::LShRByByte128 => (0xe77d, 0), // VSRLB
2818
+ VecBinaryOp::AShRByByte128 => (0xe77f, 0), // VSRAB
2819
+ VecBinaryOp::LShLByBit128 => (0xe774, 0), // VSL
2820
+ VecBinaryOp::LShRByBit128 => (0xe77c, 0), // VSRL
2821
+ VecBinaryOp::AShRByBit128 => (0xe77e, 0), // VSRA
2822
+ VecBinaryOp::Pack16x8 => (0xe794, 1), // VPKH
2823
+ VecBinaryOp::Pack32x4 => (0xe794, 2), // VPKF
2824
+ VecBinaryOp::Pack64x2 => (0xe794, 3), // VPKG
2825
+ VecBinaryOp::PackUSat16x8 => (0xe795, 1), // VPKLSH
2826
+ VecBinaryOp::PackUSat32x4 => (0xe795, 2), // VPKLSF
2827
+ VecBinaryOp::PackUSat64x2 => (0xe795, 3), // VPKLSG
2828
+ VecBinaryOp::PackSSat16x8 => (0xe797, 1), // VPKSH
2829
+ VecBinaryOp::PackSSat32x4 => (0xe797, 2), // VPKSF
2830
+ VecBinaryOp::PackSSat64x2 => (0xe797, 3), // VPKSG
2831
+ VecBinaryOp::MergeLow8x16 => (0xe760, 0), // VMRLB
2832
+ VecBinaryOp::MergeLow16x8 => (0xe760, 1), // VMRLH
2833
+ VecBinaryOp::MergeLow32x4 => (0xe760, 2), // VMRLF
2834
+ VecBinaryOp::MergeLow64x2 => (0xe760, 3), // VMRLG
2835
+ VecBinaryOp::MergeHigh8x16 => (0xe761, 0), // VMRHB
2836
+ VecBinaryOp::MergeHigh16x8 => (0xe761, 1), // VMRHH
2837
+ VecBinaryOp::MergeHigh32x4 => (0xe761, 2), // VMRHF
2838
+ VecBinaryOp::MergeHigh64x2 => (0xe761, 3), // VMRHG
2839
+ };
2840
+
2841
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, 0, 0));
2842
+ }
2843
+ &Inst::VecRR { op, rd, rn } => {
2844
+ let rd = allocs.next_writable(rd);
2845
+ let rn = allocs.next(rn);
2846
+
2847
+ let (opcode, m3) = match op {
2848
+ VecUnaryOp::Abs8x16 => (0xe7df, 0), // VLPB
2849
+ VecUnaryOp::Abs16x8 => (0xe7df, 1), // VLPH
2850
+ VecUnaryOp::Abs32x4 => (0xe7df, 2), // VLPF
2851
+ VecUnaryOp::Abs64x2 => (0xe7df, 3), // VLPG
2852
+ VecUnaryOp::Neg8x16 => (0xe7de, 0), // VLCB
2853
+ VecUnaryOp::Neg16x8 => (0xe7de, 1), // VLCH
2854
+ VecUnaryOp::Neg32x4 => (0xe7de, 2), // VLCF
2855
+ VecUnaryOp::Neg64x2 => (0xe7de, 3), // VLCG
2856
+ VecUnaryOp::Popcnt8x16 => (0xe750, 0), // VPOPCTB
2857
+ VecUnaryOp::Popcnt16x8 => (0xe750, 1), // VPOPCTH
2858
+ VecUnaryOp::Popcnt32x4 => (0xe750, 2), // VPOPCTF
2859
+ VecUnaryOp::Popcnt64x2 => (0xe750, 3), // VPOPCTG
2860
+ VecUnaryOp::Clz8x16 => (0xe753, 0), // VCLZB
2861
+ VecUnaryOp::Clz16x8 => (0xe753, 1), // VCLZH
2862
+ VecUnaryOp::Clz32x4 => (0xe753, 2), // VCLZF
2863
+ VecUnaryOp::Clz64x2 => (0xe753, 3), // VCLZG
2864
+ VecUnaryOp::Ctz8x16 => (0xe752, 0), // VCTZB
2865
+ VecUnaryOp::Ctz16x8 => (0xe752, 1), // VCTZH
2866
+ VecUnaryOp::Ctz32x4 => (0xe752, 2), // VCTZF
2867
+ VecUnaryOp::Ctz64x2 => (0xe752, 3), // VCTZG
2868
+ VecUnaryOp::UnpackULow8x16 => (0xe7d4, 0), // VUPLLB
2869
+ VecUnaryOp::UnpackULow16x8 => (0xe7d4, 1), // VUPLLH
2870
+ VecUnaryOp::UnpackULow32x4 => (0xe7d4, 2), // VUPLLF
2871
+ VecUnaryOp::UnpackUHigh8x16 => (0xe7d5, 0), // VUPLHB
2872
+ VecUnaryOp::UnpackUHigh16x8 => (0xe7d5, 1), // VUPLHH
2873
+ VecUnaryOp::UnpackUHigh32x4 => (0xe7d5, 2), // VUPLHF
2874
+ VecUnaryOp::UnpackSLow8x16 => (0xe7d6, 0), // VUPLB
2875
+ VecUnaryOp::UnpackSLow16x8 => (0xe7d6, 1), // VUPLH
2876
+ VecUnaryOp::UnpackSLow32x4 => (0xe7d6, 2), // VUPLF
2877
+ VecUnaryOp::UnpackSHigh8x16 => (0xe7d7, 0), // VUPHB
2878
+ VecUnaryOp::UnpackSHigh16x8 => (0xe7d7, 1), // VUPHH
2879
+ VecUnaryOp::UnpackSHigh32x4 => (0xe7d7, 2), // VUPHF
2880
+ };
2881
+
2882
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, m3, 0, 0));
2883
+ }
2884
+ &Inst::VecShiftRR {
2885
+ shift_op,
2886
+ rd,
2887
+ rn,
2888
+ shift_imm,
2889
+ shift_reg,
2890
+ } => {
2891
+ let rd = allocs.next_writable(rd);
2892
+ let rn = allocs.next(rn);
2893
+ let shift_reg = allocs.next(shift_reg);
2894
+
2895
+ let (opcode, m4) = match shift_op {
2896
+ VecShiftOp::RotL8x16 => (0xe733, 0), // VERLLB
2897
+ VecShiftOp::RotL16x8 => (0xe733, 1), // VERLLH
2898
+ VecShiftOp::RotL32x4 => (0xe733, 2), // VERLLF
2899
+ VecShiftOp::RotL64x2 => (0xe733, 3), // VERLLG
2900
+ VecShiftOp::LShL8x16 => (0xe730, 0), // VESLB
2901
+ VecShiftOp::LShL16x8 => (0xe730, 1), // VESLH
2902
+ VecShiftOp::LShL32x4 => (0xe730, 2), // VESLF
2903
+ VecShiftOp::LShL64x2 => (0xe730, 3), // VESLG
2904
+ VecShiftOp::LShR8x16 => (0xe738, 0), // VESRLB
2905
+ VecShiftOp::LShR16x8 => (0xe738, 1), // VESRLH
2906
+ VecShiftOp::LShR32x4 => (0xe738, 2), // VESRLF
2907
+ VecShiftOp::LShR64x2 => (0xe738, 3), // VESRLG
2908
+ VecShiftOp::AShR8x16 => (0xe73a, 0), // VESRAB
2909
+ VecShiftOp::AShR16x8 => (0xe73a, 1), // VESRAH
2910
+ VecShiftOp::AShR32x4 => (0xe73a, 2), // VESRAF
2911
+ VecShiftOp::AShR64x2 => (0xe73a, 3), // VESRAG
2912
+ };
2913
+ put(
2914
+ sink,
2915
+ &enc_vrs_a(opcode, rd.to_reg(), shift_reg, shift_imm.into(), rn, m4),
2916
+ );
2917
+ }
2918
+ &Inst::VecSelect { rd, rn, rm, ra } => {
2919
+ let rd = allocs.next_writable(rd);
2920
+ let rn = allocs.next(rn);
2921
+ let rm = allocs.next(rm);
2922
+ let ra = allocs.next(ra);
2923
+
2924
+ let opcode = 0xe78d; // VSEL
2925
+ put(sink, &enc_vrr_e(opcode, rd.to_reg(), rn, rm, ra, 0, 0));
2926
+ }
2927
+ &Inst::VecPermute { rd, rn, rm, ra } => {
2928
+ let rd = allocs.next_writable(rd);
2929
+ let rn = allocs.next(rn);
2930
+ let rm = allocs.next(rm);
2931
+ let ra = allocs.next(ra);
2932
+
2933
+ let opcode = 0xe78c; // VPERM
2934
+ put(sink, &enc_vrr_e(opcode, rd.to_reg(), rn, rm, ra, 0, 0));
2935
+ }
2936
+ &Inst::VecPermuteDWImm {
2937
+ rd,
2938
+ rn,
2939
+ rm,
2940
+ idx1,
2941
+ idx2,
2942
+ } => {
2943
+ let rd = allocs.next_writable(rd);
2944
+ let rn = allocs.next(rn);
2945
+ let rm = allocs.next(rm);
2946
+ let m4 = (idx1 & 1) * 4 + (idx2 & 1);
2947
+
2948
+ let opcode = 0xe784; // VPDI
2949
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, 0, 0));
2950
+ }
2951
+ &Inst::VecIntCmp { op, rd, rn, rm } | &Inst::VecIntCmpS { op, rd, rn, rm } => {
2952
+ let rd = allocs.next_writable(rd);
2953
+ let rn = allocs.next(rn);
2954
+ let rm = allocs.next(rm);
2955
+
2956
+ let (opcode, m4) = match op {
2957
+ VecIntCmpOp::CmpEq8x16 => (0xe7f8, 0), // VCEQB
2958
+ VecIntCmpOp::CmpEq16x8 => (0xe7f8, 1), // VCEQH
2959
+ VecIntCmpOp::CmpEq32x4 => (0xe7f8, 2), // VCEQF
2960
+ VecIntCmpOp::CmpEq64x2 => (0xe7f8, 3), // VCEQG
2961
+ VecIntCmpOp::SCmpHi8x16 => (0xe7fb, 0), // VCHB
2962
+ VecIntCmpOp::SCmpHi16x8 => (0xe7fb, 1), // VCHH
2963
+ VecIntCmpOp::SCmpHi32x4 => (0xe7fb, 2), // VCHG
2964
+ VecIntCmpOp::SCmpHi64x2 => (0xe7fb, 3), // VCHG
2965
+ VecIntCmpOp::UCmpHi8x16 => (0xe7f9, 0), // VCHLB
2966
+ VecIntCmpOp::UCmpHi16x8 => (0xe7f9, 1), // VCHLH
2967
+ VecIntCmpOp::UCmpHi32x4 => (0xe7f9, 2), // VCHLG
2968
+ VecIntCmpOp::UCmpHi64x2 => (0xe7f9, 3), // VCHLG
2969
+ };
2970
+ let m5 = match self {
2971
+ &Inst::VecIntCmp { .. } => 0,
2972
+ &Inst::VecIntCmpS { .. } => 1,
2973
+ _ => unreachable!(),
2974
+ };
2975
+
2976
+ put(sink, &enc_vrr_b(opcode, rd.to_reg(), rn, rm, m4, m5));
2977
+ }
2978
+ &Inst::VecFloatCmp { op, rd, rn, rm } | &Inst::VecFloatCmpS { op, rd, rn, rm } => {
2979
+ let rd = allocs.next_writable(rd);
2980
+ let rn = allocs.next(rn);
2981
+ let rm = allocs.next(rm);
2982
+
2983
+ let (opcode, m4) = match op {
2984
+ VecFloatCmpOp::CmpEq32x4 => (0xe7e8, 2), // VFCESB
2985
+ VecFloatCmpOp::CmpEq64x2 => (0xe7e8, 3), // VFCEDB
2986
+ VecFloatCmpOp::CmpHi32x4 => (0xe7eb, 2), // VFCHSB
2987
+ VecFloatCmpOp::CmpHi64x2 => (0xe7eb, 3), // VFCHDB
2988
+ VecFloatCmpOp::CmpHiEq32x4 => (0xe7ea, 2), // VFCHESB
2989
+ VecFloatCmpOp::CmpHiEq64x2 => (0xe7ea, 3), // VFCHEDB
2990
+ };
2991
+ let m6 = match self {
2992
+ &Inst::VecFloatCmp { .. } => 0,
2993
+ &Inst::VecFloatCmpS { .. } => 1,
2994
+ _ => unreachable!(),
2995
+ };
2996
+
2997
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, 0, m6));
2998
+ }
2999
+ &Inst::VecInt128SCmpHi { tmp, rn, rm } | &Inst::VecInt128UCmpHi { tmp, rn, rm } => {
3000
+ // Synthetic instruction to compare 128-bit values.
3001
+ // Sets CC 1 if rn > rm, sets a different CC otherwise.
3002
+ let tmp = allocs.next_writable(tmp);
3003
+ let rn = allocs.next(rn);
3004
+ let rm = allocs.next(rm);
3005
+
3006
+ // Use VECTOR ELEMENT COMPARE to compare the high parts.
3007
+ // Swap the inputs to get:
3008
+ // CC 1 if high(rn) > high(rm)
3009
+ // CC 2 if high(rn) < high(rm)
3010
+ // CC 0 if high(rn) == high(rm)
3011
+ let (opcode, m3) = match self {
3012
+ &Inst::VecInt128SCmpHi { .. } => (0xe7db, 3), // VECG
3013
+ &Inst::VecInt128UCmpHi { .. } => (0xe7d9, 3), // VECLG
3014
+ _ => unreachable!(),
3015
+ };
3016
+ put(sink, &enc_vrr_a(opcode, rm, rn, m3, 0, 0));
3017
+
3018
+ // If CC != 0, we'd done, so jump over the next instruction.
3019
+ let opcode = 0xa74; // BCR
3020
+ put(sink, &enc_ri_c(opcode, 7, 4 + 6));
3021
+
3022
+ // Otherwise, use VECTOR COMPARE HIGH LOGICAL.
3023
+ // Since we already know the high parts are equal, the CC
3024
+ // result will only depend on the low parts:
3025
+ // CC 1 if low(rn) > low(rm)
3026
+ // CC 3 if low(rn) <= low(rm)
3027
+ let inst = Inst::VecIntCmpS {
3028
+ op: VecIntCmpOp::UCmpHi64x2,
3029
+ // N.B.: This is the first write to tmp, and it happens
3030
+ // after all uses of rn and rm. If this were to ever
3031
+ // change, tmp would have to become an early-def.
3032
+ rd: tmp,
3033
+ rn,
3034
+ rm,
3035
+ };
3036
+ inst.emit(&[], sink, emit_info, state);
3037
+ }
3038
+
3039
+ &Inst::VecLoad { rd, ref mem }
3040
+ | &Inst::VecLoadRev { rd, ref mem }
3041
+ | &Inst::VecLoadByte16Rev { rd, ref mem }
3042
+ | &Inst::VecLoadByte32Rev { rd, ref mem }
3043
+ | &Inst::VecLoadByte64Rev { rd, ref mem }
3044
+ | &Inst::VecLoadElt16Rev { rd, ref mem }
3045
+ | &Inst::VecLoadElt32Rev { rd, ref mem }
3046
+ | &Inst::VecLoadElt64Rev { rd, ref mem } => {
3047
+ let rd = allocs.next_writable(rd);
3048
+ let mem = mem.with_allocs(allocs);
3049
+
3050
+ let (opcode, m3) = match self {
3051
+ &Inst::VecLoad { .. } => (0xe706, 0), // VL
3052
+ &Inst::VecLoadRev { .. } => (0xe606, 4), // VLBRQ
3053
+ &Inst::VecLoadByte16Rev { .. } => (0xe606, 1), // VLBRH
3054
+ &Inst::VecLoadByte32Rev { .. } => (0xe606, 2), // VLBRF
3055
+ &Inst::VecLoadByte64Rev { .. } => (0xe606, 3), // VLBRG
3056
+ &Inst::VecLoadElt16Rev { .. } => (0xe607, 1), // VLERH
3057
+ &Inst::VecLoadElt32Rev { .. } => (0xe607, 2), // VLERF
3058
+ &Inst::VecLoadElt64Rev { .. } => (0xe607, 3), // VLERG
3059
+ _ => unreachable!(),
3060
+ };
3061
+ mem_vrx_emit(rd.to_reg(), &mem, opcode, m3, true, sink, emit_info, state);
3062
+ }
3063
+ &Inst::VecStore { rd, ref mem }
3064
+ | &Inst::VecStoreRev { rd, ref mem }
3065
+ | &Inst::VecStoreByte16Rev { rd, ref mem }
3066
+ | &Inst::VecStoreByte32Rev { rd, ref mem }
3067
+ | &Inst::VecStoreByte64Rev { rd, ref mem }
3068
+ | &Inst::VecStoreElt16Rev { rd, ref mem }
3069
+ | &Inst::VecStoreElt32Rev { rd, ref mem }
3070
+ | &Inst::VecStoreElt64Rev { rd, ref mem } => {
3071
+ let rd = allocs.next(rd);
3072
+ let mem = mem.with_allocs(allocs);
3073
+
3074
+ let (opcode, m3) = match self {
3075
+ &Inst::VecStore { .. } => (0xe70e, 0), // VST
3076
+ &Inst::VecStoreRev { .. } => (0xe60e, 4), // VSTBRQ
3077
+ &Inst::VecStoreByte16Rev { .. } => (0xe60e, 1), // VSTBRH
3078
+ &Inst::VecStoreByte32Rev { .. } => (0xe60e, 2), // VSTBRF
3079
+ &Inst::VecStoreByte64Rev { .. } => (0xe60e, 3), // VSTBRG
3080
+ &Inst::VecStoreElt16Rev { .. } => (0xe60f, 1), // VSTERH
3081
+ &Inst::VecStoreElt32Rev { .. } => (0xe60f, 2), // VSTERF
3082
+ &Inst::VecStoreElt64Rev { .. } => (0xe60f, 3), // VSTERG
3083
+ _ => unreachable!(),
3084
+ };
3085
+ mem_vrx_emit(rd, &mem, opcode, m3, true, sink, emit_info, state);
3086
+ }
3087
+ &Inst::VecLoadReplicate { size, rd, ref mem }
3088
+ | &Inst::VecLoadReplicateRev { size, rd, ref mem } => {
3089
+ let rd = allocs.next_writable(rd);
3090
+ let mem = mem.with_allocs(allocs);
3091
+
3092
+ let (opcode, m3) = match (self, size) {
3093
+ (&Inst::VecLoadReplicate { .. }, 8) => (0xe705, 0), // VLREPB
3094
+ (&Inst::VecLoadReplicate { .. }, 16) => (0xe705, 1), // VLREPH
3095
+ (&Inst::VecLoadReplicate { .. }, 32) => (0xe705, 2), // VLREPF
3096
+ (&Inst::VecLoadReplicate { .. }, 64) => (0xe705, 3), // VLREPG
3097
+ (&Inst::VecLoadReplicateRev { .. }, 16) => (0xe605, 1), // VLREPBRH
3098
+ (&Inst::VecLoadReplicateRev { .. }, 32) => (0xe605, 2), // VLREPBRF
3099
+ (&Inst::VecLoadReplicateRev { .. }, 64) => (0xe605, 3), // VLREPBRG
3100
+ _ => unreachable!(),
3101
+ };
3102
+ mem_vrx_emit(rd.to_reg(), &mem, opcode, m3, true, sink, emit_info, state);
3103
+ }
3104
+
3105
+ &Inst::VecMov { rd, rn } => {
3106
+ let rd = allocs.next_writable(rd);
3107
+ let rn = allocs.next(rn);
3108
+
3109
+ let opcode = 0xe756; // VLR
3110
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, 0, 0, 0));
3111
+ }
3112
+ &Inst::VecCMov { rd, cond, ri, rm } => {
3113
+ let rd = allocs.next_writable(rd);
3114
+ let ri = allocs.next(ri);
3115
+ debug_assert_eq!(rd.to_reg(), ri);
3116
+ let rm = allocs.next(rm);
3117
+
3118
+ let opcode = 0xa74; // BCR
3119
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 6));
3120
+ let opcode = 0xe756; // VLR
3121
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rm, 0, 0, 0));
3122
+ }
3123
+ &Inst::MovToVec128 { rd, rn, rm } => {
3124
+ let rd = allocs.next_writable(rd);
3125
+ let rn = allocs.next(rn);
3126
+ let rm = allocs.next(rm);
3127
+
3128
+ let opcode = 0xe762; // VLVGP
3129
+ put(sink, &enc_vrr_f(opcode, rd.to_reg(), rn, rm));
3130
+ }
3131
+ &Inst::VecLoadConst { rd, const_data } => {
3132
+ let rd = allocs.next_writable(rd);
3133
+
3134
+ let opcode = 0xa75; // BRAS
3135
+ let reg = writable_spilltmp_reg().to_reg();
3136
+ put(sink, &enc_ri_b(opcode, reg, 20));
3137
+ for i in const_data.to_be_bytes().iter() {
3138
+ sink.put1(*i);
3139
+ }
3140
+ let inst = Inst::VecLoad {
3141
+ rd,
3142
+ mem: MemArg::reg(reg, MemFlags::trusted()),
3143
+ };
3144
+ inst.emit(&[], sink, emit_info, state);
3145
+ }
3146
+ &Inst::VecLoadConstReplicate {
3147
+ size,
3148
+ rd,
3149
+ const_data,
3150
+ } => {
3151
+ let rd = allocs.next_writable(rd);
3152
+
3153
+ let opcode = 0xa75; // BRAS
3154
+ let reg = writable_spilltmp_reg().to_reg();
3155
+ put(sink, &enc_ri_b(opcode, reg, (4 + size / 8) as i32));
3156
+ for i in 0..size / 8 {
3157
+ sink.put1((const_data >> (size - 8 - 8 * i)) as u8);
3158
+ }
3159
+ let inst = Inst::VecLoadReplicate {
3160
+ size,
3161
+ rd,
3162
+ mem: MemArg::reg(reg, MemFlags::trusted()),
3163
+ };
3164
+ inst.emit(&[], sink, emit_info, state);
3165
+ }
3166
+ &Inst::VecImmByteMask { rd, mask } => {
3167
+ let rd = allocs.next_writable(rd);
3168
+ let opcode = 0xe744; // VGBM
3169
+ put(sink, &enc_vri_a(opcode, rd.to_reg(), mask, 0));
3170
+ }
3171
+ &Inst::VecImmBitMask {
3172
+ size,
3173
+ rd,
3174
+ start_bit,
3175
+ end_bit,
3176
+ } => {
3177
+ let rd = allocs.next_writable(rd);
3178
+ let (opcode, m4) = match size {
3179
+ 8 => (0xe746, 0), // VGMB
3180
+ 16 => (0xe746, 1), // VGMH
3181
+ 32 => (0xe746, 2), // VGMF
3182
+ 64 => (0xe746, 3), // VGMG
3183
+ _ => unreachable!(),
3184
+ };
3185
+ put(
3186
+ sink,
3187
+ &enc_vri_b(opcode, rd.to_reg(), start_bit, end_bit, m4),
3188
+ );
3189
+ }
3190
+ &Inst::VecImmReplicate { size, rd, imm } => {
3191
+ let rd = allocs.next_writable(rd);
3192
+ let (opcode, m3) = match size {
3193
+ 8 => (0xe745, 0), // VREPIB
3194
+ 16 => (0xe745, 1), // VREPIH
3195
+ 32 => (0xe745, 2), // VREPIF
3196
+ 64 => (0xe745, 3), // VREPIG
3197
+ _ => unreachable!(),
3198
+ };
3199
+ put(sink, &enc_vri_a(opcode, rd.to_reg(), imm as u16, m3));
3200
+ }
3201
+ &Inst::VecLoadLane {
3202
+ size,
3203
+ rd,
3204
+ ri,
3205
+ ref mem,
3206
+ lane_imm,
3207
+ }
3208
+ | &Inst::VecLoadLaneRev {
3209
+ size,
3210
+ rd,
3211
+ ri,
3212
+ ref mem,
3213
+ lane_imm,
3214
+ } => {
3215
+ let rd = allocs.next_writable(rd);
3216
+ let ri = allocs.next(ri);
3217
+ debug_assert_eq!(rd.to_reg(), ri);
3218
+ let mem = mem.with_allocs(allocs);
3219
+
3220
+ let opcode_vrx = match (self, size) {
3221
+ (&Inst::VecLoadLane { .. }, 8) => 0xe700, // VLEB
3222
+ (&Inst::VecLoadLane { .. }, 16) => 0xe701, // VLEH
3223
+ (&Inst::VecLoadLane { .. }, 32) => 0xe703, // VLEF
3224
+ (&Inst::VecLoadLane { .. }, 64) => 0xe702, // VLEG
3225
+ (&Inst::VecLoadLaneRev { .. }, 16) => 0xe601, // VLEBRH
3226
+ (&Inst::VecLoadLaneRev { .. }, 32) => 0xe603, // VLEBRF
3227
+ (&Inst::VecLoadLaneRev { .. }, 64) => 0xe602, // VLEBRG
3228
+ _ => unreachable!(),
3229
+ };
3230
+
3231
+ let rd = rd.to_reg();
3232
+ mem_vrx_emit(
3233
+ rd,
3234
+ &mem,
3235
+ opcode_vrx,
3236
+ lane_imm.into(),
3237
+ true,
3238
+ sink,
3239
+ emit_info,
3240
+ state,
3241
+ );
3242
+ }
3243
+ &Inst::VecLoadLaneUndef {
3244
+ size,
3245
+ rd,
3246
+ ref mem,
3247
+ lane_imm,
3248
+ }
3249
+ | &Inst::VecLoadLaneRevUndef {
3250
+ size,
3251
+ rd,
3252
+ ref mem,
3253
+ lane_imm,
3254
+ } => {
3255
+ let rd = allocs.next_writable(rd);
3256
+ let mem = mem.with_allocs(allocs);
3257
+
3258
+ let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
3259
+ (&Inst::VecLoadLaneUndef { .. }, 8) => (0xe700, None, None), // VLEB
3260
+ (&Inst::VecLoadLaneUndef { .. }, 16) => (0xe701, None, None), // VLEH
3261
+ (&Inst::VecLoadLaneUndef { .. }, 32) => (0xe703, Some(0x78), Some(0xed64)), // VLEF, LE(Y)
3262
+ (&Inst::VecLoadLaneUndef { .. }, 64) => (0xe702, Some(0x68), Some(0xed65)), // VLEG, LD(Y)
3263
+ (&Inst::VecLoadLaneRevUndef { .. }, 16) => (0xe601, None, None), // VLEBRH
3264
+ (&Inst::VecLoadLaneRevUndef { .. }, 32) => (0xe603, None, None), // VLEBRF
3265
+ (&Inst::VecLoadLaneRevUndef { .. }, 64) => (0xe602, None, None), // VLEBRG
3266
+ _ => unreachable!(),
3267
+ };
3268
+
3269
+ let rd = rd.to_reg();
3270
+ if lane_imm == 0 && is_fpr(rd) && opcode_rx.is_some() {
3271
+ mem_emit(
3272
+ rd, &mem, opcode_rx, opcode_rxy, None, true, sink, emit_info, state,
3273
+ );
3274
+ } else {
3275
+ mem_vrx_emit(
3276
+ rd,
3277
+ &mem,
3278
+ opcode_vrx,
3279
+ lane_imm.into(),
3280
+ true,
3281
+ sink,
3282
+ emit_info,
3283
+ state,
3284
+ );
3285
+ }
3286
+ }
3287
+ &Inst::VecStoreLane {
3288
+ size,
3289
+ rd,
3290
+ ref mem,
3291
+ lane_imm,
3292
+ }
3293
+ | &Inst::VecStoreLaneRev {
3294
+ size,
3295
+ rd,
3296
+ ref mem,
3297
+ lane_imm,
3298
+ } => {
3299
+ let rd = allocs.next(rd);
3300
+ let mem = mem.with_allocs(allocs);
3301
+
3302
+ let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
3303
+ (&Inst::VecStoreLane { .. }, 8) => (0xe708, None, None), // VSTEB
3304
+ (&Inst::VecStoreLane { .. }, 16) => (0xe709, None, None), // VSTEH
3305
+ (&Inst::VecStoreLane { .. }, 32) => (0xe70b, Some(0x70), Some(0xed66)), // VSTEF, STE(Y)
3306
+ (&Inst::VecStoreLane { .. }, 64) => (0xe70a, Some(0x60), Some(0xed67)), // VSTEG, STD(Y)
3307
+ (&Inst::VecStoreLaneRev { .. }, 16) => (0xe609, None, None), // VSTEBRH
3308
+ (&Inst::VecStoreLaneRev { .. }, 32) => (0xe60b, None, None), // VSTEBRF
3309
+ (&Inst::VecStoreLaneRev { .. }, 64) => (0xe60a, None, None), // VSTEBRG
3310
+ _ => unreachable!(),
3311
+ };
3312
+
3313
+ if lane_imm == 0 && is_fpr(rd) && opcode_rx.is_some() {
3314
+ mem_emit(
3315
+ rd, &mem, opcode_rx, opcode_rxy, None, true, sink, emit_info, state,
3316
+ );
3317
+ } else {
3318
+ mem_vrx_emit(
3319
+ rd,
3320
+ &mem,
3321
+ opcode_vrx,
3322
+ lane_imm.into(),
3323
+ true,
3324
+ sink,
3325
+ emit_info,
3326
+ state,
3327
+ );
3328
+ }
3329
+ }
3330
+ &Inst::VecInsertLane {
3331
+ size,
3332
+ rd,
3333
+ ri,
3334
+ rn,
3335
+ lane_imm,
3336
+ lane_reg,
3337
+ } => {
3338
+ let rd = allocs.next_writable(rd);
3339
+ let ri = allocs.next(ri);
3340
+ debug_assert_eq!(rd.to_reg(), ri);
3341
+ let rn = allocs.next(rn);
3342
+ let lane_reg = allocs.next(lane_reg);
3343
+
3344
+ let (opcode_vrs, m4) = match size {
3345
+ 8 => (0xe722, 0), // VLVGB
3346
+ 16 => (0xe722, 1), // VLVGH
3347
+ 32 => (0xe722, 2), // VLVGF
3348
+ 64 => (0xe722, 3), // VLVGG
3349
+ _ => unreachable!(),
3350
+ };
3351
+ put(
3352
+ sink,
3353
+ &enc_vrs_b(opcode_vrs, rd.to_reg(), lane_reg, lane_imm.into(), rn, m4),
3354
+ );
3355
+ }
3356
+ &Inst::VecInsertLaneUndef {
3357
+ size,
3358
+ rd,
3359
+ rn,
3360
+ lane_imm,
3361
+ lane_reg,
3362
+ } => {
3363
+ let rd = allocs.next_writable(rd);
3364
+ let rn = allocs.next(rn);
3365
+ let lane_reg = allocs.next(lane_reg);
3366
+
3367
+ let (opcode_vrs, m4, opcode_rre) = match size {
3368
+ 8 => (0xe722, 0, None), // VLVGB
3369
+ 16 => (0xe722, 1, None), // VLVGH
3370
+ 32 => (0xe722, 2, None), // VLVGF
3371
+ 64 => (0xe722, 3, Some(0xb3c1)), // VLVGG, LDGR
3372
+ _ => unreachable!(),
3373
+ };
3374
+ if opcode_rre.is_some()
3375
+ && lane_imm == 0
3376
+ && lane_reg == zero_reg()
3377
+ && is_fpr(rd.to_reg())
3378
+ {
3379
+ put(sink, &enc_rre(opcode_rre.unwrap(), rd.to_reg(), rn));
3380
+ } else {
3381
+ put(
3382
+ sink,
3383
+ &enc_vrs_b(opcode_vrs, rd.to_reg(), lane_reg, lane_imm.into(), rn, m4),
3384
+ );
3385
+ }
3386
+ }
3387
+ &Inst::VecExtractLane {
3388
+ size,
3389
+ rd,
3390
+ rn,
3391
+ lane_imm,
3392
+ lane_reg,
3393
+ } => {
3394
+ let rd = allocs.next_writable(rd);
3395
+ let rn = allocs.next(rn);
3396
+ let lane_reg = allocs.next(lane_reg);
3397
+
3398
+ let (opcode_vrs, m4, opcode_rre) = match size {
3399
+ 8 => (0xe721, 0, None), // VLGVB
3400
+ 16 => (0xe721, 1, None), // VLGVH
3401
+ 32 => (0xe721, 2, None), // VLGVF
3402
+ 64 => (0xe721, 3, Some(0xb3cd)), // VLGVG, LGDR
3403
+ _ => unreachable!(),
3404
+ };
3405
+ if opcode_rre.is_some() && lane_imm == 0 && lane_reg == zero_reg() && is_fpr(rn) {
3406
+ put(sink, &enc_rre(opcode_rre.unwrap(), rd.to_reg(), rn));
3407
+ } else {
3408
+ put(
3409
+ sink,
3410
+ &enc_vrs_c(opcode_vrs, rd.to_reg(), lane_reg, lane_imm.into(), rn, m4),
3411
+ );
3412
+ }
3413
+ }
3414
+ &Inst::VecInsertLaneImm {
3415
+ size,
3416
+ rd,
3417
+ ri,
3418
+ imm,
3419
+ lane_imm,
3420
+ } => {
3421
+ let rd = allocs.next_writable(rd);
3422
+ let ri = allocs.next(ri);
3423
+ debug_assert_eq!(rd.to_reg(), ri);
3424
+
3425
+ let opcode = match size {
3426
+ 8 => 0xe740, // VLEIB
3427
+ 16 => 0xe741, // LEIVH
3428
+ 32 => 0xe743, // VLEIF
3429
+ 64 => 0xe742, // VLEIG
3430
+ _ => unreachable!(),
3431
+ };
3432
+ put(
3433
+ sink,
3434
+ &enc_vri_a(opcode, rd.to_reg(), imm as u16, lane_imm.into()),
3435
+ );
3436
+ }
3437
+ &Inst::VecReplicateLane {
3438
+ size,
3439
+ rd,
3440
+ rn,
3441
+ lane_imm,
3442
+ } => {
3443
+ let rd = allocs.next_writable(rd);
3444
+ let rn = allocs.next(rn);
3445
+
3446
+ let (opcode, m4) = match size {
3447
+ 8 => (0xe74d, 0), // VREPB
3448
+ 16 => (0xe74d, 1), // VREPH
3449
+ 32 => (0xe74d, 2), // VREPF
3450
+ 64 => (0xe74d, 3), // VREPG
3451
+ _ => unreachable!(),
3452
+ };
3453
+ put(
3454
+ sink,
3455
+ &enc_vri_c(opcode, rd.to_reg(), lane_imm.into(), rn, m4),
3456
+ );
3457
+ }
3458
+
3459
+ &Inst::Call { link, ref info } => {
3460
+ debug_assert_eq!(link.to_reg(), gpr(14));
3461
+
3462
+ let opcode = 0xc05; // BRASL
3463
+
3464
+ // Add relocation for target function. This has to be done *before*
3465
+ // the S390xTlsGdCall relocation if any, to ensure linker relaxation
3466
+ // works correctly.
3467
+ sink.add_reloc_at_offset(2, Reloc::S390xPLTRel32Dbl, &info.dest, 2);
3468
+
3469
+ // Add relocation for TLS libcalls to enable linker optimizations.
3470
+ match &info.tls_symbol {
3471
+ None => {}
3472
+ Some(SymbolReloc::TlsGd { name }) => {
3473
+ sink.add_reloc(Reloc::S390xTlsGdCall, name, 0)
3474
+ }
3475
+ _ => unreachable!(),
3476
+ }
3477
+
3478
+ if let Some(s) = state.take_stack_map() {
3479
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(6), s);
3480
+ }
3481
+ put(sink, &enc_ril_b(opcode, link.to_reg(), 0));
3482
+ if info.opcode.is_call() {
3483
+ sink.add_call_site(info.opcode);
3484
+ }
3485
+ }
3486
+ &Inst::CallInd { link, ref info } => {
3487
+ debug_assert_eq!(link.to_reg(), gpr(14));
3488
+ let rn = allocs.next(info.rn);
3489
+
3490
+ let opcode = 0x0d; // BASR
3491
+ if let Some(s) = state.take_stack_map() {
3492
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(2), s);
3493
+ }
3494
+ put(sink, &enc_rr(opcode, link.to_reg(), rn));
3495
+ if info.opcode.is_call() {
3496
+ sink.add_call_site(info.opcode);
3497
+ }
3498
+ }
3499
+ &Inst::Args { .. } => {}
3500
+ &Inst::Rets { .. } => {}
3501
+ &Inst::Ret { link } => {
3502
+ debug_assert_eq!(link, gpr(14));
3503
+ let opcode = 0x07; // BCR
3504
+ put(sink, &enc_rr(opcode, gpr(15), link));
3505
+ }
3506
+ &Inst::Jump { dest } => {
3507
+ let off = sink.cur_offset();
3508
+ // Indicate that the jump uses a label, if so, so that a fixup can occur later.
3509
+ sink.use_label_at_offset(off, dest, LabelUse::BranchRIL);
3510
+ sink.add_uncond_branch(off, off + 6, dest);
3511
+ // Emit the jump itself.
3512
+ let opcode = 0xc04; // BCRL
3513
+ put(sink, &enc_ril_c(opcode, 15, 0));
3514
+ }
3515
+ &Inst::IndirectBr { rn, .. } => {
3516
+ let rn = allocs.next(rn);
3517
+
3518
+ let opcode = 0x07; // BCR
3519
+ put(sink, &enc_rr(opcode, gpr(15), rn));
3520
+ }
3521
+ &Inst::CondBr {
3522
+ taken,
3523
+ not_taken,
3524
+ cond,
3525
+ } => {
3526
+ let opcode = 0xc04; // BCRL
3527
+
3528
+ // Conditional part first.
3529
+ let cond_off = sink.cur_offset();
3530
+ sink.use_label_at_offset(cond_off, taken, LabelUse::BranchRIL);
3531
+ let inverted = &enc_ril_c(opcode, cond.invert().bits(), 0);
3532
+ sink.add_cond_branch(cond_off, cond_off + 6, taken, inverted);
3533
+ put(sink, &enc_ril_c(opcode, cond.bits(), 0));
3534
+
3535
+ // Unconditional part next.
3536
+ let uncond_off = sink.cur_offset();
3537
+ sink.use_label_at_offset(uncond_off, not_taken, LabelUse::BranchRIL);
3538
+ sink.add_uncond_branch(uncond_off, uncond_off + 6, not_taken);
3539
+ put(sink, &enc_ril_c(opcode, 15, 0));
3540
+ }
3541
+ &Inst::OneWayCondBr { target, cond } => {
3542
+ let opcode = 0xc04; // BCRL
3543
+ sink.use_label_at_offset(sink.cur_offset(), target, LabelUse::BranchRIL);
3544
+ put(sink, &enc_ril_c(opcode, cond.bits(), 0));
3545
+ }
3546
+ &Inst::Nop0 => {}
3547
+ &Inst::Nop2 => {
3548
+ put(sink, &enc_e(0x0707));
3549
+ }
3550
+ &Inst::Debugtrap => {
3551
+ put(sink, &enc_e(0x0001));
3552
+ }
3553
+ &Inst::Trap { trap_code } => {
3554
+ if let Some(s) = state.take_stack_map() {
3555
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(2), s);
3556
+ }
3557
+ put_with_trap(sink, &enc_e(0x0000), trap_code);
3558
+ }
3559
+ &Inst::TrapIf { cond, trap_code } => {
3560
+ if let Some(s) = state.take_stack_map() {
3561
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(6), s);
3562
+ }
3563
+ // We implement a TrapIf as a conditional branch into the middle
3564
+ // of the branch (BRCL) instruction itself - those middle two bytes
3565
+ // are zero, which matches the trap instruction itself.
3566
+ let opcode = 0xc04; // BCRL
3567
+ let enc = &enc_ril_c(opcode, cond.bits(), 2);
3568
+ debug_assert!(enc.len() == 6 && enc[2] == 0 && enc[3] == 0);
3569
+ // The trap must be placed on the last byte of the embedded trap
3570
+ // instruction, so we need to emit the encoding in two parts.
3571
+ put_with_trap(sink, &enc[0..4], trap_code);
3572
+ put(sink, &enc[4..6]);
3573
+ }
3574
+ &Inst::JTSequence { ridx, ref targets } => {
3575
+ let ridx = allocs.next(ridx);
3576
+
3577
+ let table_label = sink.get_label();
3578
+
3579
+ // This sequence is *one* instruction in the vcode, and is expanded only here at
3580
+ // emission time, because we cannot allow the regalloc to insert spills/reloads in
3581
+ // the middle; we depend on hardcoded PC-rel addressing below.
3582
+
3583
+ // Set temp register to address of jump table.
3584
+ let rtmp = writable_spilltmp_reg();
3585
+ let inst = Inst::LoadAddr {
3586
+ rd: rtmp,
3587
+ mem: MemArg::Label {
3588
+ target: table_label,
3589
+ },
3590
+ };
3591
+ inst.emit(&[], sink, emit_info, state);
3592
+
3593
+ // Set temp to target address by adding the value of the jump table entry.
3594
+ let inst = Inst::AluRX {
3595
+ alu_op: ALUOp::Add64Ext32,
3596
+ rd: rtmp,
3597
+ ri: rtmp.to_reg(),
3598
+ mem: MemArg::reg_plus_reg(rtmp.to_reg(), ridx, MemFlags::trusted()),
3599
+ };
3600
+ inst.emit(&[], sink, emit_info, state);
3601
+
3602
+ // Branch to computed address. (`targets` here is only used for successor queries
3603
+ // and is not needed for emission.)
3604
+ let inst = Inst::IndirectBr {
3605
+ rn: rtmp.to_reg(),
3606
+ targets: vec![],
3607
+ };
3608
+ inst.emit(&[], sink, emit_info, state);
3609
+
3610
+ // Emit jump table (table of 32-bit offsets).
3611
+ sink.bind_label(table_label, &mut state.ctrl_plane);
3612
+ let jt_off = sink.cur_offset();
3613
+ for &target in targets.iter() {
3614
+ let word_off = sink.cur_offset();
3615
+ let off_into_table = word_off - jt_off;
3616
+ sink.use_label_at_offset(word_off, target, LabelUse::PCRel32);
3617
+ sink.put4(off_into_table.swap_bytes());
3618
+ }
3619
+
3620
+ // Lowering produces an EmitIsland before using a JTSequence, so we can safely
3621
+ // disable the worst-case-size check in this case.
3622
+ start_off = sink.cur_offset();
3623
+ }
3624
+
3625
+ &Inst::VirtualSPOffsetAdj { offset } => {
3626
+ trace!(
3627
+ "virtual sp offset adjusted by {} -> {}",
3628
+ offset,
3629
+ state.virtual_sp_offset + offset
3630
+ );
3631
+ state.virtual_sp_offset += offset;
3632
+ }
3633
+
3634
+ &Inst::Unwind { ref inst } => {
3635
+ sink.add_unwind(inst.clone());
3636
+ }
3637
+
3638
+ &Inst::DummyUse { .. } => {}
3639
+ }
3640
+
3641
+ let end_off = sink.cur_offset();
3642
+ debug_assert!((end_off - start_off) <= Inst::worst_case_size());
3643
+
3644
+ state.clear_post_insn();
3645
+ }
3646
+ }