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
@@ -0,0 +1,3646 @@
1
+ //! S390x ISA: binary code emission.
2
+
3
+ use crate::binemit::StackMap;
4
+ use crate::ir::{MemFlags, TrapCode};
5
+ use crate::isa::s390x::inst::*;
6
+ use crate::isa::s390x::settings as s390x_settings;
7
+ use crate::trace;
8
+ use cranelift_control::ControlPlane;
9
+ use regalloc2::Allocation;
10
+
11
+ /// Debug macro for testing that a regpair is valid: that the high register is even, and the low
12
+ /// register is one higher than the high register.
13
+ macro_rules! debug_assert_valid_regpair {
14
+ ($hi:expr, $lo:expr) => {
15
+ if cfg!(debug_assertions) {
16
+ match ($hi.to_real_reg(), $lo.to_real_reg()) {
17
+ (Some(hi), Some(lo)) => {
18
+ assert!(
19
+ hi.hw_enc() % 2 == 0,
20
+ "High register is not even: {}",
21
+ show_reg($hi)
22
+ );
23
+ assert_eq!(
24
+ hi.hw_enc() + 1,
25
+ lo.hw_enc(),
26
+ "Low register is not valid: {}, {}",
27
+ show_reg($hi),
28
+ show_reg($lo)
29
+ );
30
+ }
31
+
32
+ _ => {
33
+ panic!(
34
+ "Expected real registers for {} {}",
35
+ show_reg($hi),
36
+ show_reg($lo)
37
+ );
38
+ }
39
+ }
40
+ }
41
+ };
42
+ }
43
+
44
+ /// Type(s) of memory instructions available for mem_finalize.
45
+ pub struct MemInstType {
46
+ /// True if 12-bit unsigned displacement is supported.
47
+ pub have_d12: bool,
48
+ /// True if 20-bit signed displacement is supported.
49
+ pub have_d20: bool,
50
+ /// True if PC-relative addressing is supported (memory access).
51
+ pub have_pcrel: bool,
52
+ /// True if PC-relative addressing is supported (load address).
53
+ pub have_unaligned_pcrel: bool,
54
+ /// True if an index register is supported.
55
+ pub have_index: bool,
56
+ }
57
+
58
+ /// Memory addressing mode finalization: convert "special" modes (e.g.,
59
+ /// generic arbitrary stack offset) into real addressing modes, possibly by
60
+ /// emitting some helper instructions that come immediately before the use
61
+ /// of this amode.
62
+ pub fn mem_finalize(
63
+ mem: &MemArg,
64
+ state: &EmitState,
65
+ mi: MemInstType,
66
+ ) -> (SmallVec<[Inst; 4]>, MemArg) {
67
+ let mut insts = SmallVec::new();
68
+
69
+ // Resolve virtual addressing modes.
70
+ let mem = match mem {
71
+ &MemArg::RegOffset { off, .. }
72
+ | &MemArg::InitialSPOffset { off }
73
+ | &MemArg::NominalSPOffset { off } => {
74
+ let base = match mem {
75
+ &MemArg::RegOffset { reg, .. } => reg,
76
+ &MemArg::InitialSPOffset { .. } | &MemArg::NominalSPOffset { .. } => stack_reg(),
77
+ _ => unreachable!(),
78
+ };
79
+ let adj = match mem {
80
+ &MemArg::InitialSPOffset { .. } => {
81
+ state.initial_sp_offset + state.virtual_sp_offset
82
+ }
83
+ &MemArg::NominalSPOffset { .. } => state.virtual_sp_offset,
84
+ _ => 0,
85
+ };
86
+ let off = off + adj;
87
+
88
+ if let Some(disp) = UImm12::maybe_from_u64(off as u64) {
89
+ MemArg::BXD12 {
90
+ base,
91
+ index: zero_reg(),
92
+ disp,
93
+ flags: mem.get_flags(),
94
+ }
95
+ } else if let Some(disp) = SImm20::maybe_from_i64(off) {
96
+ MemArg::BXD20 {
97
+ base,
98
+ index: zero_reg(),
99
+ disp,
100
+ flags: mem.get_flags(),
101
+ }
102
+ } else {
103
+ let tmp = writable_spilltmp_reg();
104
+ assert!(base != tmp.to_reg());
105
+ if let Ok(imm) = i16::try_from(off) {
106
+ insts.push(Inst::Mov64SImm16 { rd: tmp, imm });
107
+ } else if let Ok(imm) = i32::try_from(off) {
108
+ insts.push(Inst::Mov64SImm32 { rd: tmp, imm });
109
+ } else {
110
+ // The offset must be smaller than the stack frame size,
111
+ // which the ABI code limits to 128 MB.
112
+ unreachable!();
113
+ }
114
+ MemArg::reg_plus_reg(base, tmp.to_reg(), mem.get_flags())
115
+ }
116
+ }
117
+ _ => mem.clone(),
118
+ };
119
+
120
+ // If this addressing mode cannot be handled by the instruction, use load-address.
121
+ let need_load_address = match &mem {
122
+ &MemArg::Label { .. } | &MemArg::Symbol { .. } if !mi.have_pcrel => true,
123
+ &MemArg::Symbol { flags, .. } if !mi.have_unaligned_pcrel && !flags.aligned() => true,
124
+ &MemArg::BXD20 { .. } if !mi.have_d20 => true,
125
+ &MemArg::BXD12 { index, .. } | &MemArg::BXD20 { index, .. } if !mi.have_index => {
126
+ index != zero_reg()
127
+ }
128
+ _ => false,
129
+ };
130
+ let mem = if need_load_address {
131
+ let flags = mem.get_flags();
132
+ let tmp = writable_spilltmp_reg();
133
+ insts.push(Inst::LoadAddr { rd: tmp, mem });
134
+ MemArg::reg(tmp.to_reg(), flags)
135
+ } else {
136
+ mem
137
+ };
138
+
139
+ // Convert 12-bit displacement to 20-bit if required.
140
+ let mem = match &mem {
141
+ &MemArg::BXD12 {
142
+ base,
143
+ index,
144
+ disp,
145
+ flags,
146
+ } if !mi.have_d12 => {
147
+ assert!(mi.have_d20);
148
+ MemArg::BXD20 {
149
+ base,
150
+ index,
151
+ disp: SImm20::from_uimm12(disp),
152
+ flags,
153
+ }
154
+ }
155
+ _ => mem,
156
+ };
157
+
158
+ (insts, mem)
159
+ }
160
+
161
+ pub fn mem_emit(
162
+ rd: Reg,
163
+ mem: &MemArg,
164
+ opcode_rx: Option<u16>,
165
+ opcode_rxy: Option<u16>,
166
+ opcode_ril: Option<u16>,
167
+ add_trap: bool,
168
+ sink: &mut MachBuffer<Inst>,
169
+ emit_info: &EmitInfo,
170
+ state: &mut EmitState,
171
+ ) {
172
+ let (mem_insts, mem) = mem_finalize(
173
+ mem,
174
+ state,
175
+ MemInstType {
176
+ have_d12: opcode_rx.is_some(),
177
+ have_d20: opcode_rxy.is_some(),
178
+ have_pcrel: opcode_ril.is_some(),
179
+ have_unaligned_pcrel: opcode_ril.is_some() && !add_trap,
180
+ have_index: true,
181
+ },
182
+ );
183
+ for inst in mem_insts.into_iter() {
184
+ inst.emit(&[], sink, emit_info, state);
185
+ }
186
+
187
+ if add_trap {
188
+ if let Some(trap_code) = mem.get_flags().trap_code() {
189
+ sink.add_trap(trap_code);
190
+ }
191
+ }
192
+
193
+ match &mem {
194
+ &MemArg::BXD12 {
195
+ base, index, disp, ..
196
+ } => {
197
+ put(
198
+ sink,
199
+ &enc_rx(opcode_rx.unwrap(), rd, base, index, disp.bits()),
200
+ );
201
+ }
202
+ &MemArg::BXD20 {
203
+ base, index, disp, ..
204
+ } => {
205
+ put(
206
+ sink,
207
+ &enc_rxy(opcode_rxy.unwrap(), rd, base, index, disp.bits()),
208
+ );
209
+ }
210
+ &MemArg::Label { target } => {
211
+ sink.use_label_at_offset(sink.cur_offset(), target, LabelUse::BranchRIL);
212
+ put(sink, &enc_ril_b(opcode_ril.unwrap(), rd, 0));
213
+ }
214
+ &MemArg::Symbol {
215
+ ref name, offset, ..
216
+ } => {
217
+ sink.add_reloc_at_offset(2, Reloc::S390xPCRel32Dbl, &**name, (offset + 2).into());
218
+ put(sink, &enc_ril_b(opcode_ril.unwrap(), rd, 0));
219
+ }
220
+ _ => unreachable!(),
221
+ }
222
+ }
223
+
224
+ pub fn mem_rs_emit(
225
+ rd: Reg,
226
+ rn: Reg,
227
+ mem: &MemArg,
228
+ opcode_rs: Option<u16>,
229
+ opcode_rsy: Option<u16>,
230
+ add_trap: bool,
231
+ sink: &mut MachBuffer<Inst>,
232
+ emit_info: &EmitInfo,
233
+ state: &mut EmitState,
234
+ ) {
235
+ let (mem_insts, mem) = mem_finalize(
236
+ mem,
237
+ state,
238
+ MemInstType {
239
+ have_d12: opcode_rs.is_some(),
240
+ have_d20: opcode_rsy.is_some(),
241
+ have_pcrel: false,
242
+ have_unaligned_pcrel: false,
243
+ have_index: false,
244
+ },
245
+ );
246
+ for inst in mem_insts.into_iter() {
247
+ inst.emit(&[], sink, emit_info, state);
248
+ }
249
+
250
+ if add_trap {
251
+ if let Some(trap_code) = mem.get_flags().trap_code() {
252
+ sink.add_trap(trap_code);
253
+ }
254
+ }
255
+
256
+ match &mem {
257
+ &MemArg::BXD12 {
258
+ base, index, disp, ..
259
+ } => {
260
+ assert!(index == zero_reg());
261
+ put(sink, &enc_rs(opcode_rs.unwrap(), rd, rn, base, disp.bits()));
262
+ }
263
+ &MemArg::BXD20 {
264
+ base, index, disp, ..
265
+ } => {
266
+ assert!(index == zero_reg());
267
+ put(
268
+ sink,
269
+ &enc_rsy(opcode_rsy.unwrap(), rd, rn, base, disp.bits()),
270
+ );
271
+ }
272
+ _ => unreachable!(),
273
+ }
274
+ }
275
+
276
+ pub fn mem_imm8_emit(
277
+ imm: u8,
278
+ mem: &MemArg,
279
+ opcode_si: u16,
280
+ opcode_siy: u16,
281
+ add_trap: bool,
282
+ sink: &mut MachBuffer<Inst>,
283
+ emit_info: &EmitInfo,
284
+ state: &mut EmitState,
285
+ ) {
286
+ let (mem_insts, mem) = mem_finalize(
287
+ mem,
288
+ state,
289
+ MemInstType {
290
+ have_d12: true,
291
+ have_d20: true,
292
+ have_pcrel: false,
293
+ have_unaligned_pcrel: false,
294
+ have_index: false,
295
+ },
296
+ );
297
+ for inst in mem_insts.into_iter() {
298
+ inst.emit(&[], sink, emit_info, state);
299
+ }
300
+
301
+ if add_trap {
302
+ if let Some(trap_code) = mem.get_flags().trap_code() {
303
+ sink.add_trap(trap_code);
304
+ }
305
+ }
306
+
307
+ match &mem {
308
+ &MemArg::BXD12 {
309
+ base, index, disp, ..
310
+ } => {
311
+ assert!(index == zero_reg());
312
+ put(sink, &enc_si(opcode_si, base, disp.bits(), imm));
313
+ }
314
+ &MemArg::BXD20 {
315
+ base, index, disp, ..
316
+ } => {
317
+ assert!(index == zero_reg());
318
+ put(sink, &enc_siy(opcode_siy, base, disp.bits(), imm));
319
+ }
320
+ _ => unreachable!(),
321
+ }
322
+ }
323
+
324
+ pub fn mem_imm16_emit(
325
+ imm: i16,
326
+ mem: &MemArg,
327
+ opcode_sil: u16,
328
+ add_trap: bool,
329
+ sink: &mut MachBuffer<Inst>,
330
+ emit_info: &EmitInfo,
331
+ state: &mut EmitState,
332
+ ) {
333
+ let (mem_insts, mem) = mem_finalize(
334
+ mem,
335
+ state,
336
+ MemInstType {
337
+ have_d12: true,
338
+ have_d20: false,
339
+ have_pcrel: false,
340
+ have_unaligned_pcrel: false,
341
+ have_index: false,
342
+ },
343
+ );
344
+ for inst in mem_insts.into_iter() {
345
+ inst.emit(&[], sink, emit_info, state);
346
+ }
347
+
348
+ if add_trap {
349
+ if let Some(trap_code) = mem.get_flags().trap_code() {
350
+ sink.add_trap(trap_code);
351
+ }
352
+ }
353
+
354
+ match &mem {
355
+ &MemArg::BXD12 {
356
+ base, index, disp, ..
357
+ } => {
358
+ assert!(index == zero_reg());
359
+ put(sink, &enc_sil(opcode_sil, base, disp.bits(), imm));
360
+ }
361
+ _ => unreachable!(),
362
+ }
363
+ }
364
+
365
+ pub fn mem_mem_emit(
366
+ dst: &MemArgPair,
367
+ src: &MemArgPair,
368
+ len_minus_one: u8,
369
+ opcode_ss: u8,
370
+ add_trap: bool,
371
+ sink: &mut MachBuffer<Inst>,
372
+ _state: &mut EmitState,
373
+ ) {
374
+ if add_trap {
375
+ if let Some(trap_code) = dst.flags.trap_code().or(src.flags.trap_code()) {
376
+ sink.add_trap(trap_code);
377
+ }
378
+ }
379
+
380
+ put(
381
+ sink,
382
+ &enc_ss_a(
383
+ opcode_ss,
384
+ dst.base,
385
+ dst.disp.bits(),
386
+ src.base,
387
+ src.disp.bits(),
388
+ len_minus_one,
389
+ ),
390
+ );
391
+ }
392
+
393
+ pub fn mem_vrx_emit(
394
+ rd: Reg,
395
+ mem: &MemArg,
396
+ opcode: u16,
397
+ m3: u8,
398
+ add_trap: bool,
399
+ sink: &mut MachBuffer<Inst>,
400
+ emit_info: &EmitInfo,
401
+ state: &mut EmitState,
402
+ ) {
403
+ let (mem_insts, mem) = mem_finalize(
404
+ mem,
405
+ state,
406
+ MemInstType {
407
+ have_d12: true,
408
+ have_d20: false,
409
+ have_pcrel: false,
410
+ have_unaligned_pcrel: false,
411
+ have_index: true,
412
+ },
413
+ );
414
+ for inst in mem_insts.into_iter() {
415
+ inst.emit(&[], sink, emit_info, state);
416
+ }
417
+
418
+ if add_trap {
419
+ if let Some(trap_code) = mem.get_flags().trap_code() {
420
+ sink.add_trap(trap_code);
421
+ }
422
+ }
423
+
424
+ match &mem {
425
+ &MemArg::BXD12 {
426
+ base, index, disp, ..
427
+ } => {
428
+ put(sink, &enc_vrx(opcode, rd, base, index, disp.bits(), m3));
429
+ }
430
+ _ => unreachable!(),
431
+ }
432
+ }
433
+
434
+ //=============================================================================
435
+ // Instructions and subcomponents: emission
436
+
437
+ fn machreg_to_gpr(m: Reg) -> u8 {
438
+ assert_eq!(m.class(), RegClass::Int);
439
+ u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap()
440
+ }
441
+
442
+ fn machreg_to_vr(m: Reg) -> u8 {
443
+ assert_eq!(m.class(), RegClass::Float);
444
+ u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap()
445
+ }
446
+
447
+ fn machreg_to_fpr(m: Reg) -> u8 {
448
+ assert!(is_fpr(m));
449
+ u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap()
450
+ }
451
+
452
+ fn machreg_to_gpr_or_fpr(m: Reg) -> u8 {
453
+ let reg = u8::try_from(m.to_real_reg().unwrap().hw_enc()).unwrap();
454
+ assert!(reg < 16);
455
+ reg
456
+ }
457
+
458
+ fn rxb(v1: Option<Reg>, v2: Option<Reg>, v3: Option<Reg>, v4: Option<Reg>) -> u8 {
459
+ let mut rxb = 0;
460
+
461
+ let is_high_vr = |reg| -> bool {
462
+ if let Some(reg) = reg {
463
+ if !is_fpr(reg) {
464
+ return true;
465
+ }
466
+ }
467
+ false
468
+ };
469
+
470
+ if is_high_vr(v1) {
471
+ rxb = rxb | 8;
472
+ }
473
+ if is_high_vr(v2) {
474
+ rxb = rxb | 4;
475
+ }
476
+ if is_high_vr(v3) {
477
+ rxb = rxb | 2;
478
+ }
479
+ if is_high_vr(v4) {
480
+ rxb = rxb | 1;
481
+ }
482
+
483
+ rxb
484
+ }
485
+
486
+ /// E-type instructions.
487
+ ///
488
+ /// 15
489
+ /// opcode
490
+ /// 0
491
+ ///
492
+ fn enc_e(opcode: u16) -> [u8; 2] {
493
+ let mut enc: [u8; 2] = [0; 2];
494
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
495
+ let opcode2 = (opcode & 0xff) as u8;
496
+
497
+ enc[0] = opcode1;
498
+ enc[1] = opcode2;
499
+ enc
500
+ }
501
+
502
+ /// RIa-type instructions.
503
+ ///
504
+ /// 31 23 19 15
505
+ /// opcode1 r1 opcode2 i2
506
+ /// 24 20 16 0
507
+ ///
508
+ fn enc_ri_a(opcode: u16, r1: Reg, i2: u16) -> [u8; 4] {
509
+ let mut enc: [u8; 4] = [0; 4];
510
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
511
+ let opcode2 = (opcode & 0xf) as u8;
512
+ let r1 = machreg_to_gpr(r1) & 0x0f;
513
+
514
+ enc[0] = opcode1;
515
+ enc[1] = r1 << 4 | opcode2;
516
+ enc[2..].copy_from_slice(&i2.to_be_bytes());
517
+ enc
518
+ }
519
+
520
+ /// RIb-type instructions.
521
+ ///
522
+ /// 31 23 19 15
523
+ /// opcode1 r1 opcode2 ri2
524
+ /// 24 20 16 0
525
+ ///
526
+ fn enc_ri_b(opcode: u16, r1: Reg, ri2: i32) -> [u8; 4] {
527
+ let mut enc: [u8; 4] = [0; 4];
528
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
529
+ let opcode2 = (opcode & 0xf) as u8;
530
+ let r1 = machreg_to_gpr(r1) & 0x0f;
531
+ let ri2 = ((ri2 >> 1) & 0xffff) as u16;
532
+
533
+ enc[0] = opcode1;
534
+ enc[1] = r1 << 4 | opcode2;
535
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
536
+ enc
537
+ }
538
+
539
+ /// RIc-type instructions.
540
+ ///
541
+ /// 31 23 19 15
542
+ /// opcode1 m1 opcode2 ri2
543
+ /// 24 20 16 0
544
+ ///
545
+ fn enc_ri_c(opcode: u16, m1: u8, ri2: i32) -> [u8; 4] {
546
+ let mut enc: [u8; 4] = [0; 4];
547
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
548
+ let opcode2 = (opcode & 0xf) as u8;
549
+ let m1 = m1 & 0x0f;
550
+ let ri2 = ((ri2 >> 1) & 0xffff) as u16;
551
+
552
+ enc[0] = opcode1;
553
+ enc[1] = m1 << 4 | opcode2;
554
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
555
+ enc
556
+ }
557
+
558
+ /// RIEa-type instructions.
559
+ ///
560
+ /// 47 39 35 31 15 11 7
561
+ /// opcode1 r1 -- i2 m3 -- opcode2
562
+ /// 40 36 32 16 12 8 0
563
+ ///
564
+ fn enc_rie_a(opcode: u16, r1: Reg, i2: u16, m3: u8) -> [u8; 6] {
565
+ let mut enc: [u8; 6] = [0; 6];
566
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
567
+ let opcode2 = (opcode & 0xff) as u8;
568
+ let r1 = machreg_to_gpr(r1) & 0x0f;
569
+ let m3 = m3 & 0x0f;
570
+
571
+ enc[0] = opcode1;
572
+ enc[1] = r1 << 4;
573
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
574
+ enc[4] = m3 << 4;
575
+ enc[5] = opcode2;
576
+ enc
577
+ }
578
+
579
+ /// RIEd-type instructions.
580
+ ///
581
+ /// 47 39 35 31 15 7
582
+ /// opcode1 r1 r3 i2 -- opcode2
583
+ /// 40 36 32 16 8 0
584
+ ///
585
+ fn enc_rie_d(opcode: u16, r1: Reg, r3: Reg, i2: u16) -> [u8; 6] {
586
+ let mut enc: [u8; 6] = [0; 6];
587
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
588
+ let opcode2 = (opcode & 0xff) as u8;
589
+ let r1 = machreg_to_gpr(r1) & 0x0f;
590
+ let r3 = machreg_to_gpr(r3) & 0x0f;
591
+
592
+ enc[0] = opcode1;
593
+ enc[1] = r1 << 4 | r3;
594
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
595
+ enc[5] = opcode2;
596
+ enc
597
+ }
598
+
599
+ /// RIEf-type instructions.
600
+ ///
601
+ /// 47 39 35 31 23 15 7
602
+ /// opcode1 r1 r2 i3 i4 i5 opcode2
603
+ /// 40 36 32 24 16 8 0
604
+ ///
605
+ fn enc_rie_f(opcode: u16, r1: Reg, r2: Reg, i3: u8, i4: u8, i5: u8) -> [u8; 6] {
606
+ let mut enc: [u8; 6] = [0; 6];
607
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
608
+ let opcode2 = (opcode & 0xff) as u8;
609
+ let r1 = machreg_to_gpr(r1) & 0x0f;
610
+ let r2 = machreg_to_gpr(r2) & 0x0f;
611
+
612
+ enc[0] = opcode1;
613
+ enc[1] = r1 << 4 | r2;
614
+ enc[2] = i3;
615
+ enc[3] = i4;
616
+ enc[4] = i5;
617
+ enc[5] = opcode2;
618
+ enc
619
+ }
620
+
621
+ /// RIEg-type instructions.
622
+ ///
623
+ /// 47 39 35 31 15 7
624
+ /// opcode1 r1 m3 i2 -- opcode2
625
+ /// 40 36 32 16 8 0
626
+ ///
627
+ fn enc_rie_g(opcode: u16, r1: Reg, i2: u16, m3: u8) -> [u8; 6] {
628
+ let mut enc: [u8; 6] = [0; 6];
629
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
630
+ let opcode2 = (opcode & 0xff) as u8;
631
+ let r1 = machreg_to_gpr(r1) & 0x0f;
632
+ let m3 = m3 & 0x0f;
633
+
634
+ enc[0] = opcode1;
635
+ enc[1] = r1 << 4 | m3;
636
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
637
+ enc[5] = opcode2;
638
+ enc
639
+ }
640
+
641
+ /// RILa-type instructions.
642
+ ///
643
+ /// 47 39 35 31
644
+ /// opcode1 r1 opcode2 i2
645
+ /// 40 36 32 0
646
+ ///
647
+ fn enc_ril_a(opcode: u16, r1: Reg, i2: u32) -> [u8; 6] {
648
+ let mut enc: [u8; 6] = [0; 6];
649
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
650
+ let opcode2 = (opcode & 0xf) as u8;
651
+ let r1 = machreg_to_gpr(r1) & 0x0f;
652
+
653
+ enc[0] = opcode1;
654
+ enc[1] = r1 << 4 | opcode2;
655
+ enc[2..].copy_from_slice(&i2.to_be_bytes());
656
+ enc
657
+ }
658
+
659
+ /// RILb-type instructions.
660
+ ///
661
+ /// 47 39 35 31
662
+ /// opcode1 r1 opcode2 ri2
663
+ /// 40 36 32 0
664
+ ///
665
+ fn enc_ril_b(opcode: u16, r1: Reg, ri2: u32) -> [u8; 6] {
666
+ let mut enc: [u8; 6] = [0; 6];
667
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
668
+ let opcode2 = (opcode & 0xf) as u8;
669
+ let r1 = machreg_to_gpr(r1) & 0x0f;
670
+ let ri2 = ri2 >> 1;
671
+
672
+ enc[0] = opcode1;
673
+ enc[1] = r1 << 4 | opcode2;
674
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
675
+ enc
676
+ }
677
+
678
+ /// RILc-type instructions.
679
+ ///
680
+ /// 47 39 35 31
681
+ /// opcode1 m1 opcode2 i2
682
+ /// 40 36 32 0
683
+ ///
684
+ fn enc_ril_c(opcode: u16, m1: u8, ri2: u32) -> [u8; 6] {
685
+ let mut enc: [u8; 6] = [0; 6];
686
+ let opcode1 = ((opcode >> 4) & 0xff) as u8;
687
+ let opcode2 = (opcode & 0xf) as u8;
688
+ let m1 = m1 & 0x0f;
689
+ let ri2 = ri2 >> 1;
690
+
691
+ enc[0] = opcode1;
692
+ enc[1] = m1 << 4 | opcode2;
693
+ enc[2..].copy_from_slice(&ri2.to_be_bytes());
694
+ enc
695
+ }
696
+
697
+ /// RR-type instructions.
698
+ ///
699
+ /// 15 7 3
700
+ /// opcode r1 r2
701
+ /// 8 4 0
702
+ ///
703
+ fn enc_rr(opcode: u16, r1: Reg, r2: Reg) -> [u8; 2] {
704
+ let mut enc: [u8; 2] = [0; 2];
705
+ let opcode = (opcode & 0xff) as u8;
706
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
707
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
708
+
709
+ enc[0] = opcode;
710
+ enc[1] = r1 << 4 | r2;
711
+ enc
712
+ }
713
+
714
+ /// RRD-type instructions.
715
+ ///
716
+ /// 31 15 11 7 3
717
+ /// opcode r1 -- r3 r2
718
+ /// 16 12 8 4 0
719
+ ///
720
+ fn enc_rrd(opcode: u16, r1: Reg, r2: Reg, r3: Reg) -> [u8; 4] {
721
+ let mut enc: [u8; 4] = [0; 4];
722
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
723
+ let opcode2 = (opcode & 0xff) as u8;
724
+ let r1 = machreg_to_fpr(r1) & 0x0f;
725
+ let r2 = machreg_to_fpr(r2) & 0x0f;
726
+ let r3 = machreg_to_fpr(r3) & 0x0f;
727
+
728
+ enc[0] = opcode1;
729
+ enc[1] = opcode2;
730
+ enc[2] = r1 << 4;
731
+ enc[3] = r3 << 4 | r2;
732
+ enc
733
+ }
734
+
735
+ /// RRE-type instructions.
736
+ ///
737
+ /// 31 15 7 3
738
+ /// opcode -- r1 r2
739
+ /// 16 8 4 0
740
+ ///
741
+ fn enc_rre(opcode: u16, r1: Reg, r2: Reg) -> [u8; 4] {
742
+ let mut enc: [u8; 4] = [0; 4];
743
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
744
+ let opcode2 = (opcode & 0xff) as u8;
745
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
746
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
747
+
748
+ enc[0] = opcode1;
749
+ enc[1] = opcode2;
750
+ enc[3] = r1 << 4 | r2;
751
+ enc
752
+ }
753
+
754
+ /// RRFa/b-type instructions.
755
+ ///
756
+ /// 31 15 11 7 3
757
+ /// opcode r3 m4 r1 r2
758
+ /// 16 12 8 4 0
759
+ ///
760
+ fn enc_rrf_ab(opcode: u16, r1: Reg, r2: Reg, r3: Reg, m4: u8) -> [u8; 4] {
761
+ let mut enc: [u8; 4] = [0; 4];
762
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
763
+ let opcode2 = (opcode & 0xff) as u8;
764
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
765
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
766
+ let r3 = machreg_to_gpr_or_fpr(r3) & 0x0f;
767
+ let m4 = m4 & 0x0f;
768
+
769
+ enc[0] = opcode1;
770
+ enc[1] = opcode2;
771
+ enc[2] = r3 << 4 | m4;
772
+ enc[3] = r1 << 4 | r2;
773
+ enc
774
+ }
775
+
776
+ /// RRFc/d/e-type instructions.
777
+ ///
778
+ /// 31 15 11 7 3
779
+ /// opcode m3 m4 r1 r2
780
+ /// 16 12 8 4 0
781
+ ///
782
+ fn enc_rrf_cde(opcode: u16, r1: Reg, r2: Reg, m3: u8, m4: u8) -> [u8; 4] {
783
+ let mut enc: [u8; 4] = [0; 4];
784
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
785
+ let opcode2 = (opcode & 0xff) as u8;
786
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
787
+ let r2 = machreg_to_gpr_or_fpr(r2) & 0x0f;
788
+ let m3 = m3 & 0x0f;
789
+ let m4 = m4 & 0x0f;
790
+
791
+ enc[0] = opcode1;
792
+ enc[1] = opcode2;
793
+ enc[2] = m3 << 4 | m4;
794
+ enc[3] = r1 << 4 | r2;
795
+ enc
796
+ }
797
+
798
+ /// RS-type instructions.
799
+ ///
800
+ /// 31 23 19 15 11
801
+ /// opcode r1 r3 b2 d2
802
+ /// 24 20 16 12 0
803
+ ///
804
+ fn enc_rs(opcode: u16, r1: Reg, r3: Reg, b2: Reg, d2: u32) -> [u8; 4] {
805
+ let opcode = (opcode & 0xff) as u8;
806
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
807
+ let r3 = machreg_to_gpr_or_fpr(r3) & 0x0f;
808
+ let b2 = machreg_to_gpr(b2) & 0x0f;
809
+ let d2_lo = (d2 & 0xff) as u8;
810
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
811
+
812
+ let mut enc: [u8; 4] = [0; 4];
813
+ enc[0] = opcode;
814
+ enc[1] = r1 << 4 | r3;
815
+ enc[2] = b2 << 4 | d2_hi;
816
+ enc[3] = d2_lo;
817
+ enc
818
+ }
819
+
820
+ /// RSY-type instructions.
821
+ ///
822
+ /// 47 39 35 31 27 15 7
823
+ /// opcode1 r1 r3 b2 dl2 dh2 opcode2
824
+ /// 40 36 32 28 16 8 0
825
+ ///
826
+ fn enc_rsy(opcode: u16, r1: Reg, r3: Reg, b2: Reg, d2: u32) -> [u8; 6] {
827
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
828
+ let opcode2 = (opcode & 0xff) as u8;
829
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
830
+ let r3 = machreg_to_gpr_or_fpr(r3) & 0x0f;
831
+ let b2 = machreg_to_gpr(b2) & 0x0f;
832
+ let dl2_lo = (d2 & 0xff) as u8;
833
+ let dl2_hi = ((d2 >> 8) & 0x0f) as u8;
834
+ let dh2 = ((d2 >> 12) & 0xff) as u8;
835
+
836
+ let mut enc: [u8; 6] = [0; 6];
837
+ enc[0] = opcode1;
838
+ enc[1] = r1 << 4 | r3;
839
+ enc[2] = b2 << 4 | dl2_hi;
840
+ enc[3] = dl2_lo;
841
+ enc[4] = dh2;
842
+ enc[5] = opcode2;
843
+ enc
844
+ }
845
+
846
+ /// RX-type instructions.
847
+ ///
848
+ /// 31 23 19 15 11
849
+ /// opcode r1 x2 b2 d2
850
+ /// 24 20 16 12 0
851
+ ///
852
+ fn enc_rx(opcode: u16, r1: Reg, b2: Reg, x2: Reg, d2: u32) -> [u8; 4] {
853
+ let opcode = (opcode & 0xff) as u8;
854
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
855
+ let b2 = machreg_to_gpr(b2) & 0x0f;
856
+ let x2 = machreg_to_gpr(x2) & 0x0f;
857
+ let d2_lo = (d2 & 0xff) as u8;
858
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
859
+
860
+ let mut enc: [u8; 4] = [0; 4];
861
+ enc[0] = opcode;
862
+ enc[1] = r1 << 4 | x2;
863
+ enc[2] = b2 << 4 | d2_hi;
864
+ enc[3] = d2_lo;
865
+ enc
866
+ }
867
+
868
+ /// RXY-type instructions.
869
+ ///
870
+ /// 47 39 35 31 27 15 7
871
+ /// opcode1 r1 x2 b2 dl2 dh2 opcode2
872
+ /// 40 36 32 28 16 8 0
873
+ ///
874
+ fn enc_rxy(opcode: u16, r1: Reg, b2: Reg, x2: Reg, d2: u32) -> [u8; 6] {
875
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
876
+ let opcode2 = (opcode & 0xff) as u8;
877
+ let r1 = machreg_to_gpr_or_fpr(r1) & 0x0f;
878
+ let b2 = machreg_to_gpr(b2) & 0x0f;
879
+ let x2 = machreg_to_gpr(x2) & 0x0f;
880
+ let dl2_lo = (d2 & 0xff) as u8;
881
+ let dl2_hi = ((d2 >> 8) & 0x0f) as u8;
882
+ let dh2 = ((d2 >> 12) & 0xff) as u8;
883
+
884
+ let mut enc: [u8; 6] = [0; 6];
885
+ enc[0] = opcode1;
886
+ enc[1] = r1 << 4 | x2;
887
+ enc[2] = b2 << 4 | dl2_hi;
888
+ enc[3] = dl2_lo;
889
+ enc[4] = dh2;
890
+ enc[5] = opcode2;
891
+ enc
892
+ }
893
+
894
+ /// SI-type instructions.
895
+ ///
896
+ /// 31 23 15 11
897
+ /// opcode i2 b1 d1
898
+ /// 24 16 12 0
899
+ ///
900
+ fn enc_si(opcode: u16, b1: Reg, d1: u32, i2: u8) -> [u8; 4] {
901
+ let opcode = (opcode & 0xff) as u8;
902
+ let b1 = machreg_to_gpr(b1) & 0x0f;
903
+ let d1_lo = (d1 & 0xff) as u8;
904
+ let d1_hi = ((d1 >> 8) & 0x0f) as u8;
905
+
906
+ let mut enc: [u8; 4] = [0; 4];
907
+ enc[0] = opcode;
908
+ enc[1] = i2;
909
+ enc[2] = b1 << 4 | d1_hi;
910
+ enc[3] = d1_lo;
911
+ enc
912
+ }
913
+
914
+ /// SIL-type instructions.
915
+ ///
916
+ /// 47 31 27 15
917
+ /// opcode b1 d1 i2
918
+ /// 32 28 16 0
919
+ ///
920
+ fn enc_sil(opcode: u16, b1: Reg, d1: u32, i2: i16) -> [u8; 6] {
921
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
922
+ let opcode2 = (opcode & 0xff) as u8;
923
+ let b1 = machreg_to_gpr(b1) & 0x0f;
924
+ let d1_lo = (d1 & 0xff) as u8;
925
+ let d1_hi = ((d1 >> 8) & 0x0f) as u8;
926
+
927
+ let mut enc: [u8; 6] = [0; 6];
928
+ enc[0] = opcode1;
929
+ enc[1] = opcode2;
930
+ enc[2] = b1 << 4 | d1_hi;
931
+ enc[3] = d1_lo;
932
+ enc[4..].copy_from_slice(&i2.to_be_bytes());
933
+ enc
934
+ }
935
+
936
+ /// SIY-type instructions.
937
+ ///
938
+ /// 47 39 31 27 15 7
939
+ /// opcode1 i2 b1 dl1 dh1 opcode2
940
+ /// 40 32 28 16 8 0
941
+ ///
942
+ fn enc_siy(opcode: u16, b1: Reg, d1: u32, i2: u8) -> [u8; 6] {
943
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
944
+ let opcode2 = (opcode & 0xff) as u8;
945
+ let b1 = machreg_to_gpr(b1) & 0x0f;
946
+ let dl1_lo = (d1 & 0xff) as u8;
947
+ let dl1_hi = ((d1 >> 8) & 0x0f) as u8;
948
+ let dh1 = ((d1 >> 12) & 0xff) as u8;
949
+
950
+ let mut enc: [u8; 6] = [0; 6];
951
+ enc[0] = opcode1;
952
+ enc[1] = i2;
953
+ enc[2] = b1 << 4 | dl1_hi;
954
+ enc[3] = dl1_lo;
955
+ enc[4] = dh1;
956
+ enc[5] = opcode2;
957
+ enc
958
+ }
959
+
960
+ /// SSa-type instructions.
961
+ ///
962
+ /// 47 39 31 27 15 11
963
+ /// opcode l b1 d1 b2 d2
964
+ /// 40 32 28 16 12 0
965
+ ///
966
+ ///
967
+ fn enc_ss_a(opcode: u8, b1: Reg, d1: u32, b2: Reg, d2: u32, l: u8) -> [u8; 6] {
968
+ let b1 = machreg_to_gpr(b1) & 0x0f;
969
+ let d1_lo = (d1 & 0xff) as u8;
970
+ let d1_hi = ((d1 >> 8) & 0x0f) as u8;
971
+ let b2 = machreg_to_gpr(b2) & 0x0f;
972
+ let d2_lo = (d2 & 0xff) as u8;
973
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
974
+
975
+ let mut enc: [u8; 6] = [0; 6];
976
+ enc[0] = opcode;
977
+ enc[1] = l;
978
+ enc[2] = b1 << 4 | d1_hi;
979
+ enc[3] = d1_lo;
980
+ enc[4] = b2 << 4 | d2_hi;
981
+ enc[5] = d2_lo;
982
+ enc
983
+ }
984
+
985
+ /// VRIa-type instructions.
986
+ ///
987
+ /// 47 39 35 31 15 11 7
988
+ /// opcode1 v1 - i2 m3 rxb opcode2
989
+ /// 40 36 32 16 12 8 0
990
+ ///
991
+ fn enc_vri_a(opcode: u16, v1: Reg, i2: u16, m3: u8) -> [u8; 6] {
992
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
993
+ let opcode2 = (opcode & 0xff) as u8;
994
+ let rxb = rxb(Some(v1), None, None, None);
995
+ let v1 = machreg_to_vr(v1) & 0x0f;
996
+ let m3 = m3 & 0x0f;
997
+
998
+ let mut enc: [u8; 6] = [0; 6];
999
+ enc[0] = opcode1;
1000
+ enc[1] = v1 << 4;
1001
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
1002
+ enc[4] = m3 << 4 | rxb;
1003
+ enc[5] = opcode2;
1004
+ enc
1005
+ }
1006
+
1007
+ /// VRIb-type instructions.
1008
+ ///
1009
+ /// 47 39 35 31 23 15 11 7
1010
+ /// opcode1 v1 - i2 i3 m4 rxb opcode2
1011
+ /// 40 36 32 24 16 12 8 0
1012
+ ///
1013
+ fn enc_vri_b(opcode: u16, v1: Reg, i2: u8, i3: u8, m4: u8) -> [u8; 6] {
1014
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1015
+ let opcode2 = (opcode & 0xff) as u8;
1016
+ let rxb = rxb(Some(v1), None, None, None);
1017
+ let v1 = machreg_to_vr(v1) & 0x0f;
1018
+ let m4 = m4 & 0x0f;
1019
+
1020
+ let mut enc: [u8; 6] = [0; 6];
1021
+ enc[0] = opcode1;
1022
+ enc[1] = v1 << 4;
1023
+ enc[2] = i2;
1024
+ enc[3] = i3;
1025
+ enc[4] = m4 << 4 | rxb;
1026
+ enc[5] = opcode2;
1027
+ enc
1028
+ }
1029
+
1030
+ /// VRIc-type instructions.
1031
+ ///
1032
+ /// 47 39 35 31 15 11 7
1033
+ /// opcode1 v1 v3 i2 m4 rxb opcode2
1034
+ /// 40 36 32 16 12 8 0
1035
+ ///
1036
+ fn enc_vri_c(opcode: u16, v1: Reg, i2: u16, v3: Reg, m4: u8) -> [u8; 6] {
1037
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1038
+ let opcode2 = (opcode & 0xff) as u8;
1039
+ let rxb = rxb(Some(v1), Some(v3), None, None);
1040
+ let v1 = machreg_to_vr(v1) & 0x0f;
1041
+ let v3 = machreg_to_vr(v3) & 0x0f;
1042
+ let m4 = m4 & 0x0f;
1043
+
1044
+ let mut enc: [u8; 6] = [0; 6];
1045
+ enc[0] = opcode1;
1046
+ enc[1] = v1 << 4 | v3;
1047
+ enc[2..4].copy_from_slice(&i2.to_be_bytes());
1048
+ enc[4] = m4 << 4 | rxb;
1049
+ enc[5] = opcode2;
1050
+ enc
1051
+ }
1052
+
1053
+ /// VRRa-type instructions.
1054
+ ///
1055
+ /// 47 39 35 31 23 19 15 11 7
1056
+ /// opcode1 v1 v2 - m5 m3 m2 rxb opcode2
1057
+ /// 40 36 32 24 20 16 12 8 0
1058
+ ///
1059
+ fn enc_vrr_a(opcode: u16, v1: Reg, v2: Reg, m3: u8, m4: u8, m5: u8) -> [u8; 6] {
1060
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1061
+ let opcode2 = (opcode & 0xff) as u8;
1062
+ let rxb = rxb(Some(v1), Some(v2), None, None);
1063
+ let v1 = machreg_to_vr(v1) & 0x0f;
1064
+ let v2 = machreg_to_vr(v2) & 0x0f;
1065
+ let m3 = m3 & 0x0f;
1066
+ let m4 = m4 & 0x0f;
1067
+ let m5 = m5 & 0x0f;
1068
+
1069
+ let mut enc: [u8; 6] = [0; 6];
1070
+ enc[0] = opcode1;
1071
+ enc[1] = v1 << 4 | v2;
1072
+ enc[2] = 0;
1073
+ enc[3] = m5 << 4 | m4;
1074
+ enc[4] = m3 << 4 | rxb;
1075
+ enc[5] = opcode2;
1076
+ enc
1077
+ }
1078
+
1079
+ /// VRRb-type instructions.
1080
+ ///
1081
+ /// 47 39 35 31 27 23 19 15 11 7
1082
+ /// opcode1 v1 v2 v3 - m5 - m4 rxb opcode2
1083
+ /// 40 36 32 28 24 20 16 12 8 0
1084
+ ///
1085
+ fn enc_vrr_b(opcode: u16, v1: Reg, v2: Reg, v3: Reg, m4: u8, m5: u8) -> [u8; 6] {
1086
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1087
+ let opcode2 = (opcode & 0xff) as u8;
1088
+ let rxb = rxb(Some(v1), Some(v2), Some(v3), None);
1089
+ let v1 = machreg_to_vr(v1) & 0x0f;
1090
+ let v2 = machreg_to_vr(v2) & 0x0f;
1091
+ let v3 = machreg_to_vr(v3) & 0x0f;
1092
+ let m4 = m4 & 0x0f;
1093
+ let m5 = m5 & 0x0f;
1094
+
1095
+ let mut enc: [u8; 6] = [0; 6];
1096
+ enc[0] = opcode1;
1097
+ enc[1] = v1 << 4 | v2;
1098
+ enc[2] = v3 << 4;
1099
+ enc[3] = m5 << 4;
1100
+ enc[4] = m4 << 4 | rxb;
1101
+ enc[5] = opcode2;
1102
+ enc
1103
+ }
1104
+
1105
+ /// VRRc-type instructions.
1106
+ ///
1107
+ /// 47 39 35 31 27 23 19 15 11 7
1108
+ /// opcode1 v1 v2 v3 - m6 m5 m4 rxb opcode2
1109
+ /// 40 36 32 28 24 20 16 12 8 0
1110
+ ///
1111
+ fn enc_vrr_c(opcode: u16, v1: Reg, v2: Reg, v3: Reg, m4: u8, m5: u8, m6: u8) -> [u8; 6] {
1112
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1113
+ let opcode2 = (opcode & 0xff) as u8;
1114
+ let rxb = rxb(Some(v1), Some(v2), Some(v3), None);
1115
+ let v1 = machreg_to_vr(v1) & 0x0f;
1116
+ let v2 = machreg_to_vr(v2) & 0x0f;
1117
+ let v3 = machreg_to_vr(v3) & 0x0f;
1118
+ let m4 = m4 & 0x0f;
1119
+ let m5 = m5 & 0x0f;
1120
+ let m6 = m6 & 0x0f;
1121
+
1122
+ let mut enc: [u8; 6] = [0; 6];
1123
+ enc[0] = opcode1;
1124
+ enc[1] = v1 << 4 | v2;
1125
+ enc[2] = v3 << 4;
1126
+ enc[3] = m6 << 4 | m5;
1127
+ enc[4] = m4 << 4 | rxb;
1128
+ enc[5] = opcode2;
1129
+ enc
1130
+ }
1131
+
1132
+ /// VRRe-type instructions.
1133
+ ///
1134
+ /// 47 39 35 31 27 23 19 15 11 7
1135
+ /// opcode1 v1 v2 v3 m6 - m5 v4 rxb opcode2
1136
+ /// 40 36 32 28 24 20 16 12 8 0
1137
+ ///
1138
+ fn enc_vrr_e(opcode: u16, v1: Reg, v2: Reg, v3: Reg, v4: Reg, m5: u8, m6: u8) -> [u8; 6] {
1139
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1140
+ let opcode2 = (opcode & 0xff) as u8;
1141
+ let rxb = rxb(Some(v1), Some(v2), Some(v3), Some(v4));
1142
+ let v1 = machreg_to_vr(v1) & 0x0f;
1143
+ let v2 = machreg_to_vr(v2) & 0x0f;
1144
+ let v3 = machreg_to_vr(v3) & 0x0f;
1145
+ let v4 = machreg_to_vr(v4) & 0x0f;
1146
+ let m5 = m5 & 0x0f;
1147
+ let m6 = m6 & 0x0f;
1148
+
1149
+ let mut enc: [u8; 6] = [0; 6];
1150
+ enc[0] = opcode1;
1151
+ enc[1] = v1 << 4 | v2;
1152
+ enc[2] = v3 << 4 | m6;
1153
+ enc[3] = m5;
1154
+ enc[4] = v4 << 4 | rxb;
1155
+ enc[5] = opcode2;
1156
+ enc
1157
+ }
1158
+
1159
+ /// VRRf-type instructions.
1160
+ ///
1161
+ /// 47 39 35 31 27 11 7
1162
+ /// opcode1 v1 r2 r3 - rxb opcode2
1163
+ /// 40 36 32 28 12 8 0
1164
+ ///
1165
+ fn enc_vrr_f(opcode: u16, v1: Reg, r2: Reg, r3: Reg) -> [u8; 6] {
1166
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1167
+ let opcode2 = (opcode & 0xff) as u8;
1168
+ let rxb = rxb(Some(v1), None, None, None);
1169
+ let v1 = machreg_to_vr(v1) & 0x0f;
1170
+ let r2 = machreg_to_gpr(r2) & 0x0f;
1171
+ let r3 = machreg_to_gpr(r3) & 0x0f;
1172
+
1173
+ let mut enc: [u8; 6] = [0; 6];
1174
+ enc[0] = opcode1;
1175
+ enc[1] = v1 << 4 | r2;
1176
+ enc[2] = r3 << 4;
1177
+ enc[4] = rxb;
1178
+ enc[5] = opcode2;
1179
+ enc
1180
+ }
1181
+
1182
+ /// VRSa-type instructions.
1183
+ ///
1184
+ /// 47 39 35 31 27 15 11 7
1185
+ /// opcode1 v1 v3 b2 d2 m4 rxb opcode2
1186
+ /// 40 36 32 28 16 12 8 0
1187
+ ///
1188
+ fn enc_vrs_a(opcode: u16, v1: Reg, b2: Reg, d2: u32, v3: Reg, m4: u8) -> [u8; 6] {
1189
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1190
+ let opcode2 = (opcode & 0xff) as u8;
1191
+ let rxb = rxb(Some(v1), Some(v3), None, None);
1192
+ let v1 = machreg_to_vr(v1) & 0x0f;
1193
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1194
+ let v3 = machreg_to_vr(v3) & 0x0f;
1195
+ let d2_lo = (d2 & 0xff) as u8;
1196
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1197
+ let m4 = m4 & 0x0f;
1198
+
1199
+ let mut enc: [u8; 6] = [0; 6];
1200
+ enc[0] = opcode1;
1201
+ enc[1] = v1 << 4 | v3;
1202
+ enc[2] = b2 << 4 | d2_hi;
1203
+ enc[3] = d2_lo;
1204
+ enc[4] = m4 << 4 | rxb;
1205
+ enc[5] = opcode2;
1206
+ enc
1207
+ }
1208
+
1209
+ /// VRSb-type instructions.
1210
+ ///
1211
+ /// 47 39 35 31 27 15 11 7
1212
+ /// opcode1 v1 r3 b2 d2 m4 rxb opcode2
1213
+ /// 40 36 32 28 16 12 8 0
1214
+ ///
1215
+ fn enc_vrs_b(opcode: u16, v1: Reg, b2: Reg, d2: u32, r3: Reg, m4: u8) -> [u8; 6] {
1216
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1217
+ let opcode2 = (opcode & 0xff) as u8;
1218
+ let rxb = rxb(Some(v1), None, None, None);
1219
+ let v1 = machreg_to_vr(v1) & 0x0f;
1220
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1221
+ let r3 = machreg_to_gpr(r3) & 0x0f;
1222
+ let d2_lo = (d2 & 0xff) as u8;
1223
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1224
+ let m4 = m4 & 0x0f;
1225
+
1226
+ let mut enc: [u8; 6] = [0; 6];
1227
+ enc[0] = opcode1;
1228
+ enc[1] = v1 << 4 | r3;
1229
+ enc[2] = b2 << 4 | d2_hi;
1230
+ enc[3] = d2_lo;
1231
+ enc[4] = m4 << 4 | rxb;
1232
+ enc[5] = opcode2;
1233
+ enc
1234
+ }
1235
+
1236
+ /// VRSc-type instructions.
1237
+ ///
1238
+ /// 47 39 35 31 27 15 11 7
1239
+ /// opcode1 r1 v3 b2 d2 m4 rxb opcode2
1240
+ /// 40 36 32 28 16 12 8 0
1241
+ ///
1242
+ fn enc_vrs_c(opcode: u16, r1: Reg, b2: Reg, d2: u32, v3: Reg, m4: u8) -> [u8; 6] {
1243
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1244
+ let opcode2 = (opcode & 0xff) as u8;
1245
+ let rxb = rxb(None, Some(v3), None, None);
1246
+ let r1 = machreg_to_gpr(r1) & 0x0f;
1247
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1248
+ let v3 = machreg_to_vr(v3) & 0x0f;
1249
+ let d2_lo = (d2 & 0xff) as u8;
1250
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1251
+ let m4 = m4 & 0x0f;
1252
+
1253
+ let mut enc: [u8; 6] = [0; 6];
1254
+ enc[0] = opcode1;
1255
+ enc[1] = r1 << 4 | v3;
1256
+ enc[2] = b2 << 4 | d2_hi;
1257
+ enc[3] = d2_lo;
1258
+ enc[4] = m4 << 4 | rxb;
1259
+ enc[5] = opcode2;
1260
+ enc
1261
+ }
1262
+
1263
+ /// VRX-type instructions.
1264
+ ///
1265
+ /// 47 39 35 31 27 15 11 7
1266
+ /// opcode1 v1 x2 b2 d2 m3 rxb opcode2
1267
+ /// 40 36 32 28 16 12 8 0
1268
+ ///
1269
+ fn enc_vrx(opcode: u16, v1: Reg, b2: Reg, x2: Reg, d2: u32, m3: u8) -> [u8; 6] {
1270
+ let opcode1 = ((opcode >> 8) & 0xff) as u8;
1271
+ let opcode2 = (opcode & 0xff) as u8;
1272
+ let rxb = rxb(Some(v1), None, None, None);
1273
+ let v1 = machreg_to_vr(v1) & 0x0f;
1274
+ let b2 = machreg_to_gpr(b2) & 0x0f;
1275
+ let x2 = machreg_to_gpr(x2) & 0x0f;
1276
+ let d2_lo = (d2 & 0xff) as u8;
1277
+ let d2_hi = ((d2 >> 8) & 0x0f) as u8;
1278
+ let m3 = m3 & 0x0f;
1279
+
1280
+ let mut enc: [u8; 6] = [0; 6];
1281
+ enc[0] = opcode1;
1282
+ enc[1] = v1 << 4 | x2;
1283
+ enc[2] = b2 << 4 | d2_hi;
1284
+ enc[3] = d2_lo;
1285
+ enc[4] = m3 << 4 | rxb;
1286
+ enc[5] = opcode2;
1287
+ enc
1288
+ }
1289
+
1290
+ /// Emit encoding to sink.
1291
+ fn put(sink: &mut MachBuffer<Inst>, enc: &[u8]) {
1292
+ for byte in enc {
1293
+ sink.put1(*byte);
1294
+ }
1295
+ }
1296
+
1297
+ /// Emit encoding to sink, adding a trap on the last byte.
1298
+ fn put_with_trap(sink: &mut MachBuffer<Inst>, enc: &[u8], trap_code: TrapCode) {
1299
+ let len = enc.len();
1300
+ for i in 0..len - 1 {
1301
+ sink.put1(enc[i]);
1302
+ }
1303
+ sink.add_trap(trap_code);
1304
+ sink.put1(enc[len - 1]);
1305
+ }
1306
+
1307
+ /// State carried between emissions of a sequence of instructions.
1308
+ #[derive(Default, Clone, Debug)]
1309
+ pub struct EmitState {
1310
+ pub(crate) initial_sp_offset: i64,
1311
+ pub(crate) virtual_sp_offset: i64,
1312
+ /// Safepoint stack map for upcoming instruction, as provided to `pre_safepoint()`.
1313
+ stack_map: Option<StackMap>,
1314
+ /// Only used during fuzz-testing. Otherwise, it is a zero-sized struct and
1315
+ /// optimized away at compiletime. See [cranelift_control].
1316
+ ctrl_plane: ControlPlane,
1317
+ }
1318
+
1319
+ impl MachInstEmitState<Inst> for EmitState {
1320
+ fn new(abi: &Callee<S390xMachineDeps>, ctrl_plane: ControlPlane) -> Self {
1321
+ EmitState {
1322
+ virtual_sp_offset: 0,
1323
+ initial_sp_offset: abi.frame_size() as i64,
1324
+ stack_map: None,
1325
+ ctrl_plane,
1326
+ }
1327
+ }
1328
+
1329
+ fn pre_safepoint(&mut self, stack_map: StackMap) {
1330
+ self.stack_map = Some(stack_map);
1331
+ }
1332
+
1333
+ fn ctrl_plane_mut(&mut self) -> &mut ControlPlane {
1334
+ &mut self.ctrl_plane
1335
+ }
1336
+
1337
+ fn take_ctrl_plane(self) -> ControlPlane {
1338
+ self.ctrl_plane
1339
+ }
1340
+ }
1341
+
1342
+ impl EmitState {
1343
+ fn take_stack_map(&mut self) -> Option<StackMap> {
1344
+ self.stack_map.take()
1345
+ }
1346
+
1347
+ fn clear_post_insn(&mut self) {
1348
+ self.stack_map = None;
1349
+ }
1350
+ }
1351
+
1352
+ /// Constant state used during function compilation.
1353
+ pub struct EmitInfo {
1354
+ isa_flags: s390x_settings::Flags,
1355
+ }
1356
+
1357
+ impl EmitInfo {
1358
+ pub(crate) fn new(isa_flags: s390x_settings::Flags) -> Self {
1359
+ Self { isa_flags }
1360
+ }
1361
+ }
1362
+
1363
+ impl MachInstEmit for Inst {
1364
+ type State = EmitState;
1365
+ type Info = EmitInfo;
1366
+
1367
+ fn emit(
1368
+ &self,
1369
+ allocs: &[Allocation],
1370
+ sink: &mut MachBuffer<Inst>,
1371
+ emit_info: &Self::Info,
1372
+ state: &mut EmitState,
1373
+ ) {
1374
+ let mut allocs = AllocationConsumer::new(allocs);
1375
+ self.emit_with_alloc_consumer(&mut allocs, sink, emit_info, state)
1376
+ }
1377
+
1378
+ fn pretty_print_inst(&self, allocs: &[Allocation], state: &mut EmitState) -> String {
1379
+ let mut allocs = AllocationConsumer::new(allocs);
1380
+ self.print_with_state(state, &mut allocs)
1381
+ }
1382
+ }
1383
+
1384
+ impl Inst {
1385
+ fn emit_with_alloc_consumer(
1386
+ &self,
1387
+ allocs: &mut AllocationConsumer,
1388
+ sink: &mut MachBuffer<Inst>,
1389
+ emit_info: &EmitInfo,
1390
+ state: &mut EmitState,
1391
+ ) {
1392
+ // Verify that we can emit this Inst in the current ISA
1393
+ let matches_isa_flags = |iset_requirement: &InstructionSet| -> bool {
1394
+ match iset_requirement {
1395
+ // Baseline ISA is z14
1396
+ InstructionSet::Base => true,
1397
+ // Miscellaneous-Instruction-Extensions Facility 2 (z15)
1398
+ InstructionSet::MIE2 => emit_info.isa_flags.has_mie2(),
1399
+ // Vector-Enhancements Facility 2 (z15)
1400
+ InstructionSet::VXRS_EXT2 => emit_info.isa_flags.has_vxrs_ext2(),
1401
+ }
1402
+ };
1403
+ let isa_requirements = self.available_in_isa();
1404
+ if !matches_isa_flags(&isa_requirements) {
1405
+ panic!(
1406
+ "Cannot emit inst '{:?}' for target; failed to match ISA requirements: {:?}",
1407
+ self, isa_requirements
1408
+ )
1409
+ }
1410
+
1411
+ // N.B.: we *must* not exceed the "worst-case size" used to compute
1412
+ // where to insert islands, except when islands are explicitly triggered
1413
+ // (with an `EmitIsland`). We check this in debug builds. This is `mut`
1414
+ // to allow disabling the check for `JTSequence`, which is always
1415
+ // emitted following an `EmitIsland`.
1416
+ let mut start_off = sink.cur_offset();
1417
+
1418
+ match self {
1419
+ &Inst::AluRRR { alu_op, rd, rn, rm } => {
1420
+ let rd = allocs.next_writable(rd);
1421
+ let rn = allocs.next(rn);
1422
+ let rm = allocs.next(rm);
1423
+
1424
+ let (opcode, have_rr) = match alu_op {
1425
+ ALUOp::Add32 => (0xb9f8, true), // ARK
1426
+ ALUOp::Add64 => (0xb9e8, true), // AGRK
1427
+ ALUOp::AddLogical32 => (0xb9fa, true), // ALRK
1428
+ ALUOp::AddLogical64 => (0xb9ea, true), // ALGRK
1429
+ ALUOp::Sub32 => (0xb9f9, true), // SRK
1430
+ ALUOp::Sub64 => (0xb9e9, true), // SGRK
1431
+ ALUOp::SubLogical32 => (0xb9fb, true), // SLRK
1432
+ ALUOp::SubLogical64 => (0xb9eb, true), // SLGRK
1433
+ ALUOp::Mul32 => (0xb9fd, true), // MSRKC
1434
+ ALUOp::Mul64 => (0xb9ed, true), // MSGRKC
1435
+ ALUOp::And32 => (0xb9f4, true), // NRK
1436
+ ALUOp::And64 => (0xb9e4, true), // NGRK
1437
+ ALUOp::Orr32 => (0xb9f6, true), // ORK
1438
+ ALUOp::Orr64 => (0xb9e6, true), // OGRK
1439
+ ALUOp::Xor32 => (0xb9f7, true), // XRK
1440
+ ALUOp::Xor64 => (0xb9e7, true), // XGRK
1441
+ ALUOp::NotAnd32 => (0xb974, false), // NNRK
1442
+ ALUOp::NotAnd64 => (0xb964, false), // NNGRK
1443
+ ALUOp::NotOrr32 => (0xb976, false), // NORK
1444
+ ALUOp::NotOrr64 => (0xb966, false), // NOGRK
1445
+ ALUOp::NotXor32 => (0xb977, false), // NXRK
1446
+ ALUOp::NotXor64 => (0xb967, false), // NXGRK
1447
+ ALUOp::AndNot32 => (0xb9f5, false), // NCRK
1448
+ ALUOp::AndNot64 => (0xb9e5, false), // NCGRK
1449
+ ALUOp::OrrNot32 => (0xb975, false), // OCRK
1450
+ ALUOp::OrrNot64 => (0xb965, false), // OCGRK
1451
+ _ => unreachable!(),
1452
+ };
1453
+ if have_rr && rd.to_reg() == rn {
1454
+ let inst = Inst::AluRR {
1455
+ alu_op,
1456
+ rd,
1457
+ ri: rn,
1458
+ rm,
1459
+ };
1460
+ inst.emit(&[], sink, emit_info, state);
1461
+ } else {
1462
+ put(sink, &enc_rrf_ab(opcode, rd.to_reg(), rn, rm, 0));
1463
+ }
1464
+ }
1465
+ &Inst::AluRRSImm16 {
1466
+ alu_op,
1467
+ rd,
1468
+ rn,
1469
+ imm,
1470
+ } => {
1471
+ let rd = allocs.next_writable(rd);
1472
+ let rn = allocs.next(rn);
1473
+
1474
+ if rd.to_reg() == rn {
1475
+ let inst = Inst::AluRSImm16 {
1476
+ alu_op,
1477
+ rd,
1478
+ ri: rn,
1479
+ imm,
1480
+ };
1481
+ inst.emit(&[], sink, emit_info, state);
1482
+ } else {
1483
+ let opcode = match alu_op {
1484
+ ALUOp::Add32 => 0xecd8, // AHIK
1485
+ ALUOp::Add64 => 0xecd9, // AGHIK
1486
+ _ => unreachable!(),
1487
+ };
1488
+ put(sink, &enc_rie_d(opcode, rd.to_reg(), rn, imm as u16));
1489
+ }
1490
+ }
1491
+ &Inst::AluRR { alu_op, rd, ri, rm } => {
1492
+ let rd = allocs.next_writable(rd);
1493
+ let ri = allocs.next(ri);
1494
+ debug_assert_eq!(rd.to_reg(), ri);
1495
+ let rm = allocs.next(rm);
1496
+
1497
+ let (opcode, is_rre) = match alu_op {
1498
+ ALUOp::Add32 => (0x1a, false), // AR
1499
+ ALUOp::Add64 => (0xb908, true), // AGR
1500
+ ALUOp::Add64Ext32 => (0xb918, true), // AGFR
1501
+ ALUOp::AddLogical32 => (0x1e, false), // ALR
1502
+ ALUOp::AddLogical64 => (0xb90a, true), // ALGR
1503
+ ALUOp::AddLogical64Ext32 => (0xb91a, true), // ALGFR
1504
+ ALUOp::Sub32 => (0x1b, false), // SR
1505
+ ALUOp::Sub64 => (0xb909, true), // SGR
1506
+ ALUOp::Sub64Ext32 => (0xb919, true), // SGFR
1507
+ ALUOp::SubLogical32 => (0x1f, false), // SLR
1508
+ ALUOp::SubLogical64 => (0xb90b, true), // SLGR
1509
+ ALUOp::SubLogical64Ext32 => (0xb91b, true), // SLGFR
1510
+ ALUOp::Mul32 => (0xb252, true), // MSR
1511
+ ALUOp::Mul64 => (0xb90c, true), // MSGR
1512
+ ALUOp::Mul64Ext32 => (0xb91c, true), // MSGFR
1513
+ ALUOp::And32 => (0x14, false), // NR
1514
+ ALUOp::And64 => (0xb980, true), // NGR
1515
+ ALUOp::Orr32 => (0x16, false), // OR
1516
+ ALUOp::Orr64 => (0xb981, true), // OGR
1517
+ ALUOp::Xor32 => (0x17, false), // XR
1518
+ ALUOp::Xor64 => (0xb982, true), // XGR
1519
+ _ => unreachable!(),
1520
+ };
1521
+ if is_rre {
1522
+ put(sink, &enc_rre(opcode, rd.to_reg(), rm));
1523
+ } else {
1524
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
1525
+ }
1526
+ }
1527
+ &Inst::AluRX {
1528
+ alu_op,
1529
+ rd,
1530
+ ri,
1531
+ ref mem,
1532
+ } => {
1533
+ let rd = allocs.next_writable(rd);
1534
+ let ri = allocs.next(ri);
1535
+ debug_assert_eq!(rd.to_reg(), ri);
1536
+ let mem = mem.with_allocs(allocs);
1537
+
1538
+ let (opcode_rx, opcode_rxy) = match alu_op {
1539
+ ALUOp::Add32 => (Some(0x5a), Some(0xe35a)), // A(Y)
1540
+ ALUOp::Add32Ext16 => (Some(0x4a), Some(0xe37a)), // AH(Y)
1541
+ ALUOp::Add64 => (None, Some(0xe308)), // AG
1542
+ ALUOp::Add64Ext16 => (None, Some(0xe338)), // AGH
1543
+ ALUOp::Add64Ext32 => (None, Some(0xe318)), // AGF
1544
+ ALUOp::AddLogical32 => (Some(0x5e), Some(0xe35e)), // AL(Y)
1545
+ ALUOp::AddLogical64 => (None, Some(0xe30a)), // ALG
1546
+ ALUOp::AddLogical64Ext32 => (None, Some(0xe31a)), // ALGF
1547
+ ALUOp::Sub32 => (Some(0x5b), Some(0xe35b)), // S(Y)
1548
+ ALUOp::Sub32Ext16 => (Some(0x4b), Some(0xe37b)), // SH(Y)
1549
+ ALUOp::Sub64 => (None, Some(0xe309)), // SG
1550
+ ALUOp::Sub64Ext16 => (None, Some(0xe339)), // SGH
1551
+ ALUOp::Sub64Ext32 => (None, Some(0xe319)), // SGF
1552
+ ALUOp::SubLogical32 => (Some(0x5f), Some(0xe35f)), // SL(Y)
1553
+ ALUOp::SubLogical64 => (None, Some(0xe30b)), // SLG
1554
+ ALUOp::SubLogical64Ext32 => (None, Some(0xe31b)), // SLGF
1555
+ ALUOp::Mul32 => (Some(0x71), Some(0xe351)), // MS(Y)
1556
+ ALUOp::Mul32Ext16 => (Some(0x4c), Some(0xe37c)), // MH(Y)
1557
+ ALUOp::Mul64 => (None, Some(0xe30c)), // MSG
1558
+ ALUOp::Mul64Ext16 => (None, Some(0xe33c)), // MSH
1559
+ ALUOp::Mul64Ext32 => (None, Some(0xe31c)), // MSGF
1560
+ ALUOp::And32 => (Some(0x54), Some(0xe354)), // N(Y)
1561
+ ALUOp::And64 => (None, Some(0xe380)), // NG
1562
+ ALUOp::Orr32 => (Some(0x56), Some(0xe356)), // O(Y)
1563
+ ALUOp::Orr64 => (None, Some(0xe381)), // OG
1564
+ ALUOp::Xor32 => (Some(0x57), Some(0xe357)), // X(Y)
1565
+ ALUOp::Xor64 => (None, Some(0xe382)), // XG
1566
+ _ => unreachable!(),
1567
+ };
1568
+ let rd = rd.to_reg();
1569
+ mem_emit(
1570
+ rd, &mem, opcode_rx, opcode_rxy, None, true, sink, emit_info, state,
1571
+ );
1572
+ }
1573
+ &Inst::AluRSImm16 {
1574
+ alu_op,
1575
+ rd,
1576
+ ri,
1577
+ imm,
1578
+ } => {
1579
+ let rd = allocs.next_writable(rd);
1580
+ let ri = allocs.next(ri);
1581
+ debug_assert_eq!(rd.to_reg(), ri);
1582
+
1583
+ let opcode = match alu_op {
1584
+ ALUOp::Add32 => 0xa7a, // AHI
1585
+ ALUOp::Add64 => 0xa7b, // AGHI
1586
+ ALUOp::Mul32 => 0xa7c, // MHI
1587
+ ALUOp::Mul64 => 0xa7d, // MGHI
1588
+ _ => unreachable!(),
1589
+ };
1590
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm as u16));
1591
+ }
1592
+ &Inst::AluRSImm32 {
1593
+ alu_op,
1594
+ rd,
1595
+ ri,
1596
+ imm,
1597
+ } => {
1598
+ let rd = allocs.next_writable(rd);
1599
+ let ri = allocs.next(ri);
1600
+ debug_assert_eq!(rd.to_reg(), ri);
1601
+
1602
+ let opcode = match alu_op {
1603
+ ALUOp::Add32 => 0xc29, // AFI
1604
+ ALUOp::Add64 => 0xc28, // AGFI
1605
+ ALUOp::Mul32 => 0xc21, // MSFI
1606
+ ALUOp::Mul64 => 0xc20, // MSGFI
1607
+ _ => unreachable!(),
1608
+ };
1609
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm as u32));
1610
+ }
1611
+ &Inst::AluRUImm32 {
1612
+ alu_op,
1613
+ rd,
1614
+ ri,
1615
+ imm,
1616
+ } => {
1617
+ let rd = allocs.next_writable(rd);
1618
+ let ri = allocs.next(ri);
1619
+ debug_assert_eq!(rd.to_reg(), ri);
1620
+
1621
+ let opcode = match alu_op {
1622
+ ALUOp::AddLogical32 => 0xc2b, // ALFI
1623
+ ALUOp::AddLogical64 => 0xc2a, // ALGFI
1624
+ ALUOp::SubLogical32 => 0xc25, // SLFI
1625
+ ALUOp::SubLogical64 => 0xc24, // SLGFI
1626
+ _ => unreachable!(),
1627
+ };
1628
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm));
1629
+ }
1630
+ &Inst::AluRUImm16Shifted {
1631
+ alu_op,
1632
+ rd,
1633
+ ri,
1634
+ imm,
1635
+ } => {
1636
+ let rd = allocs.next_writable(rd);
1637
+ let ri = allocs.next(ri);
1638
+ debug_assert_eq!(rd.to_reg(), ri);
1639
+
1640
+ let opcode = match (alu_op, imm.shift) {
1641
+ (ALUOp::And32, 0) => 0xa57, // NILL
1642
+ (ALUOp::And32, 1) => 0xa56, // NILH
1643
+ (ALUOp::And64, 0) => 0xa57, // NILL
1644
+ (ALUOp::And64, 1) => 0xa56, // NILH
1645
+ (ALUOp::And64, 2) => 0xa55, // NIHL
1646
+ (ALUOp::And64, 3) => 0xa54, // NIHL
1647
+ (ALUOp::Orr32, 0) => 0xa5b, // OILL
1648
+ (ALUOp::Orr32, 1) => 0xa5a, // OILH
1649
+ (ALUOp::Orr64, 0) => 0xa5b, // OILL
1650
+ (ALUOp::Orr64, 1) => 0xa5a, // OILH
1651
+ (ALUOp::Orr64, 2) => 0xa59, // OIHL
1652
+ (ALUOp::Orr64, 3) => 0xa58, // OIHH
1653
+ _ => unreachable!(),
1654
+ };
1655
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm.bits));
1656
+ }
1657
+ &Inst::AluRUImm32Shifted {
1658
+ alu_op,
1659
+ rd,
1660
+ ri,
1661
+ imm,
1662
+ } => {
1663
+ let rd = allocs.next_writable(rd);
1664
+ let ri = allocs.next(ri);
1665
+ debug_assert_eq!(rd.to_reg(), ri);
1666
+
1667
+ let opcode = match (alu_op, imm.shift) {
1668
+ (ALUOp::And32, 0) => 0xc0b, // NILF
1669
+ (ALUOp::And64, 0) => 0xc0b, // NILF
1670
+ (ALUOp::And64, 1) => 0xc0a, // NIHF
1671
+ (ALUOp::Orr32, 0) => 0xc0d, // OILF
1672
+ (ALUOp::Orr64, 0) => 0xc0d, // OILF
1673
+ (ALUOp::Orr64, 1) => 0xc0c, // OILF
1674
+ (ALUOp::Xor32, 0) => 0xc07, // XILF
1675
+ (ALUOp::Xor64, 0) => 0xc07, // XILF
1676
+ (ALUOp::Xor64, 1) => 0xc06, // XILH
1677
+ _ => unreachable!(),
1678
+ };
1679
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm.bits));
1680
+ }
1681
+
1682
+ &Inst::SMulWide { rd, rn, rm } => {
1683
+ let rn = allocs.next(rn);
1684
+ let rm = allocs.next(rm);
1685
+ let rd1 = allocs.next_writable(rd.hi);
1686
+ let rd2 = allocs.next_writable(rd.lo);
1687
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1688
+
1689
+ let opcode = 0xb9ec; // MGRK
1690
+ put(sink, &enc_rrf_ab(opcode, rd1.to_reg(), rn, rm, 0));
1691
+ }
1692
+ &Inst::UMulWide { rd, ri, rn } => {
1693
+ let rn = allocs.next(rn);
1694
+ let rd1 = allocs.next_writable(rd.hi);
1695
+ let rd2 = allocs.next_writable(rd.lo);
1696
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1697
+ let ri = allocs.next(ri);
1698
+ debug_assert_eq!(rd2.to_reg(), ri);
1699
+
1700
+ let opcode = 0xb986; // MLGR
1701
+ put(sink, &enc_rre(opcode, rd1.to_reg(), rn));
1702
+ }
1703
+ &Inst::SDivMod32 { rd, ri, rn } => {
1704
+ let rn = allocs.next(rn);
1705
+ let rd1 = allocs.next_writable(rd.hi);
1706
+ let rd2 = allocs.next_writable(rd.lo);
1707
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1708
+ let ri = allocs.next(ri);
1709
+ debug_assert_eq!(rd2.to_reg(), ri);
1710
+
1711
+ let opcode = 0xb91d; // DSGFR
1712
+ let trap_code = TrapCode::IntegerDivisionByZero;
1713
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1714
+ }
1715
+ &Inst::SDivMod64 { rd, ri, rn } => {
1716
+ let rn = allocs.next(rn);
1717
+ let rd1 = allocs.next_writable(rd.hi);
1718
+ let rd2 = allocs.next_writable(rd.lo);
1719
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1720
+ let ri = allocs.next(ri);
1721
+ debug_assert_eq!(rd2.to_reg(), ri);
1722
+
1723
+ let opcode = 0xb90d; // DSGR
1724
+ let trap_code = TrapCode::IntegerDivisionByZero;
1725
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1726
+ }
1727
+ &Inst::UDivMod32 { rd, ri, rn } => {
1728
+ let rn = allocs.next(rn);
1729
+ let rd1 = allocs.next_writable(rd.hi);
1730
+ let rd2 = allocs.next_writable(rd.lo);
1731
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1732
+ let ri1 = allocs.next(ri.hi);
1733
+ let ri2 = allocs.next(ri.lo);
1734
+ debug_assert_eq!(rd1.to_reg(), ri1);
1735
+ debug_assert_eq!(rd2.to_reg(), ri2);
1736
+
1737
+ let opcode = 0xb997; // DLR
1738
+ let trap_code = TrapCode::IntegerDivisionByZero;
1739
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1740
+ }
1741
+ &Inst::UDivMod64 { rd, ri, rn } => {
1742
+ let rn = allocs.next(rn);
1743
+ let rd1 = allocs.next_writable(rd.hi);
1744
+ let rd2 = allocs.next_writable(rd.lo);
1745
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1746
+ let ri1 = allocs.next(ri.hi);
1747
+ let ri2 = allocs.next(ri.lo);
1748
+ debug_assert_eq!(rd1.to_reg(), ri1);
1749
+ debug_assert_eq!(rd2.to_reg(), ri2);
1750
+
1751
+ let opcode = 0xb987; // DLGR
1752
+ let trap_code = TrapCode::IntegerDivisionByZero;
1753
+ put_with_trap(sink, &enc_rre(opcode, rd1.to_reg(), rn), trap_code);
1754
+ }
1755
+ &Inst::Flogr { rd, rn } => {
1756
+ let rn = allocs.next(rn);
1757
+ let rd1 = allocs.next_writable(rd.hi);
1758
+ let rd2 = allocs.next_writable(rd.lo);
1759
+ debug_assert_valid_regpair!(rd1.to_reg(), rd2.to_reg());
1760
+
1761
+ let opcode = 0xb983; // FLOGR
1762
+ put(sink, &enc_rre(opcode, rd1.to_reg(), rn));
1763
+ }
1764
+
1765
+ &Inst::ShiftRR {
1766
+ shift_op,
1767
+ rd,
1768
+ rn,
1769
+ shift_imm,
1770
+ shift_reg,
1771
+ } => {
1772
+ let rd = allocs.next_writable(rd);
1773
+ let rn = allocs.next(rn);
1774
+ let shift_reg = allocs.next(shift_reg);
1775
+
1776
+ let opcode = match shift_op {
1777
+ ShiftOp::RotL32 => 0xeb1d, // RLL
1778
+ ShiftOp::RotL64 => 0xeb1c, // RLLG
1779
+ ShiftOp::LShL32 => 0xebdf, // SLLK (SLL ?)
1780
+ ShiftOp::LShL64 => 0xeb0d, // SLLG
1781
+ ShiftOp::LShR32 => 0xebde, // SRLK (SRL ?)
1782
+ ShiftOp::LShR64 => 0xeb0c, // SRLG
1783
+ ShiftOp::AShR32 => 0xebdc, // SRAK (SRA ?)
1784
+ ShiftOp::AShR64 => 0xeb0a, // SRAG
1785
+ };
1786
+ put(
1787
+ sink,
1788
+ &enc_rsy(opcode, rd.to_reg(), rn, shift_reg, shift_imm.into()),
1789
+ );
1790
+ }
1791
+
1792
+ &Inst::RxSBG {
1793
+ op,
1794
+ rd,
1795
+ ri,
1796
+ rn,
1797
+ start_bit,
1798
+ end_bit,
1799
+ rotate_amt,
1800
+ } => {
1801
+ let rd = allocs.next_writable(rd);
1802
+ let ri = allocs.next(ri);
1803
+ debug_assert_eq!(rd.to_reg(), ri);
1804
+ let rn = allocs.next(rn);
1805
+
1806
+ let opcode = match op {
1807
+ RxSBGOp::Insert => 0xec59, // RISBGN
1808
+ RxSBGOp::And => 0xec54, // RNSBG
1809
+ RxSBGOp::Or => 0xec56, // ROSBG
1810
+ RxSBGOp::Xor => 0xec57, // RXSBG
1811
+ };
1812
+ put(
1813
+ sink,
1814
+ &enc_rie_f(
1815
+ opcode,
1816
+ rd.to_reg(),
1817
+ rn,
1818
+ start_bit,
1819
+ end_bit,
1820
+ (rotate_amt as u8) & 63,
1821
+ ),
1822
+ );
1823
+ }
1824
+
1825
+ &Inst::RxSBGTest {
1826
+ op,
1827
+ rd,
1828
+ rn,
1829
+ start_bit,
1830
+ end_bit,
1831
+ rotate_amt,
1832
+ } => {
1833
+ let rd = allocs.next(rd);
1834
+ let rn = allocs.next(rn);
1835
+
1836
+ let opcode = match op {
1837
+ RxSBGOp::And => 0xec54, // RNSBG
1838
+ RxSBGOp::Or => 0xec56, // ROSBG
1839
+ RxSBGOp::Xor => 0xec57, // RXSBG
1840
+ _ => unreachable!(),
1841
+ };
1842
+ put(
1843
+ sink,
1844
+ &enc_rie_f(
1845
+ opcode,
1846
+ rd,
1847
+ rn,
1848
+ start_bit | 0x80,
1849
+ end_bit,
1850
+ (rotate_amt as u8) & 63,
1851
+ ),
1852
+ );
1853
+ }
1854
+
1855
+ &Inst::UnaryRR { op, rd, rn } => {
1856
+ let rd = allocs.next_writable(rd);
1857
+ let rn = allocs.next(rn);
1858
+
1859
+ match op {
1860
+ UnaryOp::Abs32 => {
1861
+ let opcode = 0x10; // LPR
1862
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
1863
+ }
1864
+ UnaryOp::Abs64 => {
1865
+ let opcode = 0xb900; // LPGR
1866
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1867
+ }
1868
+ UnaryOp::Abs64Ext32 => {
1869
+ let opcode = 0xb910; // LPGFR
1870
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1871
+ }
1872
+ UnaryOp::Neg32 => {
1873
+ let opcode = 0x13; // LCR
1874
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
1875
+ }
1876
+ UnaryOp::Neg64 => {
1877
+ let opcode = 0xb903; // LCGR
1878
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1879
+ }
1880
+ UnaryOp::Neg64Ext32 => {
1881
+ let opcode = 0xb913; // LCGFR
1882
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1883
+ }
1884
+ UnaryOp::PopcntByte => {
1885
+ let opcode = 0xb9e1; // POPCNT
1886
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rn, 0, 0));
1887
+ }
1888
+ UnaryOp::PopcntReg => {
1889
+ let opcode = 0xb9e1; // POPCNT
1890
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rn, 8, 0));
1891
+ }
1892
+ UnaryOp::BSwap32 => {
1893
+ let opcode = 0xb91f; // LRVR
1894
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1895
+ }
1896
+ UnaryOp::BSwap64 => {
1897
+ let opcode = 0xb90f; // LRVRG
1898
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1899
+ }
1900
+ }
1901
+ }
1902
+
1903
+ &Inst::Extend {
1904
+ rd,
1905
+ rn,
1906
+ signed,
1907
+ from_bits,
1908
+ to_bits,
1909
+ } => {
1910
+ let rd = allocs.next_writable(rd);
1911
+ let rn = allocs.next(rn);
1912
+
1913
+ let opcode = match (signed, from_bits, to_bits) {
1914
+ (_, 1, 32) => 0xb926, // LBR
1915
+ (_, 1, 64) => 0xb906, // LGBR
1916
+ (false, 8, 32) => 0xb994, // LLCR
1917
+ (false, 8, 64) => 0xb984, // LLGCR
1918
+ (true, 8, 32) => 0xb926, // LBR
1919
+ (true, 8, 64) => 0xb906, // LGBR
1920
+ (false, 16, 32) => 0xb995, // LLHR
1921
+ (false, 16, 64) => 0xb985, // LLGHR
1922
+ (true, 16, 32) => 0xb927, // LHR
1923
+ (true, 16, 64) => 0xb907, // LGHR
1924
+ (false, 32, 64) => 0xb916, // LLGFR
1925
+ (true, 32, 64) => 0xb914, // LGFR
1926
+ _ => panic!(
1927
+ "Unsupported extend combination: signed = {}, from_bits = {}, to_bits = {}",
1928
+ signed, from_bits, to_bits
1929
+ ),
1930
+ };
1931
+ put(sink, &enc_rre(opcode, rd.to_reg(), rn));
1932
+ }
1933
+
1934
+ &Inst::CmpRR { op, rn, rm } => {
1935
+ let rn = allocs.next(rn);
1936
+ let rm = allocs.next(rm);
1937
+
1938
+ let (opcode, is_rre) = match op {
1939
+ CmpOp::CmpS32 => (0x19, false), // CR
1940
+ CmpOp::CmpS64 => (0xb920, true), // CGR
1941
+ CmpOp::CmpS64Ext32 => (0xb930, true), // CGFR
1942
+ CmpOp::CmpL32 => (0x15, false), // CLR
1943
+ CmpOp::CmpL64 => (0xb921, true), // CLGR
1944
+ CmpOp::CmpL64Ext32 => (0xb931, true), // CLGFR
1945
+ _ => unreachable!(),
1946
+ };
1947
+ if is_rre {
1948
+ put(sink, &enc_rre(opcode, rn, rm));
1949
+ } else {
1950
+ put(sink, &enc_rr(opcode, rn, rm));
1951
+ }
1952
+ }
1953
+ &Inst::CmpRX { op, rn, ref mem } => {
1954
+ let rn = allocs.next(rn);
1955
+ let mem = mem.with_allocs(allocs);
1956
+
1957
+ let (opcode_rx, opcode_rxy, opcode_ril) = match op {
1958
+ CmpOp::CmpS32 => (Some(0x59), Some(0xe359), Some(0xc6d)), // C(Y), CRL
1959
+ CmpOp::CmpS32Ext16 => (Some(0x49), Some(0xe379), Some(0xc65)), // CH(Y), CHRL
1960
+ CmpOp::CmpS64 => (None, Some(0xe320), Some(0xc68)), // CG, CGRL
1961
+ CmpOp::CmpS64Ext16 => (None, Some(0xe334), Some(0xc64)), // CGH, CGHRL
1962
+ CmpOp::CmpS64Ext32 => (None, Some(0xe330), Some(0xc6c)), // CGF, CGFRL
1963
+ CmpOp::CmpL32 => (Some(0x55), Some(0xe355), Some(0xc6f)), // CL(Y), CLRL
1964
+ CmpOp::CmpL32Ext16 => (None, None, Some(0xc67)), // CLHRL
1965
+ CmpOp::CmpL64 => (None, Some(0xe321), Some(0xc6a)), // CLG, CLGRL
1966
+ CmpOp::CmpL64Ext16 => (None, None, Some(0xc66)), // CLGHRL
1967
+ CmpOp::CmpL64Ext32 => (None, Some(0xe331), Some(0xc6e)), // CLGF, CLGFRL
1968
+ };
1969
+ mem_emit(
1970
+ rn, &mem, opcode_rx, opcode_rxy, opcode_ril, true, sink, emit_info, state,
1971
+ );
1972
+ }
1973
+ &Inst::CmpRSImm16 { op, rn, imm } => {
1974
+ let rn = allocs.next(rn);
1975
+
1976
+ let opcode = match op {
1977
+ CmpOp::CmpS32 => 0xa7e, // CHI
1978
+ CmpOp::CmpS64 => 0xa7f, // CGHI
1979
+ _ => unreachable!(),
1980
+ };
1981
+ put(sink, &enc_ri_a(opcode, rn, imm as u16));
1982
+ }
1983
+ &Inst::CmpRSImm32 { op, rn, imm } => {
1984
+ let rn = allocs.next(rn);
1985
+
1986
+ let opcode = match op {
1987
+ CmpOp::CmpS32 => 0xc2d, // CFI
1988
+ CmpOp::CmpS64 => 0xc2c, // CGFI
1989
+ _ => unreachable!(),
1990
+ };
1991
+ put(sink, &enc_ril_a(opcode, rn, imm as u32));
1992
+ }
1993
+ &Inst::CmpRUImm32 { op, rn, imm } => {
1994
+ let rn = allocs.next(rn);
1995
+
1996
+ let opcode = match op {
1997
+ CmpOp::CmpL32 => 0xc2f, // CLFI
1998
+ CmpOp::CmpL64 => 0xc2e, // CLGFI
1999
+ _ => unreachable!(),
2000
+ };
2001
+ put(sink, &enc_ril_a(opcode, rn, imm));
2002
+ }
2003
+ &Inst::CmpTrapRR {
2004
+ op,
2005
+ rn,
2006
+ rm,
2007
+ cond,
2008
+ trap_code,
2009
+ } => {
2010
+ let rn = allocs.next(rn);
2011
+ let rm = allocs.next(rm);
2012
+
2013
+ let opcode = match op {
2014
+ CmpOp::CmpS32 => 0xb972, // CRT
2015
+ CmpOp::CmpS64 => 0xb960, // CGRT
2016
+ CmpOp::CmpL32 => 0xb973, // CLRT
2017
+ CmpOp::CmpL64 => 0xb961, // CLGRT
2018
+ _ => unreachable!(),
2019
+ };
2020
+ put_with_trap(
2021
+ sink,
2022
+ &enc_rrf_cde(opcode, rn, rm, cond.bits(), 0),
2023
+ trap_code,
2024
+ );
2025
+ }
2026
+ &Inst::CmpTrapRSImm16 {
2027
+ op,
2028
+ rn,
2029
+ imm,
2030
+ cond,
2031
+ trap_code,
2032
+ } => {
2033
+ let rn = allocs.next(rn);
2034
+
2035
+ let opcode = match op {
2036
+ CmpOp::CmpS32 => 0xec72, // CIT
2037
+ CmpOp::CmpS64 => 0xec70, // CGIT
2038
+ _ => unreachable!(),
2039
+ };
2040
+ put_with_trap(
2041
+ sink,
2042
+ &enc_rie_a(opcode, rn, imm as u16, cond.bits()),
2043
+ trap_code,
2044
+ );
2045
+ }
2046
+ &Inst::CmpTrapRUImm16 {
2047
+ op,
2048
+ rn,
2049
+ imm,
2050
+ cond,
2051
+ trap_code,
2052
+ } => {
2053
+ let rn = allocs.next(rn);
2054
+
2055
+ let opcode = match op {
2056
+ CmpOp::CmpL32 => 0xec73, // CLFIT
2057
+ CmpOp::CmpL64 => 0xec71, // CLGIT
2058
+ _ => unreachable!(),
2059
+ };
2060
+ put_with_trap(sink, &enc_rie_a(opcode, rn, imm, cond.bits()), trap_code);
2061
+ }
2062
+
2063
+ &Inst::AtomicRmw {
2064
+ alu_op,
2065
+ rd,
2066
+ rn,
2067
+ ref mem,
2068
+ } => {
2069
+ let rd = allocs.next_writable(rd);
2070
+ let rn = allocs.next(rn);
2071
+ let mem = mem.with_allocs(allocs);
2072
+
2073
+ let opcode = match alu_op {
2074
+ ALUOp::Add32 => 0xebf8, // LAA
2075
+ ALUOp::Add64 => 0xebe8, // LAAG
2076
+ ALUOp::AddLogical32 => 0xebfa, // LAAL
2077
+ ALUOp::AddLogical64 => 0xebea, // LAALG
2078
+ ALUOp::And32 => 0xebf4, // LAN
2079
+ ALUOp::And64 => 0xebe4, // LANG
2080
+ ALUOp::Orr32 => 0xebf6, // LAO
2081
+ ALUOp::Orr64 => 0xebe6, // LAOG
2082
+ ALUOp::Xor32 => 0xebf7, // LAX
2083
+ ALUOp::Xor64 => 0xebe7, // LAXG
2084
+ _ => unreachable!(),
2085
+ };
2086
+
2087
+ let rd = rd.to_reg();
2088
+ mem_rs_emit(
2089
+ rd,
2090
+ rn,
2091
+ &mem,
2092
+ None,
2093
+ Some(opcode),
2094
+ true,
2095
+ sink,
2096
+ emit_info,
2097
+ state,
2098
+ );
2099
+ }
2100
+ &Inst::Loop { ref body, cond } => {
2101
+ // This sequence is *one* instruction in the vcode, and is expanded only here at
2102
+ // emission time, because it requires branching to internal labels.
2103
+ let loop_label = sink.get_label();
2104
+ let done_label = sink.get_label();
2105
+
2106
+ // Emit label at the start of the loop.
2107
+ sink.bind_label(loop_label, &mut state.ctrl_plane);
2108
+
2109
+ for inst in (&body).into_iter() {
2110
+ match &inst {
2111
+ // Replace a CondBreak with a branch to done_label.
2112
+ &Inst::CondBreak { cond } => {
2113
+ let inst = Inst::OneWayCondBr {
2114
+ target: done_label,
2115
+ cond: *cond,
2116
+ };
2117
+ inst.emit_with_alloc_consumer(allocs, sink, emit_info, state);
2118
+ }
2119
+ _ => inst.emit_with_alloc_consumer(allocs, sink, emit_info, state),
2120
+ };
2121
+ }
2122
+
2123
+ let inst = Inst::OneWayCondBr {
2124
+ target: loop_label,
2125
+ cond,
2126
+ };
2127
+ inst.emit(&[], sink, emit_info, state);
2128
+
2129
+ // Emit label at the end of the loop.
2130
+ sink.bind_label(done_label, &mut state.ctrl_plane);
2131
+ }
2132
+ &Inst::CondBreak { .. } => unreachable!(), // Only valid inside a Loop.
2133
+ &Inst::AtomicCas32 {
2134
+ rd,
2135
+ ri,
2136
+ rn,
2137
+ ref mem,
2138
+ }
2139
+ | &Inst::AtomicCas64 {
2140
+ rd,
2141
+ ri,
2142
+ rn,
2143
+ ref mem,
2144
+ } => {
2145
+ let rd = allocs.next_writable(rd);
2146
+ let ri = allocs.next(ri);
2147
+ debug_assert_eq!(rd.to_reg(), ri);
2148
+ let rn = allocs.next(rn);
2149
+ let mem = mem.with_allocs(allocs);
2150
+
2151
+ let (opcode_rs, opcode_rsy) = match self {
2152
+ &Inst::AtomicCas32 { .. } => (Some(0xba), Some(0xeb14)), // CS(Y)
2153
+ &Inst::AtomicCas64 { .. } => (None, Some(0xeb30)), // CSG
2154
+ _ => unreachable!(),
2155
+ };
2156
+
2157
+ let rd = rd.to_reg();
2158
+ mem_rs_emit(
2159
+ rd, rn, &mem, opcode_rs, opcode_rsy, true, sink, emit_info, state,
2160
+ );
2161
+ }
2162
+ &Inst::Fence => {
2163
+ put(sink, &enc_e(0x07e0));
2164
+ }
2165
+
2166
+ &Inst::Load32 { rd, ref mem }
2167
+ | &Inst::Load32ZExt8 { rd, ref mem }
2168
+ | &Inst::Load32SExt8 { rd, ref mem }
2169
+ | &Inst::Load32ZExt16 { rd, ref mem }
2170
+ | &Inst::Load32SExt16 { rd, ref mem }
2171
+ | &Inst::Load64 { rd, ref mem }
2172
+ | &Inst::Load64ZExt8 { rd, ref mem }
2173
+ | &Inst::Load64SExt8 { rd, ref mem }
2174
+ | &Inst::Load64ZExt16 { rd, ref mem }
2175
+ | &Inst::Load64SExt16 { rd, ref mem }
2176
+ | &Inst::Load64ZExt32 { rd, ref mem }
2177
+ | &Inst::Load64SExt32 { rd, ref mem }
2178
+ | &Inst::LoadRev16 { rd, ref mem }
2179
+ | &Inst::LoadRev32 { rd, ref mem }
2180
+ | &Inst::LoadRev64 { rd, ref mem } => {
2181
+ let rd = allocs.next_writable(rd);
2182
+ let mem = mem.with_allocs(allocs);
2183
+
2184
+ let (opcode_rx, opcode_rxy, opcode_ril) = match self {
2185
+ &Inst::Load32 { .. } => (Some(0x58), Some(0xe358), Some(0xc4d)), // L(Y), LRL
2186
+ &Inst::Load32ZExt8 { .. } => (None, Some(0xe394), None), // LLC
2187
+ &Inst::Load32SExt8 { .. } => (None, Some(0xe376), None), // LB
2188
+ &Inst::Load32ZExt16 { .. } => (None, Some(0xe395), Some(0xc42)), // LLH, LLHRL
2189
+ &Inst::Load32SExt16 { .. } => (Some(0x48), Some(0xe378), Some(0xc45)), // LH(Y), LHRL
2190
+ &Inst::Load64 { .. } => (None, Some(0xe304), Some(0xc48)), // LG, LGRL
2191
+ &Inst::Load64ZExt8 { .. } => (None, Some(0xe390), None), // LLGC
2192
+ &Inst::Load64SExt8 { .. } => (None, Some(0xe377), None), // LGB
2193
+ &Inst::Load64ZExt16 { .. } => (None, Some(0xe391), Some(0xc46)), // LLGH, LLGHRL
2194
+ &Inst::Load64SExt16 { .. } => (None, Some(0xe315), Some(0xc44)), // LGH, LGHRL
2195
+ &Inst::Load64ZExt32 { .. } => (None, Some(0xe316), Some(0xc4e)), // LLGF, LLGFRL
2196
+ &Inst::Load64SExt32 { .. } => (None, Some(0xe314), Some(0xc4c)), // LGF, LGFRL
2197
+ &Inst::LoadRev16 { .. } => (None, Some(0xe31f), None), // LRVH
2198
+ &Inst::LoadRev32 { .. } => (None, Some(0xe31e), None), // LRV
2199
+ &Inst::LoadRev64 { .. } => (None, Some(0xe30f), None), // LRVG
2200
+ _ => unreachable!(),
2201
+ };
2202
+ let rd = rd.to_reg();
2203
+ mem_emit(
2204
+ rd, &mem, opcode_rx, opcode_rxy, opcode_ril, true, sink, emit_info, state,
2205
+ );
2206
+ }
2207
+
2208
+ &Inst::Store8 { rd, ref mem }
2209
+ | &Inst::Store16 { rd, ref mem }
2210
+ | &Inst::Store32 { rd, ref mem }
2211
+ | &Inst::Store64 { rd, ref mem }
2212
+ | &Inst::StoreRev16 { rd, ref mem }
2213
+ | &Inst::StoreRev32 { rd, ref mem }
2214
+ | &Inst::StoreRev64 { rd, ref mem } => {
2215
+ let rd = allocs.next(rd);
2216
+ let mem = mem.with_allocs(allocs);
2217
+
2218
+ let (opcode_rx, opcode_rxy, opcode_ril) = match self {
2219
+ &Inst::Store8 { .. } => (Some(0x42), Some(0xe372), None), // STC(Y)
2220
+ &Inst::Store16 { .. } => (Some(0x40), Some(0xe370), Some(0xc47)), // STH(Y), STHRL
2221
+ &Inst::Store32 { .. } => (Some(0x50), Some(0xe350), Some(0xc4f)), // ST(Y), STRL
2222
+ &Inst::Store64 { .. } => (None, Some(0xe324), Some(0xc4b)), // STG, STGRL
2223
+ &Inst::StoreRev16 { .. } => (None, Some(0xe33f), None), // STRVH
2224
+ &Inst::StoreRev32 { .. } => (None, Some(0xe33e), None), // STRV
2225
+ &Inst::StoreRev64 { .. } => (None, Some(0xe32f), None), // STRVG
2226
+ _ => unreachable!(),
2227
+ };
2228
+ mem_emit(
2229
+ rd, &mem, opcode_rx, opcode_rxy, opcode_ril, true, sink, emit_info, state,
2230
+ );
2231
+ }
2232
+ &Inst::StoreImm8 { imm, ref mem } => {
2233
+ let mem = mem.with_allocs(allocs);
2234
+
2235
+ let opcode_si = 0x92; // MVI
2236
+ let opcode_siy = 0xeb52; // MVIY
2237
+ mem_imm8_emit(
2238
+ imm, &mem, opcode_si, opcode_siy, true, sink, emit_info, state,
2239
+ );
2240
+ }
2241
+ &Inst::StoreImm16 { imm, ref mem }
2242
+ | &Inst::StoreImm32SExt16 { imm, ref mem }
2243
+ | &Inst::StoreImm64SExt16 { imm, ref mem } => {
2244
+ let mem = mem.with_allocs(allocs);
2245
+
2246
+ let opcode = match self {
2247
+ &Inst::StoreImm16 { .. } => 0xe544, // MVHHI
2248
+ &Inst::StoreImm32SExt16 { .. } => 0xe54c, // MVHI
2249
+ &Inst::StoreImm64SExt16 { .. } => 0xe548, // MVGHI
2250
+ _ => unreachable!(),
2251
+ };
2252
+ mem_imm16_emit(imm, &mem, opcode, true, sink, emit_info, state);
2253
+ }
2254
+ &Inst::Mvc {
2255
+ ref dst,
2256
+ ref src,
2257
+ len_minus_one,
2258
+ } => {
2259
+ let dst = dst.with_allocs(allocs);
2260
+ let src = src.with_allocs(allocs);
2261
+ let opcode = 0xd2; // MVC
2262
+ mem_mem_emit(&dst, &src, len_minus_one, opcode, true, sink, state);
2263
+ }
2264
+
2265
+ &Inst::LoadMultiple64 { rt, rt2, ref mem } => {
2266
+ let mem = mem.with_allocs(allocs);
2267
+
2268
+ let opcode = 0xeb04; // LMG
2269
+ let rt = rt.to_reg();
2270
+ let rt2 = rt2.to_reg();
2271
+ mem_rs_emit(
2272
+ rt,
2273
+ rt2,
2274
+ &mem,
2275
+ None,
2276
+ Some(opcode),
2277
+ true,
2278
+ sink,
2279
+ emit_info,
2280
+ state,
2281
+ );
2282
+ }
2283
+ &Inst::StoreMultiple64 { rt, rt2, ref mem } => {
2284
+ let mem = mem.with_allocs(allocs);
2285
+
2286
+ let opcode = 0xeb24; // STMG
2287
+ mem_rs_emit(
2288
+ rt,
2289
+ rt2,
2290
+ &mem,
2291
+ None,
2292
+ Some(opcode),
2293
+ true,
2294
+ sink,
2295
+ emit_info,
2296
+ state,
2297
+ );
2298
+ }
2299
+
2300
+ &Inst::LoadAddr { rd, ref mem } => {
2301
+ let rd = allocs.next_writable(rd);
2302
+ let mem = mem.with_allocs(allocs);
2303
+
2304
+ let opcode_rx = Some(0x41); // LA
2305
+ let opcode_rxy = Some(0xe371); // LAY
2306
+ let opcode_ril = Some(0xc00); // LARL
2307
+ let rd = rd.to_reg();
2308
+ mem_emit(
2309
+ rd, &mem, opcode_rx, opcode_rxy, opcode_ril, false, sink, emit_info, state,
2310
+ );
2311
+ }
2312
+
2313
+ &Inst::Mov64 { rd, rm } => {
2314
+ let rd = allocs.next_writable(rd);
2315
+ let rm = allocs.next(rm);
2316
+
2317
+ let opcode = 0xb904; // LGR
2318
+ put(sink, &enc_rre(opcode, rd.to_reg(), rm));
2319
+ }
2320
+ &Inst::MovPReg { rd, rm } => {
2321
+ let rm: Reg = rm.into();
2322
+ debug_assert!([regs::gpr(0), regs::gpr(14), regs::gpr(15)].contains(&rm));
2323
+ let rd = allocs.next_writable(rd);
2324
+ Inst::Mov64 { rd, rm }.emit(&[], sink, emit_info, state);
2325
+ }
2326
+ &Inst::Mov32 { rd, rm } => {
2327
+ let rd = allocs.next_writable(rd);
2328
+ let rm = allocs.next(rm);
2329
+
2330
+ let opcode = 0x18; // LR
2331
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
2332
+ }
2333
+ &Inst::Mov32Imm { rd, imm } => {
2334
+ let rd = allocs.next_writable(rd);
2335
+
2336
+ let opcode = 0xc09; // IILF
2337
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm));
2338
+ }
2339
+ &Inst::Mov32SImm16 { rd, imm } => {
2340
+ let rd = allocs.next_writable(rd);
2341
+
2342
+ let opcode = 0xa78; // LHI
2343
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm as u16));
2344
+ }
2345
+ &Inst::Mov64SImm16 { rd, imm } => {
2346
+ let rd = allocs.next_writable(rd);
2347
+
2348
+ let opcode = 0xa79; // LGHI
2349
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm as u16));
2350
+ }
2351
+ &Inst::Mov64SImm32 { rd, imm } => {
2352
+ let rd = allocs.next_writable(rd);
2353
+
2354
+ let opcode = 0xc01; // LGFI
2355
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm as u32));
2356
+ }
2357
+ &Inst::CMov32 { rd, cond, ri, rm } => {
2358
+ let rd = allocs.next_writable(rd);
2359
+ let ri = allocs.next(ri);
2360
+ debug_assert_eq!(rd.to_reg(), ri);
2361
+ let rm = allocs.next(rm);
2362
+
2363
+ let opcode = 0xb9f2; // LOCR
2364
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rm, cond.bits(), 0));
2365
+ }
2366
+ &Inst::CMov64 { rd, cond, ri, rm } => {
2367
+ let rd = allocs.next_writable(rd);
2368
+ let ri = allocs.next(ri);
2369
+ debug_assert_eq!(rd.to_reg(), ri);
2370
+ let rm = allocs.next(rm);
2371
+
2372
+ let opcode = 0xb9e2; // LOCGR
2373
+ put(sink, &enc_rrf_cde(opcode, rd.to_reg(), rm, cond.bits(), 0));
2374
+ }
2375
+ &Inst::CMov32SImm16 { rd, cond, ri, imm } => {
2376
+ let rd = allocs.next_writable(rd);
2377
+ let ri = allocs.next(ri);
2378
+ debug_assert_eq!(rd.to_reg(), ri);
2379
+
2380
+ let opcode = 0xec42; // LOCHI
2381
+ put(
2382
+ sink,
2383
+ &enc_rie_g(opcode, rd.to_reg(), imm as u16, cond.bits()),
2384
+ );
2385
+ }
2386
+ &Inst::CMov64SImm16 { rd, cond, ri, imm } => {
2387
+ let rd = allocs.next_writable(rd);
2388
+ let ri = allocs.next(ri);
2389
+ debug_assert_eq!(rd.to_reg(), ri);
2390
+
2391
+ let opcode = 0xec46; // LOCGHI
2392
+ put(
2393
+ sink,
2394
+ &enc_rie_g(opcode, rd.to_reg(), imm as u16, cond.bits()),
2395
+ );
2396
+ }
2397
+ &Inst::Mov64UImm16Shifted { rd, imm } => {
2398
+ let rd = allocs.next_writable(rd);
2399
+
2400
+ let opcode = match imm.shift {
2401
+ 0 => 0xa5f, // LLILL
2402
+ 1 => 0xa5e, // LLILH
2403
+ 2 => 0xa5d, // LLIHL
2404
+ 3 => 0xa5c, // LLIHH
2405
+ _ => unreachable!(),
2406
+ };
2407
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm.bits));
2408
+ }
2409
+ &Inst::Mov64UImm32Shifted { rd, imm } => {
2410
+ let rd = allocs.next_writable(rd);
2411
+
2412
+ let opcode = match imm.shift {
2413
+ 0 => 0xc0f, // LLILF
2414
+ 1 => 0xc0e, // LLIHF
2415
+ _ => unreachable!(),
2416
+ };
2417
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm.bits));
2418
+ }
2419
+ &Inst::Insert64UImm16Shifted { rd, ri, imm } => {
2420
+ let rd = allocs.next_writable(rd);
2421
+ let ri = allocs.next(ri);
2422
+ debug_assert_eq!(rd.to_reg(), ri);
2423
+
2424
+ let opcode = match imm.shift {
2425
+ 0 => 0xa53, // IILL
2426
+ 1 => 0xa52, // IILH
2427
+ 2 => 0xa51, // IIHL
2428
+ 3 => 0xa50, // IIHH
2429
+ _ => unreachable!(),
2430
+ };
2431
+ put(sink, &enc_ri_a(opcode, rd.to_reg(), imm.bits));
2432
+ }
2433
+ &Inst::Insert64UImm32Shifted { rd, ri, imm } => {
2434
+ let rd = allocs.next_writable(rd);
2435
+ let ri = allocs.next(ri);
2436
+ debug_assert_eq!(rd.to_reg(), ri);
2437
+
2438
+ let opcode = match imm.shift {
2439
+ 0 => 0xc09, // IILF
2440
+ 1 => 0xc08, // IIHF
2441
+ _ => unreachable!(),
2442
+ };
2443
+ put(sink, &enc_ril_a(opcode, rd.to_reg(), imm.bits));
2444
+ }
2445
+ &Inst::LoadAR { rd, ar } => {
2446
+ let rd = allocs.next_writable(rd);
2447
+ let opcode = 0xb24f; // EAR
2448
+ put(sink, &enc_rre(opcode, rd.to_reg(), gpr(ar)));
2449
+ }
2450
+
2451
+ &Inst::InsertAR { rd, ri, ar } => {
2452
+ let rd = allocs.next_writable(rd);
2453
+ let ri = allocs.next(ri);
2454
+ debug_assert_eq!(rd.to_reg(), ri);
2455
+
2456
+ let opcode = 0xb24f; // EAR
2457
+ put(sink, &enc_rre(opcode, rd.to_reg(), gpr(ar)));
2458
+ }
2459
+ &Inst::LoadSymbolReloc {
2460
+ rd,
2461
+ ref symbol_reloc,
2462
+ } => {
2463
+ let rd = allocs.next_writable(rd);
2464
+
2465
+ let opcode = 0xa75; // BRAS
2466
+ let reg = writable_spilltmp_reg().to_reg();
2467
+ put(sink, &enc_ri_b(opcode, reg, 12));
2468
+ let (reloc, name, offset) = match &**symbol_reloc {
2469
+ SymbolReloc::Absolute { name, offset } => (Reloc::Abs8, name, *offset),
2470
+ SymbolReloc::TlsGd { name } => (Reloc::S390xTlsGd64, name, 0),
2471
+ };
2472
+ sink.add_reloc(reloc, name, offset);
2473
+ sink.put8(0);
2474
+ let inst = Inst::Load64 {
2475
+ rd,
2476
+ mem: MemArg::reg(reg, MemFlags::trusted()),
2477
+ };
2478
+ inst.emit(&[], sink, emit_info, state);
2479
+ }
2480
+
2481
+ &Inst::FpuMove32 { rd, rn } => {
2482
+ let rd = allocs.next_writable(rd);
2483
+ let rn = allocs.next(rn);
2484
+
2485
+ if is_fpr(rd.to_reg()) && is_fpr(rn) {
2486
+ let opcode = 0x38; // LER
2487
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
2488
+ } else {
2489
+ let opcode = 0xe756; // VLR
2490
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, 0, 0, 0));
2491
+ }
2492
+ }
2493
+ &Inst::FpuMove64 { rd, rn } => {
2494
+ let rd = allocs.next_writable(rd);
2495
+ let rn = allocs.next(rn);
2496
+
2497
+ if is_fpr(rd.to_reg()) && is_fpr(rn) {
2498
+ let opcode = 0x28; // LDR
2499
+ put(sink, &enc_rr(opcode, rd.to_reg(), rn));
2500
+ } else {
2501
+ let opcode = 0xe756; // VLR
2502
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, 0, 0, 0));
2503
+ }
2504
+ }
2505
+ &Inst::FpuCMov32 { rd, cond, ri, rm } => {
2506
+ let rd = allocs.next_writable(rd);
2507
+ let ri = allocs.next(ri);
2508
+ debug_assert_eq!(rd.to_reg(), ri);
2509
+ let rm = allocs.next(rm);
2510
+
2511
+ if is_fpr(rd.to_reg()) && is_fpr(rm) {
2512
+ let opcode = 0xa74; // BCR
2513
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 2));
2514
+ let opcode = 0x38; // LER
2515
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
2516
+ } else {
2517
+ let opcode = 0xa74; // BCR
2518
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 6));
2519
+ let opcode = 0xe756; // VLR
2520
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rm, 0, 0, 0));
2521
+ }
2522
+ }
2523
+ &Inst::FpuCMov64 { rd, cond, ri, rm } => {
2524
+ let rd = allocs.next_writable(rd);
2525
+ let ri = allocs.next(ri);
2526
+ debug_assert_eq!(rd.to_reg(), ri);
2527
+ let rm = allocs.next(rm);
2528
+
2529
+ if is_fpr(rd.to_reg()) && is_fpr(rm) {
2530
+ let opcode = 0xa74; // BCR
2531
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 2));
2532
+ let opcode = 0x28; // LDR
2533
+ put(sink, &enc_rr(opcode, rd.to_reg(), rm));
2534
+ } else {
2535
+ let opcode = 0xa74; // BCR
2536
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 6));
2537
+ let opcode = 0xe756; // VLR
2538
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rm, 0, 0, 0));
2539
+ }
2540
+ }
2541
+ &Inst::LoadFpuConst32 { rd, const_data } => {
2542
+ let rd = allocs.next_writable(rd);
2543
+
2544
+ let opcode = 0xa75; // BRAS
2545
+ let reg = writable_spilltmp_reg().to_reg();
2546
+ put(sink, &enc_ri_b(opcode, reg, 8));
2547
+ sink.put4(const_data.swap_bytes());
2548
+ let inst = Inst::VecLoadLaneUndef {
2549
+ size: 32,
2550
+ rd,
2551
+ mem: MemArg::reg(reg, MemFlags::trusted()),
2552
+ lane_imm: 0,
2553
+ };
2554
+ inst.emit(&[], sink, emit_info, state);
2555
+ }
2556
+ &Inst::LoadFpuConst64 { rd, const_data } => {
2557
+ let rd = allocs.next_writable(rd);
2558
+
2559
+ let opcode = 0xa75; // BRAS
2560
+ let reg = writable_spilltmp_reg().to_reg();
2561
+ put(sink, &enc_ri_b(opcode, reg, 12));
2562
+ sink.put8(const_data.swap_bytes());
2563
+ let inst = Inst::VecLoadLaneUndef {
2564
+ size: 64,
2565
+ rd,
2566
+ mem: MemArg::reg(reg, MemFlags::trusted()),
2567
+ lane_imm: 0,
2568
+ };
2569
+ inst.emit(&[], sink, emit_info, state);
2570
+ }
2571
+ &Inst::FpuRR { fpu_op, rd, rn } => {
2572
+ let rd = allocs.next_writable(rd);
2573
+ let rn = allocs.next(rn);
2574
+
2575
+ let (opcode, m3, m4, m5, opcode_fpr) = match fpu_op {
2576
+ FPUOp1::Abs32 => (0xe7cc, 2, 8, 2, Some(0xb300)), // WFPSO, LPEBR
2577
+ FPUOp1::Abs64 => (0xe7cc, 3, 8, 2, Some(0xb310)), // WFPSO, LPDBR
2578
+ FPUOp1::Abs32x4 => (0xe7cc, 2, 0, 2, None), // VFPSO
2579
+ FPUOp1::Abs64x2 => (0xe7cc, 3, 0, 2, None), // VFPSO
2580
+ FPUOp1::Neg32 => (0xe7cc, 2, 8, 0, Some(0xb303)), // WFPSO, LCEBR
2581
+ FPUOp1::Neg64 => (0xe7cc, 3, 8, 0, Some(0xb313)), // WFPSO, LCDBR
2582
+ FPUOp1::Neg32x4 => (0xe7cc, 2, 0, 0, None), // VFPSO
2583
+ FPUOp1::Neg64x2 => (0xe7cc, 3, 0, 0, None), // VFPSO
2584
+ FPUOp1::NegAbs32 => (0xe7cc, 2, 8, 1, Some(0xb301)), // WFPSO, LNEBR
2585
+ FPUOp1::NegAbs64 => (0xe7cc, 3, 8, 1, Some(0xb311)), // WFPSO, LNDBR
2586
+ FPUOp1::NegAbs32x4 => (0xe7cc, 2, 0, 1, None), // VFPSO
2587
+ FPUOp1::NegAbs64x2 => (0xe7cc, 3, 0, 1, None), // VFPSO
2588
+ FPUOp1::Sqrt32 => (0xe7ce, 2, 8, 0, Some(0xb314)), // WFSQ, SQEBR
2589
+ FPUOp1::Sqrt64 => (0xe7ce, 3, 8, 0, Some(0xb315)), // WFSQ, SQDBR
2590
+ FPUOp1::Sqrt32x4 => (0xe7ce, 2, 0, 0, None), // VFSQ
2591
+ FPUOp1::Sqrt64x2 => (0xe7ce, 3, 0, 0, None), // VFSQ
2592
+ FPUOp1::Cvt32To64 => (0xe7c4, 2, 8, 0, Some(0xb304)), // WFLL, LDEBR
2593
+ FPUOp1::Cvt32x4To64x2 => (0xe7c4, 2, 0, 0, None), // VFLL
2594
+ };
2595
+ if m4 == 8 && is_fpr(rd.to_reg()) && is_fpr(rn) {
2596
+ put(sink, &enc_rre(opcode_fpr.unwrap(), rd.to_reg(), rn));
2597
+ } else {
2598
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, m3, m4, m5));
2599
+ }
2600
+ }
2601
+ &Inst::FpuRRR { fpu_op, rd, rn, rm } => {
2602
+ let rd = allocs.next_writable(rd);
2603
+ let rn = allocs.next(rn);
2604
+ let rm = allocs.next(rm);
2605
+
2606
+ let (opcode, m4, m5, m6, opcode_fpr) = match fpu_op {
2607
+ FPUOp2::Add32 => (0xe7e3, 2, 8, 0, Some(0xb30a)), // WFA, AEBR
2608
+ FPUOp2::Add64 => (0xe7e3, 3, 8, 0, Some(0xb31a)), // WFA, ADBR
2609
+ FPUOp2::Add32x4 => (0xe7e3, 2, 0, 0, None), // VFA
2610
+ FPUOp2::Add64x2 => (0xe7e3, 3, 0, 0, None), // VFA
2611
+ FPUOp2::Sub32 => (0xe7e2, 2, 8, 0, Some(0xb30b)), // WFS, SEBR
2612
+ FPUOp2::Sub64 => (0xe7e2, 3, 8, 0, Some(0xb31b)), // WFS, SDBR
2613
+ FPUOp2::Sub32x4 => (0xe7e2, 2, 0, 0, None), // VFS
2614
+ FPUOp2::Sub64x2 => (0xe7e2, 3, 0, 0, None), // VFS
2615
+ FPUOp2::Mul32 => (0xe7e7, 2, 8, 0, Some(0xb317)), // WFM, MEEBR
2616
+ FPUOp2::Mul64 => (0xe7e7, 3, 8, 0, Some(0xb31c)), // WFM, MDBR
2617
+ FPUOp2::Mul32x4 => (0xe7e7, 2, 0, 0, None), // VFM
2618
+ FPUOp2::Mul64x2 => (0xe7e7, 3, 0, 0, None), // VFM
2619
+ FPUOp2::Div32 => (0xe7e5, 2, 8, 0, Some(0xb30d)), // WFD, DEBR
2620
+ FPUOp2::Div64 => (0xe7e5, 3, 8, 0, Some(0xb31d)), // WFD, DDBR
2621
+ FPUOp2::Div32x4 => (0xe7e5, 2, 0, 0, None), // VFD
2622
+ FPUOp2::Div64x2 => (0xe7e5, 3, 0, 0, None), // VFD
2623
+ FPUOp2::Max32 => (0xe7ef, 2, 8, 1, None), // WFMAX
2624
+ FPUOp2::Max64 => (0xe7ef, 3, 8, 1, None), // WFMAX
2625
+ FPUOp2::Max32x4 => (0xe7ef, 2, 0, 1, None), // VFMAX
2626
+ FPUOp2::Max64x2 => (0xe7ef, 3, 0, 1, None), // VFMAX
2627
+ FPUOp2::Min32 => (0xe7ee, 2, 8, 1, None), // WFMIN
2628
+ FPUOp2::Min64 => (0xe7ee, 3, 8, 1, None), // WFMIN
2629
+ FPUOp2::Min32x4 => (0xe7ee, 2, 0, 1, None), // VFMIN
2630
+ FPUOp2::Min64x2 => (0xe7ee, 3, 0, 1, None), // VFMIN
2631
+ FPUOp2::MaxPseudo32 => (0xe7ef, 2, 8, 3, None), // WFMAX
2632
+ FPUOp2::MaxPseudo64 => (0xe7ef, 3, 8, 3, None), // WFMAX
2633
+ FPUOp2::MaxPseudo32x4 => (0xe7ef, 2, 0, 3, None), // VFMAX
2634
+ FPUOp2::MaxPseudo64x2 => (0xe7ef, 3, 0, 3, None), // VFMAX
2635
+ FPUOp2::MinPseudo32 => (0xe7ee, 2, 8, 3, None), // WFMIN
2636
+ FPUOp2::MinPseudo64 => (0xe7ee, 3, 8, 3, None), // WFMIN
2637
+ FPUOp2::MinPseudo32x4 => (0xe7ee, 2, 0, 3, None), // VFMIN
2638
+ FPUOp2::MinPseudo64x2 => (0xe7ee, 3, 0, 3, None), // VFMIN
2639
+ };
2640
+ if m5 == 8 && opcode_fpr.is_some() && rd.to_reg() == rn && is_fpr(rn) && is_fpr(rm)
2641
+ {
2642
+ put(sink, &enc_rre(opcode_fpr.unwrap(), rd.to_reg(), rm));
2643
+ } else {
2644
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, m5, m6));
2645
+ }
2646
+ }
2647
+ &Inst::FpuRRRR {
2648
+ fpu_op,
2649
+ rd,
2650
+ rn,
2651
+ rm,
2652
+ ra,
2653
+ } => {
2654
+ let rd = allocs.next_writable(rd);
2655
+ let rn = allocs.next(rn);
2656
+ let rm = allocs.next(rm);
2657
+ let ra = allocs.next(ra);
2658
+
2659
+ let (opcode, m5, m6, opcode_fpr) = match fpu_op {
2660
+ FPUOp3::MAdd32 => (0xe78f, 8, 2, Some(0xb30e)), // WFMA, MAEBR
2661
+ FPUOp3::MAdd64 => (0xe78f, 8, 3, Some(0xb31e)), // WFMA, MADBR
2662
+ FPUOp3::MAdd32x4 => (0xe78f, 0, 2, None), // VFMA
2663
+ FPUOp3::MAdd64x2 => (0xe78f, 0, 3, None), // VFMA
2664
+ FPUOp3::MSub32 => (0xe78e, 8, 2, Some(0xb30f)), // WFMS, MSEBR
2665
+ FPUOp3::MSub64 => (0xe78e, 8, 3, Some(0xb31f)), // WFMS, MSDBR
2666
+ FPUOp3::MSub32x4 => (0xe78e, 0, 2, None), // VFMS
2667
+ FPUOp3::MSub64x2 => (0xe78e, 0, 3, None), // VFMS
2668
+ };
2669
+ if m5 == 8 && rd.to_reg() == ra && is_fpr(rn) && is_fpr(rm) && is_fpr(ra) {
2670
+ put(sink, &enc_rrd(opcode_fpr.unwrap(), rd.to_reg(), rm, rn));
2671
+ } else {
2672
+ put(sink, &enc_vrr_e(opcode, rd.to_reg(), rn, rm, ra, m5, m6));
2673
+ }
2674
+ }
2675
+ &Inst::FpuRound { op, mode, rd, rn } => {
2676
+ let rd = allocs.next_writable(rd);
2677
+ let rn = allocs.next(rn);
2678
+
2679
+ let mode = match mode {
2680
+ FpuRoundMode::Current => 0,
2681
+ FpuRoundMode::ToNearest => 1,
2682
+ FpuRoundMode::ShorterPrecision => 3,
2683
+ FpuRoundMode::ToNearestTiesToEven => 4,
2684
+ FpuRoundMode::ToZero => 5,
2685
+ FpuRoundMode::ToPosInfinity => 6,
2686
+ FpuRoundMode::ToNegInfinity => 7,
2687
+ };
2688
+ let (opcode, m3, m4, opcode_fpr) = match op {
2689
+ FpuRoundOp::Cvt64To32 => (0xe7c5, 3, 8, Some(0xb344)), // WFLR, LEDBR(A)
2690
+ FpuRoundOp::Cvt64x2To32x4 => (0xe7c5, 3, 0, None), // VFLR
2691
+ FpuRoundOp::Round32 => (0xe7c7, 2, 8, Some(0xb357)), // WFI, FIEBR
2692
+ FpuRoundOp::Round64 => (0xe7c7, 3, 8, Some(0xb35f)), // WFI, FIDBR
2693
+ FpuRoundOp::Round32x4 => (0xe7c7, 2, 0, None), // VFI
2694
+ FpuRoundOp::Round64x2 => (0xe7c7, 3, 0, None), // VFI
2695
+ FpuRoundOp::ToSInt32 => (0xe7c2, 2, 8, None), // WCSFP
2696
+ FpuRoundOp::ToSInt64 => (0xe7c2, 3, 8, None), // WCSFP
2697
+ FpuRoundOp::ToUInt32 => (0xe7c0, 2, 8, None), // WCLFP
2698
+ FpuRoundOp::ToUInt64 => (0xe7c0, 3, 8, None), // WCLFP
2699
+ FpuRoundOp::ToSInt32x4 => (0xe7c2, 2, 0, None), // VCSFP
2700
+ FpuRoundOp::ToSInt64x2 => (0xe7c2, 3, 0, None), // VCSFP
2701
+ FpuRoundOp::ToUInt32x4 => (0xe7c0, 2, 0, None), // VCLFP
2702
+ FpuRoundOp::ToUInt64x2 => (0xe7c0, 3, 0, None), // VCLFP
2703
+ FpuRoundOp::FromSInt32 => (0xe7c3, 2, 8, None), // WCFPS
2704
+ FpuRoundOp::FromSInt64 => (0xe7c3, 3, 8, None), // WCFPS
2705
+ FpuRoundOp::FromUInt32 => (0xe7c1, 2, 8, None), // WCFPL
2706
+ FpuRoundOp::FromUInt64 => (0xe7c1, 3, 8, None), // WCFPL
2707
+ FpuRoundOp::FromSInt32x4 => (0xe7c3, 2, 0, None), // VCFPS
2708
+ FpuRoundOp::FromSInt64x2 => (0xe7c3, 3, 0, None), // VCFPS
2709
+ FpuRoundOp::FromUInt32x4 => (0xe7c1, 2, 0, None), // VCFPL
2710
+ FpuRoundOp::FromUInt64x2 => (0xe7c1, 3, 0, None), // VCFPL
2711
+ };
2712
+ if m4 == 8 && opcode_fpr.is_some() && is_fpr(rd.to_reg()) && is_fpr(rn) {
2713
+ put(
2714
+ sink,
2715
+ &enc_rrf_cde(opcode_fpr.unwrap(), rd.to_reg(), rn, mode, 0),
2716
+ );
2717
+ } else {
2718
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, m3, m4, mode));
2719
+ }
2720
+ }
2721
+ &Inst::FpuCmp32 { rn, rm } => {
2722
+ let rn = allocs.next(rn);
2723
+ let rm = allocs.next(rm);
2724
+
2725
+ if is_fpr(rn) && is_fpr(rm) {
2726
+ let opcode = 0xb309; // CEBR
2727
+ put(sink, &enc_rre(opcode, rn, rm));
2728
+ } else {
2729
+ let opcode = 0xe7cb; // WFC
2730
+ put(sink, &enc_vrr_a(opcode, rn, rm, 2, 0, 0));
2731
+ }
2732
+ }
2733
+ &Inst::FpuCmp64 { rn, rm } => {
2734
+ let rn = allocs.next(rn);
2735
+ let rm = allocs.next(rm);
2736
+
2737
+ if is_fpr(rn) && is_fpr(rm) {
2738
+ let opcode = 0xb319; // CDBR
2739
+ put(sink, &enc_rre(opcode, rn, rm));
2740
+ } else {
2741
+ let opcode = 0xe7cb; // WFC
2742
+ put(sink, &enc_vrr_a(opcode, rn, rm, 3, 0, 0));
2743
+ }
2744
+ }
2745
+
2746
+ &Inst::VecRRR { op, rd, rn, rm } => {
2747
+ let rd = allocs.next_writable(rd);
2748
+ let rn = allocs.next(rn);
2749
+ let rm = allocs.next(rm);
2750
+
2751
+ let (opcode, m4) = match op {
2752
+ VecBinaryOp::Add8x16 => (0xe7f3, 0), // VAB
2753
+ VecBinaryOp::Add16x8 => (0xe7f3, 1), // VAH
2754
+ VecBinaryOp::Add32x4 => (0xe7f3, 2), // VAF
2755
+ VecBinaryOp::Add64x2 => (0xe7f3, 3), // VAG
2756
+ VecBinaryOp::Add128 => (0xe7f3, 4), // VAQ
2757
+ VecBinaryOp::Sub8x16 => (0xe7f7, 0), // VSB
2758
+ VecBinaryOp::Sub16x8 => (0xe7f7, 1), // VSH
2759
+ VecBinaryOp::Sub32x4 => (0xe7f7, 2), // VSF
2760
+ VecBinaryOp::Sub64x2 => (0xe7f7, 3), // VSG
2761
+ VecBinaryOp::Sub128 => (0xe7f7, 4), // VSQ
2762
+ VecBinaryOp::Mul8x16 => (0xe7a2, 0), // VMLB
2763
+ VecBinaryOp::Mul16x8 => (0xe7a2, 1), // VMLHW
2764
+ VecBinaryOp::Mul32x4 => (0xe7a2, 2), // VMLF
2765
+ VecBinaryOp::UMulHi8x16 => (0xe7a1, 0), // VMLHB
2766
+ VecBinaryOp::UMulHi16x8 => (0xe7a1, 1), // VMLHH
2767
+ VecBinaryOp::UMulHi32x4 => (0xe7a1, 2), // VMLHF
2768
+ VecBinaryOp::SMulHi8x16 => (0xe7a3, 0), // VMHB
2769
+ VecBinaryOp::SMulHi16x8 => (0xe7a3, 1), // VMHH
2770
+ VecBinaryOp::SMulHi32x4 => (0xe7a3, 2), // VMHF
2771
+ VecBinaryOp::UMulEven8x16 => (0xe7a4, 0), // VMLEB
2772
+ VecBinaryOp::UMulEven16x8 => (0xe7a4, 1), // VMLEH
2773
+ VecBinaryOp::UMulEven32x4 => (0xe7a4, 2), // VMLEF
2774
+ VecBinaryOp::SMulEven8x16 => (0xe7a6, 0), // VMEB
2775
+ VecBinaryOp::SMulEven16x8 => (0xe7a6, 1), // VMEH
2776
+ VecBinaryOp::SMulEven32x4 => (0xe7a6, 2), // VMEF
2777
+ VecBinaryOp::UMulOdd8x16 => (0xe7a5, 0), // VMLOB
2778
+ VecBinaryOp::UMulOdd16x8 => (0xe7a5, 1), // VMLOH
2779
+ VecBinaryOp::UMulOdd32x4 => (0xe7a5, 2), // VMLOF
2780
+ VecBinaryOp::SMulOdd8x16 => (0xe7a7, 0), // VMOB
2781
+ VecBinaryOp::SMulOdd16x8 => (0xe7a7, 1), // VMOH
2782
+ VecBinaryOp::SMulOdd32x4 => (0xe7a7, 2), // VMOF
2783
+ VecBinaryOp::UMax8x16 => (0xe7fd, 0), // VMXLB
2784
+ VecBinaryOp::UMax16x8 => (0xe7fd, 1), // VMXLH
2785
+ VecBinaryOp::UMax32x4 => (0xe7fd, 2), // VMXLF
2786
+ VecBinaryOp::UMax64x2 => (0xe7fd, 3), // VMXLG
2787
+ VecBinaryOp::SMax8x16 => (0xe7ff, 0), // VMXB
2788
+ VecBinaryOp::SMax16x8 => (0xe7ff, 1), // VMXH
2789
+ VecBinaryOp::SMax32x4 => (0xe7ff, 2), // VMXF
2790
+ VecBinaryOp::SMax64x2 => (0xe7ff, 3), // VMXG
2791
+ VecBinaryOp::UMin8x16 => (0xe7fc, 0), // VMNLB
2792
+ VecBinaryOp::UMin16x8 => (0xe7fc, 1), // VMNLH
2793
+ VecBinaryOp::UMin32x4 => (0xe7fc, 2), // VMNLF
2794
+ VecBinaryOp::UMin64x2 => (0xe7fc, 3), // VMNLG
2795
+ VecBinaryOp::SMin8x16 => (0xe7fe, 0), // VMNB
2796
+ VecBinaryOp::SMin16x8 => (0xe7fe, 1), // VMNH
2797
+ VecBinaryOp::SMin32x4 => (0xe7fe, 2), // VMNF
2798
+ VecBinaryOp::SMin64x2 => (0xe7fe, 3), // VMNG
2799
+ VecBinaryOp::UAvg8x16 => (0xe7f0, 0), // VAVGLB
2800
+ VecBinaryOp::UAvg16x8 => (0xe7f0, 1), // VAVGLH
2801
+ VecBinaryOp::UAvg32x4 => (0xe7f0, 2), // VAVGLF
2802
+ VecBinaryOp::UAvg64x2 => (0xe7f0, 3), // VAVGLG
2803
+ VecBinaryOp::SAvg8x16 => (0xe7f2, 0), // VAVGB
2804
+ VecBinaryOp::SAvg16x8 => (0xe7f2, 1), // VAVGH
2805
+ VecBinaryOp::SAvg32x4 => (0xe7f2, 2), // VAVGF
2806
+ VecBinaryOp::SAvg64x2 => (0xe7f2, 3), // VAVGG
2807
+ VecBinaryOp::And128 => (0xe768, 0), // VN
2808
+ VecBinaryOp::Orr128 => (0xe76a, 0), // VO
2809
+ VecBinaryOp::Xor128 => (0xe76d, 0), // VX
2810
+ VecBinaryOp::NotAnd128 => (0xe76e, 0), // VNN
2811
+ VecBinaryOp::NotOrr128 => (0xe76b, 0), // VNO
2812
+ VecBinaryOp::NotXor128 => (0xe76c, 0), // VNX
2813
+ VecBinaryOp::AndNot128 => (0xe769, 0), // VNC
2814
+ VecBinaryOp::OrrNot128 => (0xe76f, 0), // VOC
2815
+ VecBinaryOp::BitPermute128 => (0xe785, 0), // VBPERM
2816
+ VecBinaryOp::LShLByByte128 => (0xe775, 0), // VSLB
2817
+ VecBinaryOp::LShRByByte128 => (0xe77d, 0), // VSRLB
2818
+ VecBinaryOp::AShRByByte128 => (0xe77f, 0), // VSRAB
2819
+ VecBinaryOp::LShLByBit128 => (0xe774, 0), // VSL
2820
+ VecBinaryOp::LShRByBit128 => (0xe77c, 0), // VSRL
2821
+ VecBinaryOp::AShRByBit128 => (0xe77e, 0), // VSRA
2822
+ VecBinaryOp::Pack16x8 => (0xe794, 1), // VPKH
2823
+ VecBinaryOp::Pack32x4 => (0xe794, 2), // VPKF
2824
+ VecBinaryOp::Pack64x2 => (0xe794, 3), // VPKG
2825
+ VecBinaryOp::PackUSat16x8 => (0xe795, 1), // VPKLSH
2826
+ VecBinaryOp::PackUSat32x4 => (0xe795, 2), // VPKLSF
2827
+ VecBinaryOp::PackUSat64x2 => (0xe795, 3), // VPKLSG
2828
+ VecBinaryOp::PackSSat16x8 => (0xe797, 1), // VPKSH
2829
+ VecBinaryOp::PackSSat32x4 => (0xe797, 2), // VPKSF
2830
+ VecBinaryOp::PackSSat64x2 => (0xe797, 3), // VPKSG
2831
+ VecBinaryOp::MergeLow8x16 => (0xe760, 0), // VMRLB
2832
+ VecBinaryOp::MergeLow16x8 => (0xe760, 1), // VMRLH
2833
+ VecBinaryOp::MergeLow32x4 => (0xe760, 2), // VMRLF
2834
+ VecBinaryOp::MergeLow64x2 => (0xe760, 3), // VMRLG
2835
+ VecBinaryOp::MergeHigh8x16 => (0xe761, 0), // VMRHB
2836
+ VecBinaryOp::MergeHigh16x8 => (0xe761, 1), // VMRHH
2837
+ VecBinaryOp::MergeHigh32x4 => (0xe761, 2), // VMRHF
2838
+ VecBinaryOp::MergeHigh64x2 => (0xe761, 3), // VMRHG
2839
+ };
2840
+
2841
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, 0, 0));
2842
+ }
2843
+ &Inst::VecRR { op, rd, rn } => {
2844
+ let rd = allocs.next_writable(rd);
2845
+ let rn = allocs.next(rn);
2846
+
2847
+ let (opcode, m3) = match op {
2848
+ VecUnaryOp::Abs8x16 => (0xe7df, 0), // VLPB
2849
+ VecUnaryOp::Abs16x8 => (0xe7df, 1), // VLPH
2850
+ VecUnaryOp::Abs32x4 => (0xe7df, 2), // VLPF
2851
+ VecUnaryOp::Abs64x2 => (0xe7df, 3), // VLPG
2852
+ VecUnaryOp::Neg8x16 => (0xe7de, 0), // VLCB
2853
+ VecUnaryOp::Neg16x8 => (0xe7de, 1), // VLCH
2854
+ VecUnaryOp::Neg32x4 => (0xe7de, 2), // VLCF
2855
+ VecUnaryOp::Neg64x2 => (0xe7de, 3), // VLCG
2856
+ VecUnaryOp::Popcnt8x16 => (0xe750, 0), // VPOPCTB
2857
+ VecUnaryOp::Popcnt16x8 => (0xe750, 1), // VPOPCTH
2858
+ VecUnaryOp::Popcnt32x4 => (0xe750, 2), // VPOPCTF
2859
+ VecUnaryOp::Popcnt64x2 => (0xe750, 3), // VPOPCTG
2860
+ VecUnaryOp::Clz8x16 => (0xe753, 0), // VCLZB
2861
+ VecUnaryOp::Clz16x8 => (0xe753, 1), // VCLZH
2862
+ VecUnaryOp::Clz32x4 => (0xe753, 2), // VCLZF
2863
+ VecUnaryOp::Clz64x2 => (0xe753, 3), // VCLZG
2864
+ VecUnaryOp::Ctz8x16 => (0xe752, 0), // VCTZB
2865
+ VecUnaryOp::Ctz16x8 => (0xe752, 1), // VCTZH
2866
+ VecUnaryOp::Ctz32x4 => (0xe752, 2), // VCTZF
2867
+ VecUnaryOp::Ctz64x2 => (0xe752, 3), // VCTZG
2868
+ VecUnaryOp::UnpackULow8x16 => (0xe7d4, 0), // VUPLLB
2869
+ VecUnaryOp::UnpackULow16x8 => (0xe7d4, 1), // VUPLLH
2870
+ VecUnaryOp::UnpackULow32x4 => (0xe7d4, 2), // VUPLLF
2871
+ VecUnaryOp::UnpackUHigh8x16 => (0xe7d5, 0), // VUPLHB
2872
+ VecUnaryOp::UnpackUHigh16x8 => (0xe7d5, 1), // VUPLHH
2873
+ VecUnaryOp::UnpackUHigh32x4 => (0xe7d5, 2), // VUPLHF
2874
+ VecUnaryOp::UnpackSLow8x16 => (0xe7d6, 0), // VUPLB
2875
+ VecUnaryOp::UnpackSLow16x8 => (0xe7d6, 1), // VUPLH
2876
+ VecUnaryOp::UnpackSLow32x4 => (0xe7d6, 2), // VUPLF
2877
+ VecUnaryOp::UnpackSHigh8x16 => (0xe7d7, 0), // VUPHB
2878
+ VecUnaryOp::UnpackSHigh16x8 => (0xe7d7, 1), // VUPHH
2879
+ VecUnaryOp::UnpackSHigh32x4 => (0xe7d7, 2), // VUPHF
2880
+ };
2881
+
2882
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, m3, 0, 0));
2883
+ }
2884
+ &Inst::VecShiftRR {
2885
+ shift_op,
2886
+ rd,
2887
+ rn,
2888
+ shift_imm,
2889
+ shift_reg,
2890
+ } => {
2891
+ let rd = allocs.next_writable(rd);
2892
+ let rn = allocs.next(rn);
2893
+ let shift_reg = allocs.next(shift_reg);
2894
+
2895
+ let (opcode, m4) = match shift_op {
2896
+ VecShiftOp::RotL8x16 => (0xe733, 0), // VERLLB
2897
+ VecShiftOp::RotL16x8 => (0xe733, 1), // VERLLH
2898
+ VecShiftOp::RotL32x4 => (0xe733, 2), // VERLLF
2899
+ VecShiftOp::RotL64x2 => (0xe733, 3), // VERLLG
2900
+ VecShiftOp::LShL8x16 => (0xe730, 0), // VESLB
2901
+ VecShiftOp::LShL16x8 => (0xe730, 1), // VESLH
2902
+ VecShiftOp::LShL32x4 => (0xe730, 2), // VESLF
2903
+ VecShiftOp::LShL64x2 => (0xe730, 3), // VESLG
2904
+ VecShiftOp::LShR8x16 => (0xe738, 0), // VESRLB
2905
+ VecShiftOp::LShR16x8 => (0xe738, 1), // VESRLH
2906
+ VecShiftOp::LShR32x4 => (0xe738, 2), // VESRLF
2907
+ VecShiftOp::LShR64x2 => (0xe738, 3), // VESRLG
2908
+ VecShiftOp::AShR8x16 => (0xe73a, 0), // VESRAB
2909
+ VecShiftOp::AShR16x8 => (0xe73a, 1), // VESRAH
2910
+ VecShiftOp::AShR32x4 => (0xe73a, 2), // VESRAF
2911
+ VecShiftOp::AShR64x2 => (0xe73a, 3), // VESRAG
2912
+ };
2913
+ put(
2914
+ sink,
2915
+ &enc_vrs_a(opcode, rd.to_reg(), shift_reg, shift_imm.into(), rn, m4),
2916
+ );
2917
+ }
2918
+ &Inst::VecSelect { rd, rn, rm, ra } => {
2919
+ let rd = allocs.next_writable(rd);
2920
+ let rn = allocs.next(rn);
2921
+ let rm = allocs.next(rm);
2922
+ let ra = allocs.next(ra);
2923
+
2924
+ let opcode = 0xe78d; // VSEL
2925
+ put(sink, &enc_vrr_e(opcode, rd.to_reg(), rn, rm, ra, 0, 0));
2926
+ }
2927
+ &Inst::VecPermute { rd, rn, rm, ra } => {
2928
+ let rd = allocs.next_writable(rd);
2929
+ let rn = allocs.next(rn);
2930
+ let rm = allocs.next(rm);
2931
+ let ra = allocs.next(ra);
2932
+
2933
+ let opcode = 0xe78c; // VPERM
2934
+ put(sink, &enc_vrr_e(opcode, rd.to_reg(), rn, rm, ra, 0, 0));
2935
+ }
2936
+ &Inst::VecPermuteDWImm {
2937
+ rd,
2938
+ rn,
2939
+ rm,
2940
+ idx1,
2941
+ idx2,
2942
+ } => {
2943
+ let rd = allocs.next_writable(rd);
2944
+ let rn = allocs.next(rn);
2945
+ let rm = allocs.next(rm);
2946
+ let m4 = (idx1 & 1) * 4 + (idx2 & 1);
2947
+
2948
+ let opcode = 0xe784; // VPDI
2949
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, 0, 0));
2950
+ }
2951
+ &Inst::VecIntCmp { op, rd, rn, rm } | &Inst::VecIntCmpS { op, rd, rn, rm } => {
2952
+ let rd = allocs.next_writable(rd);
2953
+ let rn = allocs.next(rn);
2954
+ let rm = allocs.next(rm);
2955
+
2956
+ let (opcode, m4) = match op {
2957
+ VecIntCmpOp::CmpEq8x16 => (0xe7f8, 0), // VCEQB
2958
+ VecIntCmpOp::CmpEq16x8 => (0xe7f8, 1), // VCEQH
2959
+ VecIntCmpOp::CmpEq32x4 => (0xe7f8, 2), // VCEQF
2960
+ VecIntCmpOp::CmpEq64x2 => (0xe7f8, 3), // VCEQG
2961
+ VecIntCmpOp::SCmpHi8x16 => (0xe7fb, 0), // VCHB
2962
+ VecIntCmpOp::SCmpHi16x8 => (0xe7fb, 1), // VCHH
2963
+ VecIntCmpOp::SCmpHi32x4 => (0xe7fb, 2), // VCHG
2964
+ VecIntCmpOp::SCmpHi64x2 => (0xe7fb, 3), // VCHG
2965
+ VecIntCmpOp::UCmpHi8x16 => (0xe7f9, 0), // VCHLB
2966
+ VecIntCmpOp::UCmpHi16x8 => (0xe7f9, 1), // VCHLH
2967
+ VecIntCmpOp::UCmpHi32x4 => (0xe7f9, 2), // VCHLG
2968
+ VecIntCmpOp::UCmpHi64x2 => (0xe7f9, 3), // VCHLG
2969
+ };
2970
+ let m5 = match self {
2971
+ &Inst::VecIntCmp { .. } => 0,
2972
+ &Inst::VecIntCmpS { .. } => 1,
2973
+ _ => unreachable!(),
2974
+ };
2975
+
2976
+ put(sink, &enc_vrr_b(opcode, rd.to_reg(), rn, rm, m4, m5));
2977
+ }
2978
+ &Inst::VecFloatCmp { op, rd, rn, rm } | &Inst::VecFloatCmpS { op, rd, rn, rm } => {
2979
+ let rd = allocs.next_writable(rd);
2980
+ let rn = allocs.next(rn);
2981
+ let rm = allocs.next(rm);
2982
+
2983
+ let (opcode, m4) = match op {
2984
+ VecFloatCmpOp::CmpEq32x4 => (0xe7e8, 2), // VFCESB
2985
+ VecFloatCmpOp::CmpEq64x2 => (0xe7e8, 3), // VFCEDB
2986
+ VecFloatCmpOp::CmpHi32x4 => (0xe7eb, 2), // VFCHSB
2987
+ VecFloatCmpOp::CmpHi64x2 => (0xe7eb, 3), // VFCHDB
2988
+ VecFloatCmpOp::CmpHiEq32x4 => (0xe7ea, 2), // VFCHESB
2989
+ VecFloatCmpOp::CmpHiEq64x2 => (0xe7ea, 3), // VFCHEDB
2990
+ };
2991
+ let m6 = match self {
2992
+ &Inst::VecFloatCmp { .. } => 0,
2993
+ &Inst::VecFloatCmpS { .. } => 1,
2994
+ _ => unreachable!(),
2995
+ };
2996
+
2997
+ put(sink, &enc_vrr_c(opcode, rd.to_reg(), rn, rm, m4, 0, m6));
2998
+ }
2999
+ &Inst::VecInt128SCmpHi { tmp, rn, rm } | &Inst::VecInt128UCmpHi { tmp, rn, rm } => {
3000
+ // Synthetic instruction to compare 128-bit values.
3001
+ // Sets CC 1 if rn > rm, sets a different CC otherwise.
3002
+ let tmp = allocs.next_writable(tmp);
3003
+ let rn = allocs.next(rn);
3004
+ let rm = allocs.next(rm);
3005
+
3006
+ // Use VECTOR ELEMENT COMPARE to compare the high parts.
3007
+ // Swap the inputs to get:
3008
+ // CC 1 if high(rn) > high(rm)
3009
+ // CC 2 if high(rn) < high(rm)
3010
+ // CC 0 if high(rn) == high(rm)
3011
+ let (opcode, m3) = match self {
3012
+ &Inst::VecInt128SCmpHi { .. } => (0xe7db, 3), // VECG
3013
+ &Inst::VecInt128UCmpHi { .. } => (0xe7d9, 3), // VECLG
3014
+ _ => unreachable!(),
3015
+ };
3016
+ put(sink, &enc_vrr_a(opcode, rm, rn, m3, 0, 0));
3017
+
3018
+ // If CC != 0, we'd done, so jump over the next instruction.
3019
+ let opcode = 0xa74; // BCR
3020
+ put(sink, &enc_ri_c(opcode, 7, 4 + 6));
3021
+
3022
+ // Otherwise, use VECTOR COMPARE HIGH LOGICAL.
3023
+ // Since we already know the high parts are equal, the CC
3024
+ // result will only depend on the low parts:
3025
+ // CC 1 if low(rn) > low(rm)
3026
+ // CC 3 if low(rn) <= low(rm)
3027
+ let inst = Inst::VecIntCmpS {
3028
+ op: VecIntCmpOp::UCmpHi64x2,
3029
+ // N.B.: This is the first write to tmp, and it happens
3030
+ // after all uses of rn and rm. If this were to ever
3031
+ // change, tmp would have to become an early-def.
3032
+ rd: tmp,
3033
+ rn,
3034
+ rm,
3035
+ };
3036
+ inst.emit(&[], sink, emit_info, state);
3037
+ }
3038
+
3039
+ &Inst::VecLoad { rd, ref mem }
3040
+ | &Inst::VecLoadRev { rd, ref mem }
3041
+ | &Inst::VecLoadByte16Rev { rd, ref mem }
3042
+ | &Inst::VecLoadByte32Rev { rd, ref mem }
3043
+ | &Inst::VecLoadByte64Rev { rd, ref mem }
3044
+ | &Inst::VecLoadElt16Rev { rd, ref mem }
3045
+ | &Inst::VecLoadElt32Rev { rd, ref mem }
3046
+ | &Inst::VecLoadElt64Rev { rd, ref mem } => {
3047
+ let rd = allocs.next_writable(rd);
3048
+ let mem = mem.with_allocs(allocs);
3049
+
3050
+ let (opcode, m3) = match self {
3051
+ &Inst::VecLoad { .. } => (0xe706, 0), // VL
3052
+ &Inst::VecLoadRev { .. } => (0xe606, 4), // VLBRQ
3053
+ &Inst::VecLoadByte16Rev { .. } => (0xe606, 1), // VLBRH
3054
+ &Inst::VecLoadByte32Rev { .. } => (0xe606, 2), // VLBRF
3055
+ &Inst::VecLoadByte64Rev { .. } => (0xe606, 3), // VLBRG
3056
+ &Inst::VecLoadElt16Rev { .. } => (0xe607, 1), // VLERH
3057
+ &Inst::VecLoadElt32Rev { .. } => (0xe607, 2), // VLERF
3058
+ &Inst::VecLoadElt64Rev { .. } => (0xe607, 3), // VLERG
3059
+ _ => unreachable!(),
3060
+ };
3061
+ mem_vrx_emit(rd.to_reg(), &mem, opcode, m3, true, sink, emit_info, state);
3062
+ }
3063
+ &Inst::VecStore { rd, ref mem }
3064
+ | &Inst::VecStoreRev { rd, ref mem }
3065
+ | &Inst::VecStoreByte16Rev { rd, ref mem }
3066
+ | &Inst::VecStoreByte32Rev { rd, ref mem }
3067
+ | &Inst::VecStoreByte64Rev { rd, ref mem }
3068
+ | &Inst::VecStoreElt16Rev { rd, ref mem }
3069
+ | &Inst::VecStoreElt32Rev { rd, ref mem }
3070
+ | &Inst::VecStoreElt64Rev { rd, ref mem } => {
3071
+ let rd = allocs.next(rd);
3072
+ let mem = mem.with_allocs(allocs);
3073
+
3074
+ let (opcode, m3) = match self {
3075
+ &Inst::VecStore { .. } => (0xe70e, 0), // VST
3076
+ &Inst::VecStoreRev { .. } => (0xe60e, 4), // VSTBRQ
3077
+ &Inst::VecStoreByte16Rev { .. } => (0xe60e, 1), // VSTBRH
3078
+ &Inst::VecStoreByte32Rev { .. } => (0xe60e, 2), // VSTBRF
3079
+ &Inst::VecStoreByte64Rev { .. } => (0xe60e, 3), // VSTBRG
3080
+ &Inst::VecStoreElt16Rev { .. } => (0xe60f, 1), // VSTERH
3081
+ &Inst::VecStoreElt32Rev { .. } => (0xe60f, 2), // VSTERF
3082
+ &Inst::VecStoreElt64Rev { .. } => (0xe60f, 3), // VSTERG
3083
+ _ => unreachable!(),
3084
+ };
3085
+ mem_vrx_emit(rd, &mem, opcode, m3, true, sink, emit_info, state);
3086
+ }
3087
+ &Inst::VecLoadReplicate { size, rd, ref mem }
3088
+ | &Inst::VecLoadReplicateRev { size, rd, ref mem } => {
3089
+ let rd = allocs.next_writable(rd);
3090
+ let mem = mem.with_allocs(allocs);
3091
+
3092
+ let (opcode, m3) = match (self, size) {
3093
+ (&Inst::VecLoadReplicate { .. }, 8) => (0xe705, 0), // VLREPB
3094
+ (&Inst::VecLoadReplicate { .. }, 16) => (0xe705, 1), // VLREPH
3095
+ (&Inst::VecLoadReplicate { .. }, 32) => (0xe705, 2), // VLREPF
3096
+ (&Inst::VecLoadReplicate { .. }, 64) => (0xe705, 3), // VLREPG
3097
+ (&Inst::VecLoadReplicateRev { .. }, 16) => (0xe605, 1), // VLREPBRH
3098
+ (&Inst::VecLoadReplicateRev { .. }, 32) => (0xe605, 2), // VLREPBRF
3099
+ (&Inst::VecLoadReplicateRev { .. }, 64) => (0xe605, 3), // VLREPBRG
3100
+ _ => unreachable!(),
3101
+ };
3102
+ mem_vrx_emit(rd.to_reg(), &mem, opcode, m3, true, sink, emit_info, state);
3103
+ }
3104
+
3105
+ &Inst::VecMov { rd, rn } => {
3106
+ let rd = allocs.next_writable(rd);
3107
+ let rn = allocs.next(rn);
3108
+
3109
+ let opcode = 0xe756; // VLR
3110
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rn, 0, 0, 0));
3111
+ }
3112
+ &Inst::VecCMov { rd, cond, ri, rm } => {
3113
+ let rd = allocs.next_writable(rd);
3114
+ let ri = allocs.next(ri);
3115
+ debug_assert_eq!(rd.to_reg(), ri);
3116
+ let rm = allocs.next(rm);
3117
+
3118
+ let opcode = 0xa74; // BCR
3119
+ put(sink, &enc_ri_c(opcode, cond.invert().bits(), 4 + 6));
3120
+ let opcode = 0xe756; // VLR
3121
+ put(sink, &enc_vrr_a(opcode, rd.to_reg(), rm, 0, 0, 0));
3122
+ }
3123
+ &Inst::MovToVec128 { rd, rn, rm } => {
3124
+ let rd = allocs.next_writable(rd);
3125
+ let rn = allocs.next(rn);
3126
+ let rm = allocs.next(rm);
3127
+
3128
+ let opcode = 0xe762; // VLVGP
3129
+ put(sink, &enc_vrr_f(opcode, rd.to_reg(), rn, rm));
3130
+ }
3131
+ &Inst::VecLoadConst { rd, const_data } => {
3132
+ let rd = allocs.next_writable(rd);
3133
+
3134
+ let opcode = 0xa75; // BRAS
3135
+ let reg = writable_spilltmp_reg().to_reg();
3136
+ put(sink, &enc_ri_b(opcode, reg, 20));
3137
+ for i in const_data.to_be_bytes().iter() {
3138
+ sink.put1(*i);
3139
+ }
3140
+ let inst = Inst::VecLoad {
3141
+ rd,
3142
+ mem: MemArg::reg(reg, MemFlags::trusted()),
3143
+ };
3144
+ inst.emit(&[], sink, emit_info, state);
3145
+ }
3146
+ &Inst::VecLoadConstReplicate {
3147
+ size,
3148
+ rd,
3149
+ const_data,
3150
+ } => {
3151
+ let rd = allocs.next_writable(rd);
3152
+
3153
+ let opcode = 0xa75; // BRAS
3154
+ let reg = writable_spilltmp_reg().to_reg();
3155
+ put(sink, &enc_ri_b(opcode, reg, (4 + size / 8) as i32));
3156
+ for i in 0..size / 8 {
3157
+ sink.put1((const_data >> (size - 8 - 8 * i)) as u8);
3158
+ }
3159
+ let inst = Inst::VecLoadReplicate {
3160
+ size,
3161
+ rd,
3162
+ mem: MemArg::reg(reg, MemFlags::trusted()),
3163
+ };
3164
+ inst.emit(&[], sink, emit_info, state);
3165
+ }
3166
+ &Inst::VecImmByteMask { rd, mask } => {
3167
+ let rd = allocs.next_writable(rd);
3168
+ let opcode = 0xe744; // VGBM
3169
+ put(sink, &enc_vri_a(opcode, rd.to_reg(), mask, 0));
3170
+ }
3171
+ &Inst::VecImmBitMask {
3172
+ size,
3173
+ rd,
3174
+ start_bit,
3175
+ end_bit,
3176
+ } => {
3177
+ let rd = allocs.next_writable(rd);
3178
+ let (opcode, m4) = match size {
3179
+ 8 => (0xe746, 0), // VGMB
3180
+ 16 => (0xe746, 1), // VGMH
3181
+ 32 => (0xe746, 2), // VGMF
3182
+ 64 => (0xe746, 3), // VGMG
3183
+ _ => unreachable!(),
3184
+ };
3185
+ put(
3186
+ sink,
3187
+ &enc_vri_b(opcode, rd.to_reg(), start_bit, end_bit, m4),
3188
+ );
3189
+ }
3190
+ &Inst::VecImmReplicate { size, rd, imm } => {
3191
+ let rd = allocs.next_writable(rd);
3192
+ let (opcode, m3) = match size {
3193
+ 8 => (0xe745, 0), // VREPIB
3194
+ 16 => (0xe745, 1), // VREPIH
3195
+ 32 => (0xe745, 2), // VREPIF
3196
+ 64 => (0xe745, 3), // VREPIG
3197
+ _ => unreachable!(),
3198
+ };
3199
+ put(sink, &enc_vri_a(opcode, rd.to_reg(), imm as u16, m3));
3200
+ }
3201
+ &Inst::VecLoadLane {
3202
+ size,
3203
+ rd,
3204
+ ri,
3205
+ ref mem,
3206
+ lane_imm,
3207
+ }
3208
+ | &Inst::VecLoadLaneRev {
3209
+ size,
3210
+ rd,
3211
+ ri,
3212
+ ref mem,
3213
+ lane_imm,
3214
+ } => {
3215
+ let rd = allocs.next_writable(rd);
3216
+ let ri = allocs.next(ri);
3217
+ debug_assert_eq!(rd.to_reg(), ri);
3218
+ let mem = mem.with_allocs(allocs);
3219
+
3220
+ let opcode_vrx = match (self, size) {
3221
+ (&Inst::VecLoadLane { .. }, 8) => 0xe700, // VLEB
3222
+ (&Inst::VecLoadLane { .. }, 16) => 0xe701, // VLEH
3223
+ (&Inst::VecLoadLane { .. }, 32) => 0xe703, // VLEF
3224
+ (&Inst::VecLoadLane { .. }, 64) => 0xe702, // VLEG
3225
+ (&Inst::VecLoadLaneRev { .. }, 16) => 0xe601, // VLEBRH
3226
+ (&Inst::VecLoadLaneRev { .. }, 32) => 0xe603, // VLEBRF
3227
+ (&Inst::VecLoadLaneRev { .. }, 64) => 0xe602, // VLEBRG
3228
+ _ => unreachable!(),
3229
+ };
3230
+
3231
+ let rd = rd.to_reg();
3232
+ mem_vrx_emit(
3233
+ rd,
3234
+ &mem,
3235
+ opcode_vrx,
3236
+ lane_imm.into(),
3237
+ true,
3238
+ sink,
3239
+ emit_info,
3240
+ state,
3241
+ );
3242
+ }
3243
+ &Inst::VecLoadLaneUndef {
3244
+ size,
3245
+ rd,
3246
+ ref mem,
3247
+ lane_imm,
3248
+ }
3249
+ | &Inst::VecLoadLaneRevUndef {
3250
+ size,
3251
+ rd,
3252
+ ref mem,
3253
+ lane_imm,
3254
+ } => {
3255
+ let rd = allocs.next_writable(rd);
3256
+ let mem = mem.with_allocs(allocs);
3257
+
3258
+ let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
3259
+ (&Inst::VecLoadLaneUndef { .. }, 8) => (0xe700, None, None), // VLEB
3260
+ (&Inst::VecLoadLaneUndef { .. }, 16) => (0xe701, None, None), // VLEH
3261
+ (&Inst::VecLoadLaneUndef { .. }, 32) => (0xe703, Some(0x78), Some(0xed64)), // VLEF, LE(Y)
3262
+ (&Inst::VecLoadLaneUndef { .. }, 64) => (0xe702, Some(0x68), Some(0xed65)), // VLEG, LD(Y)
3263
+ (&Inst::VecLoadLaneRevUndef { .. }, 16) => (0xe601, None, None), // VLEBRH
3264
+ (&Inst::VecLoadLaneRevUndef { .. }, 32) => (0xe603, None, None), // VLEBRF
3265
+ (&Inst::VecLoadLaneRevUndef { .. }, 64) => (0xe602, None, None), // VLEBRG
3266
+ _ => unreachable!(),
3267
+ };
3268
+
3269
+ let rd = rd.to_reg();
3270
+ if lane_imm == 0 && is_fpr(rd) && opcode_rx.is_some() {
3271
+ mem_emit(
3272
+ rd, &mem, opcode_rx, opcode_rxy, None, true, sink, emit_info, state,
3273
+ );
3274
+ } else {
3275
+ mem_vrx_emit(
3276
+ rd,
3277
+ &mem,
3278
+ opcode_vrx,
3279
+ lane_imm.into(),
3280
+ true,
3281
+ sink,
3282
+ emit_info,
3283
+ state,
3284
+ );
3285
+ }
3286
+ }
3287
+ &Inst::VecStoreLane {
3288
+ size,
3289
+ rd,
3290
+ ref mem,
3291
+ lane_imm,
3292
+ }
3293
+ | &Inst::VecStoreLaneRev {
3294
+ size,
3295
+ rd,
3296
+ ref mem,
3297
+ lane_imm,
3298
+ } => {
3299
+ let rd = allocs.next(rd);
3300
+ let mem = mem.with_allocs(allocs);
3301
+
3302
+ let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
3303
+ (&Inst::VecStoreLane { .. }, 8) => (0xe708, None, None), // VSTEB
3304
+ (&Inst::VecStoreLane { .. }, 16) => (0xe709, None, None), // VSTEH
3305
+ (&Inst::VecStoreLane { .. }, 32) => (0xe70b, Some(0x70), Some(0xed66)), // VSTEF, STE(Y)
3306
+ (&Inst::VecStoreLane { .. }, 64) => (0xe70a, Some(0x60), Some(0xed67)), // VSTEG, STD(Y)
3307
+ (&Inst::VecStoreLaneRev { .. }, 16) => (0xe609, None, None), // VSTEBRH
3308
+ (&Inst::VecStoreLaneRev { .. }, 32) => (0xe60b, None, None), // VSTEBRF
3309
+ (&Inst::VecStoreLaneRev { .. }, 64) => (0xe60a, None, None), // VSTEBRG
3310
+ _ => unreachable!(),
3311
+ };
3312
+
3313
+ if lane_imm == 0 && is_fpr(rd) && opcode_rx.is_some() {
3314
+ mem_emit(
3315
+ rd, &mem, opcode_rx, opcode_rxy, None, true, sink, emit_info, state,
3316
+ );
3317
+ } else {
3318
+ mem_vrx_emit(
3319
+ rd,
3320
+ &mem,
3321
+ opcode_vrx,
3322
+ lane_imm.into(),
3323
+ true,
3324
+ sink,
3325
+ emit_info,
3326
+ state,
3327
+ );
3328
+ }
3329
+ }
3330
+ &Inst::VecInsertLane {
3331
+ size,
3332
+ rd,
3333
+ ri,
3334
+ rn,
3335
+ lane_imm,
3336
+ lane_reg,
3337
+ } => {
3338
+ let rd = allocs.next_writable(rd);
3339
+ let ri = allocs.next(ri);
3340
+ debug_assert_eq!(rd.to_reg(), ri);
3341
+ let rn = allocs.next(rn);
3342
+ let lane_reg = allocs.next(lane_reg);
3343
+
3344
+ let (opcode_vrs, m4) = match size {
3345
+ 8 => (0xe722, 0), // VLVGB
3346
+ 16 => (0xe722, 1), // VLVGH
3347
+ 32 => (0xe722, 2), // VLVGF
3348
+ 64 => (0xe722, 3), // VLVGG
3349
+ _ => unreachable!(),
3350
+ };
3351
+ put(
3352
+ sink,
3353
+ &enc_vrs_b(opcode_vrs, rd.to_reg(), lane_reg, lane_imm.into(), rn, m4),
3354
+ );
3355
+ }
3356
+ &Inst::VecInsertLaneUndef {
3357
+ size,
3358
+ rd,
3359
+ rn,
3360
+ lane_imm,
3361
+ lane_reg,
3362
+ } => {
3363
+ let rd = allocs.next_writable(rd);
3364
+ let rn = allocs.next(rn);
3365
+ let lane_reg = allocs.next(lane_reg);
3366
+
3367
+ let (opcode_vrs, m4, opcode_rre) = match size {
3368
+ 8 => (0xe722, 0, None), // VLVGB
3369
+ 16 => (0xe722, 1, None), // VLVGH
3370
+ 32 => (0xe722, 2, None), // VLVGF
3371
+ 64 => (0xe722, 3, Some(0xb3c1)), // VLVGG, LDGR
3372
+ _ => unreachable!(),
3373
+ };
3374
+ if opcode_rre.is_some()
3375
+ && lane_imm == 0
3376
+ && lane_reg == zero_reg()
3377
+ && is_fpr(rd.to_reg())
3378
+ {
3379
+ put(sink, &enc_rre(opcode_rre.unwrap(), rd.to_reg(), rn));
3380
+ } else {
3381
+ put(
3382
+ sink,
3383
+ &enc_vrs_b(opcode_vrs, rd.to_reg(), lane_reg, lane_imm.into(), rn, m4),
3384
+ );
3385
+ }
3386
+ }
3387
+ &Inst::VecExtractLane {
3388
+ size,
3389
+ rd,
3390
+ rn,
3391
+ lane_imm,
3392
+ lane_reg,
3393
+ } => {
3394
+ let rd = allocs.next_writable(rd);
3395
+ let rn = allocs.next(rn);
3396
+ let lane_reg = allocs.next(lane_reg);
3397
+
3398
+ let (opcode_vrs, m4, opcode_rre) = match size {
3399
+ 8 => (0xe721, 0, None), // VLGVB
3400
+ 16 => (0xe721, 1, None), // VLGVH
3401
+ 32 => (0xe721, 2, None), // VLGVF
3402
+ 64 => (0xe721, 3, Some(0xb3cd)), // VLGVG, LGDR
3403
+ _ => unreachable!(),
3404
+ };
3405
+ if opcode_rre.is_some() && lane_imm == 0 && lane_reg == zero_reg() && is_fpr(rn) {
3406
+ put(sink, &enc_rre(opcode_rre.unwrap(), rd.to_reg(), rn));
3407
+ } else {
3408
+ put(
3409
+ sink,
3410
+ &enc_vrs_c(opcode_vrs, rd.to_reg(), lane_reg, lane_imm.into(), rn, m4),
3411
+ );
3412
+ }
3413
+ }
3414
+ &Inst::VecInsertLaneImm {
3415
+ size,
3416
+ rd,
3417
+ ri,
3418
+ imm,
3419
+ lane_imm,
3420
+ } => {
3421
+ let rd = allocs.next_writable(rd);
3422
+ let ri = allocs.next(ri);
3423
+ debug_assert_eq!(rd.to_reg(), ri);
3424
+
3425
+ let opcode = match size {
3426
+ 8 => 0xe740, // VLEIB
3427
+ 16 => 0xe741, // LEIVH
3428
+ 32 => 0xe743, // VLEIF
3429
+ 64 => 0xe742, // VLEIG
3430
+ _ => unreachable!(),
3431
+ };
3432
+ put(
3433
+ sink,
3434
+ &enc_vri_a(opcode, rd.to_reg(), imm as u16, lane_imm.into()),
3435
+ );
3436
+ }
3437
+ &Inst::VecReplicateLane {
3438
+ size,
3439
+ rd,
3440
+ rn,
3441
+ lane_imm,
3442
+ } => {
3443
+ let rd = allocs.next_writable(rd);
3444
+ let rn = allocs.next(rn);
3445
+
3446
+ let (opcode, m4) = match size {
3447
+ 8 => (0xe74d, 0), // VREPB
3448
+ 16 => (0xe74d, 1), // VREPH
3449
+ 32 => (0xe74d, 2), // VREPF
3450
+ 64 => (0xe74d, 3), // VREPG
3451
+ _ => unreachable!(),
3452
+ };
3453
+ put(
3454
+ sink,
3455
+ &enc_vri_c(opcode, rd.to_reg(), lane_imm.into(), rn, m4),
3456
+ );
3457
+ }
3458
+
3459
+ &Inst::Call { link, ref info } => {
3460
+ debug_assert_eq!(link.to_reg(), gpr(14));
3461
+
3462
+ let opcode = 0xc05; // BRASL
3463
+
3464
+ // Add relocation for target function. This has to be done *before*
3465
+ // the S390xTlsGdCall relocation if any, to ensure linker relaxation
3466
+ // works correctly.
3467
+ sink.add_reloc_at_offset(2, Reloc::S390xPLTRel32Dbl, &info.dest, 2);
3468
+
3469
+ // Add relocation for TLS libcalls to enable linker optimizations.
3470
+ match &info.tls_symbol {
3471
+ None => {}
3472
+ Some(SymbolReloc::TlsGd { name }) => {
3473
+ sink.add_reloc(Reloc::S390xTlsGdCall, name, 0)
3474
+ }
3475
+ _ => unreachable!(),
3476
+ }
3477
+
3478
+ if let Some(s) = state.take_stack_map() {
3479
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(6), s);
3480
+ }
3481
+ put(sink, &enc_ril_b(opcode, link.to_reg(), 0));
3482
+ if info.opcode.is_call() {
3483
+ sink.add_call_site(info.opcode);
3484
+ }
3485
+ }
3486
+ &Inst::CallInd { link, ref info } => {
3487
+ debug_assert_eq!(link.to_reg(), gpr(14));
3488
+ let rn = allocs.next(info.rn);
3489
+
3490
+ let opcode = 0x0d; // BASR
3491
+ if let Some(s) = state.take_stack_map() {
3492
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(2), s);
3493
+ }
3494
+ put(sink, &enc_rr(opcode, link.to_reg(), rn));
3495
+ if info.opcode.is_call() {
3496
+ sink.add_call_site(info.opcode);
3497
+ }
3498
+ }
3499
+ &Inst::Args { .. } => {}
3500
+ &Inst::Rets { .. } => {}
3501
+ &Inst::Ret { link } => {
3502
+ debug_assert_eq!(link, gpr(14));
3503
+ let opcode = 0x07; // BCR
3504
+ put(sink, &enc_rr(opcode, gpr(15), link));
3505
+ }
3506
+ &Inst::Jump { dest } => {
3507
+ let off = sink.cur_offset();
3508
+ // Indicate that the jump uses a label, if so, so that a fixup can occur later.
3509
+ sink.use_label_at_offset(off, dest, LabelUse::BranchRIL);
3510
+ sink.add_uncond_branch(off, off + 6, dest);
3511
+ // Emit the jump itself.
3512
+ let opcode = 0xc04; // BCRL
3513
+ put(sink, &enc_ril_c(opcode, 15, 0));
3514
+ }
3515
+ &Inst::IndirectBr { rn, .. } => {
3516
+ let rn = allocs.next(rn);
3517
+
3518
+ let opcode = 0x07; // BCR
3519
+ put(sink, &enc_rr(opcode, gpr(15), rn));
3520
+ }
3521
+ &Inst::CondBr {
3522
+ taken,
3523
+ not_taken,
3524
+ cond,
3525
+ } => {
3526
+ let opcode = 0xc04; // BCRL
3527
+
3528
+ // Conditional part first.
3529
+ let cond_off = sink.cur_offset();
3530
+ sink.use_label_at_offset(cond_off, taken, LabelUse::BranchRIL);
3531
+ let inverted = &enc_ril_c(opcode, cond.invert().bits(), 0);
3532
+ sink.add_cond_branch(cond_off, cond_off + 6, taken, inverted);
3533
+ put(sink, &enc_ril_c(opcode, cond.bits(), 0));
3534
+
3535
+ // Unconditional part next.
3536
+ let uncond_off = sink.cur_offset();
3537
+ sink.use_label_at_offset(uncond_off, not_taken, LabelUse::BranchRIL);
3538
+ sink.add_uncond_branch(uncond_off, uncond_off + 6, not_taken);
3539
+ put(sink, &enc_ril_c(opcode, 15, 0));
3540
+ }
3541
+ &Inst::OneWayCondBr { target, cond } => {
3542
+ let opcode = 0xc04; // BCRL
3543
+ sink.use_label_at_offset(sink.cur_offset(), target, LabelUse::BranchRIL);
3544
+ put(sink, &enc_ril_c(opcode, cond.bits(), 0));
3545
+ }
3546
+ &Inst::Nop0 => {}
3547
+ &Inst::Nop2 => {
3548
+ put(sink, &enc_e(0x0707));
3549
+ }
3550
+ &Inst::Debugtrap => {
3551
+ put(sink, &enc_e(0x0001));
3552
+ }
3553
+ &Inst::Trap { trap_code } => {
3554
+ if let Some(s) = state.take_stack_map() {
3555
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(2), s);
3556
+ }
3557
+ put_with_trap(sink, &enc_e(0x0000), trap_code);
3558
+ }
3559
+ &Inst::TrapIf { cond, trap_code } => {
3560
+ if let Some(s) = state.take_stack_map() {
3561
+ sink.add_stack_map(StackMapExtent::UpcomingBytes(6), s);
3562
+ }
3563
+ // We implement a TrapIf as a conditional branch into the middle
3564
+ // of the branch (BRCL) instruction itself - those middle two bytes
3565
+ // are zero, which matches the trap instruction itself.
3566
+ let opcode = 0xc04; // BCRL
3567
+ let enc = &enc_ril_c(opcode, cond.bits(), 2);
3568
+ debug_assert!(enc.len() == 6 && enc[2] == 0 && enc[3] == 0);
3569
+ // The trap must be placed on the last byte of the embedded trap
3570
+ // instruction, so we need to emit the encoding in two parts.
3571
+ put_with_trap(sink, &enc[0..4], trap_code);
3572
+ put(sink, &enc[4..6]);
3573
+ }
3574
+ &Inst::JTSequence { ridx, ref targets } => {
3575
+ let ridx = allocs.next(ridx);
3576
+
3577
+ let table_label = sink.get_label();
3578
+
3579
+ // This sequence is *one* instruction in the vcode, and is expanded only here at
3580
+ // emission time, because we cannot allow the regalloc to insert spills/reloads in
3581
+ // the middle; we depend on hardcoded PC-rel addressing below.
3582
+
3583
+ // Set temp register to address of jump table.
3584
+ let rtmp = writable_spilltmp_reg();
3585
+ let inst = Inst::LoadAddr {
3586
+ rd: rtmp,
3587
+ mem: MemArg::Label {
3588
+ target: table_label,
3589
+ },
3590
+ };
3591
+ inst.emit(&[], sink, emit_info, state);
3592
+
3593
+ // Set temp to target address by adding the value of the jump table entry.
3594
+ let inst = Inst::AluRX {
3595
+ alu_op: ALUOp::Add64Ext32,
3596
+ rd: rtmp,
3597
+ ri: rtmp.to_reg(),
3598
+ mem: MemArg::reg_plus_reg(rtmp.to_reg(), ridx, MemFlags::trusted()),
3599
+ };
3600
+ inst.emit(&[], sink, emit_info, state);
3601
+
3602
+ // Branch to computed address. (`targets` here is only used for successor queries
3603
+ // and is not needed for emission.)
3604
+ let inst = Inst::IndirectBr {
3605
+ rn: rtmp.to_reg(),
3606
+ targets: vec![],
3607
+ };
3608
+ inst.emit(&[], sink, emit_info, state);
3609
+
3610
+ // Emit jump table (table of 32-bit offsets).
3611
+ sink.bind_label(table_label, &mut state.ctrl_plane);
3612
+ let jt_off = sink.cur_offset();
3613
+ for &target in targets.iter() {
3614
+ let word_off = sink.cur_offset();
3615
+ let off_into_table = word_off - jt_off;
3616
+ sink.use_label_at_offset(word_off, target, LabelUse::PCRel32);
3617
+ sink.put4(off_into_table.swap_bytes());
3618
+ }
3619
+
3620
+ // Lowering produces an EmitIsland before using a JTSequence, so we can safely
3621
+ // disable the worst-case-size check in this case.
3622
+ start_off = sink.cur_offset();
3623
+ }
3624
+
3625
+ &Inst::VirtualSPOffsetAdj { offset } => {
3626
+ trace!(
3627
+ "virtual sp offset adjusted by {} -> {}",
3628
+ offset,
3629
+ state.virtual_sp_offset + offset
3630
+ );
3631
+ state.virtual_sp_offset += offset;
3632
+ }
3633
+
3634
+ &Inst::Unwind { ref inst } => {
3635
+ sink.add_unwind(inst.clone());
3636
+ }
3637
+
3638
+ &Inst::DummyUse { .. } => {}
3639
+ }
3640
+
3641
+ let end_off = sink.cur_offset();
3642
+ debug_assert!((end_off - start_off) <= Inst::worst_case_size());
3643
+
3644
+ state.clear_post_insn();
3645
+ }
3646
+ }