wasmtime 20.0.2 → 21.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (2089) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +129 -124
  3. data/ext/Cargo.toml +8 -6
  4. data/ext/cargo-vendor/cobs-0.2.3/.cargo-checksum.json +1 -0
  5. data/ext/cargo-vendor/cobs-0.2.3/Cargo.toml +39 -0
  6. data/ext/cargo-vendor/cobs-0.2.3/LICENSE-APACHE +202 -0
  7. data/ext/cargo-vendor/cobs-0.2.3/LICENSE-MIT +19 -0
  8. data/ext/cargo-vendor/cobs-0.2.3/README.md +23 -0
  9. data/ext/cargo-vendor/cobs-0.2.3/src/dec.rs +360 -0
  10. data/ext/cargo-vendor/cobs-0.2.3/src/enc.rs +216 -0
  11. data/ext/cargo-vendor/cobs-0.2.3/src/lib.rs +14 -0
  12. data/ext/cargo-vendor/cobs-0.2.3/tests/test.rs +265 -0
  13. data/ext/cargo-vendor/cranelift-bforest-0.108.1/.cargo-checksum.json +1 -0
  14. data/ext/cargo-vendor/cranelift-bforest-0.108.1/Cargo.toml +40 -0
  15. data/ext/cargo-vendor/cranelift-codegen-0.108.1/.cargo-checksum.json +1 -0
  16. data/ext/cargo-vendor/cranelift-codegen-0.108.1/Cargo.toml +189 -0
  17. data/ext/cargo-vendor/cranelift-codegen-0.108.1/build.rs +266 -0
  18. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/alias_analysis.rs +403 -0
  19. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/context.rs +395 -0
  20. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/ctxhash.rs +167 -0
  21. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/egraph/elaborate.rs +835 -0
  22. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/egraph.rs +839 -0
  23. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/incremental_cache.rs +256 -0
  24. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/ir/instructions.rs +1020 -0
  25. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/abi.rs +1580 -0
  26. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/args.rs +721 -0
  27. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/emit.rs +3846 -0
  28. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/emit_tests.rs +7902 -0
  29. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/imms.rs +1213 -0
  30. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/mod.rs +3094 -0
  31. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst/regs.rs +288 -0
  32. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/inst.isle +4225 -0
  33. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/lower/isle.rs +810 -0
  34. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/aarch64/pcc.rs +568 -0
  35. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/mod.rs +449 -0
  36. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/abi.rs +1051 -0
  37. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/args.rs +1938 -0
  38. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/emit.rs +2681 -0
  39. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/emit_tests.rs +2197 -0
  40. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/mod.rs +1975 -0
  41. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/regs.rs +168 -0
  42. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst/vector.rs +1144 -0
  43. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/inst.isle +2969 -0
  44. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/lower/isle.rs +625 -0
  45. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/riscv64/lower.isle +2883 -0
  46. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/abi.rs +1037 -0
  47. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/args.rs +314 -0
  48. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/emit.rs +3646 -0
  49. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/imms.rs +202 -0
  50. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/mod.rs +3421 -0
  51. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/s390x/inst/regs.rs +180 -0
  52. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/abi.rs +1410 -0
  53. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/args.rs +2256 -0
  54. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/emit.rs +4311 -0
  55. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/emit_tests.rs +5171 -0
  56. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/mod.rs +2838 -0
  57. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst/regs.rs +276 -0
  58. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/inst.isle +5294 -0
  59. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/lower/isle.rs +1064 -0
  60. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/lower.isle +4808 -0
  61. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/lower.rs +337 -0
  62. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/isa/x64/pcc.rs +1014 -0
  63. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/lib.rs +106 -0
  64. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/abi.rs +2506 -0
  65. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/blockorder.rs +465 -0
  66. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/isle.rs +903 -0
  67. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/lower.rs +1432 -0
  68. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/mod.rs +555 -0
  69. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/reg.rs +522 -0
  70. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/valueregs.rs +138 -0
  71. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/machinst/vcode.rs +1741 -0
  72. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/nan_canonicalization.rs +130 -0
  73. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/opts/arithmetic.isle +240 -0
  74. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/opts/icmp.isle +215 -0
  75. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/ranges.rs +131 -0
  76. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/remove_constant_phis.rs +419 -0
  77. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/scoped_hash_map.rs +310 -0
  78. data/ext/cargo-vendor/cranelift-codegen-0.108.1/src/settings.rs +590 -0
  79. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/.cargo-checksum.json +1 -0
  80. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/Cargo.toml +35 -0
  81. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_inst.rs +1278 -0
  82. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_isle.rs +519 -0
  83. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_settings.rs +508 -0
  84. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/gen_types.rs +75 -0
  85. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/isa/riscv64.rs +168 -0
  86. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/isa/x86.rs +414 -0
  87. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/isle.rs +126 -0
  88. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/lib.rs +98 -0
  89. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/shared/settings.rs +348 -0
  90. data/ext/cargo-vendor/cranelift-codegen-meta-0.108.1/src/srcgen.rs +464 -0
  91. data/ext/cargo-vendor/cranelift-codegen-shared-0.108.1/.cargo-checksum.json +1 -0
  92. data/ext/cargo-vendor/cranelift-codegen-shared-0.108.1/Cargo.toml +22 -0
  93. data/ext/cargo-vendor/cranelift-control-0.108.1/.cargo-checksum.json +1 -0
  94. data/ext/cargo-vendor/cranelift-control-0.108.1/Cargo.toml +30 -0
  95. data/ext/cargo-vendor/cranelift-entity-0.108.1/.cargo-checksum.json +1 -0
  96. data/ext/cargo-vendor/cranelift-entity-0.108.1/Cargo.toml +52 -0
  97. data/ext/cargo-vendor/cranelift-entity-0.108.1/src/lib.rs +381 -0
  98. data/ext/cargo-vendor/cranelift-frontend-0.108.1/.cargo-checksum.json +1 -0
  99. data/ext/cargo-vendor/cranelift-frontend-0.108.1/Cargo.toml +67 -0
  100. data/ext/cargo-vendor/cranelift-frontend-0.108.1/src/switch.rs +696 -0
  101. data/ext/cargo-vendor/cranelift-isle-0.108.1/.cargo-checksum.json +1 -0
  102. data/ext/cargo-vendor/cranelift-isle-0.108.1/Cargo.toml +46 -0
  103. data/ext/cargo-vendor/cranelift-isle-0.108.1/src/codegen.rs +886 -0
  104. data/ext/cargo-vendor/cranelift-isle-0.108.1/src/disjointsets.rs +169 -0
  105. data/ext/cargo-vendor/cranelift-isle-0.108.1/src/lib.rs +33 -0
  106. data/ext/cargo-vendor/cranelift-isle-0.108.1/src/sema.rs +2492 -0
  107. data/ext/cargo-vendor/cranelift-isle-0.108.1/src/serialize.rs +846 -0
  108. data/ext/cargo-vendor/cranelift-isle-0.108.1/src/stablemapset.rs +79 -0
  109. data/ext/cargo-vendor/cranelift-isle-0.108.1/src/trie_again.rs +684 -0
  110. data/ext/cargo-vendor/cranelift-native-0.108.1/.cargo-checksum.json +1 -0
  111. data/ext/cargo-vendor/cranelift-native-0.108.1/Cargo.toml +43 -0
  112. data/ext/cargo-vendor/cranelift-wasm-0.108.1/.cargo-checksum.json +1 -0
  113. data/ext/cargo-vendor/cranelift-wasm-0.108.1/Cargo.toml +109 -0
  114. data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/code_translator.rs +3687 -0
  115. data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/environ/dummy.rs +906 -0
  116. data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/environ/spec.rs +945 -0
  117. data/ext/cargo-vendor/cranelift-wasm-0.108.1/src/sections_translator.rs +389 -0
  118. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.22/.cargo-checksum.json +1 -0
  119. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.22/Cargo.toml +48 -0
  120. data/ext/cargo-vendor/embedded-io-0.4.0/.cargo-checksum.json +1 -0
  121. data/ext/cargo-vendor/embedded-io-0.4.0/CHANGELOG.md +28 -0
  122. data/ext/cargo-vendor/embedded-io-0.4.0/Cargo.toml +73 -0
  123. data/ext/cargo-vendor/embedded-io-0.4.0/LICENSE-APACHE +201 -0
  124. data/ext/cargo-vendor/embedded-io-0.4.0/LICENSE-MIT +25 -0
  125. data/ext/cargo-vendor/embedded-io-0.4.0/README.md +33 -0
  126. data/ext/cargo-vendor/embedded-io-0.4.0/ci.sh +21 -0
  127. data/ext/cargo-vendor/embedded-io-0.4.0/rust-toolchain.toml +3 -0
  128. data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/futures_io.rs +65 -0
  129. data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/mod.rs +40 -0
  130. data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/std_io.rs +107 -0
  131. data/ext/cargo-vendor/embedded-io-0.4.0/src/adapters/tokio.rs +108 -0
  132. data/ext/cargo-vendor/embedded-io-0.4.0/src/asynch.rs +230 -0
  133. data/ext/cargo-vendor/embedded-io-0.4.0/src/blocking.rs +309 -0
  134. data/ext/cargo-vendor/embedded-io-0.4.0/src/fmt.rs +228 -0
  135. data/ext/cargo-vendor/embedded-io-0.4.0/src/lib.rs +125 -0
  136. data/ext/cargo-vendor/libm-0.2.8/.cargo-checksum.json +1 -0
  137. data/ext/cargo-vendor/libm-0.2.8/CHANGELOG.md +123 -0
  138. data/ext/cargo-vendor/libm-0.2.8/CONTRIBUTING.md +95 -0
  139. data/ext/cargo-vendor/libm-0.2.8/Cargo.toml +45 -0
  140. data/ext/cargo-vendor/libm-0.2.8/LICENSE-APACHE +201 -0
  141. data/ext/cargo-vendor/libm-0.2.8/LICENSE-MIT +25 -0
  142. data/ext/cargo-vendor/libm-0.2.8/README.md +51 -0
  143. data/ext/cargo-vendor/libm-0.2.8/build.rs +463 -0
  144. data/ext/cargo-vendor/libm-0.2.8/src/lib.rs +59 -0
  145. data/ext/cargo-vendor/libm-0.2.8/src/libm_helper.rs +171 -0
  146. data/ext/cargo-vendor/libm-0.2.8/src/math/acos.rs +112 -0
  147. data/ext/cargo-vendor/libm-0.2.8/src/math/acosf.rs +79 -0
  148. data/ext/cargo-vendor/libm-0.2.8/src/math/acosh.rs +27 -0
  149. data/ext/cargo-vendor/libm-0.2.8/src/math/acoshf.rs +26 -0
  150. data/ext/cargo-vendor/libm-0.2.8/src/math/asin.rs +119 -0
  151. data/ext/cargo-vendor/libm-0.2.8/src/math/asinf.rs +72 -0
  152. data/ext/cargo-vendor/libm-0.2.8/src/math/asinh.rs +40 -0
  153. data/ext/cargo-vendor/libm-0.2.8/src/math/asinhf.rs +39 -0
  154. data/ext/cargo-vendor/libm-0.2.8/src/math/atan.rs +184 -0
  155. data/ext/cargo-vendor/libm-0.2.8/src/math/atan2.rs +126 -0
  156. data/ext/cargo-vendor/libm-0.2.8/src/math/atan2f.rs +91 -0
  157. data/ext/cargo-vendor/libm-0.2.8/src/math/atanf.rs +112 -0
  158. data/ext/cargo-vendor/libm-0.2.8/src/math/atanh.rs +37 -0
  159. data/ext/cargo-vendor/libm-0.2.8/src/math/atanhf.rs +37 -0
  160. data/ext/cargo-vendor/libm-0.2.8/src/math/cbrt.rs +113 -0
  161. data/ext/cargo-vendor/libm-0.2.8/src/math/cbrtf.rs +75 -0
  162. data/ext/cargo-vendor/libm-0.2.8/src/math/ceil.rs +82 -0
  163. data/ext/cargo-vendor/libm-0.2.8/src/math/ceilf.rs +65 -0
  164. data/ext/cargo-vendor/libm-0.2.8/src/math/copysign.rs +12 -0
  165. data/ext/cargo-vendor/libm-0.2.8/src/math/copysignf.rs +12 -0
  166. data/ext/cargo-vendor/libm-0.2.8/src/math/cos.rs +73 -0
  167. data/ext/cargo-vendor/libm-0.2.8/src/math/cosf.rs +83 -0
  168. data/ext/cargo-vendor/libm-0.2.8/src/math/cosh.rs +38 -0
  169. data/ext/cargo-vendor/libm-0.2.8/src/math/coshf.rs +38 -0
  170. data/ext/cargo-vendor/libm-0.2.8/src/math/erf.rs +318 -0
  171. data/ext/cargo-vendor/libm-0.2.8/src/math/erff.rs +230 -0
  172. data/ext/cargo-vendor/libm-0.2.8/src/math/exp.rs +154 -0
  173. data/ext/cargo-vendor/libm-0.2.8/src/math/exp10.rs +22 -0
  174. data/ext/cargo-vendor/libm-0.2.8/src/math/exp10f.rs +22 -0
  175. data/ext/cargo-vendor/libm-0.2.8/src/math/exp2.rs +394 -0
  176. data/ext/cargo-vendor/libm-0.2.8/src/math/exp2f.rs +135 -0
  177. data/ext/cargo-vendor/libm-0.2.8/src/math/expf.rs +101 -0
  178. data/ext/cargo-vendor/libm-0.2.8/src/math/expm1.rs +144 -0
  179. data/ext/cargo-vendor/libm-0.2.8/src/math/expm1f.rs +134 -0
  180. data/ext/cargo-vendor/libm-0.2.8/src/math/expo2.rs +14 -0
  181. data/ext/cargo-vendor/libm-0.2.8/src/math/fabs.rs +41 -0
  182. data/ext/cargo-vendor/libm-0.2.8/src/math/fabsf.rs +41 -0
  183. data/ext/cargo-vendor/libm-0.2.8/src/math/fdim.rs +22 -0
  184. data/ext/cargo-vendor/libm-0.2.8/src/math/fdimf.rs +22 -0
  185. data/ext/cargo-vendor/libm-0.2.8/src/math/fenv.rs +27 -0
  186. data/ext/cargo-vendor/libm-0.2.8/src/math/floor.rs +81 -0
  187. data/ext/cargo-vendor/libm-0.2.8/src/math/floorf.rs +66 -0
  188. data/ext/cargo-vendor/libm-0.2.8/src/math/fma.rs +232 -0
  189. data/ext/cargo-vendor/libm-0.2.8/src/math/fmaf.rs +117 -0
  190. data/ext/cargo-vendor/libm-0.2.8/src/math/fmax.rs +12 -0
  191. data/ext/cargo-vendor/libm-0.2.8/src/math/fmaxf.rs +12 -0
  192. data/ext/cargo-vendor/libm-0.2.8/src/math/fmin.rs +12 -0
  193. data/ext/cargo-vendor/libm-0.2.8/src/math/fminf.rs +12 -0
  194. data/ext/cargo-vendor/libm-0.2.8/src/math/fmod.rs +80 -0
  195. data/ext/cargo-vendor/libm-0.2.8/src/math/fmodf.rs +89 -0
  196. data/ext/cargo-vendor/libm-0.2.8/src/math/frexp.rs +20 -0
  197. data/ext/cargo-vendor/libm-0.2.8/src/math/frexpf.rs +21 -0
  198. data/ext/cargo-vendor/libm-0.2.8/src/math/hypot.rs +74 -0
  199. data/ext/cargo-vendor/libm-0.2.8/src/math/hypotf.rs +43 -0
  200. data/ext/cargo-vendor/libm-0.2.8/src/math/ilogb.rs +32 -0
  201. data/ext/cargo-vendor/libm-0.2.8/src/math/ilogbf.rs +32 -0
  202. data/ext/cargo-vendor/libm-0.2.8/src/math/j0.rs +422 -0
  203. data/ext/cargo-vendor/libm-0.2.8/src/math/j0f.rs +359 -0
  204. data/ext/cargo-vendor/libm-0.2.8/src/math/j1.rs +414 -0
  205. data/ext/cargo-vendor/libm-0.2.8/src/math/j1f.rs +380 -0
  206. data/ext/cargo-vendor/libm-0.2.8/src/math/jn.rs +343 -0
  207. data/ext/cargo-vendor/libm-0.2.8/src/math/jnf.rs +259 -0
  208. data/ext/cargo-vendor/libm-0.2.8/src/math/k_cos.rs +62 -0
  209. data/ext/cargo-vendor/libm-0.2.8/src/math/k_cosf.rs +29 -0
  210. data/ext/cargo-vendor/libm-0.2.8/src/math/k_expo2.rs +14 -0
  211. data/ext/cargo-vendor/libm-0.2.8/src/math/k_expo2f.rs +14 -0
  212. data/ext/cargo-vendor/libm-0.2.8/src/math/k_sin.rs +57 -0
  213. data/ext/cargo-vendor/libm-0.2.8/src/math/k_sinf.rs +30 -0
  214. data/ext/cargo-vendor/libm-0.2.8/src/math/k_tan.rs +105 -0
  215. data/ext/cargo-vendor/libm-0.2.8/src/math/k_tanf.rs +46 -0
  216. data/ext/cargo-vendor/libm-0.2.8/src/math/ldexp.rs +4 -0
  217. data/ext/cargo-vendor/libm-0.2.8/src/math/ldexpf.rs +4 -0
  218. data/ext/cargo-vendor/libm-0.2.8/src/math/lgamma.rs +6 -0
  219. data/ext/cargo-vendor/libm-0.2.8/src/math/lgamma_r.rs +320 -0
  220. data/ext/cargo-vendor/libm-0.2.8/src/math/lgammaf.rs +6 -0
  221. data/ext/cargo-vendor/libm-0.2.8/src/math/lgammaf_r.rs +255 -0
  222. data/ext/cargo-vendor/libm-0.2.8/src/math/log.rs +117 -0
  223. data/ext/cargo-vendor/libm-0.2.8/src/math/log10.rs +117 -0
  224. data/ext/cargo-vendor/libm-0.2.8/src/math/log10f.rs +91 -0
  225. data/ext/cargo-vendor/libm-0.2.8/src/math/log1p.rs +143 -0
  226. data/ext/cargo-vendor/libm-0.2.8/src/math/log1pf.rs +98 -0
  227. data/ext/cargo-vendor/libm-0.2.8/src/math/log2.rs +106 -0
  228. data/ext/cargo-vendor/libm-0.2.8/src/math/log2f.rs +87 -0
  229. data/ext/cargo-vendor/libm-0.2.8/src/math/logf.rs +65 -0
  230. data/ext/cargo-vendor/libm-0.2.8/src/math/mod.rs +370 -0
  231. data/ext/cargo-vendor/libm-0.2.8/src/math/modf.rs +34 -0
  232. data/ext/cargo-vendor/libm-0.2.8/src/math/modff.rs +33 -0
  233. data/ext/cargo-vendor/libm-0.2.8/src/math/nextafter.rs +37 -0
  234. data/ext/cargo-vendor/libm-0.2.8/src/math/nextafterf.rs +37 -0
  235. data/ext/cargo-vendor/libm-0.2.8/src/math/pow.rs +637 -0
  236. data/ext/cargo-vendor/libm-0.2.8/src/math/powf.rs +342 -0
  237. data/ext/cargo-vendor/libm-0.2.8/src/math/rem_pio2.rs +233 -0
  238. data/ext/cargo-vendor/libm-0.2.8/src/math/rem_pio2_large.rs +470 -0
  239. data/ext/cargo-vendor/libm-0.2.8/src/math/rem_pio2f.rs +67 -0
  240. data/ext/cargo-vendor/libm-0.2.8/src/math/remainder.rs +5 -0
  241. data/ext/cargo-vendor/libm-0.2.8/src/math/remainderf.rs +5 -0
  242. data/ext/cargo-vendor/libm-0.2.8/src/math/remquo.rs +110 -0
  243. data/ext/cargo-vendor/libm-0.2.8/src/math/remquof.rs +97 -0
  244. data/ext/cargo-vendor/libm-0.2.8/src/math/rint.rs +58 -0
  245. data/ext/cargo-vendor/libm-0.2.8/src/math/rintf.rs +58 -0
  246. data/ext/cargo-vendor/libm-0.2.8/src/math/round.rs +28 -0
  247. data/ext/cargo-vendor/libm-0.2.8/src/math/roundf.rs +30 -0
  248. data/ext/cargo-vendor/libm-0.2.8/src/math/scalbn.rs +33 -0
  249. data/ext/cargo-vendor/libm-0.2.8/src/math/scalbnf.rs +29 -0
  250. data/ext/cargo-vendor/libm-0.2.8/src/math/sin.rs +88 -0
  251. data/ext/cargo-vendor/libm-0.2.8/src/math/sincos.rs +134 -0
  252. data/ext/cargo-vendor/libm-0.2.8/src/math/sincosf.rs +185 -0
  253. data/ext/cargo-vendor/libm-0.2.8/src/math/sinf.rs +93 -0
  254. data/ext/cargo-vendor/libm-0.2.8/src/math/sinh.rs +49 -0
  255. data/ext/cargo-vendor/libm-0.2.8/src/math/sinhf.rs +30 -0
  256. data/ext/cargo-vendor/libm-0.2.8/src/math/sqrt.rs +280 -0
  257. data/ext/cargo-vendor/libm-0.2.8/src/math/sqrtf.rs +170 -0
  258. data/ext/cargo-vendor/libm-0.2.8/src/math/tan.rs +70 -0
  259. data/ext/cargo-vendor/libm-0.2.8/src/math/tanf.rs +78 -0
  260. data/ext/cargo-vendor/libm-0.2.8/src/math/tanh.rs +53 -0
  261. data/ext/cargo-vendor/libm-0.2.8/src/math/tanhf.rs +39 -0
  262. data/ext/cargo-vendor/libm-0.2.8/src/math/tgamma.rs +208 -0
  263. data/ext/cargo-vendor/libm-0.2.8/src/math/tgammaf.rs +6 -0
  264. data/ext/cargo-vendor/libm-0.2.8/src/math/trunc.rs +40 -0
  265. data/ext/cargo-vendor/libm-0.2.8/src/math/truncf.rs +42 -0
  266. data/ext/cargo-vendor/postcard-1.0.8/.cargo-checksum.json +1 -0
  267. data/ext/cargo-vendor/postcard-1.0.8/CHANGELOG.md +141 -0
  268. data/ext/cargo-vendor/postcard-1.0.8/Cargo.toml +100 -0
  269. data/ext/cargo-vendor/postcard-1.0.8/LICENSE-APACHE +201 -0
  270. data/ext/cargo-vendor/postcard-1.0.8/LICENSE-MIT +25 -0
  271. data/ext/cargo-vendor/postcard-1.0.8/README.md +146 -0
  272. data/ext/cargo-vendor/postcard-1.0.8/spec/LICENSE-CC-BY-SA +427 -0
  273. data/ext/cargo-vendor/postcard-1.0.8/spec/book.toml +6 -0
  274. data/ext/cargo-vendor/postcard-1.0.8/spec/src/SUMMARY.md +6 -0
  275. data/ext/cargo-vendor/postcard-1.0.8/spec/src/glossary.md +17 -0
  276. data/ext/cargo-vendor/postcard-1.0.8/spec/src/intro.md +12 -0
  277. data/ext/cargo-vendor/postcard-1.0.8/spec/src/serde-data-model.md +190 -0
  278. data/ext/cargo-vendor/postcard-1.0.8/spec/src/wire-format.md +327 -0
  279. data/ext/cargo-vendor/postcard-1.0.8/src/accumulator.rs +367 -0
  280. data/ext/cargo-vendor/postcard-1.0.8/src/de/deserializer.rs +599 -0
  281. data/ext/cargo-vendor/postcard-1.0.8/src/de/flavors.rs +468 -0
  282. data/ext/cargo-vendor/postcard-1.0.8/src/de/mod.rs +568 -0
  283. data/ext/cargo-vendor/postcard-1.0.8/src/error.rs +95 -0
  284. data/ext/cargo-vendor/postcard-1.0.8/src/fixint.rs +189 -0
  285. data/ext/cargo-vendor/postcard-1.0.8/src/lib.rs +143 -0
  286. data/ext/cargo-vendor/postcard-1.0.8/src/max_size.rs +233 -0
  287. data/ext/cargo-vendor/postcard-1.0.8/src/schema.rs +282 -0
  288. data/ext/cargo-vendor/postcard-1.0.8/src/ser/flavors.rs +722 -0
  289. data/ext/cargo-vendor/postcard-1.0.8/src/ser/mod.rs +866 -0
  290. data/ext/cargo-vendor/postcard-1.0.8/src/ser/serializer.rs +564 -0
  291. data/ext/cargo-vendor/postcard-1.0.8/src/varint.rs +103 -0
  292. data/ext/cargo-vendor/postcard-1.0.8/tests/accumulator.rs +57 -0
  293. data/ext/cargo-vendor/postcard-1.0.8/tests/crc.rs +60 -0
  294. data/ext/cargo-vendor/postcard-1.0.8/tests/loopback.rs +248 -0
  295. data/ext/cargo-vendor/postcard-1.0.8/tests/max_size.rs +101 -0
  296. data/ext/cargo-vendor/postcard-1.0.8/tests/schema.rs +107 -0
  297. data/ext/cargo-vendor/rb-sys-0.9.100/.cargo-checksum.json +1 -0
  298. data/ext/cargo-vendor/rb-sys-0.9.100/Cargo.toml +58 -0
  299. data/ext/cargo-vendor/rb-sys-0.9.100/build/main.rs +267 -0
  300. data/ext/cargo-vendor/rb-sys-0.9.100/build/stable_api_config.rs +139 -0
  301. data/ext/cargo-vendor/rb-sys-0.9.100/src/bindings.rs +21 -0
  302. data/ext/cargo-vendor/rb-sys-0.9.100/src/tracking_allocator.rs +266 -0
  303. data/ext/cargo-vendor/rb-sys-build-0.9.100/.cargo-checksum.json +1 -0
  304. data/ext/cargo-vendor/rb-sys-build-0.9.100/Cargo.toml +62 -0
  305. data/ext/cargo-vendor/rb-sys-build-0.9.100/src/bindings/stable_api.rs +203 -0
  306. data/ext/cargo-vendor/rb-sys-build-0.9.100/src/bindings.rs +254 -0
  307. data/ext/cargo-vendor/rb-sys-build-0.9.100/src/cc.rs +374 -0
  308. data/ext/cargo-vendor/rb-sys-build-0.9.100/src/utils.rs +52 -0
  309. data/ext/cargo-vendor/wasi-common-21.0.1/.cargo-checksum.json +1 -0
  310. data/ext/cargo-vendor/wasi-common-21.0.1/Cargo.toml +223 -0
  311. data/ext/cargo-vendor/wasi-common-21.0.1/tests/all/async_.rs +293 -0
  312. data/ext/cargo-vendor/wasi-common-21.0.1/tests/all/main.rs +21 -0
  313. data/ext/cargo-vendor/wasi-common-21.0.1/tests/all/sync.rs +279 -0
  314. data/ext/cargo-vendor/wasm-encoder-0.207.0/.cargo-checksum.json +1 -0
  315. data/ext/cargo-vendor/wasm-encoder-0.207.0/Cargo.toml +45 -0
  316. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/code.rs +3502 -0
  317. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/data.rs +186 -0
  318. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/elements.rs +221 -0
  319. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/globals.rs +112 -0
  320. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/imports.rs +157 -0
  321. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/memories.rs +128 -0
  322. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/tables.rs +134 -0
  323. data/ext/cargo-vendor/wasm-encoder-0.207.0/src/core/types.rs +678 -0
  324. data/ext/cargo-vendor/wasmparser-0.207.0/.cargo-checksum.json +1 -0
  325. data/ext/cargo-vendor/wasmparser-0.207.0/Cargo.lock +659 -0
  326. data/ext/cargo-vendor/wasmparser-0.207.0/Cargo.toml +95 -0
  327. data/ext/cargo-vendor/wasmparser-0.207.0/src/binary_reader.rs +1867 -0
  328. data/ext/cargo-vendor/wasmparser-0.207.0/src/lib.rs +805 -0
  329. data/ext/cargo-vendor/wasmparser-0.207.0/src/limits.rs +78 -0
  330. data/ext/cargo-vendor/wasmparser-0.207.0/src/map.rs +137 -0
  331. data/ext/cargo-vendor/wasmparser-0.207.0/src/parser.rs +1636 -0
  332. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/canonicals.rs +121 -0
  333. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/instances.rs +164 -0
  334. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/names.rs +102 -0
  335. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/start.rs +31 -0
  336. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/component/types.rs +551 -0
  337. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/code.rs +146 -0
  338. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/coredumps.rs +244 -0
  339. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/custom.rs +64 -0
  340. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/data.rs +96 -0
  341. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/dylink0.rs +110 -0
  342. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/elements.rs +152 -0
  343. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/globals.rs +51 -0
  344. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/linking.rs +450 -0
  345. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/memories.rs +57 -0
  346. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/names.rs +159 -0
  347. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/operators.rs +430 -0
  348. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/reloc.rs +301 -0
  349. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/tables.rs +93 -0
  350. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/types/matches.rs +277 -0
  351. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core/types.rs +1773 -0
  352. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers/core.rs +43 -0
  353. data/ext/cargo-vendor/wasmparser-0.207.0/src/readers.rs +316 -0
  354. data/ext/cargo-vendor/wasmparser-0.207.0/src/resources.rs +235 -0
  355. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/component.rs +3242 -0
  356. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/core/canonical.rs +233 -0
  357. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/core.rs +1450 -0
  358. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/func.rs +331 -0
  359. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/names.rs +947 -0
  360. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/operators.rs +4117 -0
  361. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator/types.rs +4492 -0
  362. data/ext/cargo-vendor/wasmparser-0.207.0/src/validator.rs +1786 -0
  363. data/ext/cargo-vendor/wasmprinter-0.207.0/.cargo-checksum.json +1 -0
  364. data/ext/cargo-vendor/wasmprinter-0.207.0/Cargo.toml +50 -0
  365. data/ext/cargo-vendor/wasmprinter-0.207.0/src/lib.rs +3226 -0
  366. data/ext/cargo-vendor/wasmprinter-0.207.0/src/operator.rs +1164 -0
  367. data/ext/cargo-vendor/wasmprinter-0.207.0/tests/all.rs +293 -0
  368. data/ext/cargo-vendor/wasmtime-21.0.1/.cargo-checksum.json +1 -0
  369. data/ext/cargo-vendor/wasmtime-21.0.1/Cargo.toml +386 -0
  370. data/ext/cargo-vendor/wasmtime-21.0.1/build.rs +37 -0
  371. data/ext/cargo-vendor/wasmtime-21.0.1/src/compile/code_builder.rs +275 -0
  372. data/ext/cargo-vendor/wasmtime-21.0.1/src/compile/runtime.rs +176 -0
  373. data/ext/cargo-vendor/wasmtime-21.0.1/src/compile.rs +910 -0
  374. data/ext/cargo-vendor/wasmtime-21.0.1/src/config.rs +2904 -0
  375. data/ext/cargo-vendor/wasmtime-21.0.1/src/engine/serialization.rs +887 -0
  376. data/ext/cargo-vendor/wasmtime-21.0.1/src/engine.rs +728 -0
  377. data/ext/cargo-vendor/wasmtime-21.0.1/src/lib.rs +328 -0
  378. data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent/jitdump.rs +67 -0
  379. data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent/perfmap.rs +48 -0
  380. data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent/vtune.rs +81 -0
  381. data/ext/cargo-vendor/wasmtime-21.0.1/src/profiling_agent.rs +106 -0
  382. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/code.rs +102 -0
  383. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/code_memory.rs +337 -0
  384. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/component.rs +661 -0
  385. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func/host.rs +440 -0
  386. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func/options.rs +555 -0
  387. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func/typed.rs +2498 -0
  388. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/func.rs +746 -0
  389. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/instance.rs +814 -0
  390. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/linker.rs +783 -0
  391. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/matching.rs +217 -0
  392. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/mod.rs +783 -0
  393. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/resource_table.rs +355 -0
  394. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/resources.rs +1133 -0
  395. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/storage.rs +43 -0
  396. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/store.rs +29 -0
  397. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/types.rs +892 -0
  398. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/component/values.rs +980 -0
  399. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/coredump.rs +342 -0
  400. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/debug.rs +166 -0
  401. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/externals/global.rs +310 -0
  402. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/externals/table.rs +477 -0
  403. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/externals.rs +236 -0
  404. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/func/typed.rs +899 -0
  405. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/func.rs +2627 -0
  406. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/disabled/anyref.rs +46 -0
  407. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/disabled/externref.rs +50 -0
  408. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/disabled/rooting.rs +224 -0
  409. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/anyref.rs +473 -0
  410. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/externref.rs +650 -0
  411. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/i31.rs +346 -0
  412. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc/enabled/rooting.rs +1588 -0
  413. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/gc.rs +89 -0
  414. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/instance.rs +992 -0
  415. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/instantiate.rs +346 -0
  416. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/limits.rs +399 -0
  417. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/linker.rs +1506 -0
  418. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/memory.rs +998 -0
  419. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/module/registry.rs +353 -0
  420. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/module.rs +1295 -0
  421. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/profiling.rs +221 -0
  422. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/resources.rs +33 -0
  423. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/signatures.rs +216 -0
  424. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/stack.rs +73 -0
  425. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store/context.rs +243 -0
  426. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store/data.rs +301 -0
  427. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store/func_refs.rs +90 -0
  428. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/store.rs +2820 -0
  429. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/func.rs +139 -0
  430. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/global.rs +68 -0
  431. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/memory.rs +287 -0
  432. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline/table.rs +29 -0
  433. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trampoline.rs +78 -0
  434. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/trap.rs +642 -0
  435. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/type_registry.rs +807 -0
  436. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/types/matching.rs +421 -0
  437. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/types.rs +2239 -0
  438. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/unix.rs +40 -0
  439. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/v128.rs +131 -0
  440. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/values.rs +966 -0
  441. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/arch/aarch64.rs +76 -0
  442. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/arch/x86_64.rs +41 -0
  443. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/async_yield.rs +35 -0
  444. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/component/libcalls.rs +571 -0
  445. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/component/resources.rs +352 -0
  446. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/component.rs +860 -0
  447. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/const_expr.rs +102 -0
  448. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/cow.rs +893 -0
  449. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/debug_builtins.rs +59 -0
  450. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/export.rs +108 -0
  451. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/disabled.rs +24 -0
  452. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled/drc.rs +968 -0
  453. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled/externref.rs +116 -0
  454. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled/free_list.rs +771 -0
  455. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/enabled.rs +18 -0
  456. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/gc_ref.rs +491 -0
  457. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/gc_runtime.rs +506 -0
  458. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/host_data.rs +82 -0
  459. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc/i31.rs +87 -0
  460. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/gc.rs +245 -0
  461. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/imports.rs +29 -0
  462. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/on_demand.rs +218 -0
  463. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/gc_heap_pool.rs +93 -0
  464. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/generic_stack_pool.rs +66 -0
  465. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/index_allocator.rs +705 -0
  466. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/memory_pool.rs +1000 -0
  467. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/table_pool.rs +233 -0
  468. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling/unix_stack_pool.rs +245 -0
  469. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator/pooling.rs +656 -0
  470. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance/allocator.rs +798 -0
  471. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/instance.rs +1519 -0
  472. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/libcalls.rs +834 -0
  473. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/memory.rs +744 -0
  474. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mmap.rs +220 -0
  475. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mmap_vec.rs +162 -0
  476. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/module_id.rs +43 -0
  477. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/enabled.rs +214 -0
  478. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/mod.rs +54 -0
  479. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/pkru.rs +104 -0
  480. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/mpk/sys.rs +114 -0
  481. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/send_sync_ptr.rs +106 -0
  482. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/store_box.rs +37 -0
  483. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/capi.rs +200 -0
  484. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/mmap.rs +112 -0
  485. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/mod.rs +34 -0
  486. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/traphandlers.rs +55 -0
  487. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/custom/vm.rs +109 -0
  488. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/miri/mmap.rs +95 -0
  489. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/miri/mod.rs +24 -0
  490. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/miri/traphandlers.rs +47 -0
  491. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/mod.rs +25 -0
  492. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/machports.rs +416 -0
  493. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/mmap.rs +162 -0
  494. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/mod.rs +35 -0
  495. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/signals.rs +401 -0
  496. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/unwind.rs +150 -0
  497. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/unix/vm.rs +215 -0
  498. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/windows/mmap.rs +221 -0
  499. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/windows/mod.rs +20 -0
  500. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/sys/windows/traphandlers.rs +104 -0
  501. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/table.rs +847 -0
  502. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/threads/parking_spot.rs +623 -0
  503. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/threads/shared_memory.rs +233 -0
  504. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/threads/shared_memory_disabled.rs +101 -0
  505. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers/backtrace.rs +267 -0
  506. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers/coredump_disabled.rs +16 -0
  507. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers/coredump_enabled.rs +42 -0
  508. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/traphandlers.rs +768 -0
  509. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/vmcontext/vm_host_func_context.rs +138 -0
  510. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm/vmcontext.rs +1337 -0
  511. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/vm.rs +287 -0
  512. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime/windows.rs +35 -0
  513. data/ext/cargo-vendor/wasmtime-21.0.1/src/runtime.rs +110 -0
  514. data/ext/cargo-vendor/wasmtime-21.0.1/src/sync_nostd.rs +255 -0
  515. data/ext/cargo-vendor/wasmtime-21.0.1/src/sync_std.rs +52 -0
  516. data/ext/cargo-vendor/wasmtime-asm-macros-21.0.1/.cargo-checksum.json +1 -0
  517. data/ext/cargo-vendor/wasmtime-asm-macros-21.0.1/Cargo.toml +22 -0
  518. data/ext/cargo-vendor/wasmtime-asm-macros-21.0.1/src/lib.rs +83 -0
  519. data/ext/cargo-vendor/wasmtime-cache-21.0.1/.cargo-checksum.json +1 -0
  520. data/ext/cargo-vendor/wasmtime-cache-21.0.1/Cargo.toml +88 -0
  521. data/ext/cargo-vendor/wasmtime-cache-21.0.1/src/lib.rs +235 -0
  522. data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/.cargo-checksum.json +1 -0
  523. data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/Cargo.toml +79 -0
  524. data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/src/bindgen.rs +436 -0
  525. data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/src/component.rs +1295 -0
  526. data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/tests/codegen.rs +576 -0
  527. data/ext/cargo-vendor/wasmtime-component-macro-21.0.1/tests/codegen_no_std.rs +16 -0
  528. data/ext/cargo-vendor/wasmtime-component-util-21.0.1/.cargo-checksum.json +1 -0
  529. data/ext/cargo-vendor/wasmtime-component-util-21.0.1/Cargo.toml +25 -0
  530. data/ext/cargo-vendor/wasmtime-component-util-21.0.1/src/lib.rs +182 -0
  531. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/.cargo-checksum.json +1 -0
  532. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/Cargo.toml +114 -0
  533. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/compiler/component.rs +968 -0
  534. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/compiler.rs +1383 -0
  535. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/gc.rs +252 -0
  536. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/attr.rs +320 -0
  537. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/expression.rs +1248 -0
  538. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/line_program.rs +287 -0
  539. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/mod.rs +256 -0
  540. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/unit.rs +529 -0
  541. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/transform/utils.rs +186 -0
  542. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug/write_debuginfo.rs +196 -0
  543. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/debug.rs +18 -0
  544. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/func_environ.rs +2888 -0
  545. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/gc/enabled.rs +648 -0
  546. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/gc.rs +198 -0
  547. data/ext/cargo-vendor/wasmtime-cranelift-21.0.1/src/lib.rs +511 -0
  548. data/ext/cargo-vendor/wasmtime-environ-21.0.1/.cargo-checksum.json +1 -0
  549. data/ext/cargo-vendor/wasmtime-environ-21.0.1/Cargo.lock +772 -0
  550. data/ext/cargo-vendor/wasmtime-environ-21.0.1/Cargo.toml +154 -0
  551. data/ext/cargo-vendor/wasmtime-environ-21.0.1/examples/factc.rs +198 -0
  552. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/address_map.rs +73 -0
  553. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/mod.rs +419 -0
  554. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/module_artifacts.rs +315 -0
  555. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/module_environ.rs +1337 -0
  556. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/module_types.rs +362 -0
  557. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/compile/trap_encoding.rs +70 -0
  558. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/compiler.rs +20 -0
  559. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/dfg.rs +691 -0
  560. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/info.rs +672 -0
  561. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/translate/adapt.rs +455 -0
  562. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/translate.rs +978 -0
  563. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/types.rs +1029 -0
  564. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/types_builder/resources.rs +233 -0
  565. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component/types_builder.rs +997 -0
  566. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/component.rs +107 -0
  567. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/demangling.rs +28 -0
  568. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/core_types.rs +25 -0
  569. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/signature.rs +119 -0
  570. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/trampoline.rs +3234 -0
  571. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/transcode.rs +90 -0
  572. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact/traps.rs +116 -0
  573. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/fact.rs +714 -0
  574. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/lib.rs +161 -0
  575. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/module.rs +697 -0
  576. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/module_artifacts.rs +146 -0
  577. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/module_types.rs +91 -0
  578. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/scopevec.rs +80 -0
  579. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/stack_map.rs +37 -0
  580. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/trap_encoding.rs +189 -0
  581. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/tunables.rs +168 -0
  582. data/ext/cargo-vendor/wasmtime-environ-21.0.1/src/vmoffsets.rs +1015 -0
  583. data/ext/cargo-vendor/wasmtime-fiber-21.0.1/.cargo-checksum.json +1 -0
  584. data/ext/cargo-vendor/wasmtime-fiber-21.0.1/Cargo.toml +64 -0
  585. data/ext/cargo-vendor/wasmtime-fiber-21.0.1/build.rs +38 -0
  586. data/ext/cargo-vendor/wasmtime-fiber-21.0.1/src/lib.rs +328 -0
  587. data/ext/cargo-vendor/wasmtime-fiber-21.0.1/src/unix.rs +490 -0
  588. data/ext/cargo-vendor/wasmtime-fiber-21.0.1/src/windows.rs +166 -0
  589. data/ext/cargo-vendor/wasmtime-jit-debug-21.0.1/.cargo-checksum.json +1 -0
  590. data/ext/cargo-vendor/wasmtime-jit-debug-21.0.1/Cargo.toml +67 -0
  591. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/.cargo-checksum.json +1 -0
  592. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/Cargo.toml +51 -0
  593. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/lib.rs +109 -0
  594. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/libc.rs +163 -0
  595. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/miri.rs +10 -0
  596. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-21.0.1/src/win.rs +49 -0
  597. data/ext/cargo-vendor/wasmtime-slab-21.0.1/.cargo-checksum.json +1 -0
  598. data/ext/cargo-vendor/wasmtime-slab-21.0.1/Cargo.toml +21 -0
  599. data/ext/cargo-vendor/wasmtime-slab-21.0.1/src/lib.rs +498 -0
  600. data/ext/cargo-vendor/wasmtime-types-21.0.1/.cargo-checksum.json +1 -0
  601. data/ext/cargo-vendor/wasmtime-types-21.0.1/Cargo.toml +55 -0
  602. data/ext/cargo-vendor/wasmtime-types-21.0.1/src/error.rs +81 -0
  603. data/ext/cargo-vendor/wasmtime-types-21.0.1/src/lib.rs +1572 -0
  604. data/ext/cargo-vendor/wasmtime-versioned-export-macros-21.0.1/.cargo-checksum.json +1 -0
  605. data/ext/cargo-vendor/wasmtime-versioned-export-macros-21.0.1/Cargo.toml +32 -0
  606. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/.cargo-checksum.json +1 -0
  607. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/Cargo.toml +200 -0
  608. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/bindings.rs +280 -0
  609. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/ctx.rs +667 -0
  610. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/filesystem.rs +446 -0
  611. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/lib.rs +426 -0
  612. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/preview0.rs +877 -0
  613. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/src/preview1.rs +2660 -0
  614. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/api.rs +198 -0
  615. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/async_.rs +397 -0
  616. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/main.rs +91 -0
  617. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/preview1.rs +251 -0
  618. data/ext/cargo-vendor/wasmtime-wasi-21.0.1/tests/all/sync.rs +331 -0
  619. data/ext/cargo-vendor/wasmtime-winch-21.0.1/.cargo-checksum.json +1 -0
  620. data/ext/cargo-vendor/wasmtime-winch-21.0.1/Cargo.toml +81 -0
  621. data/ext/cargo-vendor/wasmtime-winch-21.0.1/src/compiler.rs +261 -0
  622. data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/.cargo-checksum.json +1 -0
  623. data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/Cargo.toml +46 -0
  624. data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/src/lib.rs +2541 -0
  625. data/ext/cargo-vendor/wasmtime-wit-bindgen-21.0.1/src/rust.rs +421 -0
  626. data/ext/cargo-vendor/wiggle-21.0.1/.cargo-checksum.json +1 -0
  627. data/ext/cargo-vendor/wiggle-21.0.1/Cargo.toml +123 -0
  628. data/ext/cargo-vendor/wiggle-generate-21.0.1/.cargo-checksum.json +1 -0
  629. data/ext/cargo-vendor/wiggle-generate-21.0.1/Cargo.toml +66 -0
  630. data/ext/cargo-vendor/wiggle-macro-21.0.1/.cargo-checksum.json +1 -0
  631. data/ext/cargo-vendor/wiggle-macro-21.0.1/Cargo.toml +55 -0
  632. data/ext/cargo-vendor/winch-codegen-0.19.1/.cargo-checksum.json +1 -0
  633. data/ext/cargo-vendor/winch-codegen-0.19.1/Cargo.toml +76 -0
  634. data/ext/cargo-vendor/winch-codegen-0.19.1/src/codegen/context.rs +534 -0
  635. data/ext/cargo-vendor/winch-codegen-0.19.1/src/codegen/env.rs +440 -0
  636. data/ext/cargo-vendor/winch-codegen-0.19.1/src/codegen/mod.rs +882 -0
  637. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/abi.rs +291 -0
  638. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/address.rs +143 -0
  639. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/asm.rs +380 -0
  640. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/masm.rs +566 -0
  641. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/mod.rs +158 -0
  642. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/aarch64/regs.rs +161 -0
  643. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/reg.rs +73 -0
  644. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/x64/asm.rs +1423 -0
  645. data/ext/cargo-vendor/winch-codegen-0.19.1/src/isa/x64/masm.rs +1120 -0
  646. data/ext/cargo-vendor/winch-codegen-0.19.1/src/masm.rs +941 -0
  647. data/ext/cargo-vendor/winch-codegen-0.19.1/src/regalloc.rs +65 -0
  648. data/ext/cargo-vendor/winch-codegen-0.19.1/src/regset.rs +194 -0
  649. data/ext/cargo-vendor/winch-codegen-0.19.1/src/visitor.rs +2144 -0
  650. data/ext/cargo-vendor/wit-parser-0.207.0/.cargo-checksum.json +1 -0
  651. data/ext/cargo-vendor/wit-parser-0.207.0/Cargo.toml +109 -0
  652. data/ext/cargo-vendor/wit-parser-0.207.0/src/ast/resolve.rs +1442 -0
  653. data/ext/cargo-vendor/wit-parser-0.207.0/src/decoding.rs +1764 -0
  654. data/ext/cargo-vendor/wit-parser-0.207.0/src/lib.rs +777 -0
  655. data/ext/cargo-vendor/wit-parser-0.207.0/src/live.rs +126 -0
  656. data/ext/cargo-vendor/wit-parser-0.207.0/src/resolve.rs +2337 -0
  657. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/resources-multiple-returns-borrow.wit.result +5 -0
  658. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/resources-return-borrow.wit.result +5 -0
  659. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow1.wit +7 -0
  660. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow1.wit.result +5 -0
  661. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow2.wit +8 -0
  662. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow2.wit.result +5 -0
  663. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow3.wit +7 -0
  664. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow3.wit.result +5 -0
  665. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow4.wit +7 -0
  666. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow4.wit.result +5 -0
  667. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow5.wit +7 -0
  668. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow5.wit.result +5 -0
  669. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow6.wit +7 -0
  670. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow6.wit.result +5 -0
  671. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow7.wit +11 -0
  672. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow7.wit.result +5 -0
  673. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow8/deps/baz.wit +9 -0
  674. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow8/foo.wit +7 -0
  675. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/parse-fail/return-borrow8.wit.result +8 -0
  676. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/world-top-level-resources.wit +24 -0
  677. data/ext/cargo-vendor/wit-parser-0.207.0/tests/ui/world-top-level-resources.wit.json +231 -0
  678. data/ext/src/lib.rs +1 -0
  679. data/ext/src/ruby_api/config.rs +1 -12
  680. data/ext/src/ruby_api/engine.rs +3 -6
  681. data/ext/src/ruby_api/store.rs +68 -5
  682. data/lib/wasmtime/version.rb +1 -1
  683. metadata +1601 -1408
  684. data/ext/cargo-vendor/bincode-1.3.3/.cargo-checksum.json +0 -1
  685. data/ext/cargo-vendor/bincode-1.3.3/Cargo.toml +0 -37
  686. data/ext/cargo-vendor/bincode-1.3.3/LICENSE.md +0 -21
  687. data/ext/cargo-vendor/bincode-1.3.3/readme.md +0 -112
  688. data/ext/cargo-vendor/bincode-1.3.3/src/byteorder.rs +0 -385
  689. data/ext/cargo-vendor/bincode-1.3.3/src/config/endian.rs +0 -27
  690. data/ext/cargo-vendor/bincode-1.3.3/src/config/int.rs +0 -682
  691. data/ext/cargo-vendor/bincode-1.3.3/src/config/legacy.rs +0 -253
  692. data/ext/cargo-vendor/bincode-1.3.3/src/config/limit.rs +0 -49
  693. data/ext/cargo-vendor/bincode-1.3.3/src/config/mod.rs +0 -408
  694. data/ext/cargo-vendor/bincode-1.3.3/src/config/trailing.rs +0 -37
  695. data/ext/cargo-vendor/bincode-1.3.3/src/de/mod.rs +0 -515
  696. data/ext/cargo-vendor/bincode-1.3.3/src/de/read.rs +0 -202
  697. data/ext/cargo-vendor/bincode-1.3.3/src/error.rs +0 -115
  698. data/ext/cargo-vendor/bincode-1.3.3/src/internal.rs +0 -124
  699. data/ext/cargo-vendor/bincode-1.3.3/src/lib.rs +0 -201
  700. data/ext/cargo-vendor/bincode-1.3.3/src/ser/mod.rs +0 -772
  701. data/ext/cargo-vendor/bincode-1.3.3/tests/test.rs +0 -899
  702. data/ext/cargo-vendor/cranelift-bforest-0.107.2/.cargo-checksum.json +0 -1
  703. data/ext/cargo-vendor/cranelift-bforest-0.107.2/Cargo.toml +0 -40
  704. data/ext/cargo-vendor/cranelift-codegen-0.107.2/.cargo-checksum.json +0 -1
  705. data/ext/cargo-vendor/cranelift-codegen-0.107.2/Cargo.toml +0 -178
  706. data/ext/cargo-vendor/cranelift-codegen-0.107.2/build.rs +0 -396
  707. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/alias_analysis.rs +0 -403
  708. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/context.rs +0 -386
  709. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ctxhash.rs +0 -167
  710. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/egraph/elaborate.rs +0 -835
  711. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/egraph.rs +0 -838
  712. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/fx.rs +0 -105
  713. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/incremental_cache.rs +0 -256
  714. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/ir/instructions.rs +0 -1019
  715. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/abi.rs +0 -1707
  716. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/args.rs +0 -779
  717. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/emit.rs +0 -3932
  718. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/emit_tests.rs +0 -7919
  719. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/imms.rs +0 -1218
  720. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/mod.rs +0 -3083
  721. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst/regs.rs +0 -292
  722. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/inst.isle +0 -4218
  723. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/lower/isle.rs +0 -884
  724. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/aarch64/pcc.rs +0 -565
  725. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/mod.rs +0 -432
  726. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/abi.rs +0 -1109
  727. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/args.rs +0 -1968
  728. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/emit.rs +0 -3466
  729. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/emit_tests.rs +0 -2146
  730. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/mod.rs +0 -2041
  731. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/regs.rs +0 -175
  732. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst/vector.rs +0 -1162
  733. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/inst.isle +0 -2944
  734. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/lower/isle.rs +0 -625
  735. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/riscv64/lower.isle +0 -2872
  736. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/abi.rs +0 -1047
  737. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/args.rs +0 -347
  738. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/emit.rs +0 -3646
  739. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/imms.rs +0 -202
  740. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/mod.rs +0 -3423
  741. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/s390x/inst/regs.rs +0 -187
  742. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/abi.rs +0 -1369
  743. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/args.rs +0 -2289
  744. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/emit.rs +0 -4383
  745. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/emit_tests.rs +0 -5131
  746. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/mod.rs +0 -2798
  747. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst/regs.rs +0 -276
  748. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/inst.isle +0 -5304
  749. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower/isle.rs +0 -1066
  750. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower.isle +0 -4809
  751. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/lower.rs +0 -339
  752. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/isa/x64/pcc.rs +0 -1003
  753. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/lib.rs +0 -106
  754. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/abi.rs +0 -2594
  755. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/blockorder.rs +0 -465
  756. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/isle.rs +0 -914
  757. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/lower.rs +0 -1452
  758. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/mod.rs +0 -555
  759. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/reg.rs +0 -562
  760. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/valueregs.rs +0 -132
  761. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/machinst/vcode.rs +0 -1807
  762. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/nan_canonicalization.rs +0 -110
  763. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/opts/arithmetic.isle +0 -179
  764. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/opts/icmp.isle +0 -197
  765. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/remove_constant_phis.rs +0 -420
  766. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/scoped_hash_map.rs +0 -310
  767. data/ext/cargo-vendor/cranelift-codegen-0.107.2/src/settings.rs +0 -591
  768. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/.cargo-checksum.json +0 -1
  769. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/Cargo.toml +0 -35
  770. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/gen_inst.rs +0 -1784
  771. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/gen_settings.rs +0 -508
  772. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/gen_types.rs +0 -75
  773. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/isa/riscv64.rs +0 -160
  774. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/isa/x86.rs +0 -402
  775. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/lib.rs +0 -59
  776. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/shared/settings.rs +0 -355
  777. data/ext/cargo-vendor/cranelift-codegen-meta-0.107.2/src/srcgen.rs +0 -470
  778. data/ext/cargo-vendor/cranelift-codegen-shared-0.107.2/.cargo-checksum.json +0 -1
  779. data/ext/cargo-vendor/cranelift-codegen-shared-0.107.2/Cargo.toml +0 -22
  780. data/ext/cargo-vendor/cranelift-control-0.107.2/.cargo-checksum.json +0 -1
  781. data/ext/cargo-vendor/cranelift-control-0.107.2/Cargo.toml +0 -30
  782. data/ext/cargo-vendor/cranelift-entity-0.107.2/.cargo-checksum.json +0 -1
  783. data/ext/cargo-vendor/cranelift-entity-0.107.2/Cargo.toml +0 -50
  784. data/ext/cargo-vendor/cranelift-entity-0.107.2/src/lib.rs +0 -317
  785. data/ext/cargo-vendor/cranelift-frontend-0.107.2/.cargo-checksum.json +0 -1
  786. data/ext/cargo-vendor/cranelift-frontend-0.107.2/Cargo.toml +0 -69
  787. data/ext/cargo-vendor/cranelift-frontend-0.107.2/src/switch.rs +0 -654
  788. data/ext/cargo-vendor/cranelift-isle-0.107.2/.cargo-checksum.json +0 -1
  789. data/ext/cargo-vendor/cranelift-isle-0.107.2/Cargo.toml +0 -46
  790. data/ext/cargo-vendor/cranelift-isle-0.107.2/src/codegen.rs +0 -886
  791. data/ext/cargo-vendor/cranelift-isle-0.107.2/src/lib.rs +0 -271
  792. data/ext/cargo-vendor/cranelift-isle-0.107.2/src/sema.rs +0 -2492
  793. data/ext/cargo-vendor/cranelift-isle-0.107.2/src/serialize.rs +0 -846
  794. data/ext/cargo-vendor/cranelift-isle-0.107.2/src/trie_again.rs +0 -683
  795. data/ext/cargo-vendor/cranelift-native-0.107.2/.cargo-checksum.json +0 -1
  796. data/ext/cargo-vendor/cranelift-native-0.107.2/Cargo.toml +0 -45
  797. data/ext/cargo-vendor/cranelift-wasm-0.107.2/.cargo-checksum.json +0 -1
  798. data/ext/cargo-vendor/cranelift-wasm-0.107.2/Cargo.toml +0 -107
  799. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/code_translator.rs +0 -3683
  800. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/environ/dummy.rs +0 -912
  801. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/environ/spec.rs +0 -945
  802. data/ext/cargo-vendor/cranelift-wasm-0.107.2/src/sections_translator.rs +0 -409
  803. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.21/.cargo-checksum.json +0 -1
  804. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.21/Cargo.toml +0 -48
  805. data/ext/cargo-vendor/rb-sys-0.9.97/.cargo-checksum.json +0 -1
  806. data/ext/cargo-vendor/rb-sys-0.9.97/Cargo.toml +0 -54
  807. data/ext/cargo-vendor/rb-sys-0.9.97/build/main.rs +0 -238
  808. data/ext/cargo-vendor/rb-sys-0.9.97/build/stable_api_config.rs +0 -133
  809. data/ext/cargo-vendor/rb-sys-0.9.97/src/bindings.rs +0 -20
  810. data/ext/cargo-vendor/rb-sys-0.9.97/src/tracking_allocator.rs +0 -265
  811. data/ext/cargo-vendor/rb-sys-build-0.9.97/.cargo-checksum.json +0 -1
  812. data/ext/cargo-vendor/rb-sys-build-0.9.97/Cargo.toml +0 -62
  813. data/ext/cargo-vendor/rb-sys-build-0.9.97/src/bindings/stable_api.rs +0 -202
  814. data/ext/cargo-vendor/rb-sys-build-0.9.97/src/bindings.rs +0 -250
  815. data/ext/cargo-vendor/rb-sys-build-0.9.97/src/cc.rs +0 -365
  816. data/ext/cargo-vendor/rb-sys-build-0.9.97/src/utils.rs +0 -52
  817. data/ext/cargo-vendor/wasi-common-20.0.2/.cargo-checksum.json +0 -1
  818. data/ext/cargo-vendor/wasi-common-20.0.2/Cargo.toml +0 -220
  819. data/ext/cargo-vendor/wasi-common-20.0.2/tests/all/async_.rs +0 -293
  820. data/ext/cargo-vendor/wasi-common-20.0.2/tests/all/main.rs +0 -21
  821. data/ext/cargo-vendor/wasi-common-20.0.2/tests/all/sync.rs +0 -279
  822. data/ext/cargo-vendor/wasm-encoder-0.202.0/.cargo-checksum.json +0 -1
  823. data/ext/cargo-vendor/wasm-encoder-0.202.0/Cargo.toml +0 -43
  824. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/code.rs +0 -3444
  825. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/data.rs +0 -185
  826. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/elements.rs +0 -220
  827. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/globals.rs +0 -101
  828. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/imports.rs +0 -156
  829. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/memories.rs +0 -111
  830. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/tables.rs +0 -116
  831. data/ext/cargo-vendor/wasm-encoder-0.202.0/src/core/types.rs +0 -673
  832. data/ext/cargo-vendor/wasmparser-0.202.0/.cargo-checksum.json +0 -1
  833. data/ext/cargo-vendor/wasmparser-0.202.0/Cargo.lock +0 -744
  834. data/ext/cargo-vendor/wasmparser-0.202.0/Cargo.toml +0 -66
  835. data/ext/cargo-vendor/wasmparser-0.202.0/src/binary_reader.rs +0 -1849
  836. data/ext/cargo-vendor/wasmparser-0.202.0/src/lib.rs +0 -766
  837. data/ext/cargo-vendor/wasmparser-0.202.0/src/limits.rs +0 -64
  838. data/ext/cargo-vendor/wasmparser-0.202.0/src/parser.rs +0 -1611
  839. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/canonicals.rs +0 -120
  840. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/instances.rs +0 -163
  841. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/names.rs +0 -102
  842. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/start.rs +0 -30
  843. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/component/types.rs +0 -549
  844. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/code.rs +0 -146
  845. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/coredumps.rs +0 -243
  846. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/custom.rs +0 -63
  847. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/data.rs +0 -96
  848. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/dylink0.rs +0 -109
  849. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/elements.rs +0 -152
  850. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/globals.rs +0 -49
  851. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/linking.rs +0 -449
  852. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/memories.rs +0 -56
  853. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/names.rs +0 -156
  854. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/operators.rs +0 -411
  855. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/tables.rs +0 -87
  856. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/types/matches.rs +0 -277
  857. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core/types.rs +0 -1680
  858. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers/core.rs +0 -41
  859. data/ext/cargo-vendor/wasmparser-0.202.0/src/readers.rs +0 -316
  860. data/ext/cargo-vendor/wasmparser-0.202.0/src/resources.rs +0 -235
  861. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/component.rs +0 -3238
  862. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/core/canonical.rs +0 -233
  863. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/core.rs +0 -1400
  864. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/func.rs +0 -338
  865. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/names.rs +0 -929
  866. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/operators.rs +0 -4076
  867. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator/types.rs +0 -4449
  868. data/ext/cargo-vendor/wasmparser-0.202.0/src/validator.rs +0 -1619
  869. data/ext/cargo-vendor/wasmprinter-0.202.0/.cargo-checksum.json +0 -1
  870. data/ext/cargo-vendor/wasmprinter-0.202.0/Cargo.toml +0 -45
  871. data/ext/cargo-vendor/wasmprinter-0.202.0/src/lib.rs +0 -3202
  872. data/ext/cargo-vendor/wasmprinter-0.202.0/src/operator.rs +0 -1131
  873. data/ext/cargo-vendor/wasmprinter-0.202.0/tests/all.rs +0 -279
  874. data/ext/cargo-vendor/wasmtime-20.0.2/.cargo-checksum.json +0 -1
  875. data/ext/cargo-vendor/wasmtime-20.0.2/Cargo.toml +0 -268
  876. data/ext/cargo-vendor/wasmtime-20.0.2/src/compile/code_builder.rs +0 -201
  877. data/ext/cargo-vendor/wasmtime-20.0.2/src/compile/runtime.rs +0 -175
  878. data/ext/cargo-vendor/wasmtime-20.0.2/src/compile.rs +0 -897
  879. data/ext/cargo-vendor/wasmtime-20.0.2/src/config.rs +0 -2695
  880. data/ext/cargo-vendor/wasmtime-20.0.2/src/engine/serialization.rs +0 -849
  881. data/ext/cargo-vendor/wasmtime-20.0.2/src/engine.rs +0 -741
  882. data/ext/cargo-vendor/wasmtime-20.0.2/src/lib.rs +0 -303
  883. data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent/jitdump.rs +0 -66
  884. data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent/perfmap.rs +0 -47
  885. data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent/vtune.rs +0 -80
  886. data/ext/cargo-vendor/wasmtime-20.0.2/src/profiling_agent.rs +0 -105
  887. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/code.rs +0 -102
  888. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/code_memory.rs +0 -335
  889. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/component.rs +0 -661
  890. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func/host.rs +0 -439
  891. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func/options.rs +0 -554
  892. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func/typed.rs +0 -2484
  893. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/func.rs +0 -747
  894. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/instance.rs +0 -804
  895. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/linker.rs +0 -786
  896. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/matching.rs +0 -217
  897. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/mod.rs +0 -756
  898. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/resource_table.rs +0 -350
  899. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/resources.rs +0 -1133
  900. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/storage.rs +0 -43
  901. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/store.rs +0 -28
  902. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/types.rs +0 -892
  903. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/component/values.rs +0 -978
  904. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/coredump.rs +0 -336
  905. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/debug.rs +0 -165
  906. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/externals/global.rs +0 -300
  907. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/externals/table.rs +0 -480
  908. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/externals.rs +0 -236
  909. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/func/typed.rs +0 -898
  910. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/func.rs +0 -2633
  911. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/disabled/anyref.rs +0 -46
  912. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/disabled/externref.rs +0 -50
  913. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/disabled/rooting.rs +0 -222
  914. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/anyref.rs +0 -472
  915. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/externref.rs +0 -644
  916. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/i31.rs +0 -345
  917. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc/enabled/rooting.rs +0 -1543
  918. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/gc.rs +0 -87
  919. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/instance.rs +0 -992
  920. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/instantiate.rs +0 -345
  921. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/limits.rs +0 -398
  922. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/linker.rs +0 -1521
  923. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/memory.rs +0 -999
  924. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/module/registry.rs +0 -354
  925. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/module.rs +0 -1295
  926. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/profiling.rs +0 -224
  927. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/resources.rs +0 -33
  928. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/signatures.rs +0 -216
  929. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/stack.rs +0 -73
  930. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store/context.rs +0 -243
  931. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store/data.rs +0 -289
  932. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store/func_refs.rs +0 -85
  933. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/store.rs +0 -2796
  934. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/func.rs +0 -138
  935. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/global.rs +0 -68
  936. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/memory.rs +0 -286
  937. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline/table.rs +0 -34
  938. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trampoline.rs +0 -77
  939. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/trap.rs +0 -641
  940. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/type_registry.rs +0 -632
  941. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/types/matching.rs +0 -367
  942. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/types.rs +0 -1378
  943. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/unix.rs +0 -39
  944. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/v128.rs +0 -131
  945. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/values.rs +0 -945
  946. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime/windows.rs +0 -34
  947. data/ext/cargo-vendor/wasmtime-20.0.2/src/runtime.rs +0 -112
  948. data/ext/cargo-vendor/wasmtime-asm-macros-20.0.2/.cargo-checksum.json +0 -1
  949. data/ext/cargo-vendor/wasmtime-asm-macros-20.0.2/Cargo.toml +0 -22
  950. data/ext/cargo-vendor/wasmtime-asm-macros-20.0.2/src/lib.rs +0 -81
  951. data/ext/cargo-vendor/wasmtime-cache-20.0.2/.cargo-checksum.json +0 -1
  952. data/ext/cargo-vendor/wasmtime-cache-20.0.2/Cargo.toml +0 -81
  953. data/ext/cargo-vendor/wasmtime-cache-20.0.2/src/lib.rs +0 -235
  954. data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/.cargo-checksum.json +0 -1
  955. data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/Cargo.toml +0 -67
  956. data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/src/bindgen.rs +0 -390
  957. data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/src/component.rs +0 -1295
  958. data/ext/cargo-vendor/wasmtime-component-macro-20.0.2/tests/codegen.rs +0 -342
  959. data/ext/cargo-vendor/wasmtime-component-util-20.0.2/.cargo-checksum.json +0 -1
  960. data/ext/cargo-vendor/wasmtime-component-util-20.0.2/Cargo.toml +0 -25
  961. data/ext/cargo-vendor/wasmtime-component-util-20.0.2/src/lib.rs +0 -180
  962. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/.cargo-checksum.json +0 -1
  963. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/Cargo.toml +0 -114
  964. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/compiler/component.rs +0 -962
  965. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/compiler.rs +0 -1369
  966. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/gc.rs +0 -239
  967. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/attr.rs +0 -345
  968. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/expression.rs +0 -1252
  969. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/line_program.rs +0 -282
  970. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/mod.rs +0 -126
  971. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/unit.rs +0 -522
  972. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/transform/utils.rs +0 -187
  973. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug/write_debuginfo.rs +0 -187
  974. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/debug.rs +0 -18
  975. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/func_environ.rs +0 -2672
  976. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/gc/enabled.rs +0 -649
  977. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/gc.rs +0 -198
  978. data/ext/cargo-vendor/wasmtime-cranelift-20.0.2/src/lib.rs +0 -505
  979. data/ext/cargo-vendor/wasmtime-environ-20.0.2/.cargo-checksum.json +0 -1
  980. data/ext/cargo-vendor/wasmtime-environ-20.0.2/Cargo.lock +0 -782
  981. data/ext/cargo-vendor/wasmtime-environ-20.0.2/Cargo.toml +0 -144
  982. data/ext/cargo-vendor/wasmtime-environ-20.0.2/examples/factc.rs +0 -205
  983. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/address_map.rs +0 -72
  984. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/mod.rs +0 -389
  985. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/module_artifacts.rs +0 -300
  986. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/compile/trap_encoding.rs +0 -69
  987. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/compiler.rs +0 -19
  988. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/dfg.rs +0 -690
  989. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/info.rs +0 -672
  990. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/translate/adapt.rs +0 -459
  991. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/translate.rs +0 -965
  992. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/types/resources.rs +0 -234
  993. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component/types.rs +0 -1972
  994. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/component.rs +0 -103
  995. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/demangling.rs +0 -28
  996. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/core_types.rs +0 -24
  997. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/signature.rs +0 -135
  998. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/trampoline.rs +0 -3233
  999. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/transcode.rs +0 -89
  1000. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact/traps.rs +0 -115
  1001. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/fact.rs +0 -711
  1002. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/lib.rs +0 -70
  1003. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module.rs +0 -780
  1004. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module_artifacts.rs +0 -145
  1005. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module_environ.rs +0 -1288
  1006. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/module_types.rs +0 -122
  1007. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/scopevec.rs +0 -78
  1008. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/stack_map.rs +0 -36
  1009. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/trap_encoding.rs +0 -188
  1010. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/tunables.rs +0 -158
  1011. data/ext/cargo-vendor/wasmtime-environ-20.0.2/src/vmoffsets.rs +0 -952
  1012. data/ext/cargo-vendor/wasmtime-fiber-20.0.2/.cargo-checksum.json +0 -1
  1013. data/ext/cargo-vendor/wasmtime-fiber-20.0.2/Cargo.toml +0 -63
  1014. data/ext/cargo-vendor/wasmtime-fiber-20.0.2/build.rs +0 -26
  1015. data/ext/cargo-vendor/wasmtime-fiber-20.0.2/src/lib.rs +0 -328
  1016. data/ext/cargo-vendor/wasmtime-fiber-20.0.2/src/unix.rs +0 -265
  1017. data/ext/cargo-vendor/wasmtime-fiber-20.0.2/src/windows.rs +0 -166
  1018. data/ext/cargo-vendor/wasmtime-jit-debug-20.0.2/.cargo-checksum.json +0 -1
  1019. data/ext/cargo-vendor/wasmtime-jit-debug-20.0.2/Cargo.toml +0 -67
  1020. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/.cargo-checksum.json +0 -1
  1021. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/Cargo.toml +0 -47
  1022. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/lib.rs +0 -108
  1023. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/libc.rs +0 -149
  1024. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/miri.rs +0 -10
  1025. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-20.0.2/src/win.rs +0 -45
  1026. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/.cargo-checksum.json +0 -1
  1027. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/Cargo.toml +0 -147
  1028. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/build.rs +0 -24
  1029. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/arch/aarch64.rs +0 -76
  1030. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/arch/x86_64.rs +0 -41
  1031. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/async_yield.rs +0 -35
  1032. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/component/libcalls.rs +0 -571
  1033. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/component/resources.rs +0 -351
  1034. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/component.rs +0 -860
  1035. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/cow.rs +0 -888
  1036. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/debug_builtins.rs +0 -59
  1037. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/export.rs +0 -108
  1038. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/disabled.rs +0 -23
  1039. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled/drc.rs +0 -963
  1040. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled/externref.rs +0 -115
  1041. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled/free_list.rs +0 -767
  1042. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/enabled.rs +0 -18
  1043. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/gc_ref.rs +0 -486
  1044. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/gc_runtime.rs +0 -503
  1045. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/host_data.rs +0 -81
  1046. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc/i31.rs +0 -86
  1047. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/gc.rs +0 -244
  1048. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/imports.rs +0 -27
  1049. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/on_demand.rs +0 -217
  1050. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/gc_heap_pool.rs +0 -92
  1051. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/index_allocator.rs +0 -704
  1052. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/memory_pool.rs +0 -996
  1053. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/stack_pool.rs +0 -242
  1054. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling/table_pool.rs +0 -231
  1055. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator/pooling.rs +0 -699
  1056. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance/allocator.rs +0 -780
  1057. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/instance.rs +0 -1566
  1058. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/lib.rs +0 -289
  1059. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/libcalls.rs +0 -777
  1060. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/memory.rs +0 -751
  1061. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mmap.rs +0 -214
  1062. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mmap_vec.rs +0 -201
  1063. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/module_id.rs +0 -43
  1064. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/enabled.rs +0 -213
  1065. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/mod.rs +0 -54
  1066. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/pkru.rs +0 -104
  1067. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/mpk/sys.rs +0 -113
  1068. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/send_sync_ptr.rs +0 -106
  1069. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/store_box.rs +0 -35
  1070. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/capi.rs +0 -189
  1071. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/mmap.rs +0 -111
  1072. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/mod.rs +0 -24
  1073. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/traphandlers.rs +0 -55
  1074. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/custom/vm.rs +0 -108
  1075. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/miri/mmap.rs +0 -94
  1076. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/miri/mod.rs +0 -10
  1077. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/miri/traphandlers.rs +0 -47
  1078. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/mod.rs +0 -33
  1079. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/machports.rs +0 -416
  1080. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/mmap.rs +0 -151
  1081. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/mod.rs +0 -21
  1082. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/signals.rs +0 -401
  1083. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/unwind.rs +0 -149
  1084. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/unix/vm.rs +0 -208
  1085. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/windows/mmap.rs +0 -216
  1086. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/windows/mod.rs +0 -6
  1087. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/sys/windows/traphandlers.rs +0 -104
  1088. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/table.rs +0 -851
  1089. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/threads/parking_spot.rs +0 -621
  1090. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/threads/shared_memory.rs +0 -230
  1091. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/threads/shared_memory_disabled.rs +0 -100
  1092. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers/backtrace.rs +0 -265
  1093. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers/coredump_disabled.rs +0 -16
  1094. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers/coredump_enabled.rs +0 -40
  1095. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/traphandlers.rs +0 -785
  1096. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/vmcontext/vm_host_func_context.rs +0 -137
  1097. data/ext/cargo-vendor/wasmtime-runtime-20.0.2/src/vmcontext.rs +0 -1293
  1098. data/ext/cargo-vendor/wasmtime-slab-20.0.2/.cargo-checksum.json +0 -1
  1099. data/ext/cargo-vendor/wasmtime-slab-20.0.2/Cargo.toml +0 -21
  1100. data/ext/cargo-vendor/wasmtime-slab-20.0.2/src/lib.rs +0 -493
  1101. data/ext/cargo-vendor/wasmtime-types-20.0.2/.cargo-checksum.json +0 -1
  1102. data/ext/cargo-vendor/wasmtime-types-20.0.2/Cargo.toml +0 -36
  1103. data/ext/cargo-vendor/wasmtime-types-20.0.2/src/error.rs +0 -59
  1104. data/ext/cargo-vendor/wasmtime-types-20.0.2/src/lib.rs +0 -832
  1105. data/ext/cargo-vendor/wasmtime-versioned-export-macros-20.0.2/.cargo-checksum.json +0 -1
  1106. data/ext/cargo-vendor/wasmtime-versioned-export-macros-20.0.2/Cargo.toml +0 -32
  1107. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/.cargo-checksum.json +0 -1
  1108. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/Cargo.toml +0 -194
  1109. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/bindings.rs +0 -283
  1110. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/ctx.rs +0 -659
  1111. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/filesystem.rs +0 -433
  1112. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/lib.rs +0 -404
  1113. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/preview0.rs +0 -879
  1114. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/src/preview1.rs +0 -2601
  1115. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/api.rs +0 -194
  1116. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/async_.rs +0 -397
  1117. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/main.rs +0 -91
  1118. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/preview1.rs +0 -251
  1119. data/ext/cargo-vendor/wasmtime-wasi-20.0.2/tests/all/sync.rs +0 -333
  1120. data/ext/cargo-vendor/wasmtime-winch-20.0.2/.cargo-checksum.json +0 -1
  1121. data/ext/cargo-vendor/wasmtime-winch-20.0.2/Cargo.toml +0 -81
  1122. data/ext/cargo-vendor/wasmtime-winch-20.0.2/src/compiler.rs +0 -257
  1123. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/.cargo-checksum.json +0 -1
  1124. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/Cargo.toml +0 -41
  1125. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/src/lib.rs +0 -2213
  1126. data/ext/cargo-vendor/wasmtime-wit-bindgen-20.0.2/src/rust.rs +0 -421
  1127. data/ext/cargo-vendor/wiggle-20.0.2/.cargo-checksum.json +0 -1
  1128. data/ext/cargo-vendor/wiggle-20.0.2/Cargo.toml +0 -122
  1129. data/ext/cargo-vendor/wiggle-generate-20.0.2/.cargo-checksum.json +0 -1
  1130. data/ext/cargo-vendor/wiggle-generate-20.0.2/Cargo.toml +0 -65
  1131. data/ext/cargo-vendor/wiggle-generate-20.0.2/LICENSE +0 -220
  1132. data/ext/cargo-vendor/wiggle-macro-20.0.2/.cargo-checksum.json +0 -1
  1133. data/ext/cargo-vendor/wiggle-macro-20.0.2/Cargo.toml +0 -55
  1134. data/ext/cargo-vendor/wiggle-macro-20.0.2/LICENSE +0 -220
  1135. data/ext/cargo-vendor/winch-codegen-0.18.2/.cargo-checksum.json +0 -1
  1136. data/ext/cargo-vendor/winch-codegen-0.18.2/Cargo.toml +0 -81
  1137. data/ext/cargo-vendor/winch-codegen-0.18.2/src/codegen/context.rs +0 -534
  1138. data/ext/cargo-vendor/winch-codegen-0.18.2/src/codegen/env.rs +0 -435
  1139. data/ext/cargo-vendor/winch-codegen-0.18.2/src/codegen/mod.rs +0 -756
  1140. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/abi.rs +0 -291
  1141. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/address.rs +0 -144
  1142. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/asm.rs +0 -252
  1143. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/masm.rs +0 -573
  1144. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/mod.rs +0 -154
  1145. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/aarch64/regs.rs +0 -149
  1146. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/reg.rs +0 -86
  1147. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/x64/asm.rs +0 -1423
  1148. data/ext/cargo-vendor/winch-codegen-0.18.2/src/isa/x64/masm.rs +0 -1256
  1149. data/ext/cargo-vendor/winch-codegen-0.18.2/src/masm.rs +0 -947
  1150. data/ext/cargo-vendor/winch-codegen-0.18.2/src/regalloc.rs +0 -65
  1151. data/ext/cargo-vendor/winch-codegen-0.18.2/src/regset.rs +0 -194
  1152. data/ext/cargo-vendor/winch-codegen-0.18.2/src/visitor.rs +0 -2149
  1153. data/ext/cargo-vendor/wit-parser-0.202.0/.cargo-checksum.json +0 -1
  1154. data/ext/cargo-vendor/wit-parser-0.202.0/Cargo.toml +0 -101
  1155. data/ext/cargo-vendor/wit-parser-0.202.0/src/ast/resolve.rs +0 -1443
  1156. data/ext/cargo-vendor/wit-parser-0.202.0/src/decoding.rs +0 -1764
  1157. data/ext/cargo-vendor/wit-parser-0.202.0/src/lib.rs +0 -765
  1158. data/ext/cargo-vendor/wit-parser-0.202.0/src/live.rs +0 -111
  1159. data/ext/cargo-vendor/wit-parser-0.202.0/src/resolve.rs +0 -2240
  1160. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/resources-multiple-returns-borrow.wit.json +0 -74
  1161. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/resources-return-borrow.wit.json +0 -69
  1162. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/world-top-level-resources.wit +0 -24
  1163. data/ext/cargo-vendor/wit-parser-0.202.0/tests/ui/world-top-level-resources.wit.json +0 -240
  1164. data/ext/src/ruby_api/config/tracked_memory_creator.rs +0 -82
  1165. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/LICENSE +0 -0
  1166. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/README.md +0 -0
  1167. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/lib.rs +0 -0
  1168. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/map.rs +0 -0
  1169. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/node.rs +0 -0
  1170. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/path.rs +0 -0
  1171. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/pool.rs +0 -0
  1172. /data/ext/cargo-vendor/{cranelift-bforest-0.107.2 → cranelift-bforest-0.108.1}/src/set.rs +0 -0
  1173. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/LICENSE +0 -0
  1174. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/README.md +0 -0
  1175. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/benches/x64-evex-encoding.rs +0 -0
  1176. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/binemit/mod.rs +0 -0
  1177. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/binemit/stack_map.rs +0 -0
  1178. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/bitset.rs +0 -0
  1179. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/cfg_printer.rs +0 -0
  1180. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/constant_hash.rs +0 -0
  1181. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/cursor.rs +0 -0
  1182. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/data_value.rs +0 -0
  1183. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/dbg.rs +0 -0
  1184. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/dce.rs +0 -0
  1185. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/dominator_tree.rs +0 -0
  1186. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/egraph/cost.rs +0 -0
  1187. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/flowgraph.rs +0 -0
  1188. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/inst_predicates.rs +0 -0
  1189. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/atomic_rmw_op.rs +0 -0
  1190. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/builder.rs +0 -0
  1191. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/condcodes.rs +0 -0
  1192. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/constant.rs +0 -0
  1193. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/dfg.rs +0 -0
  1194. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/dynamic_type.rs +0 -0
  1195. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/entities.rs +0 -0
  1196. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/extfunc.rs +0 -0
  1197. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/extname.rs +0 -0
  1198. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/function.rs +0 -0
  1199. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/globalvalue.rs +0 -0
  1200. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/immediates.rs +0 -0
  1201. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/jumptable.rs +0 -0
  1202. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/known_symbol.rs +0 -0
  1203. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/layout.rs +0 -0
  1204. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/libcall.rs +0 -0
  1205. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/memflags.rs +0 -0
  1206. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/memtype.rs +0 -0
  1207. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/mod.rs +0 -0
  1208. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/pcc.rs +0 -0
  1209. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/progpoint.rs +0 -0
  1210. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/sourceloc.rs +0 -0
  1211. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/stackslot.rs +0 -0
  1212. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/trapcode.rs +0 -0
  1213. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/ir/types.rs +0 -0
  1214. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/inst/unwind/systemv.rs +0 -0
  1215. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/inst/unwind.rs +0 -0
  1216. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/inst_neon.isle +0 -0
  1217. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
  1218. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower.isle +0 -0
  1219. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower.rs +0 -0
  1220. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
  1221. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/mod.rs +0 -0
  1222. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/aarch64/settings.rs +0 -0
  1223. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/call_conv.rs +0 -0
  1224. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/encode.rs +0 -0
  1225. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/imms.rs +0 -0
  1226. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/unwind/systemv.rs +0 -0
  1227. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst/unwind.rs +0 -0
  1228. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/inst_vector.isle +0 -0
  1229. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
  1230. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/lower.rs +0 -0
  1231. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/mod.rs +0 -0
  1232. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/riscv64/settings.rs +0 -0
  1233. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst/emit_tests.rs +0 -0
  1234. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst/unwind/systemv.rs +0 -0
  1235. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst/unwind.rs +0 -0
  1236. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/inst.isle +0 -0
  1237. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
  1238. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower/isle.rs +0 -0
  1239. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower.isle +0 -0
  1240. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/lower.rs +0 -0
  1241. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/mod.rs +0 -0
  1242. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/s390x/settings.rs +0 -0
  1243. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/unwind/systemv.rs +0 -0
  1244. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/unwind/winx64.rs +0 -0
  1245. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/unwind.rs +0 -0
  1246. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/evex.rs +0 -0
  1247. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/mod.rs +0 -0
  1248. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/rex.rs +0 -0
  1249. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/encoding/vex.rs +0 -0
  1250. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/emit_state.rs +0 -0
  1251. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/unwind/systemv.rs +0 -0
  1252. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/unwind/winx64.rs +0 -0
  1253. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/inst/unwind.rs +0 -0
  1254. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/lower/isle/generated_code.rs +0 -0
  1255. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/mod.rs +0 -0
  1256. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isa/x64/settings.rs +0 -0
  1257. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/isle_prelude.rs +0 -0
  1258. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/iterators.rs +0 -0
  1259. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/legalizer/globalvalue.rs +0 -0
  1260. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/legalizer/mod.rs +0 -0
  1261. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/loop_analysis.rs +0 -0
  1262. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/buffer.rs +0 -0
  1263. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/compile.rs +0 -0
  1264. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/helpers.rs +0 -0
  1265. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/inst_common.rs +0 -0
  1266. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/machinst/pcc.rs +0 -0
  1267. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/README.md +0 -0
  1268. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/bitops.isle +0 -0
  1269. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/cprop.isle +0 -0
  1270. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/extends.isle +0 -0
  1271. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/generated_code.rs +0 -0
  1272. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/remat.isle +0 -0
  1273. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/selects.isle +0 -0
  1274. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/shifts.isle +0 -0
  1275. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/spaceship.isle +0 -0
  1276. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/spectre.isle +0 -0
  1277. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts/vector.isle +0 -0
  1278. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/opts.rs +0 -0
  1279. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/prelude.isle +0 -0
  1280. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/prelude_lower.isle +0 -0
  1281. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/prelude_opt.isle +0 -0
  1282. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/print_errors.rs +0 -0
  1283. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/result.rs +0 -0
  1284. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/souper_harvest.rs +0 -0
  1285. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/timing.rs +0 -0
  1286. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/unionfind.rs +0 -0
  1287. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/unreachable_code.rs +0 -0
  1288. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/value_label.rs +0 -0
  1289. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/verifier/mod.rs +0 -0
  1290. /data/ext/cargo-vendor/{cranelift-codegen-0.107.2 → cranelift-codegen-0.108.1}/src/write.rs +0 -0
  1291. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/LICENSE +0 -0
  1292. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/README.md +0 -0
  1293. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/formats.rs +0 -0
  1294. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/instructions.rs +0 -0
  1295. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/isa.rs +0 -0
  1296. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/mod.rs +0 -0
  1297. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/operands.rs +0 -0
  1298. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/settings.rs +0 -0
  1299. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/types.rs +0 -0
  1300. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/cdsl/typevar.rs +0 -0
  1301. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/constant_hash.rs +0 -0
  1302. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/error.rs +0 -0
  1303. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/isa/arm64.rs +0 -0
  1304. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/isa/mod.rs +0 -0
  1305. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/isa/s390x.rs +0 -0
  1306. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/entities.rs +0 -0
  1307. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/formats.rs +0 -0
  1308. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/immediates.rs +0 -0
  1309. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/instructions.rs +0 -0
  1310. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/mod.rs +0 -0
  1311. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/shared/types.rs +0 -0
  1312. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.107.2 → cranelift-codegen-meta-0.108.1}/src/unique_table.rs +0 -0
  1313. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/LICENSE +0 -0
  1314. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/README.md +0 -0
  1315. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/src/constant_hash.rs +0 -0
  1316. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/src/constants.rs +0 -0
  1317. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.107.2 → cranelift-codegen-shared-0.108.1}/src/lib.rs +0 -0
  1318. /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/LICENSE +0 -0
  1319. /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/README.md +0 -0
  1320. /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/src/chaos.rs +0 -0
  1321. /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/src/lib.rs +0 -0
  1322. /data/ext/cargo-vendor/{cranelift-control-0.107.2 → cranelift-control-0.108.1}/src/zero_sized.rs +0 -0
  1323. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/LICENSE +0 -0
  1324. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/README.md +0 -0
  1325. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/boxed_slice.rs +0 -0
  1326. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/iter.rs +0 -0
  1327. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/keys.rs +0 -0
  1328. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/list.rs +0 -0
  1329. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/map.rs +0 -0
  1330. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/packed_option.rs +0 -0
  1331. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/primary.rs +0 -0
  1332. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/set.rs +0 -0
  1333. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/sparse.rs +0 -0
  1334. /data/ext/cargo-vendor/{cranelift-entity-0.107.2 → cranelift-entity-0.108.1}/src/unsigned.rs +0 -0
  1335. /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/LICENSE +0 -0
  1336. /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/README.md +0 -0
  1337. /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/frontend.rs +0 -0
  1338. /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/lib.rs +0 -0
  1339. /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/ssa.rs +0 -0
  1340. /data/ext/cargo-vendor/{cranelift-frontend-0.107.2 → cranelift-frontend-0.108.1}/src/variable.rs +0 -0
  1341. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/README.md +0 -0
  1342. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/build.rs +0 -0
  1343. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/bad_converters.isle +0 -0
  1344. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
  1345. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
  1346. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/error1.isle +0 -0
  1347. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/extra_parens.isle +0 -0
  1348. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/impure_expression.isle +0 -0
  1349. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/impure_rhs.isle +0 -0
  1350. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/multi_internal_etor.isle +0 -0
  1351. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/fail/multi_prio.isle +0 -0
  1352. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/borrows.isle +0 -0
  1353. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/borrows_main.rs +0 -0
  1354. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/iflets.isle +0 -0
  1355. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/iflets_main.rs +0 -0
  1356. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_constructor.isle +0 -0
  1357. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_constructor_main.rs +0 -0
  1358. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_extractor.isle +0 -0
  1359. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/multi_extractor_main.rs +0 -0
  1360. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/test.isle +0 -0
  1361. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/link/test_main.rs +0 -0
  1362. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/bound_var.isle +0 -0
  1363. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/construct_and_extract.isle +0 -0
  1364. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/conversions.isle +0 -0
  1365. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/conversions_extern.isle +0 -0
  1366. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/let.isle +0 -0
  1367. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/nodebug.isle +0 -0
  1368. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/prio_trie_bug.isle +0 -0
  1369. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/test2.isle +0 -0
  1370. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/test3.isle +0 -0
  1371. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/test4.isle +0 -0
  1372. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/pass/tutorial.isle +0 -0
  1373. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/iconst.isle +0 -0
  1374. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/iconst_main.rs +0 -0
  1375. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/let_shadowing.isle +0 -0
  1376. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/isle_examples/run/let_shadowing_main.rs +0 -0
  1377. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/ast.rs +0 -0
  1378. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/compile.rs +0 -0
  1379. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/error.rs +0 -0
  1380. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/lexer.rs +0 -0
  1381. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/log.rs +0 -0
  1382. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/overlap.rs +0 -0
  1383. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/src/parser.rs +0 -0
  1384. /data/ext/cargo-vendor/{cranelift-isle-0.107.2 → cranelift-isle-0.108.1}/tests/run_tests.rs +0 -0
  1385. /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/LICENSE +0 -0
  1386. /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/README.md +0 -0
  1387. /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/src/lib.rs +0 -0
  1388. /data/ext/cargo-vendor/{cranelift-native-0.107.2 → cranelift-native-0.108.1}/src/riscv.rs +0 -0
  1389. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/LICENSE +0 -0
  1390. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/README.md +0 -0
  1391. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/code_translator/bounds_checks.rs +0 -0
  1392. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/environ/mod.rs +0 -0
  1393. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/func_translator.rs +0 -0
  1394. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/heap.rs +0 -0
  1395. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/lib.rs +0 -0
  1396. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/module_translator.rs +0 -0
  1397. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/state.rs +0 -0
  1398. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/table.rs +0 -0
  1399. /data/ext/cargo-vendor/{cranelift-wasm-0.107.2 → cranelift-wasm-0.108.1}/src/translation_utils.rs +0 -0
  1400. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/README.md +0 -0
  1401. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/src/clocks.rs +0 -0
  1402. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/src/lib.rs +0 -0
  1403. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/src/noop_scheduler.rs +0 -0
  1404. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/clocks.rs +0 -0
  1405. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/common/mod.rs +0 -0
  1406. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/random.rs +0 -0
  1407. /data/ext/cargo-vendor/{deterministic-wasi-ctx-0.1.21 → deterministic-wasi-ctx-0.1.22}/tests/scheduler.rs +0 -0
  1408. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/LICENSE-APACHE +0 -0
  1409. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/LICENSE-MIT +0 -0
  1410. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/bin/release.sh +0 -0
  1411. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/build/features.rs +0 -0
  1412. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/build/version.rs +0 -0
  1413. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/readme.md +0 -0
  1414. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/hidden.rs +0 -0
  1415. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/lib.rs +0 -0
  1416. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/macros.rs +0 -0
  1417. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/memory.rs +0 -0
  1418. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/ruby_abi_version.rs +0 -0
  1419. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/special_consts.rs +0 -0
  1420. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/compiled.c +0 -0
  1421. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/compiled.rs +0 -0
  1422. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_2_6.rs +0 -0
  1423. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_2_7.rs +0 -0
  1424. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_0.rs +0 -0
  1425. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_1.rs +0 -0
  1426. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_2.rs +0 -0
  1427. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api/ruby_3_3.rs +0 -0
  1428. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/stable_api.rs +0 -0
  1429. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/symbol.rs +0 -0
  1430. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/utils.rs +0 -0
  1431. /data/ext/cargo-vendor/{rb-sys-0.9.97 → rb-sys-0.9.100}/src/value_type.rs +0 -0
  1432. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/LICENSE-APACHE +0 -0
  1433. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/LICENSE-MIT +0 -0
  1434. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/bindings/sanitizer.rs +0 -0
  1435. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/bindings/wrapper.h +0 -0
  1436. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/lib.rs +0 -0
  1437. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config/flags.rs +0 -0
  1438. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config/library.rs +0 -0
  1439. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config/search_path.rs +0 -0
  1440. /data/ext/cargo-vendor/{rb-sys-build-0.9.97 → rb-sys-build-0.9.100}/src/rb_config.rs +0 -0
  1441. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/LICENSE +0 -0
  1442. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/README.md +0 -0
  1443. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/clocks.rs +0 -0
  1444. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/ctx.rs +0 -0
  1445. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/dir.rs +0 -0
  1446. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/error.rs +0 -0
  1447. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/file.rs +0 -0
  1448. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/lib.rs +0 -0
  1449. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/pipe.rs +0 -0
  1450. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/random.rs +0 -0
  1451. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sched/subscription.rs +0 -0
  1452. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sched.rs +0 -0
  1453. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/mod.rs +0 -0
  1454. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/preview_0.rs +0 -0
  1455. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/preview_1/error.rs +0 -0
  1456. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/snapshots/preview_1.rs +0 -0
  1457. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/string_array.rs +0 -0
  1458. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/clocks.rs +0 -0
  1459. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/dir.rs +0 -0
  1460. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/file.rs +0 -0
  1461. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/mod.rs +0 -0
  1462. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/net.rs +0 -0
  1463. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/sched/unix.rs +0 -0
  1464. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/sched/windows.rs +0 -0
  1465. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/sched.rs +0 -0
  1466. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/sync/stdio.rs +0 -0
  1467. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/table.rs +0 -0
  1468. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/dir.rs +0 -0
  1469. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/file.rs +0 -0
  1470. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/mod.rs +0 -0
  1471. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/net.rs +0 -0
  1472. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/sched/unix.rs +0 -0
  1473. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/sched/windows.rs +0 -0
  1474. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/sched.rs +0 -0
  1475. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/src/tokio/stdio.rs +0 -0
  1476. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview0/typenames.witx +0 -0
  1477. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview0/wasi_unstable.witx +0 -0
  1478. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview1/typenames.witx +0 -0
  1479. /data/ext/cargo-vendor/{wasi-common-20.0.2 → wasi-common-21.0.1}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1480. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/LICENSE +0 -0
  1481. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/README.md +0 -0
  1482. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/aliases.rs +0 -0
  1483. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/builder.rs +0 -0
  1484. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/canonicals.rs +0 -0
  1485. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/components.rs +0 -0
  1486. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/exports.rs +0 -0
  1487. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/imports.rs +0 -0
  1488. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/instances.rs +0 -0
  1489. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/modules.rs +0 -0
  1490. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/names.rs +0 -0
  1491. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/start.rs +0 -0
  1492. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component/types.rs +0 -0
  1493. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/component.rs +0 -0
  1494. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/custom.rs +0 -0
  1495. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/dump.rs +0 -0
  1496. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/exports.rs +0 -0
  1497. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/functions.rs +0 -0
  1498. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/linking.rs +0 -0
  1499. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/names.rs +0 -0
  1500. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/producers.rs +0 -0
  1501. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/start.rs +0 -0
  1502. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core/tags.rs +0 -0
  1503. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/core.rs +0 -0
  1504. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/lib.rs +0 -0
  1505. /data/ext/cargo-vendor/{wasm-encoder-0.202.0 → wasm-encoder-0.207.0}/src/raw.rs +0 -0
  1506. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/README.md +0 -0
  1507. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/benches/benchmark.rs +0 -0
  1508. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/examples/simple.rs +0 -0
  1509. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component/aliases.rs +0 -0
  1510. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component/exports.rs +0 -0
  1511. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component/imports.rs +0 -0
  1512. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/component.rs +0 -0
  1513. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/branch_hinting.rs +0 -0
  1514. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/exports.rs +0 -0
  1515. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/functions.rs +0 -0
  1516. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/imports.rs +0 -0
  1517. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/init.rs +0 -0
  1518. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/producers.rs +0 -0
  1519. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/src/readers/core/tags.rs +0 -0
  1520. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmparser-0.207.0}/tests/big-module.rs +0 -0
  1521. /data/ext/cargo-vendor/{wasmparser-0.202.0 → wasmprinter-0.207.0}/LICENSE +0 -0
  1522. /data/ext/cargo-vendor/{wasmprinter-0.202.0 → wasmprinter-0.207.0}/README.md +0 -0
  1523. /data/ext/cargo-vendor/{wasmprinter-0.202.0 → wasmtime-21.0.1}/LICENSE +0 -0
  1524. /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/README.md +0 -0
  1525. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/proptest-regressions → wasmtime-21.0.1/proptest-regressions/runtime/vm}/instance/allocator/pooling/memory_pool.txt +0 -0
  1526. /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/gc/disabled/i31.rs +0 -0
  1527. /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/gc/disabled.rs +0 -0
  1528. /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/gc/enabled.rs +0 -0
  1529. /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-21.0.1}/src/runtime/uninhabited.rs +0 -0
  1530. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/mod.rs +0 -0
  1531. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/riscv64.rs +0 -0
  1532. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/s390x.S +0 -0
  1533. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/arch/s390x.rs +0 -0
  1534. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/helpers.c +0 -0
  1535. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/mpk/disabled.rs +0 -0
  1536. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/custom/unwind.rs +0 -0
  1537. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/miri/unwind.rs +0 -0
  1538. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/miri/vm.rs +0 -0
  1539. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/unix/macos_traphandlers.rs +0 -0
  1540. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/windows/unwind.rs +0 -0
  1541. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/sys/windows/vm.rs +0 -0
  1542. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2/src → wasmtime-21.0.1/src/runtime/vm}/threads/mod.rs +0 -0
  1543. /data/ext/cargo-vendor/{wasmtime-20.0.2 → wasmtime-cache-21.0.1}/LICENSE +0 -0
  1544. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/build.rs +0 -0
  1545. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/config/tests.rs +0 -0
  1546. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/config.rs +0 -0
  1547. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/tests.rs +0 -0
  1548. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/worker/tests/system_time_stub.rs +0 -0
  1549. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/worker/tests.rs +0 -0
  1550. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/src/worker.rs +0 -0
  1551. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cache-21.0.1}/tests/cache_write_default_config.rs +0 -0
  1552. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/build.rs +0 -0
  1553. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/src/lib.rs +0 -0
  1554. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/char.wit +0 -0
  1555. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/conventions.wit +0 -0
  1556. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/dead-code.wit +0 -0
  1557. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/direct-import.wit +0 -0
  1558. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/empty.wit +0 -0
  1559. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/flags.wit +0 -0
  1560. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/floats.wit +0 -0
  1561. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/function-new.wit +0 -0
  1562. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/integers.wit +0 -0
  1563. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/lists.wit +0 -0
  1564. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/many-arguments.wit +0 -0
  1565. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multi-return.wit +0 -0
  1566. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multiversion/deps/v1/root.wit +0 -0
  1567. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multiversion/deps/v2/root.wit +0 -0
  1568. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/multiversion/root.wit +0 -0
  1569. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/records.wit +0 -0
  1570. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/rename.wit +0 -0
  1571. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/resources-export.wit +0 -0
  1572. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/resources-import.wit +0 -0
  1573. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/share-types.wit +0 -0
  1574. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/simple-functions.wit +0 -0
  1575. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/simple-lists.wit +0 -0
  1576. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/simple-wasi.wit +0 -0
  1577. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/small-anonymous.wit +0 -0
  1578. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/smoke-default.wit +0 -0
  1579. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/smoke-export.wit +0 -0
  1580. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/smoke.wit +0 -0
  1581. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/strings.wit +0 -0
  1582. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/unversioned-foo.wit +0 -0
  1583. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/use-paths.wit +0 -0
  1584. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/variants.wit +0 -0
  1585. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/wat.wit +0 -0
  1586. /data/ext/cargo-vendor/{wasmtime-component-macro-20.0.2 → wasmtime-component-macro-21.0.1}/tests/codegen/worlds-with-types.wit +0 -0
  1587. /data/ext/cargo-vendor/{wasmtime-cache-20.0.2 → wasmtime-cranelift-21.0.1}/LICENSE +0 -0
  1588. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/SECURITY.md +0 -0
  1589. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/builder.rs +0 -0
  1590. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/compiled_function.rs +0 -0
  1591. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/address_transform.rs +0 -0
  1592. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/range_info_builder.rs +0 -0
  1593. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/refs.rs +0 -0
  1594. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/debug/transform/simulate.rs +0 -0
  1595. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/gc/disabled.rs +0 -0
  1596. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/isa_builder.rs +0 -0
  1597. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-cranelift-21.0.1}/src/obj.rs +0 -0
  1598. /data/ext/cargo-vendor/{wasmtime-cranelift-20.0.2 → wasmtime-environ-21.0.1}/LICENSE +0 -0
  1599. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/address_map.rs +0 -0
  1600. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/builtin.rs +0 -0
  1601. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/component/artifacts.rs +0 -0
  1602. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/component/translate/inline.rs +0 -0
  1603. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/component/vmcomponent_offsets.rs +0 -0
  1604. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/gc.rs +0 -0
  1605. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/obj.rs +0 -0
  1606. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-environ-21.0.1}/src/ref_bits.rs +0 -0
  1607. /data/ext/cargo-vendor/{wasmtime-environ-20.0.2 → wasmtime-fiber-21.0.1}/LICENSE +0 -0
  1608. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/aarch64.rs +0 -0
  1609. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/arm.rs +0 -0
  1610. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/riscv64.rs +0 -0
  1611. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/s390x.S +0 -0
  1612. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/x86.rs +0 -0
  1613. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/unix/x86_64.rs +0 -0
  1614. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-fiber-21.0.1}/src/windows.c +0 -0
  1615. /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/README.md +0 -0
  1616. /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/src/gdb_jit_int.rs +0 -0
  1617. /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/src/lib.rs +0 -0
  1618. /data/ext/cargo-vendor/{wasmtime-jit-debug-20.0.2 → wasmtime-jit-debug-21.0.1}/src/perf_jitdump.rs +0 -0
  1619. /data/ext/cargo-vendor/{wasmtime-fiber-20.0.2 → wasmtime-types-21.0.1}/LICENSE +0 -0
  1620. /data/ext/cargo-vendor/{wasmtime-versioned-export-macros-20.0.2 → wasmtime-versioned-export-macros-21.0.1}/src/lib.rs +0 -0
  1621. /data/ext/cargo-vendor/{wasmtime-runtime-20.0.2 → wasmtime-wasi-21.0.1}/LICENSE +0 -0
  1622. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/README.md +0 -0
  1623. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/clocks/host.rs +0 -0
  1624. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/clocks.rs +0 -0
  1625. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/error.rs +0 -0
  1626. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/clocks.rs +0 -0
  1627. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/env.rs +0 -0
  1628. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/exit.rs +0 -0
  1629. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/filesystem/sync.rs +0 -0
  1630. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/filesystem.rs +0 -0
  1631. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/instance_network.rs +0 -0
  1632. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/io.rs +0 -0
  1633. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/mod.rs +0 -0
  1634. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/network.rs +0 -0
  1635. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/random.rs +0 -0
  1636. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/tcp.rs +0 -0
  1637. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/tcp_create_socket.rs +0 -0
  1638. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/udp.rs +0 -0
  1639. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/host/udp_create_socket.rs +0 -0
  1640. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/ip_name_lookup.rs +0 -0
  1641. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/network.rs +0 -0
  1642. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/pipe.rs +0 -0
  1643. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/poll.rs +0 -0
  1644. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/random.rs +0 -0
  1645. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/runtime.rs +0 -0
  1646. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/stdio/worker_thread_stdin.rs +0 -0
  1647. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/stdio.rs +0 -0
  1648. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/stream.rs +0 -0
  1649. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/tcp.rs +0 -0
  1650. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/udp.rs +0 -0
  1651. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/src/write_stream.rs +0 -0
  1652. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/tests/process_stdin.rs +0 -0
  1653. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/command-extended.wit +0 -0
  1654. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/command.wit +0 -0
  1655. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/environment.wit +0 -0
  1656. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/exit.wit +0 -0
  1657. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/imports.wit +0 -0
  1658. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/run.wit +0 -0
  1659. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/stdio.wit +0 -0
  1660. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/cli/terminal.wit +0 -0
  1661. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/clocks/monotonic-clock.wit +0 -0
  1662. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/clocks/wall-clock.wit +0 -0
  1663. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/clocks/world.wit +0 -0
  1664. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/filesystem/preopens.wit +0 -0
  1665. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/filesystem/types.wit +0 -0
  1666. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/filesystem/world.wit +0 -0
  1667. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/http/handler.wit +0 -0
  1668. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/http/proxy.wit +0 -0
  1669. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/http/types.wit +0 -0
  1670. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/error.wit +0 -0
  1671. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/poll.wit +0 -0
  1672. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/streams.wit +0 -0
  1673. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/io/world.wit +0 -0
  1674. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/insecure-seed.wit +0 -0
  1675. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/insecure.wit +0 -0
  1676. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/random.wit +0 -0
  1677. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/random/world.wit +0 -0
  1678. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/instance-network.wit +0 -0
  1679. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/ip-name-lookup.wit +0 -0
  1680. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/network.wit +0 -0
  1681. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/tcp-create-socket.wit +0 -0
  1682. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/tcp.wit +0 -0
  1683. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/udp-create-socket.wit +0 -0
  1684. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/udp.wit +0 -0
  1685. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/deps/sockets/world.wit +0 -0
  1686. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/wit/test.wit +0 -0
  1687. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview0/typenames.witx +0 -0
  1688. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview0/wasi_unstable.witx +0 -0
  1689. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview1/typenames.witx +0 -0
  1690. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wasmtime-wasi-21.0.1}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1691. /data/ext/cargo-vendor/{wasmtime-winch-20.0.2 → wasmtime-winch-21.0.1}/LICENSE +0 -0
  1692. /data/ext/cargo-vendor/{wasmtime-winch-20.0.2 → wasmtime-winch-21.0.1}/src/builder.rs +0 -0
  1693. /data/ext/cargo-vendor/{wasmtime-winch-20.0.2 → wasmtime-winch-21.0.1}/src/lib.rs +0 -0
  1694. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-20.0.2 → wasmtime-wit-bindgen-21.0.1}/src/source.rs +0 -0
  1695. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-20.0.2 → wasmtime-wit-bindgen-21.0.1}/src/types.rs +0 -0
  1696. /data/ext/cargo-vendor/{wasmtime-types-20.0.2 → wiggle-21.0.1}/LICENSE +0 -0
  1697. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/README.md +0 -0
  1698. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/borrow.rs +0 -0
  1699. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/error.rs +0 -0
  1700. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/guest_type.rs +0 -0
  1701. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/lib.rs +0 -0
  1702. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/region.rs +0 -0
  1703. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-21.0.1}/src/wasmtime.rs +0 -0
  1704. /data/ext/cargo-vendor/{wasmtime-wasi-20.0.2 → wiggle-generate-21.0.1}/LICENSE +0 -0
  1705. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/README.md +0 -0
  1706. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/codegen_settings.rs +0 -0
  1707. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/config.rs +0 -0
  1708. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/funcs.rs +0 -0
  1709. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/lib.rs +0 -0
  1710. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/lifetimes.rs +0 -0
  1711. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/module_trait.rs +0 -0
  1712. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/names.rs +0 -0
  1713. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/error.rs +0 -0
  1714. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/flags.rs +0 -0
  1715. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/handle.rs +0 -0
  1716. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/mod.rs +0 -0
  1717. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/record.rs +0 -0
  1718. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/types/variant.rs +0 -0
  1719. /data/ext/cargo-vendor/{wiggle-generate-20.0.2 → wiggle-generate-21.0.1}/src/wasmtime.rs +0 -0
  1720. /data/ext/cargo-vendor/{wiggle-20.0.2 → wiggle-macro-21.0.1}/LICENSE +0 -0
  1721. /data/ext/cargo-vendor/{wiggle-macro-20.0.2 → wiggle-macro-21.0.1}/src/lib.rs +0 -0
  1722. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/LICENSE +0 -0
  1723. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/build.rs +0 -0
  1724. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/abi/local.rs +0 -0
  1725. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/abi/mod.rs +0 -0
  1726. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/bounds.rs +0 -0
  1727. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/builtin.rs +0 -0
  1728. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/call.rs +0 -0
  1729. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/codegen/control.rs +0 -0
  1730. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/frame/mod.rs +0 -0
  1731. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/mod.rs +0 -0
  1732. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/abi.rs +0 -0
  1733. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/address.rs +0 -0
  1734. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/mod.rs +0 -0
  1735. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/isa/x64/regs.rs +0 -0
  1736. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/lib.rs +0 -0
  1737. /data/ext/cargo-vendor/{winch-codegen-0.18.2 → winch-codegen-0.19.1}/src/stack.rs +0 -0
  1738. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/README.md +0 -0
  1739. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/abi.rs +0 -0
  1740. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/ast/lex.rs +0 -0
  1741. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/ast/toposort.rs +0 -0
  1742. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/ast.rs +0 -0
  1743. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/docs.rs +0 -0
  1744. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/serde_.rs +0 -0
  1745. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/src/sizealign.rs +0 -0
  1746. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/all.rs +0 -0
  1747. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/comments.wit +0 -0
  1748. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/comments.wit.json +0 -0
  1749. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include/deps/bar/root.wit +0 -0
  1750. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include/deps/baz/root.wit +0 -0
  1751. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include/root.wit +0 -0
  1752. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/complex-include.wit.json +0 -0
  1753. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/cross-package-resource/deps/foo/foo.wit +0 -0
  1754. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/cross-package-resource/foo.wit +0 -0
  1755. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/cross-package-resource.wit.json +0 -0
  1756. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1/deps/dep1/types.wit +0 -0
  1757. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1/deps/dep2/types.wit +0 -0
  1758. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1/join.wit +0 -0
  1759. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/diamond1.wit.json +0 -0
  1760. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond/shared1.wit +0 -0
  1761. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond/shared2.wit +0 -0
  1762. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond/world.wit +0 -0
  1763. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/disambiguate-diamond.wit.json +0 -0
  1764. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/empty.wit +0 -0
  1765. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/empty.wit.json +0 -0
  1766. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/another-pkg/other-doc.wit +0 -0
  1767. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/corp/saas.wit +0 -0
  1768. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/different-pkg/the-doc.wit +0 -0
  1769. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/foreign-pkg/the-doc.wit +0 -0
  1770. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/some-pkg/some-doc.wit +0 -0
  1771. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/wasi/clocks.wit +0 -0
  1772. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/deps/wasi/filesystem.wit +0 -0
  1773. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps/root.wit +0 -0
  1774. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/another-pkg/other-doc.wit +0 -0
  1775. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/corp/saas.wit +0 -0
  1776. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/different-pkg/the-doc.wit +0 -0
  1777. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/foreign-pkg/the-doc.wit +0 -0
  1778. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/some-pkg/some-doc.wit +0 -0
  1779. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/wasi/clocks.wit +0 -0
  1780. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/wasi/filesystem.wit +0 -0
  1781. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/deps/wasi/wasi.wit +0 -0
  1782. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union/root.wit +0 -0
  1783. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps-union.wit.json +0 -0
  1784. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/foreign-deps.wit.json +0 -0
  1785. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/functions.wit +0 -0
  1786. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/functions.wit.json +0 -0
  1787. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps/deps/bar/types.wit +0 -0
  1788. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps/deps/ignore-me.txt +0 -0
  1789. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps/world.wit +0 -0
  1790. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/ignore-files-deps.wit.json +0 -0
  1791. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap1.wit +0 -0
  1792. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap1.wit.json +0 -0
  1793. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap2.wit +0 -0
  1794. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/import-export-overlap2.wit.json +0 -0
  1795. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/include-reps.wit +0 -0
  1796. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/include-reps.wit.json +0 -0
  1797. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kebab-name-include-with.wit +0 -0
  1798. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kebab-name-include-with.wit.json +0 -0
  1799. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/a.wit +0 -0
  1800. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/b/root.wit +0 -0
  1801. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/c.wit +0 -0
  1802. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/d.wat +0 -0
  1803. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps/deps/e.wasm +0 -0
  1804. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/kinds-of-deps.wit.json +0 -0
  1805. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/many-names/a.wit +0 -0
  1806. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/many-names/b.wit +0 -0
  1807. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/many-names.wit.json +0 -0
  1808. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/bar.wit +0 -0
  1809. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/cycle-a.wit +0 -0
  1810. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/cycle-b.wit +0 -0
  1811. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file/foo.wit +0 -0
  1812. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/multi-file.wit.json +0 -0
  1813. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/name-both-resource-and-type/deps/dep/foo.wit +0 -0
  1814. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/name-both-resource-and-type/foo.wit +0 -0
  1815. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/name-both-resource-and-type.wit.json +0 -0
  1816. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax1.wit +0 -0
  1817. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax1.wit.json +0 -0
  1818. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax3.wit +0 -0
  1819. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax3.wit.json +0 -0
  1820. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax4.wit +0 -0
  1821. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/package-syntax4.wit.json +0 -0
  1822. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/alias-no-type.wit +0 -0
  1823. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/alias-no-type.wit.result +0 -0
  1824. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/async.wit.result +0 -0
  1825. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/async1.wit.result +0 -0
  1826. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function.wit +0 -0
  1827. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function.wit.result +0 -0
  1828. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function2.wit +0 -0
  1829. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-function2.wit.result +0 -0
  1830. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include1.wit +0 -0
  1831. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include1.wit.result +0 -0
  1832. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include2.wit +0 -0
  1833. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include2.wit.result +0 -0
  1834. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include3.wit +0 -0
  1835. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-include3.wit.result +0 -0
  1836. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-list.wit +0 -0
  1837. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-list.wit.result +0 -0
  1838. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg1/root.wit +0 -0
  1839. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg1.wit.result +0 -0
  1840. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg2/deps/bar/empty.wit +0 -0
  1841. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg2/root.wit +0 -0
  1842. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg2.wit.result +0 -0
  1843. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg3/deps/bar/baz.wit +0 -0
  1844. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg3/root.wit +0 -0
  1845. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg3.wit.result +0 -0
  1846. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg4/deps/bar/baz.wit +0 -0
  1847. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg4/root.wit +0 -0
  1848. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg4.wit.result +0 -0
  1849. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg5/deps/bar/baz.wit +0 -0
  1850. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg5/root.wit +0 -0
  1851. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg5.wit.result +0 -0
  1852. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg6/deps/bar/baz.wit +0 -0
  1853. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg6/root.wit +0 -0
  1854. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-pkg6.wit.result +0 -0
  1855. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource1.wit +0 -0
  1856. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource1.wit.result +0 -0
  1857. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource10.wit +0 -0
  1858. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource10.wit.result +0 -0
  1859. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource11.wit +0 -0
  1860. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource11.wit.result +0 -0
  1861. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource12.wit +0 -0
  1862. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource12.wit.result +0 -0
  1863. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource13.wit +0 -0
  1864. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource13.wit.result +0 -0
  1865. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource14.wit +0 -0
  1866. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource14.wit.result +0 -0
  1867. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource15/deps/foo/foo.wit +0 -0
  1868. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource15/foo.wit +0 -0
  1869. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource15.wit.result +0 -0
  1870. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource2.wit +0 -0
  1871. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource2.wit.result +0 -0
  1872. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource3.wit +0 -0
  1873. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource3.wit.result +0 -0
  1874. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource4.wit +0 -0
  1875. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource4.wit.result +0 -0
  1876. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource5.wit +0 -0
  1877. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource5.wit.result +0 -0
  1878. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource6.wit +0 -0
  1879. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource6.wit.result +0 -0
  1880. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource7.wit +0 -0
  1881. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource7.wit.result +0 -0
  1882. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource8.wit +0 -0
  1883. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource8.wit.result +0 -0
  1884. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource9.wit +0 -0
  1885. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-resource9.wit.result +0 -0
  1886. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-world-type1.wit +0 -0
  1887. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/bad-world-type1.wit.result +0 -0
  1888. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/conflicting-package/a.wit +0 -0
  1889. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/conflicting-package/b.wit +0 -0
  1890. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/conflicting-package.wit.result +0 -0
  1891. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle.wit +0 -0
  1892. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle.wit.result +0 -0
  1893. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle2.wit +0 -0
  1894. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle2.wit.result +0 -0
  1895. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle3.wit +0 -0
  1896. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle3.wit.result +0 -0
  1897. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle4.wit +0 -0
  1898. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle4.wit.result +0 -0
  1899. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle5.wit +0 -0
  1900. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/cycle5.wit.result +0 -0
  1901. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/dangling-type.wit +0 -0
  1902. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/dangling-type.wit.result +0 -0
  1903. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-function-params.wit +0 -0
  1904. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-function-params.wit.result +0 -0
  1905. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-functions.wit +0 -0
  1906. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-functions.wit.result +0 -0
  1907. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface.wit +0 -0
  1908. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface.wit.result +0 -0
  1909. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface2/foo.wit +0 -0
  1910. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface2/foo2.wit +0 -0
  1911. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-interface2.wit.result +0 -0
  1912. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-type.wit +0 -0
  1913. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/duplicate-type.wit.result +0 -0
  1914. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-enum.wit +0 -0
  1915. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-enum.wit.result +0 -0
  1916. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-variant1.wit +0 -0
  1917. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/empty-variant1.wit.result +0 -0
  1918. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/export-twice.wit +0 -0
  1919. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/export-twice.wit.result +0 -0
  1920. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export1.wit +0 -0
  1921. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export1.wit.result +0 -0
  1922. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export2.wit +0 -0
  1923. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export2.wit.result +0 -0
  1924. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export3.wit +0 -0
  1925. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export3.wit.result +0 -0
  1926. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export4.wit +0 -0
  1927. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export4.wit.result +0 -0
  1928. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export5.wit +0 -0
  1929. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-and-export5.wit.result +0 -0
  1930. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-twice.wit +0 -0
  1931. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/import-twice.wit.result +0 -0
  1932. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-cycle.wit +0 -0
  1933. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-cycle.wit.result +0 -0
  1934. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-foreign/deps/bar/empty.wit +0 -0
  1935. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-foreign/root.wit +0 -0
  1936. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-foreign.wit.result +0 -0
  1937. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-id.wit +0 -0
  1938. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-id.wit.result +0 -0
  1939. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-on-id.wit +0 -0
  1940. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/include-with-on-id.wit.result +0 -0
  1941. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-toplevel.wit +0 -0
  1942. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-toplevel.wit.result +0 -0
  1943. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference.wit +0 -0
  1944. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference.wit.result +0 -0
  1945. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference2.wit +0 -0
  1946. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/invalid-type-reference2.wit.result +0 -0
  1947. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit +0 -0
  1948. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include-not-found.wit.result +0 -0
  1949. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include.wit +0 -0
  1950. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/kebab-name-include.wit.result +0 -0
  1951. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/keyword.wit +0 -0
  1952. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/keyword.wit.result +0 -0
  1953. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/missing-package.wit +0 -0
  1954. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/missing-package.wit.result +0 -0
  1955. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/multiple-package-docs/a.wit +0 -0
  1956. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/multiple-package-docs/b.wit +0 -0
  1957. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/multiple-package-docs.wit.result +0 -0
  1958. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/no-access-to-sibling-use/bar.wit +0 -0
  1959. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/no-access-to-sibling-use/foo.wit +0 -0
  1960. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/no-access-to-sibling-use.wit.result +0 -0
  1961. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/non-existance-world-include/deps/bar/baz.wit +0 -0
  1962. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/non-existance-world-include/root.wit +0 -0
  1963. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/non-existance-world-include.wit.result +0 -0
  1964. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle/deps/a1/root.wit +0 -0
  1965. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle/root.wit +0 -0
  1966. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle.wit.result +0 -0
  1967. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2/deps/a1/root.wit +0 -0
  1968. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2/deps/a2/root.wit +0 -0
  1969. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2/root.wit +0 -0
  1970. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/pkg-cycle2.wit.result +0 -0
  1971. /data/ext/cargo-vendor/{wit-parser-0.202.0/tests/ui → wit-parser-0.207.0/tests/ui/parse-fail}/resources-multiple-returns-borrow.wit +0 -0
  1972. /data/ext/cargo-vendor/{wit-parser-0.202.0/tests/ui → wit-parser-0.207.0/tests/ui/parse-fail}/resources-return-borrow.wit +0 -0
  1973. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/type-and-resource-same-name/deps/dep/foo.wit +0 -0
  1974. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/type-and-resource-same-name/foo.wit +0 -0
  1975. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/type-and-resource-same-name.wit.result +0 -0
  1976. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/undefined-typed.wit +0 -0
  1977. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/undefined-typed.wit.result +0 -0
  1978. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unknown-interface.wit +0 -0
  1979. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unknown-interface.wit.result +0 -0
  1980. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface1.wit +0 -0
  1981. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface1.wit.result +0 -0
  1982. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface2.wit +0 -0
  1983. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface2.wit.result +0 -0
  1984. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface3.wit +0 -0
  1985. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface3.wit.result +0 -0
  1986. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface4.wit +0 -0
  1987. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-interface4.wit.result +0 -0
  1988. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use1.wit +0 -0
  1989. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use1.wit.result +0 -0
  1990. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use10/bar.wit +0 -0
  1991. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use10/foo.wit +0 -0
  1992. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use10.wit.result +0 -0
  1993. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use2.wit +0 -0
  1994. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use2.wit.result +0 -0
  1995. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use3.wit +0 -0
  1996. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use3.wit.result +0 -0
  1997. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use7.wit +0 -0
  1998. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use7.wit.result +0 -0
  1999. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use8.wit +0 -0
  2000. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use8.wit.result +0 -0
  2001. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use9.wit +0 -0
  2002. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unresolved-use9.wit.result +0 -0
  2003. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/unterminated-string.wit.result +0 -0
  2004. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-and-include-world/deps/bar/baz.wit +0 -0
  2005. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-and-include-world/root.wit +0 -0
  2006. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-and-include-world.wit.result +0 -0
  2007. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict.wit +0 -0
  2008. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict.wit.result +0 -0
  2009. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict2.wit +0 -0
  2010. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict2.wit.result +0 -0
  2011. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict3.wit +0 -0
  2012. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-conflict3.wit.result +0 -0
  2013. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle1.wit +0 -0
  2014. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle1.wit.result +0 -0
  2015. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle4.wit +0 -0
  2016. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-cycle4.wit.result +0 -0
  2017. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-shadow1.wit +0 -0
  2018. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-shadow1.wit.result +0 -0
  2019. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-world/deps/bar/baz.wit +0 -0
  2020. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-world/root.wit +0 -0
  2021. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/use-world.wit.result +0 -0
  2022. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-interface-clash.wit +0 -0
  2023. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-interface-clash.wit.result +0 -0
  2024. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields2.wit +0 -0
  2025. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields2.wit.result +0 -0
  2026. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields3.wit +0 -0
  2027. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-same-fields3.wit.result +0 -0
  2028. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func.wit +0 -0
  2029. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func.wit.result +0 -0
  2030. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func2.wit +0 -0
  2031. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/parse-fail/world-top-level-func2.wit.result +0 -0
  2032. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/random.wit +0 -0
  2033. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/random.wit.json +0 -0
  2034. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-empty.wit +0 -0
  2035. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-empty.wit.json +0 -0
  2036. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple-returns-own.wit +0 -0
  2037. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple-returns-own.wit.json +0 -0
  2038. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple.wit +0 -0
  2039. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-multiple.wit.json +0 -0
  2040. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-return-own.wit +0 -0
  2041. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources-return-own.wit.json +0 -0
  2042. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources.wit +0 -0
  2043. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources.wit.json +0 -0
  2044. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources1.wit +0 -0
  2045. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/resources1.wit.json +0 -0
  2046. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/same-name-import-export.wit +0 -0
  2047. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/same-name-import-export.wit.json +0 -0
  2048. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/shared-types.wit +0 -0
  2049. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/shared-types.wit.json +0 -0
  2050. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/simple-wasm-text.wat +0 -0
  2051. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/simple-wasm-text.wit.json +0 -0
  2052. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/stress-export-elaborate.wit +0 -0
  2053. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/stress-export-elaborate.wit.json +0 -0
  2054. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/type-then-eof.wit +0 -0
  2055. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/type-then-eof.wit.json +0 -0
  2056. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/types.wit +0 -0
  2057. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/types.wit.json +0 -0
  2058. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-1.wit +0 -0
  2059. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-1.wit.json +0 -0
  2060. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-2.wit +0 -0
  2061. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/union-fuzz-2.wit.json +0 -0
  2062. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use-chain.wit +0 -0
  2063. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use-chain.wit.json +0 -0
  2064. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use.wit +0 -0
  2065. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/use.wit.json +0 -0
  2066. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions/deps/a1/foo.wit +0 -0
  2067. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions/deps/a2/foo.wit +0 -0
  2068. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions/foo.wit +0 -0
  2069. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/versions.wit.json +0 -0
  2070. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/wasi.wit +0 -0
  2071. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/wasi.wit.json +0 -0
  2072. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-diamond.wit +0 -0
  2073. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-diamond.wit.json +0 -0
  2074. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-iface-no-collide.wit +0 -0
  2075. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-iface-no-collide.wit.json +0 -0
  2076. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import1.wit +0 -0
  2077. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import1.wit.json +0 -0
  2078. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import2.wit +0 -0
  2079. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import2.wit.json +0 -0
  2080. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import3.wit +0 -0
  2081. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-implicit-import3.wit.json +0 -0
  2082. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-same-fields4.wit +0 -0
  2083. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-same-fields4.wit.json +0 -0
  2084. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-top-level-funcs.wit +0 -0
  2085. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/world-top-level-funcs.wit.json +0 -0
  2086. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-union-dedup.wit +0 -0
  2087. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-union-dedup.wit.json +0 -0
  2088. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-with-types.wit +0 -0
  2089. /data/ext/cargo-vendor/{wit-parser-0.202.0 → wit-parser-0.207.0}/tests/ui/worlds-with-types.wit.json +0 -0
@@ -1,3646 +0,0 @@
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
- }