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,3421 @@
1
+ //! This module defines s390x-specific machine instruction types.
2
+
3
+ use crate::binemit::{Addend, CodeOffset, Reloc};
4
+ use crate::ir::{types, ExternalName, Opcode, Type};
5
+ use crate::isa::s390x::abi::S390xMachineDeps;
6
+ use crate::isa::{CallConv, FunctionAlignment};
7
+ use crate::machinst::*;
8
+ use crate::{settings, CodegenError, CodegenResult};
9
+ use alloc::boxed::Box;
10
+ use alloc::vec::Vec;
11
+ use regalloc2::PRegSet;
12
+ use smallvec::SmallVec;
13
+ use std::fmt::Write;
14
+ use std::string::{String, ToString};
15
+ pub mod regs;
16
+ pub use self::regs::*;
17
+ pub mod imms;
18
+ pub use self::imms::*;
19
+ pub mod args;
20
+ pub use self::args::*;
21
+ pub mod emit;
22
+ pub use self::emit::*;
23
+ pub mod unwind;
24
+
25
+ #[cfg(test)]
26
+ mod emit_tests;
27
+
28
+ //=============================================================================
29
+ // Instructions (top level): definition
30
+
31
+ pub use crate::isa::s390x::lower::isle::generated_code::{
32
+ ALUOp, CmpOp, FPUOp1, FPUOp2, FPUOp3, FpuRoundMode, FpuRoundOp, LaneOrder, MInst as Inst,
33
+ RxSBGOp, ShiftOp, SymbolReloc, UnaryOp, VecBinaryOp, VecFloatCmpOp, VecIntCmpOp, VecShiftOp,
34
+ VecUnaryOp,
35
+ };
36
+
37
+ /// Additional information for (direct) Call instructions, left out of line to lower the size of
38
+ /// the Inst enum.
39
+ #[derive(Clone, Debug)]
40
+ pub struct CallInfo {
41
+ pub dest: ExternalName,
42
+ pub uses: CallArgList,
43
+ pub defs: CallRetList,
44
+ pub clobbers: PRegSet,
45
+ pub opcode: Opcode,
46
+ pub caller_callconv: CallConv,
47
+ pub callee_callconv: CallConv,
48
+ pub tls_symbol: Option<SymbolReloc>,
49
+ }
50
+
51
+ /// Additional information for CallInd instructions, left out of line to lower the size of the Inst
52
+ /// enum.
53
+ #[derive(Clone, Debug)]
54
+ pub struct CallIndInfo {
55
+ pub rn: Reg,
56
+ pub uses: CallArgList,
57
+ pub defs: CallRetList,
58
+ pub clobbers: PRegSet,
59
+ pub opcode: Opcode,
60
+ pub caller_callconv: CallConv,
61
+ pub callee_callconv: CallConv,
62
+ }
63
+
64
+ #[test]
65
+ fn inst_size_test() {
66
+ // This test will help with unintentionally growing the size
67
+ // of the Inst enum.
68
+ assert_eq!(32, std::mem::size_of::<Inst>());
69
+ }
70
+
71
+ /// A register pair. Enum so it can be destructured in ISLE.
72
+ #[derive(Clone, Copy, Debug)]
73
+ pub struct RegPair {
74
+ pub hi: Reg,
75
+ pub lo: Reg,
76
+ }
77
+
78
+ /// A writable register pair. Enum so it can be destructured in ISLE.
79
+ #[derive(Clone, Copy, Debug)]
80
+ pub struct WritableRegPair {
81
+ pub hi: Writable<Reg>,
82
+ pub lo: Writable<Reg>,
83
+ }
84
+
85
+ impl WritableRegPair {
86
+ pub fn to_regpair(&self) -> RegPair {
87
+ RegPair {
88
+ hi: self.hi.to_reg(),
89
+ lo: self.lo.to_reg(),
90
+ }
91
+ }
92
+ }
93
+
94
+ /// Supported instruction sets
95
+ #[allow(non_camel_case_types)]
96
+ #[derive(Debug)]
97
+ pub(crate) enum InstructionSet {
98
+ /// Baseline ISA for cranelift is z14.
99
+ Base,
100
+ /// Miscellaneous-Instruction-Extensions Facility 2 (z15)
101
+ MIE2,
102
+ /// Vector-Enhancements Facility 2 (z15)
103
+ VXRS_EXT2,
104
+ }
105
+
106
+ impl Inst {
107
+ /// Retrieve the ISA feature set in which the instruction is available.
108
+ fn available_in_isa(&self) -> InstructionSet {
109
+ match self {
110
+ // These instructions are part of the baseline ISA for cranelift (z14)
111
+ Inst::Nop0
112
+ | Inst::Nop2
113
+ | Inst::AluRRSImm16 { .. }
114
+ | Inst::AluRR { .. }
115
+ | Inst::AluRX { .. }
116
+ | Inst::AluRSImm16 { .. }
117
+ | Inst::AluRSImm32 { .. }
118
+ | Inst::AluRUImm32 { .. }
119
+ | Inst::AluRUImm16Shifted { .. }
120
+ | Inst::AluRUImm32Shifted { .. }
121
+ | Inst::ShiftRR { .. }
122
+ | Inst::RxSBG { .. }
123
+ | Inst::RxSBGTest { .. }
124
+ | Inst::SMulWide { .. }
125
+ | Inst::UMulWide { .. }
126
+ | Inst::SDivMod32 { .. }
127
+ | Inst::SDivMod64 { .. }
128
+ | Inst::UDivMod32 { .. }
129
+ | Inst::UDivMod64 { .. }
130
+ | Inst::Flogr { .. }
131
+ | Inst::CmpRR { .. }
132
+ | Inst::CmpRX { .. }
133
+ | Inst::CmpRSImm16 { .. }
134
+ | Inst::CmpRSImm32 { .. }
135
+ | Inst::CmpRUImm32 { .. }
136
+ | Inst::CmpTrapRR { .. }
137
+ | Inst::CmpTrapRSImm16 { .. }
138
+ | Inst::CmpTrapRUImm16 { .. }
139
+ | Inst::AtomicRmw { .. }
140
+ | Inst::AtomicCas32 { .. }
141
+ | Inst::AtomicCas64 { .. }
142
+ | Inst::Fence
143
+ | Inst::Load32 { .. }
144
+ | Inst::Load32ZExt8 { .. }
145
+ | Inst::Load32SExt8 { .. }
146
+ | Inst::Load32ZExt16 { .. }
147
+ | Inst::Load32SExt16 { .. }
148
+ | Inst::Load64 { .. }
149
+ | Inst::Load64ZExt8 { .. }
150
+ | Inst::Load64SExt8 { .. }
151
+ | Inst::Load64ZExt16 { .. }
152
+ | Inst::Load64SExt16 { .. }
153
+ | Inst::Load64ZExt32 { .. }
154
+ | Inst::Load64SExt32 { .. }
155
+ | Inst::LoadRev16 { .. }
156
+ | Inst::LoadRev32 { .. }
157
+ | Inst::LoadRev64 { .. }
158
+ | Inst::Store8 { .. }
159
+ | Inst::Store16 { .. }
160
+ | Inst::Store32 { .. }
161
+ | Inst::Store64 { .. }
162
+ | Inst::StoreImm8 { .. }
163
+ | Inst::StoreImm16 { .. }
164
+ | Inst::StoreImm32SExt16 { .. }
165
+ | Inst::StoreImm64SExt16 { .. }
166
+ | Inst::StoreRev16 { .. }
167
+ | Inst::StoreRev32 { .. }
168
+ | Inst::StoreRev64 { .. }
169
+ | Inst::Mvc { .. }
170
+ | Inst::LoadMultiple64 { .. }
171
+ | Inst::StoreMultiple64 { .. }
172
+ | Inst::Mov32 { .. }
173
+ | Inst::Mov64 { .. }
174
+ | Inst::MovPReg { .. }
175
+ | Inst::Mov32Imm { .. }
176
+ | Inst::Mov32SImm16 { .. }
177
+ | Inst::Mov64SImm16 { .. }
178
+ | Inst::Mov64SImm32 { .. }
179
+ | Inst::Mov64UImm16Shifted { .. }
180
+ | Inst::Mov64UImm32Shifted { .. }
181
+ | Inst::Insert64UImm16Shifted { .. }
182
+ | Inst::Insert64UImm32Shifted { .. }
183
+ | Inst::LoadAR { .. }
184
+ | Inst::InsertAR { .. }
185
+ | Inst::Extend { .. }
186
+ | Inst::CMov32 { .. }
187
+ | Inst::CMov64 { .. }
188
+ | Inst::CMov32SImm16 { .. }
189
+ | Inst::CMov64SImm16 { .. }
190
+ | Inst::FpuMove32 { .. }
191
+ | Inst::FpuMove64 { .. }
192
+ | Inst::FpuCMov32 { .. }
193
+ | Inst::FpuCMov64 { .. }
194
+ | Inst::FpuRR { .. }
195
+ | Inst::FpuRRR { .. }
196
+ | Inst::FpuRRRR { .. }
197
+ | Inst::FpuCmp32 { .. }
198
+ | Inst::FpuCmp64 { .. }
199
+ | Inst::LoadFpuConst32 { .. }
200
+ | Inst::LoadFpuConst64 { .. }
201
+ | Inst::VecRRR { .. }
202
+ | Inst::VecRR { .. }
203
+ | Inst::VecShiftRR { .. }
204
+ | Inst::VecSelect { .. }
205
+ | Inst::VecPermute { .. }
206
+ | Inst::VecPermuteDWImm { .. }
207
+ | Inst::VecIntCmp { .. }
208
+ | Inst::VecIntCmpS { .. }
209
+ | Inst::VecFloatCmp { .. }
210
+ | Inst::VecFloatCmpS { .. }
211
+ | Inst::VecInt128SCmpHi { .. }
212
+ | Inst::VecInt128UCmpHi { .. }
213
+ | Inst::VecLoad { .. }
214
+ | Inst::VecStore { .. }
215
+ | Inst::VecLoadReplicate { .. }
216
+ | Inst::VecMov { .. }
217
+ | Inst::VecCMov { .. }
218
+ | Inst::MovToVec128 { .. }
219
+ | Inst::VecLoadConst { .. }
220
+ | Inst::VecLoadConstReplicate { .. }
221
+ | Inst::VecImmByteMask { .. }
222
+ | Inst::VecImmBitMask { .. }
223
+ | Inst::VecImmReplicate { .. }
224
+ | Inst::VecLoadLane { .. }
225
+ | Inst::VecLoadLaneUndef { .. }
226
+ | Inst::VecStoreLane { .. }
227
+ | Inst::VecInsertLane { .. }
228
+ | Inst::VecInsertLaneUndef { .. }
229
+ | Inst::VecExtractLane { .. }
230
+ | Inst::VecInsertLaneImm { .. }
231
+ | Inst::VecReplicateLane { .. }
232
+ | Inst::Call { .. }
233
+ | Inst::CallInd { .. }
234
+ | Inst::Args { .. }
235
+ | Inst::Rets { .. }
236
+ | Inst::Ret { .. }
237
+ | Inst::Jump { .. }
238
+ | Inst::CondBr { .. }
239
+ | Inst::TrapIf { .. }
240
+ | Inst::OneWayCondBr { .. }
241
+ | Inst::IndirectBr { .. }
242
+ | Inst::Debugtrap
243
+ | Inst::Trap { .. }
244
+ | Inst::JTSequence { .. }
245
+ | Inst::LoadSymbolReloc { .. }
246
+ | Inst::LoadAddr { .. }
247
+ | Inst::Loop { .. }
248
+ | Inst::CondBreak { .. }
249
+ | Inst::VirtualSPOffsetAdj { .. }
250
+ | Inst::Unwind { .. } => InstructionSet::Base,
251
+
252
+ // These depend on the opcode
253
+ Inst::AluRRR { alu_op, .. } => match alu_op {
254
+ ALUOp::NotAnd32 | ALUOp::NotAnd64 => InstructionSet::MIE2,
255
+ ALUOp::NotOrr32 | ALUOp::NotOrr64 => InstructionSet::MIE2,
256
+ ALUOp::NotXor32 | ALUOp::NotXor64 => InstructionSet::MIE2,
257
+ ALUOp::AndNot32 | ALUOp::AndNot64 => InstructionSet::MIE2,
258
+ ALUOp::OrrNot32 | ALUOp::OrrNot64 => InstructionSet::MIE2,
259
+ _ => InstructionSet::Base,
260
+ },
261
+ Inst::UnaryRR { op, .. } => match op {
262
+ UnaryOp::PopcntReg => InstructionSet::MIE2,
263
+ _ => InstructionSet::Base,
264
+ },
265
+ Inst::FpuRound { op, .. } => match op {
266
+ FpuRoundOp::ToSInt32 | FpuRoundOp::FromSInt32 => InstructionSet::VXRS_EXT2,
267
+ FpuRoundOp::ToUInt32 | FpuRoundOp::FromUInt32 => InstructionSet::VXRS_EXT2,
268
+ FpuRoundOp::ToSInt32x4 | FpuRoundOp::FromSInt32x4 => InstructionSet::VXRS_EXT2,
269
+ FpuRoundOp::ToUInt32x4 | FpuRoundOp::FromUInt32x4 => InstructionSet::VXRS_EXT2,
270
+ _ => InstructionSet::Base,
271
+ },
272
+
273
+ // These are all part of VXRS_EXT2
274
+ Inst::VecLoadRev { .. }
275
+ | Inst::VecLoadByte16Rev { .. }
276
+ | Inst::VecLoadByte32Rev { .. }
277
+ | Inst::VecLoadByte64Rev { .. }
278
+ | Inst::VecLoadElt16Rev { .. }
279
+ | Inst::VecLoadElt32Rev { .. }
280
+ | Inst::VecLoadElt64Rev { .. }
281
+ | Inst::VecStoreRev { .. }
282
+ | Inst::VecStoreByte16Rev { .. }
283
+ | Inst::VecStoreByte32Rev { .. }
284
+ | Inst::VecStoreByte64Rev { .. }
285
+ | Inst::VecStoreElt16Rev { .. }
286
+ | Inst::VecStoreElt32Rev { .. }
287
+ | Inst::VecStoreElt64Rev { .. }
288
+ | Inst::VecLoadReplicateRev { .. }
289
+ | Inst::VecLoadLaneRev { .. }
290
+ | Inst::VecLoadLaneRevUndef { .. }
291
+ | Inst::VecStoreLaneRev { .. } => InstructionSet::VXRS_EXT2,
292
+
293
+ Inst::DummyUse { .. } => InstructionSet::Base,
294
+ }
295
+ }
296
+
297
+ /// Create a 128-bit move instruction.
298
+ pub fn mov128(to_reg: Writable<Reg>, from_reg: Reg) -> Inst {
299
+ assert!(to_reg.to_reg().class() == RegClass::Float);
300
+ assert!(from_reg.class() == RegClass::Float);
301
+ Inst::VecMov {
302
+ rd: to_reg,
303
+ rn: from_reg,
304
+ }
305
+ }
306
+
307
+ /// Create a 64-bit move instruction.
308
+ pub fn mov64(to_reg: Writable<Reg>, from_reg: Reg) -> Inst {
309
+ assert!(to_reg.to_reg().class() == from_reg.class());
310
+ if from_reg.class() == RegClass::Int {
311
+ Inst::Mov64 {
312
+ rd: to_reg,
313
+ rm: from_reg,
314
+ }
315
+ } else {
316
+ Inst::FpuMove64 {
317
+ rd: to_reg,
318
+ rn: from_reg,
319
+ }
320
+ }
321
+ }
322
+
323
+ /// Create a 32-bit move instruction.
324
+ pub fn mov32(to_reg: Writable<Reg>, from_reg: Reg) -> Inst {
325
+ if from_reg.class() == RegClass::Int {
326
+ Inst::Mov32 {
327
+ rd: to_reg,
328
+ rm: from_reg,
329
+ }
330
+ } else {
331
+ Inst::FpuMove32 {
332
+ rd: to_reg,
333
+ rn: from_reg,
334
+ }
335
+ }
336
+ }
337
+
338
+ /// Generic constructor for a load (zero-extending where appropriate).
339
+ pub fn gen_load(into_reg: Writable<Reg>, mem: MemArg, ty: Type) -> Inst {
340
+ match ty {
341
+ types::I8 => Inst::Load64ZExt8 { rd: into_reg, mem },
342
+ types::I16 => Inst::Load64ZExt16 { rd: into_reg, mem },
343
+ types::I32 => Inst::Load64ZExt32 { rd: into_reg, mem },
344
+ types::I64 | types::R64 => Inst::Load64 { rd: into_reg, mem },
345
+ types::F32 => Inst::VecLoadLaneUndef {
346
+ size: 32,
347
+ rd: into_reg,
348
+ mem,
349
+ lane_imm: 0,
350
+ },
351
+ types::F64 => Inst::VecLoadLaneUndef {
352
+ size: 64,
353
+ rd: into_reg,
354
+ mem,
355
+ lane_imm: 0,
356
+ },
357
+ _ if ty.is_vector() && ty.bits() == 128 => Inst::VecLoad { rd: into_reg, mem },
358
+ types::I128 => Inst::VecLoad { rd: into_reg, mem },
359
+ _ => unimplemented!("gen_load({})", ty),
360
+ }
361
+ }
362
+
363
+ /// Generic constructor for a store.
364
+ pub fn gen_store(mem: MemArg, from_reg: Reg, ty: Type) -> Inst {
365
+ match ty {
366
+ types::I8 => Inst::Store8 { rd: from_reg, mem },
367
+ types::I16 => Inst::Store16 { rd: from_reg, mem },
368
+ types::I32 => Inst::Store32 { rd: from_reg, mem },
369
+ types::I64 | types::R64 => Inst::Store64 { rd: from_reg, mem },
370
+ types::F32 => Inst::VecStoreLane {
371
+ size: 32,
372
+ rd: from_reg,
373
+ mem,
374
+ lane_imm: 0,
375
+ },
376
+ types::F64 => Inst::VecStoreLane {
377
+ size: 64,
378
+ rd: from_reg,
379
+ mem,
380
+ lane_imm: 0,
381
+ },
382
+ _ if ty.is_vector() && ty.bits() == 128 => Inst::VecStore { rd: from_reg, mem },
383
+ types::I128 => Inst::VecStore { rd: from_reg, mem },
384
+ _ => unimplemented!("gen_store({})", ty),
385
+ }
386
+ }
387
+ }
388
+
389
+ //=============================================================================
390
+ // Instructions: get_regs
391
+
392
+ fn memarg_operands(memarg: &mut MemArg, collector: &mut impl OperandVisitor) {
393
+ match memarg {
394
+ MemArg::BXD12 { base, index, .. } | MemArg::BXD20 { base, index, .. } => {
395
+ collector.reg_use(base);
396
+ collector.reg_use(index);
397
+ }
398
+ MemArg::Label { .. } | MemArg::Symbol { .. } => {}
399
+ MemArg::RegOffset { reg, .. } => {
400
+ collector.reg_use(reg);
401
+ }
402
+ MemArg::InitialSPOffset { .. } | MemArg::NominalSPOffset { .. } => {}
403
+ }
404
+ // mem_finalize might require %r1 to hold (part of) the address.
405
+ // Conservatively assume this will always be necessary here.
406
+ collector.reg_fixed_nonallocatable(gpr_preg(1));
407
+ }
408
+
409
+ fn s390x_get_operands(inst: &mut Inst, collector: &mut DenyReuseVisitor<impl OperandVisitor>) {
410
+ match inst {
411
+ Inst::AluRRR { rd, rn, rm, .. } => {
412
+ collector.reg_def(rd);
413
+ collector.reg_use(rn);
414
+ collector.reg_use(rm);
415
+ }
416
+ Inst::AluRRSImm16 { rd, rn, .. } => {
417
+ collector.reg_def(rd);
418
+ collector.reg_use(rn);
419
+ }
420
+ Inst::AluRR { rd, ri, rm, .. } => {
421
+ collector.reg_reuse_def(rd, 1);
422
+ collector.reg_use(ri);
423
+ collector.reg_use(rm);
424
+ }
425
+ Inst::AluRX { rd, ri, mem, .. } => {
426
+ collector.reg_reuse_def(rd, 1);
427
+ collector.reg_use(ri);
428
+ memarg_operands(mem, collector);
429
+ }
430
+ Inst::AluRSImm16 { rd, ri, .. } => {
431
+ collector.reg_reuse_def(rd, 1);
432
+ collector.reg_use(ri);
433
+ }
434
+ Inst::AluRSImm32 { rd, ri, .. } => {
435
+ collector.reg_reuse_def(rd, 1);
436
+ collector.reg_use(ri);
437
+ }
438
+ Inst::AluRUImm32 { rd, ri, .. } => {
439
+ collector.reg_reuse_def(rd, 1);
440
+ collector.reg_use(ri);
441
+ }
442
+ Inst::AluRUImm16Shifted { rd, ri, .. } => {
443
+ collector.reg_reuse_def(rd, 1);
444
+ collector.reg_use(ri);
445
+ }
446
+ Inst::AluRUImm32Shifted { rd, ri, .. } => {
447
+ collector.reg_reuse_def(rd, 1);
448
+ collector.reg_use(ri);
449
+ }
450
+ Inst::SMulWide { rd, rn, rm } => {
451
+ collector.reg_use(rn);
452
+ collector.reg_use(rm);
453
+ // FIXME: The pair is hard-coded as %r2/%r3 because regalloc cannot handle pairs. If
454
+ // that changes, all the hard-coded uses of %r2/%r3 can be changed.
455
+ collector.reg_fixed_def(&mut rd.hi, gpr(2));
456
+ collector.reg_fixed_def(&mut rd.lo, gpr(3));
457
+ }
458
+ Inst::UMulWide { rd, ri, rn } => {
459
+ collector.reg_use(rn);
460
+ collector.reg_fixed_def(&mut rd.hi, gpr(2));
461
+ collector.reg_fixed_def(&mut rd.lo, gpr(3));
462
+ collector.reg_fixed_use(ri, gpr(3));
463
+ }
464
+ Inst::SDivMod32 { rd, ri, rn } | Inst::SDivMod64 { rd, ri, rn } => {
465
+ collector.reg_use(rn);
466
+ collector.reg_fixed_def(&mut rd.hi, gpr(2));
467
+ collector.reg_fixed_def(&mut rd.lo, gpr(3));
468
+ collector.reg_fixed_use(ri, gpr(3));
469
+ }
470
+ Inst::UDivMod32 { rd, ri, rn } | Inst::UDivMod64 { rd, ri, rn } => {
471
+ collector.reg_use(rn);
472
+ collector.reg_fixed_def(&mut rd.hi, gpr(2));
473
+ collector.reg_fixed_def(&mut rd.lo, gpr(3));
474
+ collector.reg_fixed_use(&mut ri.hi, gpr(2));
475
+ collector.reg_fixed_use(&mut ri.lo, gpr(3));
476
+ }
477
+ Inst::Flogr { rd, rn } => {
478
+ collector.reg_use(rn);
479
+ collector.reg_fixed_def(&mut rd.hi, gpr(2));
480
+ collector.reg_fixed_def(&mut rd.lo, gpr(3));
481
+ }
482
+ Inst::ShiftRR {
483
+ rd, rn, shift_reg, ..
484
+ } => {
485
+ collector.reg_def(rd);
486
+ collector.reg_use(rn);
487
+ collector.reg_use(shift_reg);
488
+ }
489
+ Inst::RxSBG { rd, ri, rn, .. } => {
490
+ collector.reg_reuse_def(rd, 1);
491
+ collector.reg_use(ri);
492
+ collector.reg_use(rn);
493
+ }
494
+ Inst::RxSBGTest { rd, rn, .. } => {
495
+ collector.reg_use(rd);
496
+ collector.reg_use(rn);
497
+ }
498
+ Inst::UnaryRR { rd, rn, .. } => {
499
+ collector.reg_def(rd);
500
+ collector.reg_use(rn);
501
+ }
502
+ Inst::CmpRR { rn, rm, .. } => {
503
+ collector.reg_use(rn);
504
+ collector.reg_use(rm);
505
+ }
506
+ Inst::CmpRX { rn, mem, .. } => {
507
+ collector.reg_use(rn);
508
+ memarg_operands(mem, collector);
509
+ }
510
+ Inst::CmpRSImm16 { rn, .. } => {
511
+ collector.reg_use(rn);
512
+ }
513
+ Inst::CmpRSImm32 { rn, .. } => {
514
+ collector.reg_use(rn);
515
+ }
516
+ Inst::CmpRUImm32 { rn, .. } => {
517
+ collector.reg_use(rn);
518
+ }
519
+ Inst::CmpTrapRR { rn, rm, .. } => {
520
+ collector.reg_use(rn);
521
+ collector.reg_use(rm);
522
+ }
523
+ Inst::CmpTrapRSImm16 { rn, .. } => {
524
+ collector.reg_use(rn);
525
+ }
526
+ Inst::CmpTrapRUImm16 { rn, .. } => {
527
+ collector.reg_use(rn);
528
+ }
529
+ Inst::AtomicRmw { rd, rn, mem, .. } => {
530
+ collector.reg_def(rd);
531
+ collector.reg_use(rn);
532
+ memarg_operands(mem, collector);
533
+ }
534
+ Inst::AtomicCas32 {
535
+ rd, ri, rn, mem, ..
536
+ }
537
+ | Inst::AtomicCas64 {
538
+ rd, ri, rn, mem, ..
539
+ } => {
540
+ collector.reg_reuse_def(rd, 1);
541
+ collector.reg_use(ri);
542
+ collector.reg_use(rn);
543
+ memarg_operands(mem, collector);
544
+ }
545
+ Inst::Fence => {}
546
+ Inst::Load32 { rd, mem, .. }
547
+ | Inst::Load32ZExt8 { rd, mem, .. }
548
+ | Inst::Load32SExt8 { rd, mem, .. }
549
+ | Inst::Load32ZExt16 { rd, mem, .. }
550
+ | Inst::Load32SExt16 { rd, mem, .. }
551
+ | Inst::Load64 { rd, mem, .. }
552
+ | Inst::Load64ZExt8 { rd, mem, .. }
553
+ | Inst::Load64SExt8 { rd, mem, .. }
554
+ | Inst::Load64ZExt16 { rd, mem, .. }
555
+ | Inst::Load64SExt16 { rd, mem, .. }
556
+ | Inst::Load64ZExt32 { rd, mem, .. }
557
+ | Inst::Load64SExt32 { rd, mem, .. }
558
+ | Inst::LoadRev16 { rd, mem, .. }
559
+ | Inst::LoadRev32 { rd, mem, .. }
560
+ | Inst::LoadRev64 { rd, mem, .. } => {
561
+ collector.reg_def(rd);
562
+ memarg_operands(mem, collector);
563
+ }
564
+ Inst::Store8 { rd, mem, .. }
565
+ | Inst::Store16 { rd, mem, .. }
566
+ | Inst::Store32 { rd, mem, .. }
567
+ | Inst::Store64 { rd, mem, .. }
568
+ | Inst::StoreRev16 { rd, mem, .. }
569
+ | Inst::StoreRev32 { rd, mem, .. }
570
+ | Inst::StoreRev64 { rd, mem, .. } => {
571
+ collector.reg_use(rd);
572
+ memarg_operands(mem, collector);
573
+ }
574
+ Inst::StoreImm8 { mem, .. }
575
+ | Inst::StoreImm16 { mem, .. }
576
+ | Inst::StoreImm32SExt16 { mem, .. }
577
+ | Inst::StoreImm64SExt16 { mem, .. } => {
578
+ memarg_operands(mem, collector);
579
+ }
580
+ Inst::Mvc { dst, src, .. } => {
581
+ collector.reg_use(&mut dst.base);
582
+ collector.reg_use(&mut src.base);
583
+ }
584
+ Inst::LoadMultiple64 { rt, rt2, mem, .. } => {
585
+ memarg_operands(mem, collector);
586
+ let first_regnum = rt.to_reg().to_real_reg().unwrap().hw_enc();
587
+ let last_regnum = rt2.to_reg().to_real_reg().unwrap().hw_enc();
588
+ for regnum in first_regnum..last_regnum + 1 {
589
+ collector.reg_fixed_nonallocatable(gpr_preg(regnum));
590
+ }
591
+ }
592
+ Inst::StoreMultiple64 { rt, rt2, mem, .. } => {
593
+ memarg_operands(mem, collector);
594
+ let first_regnum = rt.to_real_reg().unwrap().hw_enc();
595
+ let last_regnum = rt2.to_real_reg().unwrap().hw_enc();
596
+ for regnum in first_regnum..last_regnum + 1 {
597
+ collector.reg_fixed_nonallocatable(gpr_preg(regnum));
598
+ }
599
+ }
600
+ Inst::Mov64 { rd, rm } => {
601
+ collector.reg_def(rd);
602
+ collector.reg_use(rm);
603
+ }
604
+ Inst::MovPReg { rd, rm } => {
605
+ debug_assert!([gpr_preg(0), gpr_preg(14), gpr_preg(15)].contains(rm));
606
+ debug_assert!(rd.to_reg().is_virtual());
607
+ collector.reg_def(rd);
608
+ }
609
+ Inst::Mov32 { rd, rm } => {
610
+ collector.reg_def(rd);
611
+ collector.reg_use(rm);
612
+ }
613
+ Inst::Mov32Imm { rd, .. }
614
+ | Inst::Mov32SImm16 { rd, .. }
615
+ | Inst::Mov64SImm16 { rd, .. }
616
+ | Inst::Mov64SImm32 { rd, .. }
617
+ | Inst::Mov64UImm16Shifted { rd, .. }
618
+ | Inst::Mov64UImm32Shifted { rd, .. } => {
619
+ collector.reg_def(rd);
620
+ }
621
+ Inst::CMov32 { rd, ri, rm, .. } | Inst::CMov64 { rd, ri, rm, .. } => {
622
+ collector.reg_reuse_def(rd, 1);
623
+ collector.reg_use(ri);
624
+ collector.reg_use(rm);
625
+ }
626
+ Inst::CMov32SImm16 { rd, ri, .. } | Inst::CMov64SImm16 { rd, ri, .. } => {
627
+ collector.reg_reuse_def(rd, 1);
628
+ collector.reg_use(ri);
629
+ }
630
+ Inst::Insert64UImm16Shifted { rd, ri, .. } | Inst::Insert64UImm32Shifted { rd, ri, .. } => {
631
+ collector.reg_reuse_def(rd, 1);
632
+ collector.reg_use(ri);
633
+ }
634
+ Inst::LoadAR { rd, .. } => {
635
+ collector.reg_def(rd);
636
+ }
637
+ Inst::InsertAR { rd, ri, .. } => {
638
+ collector.reg_reuse_def(rd, 1);
639
+ collector.reg_use(ri);
640
+ }
641
+ Inst::FpuMove32 { rd, rn } | Inst::FpuMove64 { rd, rn } => {
642
+ collector.reg_def(rd);
643
+ collector.reg_use(rn);
644
+ }
645
+ Inst::FpuCMov32 { rd, ri, rm, .. } | Inst::FpuCMov64 { rd, ri, rm, .. } => {
646
+ collector.reg_reuse_def(rd, 1);
647
+ collector.reg_use(ri);
648
+ collector.reg_use(rm);
649
+ }
650
+ Inst::FpuRR { rd, rn, .. } => {
651
+ collector.reg_def(rd);
652
+ collector.reg_use(rn);
653
+ }
654
+ Inst::FpuRRR { rd, rn, rm, .. } => {
655
+ collector.reg_def(rd);
656
+ collector.reg_use(rn);
657
+ collector.reg_use(rm);
658
+ }
659
+ Inst::FpuRRRR { rd, rn, rm, ra, .. } => {
660
+ collector.reg_def(rd);
661
+ collector.reg_use(rn);
662
+ collector.reg_use(rm);
663
+ collector.reg_use(ra);
664
+ }
665
+ Inst::FpuCmp32 { rn, rm } | Inst::FpuCmp64 { rn, rm } => {
666
+ collector.reg_use(rn);
667
+ collector.reg_use(rm);
668
+ }
669
+ Inst::LoadFpuConst32 { rd, .. } | Inst::LoadFpuConst64 { rd, .. } => {
670
+ collector.reg_def(rd);
671
+ collector.reg_fixed_nonallocatable(gpr_preg(1));
672
+ }
673
+ Inst::FpuRound { rd, rn, .. } => {
674
+ collector.reg_def(rd);
675
+ collector.reg_use(rn);
676
+ }
677
+ Inst::VecRRR { rd, rn, rm, .. } => {
678
+ collector.reg_def(rd);
679
+ collector.reg_use(rn);
680
+ collector.reg_use(rm);
681
+ }
682
+ Inst::VecRR { rd, rn, .. } => {
683
+ collector.reg_def(rd);
684
+ collector.reg_use(rn);
685
+ }
686
+ Inst::VecShiftRR {
687
+ rd, rn, shift_reg, ..
688
+ } => {
689
+ collector.reg_def(rd);
690
+ collector.reg_use(rn);
691
+ collector.reg_use(shift_reg);
692
+ }
693
+ Inst::VecSelect { rd, rn, rm, ra, .. } => {
694
+ collector.reg_def(rd);
695
+ collector.reg_use(rn);
696
+ collector.reg_use(rm);
697
+ collector.reg_use(ra);
698
+ }
699
+ Inst::VecPermute { rd, rn, rm, ra, .. } => {
700
+ collector.reg_def(rd);
701
+ collector.reg_use(rn);
702
+ collector.reg_use(rm);
703
+ collector.reg_use(ra);
704
+ }
705
+ Inst::VecPermuteDWImm { rd, rn, rm, .. } => {
706
+ collector.reg_def(rd);
707
+ collector.reg_use(rn);
708
+ collector.reg_use(rm);
709
+ }
710
+ Inst::VecIntCmp { rd, rn, rm, .. } | Inst::VecIntCmpS { rd, rn, rm, .. } => {
711
+ collector.reg_def(rd);
712
+ collector.reg_use(rn);
713
+ collector.reg_use(rm);
714
+ }
715
+ Inst::VecFloatCmp { rd, rn, rm, .. } | Inst::VecFloatCmpS { rd, rn, rm, .. } => {
716
+ collector.reg_def(rd);
717
+ collector.reg_use(rn);
718
+ collector.reg_use(rm);
719
+ }
720
+ Inst::VecInt128SCmpHi { tmp, rn, rm, .. } | Inst::VecInt128UCmpHi { tmp, rn, rm, .. } => {
721
+ collector.reg_def(tmp);
722
+ collector.reg_use(rn);
723
+ collector.reg_use(rm);
724
+ }
725
+ Inst::VecLoad { rd, mem, .. } => {
726
+ collector.reg_def(rd);
727
+ memarg_operands(mem, collector);
728
+ }
729
+ Inst::VecLoadRev { rd, mem, .. } => {
730
+ collector.reg_def(rd);
731
+ memarg_operands(mem, collector);
732
+ }
733
+ Inst::VecLoadByte16Rev { rd, mem, .. } => {
734
+ collector.reg_def(rd);
735
+ memarg_operands(mem, collector);
736
+ }
737
+ Inst::VecLoadByte32Rev { rd, mem, .. } => {
738
+ collector.reg_def(rd);
739
+ memarg_operands(mem, collector);
740
+ }
741
+ Inst::VecLoadByte64Rev { rd, mem, .. } => {
742
+ collector.reg_def(rd);
743
+ memarg_operands(mem, collector);
744
+ }
745
+ Inst::VecLoadElt16Rev { rd, mem, .. } => {
746
+ collector.reg_def(rd);
747
+ memarg_operands(mem, collector);
748
+ }
749
+ Inst::VecLoadElt32Rev { rd, mem, .. } => {
750
+ collector.reg_def(rd);
751
+ memarg_operands(mem, collector);
752
+ }
753
+ Inst::VecLoadElt64Rev { rd, mem, .. } => {
754
+ collector.reg_def(rd);
755
+ memarg_operands(mem, collector);
756
+ }
757
+ Inst::VecStore { rd, mem, .. } => {
758
+ collector.reg_use(rd);
759
+ memarg_operands(mem, collector);
760
+ }
761
+ Inst::VecStoreRev { rd, mem, .. } => {
762
+ collector.reg_use(rd);
763
+ memarg_operands(mem, collector);
764
+ }
765
+ Inst::VecStoreByte16Rev { rd, mem, .. } => {
766
+ collector.reg_use(rd);
767
+ memarg_operands(mem, collector);
768
+ }
769
+ Inst::VecStoreByte32Rev { rd, mem, .. } => {
770
+ collector.reg_use(rd);
771
+ memarg_operands(mem, collector);
772
+ }
773
+ Inst::VecStoreByte64Rev { rd, mem, .. } => {
774
+ collector.reg_use(rd);
775
+ memarg_operands(mem, collector);
776
+ }
777
+ Inst::VecStoreElt16Rev { rd, mem, .. } => {
778
+ collector.reg_use(rd);
779
+ memarg_operands(mem, collector);
780
+ }
781
+ Inst::VecStoreElt32Rev { rd, mem, .. } => {
782
+ collector.reg_use(rd);
783
+ memarg_operands(mem, collector);
784
+ }
785
+ Inst::VecStoreElt64Rev { rd, mem, .. } => {
786
+ collector.reg_use(rd);
787
+ memarg_operands(mem, collector);
788
+ }
789
+ Inst::VecLoadReplicate { rd, mem, .. } => {
790
+ collector.reg_def(rd);
791
+ memarg_operands(mem, collector);
792
+ }
793
+ Inst::VecLoadReplicateRev { rd, mem, .. } => {
794
+ collector.reg_def(rd);
795
+ memarg_operands(mem, collector);
796
+ }
797
+ Inst::VecMov { rd, rn } => {
798
+ collector.reg_def(rd);
799
+ collector.reg_use(rn);
800
+ }
801
+ Inst::VecCMov { rd, ri, rm, .. } => {
802
+ collector.reg_reuse_def(rd, 1);
803
+ collector.reg_use(ri);
804
+ collector.reg_use(rm);
805
+ }
806
+ Inst::MovToVec128 { rd, rn, rm } => {
807
+ collector.reg_def(rd);
808
+ collector.reg_use(rn);
809
+ collector.reg_use(rm);
810
+ }
811
+ Inst::VecLoadConst { rd, .. } | Inst::VecLoadConstReplicate { rd, .. } => {
812
+ collector.reg_def(rd);
813
+ collector.reg_fixed_nonallocatable(gpr_preg(1));
814
+ }
815
+ Inst::VecImmByteMask { rd, .. } => {
816
+ collector.reg_def(rd);
817
+ }
818
+ Inst::VecImmBitMask { rd, .. } => {
819
+ collector.reg_def(rd);
820
+ }
821
+ Inst::VecImmReplicate { rd, .. } => {
822
+ collector.reg_def(rd);
823
+ }
824
+ Inst::VecLoadLane { rd, ri, mem, .. } => {
825
+ collector.reg_reuse_def(rd, 1);
826
+ collector.reg_use(ri);
827
+ memarg_operands(mem, collector);
828
+ }
829
+ Inst::VecLoadLaneUndef { rd, mem, .. } => {
830
+ collector.reg_def(rd);
831
+ memarg_operands(mem, collector);
832
+ }
833
+ Inst::VecStoreLaneRev { rd, mem, .. } => {
834
+ collector.reg_use(rd);
835
+ memarg_operands(mem, collector);
836
+ }
837
+ Inst::VecLoadLaneRevUndef { rd, mem, .. } => {
838
+ collector.reg_def(rd);
839
+ memarg_operands(mem, collector);
840
+ }
841
+ Inst::VecStoreLane { rd, mem, .. } => {
842
+ collector.reg_use(rd);
843
+ memarg_operands(mem, collector);
844
+ }
845
+ Inst::VecLoadLaneRev { rd, ri, mem, .. } => {
846
+ collector.reg_reuse_def(rd, 1);
847
+ collector.reg_use(ri);
848
+ memarg_operands(mem, collector);
849
+ }
850
+ Inst::VecInsertLane {
851
+ rd,
852
+ ri,
853
+ rn,
854
+ lane_reg,
855
+ ..
856
+ } => {
857
+ collector.reg_reuse_def(rd, 1);
858
+ collector.reg_use(ri);
859
+ collector.reg_use(rn);
860
+ collector.reg_use(lane_reg);
861
+ }
862
+ Inst::VecInsertLaneUndef {
863
+ rd, rn, lane_reg, ..
864
+ } => {
865
+ collector.reg_def(rd);
866
+ collector.reg_use(rn);
867
+ collector.reg_use(lane_reg);
868
+ }
869
+ Inst::VecExtractLane {
870
+ rd, rn, lane_reg, ..
871
+ } => {
872
+ collector.reg_def(rd);
873
+ collector.reg_use(rn);
874
+ collector.reg_use(lane_reg);
875
+ }
876
+ Inst::VecInsertLaneImm { rd, ri, .. } => {
877
+ collector.reg_reuse_def(rd, 1);
878
+ collector.reg_use(ri);
879
+ }
880
+ Inst::VecReplicateLane { rd, rn, .. } => {
881
+ collector.reg_def(rd);
882
+ collector.reg_use(rn);
883
+ }
884
+ Inst::Extend { rd, rn, .. } => {
885
+ collector.reg_def(rd);
886
+ collector.reg_use(rn);
887
+ }
888
+ Inst::Call { link, info } => {
889
+ let CallInfo { uses, defs, .. } = &mut **info;
890
+ for CallArgPair { vreg, preg } in uses {
891
+ collector.reg_fixed_use(vreg, *preg);
892
+ }
893
+ for CallRetPair { vreg, preg } in defs {
894
+ collector.reg_fixed_def(vreg, *preg);
895
+ }
896
+ let mut clobbers = info.clobbers.clone();
897
+ clobbers.add(link.to_reg().to_real_reg().unwrap().into());
898
+ collector.reg_clobbers(clobbers);
899
+ }
900
+ Inst::CallInd { link, info } => {
901
+ let CallIndInfo { rn, uses, defs, .. } = &mut **info;
902
+ collector.reg_use(rn);
903
+ for CallArgPair { vreg, preg } in uses {
904
+ collector.reg_fixed_use(vreg, *preg);
905
+ }
906
+ for CallRetPair { vreg, preg } in defs {
907
+ collector.reg_fixed_def(vreg, *preg);
908
+ }
909
+ let mut clobbers = info.clobbers.clone();
910
+ clobbers.add(link.to_reg().to_real_reg().unwrap().into());
911
+ collector.reg_clobbers(clobbers);
912
+ }
913
+ Inst::Args { args } => {
914
+ for ArgPair { vreg, preg } in args {
915
+ collector.reg_fixed_def(vreg, *preg);
916
+ }
917
+ }
918
+ Inst::Rets { rets } => {
919
+ for RetPair { vreg, preg } in rets {
920
+ collector.reg_fixed_use(vreg, *preg);
921
+ }
922
+ }
923
+ Inst::Ret { .. } => {
924
+ // NOTE: we explicitly don't mark the link register as used here, as the use is only in
925
+ // the epilog where callee-save registers are restored.
926
+ }
927
+ Inst::Jump { .. } => {}
928
+ Inst::IndirectBr { rn, .. } => {
929
+ collector.reg_use(rn);
930
+ }
931
+ Inst::CondBr { .. } | Inst::OneWayCondBr { .. } => {}
932
+ Inst::Nop0 | Inst::Nop2 => {}
933
+ Inst::Debugtrap => {}
934
+ Inst::Trap { .. } => {}
935
+ Inst::TrapIf { .. } => {}
936
+ Inst::JTSequence { ridx, .. } => {
937
+ collector.reg_use(ridx);
938
+ collector.reg_fixed_nonallocatable(gpr_preg(1));
939
+ }
940
+ Inst::LoadSymbolReloc { rd, .. } => {
941
+ collector.reg_def(rd);
942
+ collector.reg_fixed_nonallocatable(gpr_preg(1));
943
+ }
944
+ Inst::LoadAddr { rd, mem } => {
945
+ collector.reg_def(rd);
946
+ memarg_operands(mem, collector);
947
+ }
948
+ Inst::Loop { body, .. } => {
949
+ // `reuse_def` constraints can't be permitted in a Loop instruction because the operand
950
+ // index will always be relative to the Loop instruction, not the individual
951
+ // instruction in the loop body. However, fixed-nonallocatable registers used with
952
+ // instructions that would have emitted `reuse_def` constraints are fine.
953
+ let mut collector = DenyReuseVisitor {
954
+ inner: collector.inner,
955
+ deny_reuse: true,
956
+ };
957
+ for inst in body {
958
+ s390x_get_operands(inst, &mut collector);
959
+ }
960
+ }
961
+ Inst::CondBreak { .. } => {}
962
+ Inst::VirtualSPOffsetAdj { .. } => {}
963
+ Inst::Unwind { .. } => {}
964
+ Inst::DummyUse { reg } => {
965
+ collector.reg_use(reg);
966
+ }
967
+ }
968
+ }
969
+
970
+ struct DenyReuseVisitor<'a, T> {
971
+ inner: &'a mut T,
972
+ deny_reuse: bool,
973
+ }
974
+
975
+ impl<T: OperandVisitor> OperandVisitor for DenyReuseVisitor<'_, T> {
976
+ fn add_operand(
977
+ &mut self,
978
+ reg: &mut Reg,
979
+ constraint: regalloc2::OperandConstraint,
980
+ kind: regalloc2::OperandKind,
981
+ pos: regalloc2::OperandPos,
982
+ ) {
983
+ debug_assert!(
984
+ !self.deny_reuse || !matches!(constraint, regalloc2::OperandConstraint::Reuse(_))
985
+ );
986
+ self.inner.add_operand(reg, constraint, kind, pos);
987
+ }
988
+
989
+ fn debug_assert_is_allocatable_preg(&self, reg: regalloc2::PReg, expected: bool) {
990
+ self.inner.debug_assert_is_allocatable_preg(reg, expected);
991
+ }
992
+
993
+ fn reg_clobbers(&mut self, regs: PRegSet) {
994
+ self.inner.reg_clobbers(regs);
995
+ }
996
+ }
997
+
998
+ //=============================================================================
999
+ // Instructions: misc functions and external interface
1000
+
1001
+ impl MachInst for Inst {
1002
+ type ABIMachineSpec = S390xMachineDeps;
1003
+ type LabelUse = LabelUse;
1004
+ const TRAP_OPCODE: &'static [u8] = &[0, 0];
1005
+
1006
+ fn get_operands(&mut self, collector: &mut impl OperandVisitor) {
1007
+ s390x_get_operands(
1008
+ self,
1009
+ &mut DenyReuseVisitor {
1010
+ inner: collector,
1011
+ deny_reuse: false,
1012
+ },
1013
+ );
1014
+ }
1015
+
1016
+ fn is_move(&self) -> Option<(Writable<Reg>, Reg)> {
1017
+ match self {
1018
+ &Inst::Mov32 { rd, rm } => Some((rd, rm)),
1019
+ &Inst::Mov64 { rd, rm } => Some((rd, rm)),
1020
+ &Inst::FpuMove32 { rd, rn } => Some((rd, rn)),
1021
+ &Inst::FpuMove64 { rd, rn } => Some((rd, rn)),
1022
+ &Inst::VecMov { rd, rn } => Some((rd, rn)),
1023
+ _ => None,
1024
+ }
1025
+ }
1026
+
1027
+ fn is_included_in_clobbers(&self) -> bool {
1028
+ // We exclude call instructions from the clobber-set when they are calls
1029
+ // from caller to callee with the same ABI. Such calls cannot possibly
1030
+ // force any new registers to be saved in the prologue, because anything
1031
+ // that the callee clobbers, the caller is also allowed to clobber. This
1032
+ // both saves work and enables us to more precisely follow the
1033
+ // half-caller-save, half-callee-save SysV ABI for some vector
1034
+ // registers.
1035
+ match self {
1036
+ &Inst::Args { .. } => false,
1037
+ &Inst::Call { ref info, .. } => info.caller_callconv != info.callee_callconv,
1038
+ &Inst::CallInd { ref info, .. } => info.caller_callconv != info.callee_callconv,
1039
+ _ => true,
1040
+ }
1041
+ }
1042
+
1043
+ fn is_trap(&self) -> bool {
1044
+ match self {
1045
+ Self::Trap { .. } => true,
1046
+ _ => false,
1047
+ }
1048
+ }
1049
+
1050
+ fn is_args(&self) -> bool {
1051
+ match self {
1052
+ Self::Args { .. } => true,
1053
+ _ => false,
1054
+ }
1055
+ }
1056
+
1057
+ fn is_term(&self) -> MachTerminator {
1058
+ match self {
1059
+ &Inst::Rets { .. } => MachTerminator::Ret,
1060
+ &Inst::Jump { .. } => MachTerminator::Uncond,
1061
+ &Inst::CondBr { .. } => MachTerminator::Cond,
1062
+ &Inst::OneWayCondBr { .. } => {
1063
+ // Explicitly invisible to CFG processing.
1064
+ MachTerminator::None
1065
+ }
1066
+ &Inst::IndirectBr { .. } => MachTerminator::Indirect,
1067
+ &Inst::JTSequence { .. } => MachTerminator::Indirect,
1068
+ _ => MachTerminator::None,
1069
+ }
1070
+ }
1071
+
1072
+ fn is_mem_access(&self) -> bool {
1073
+ panic!("TODO FILL ME OUT")
1074
+ }
1075
+
1076
+ fn is_safepoint(&self) -> bool {
1077
+ match self {
1078
+ &Inst::Call { .. }
1079
+ | &Inst::CallInd { .. }
1080
+ | &Inst::Trap { .. }
1081
+ | Inst::TrapIf { .. }
1082
+ | &Inst::CmpTrapRR { .. }
1083
+ | &Inst::CmpTrapRSImm16 { .. }
1084
+ | &Inst::CmpTrapRUImm16 { .. } => true,
1085
+ _ => false,
1086
+ }
1087
+ }
1088
+
1089
+ fn gen_move(to_reg: Writable<Reg>, from_reg: Reg, ty: Type) -> Inst {
1090
+ assert!(ty.bits() <= 128);
1091
+ if ty.bits() <= 32 {
1092
+ Inst::mov32(to_reg, from_reg)
1093
+ } else if ty.bits() <= 64 {
1094
+ Inst::mov64(to_reg, from_reg)
1095
+ } else {
1096
+ Inst::mov128(to_reg, from_reg)
1097
+ }
1098
+ }
1099
+
1100
+ fn gen_nop(preferred_size: usize) -> Inst {
1101
+ if preferred_size == 0 {
1102
+ Inst::Nop0
1103
+ } else {
1104
+ // We can't give a NOP (or any insn) < 2 bytes.
1105
+ assert!(preferred_size >= 2);
1106
+ Inst::Nop2
1107
+ }
1108
+ }
1109
+
1110
+ fn rc_for_type(ty: Type) -> CodegenResult<(&'static [RegClass], &'static [Type])> {
1111
+ match ty {
1112
+ types::I8 => Ok((&[RegClass::Int], &[types::I8])),
1113
+ types::I16 => Ok((&[RegClass::Int], &[types::I16])),
1114
+ types::I32 => Ok((&[RegClass::Int], &[types::I32])),
1115
+ types::I64 => Ok((&[RegClass::Int], &[types::I64])),
1116
+ types::R32 => panic!("32-bit reftype pointer should never be seen on s390x"),
1117
+ types::R64 => Ok((&[RegClass::Int], &[types::R64])),
1118
+ types::F32 => Ok((&[RegClass::Float], &[types::F32])),
1119
+ types::F64 => Ok((&[RegClass::Float], &[types::F64])),
1120
+ types::I128 => Ok((&[RegClass::Float], &[types::I128])),
1121
+ _ if ty.is_vector() && ty.bits() == 128 => Ok((&[RegClass::Float], &[types::I8X16])),
1122
+ _ => Err(CodegenError::Unsupported(format!(
1123
+ "Unexpected SSA-value type: {}",
1124
+ ty
1125
+ ))),
1126
+ }
1127
+ }
1128
+
1129
+ fn canonical_type_for_rc(rc: RegClass) -> Type {
1130
+ match rc {
1131
+ RegClass::Int => types::I64,
1132
+ RegClass::Float => types::I8X16,
1133
+ RegClass::Vector => unreachable!(),
1134
+ }
1135
+ }
1136
+
1137
+ fn gen_jump(target: MachLabel) -> Inst {
1138
+ Inst::Jump { dest: target }
1139
+ }
1140
+
1141
+ fn worst_case_size() -> CodeOffset {
1142
+ // The maximum size, in bytes, of any `Inst`'s emitted code. We have at least one case of
1143
+ // an 8-instruction sequence (saturating int-to-float conversions) with three embedded
1144
+ // 64-bit f64 constants.
1145
+ //
1146
+ // Note that inline jump-tables handle island/pool insertion separately, so we do not need
1147
+ // to account for them here (otherwise the worst case would be 2^31 * 4, clearly not
1148
+ // feasible for other reasons).
1149
+ 44
1150
+ }
1151
+
1152
+ fn ref_type_regclass(_: &settings::Flags) -> RegClass {
1153
+ RegClass::Int
1154
+ }
1155
+
1156
+ fn gen_dummy_use(reg: Reg) -> Inst {
1157
+ Inst::DummyUse { reg }
1158
+ }
1159
+
1160
+ fn function_alignment() -> FunctionAlignment {
1161
+ FunctionAlignment {
1162
+ minimum: 4,
1163
+ preferred: 4,
1164
+ }
1165
+ }
1166
+ }
1167
+
1168
+ //=============================================================================
1169
+ // Pretty-printing of instructions.
1170
+
1171
+ fn mem_finalize_for_show(mem: &MemArg, state: &EmitState, mi: MemInstType) -> (String, MemArg) {
1172
+ let (mem_insts, mem) = mem_finalize(mem, state, mi);
1173
+ let mut mem_str = mem_insts
1174
+ .into_iter()
1175
+ .map(|inst| {
1176
+ inst.print_with_state(&mut EmitState::default(), &mut AllocationConsumer::new(&[]))
1177
+ })
1178
+ .collect::<Vec<_>>()
1179
+ .join(" ; ");
1180
+ if !mem_str.is_empty() {
1181
+ mem_str += " ; ";
1182
+ }
1183
+
1184
+ (mem_str, mem)
1185
+ }
1186
+
1187
+ impl Inst {
1188
+ fn print_with_state(&self, state: &mut EmitState, allocs: &mut AllocationConsumer) -> String {
1189
+ let mut empty_allocs = AllocationConsumer::new(&[]);
1190
+
1191
+ match self {
1192
+ &Inst::Nop0 => "nop-zero-len".to_string(),
1193
+ &Inst::Nop2 => "nop".to_string(),
1194
+ &Inst::AluRRR { alu_op, rd, rn, rm } => {
1195
+ let rd = allocs.next_writable(rd);
1196
+ let rn = allocs.next(rn);
1197
+ let rm = allocs.next(rm);
1198
+
1199
+ let (op, have_rr) = match alu_op {
1200
+ ALUOp::Add32 => ("ark", true),
1201
+ ALUOp::Add64 => ("agrk", true),
1202
+ ALUOp::AddLogical32 => ("alrk", true),
1203
+ ALUOp::AddLogical64 => ("algrk", true),
1204
+ ALUOp::Sub32 => ("srk", true),
1205
+ ALUOp::Sub64 => ("sgrk", true),
1206
+ ALUOp::SubLogical32 => ("slrk", true),
1207
+ ALUOp::SubLogical64 => ("slgrk", true),
1208
+ ALUOp::Mul32 => ("msrkc", true),
1209
+ ALUOp::Mul64 => ("msgrkc", true),
1210
+ ALUOp::And32 => ("nrk", true),
1211
+ ALUOp::And64 => ("ngrk", true),
1212
+ ALUOp::Orr32 => ("ork", true),
1213
+ ALUOp::Orr64 => ("ogrk", true),
1214
+ ALUOp::Xor32 => ("xrk", true),
1215
+ ALUOp::Xor64 => ("xgrk", true),
1216
+ ALUOp::NotAnd32 => ("nnrk", false),
1217
+ ALUOp::NotAnd64 => ("nngrk", false),
1218
+ ALUOp::NotOrr32 => ("nork", false),
1219
+ ALUOp::NotOrr64 => ("nogrk", false),
1220
+ ALUOp::NotXor32 => ("nxrk", false),
1221
+ ALUOp::NotXor64 => ("nxgrk", false),
1222
+ ALUOp::AndNot32 => ("ncrk", false),
1223
+ ALUOp::AndNot64 => ("ncgrk", false),
1224
+ ALUOp::OrrNot32 => ("ocrk", false),
1225
+ ALUOp::OrrNot64 => ("ocgrk", false),
1226
+ _ => unreachable!(),
1227
+ };
1228
+ if have_rr && rd.to_reg() == rn {
1229
+ let inst = Inst::AluRR {
1230
+ alu_op,
1231
+ rd,
1232
+ ri: rd.to_reg(),
1233
+ rm,
1234
+ };
1235
+ return inst.print_with_state(state, &mut empty_allocs);
1236
+ }
1237
+ let rd = pretty_print_reg(rd.to_reg(), &mut empty_allocs);
1238
+ let rn = pretty_print_reg(rn, &mut empty_allocs);
1239
+ let rm = pretty_print_reg(rm, &mut empty_allocs);
1240
+ format!("{} {}, {}, {}", op, rd, rn, rm)
1241
+ }
1242
+ &Inst::AluRRSImm16 {
1243
+ alu_op,
1244
+ rd,
1245
+ rn,
1246
+ imm,
1247
+ } => {
1248
+ let rd = allocs.next_writable(rd);
1249
+ let rn = allocs.next(rn);
1250
+
1251
+ if rd.to_reg() == rn {
1252
+ let inst = Inst::AluRSImm16 {
1253
+ alu_op,
1254
+ rd,
1255
+ ri: rd.to_reg(),
1256
+ imm,
1257
+ };
1258
+ return inst.print_with_state(state, &mut empty_allocs);
1259
+ }
1260
+ let op = match alu_op {
1261
+ ALUOp::Add32 => "ahik",
1262
+ ALUOp::Add64 => "aghik",
1263
+ _ => unreachable!(),
1264
+ };
1265
+ let rd = pretty_print_reg(rd.to_reg(), &mut empty_allocs);
1266
+ let rn = pretty_print_reg(rn, &mut empty_allocs);
1267
+ format!("{} {}, {}, {}", op, rd, rn, imm)
1268
+ }
1269
+ &Inst::AluRR { alu_op, rd, ri, rm } => {
1270
+ let op = match alu_op {
1271
+ ALUOp::Add32 => "ar",
1272
+ ALUOp::Add64 => "agr",
1273
+ ALUOp::Add64Ext32 => "agfr",
1274
+ ALUOp::AddLogical32 => "alr",
1275
+ ALUOp::AddLogical64 => "algr",
1276
+ ALUOp::AddLogical64Ext32 => "algfr",
1277
+ ALUOp::Sub32 => "sr",
1278
+ ALUOp::Sub64 => "sgr",
1279
+ ALUOp::Sub64Ext32 => "sgfr",
1280
+ ALUOp::SubLogical32 => "slr",
1281
+ ALUOp::SubLogical64 => "slgr",
1282
+ ALUOp::SubLogical64Ext32 => "slgfr",
1283
+ ALUOp::Mul32 => "msr",
1284
+ ALUOp::Mul64 => "msgr",
1285
+ ALUOp::Mul64Ext32 => "msgfr",
1286
+ ALUOp::And32 => "nr",
1287
+ ALUOp::And64 => "ngr",
1288
+ ALUOp::Orr32 => "or",
1289
+ ALUOp::Orr64 => "ogr",
1290
+ ALUOp::Xor32 => "xr",
1291
+ ALUOp::Xor64 => "xgr",
1292
+ _ => unreachable!(),
1293
+ };
1294
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1295
+ let rm = pretty_print_reg(rm, allocs);
1296
+ format!("{} {}, {}", op, rd, rm)
1297
+ }
1298
+ &Inst::AluRX {
1299
+ alu_op,
1300
+ rd,
1301
+ ri,
1302
+ ref mem,
1303
+ } => {
1304
+ let (opcode_rx, opcode_rxy) = match alu_op {
1305
+ ALUOp::Add32 => (Some("a"), Some("ay")),
1306
+ ALUOp::Add32Ext16 => (Some("ah"), Some("ahy")),
1307
+ ALUOp::Add64 => (None, Some("ag")),
1308
+ ALUOp::Add64Ext16 => (None, Some("agh")),
1309
+ ALUOp::Add64Ext32 => (None, Some("agf")),
1310
+ ALUOp::AddLogical32 => (Some("al"), Some("aly")),
1311
+ ALUOp::AddLogical64 => (None, Some("alg")),
1312
+ ALUOp::AddLogical64Ext32 => (None, Some("algf")),
1313
+ ALUOp::Sub32 => (Some("s"), Some("sy")),
1314
+ ALUOp::Sub32Ext16 => (Some("sh"), Some("shy")),
1315
+ ALUOp::Sub64 => (None, Some("sg")),
1316
+ ALUOp::Sub64Ext16 => (None, Some("sgh")),
1317
+ ALUOp::Sub64Ext32 => (None, Some("sgf")),
1318
+ ALUOp::SubLogical32 => (Some("sl"), Some("sly")),
1319
+ ALUOp::SubLogical64 => (None, Some("slg")),
1320
+ ALUOp::SubLogical64Ext32 => (None, Some("slgf")),
1321
+ ALUOp::Mul32 => (Some("ms"), Some("msy")),
1322
+ ALUOp::Mul32Ext16 => (Some("mh"), Some("mhy")),
1323
+ ALUOp::Mul64 => (None, Some("msg")),
1324
+ ALUOp::Mul64Ext16 => (None, Some("mgh")),
1325
+ ALUOp::Mul64Ext32 => (None, Some("msgf")),
1326
+ ALUOp::And32 => (Some("n"), Some("ny")),
1327
+ ALUOp::And64 => (None, Some("ng")),
1328
+ ALUOp::Orr32 => (Some("o"), Some("oy")),
1329
+ ALUOp::Orr64 => (None, Some("og")),
1330
+ ALUOp::Xor32 => (Some("x"), Some("xy")),
1331
+ ALUOp::Xor64 => (None, Some("xg")),
1332
+ _ => unreachable!(),
1333
+ };
1334
+
1335
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1336
+ let mem = mem.with_allocs(allocs);
1337
+ let (mem_str, mem) = mem_finalize_for_show(
1338
+ &mem,
1339
+ state,
1340
+ MemInstType {
1341
+ have_d12: opcode_rx.is_some(),
1342
+ have_d20: opcode_rxy.is_some(),
1343
+ have_pcrel: false,
1344
+ have_unaligned_pcrel: false,
1345
+ have_index: true,
1346
+ },
1347
+ );
1348
+ let op = match &mem {
1349
+ &MemArg::BXD12 { .. } => opcode_rx,
1350
+ &MemArg::BXD20 { .. } => opcode_rxy,
1351
+ _ => unreachable!(),
1352
+ };
1353
+ let mem = mem.pretty_print_default();
1354
+
1355
+ format!("{}{} {}, {}", mem_str, op.unwrap(), rd, mem)
1356
+ }
1357
+ &Inst::AluRSImm16 {
1358
+ alu_op,
1359
+ rd,
1360
+ ri,
1361
+ imm,
1362
+ } => {
1363
+ let op = match alu_op {
1364
+ ALUOp::Add32 => "ahi",
1365
+ ALUOp::Add64 => "aghi",
1366
+ ALUOp::Mul32 => "mhi",
1367
+ ALUOp::Mul64 => "mghi",
1368
+ _ => unreachable!(),
1369
+ };
1370
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1371
+ format!("{} {}, {}", op, rd, imm)
1372
+ }
1373
+ &Inst::AluRSImm32 {
1374
+ alu_op,
1375
+ rd,
1376
+ ri,
1377
+ imm,
1378
+ } => {
1379
+ let op = match alu_op {
1380
+ ALUOp::Add32 => "afi",
1381
+ ALUOp::Add64 => "agfi",
1382
+ ALUOp::Mul32 => "msfi",
1383
+ ALUOp::Mul64 => "msgfi",
1384
+ _ => unreachable!(),
1385
+ };
1386
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1387
+ format!("{} {}, {}", op, rd, imm)
1388
+ }
1389
+ &Inst::AluRUImm32 {
1390
+ alu_op,
1391
+ rd,
1392
+ ri,
1393
+ imm,
1394
+ } => {
1395
+ let op = match alu_op {
1396
+ ALUOp::AddLogical32 => "alfi",
1397
+ ALUOp::AddLogical64 => "algfi",
1398
+ ALUOp::SubLogical32 => "slfi",
1399
+ ALUOp::SubLogical64 => "slgfi",
1400
+ _ => unreachable!(),
1401
+ };
1402
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1403
+ format!("{} {}, {}", op, rd, imm)
1404
+ }
1405
+ &Inst::AluRUImm16Shifted {
1406
+ alu_op,
1407
+ rd,
1408
+ ri,
1409
+ imm,
1410
+ } => {
1411
+ let op = match (alu_op, imm.shift) {
1412
+ (ALUOp::And32, 0) => "nill",
1413
+ (ALUOp::And32, 1) => "nilh",
1414
+ (ALUOp::And64, 0) => "nill",
1415
+ (ALUOp::And64, 1) => "nilh",
1416
+ (ALUOp::And64, 2) => "nihl",
1417
+ (ALUOp::And64, 3) => "nihh",
1418
+ (ALUOp::Orr32, 0) => "oill",
1419
+ (ALUOp::Orr32, 1) => "oilh",
1420
+ (ALUOp::Orr64, 0) => "oill",
1421
+ (ALUOp::Orr64, 1) => "oilh",
1422
+ (ALUOp::Orr64, 2) => "oihl",
1423
+ (ALUOp::Orr64, 3) => "oihh",
1424
+ _ => unreachable!(),
1425
+ };
1426
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1427
+ format!("{} {}, {}", op, rd, imm.bits)
1428
+ }
1429
+ &Inst::AluRUImm32Shifted {
1430
+ alu_op,
1431
+ rd,
1432
+ ri,
1433
+ imm,
1434
+ } => {
1435
+ let op = match (alu_op, imm.shift) {
1436
+ (ALUOp::And32, 0) => "nilf",
1437
+ (ALUOp::And64, 0) => "nilf",
1438
+ (ALUOp::And64, 1) => "nihf",
1439
+ (ALUOp::Orr32, 0) => "oilf",
1440
+ (ALUOp::Orr64, 0) => "oilf",
1441
+ (ALUOp::Orr64, 1) => "oihf",
1442
+ (ALUOp::Xor32, 0) => "xilf",
1443
+ (ALUOp::Xor64, 0) => "xilf",
1444
+ (ALUOp::Xor64, 1) => "xihf",
1445
+ _ => unreachable!(),
1446
+ };
1447
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1448
+ format!("{} {}, {}", op, rd, imm.bits)
1449
+ }
1450
+ &Inst::SMulWide { rd, rn, rm } => {
1451
+ let op = "mgrk";
1452
+ let rn = pretty_print_reg(rn, allocs);
1453
+ let rm = pretty_print_reg(rm, allocs);
1454
+ let rd = pretty_print_regpair(rd.to_regpair(), allocs);
1455
+ format!("{} {}, {}, {}", op, rd, rn, rm)
1456
+ }
1457
+ &Inst::UMulWide { rd, ri, rn } => {
1458
+ let op = "mlgr";
1459
+ let rn = pretty_print_reg(rn, allocs);
1460
+ let rd = pretty_print_regpair_mod_lo(rd, ri, allocs);
1461
+ format!("{} {}, {}", op, rd, rn)
1462
+ }
1463
+ &Inst::SDivMod32 { rd, ri, rn } => {
1464
+ let op = "dsgfr";
1465
+ let rn = pretty_print_reg(rn, allocs);
1466
+ let rd = pretty_print_regpair_mod_lo(rd, ri, allocs);
1467
+ format!("{} {}, {}", op, rd, rn)
1468
+ }
1469
+ &Inst::SDivMod64 { rd, ri, rn } => {
1470
+ let op = "dsgr";
1471
+ let rn = pretty_print_reg(rn, allocs);
1472
+ let rd = pretty_print_regpair_mod_lo(rd, ri, allocs);
1473
+ format!("{} {}, {}", op, rd, rn)
1474
+ }
1475
+ &Inst::UDivMod32 { rd, ri, rn } => {
1476
+ let op = "dlr";
1477
+ let rn = pretty_print_reg(rn, allocs);
1478
+ let rd = pretty_print_regpair_mod(rd, ri, allocs);
1479
+ format!("{} {}, {}", op, rd, rn)
1480
+ }
1481
+ &Inst::UDivMod64 { rd, ri, rn } => {
1482
+ let op = "dlgr";
1483
+ let rn = pretty_print_reg(rn, allocs);
1484
+ let rd = pretty_print_regpair_mod(rd, ri, allocs);
1485
+ format!("{} {}, {}", op, rd, rn)
1486
+ }
1487
+ &Inst::Flogr { rd, rn } => {
1488
+ let op = "flogr";
1489
+ let rn = pretty_print_reg(rn, allocs);
1490
+ let rd = pretty_print_regpair(rd.to_regpair(), allocs);
1491
+ format!("{} {}, {}", op, rd, rn)
1492
+ }
1493
+ &Inst::ShiftRR {
1494
+ shift_op,
1495
+ rd,
1496
+ rn,
1497
+ shift_imm,
1498
+ shift_reg,
1499
+ } => {
1500
+ let op = match shift_op {
1501
+ ShiftOp::RotL32 => "rll",
1502
+ ShiftOp::RotL64 => "rllg",
1503
+ ShiftOp::LShL32 => "sllk",
1504
+ ShiftOp::LShL64 => "sllg",
1505
+ ShiftOp::LShR32 => "srlk",
1506
+ ShiftOp::LShR64 => "srlg",
1507
+ ShiftOp::AShR32 => "srak",
1508
+ ShiftOp::AShR64 => "srag",
1509
+ };
1510
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1511
+ let rn = pretty_print_reg(rn, allocs);
1512
+ let shift_reg = if shift_reg != zero_reg() {
1513
+ format!("({})", pretty_print_reg(shift_reg, allocs))
1514
+ } else {
1515
+ "".to_string()
1516
+ };
1517
+ format!("{} {}, {}, {}{}", op, rd, rn, shift_imm, shift_reg)
1518
+ }
1519
+ &Inst::RxSBG {
1520
+ op,
1521
+ rd,
1522
+ ri,
1523
+ rn,
1524
+ start_bit,
1525
+ end_bit,
1526
+ rotate_amt,
1527
+ } => {
1528
+ let op = match op {
1529
+ RxSBGOp::Insert => "risbgn",
1530
+ RxSBGOp::And => "rnsbg",
1531
+ RxSBGOp::Or => "rosbg",
1532
+ RxSBGOp::Xor => "rxsbg",
1533
+ };
1534
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1535
+ let rn = pretty_print_reg(rn, allocs);
1536
+ format!(
1537
+ "{} {}, {}, {}, {}, {}",
1538
+ op,
1539
+ rd,
1540
+ rn,
1541
+ start_bit,
1542
+ end_bit,
1543
+ (rotate_amt as u8) & 63
1544
+ )
1545
+ }
1546
+ &Inst::RxSBGTest {
1547
+ op,
1548
+ rd,
1549
+ rn,
1550
+ start_bit,
1551
+ end_bit,
1552
+ rotate_amt,
1553
+ } => {
1554
+ let op = match op {
1555
+ RxSBGOp::And => "rnsbg",
1556
+ RxSBGOp::Or => "rosbg",
1557
+ RxSBGOp::Xor => "rxsbg",
1558
+ _ => unreachable!(),
1559
+ };
1560
+ let rd = pretty_print_reg(rd, allocs);
1561
+ let rn = pretty_print_reg(rn, allocs);
1562
+ format!(
1563
+ "{} {}, {}, {}, {}, {}",
1564
+ op,
1565
+ rd,
1566
+ rn,
1567
+ start_bit | 0x80,
1568
+ end_bit,
1569
+ (rotate_amt as u8) & 63
1570
+ )
1571
+ }
1572
+ &Inst::UnaryRR { op, rd, rn } => {
1573
+ let (op, extra) = match op {
1574
+ UnaryOp::Abs32 => ("lpr", ""),
1575
+ UnaryOp::Abs64 => ("lpgr", ""),
1576
+ UnaryOp::Abs64Ext32 => ("lpgfr", ""),
1577
+ UnaryOp::Neg32 => ("lcr", ""),
1578
+ UnaryOp::Neg64 => ("lcgr", ""),
1579
+ UnaryOp::Neg64Ext32 => ("lcgfr", ""),
1580
+ UnaryOp::PopcntByte => ("popcnt", ""),
1581
+ UnaryOp::PopcntReg => ("popcnt", ", 8"),
1582
+ UnaryOp::BSwap32 => ("lrvr", ""),
1583
+ UnaryOp::BSwap64 => ("lrvgr", ""),
1584
+ };
1585
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1586
+ let rn = pretty_print_reg(rn, allocs);
1587
+ format!("{} {}, {}{}", op, rd, rn, extra)
1588
+ }
1589
+ &Inst::CmpRR { op, rn, rm } => {
1590
+ let op = match op {
1591
+ CmpOp::CmpS32 => "cr",
1592
+ CmpOp::CmpS64 => "cgr",
1593
+ CmpOp::CmpS64Ext32 => "cgfr",
1594
+ CmpOp::CmpL32 => "clr",
1595
+ CmpOp::CmpL64 => "clgr",
1596
+ CmpOp::CmpL64Ext32 => "clgfr",
1597
+ _ => unreachable!(),
1598
+ };
1599
+ let rn = pretty_print_reg(rn, allocs);
1600
+ let rm = pretty_print_reg(rm, allocs);
1601
+ format!("{} {}, {}", op, rn, rm)
1602
+ }
1603
+ &Inst::CmpRX { op, rn, ref mem } => {
1604
+ let (opcode_rx, opcode_rxy, opcode_ril) = match op {
1605
+ CmpOp::CmpS32 => (Some("c"), Some("cy"), Some("crl")),
1606
+ CmpOp::CmpS32Ext16 => (Some("ch"), Some("chy"), Some("chrl")),
1607
+ CmpOp::CmpS64 => (None, Some("cg"), Some("cgrl")),
1608
+ CmpOp::CmpS64Ext16 => (None, Some("cgh"), Some("cghrl")),
1609
+ CmpOp::CmpS64Ext32 => (None, Some("cgf"), Some("cgfrl")),
1610
+ CmpOp::CmpL32 => (Some("cl"), Some("cly"), Some("clrl")),
1611
+ CmpOp::CmpL32Ext16 => (None, None, Some("clhrl")),
1612
+ CmpOp::CmpL64 => (None, Some("clg"), Some("clgrl")),
1613
+ CmpOp::CmpL64Ext16 => (None, None, Some("clghrl")),
1614
+ CmpOp::CmpL64Ext32 => (None, Some("clgf"), Some("clgfrl")),
1615
+ };
1616
+
1617
+ let rn = pretty_print_reg(rn, allocs);
1618
+ let mem = mem.with_allocs(allocs);
1619
+ let (mem_str, mem) = mem_finalize_for_show(
1620
+ &mem,
1621
+ state,
1622
+ MemInstType {
1623
+ have_d12: opcode_rx.is_some(),
1624
+ have_d20: opcode_rxy.is_some(),
1625
+ have_pcrel: opcode_ril.is_some(),
1626
+ have_unaligned_pcrel: false,
1627
+ have_index: true,
1628
+ },
1629
+ );
1630
+ let op = match &mem {
1631
+ &MemArg::BXD12 { .. } => opcode_rx,
1632
+ &MemArg::BXD20 { .. } => opcode_rxy,
1633
+ &MemArg::Label { .. } | &MemArg::Symbol { .. } => opcode_ril,
1634
+ _ => unreachable!(),
1635
+ };
1636
+ let mem = mem.pretty_print_default();
1637
+
1638
+ format!("{}{} {}, {}", mem_str, op.unwrap(), rn, mem)
1639
+ }
1640
+ &Inst::CmpRSImm16 { op, rn, imm } => {
1641
+ let op = match op {
1642
+ CmpOp::CmpS32 => "chi",
1643
+ CmpOp::CmpS64 => "cghi",
1644
+ _ => unreachable!(),
1645
+ };
1646
+ let rn = pretty_print_reg(rn, allocs);
1647
+ format!("{} {}, {}", op, rn, imm)
1648
+ }
1649
+ &Inst::CmpRSImm32 { op, rn, imm } => {
1650
+ let op = match op {
1651
+ CmpOp::CmpS32 => "cfi",
1652
+ CmpOp::CmpS64 => "cgfi",
1653
+ _ => unreachable!(),
1654
+ };
1655
+ let rn = pretty_print_reg(rn, allocs);
1656
+ format!("{} {}, {}", op, rn, imm)
1657
+ }
1658
+ &Inst::CmpRUImm32 { op, rn, imm } => {
1659
+ let op = match op {
1660
+ CmpOp::CmpL32 => "clfi",
1661
+ CmpOp::CmpL64 => "clgfi",
1662
+ _ => unreachable!(),
1663
+ };
1664
+ let rn = pretty_print_reg(rn, allocs);
1665
+ format!("{} {}, {}", op, rn, imm)
1666
+ }
1667
+ &Inst::CmpTrapRR {
1668
+ op, rn, rm, cond, ..
1669
+ } => {
1670
+ let op = match op {
1671
+ CmpOp::CmpS32 => "crt",
1672
+ CmpOp::CmpS64 => "cgrt",
1673
+ CmpOp::CmpL32 => "clrt",
1674
+ CmpOp::CmpL64 => "clgrt",
1675
+ _ => unreachable!(),
1676
+ };
1677
+ let rn = pretty_print_reg(rn, allocs);
1678
+ let rm = pretty_print_reg(rm, allocs);
1679
+ let cond = cond.pretty_print_default();
1680
+ format!("{}{} {}, {}", op, cond, rn, rm)
1681
+ }
1682
+ &Inst::CmpTrapRSImm16 {
1683
+ op, rn, imm, cond, ..
1684
+ } => {
1685
+ let op = match op {
1686
+ CmpOp::CmpS32 => "cit",
1687
+ CmpOp::CmpS64 => "cgit",
1688
+ _ => unreachable!(),
1689
+ };
1690
+ let rn = pretty_print_reg(rn, allocs);
1691
+ let cond = cond.pretty_print_default();
1692
+ format!("{}{} {}, {}", op, cond, rn, imm)
1693
+ }
1694
+ &Inst::CmpTrapRUImm16 {
1695
+ op, rn, imm, cond, ..
1696
+ } => {
1697
+ let op = match op {
1698
+ CmpOp::CmpL32 => "clfit",
1699
+ CmpOp::CmpL64 => "clgit",
1700
+ _ => unreachable!(),
1701
+ };
1702
+ let rn = pretty_print_reg(rn, allocs);
1703
+ let cond = cond.pretty_print_default();
1704
+ format!("{}{} {}, {}", op, cond, rn, imm)
1705
+ }
1706
+ &Inst::AtomicRmw {
1707
+ alu_op,
1708
+ rd,
1709
+ rn,
1710
+ ref mem,
1711
+ } => {
1712
+ let op = match alu_op {
1713
+ ALUOp::Add32 => "laa",
1714
+ ALUOp::Add64 => "laag",
1715
+ ALUOp::AddLogical32 => "laal",
1716
+ ALUOp::AddLogical64 => "laalg",
1717
+ ALUOp::And32 => "lan",
1718
+ ALUOp::And64 => "lang",
1719
+ ALUOp::Orr32 => "lao",
1720
+ ALUOp::Orr64 => "laog",
1721
+ ALUOp::Xor32 => "lax",
1722
+ ALUOp::Xor64 => "laxg",
1723
+ _ => unreachable!(),
1724
+ };
1725
+
1726
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1727
+ let rn = pretty_print_reg(rn, allocs);
1728
+ let mem = mem.with_allocs(allocs);
1729
+ let (mem_str, mem) = mem_finalize_for_show(
1730
+ &mem,
1731
+ state,
1732
+ MemInstType {
1733
+ have_d12: false,
1734
+ have_d20: true,
1735
+ have_pcrel: false,
1736
+ have_unaligned_pcrel: false,
1737
+ have_index: false,
1738
+ },
1739
+ );
1740
+ let mem = mem.pretty_print_default();
1741
+ format!("{}{} {}, {}, {}", mem_str, op, rd, rn, mem)
1742
+ }
1743
+ &Inst::AtomicCas32 {
1744
+ rd,
1745
+ ri,
1746
+ rn,
1747
+ ref mem,
1748
+ }
1749
+ | &Inst::AtomicCas64 {
1750
+ rd,
1751
+ ri,
1752
+ rn,
1753
+ ref mem,
1754
+ } => {
1755
+ let (opcode_rs, opcode_rsy) = match self {
1756
+ &Inst::AtomicCas32 { .. } => (Some("cs"), Some("csy")),
1757
+ &Inst::AtomicCas64 { .. } => (None, Some("csg")),
1758
+ _ => unreachable!(),
1759
+ };
1760
+
1761
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
1762
+ let rn = pretty_print_reg(rn, allocs);
1763
+ let mem = mem.with_allocs(allocs);
1764
+ let (mem_str, mem) = mem_finalize_for_show(
1765
+ &mem,
1766
+ state,
1767
+ MemInstType {
1768
+ have_d12: opcode_rs.is_some(),
1769
+ have_d20: opcode_rsy.is_some(),
1770
+ have_pcrel: false,
1771
+ have_unaligned_pcrel: false,
1772
+ have_index: false,
1773
+ },
1774
+ );
1775
+ let op = match &mem {
1776
+ &MemArg::BXD12 { .. } => opcode_rs,
1777
+ &MemArg::BXD20 { .. } => opcode_rsy,
1778
+ _ => unreachable!(),
1779
+ };
1780
+ let mem = mem.pretty_print_default();
1781
+
1782
+ format!("{}{} {}, {}, {}", mem_str, op.unwrap(), rd, rn, mem)
1783
+ }
1784
+ &Inst::Fence => "bcr 14, 0".to_string(),
1785
+ &Inst::Load32 { rd, ref mem }
1786
+ | &Inst::Load32ZExt8 { rd, ref mem }
1787
+ | &Inst::Load32SExt8 { rd, ref mem }
1788
+ | &Inst::Load32ZExt16 { rd, ref mem }
1789
+ | &Inst::Load32SExt16 { rd, ref mem }
1790
+ | &Inst::Load64 { rd, ref mem }
1791
+ | &Inst::Load64ZExt8 { rd, ref mem }
1792
+ | &Inst::Load64SExt8 { rd, ref mem }
1793
+ | &Inst::Load64ZExt16 { rd, ref mem }
1794
+ | &Inst::Load64SExt16 { rd, ref mem }
1795
+ | &Inst::Load64ZExt32 { rd, ref mem }
1796
+ | &Inst::Load64SExt32 { rd, ref mem }
1797
+ | &Inst::LoadRev16 { rd, ref mem }
1798
+ | &Inst::LoadRev32 { rd, ref mem }
1799
+ | &Inst::LoadRev64 { rd, ref mem } => {
1800
+ let (opcode_rx, opcode_rxy, opcode_ril) = match self {
1801
+ &Inst::Load32 { .. } => (Some("l"), Some("ly"), Some("lrl")),
1802
+ &Inst::Load32ZExt8 { .. } => (None, Some("llc"), None),
1803
+ &Inst::Load32SExt8 { .. } => (None, Some("lb"), None),
1804
+ &Inst::Load32ZExt16 { .. } => (None, Some("llh"), Some("llhrl")),
1805
+ &Inst::Load32SExt16 { .. } => (Some("lh"), Some("lhy"), Some("lhrl")),
1806
+ &Inst::Load64 { .. } => (None, Some("lg"), Some("lgrl")),
1807
+ &Inst::Load64ZExt8 { .. } => (None, Some("llgc"), None),
1808
+ &Inst::Load64SExt8 { .. } => (None, Some("lgb"), None),
1809
+ &Inst::Load64ZExt16 { .. } => (None, Some("llgh"), Some("llghrl")),
1810
+ &Inst::Load64SExt16 { .. } => (None, Some("lgh"), Some("lghrl")),
1811
+ &Inst::Load64ZExt32 { .. } => (None, Some("llgf"), Some("llgfrl")),
1812
+ &Inst::Load64SExt32 { .. } => (None, Some("lgf"), Some("lgfrl")),
1813
+ &Inst::LoadRev16 { .. } => (None, Some("lrvh"), None),
1814
+ &Inst::LoadRev32 { .. } => (None, Some("lrv"), None),
1815
+ &Inst::LoadRev64 { .. } => (None, Some("lrvg"), None),
1816
+ _ => unreachable!(),
1817
+ };
1818
+
1819
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1820
+ let mem = mem.with_allocs(allocs);
1821
+ let (mem_str, mem) = mem_finalize_for_show(
1822
+ &mem,
1823
+ state,
1824
+ MemInstType {
1825
+ have_d12: opcode_rx.is_some(),
1826
+ have_d20: opcode_rxy.is_some(),
1827
+ have_pcrel: opcode_ril.is_some(),
1828
+ have_unaligned_pcrel: false,
1829
+ have_index: true,
1830
+ },
1831
+ );
1832
+ let op = match &mem {
1833
+ &MemArg::BXD12 { .. } => opcode_rx,
1834
+ &MemArg::BXD20 { .. } => opcode_rxy,
1835
+ &MemArg::Label { .. } | &MemArg::Symbol { .. } => opcode_ril,
1836
+ _ => unreachable!(),
1837
+ };
1838
+ let mem = mem.pretty_print_default();
1839
+ format!("{}{} {}, {}", mem_str, op.unwrap(), rd, mem)
1840
+ }
1841
+ &Inst::Store8 { rd, ref mem }
1842
+ | &Inst::Store16 { rd, ref mem }
1843
+ | &Inst::Store32 { rd, ref mem }
1844
+ | &Inst::Store64 { rd, ref mem }
1845
+ | &Inst::StoreRev16 { rd, ref mem }
1846
+ | &Inst::StoreRev32 { rd, ref mem }
1847
+ | &Inst::StoreRev64 { rd, ref mem } => {
1848
+ let (opcode_rx, opcode_rxy, opcode_ril) = match self {
1849
+ &Inst::Store8 { .. } => (Some("stc"), Some("stcy"), None),
1850
+ &Inst::Store16 { .. } => (Some("sth"), Some("sthy"), Some("sthrl")),
1851
+ &Inst::Store32 { .. } => (Some("st"), Some("sty"), Some("strl")),
1852
+ &Inst::Store64 { .. } => (None, Some("stg"), Some("stgrl")),
1853
+ &Inst::StoreRev16 { .. } => (None, Some("strvh"), None),
1854
+ &Inst::StoreRev32 { .. } => (None, Some("strv"), None),
1855
+ &Inst::StoreRev64 { .. } => (None, Some("strvg"), None),
1856
+ _ => unreachable!(),
1857
+ };
1858
+
1859
+ let rd = pretty_print_reg(rd, allocs);
1860
+ let mem = mem.with_allocs(allocs);
1861
+ let (mem_str, mem) = mem_finalize_for_show(
1862
+ &mem,
1863
+ state,
1864
+ MemInstType {
1865
+ have_d12: opcode_rx.is_some(),
1866
+ have_d20: opcode_rxy.is_some(),
1867
+ have_pcrel: opcode_ril.is_some(),
1868
+ have_unaligned_pcrel: false,
1869
+ have_index: true,
1870
+ },
1871
+ );
1872
+ let op = match &mem {
1873
+ &MemArg::BXD12 { .. } => opcode_rx,
1874
+ &MemArg::BXD20 { .. } => opcode_rxy,
1875
+ &MemArg::Label { .. } | &MemArg::Symbol { .. } => opcode_ril,
1876
+ _ => unreachable!(),
1877
+ };
1878
+ let mem = mem.pretty_print_default();
1879
+
1880
+ format!("{}{} {}, {}", mem_str, op.unwrap(), rd, mem)
1881
+ }
1882
+ &Inst::StoreImm8 { imm, ref mem } => {
1883
+ let mem = mem.with_allocs(allocs);
1884
+ let (mem_str, mem) = mem_finalize_for_show(
1885
+ &mem,
1886
+ state,
1887
+ MemInstType {
1888
+ have_d12: true,
1889
+ have_d20: true,
1890
+ have_pcrel: false,
1891
+ have_unaligned_pcrel: false,
1892
+ have_index: false,
1893
+ },
1894
+ );
1895
+ let op = match &mem {
1896
+ &MemArg::BXD12 { .. } => "mvi",
1897
+ &MemArg::BXD20 { .. } => "mviy",
1898
+ _ => unreachable!(),
1899
+ };
1900
+ let mem = mem.pretty_print_default();
1901
+
1902
+ format!("{}{} {}, {}", mem_str, op, mem, imm)
1903
+ }
1904
+ &Inst::StoreImm16 { imm, ref mem }
1905
+ | &Inst::StoreImm32SExt16 { imm, ref mem }
1906
+ | &Inst::StoreImm64SExt16 { imm, ref mem } => {
1907
+ let mem = mem.with_allocs(allocs);
1908
+ let (mem_str, mem) = mem_finalize_for_show(
1909
+ &mem,
1910
+ state,
1911
+ MemInstType {
1912
+ have_d12: false,
1913
+ have_d20: true,
1914
+ have_pcrel: false,
1915
+ have_unaligned_pcrel: false,
1916
+ have_index: false,
1917
+ },
1918
+ );
1919
+ let op = match self {
1920
+ &Inst::StoreImm16 { .. } => "mvhhi",
1921
+ &Inst::StoreImm32SExt16 { .. } => "mvhi",
1922
+ &Inst::StoreImm64SExt16 { .. } => "mvghi",
1923
+ _ => unreachable!(),
1924
+ };
1925
+ let mem = mem.pretty_print_default();
1926
+
1927
+ format!("{}{} {}, {}", mem_str, op, mem, imm)
1928
+ }
1929
+ &Inst::Mvc {
1930
+ ref dst,
1931
+ ref src,
1932
+ len_minus_one,
1933
+ } => {
1934
+ let dst = dst.with_allocs(allocs);
1935
+ let src = src.with_allocs(allocs);
1936
+ format!(
1937
+ "mvc {}({},{}), {}({})",
1938
+ dst.disp.pretty_print_default(),
1939
+ len_minus_one,
1940
+ show_reg(dst.base),
1941
+ src.disp.pretty_print_default(),
1942
+ show_reg(src.base)
1943
+ )
1944
+ }
1945
+ &Inst::LoadMultiple64 { rt, rt2, ref mem } => {
1946
+ let mem = mem.with_allocs(allocs);
1947
+ let (mem_str, mem) = mem_finalize_for_show(
1948
+ &mem,
1949
+ state,
1950
+ MemInstType {
1951
+ have_d12: false,
1952
+ have_d20: true,
1953
+ have_pcrel: false,
1954
+ have_unaligned_pcrel: false,
1955
+ have_index: false,
1956
+ },
1957
+ );
1958
+ let rt = pretty_print_reg(rt.to_reg(), &mut empty_allocs);
1959
+ let rt2 = pretty_print_reg(rt2.to_reg(), &mut empty_allocs);
1960
+ let mem = mem.pretty_print_default();
1961
+ format!("{}lmg {}, {}, {}", mem_str, rt, rt2, mem)
1962
+ }
1963
+ &Inst::StoreMultiple64 { rt, rt2, ref mem } => {
1964
+ let mem = mem.with_allocs(allocs);
1965
+ let (mem_str, mem) = mem_finalize_for_show(
1966
+ &mem,
1967
+ state,
1968
+ MemInstType {
1969
+ have_d12: false,
1970
+ have_d20: true,
1971
+ have_pcrel: false,
1972
+ have_unaligned_pcrel: false,
1973
+ have_index: false,
1974
+ },
1975
+ );
1976
+ let rt = pretty_print_reg(rt, &mut empty_allocs);
1977
+ let rt2 = pretty_print_reg(rt2, &mut empty_allocs);
1978
+ let mem = mem.pretty_print_default();
1979
+ format!("{}stmg {}, {}, {}", mem_str, rt, rt2, mem)
1980
+ }
1981
+ &Inst::Mov64 { rd, rm } => {
1982
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1983
+ let rm = pretty_print_reg(rm, allocs);
1984
+ format!("lgr {}, {}", rd, rm)
1985
+ }
1986
+ &Inst::MovPReg { rd, rm } => {
1987
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1988
+ let rm = show_reg(rm.into());
1989
+ format!("lgr {}, {}", rd, rm)
1990
+ }
1991
+ &Inst::Mov32 { rd, rm } => {
1992
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1993
+ let rm = pretty_print_reg(rm, allocs);
1994
+ format!("lr {}, {}", rd, rm)
1995
+ }
1996
+ &Inst::Mov32Imm { rd, ref imm } => {
1997
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
1998
+ format!("iilf {}, {}", rd, imm)
1999
+ }
2000
+ &Inst::Mov32SImm16 { rd, ref imm } => {
2001
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2002
+ format!("lhi {}, {}", rd, imm)
2003
+ }
2004
+ &Inst::Mov64SImm16 { rd, ref imm } => {
2005
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2006
+ format!("lghi {}, {}", rd, imm)
2007
+ }
2008
+ &Inst::Mov64SImm32 { rd, ref imm } => {
2009
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2010
+ format!("lgfi {}, {}", rd, imm)
2011
+ }
2012
+ &Inst::Mov64UImm16Shifted { rd, ref imm } => {
2013
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2014
+ let op = match imm.shift {
2015
+ 0 => "llill",
2016
+ 1 => "llilh",
2017
+ 2 => "llihl",
2018
+ 3 => "llihh",
2019
+ _ => unreachable!(),
2020
+ };
2021
+ format!("{} {}, {}", op, rd, imm.bits)
2022
+ }
2023
+ &Inst::Mov64UImm32Shifted { rd, ref imm } => {
2024
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2025
+ let op = match imm.shift {
2026
+ 0 => "llilf",
2027
+ 1 => "llihf",
2028
+ _ => unreachable!(),
2029
+ };
2030
+ format!("{} {}, {}", op, rd, imm.bits)
2031
+ }
2032
+ &Inst::Insert64UImm16Shifted { rd, ri, ref imm } => {
2033
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2034
+ let op = match imm.shift {
2035
+ 0 => "iill",
2036
+ 1 => "iilh",
2037
+ 2 => "iihl",
2038
+ 3 => "iihh",
2039
+ _ => unreachable!(),
2040
+ };
2041
+ format!("{} {}, {}", op, rd, imm.bits)
2042
+ }
2043
+ &Inst::Insert64UImm32Shifted { rd, ri, ref imm } => {
2044
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2045
+ let op = match imm.shift {
2046
+ 0 => "iilf",
2047
+ 1 => "iihf",
2048
+ _ => unreachable!(),
2049
+ };
2050
+ format!("{} {}, {}", op, rd, imm.bits)
2051
+ }
2052
+ &Inst::LoadAR { rd, ar } => {
2053
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2054
+ format!("ear {}, %a{}", rd, ar)
2055
+ }
2056
+ &Inst::InsertAR { rd, ri, ar } => {
2057
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2058
+ format!("ear {}, %a{}", rd, ar)
2059
+ }
2060
+ &Inst::CMov32 { rd, cond, ri, rm } => {
2061
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2062
+ let rm = pretty_print_reg(rm, allocs);
2063
+ let cond = cond.pretty_print_default();
2064
+ format!("locr{} {}, {}", cond, rd, rm)
2065
+ }
2066
+ &Inst::CMov64 { rd, cond, ri, rm } => {
2067
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2068
+ let rm = pretty_print_reg(rm, allocs);
2069
+ let cond = cond.pretty_print_default();
2070
+ format!("locgr{} {}, {}", cond, rd, rm)
2071
+ }
2072
+ &Inst::CMov32SImm16 {
2073
+ rd,
2074
+ cond,
2075
+ ri,
2076
+ ref imm,
2077
+ } => {
2078
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2079
+ let cond = cond.pretty_print_default();
2080
+ format!("lochi{} {}, {}", cond, rd, imm)
2081
+ }
2082
+ &Inst::CMov64SImm16 {
2083
+ rd,
2084
+ cond,
2085
+ ri,
2086
+ ref imm,
2087
+ } => {
2088
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2089
+ let cond = cond.pretty_print_default();
2090
+ format!("locghi{} {}, {}", cond, rd, imm)
2091
+ }
2092
+ &Inst::FpuMove32 { rd, rn } => {
2093
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2094
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2095
+ if rd_fpr.is_some() && rn_fpr.is_some() {
2096
+ format!("ler {}, {}", rd_fpr.unwrap(), rn_fpr.unwrap())
2097
+ } else {
2098
+ format!("vlr {}, {}", rd, rn)
2099
+ }
2100
+ }
2101
+ &Inst::FpuMove64 { rd, rn } => {
2102
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2103
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2104
+ if rd_fpr.is_some() && rn_fpr.is_some() {
2105
+ format!("ldr {}, {}", rd_fpr.unwrap(), rn_fpr.unwrap())
2106
+ } else {
2107
+ format!("vlr {}, {}", rd, rn)
2108
+ }
2109
+ }
2110
+ &Inst::FpuCMov32 { rd, cond, ri, rm } => {
2111
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2112
+ let _ri = allocs.next(ri);
2113
+ let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2114
+ if rd_fpr.is_some() && rm_fpr.is_some() {
2115
+ let cond = cond.invert().pretty_print_default();
2116
+ format!("j{} 6 ; ler {}, {}", cond, rd_fpr.unwrap(), rm_fpr.unwrap())
2117
+ } else {
2118
+ let cond = cond.invert().pretty_print_default();
2119
+ format!("j{} 10 ; vlr {}, {}", cond, rd, rm)
2120
+ }
2121
+ }
2122
+ &Inst::FpuCMov64 { rd, cond, ri, rm } => {
2123
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2124
+ let _ri = allocs.next(ri);
2125
+ let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2126
+ if rd_fpr.is_some() && rm_fpr.is_some() {
2127
+ let cond = cond.invert().pretty_print_default();
2128
+ format!("j{} 6 ; ldr {}, {}", cond, rd_fpr.unwrap(), rm_fpr.unwrap())
2129
+ } else {
2130
+ let cond = cond.invert().pretty_print_default();
2131
+ format!("j{} 10 ; vlr {}, {}", cond, rd, rm)
2132
+ }
2133
+ }
2134
+ &Inst::FpuRR { fpu_op, rd, rn } => {
2135
+ let (op, op_fpr) = match fpu_op {
2136
+ FPUOp1::Abs32 => ("wflpsb", Some("lpebr")),
2137
+ FPUOp1::Abs64 => ("wflpdb", Some("lpdbr")),
2138
+ FPUOp1::Abs32x4 => ("vflpsb", None),
2139
+ FPUOp1::Abs64x2 => ("vflpdb", None),
2140
+ FPUOp1::Neg32 => ("wflcsb", Some("lcebr")),
2141
+ FPUOp1::Neg64 => ("wflcdb", Some("lcdbr")),
2142
+ FPUOp1::Neg32x4 => ("vflcsb", None),
2143
+ FPUOp1::Neg64x2 => ("vflcdb", None),
2144
+ FPUOp1::NegAbs32 => ("wflnsb", Some("lnebr")),
2145
+ FPUOp1::NegAbs64 => ("wflndb", Some("lndbr")),
2146
+ FPUOp1::NegAbs32x4 => ("vflnsb", None),
2147
+ FPUOp1::NegAbs64x2 => ("vflndb", None),
2148
+ FPUOp1::Sqrt32 => ("wfsqsb", Some("sqebr")),
2149
+ FPUOp1::Sqrt64 => ("wfsqdb", Some("sqdbr")),
2150
+ FPUOp1::Sqrt32x4 => ("vfsqsb", None),
2151
+ FPUOp1::Sqrt64x2 => ("vfsqdb", None),
2152
+ FPUOp1::Cvt32To64 => ("wldeb", Some("ldebr")),
2153
+ FPUOp1::Cvt32x4To64x2 => ("vldeb", None),
2154
+ };
2155
+
2156
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2157
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2158
+ if op_fpr.is_some() && rd_fpr.is_some() && rn_fpr.is_some() {
2159
+ format!(
2160
+ "{} {}, {}",
2161
+ op_fpr.unwrap(),
2162
+ rd_fpr.unwrap(),
2163
+ rn_fpr.unwrap()
2164
+ )
2165
+ } else if op.starts_with('w') {
2166
+ format!("{} {}, {}", op, rd_fpr.unwrap_or(rd), rn_fpr.unwrap_or(rn))
2167
+ } else {
2168
+ format!("{} {}, {}", op, rd, rn)
2169
+ }
2170
+ }
2171
+ &Inst::FpuRRR { fpu_op, rd, rn, rm } => {
2172
+ let (op, opt_m6, op_fpr) = match fpu_op {
2173
+ FPUOp2::Add32 => ("wfasb", "", Some("aebr")),
2174
+ FPUOp2::Add64 => ("wfadb", "", Some("adbr")),
2175
+ FPUOp2::Add32x4 => ("vfasb", "", None),
2176
+ FPUOp2::Add64x2 => ("vfadb", "", None),
2177
+ FPUOp2::Sub32 => ("wfssb", "", Some("sebr")),
2178
+ FPUOp2::Sub64 => ("wfsdb", "", Some("sdbr")),
2179
+ FPUOp2::Sub32x4 => ("vfssb", "", None),
2180
+ FPUOp2::Sub64x2 => ("vfsdb", "", None),
2181
+ FPUOp2::Mul32 => ("wfmsb", "", Some("meebr")),
2182
+ FPUOp2::Mul64 => ("wfmdb", "", Some("mdbr")),
2183
+ FPUOp2::Mul32x4 => ("vfmsb", "", None),
2184
+ FPUOp2::Mul64x2 => ("vfmdb", "", None),
2185
+ FPUOp2::Div32 => ("wfdsb", "", Some("debr")),
2186
+ FPUOp2::Div64 => ("wfddb", "", Some("ddbr")),
2187
+ FPUOp2::Div32x4 => ("vfdsb", "", None),
2188
+ FPUOp2::Div64x2 => ("vfddb", "", None),
2189
+ FPUOp2::Max32 => ("wfmaxsb", ", 1", None),
2190
+ FPUOp2::Max64 => ("wfmaxdb", ", 1", None),
2191
+ FPUOp2::Max32x4 => ("vfmaxsb", ", 1", None),
2192
+ FPUOp2::Max64x2 => ("vfmaxdb", ", 1", None),
2193
+ FPUOp2::Min32 => ("wfminsb", ", 1", None),
2194
+ FPUOp2::Min64 => ("wfmindb", ", 1", None),
2195
+ FPUOp2::Min32x4 => ("vfminsb", ", 1", None),
2196
+ FPUOp2::Min64x2 => ("vfmindb", ", 1", None),
2197
+ FPUOp2::MaxPseudo32 => ("wfmaxsb", ", 3", None),
2198
+ FPUOp2::MaxPseudo64 => ("wfmaxdb", ", 3", None),
2199
+ FPUOp2::MaxPseudo32x4 => ("vfmaxsb", ", 3", None),
2200
+ FPUOp2::MaxPseudo64x2 => ("vfmaxdb", ", 3", None),
2201
+ FPUOp2::MinPseudo32 => ("wfminsb", ", 3", None),
2202
+ FPUOp2::MinPseudo64 => ("wfmindb", ", 3", None),
2203
+ FPUOp2::MinPseudo32x4 => ("vfminsb", ", 3", None),
2204
+ FPUOp2::MinPseudo64x2 => ("vfmindb", ", 3", None),
2205
+ };
2206
+
2207
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2208
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2209
+ let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2210
+ if op_fpr.is_some() && rd == rn && rd_fpr.is_some() && rm_fpr.is_some() {
2211
+ format!(
2212
+ "{} {}, {}",
2213
+ op_fpr.unwrap(),
2214
+ rd_fpr.unwrap(),
2215
+ rm_fpr.unwrap()
2216
+ )
2217
+ } else if op.starts_with('w') {
2218
+ format!(
2219
+ "{} {}, {}, {}{}",
2220
+ op,
2221
+ rd_fpr.unwrap_or(rd),
2222
+ rn_fpr.unwrap_or(rn),
2223
+ rm_fpr.unwrap_or(rm),
2224
+ opt_m6
2225
+ )
2226
+ } else {
2227
+ format!("{} {}, {}, {}{}", op, rd, rn, rm, opt_m6)
2228
+ }
2229
+ }
2230
+ &Inst::FpuRRRR {
2231
+ fpu_op,
2232
+ rd,
2233
+ rn,
2234
+ rm,
2235
+ ra,
2236
+ } => {
2237
+ let (op, op_fpr) = match fpu_op {
2238
+ FPUOp3::MAdd32 => ("wfmasb", Some("maebr")),
2239
+ FPUOp3::MAdd64 => ("wfmadb", Some("madbr")),
2240
+ FPUOp3::MAdd32x4 => ("vfmasb", None),
2241
+ FPUOp3::MAdd64x2 => ("vfmadb", None),
2242
+ FPUOp3::MSub32 => ("wfmssb", Some("msebr")),
2243
+ FPUOp3::MSub64 => ("wfmsdb", Some("msdbr")),
2244
+ FPUOp3::MSub32x4 => ("vfmssb", None),
2245
+ FPUOp3::MSub64x2 => ("vfmsdb", None),
2246
+ };
2247
+
2248
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2249
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2250
+ let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2251
+ let (ra, ra_fpr) = pretty_print_fpr(ra, allocs);
2252
+ if op_fpr.is_some()
2253
+ && rd == ra
2254
+ && rd_fpr.is_some()
2255
+ && rn_fpr.is_some()
2256
+ && rm_fpr.is_some()
2257
+ {
2258
+ format!(
2259
+ "{} {}, {}, {}",
2260
+ op_fpr.unwrap(),
2261
+ rd_fpr.unwrap(),
2262
+ rn_fpr.unwrap(),
2263
+ rm_fpr.unwrap()
2264
+ )
2265
+ } else if op.starts_with('w') {
2266
+ format!(
2267
+ "{} {}, {}, {}, {}",
2268
+ op,
2269
+ rd_fpr.unwrap_or(rd),
2270
+ rn_fpr.unwrap_or(rn),
2271
+ rm_fpr.unwrap_or(rm),
2272
+ ra_fpr.unwrap_or(ra)
2273
+ )
2274
+ } else {
2275
+ format!("{} {}, {}, {}, {}", op, rd, rn, rm, ra)
2276
+ }
2277
+ }
2278
+ &Inst::FpuCmp32 { rn, rm } => {
2279
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2280
+ let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2281
+ if rn_fpr.is_some() && rm_fpr.is_some() {
2282
+ format!("cebr {}, {}", rn_fpr.unwrap(), rm_fpr.unwrap())
2283
+ } else {
2284
+ format!("wfcsb {}, {}", rn_fpr.unwrap_or(rn), rm_fpr.unwrap_or(rm))
2285
+ }
2286
+ }
2287
+ &Inst::FpuCmp64 { rn, rm } => {
2288
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2289
+ let (rm, rm_fpr) = pretty_print_fpr(rm, allocs);
2290
+ if rn_fpr.is_some() && rm_fpr.is_some() {
2291
+ format!("cdbr {}, {}", rn_fpr.unwrap(), rm_fpr.unwrap())
2292
+ } else {
2293
+ format!("wfcdb {}, {}", rn_fpr.unwrap_or(rn), rm_fpr.unwrap_or(rm))
2294
+ }
2295
+ }
2296
+ &Inst::LoadFpuConst32 { rd, const_data } => {
2297
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2298
+ let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2299
+ if rd_fpr.is_some() {
2300
+ format!(
2301
+ "bras {}, 8 ; data.f32 {} ; le {}, 0({})",
2302
+ tmp,
2303
+ f32::from_bits(const_data),
2304
+ rd_fpr.unwrap(),
2305
+ tmp
2306
+ )
2307
+ } else {
2308
+ format!(
2309
+ "bras {}, 8 ; data.f32 {} ; vlef {}, 0({}), 0",
2310
+ tmp,
2311
+ f32::from_bits(const_data),
2312
+ rd,
2313
+ tmp
2314
+ )
2315
+ }
2316
+ }
2317
+ &Inst::LoadFpuConst64 { rd, const_data } => {
2318
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2319
+ let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2320
+ if rd_fpr.is_some() {
2321
+ format!(
2322
+ "bras {}, 12 ; data.f64 {} ; ld {}, 0({})",
2323
+ tmp,
2324
+ f64::from_bits(const_data),
2325
+ rd_fpr.unwrap(),
2326
+ tmp
2327
+ )
2328
+ } else {
2329
+ format!(
2330
+ "bras {}, 12 ; data.f64 {} ; vleg {}, 0({}), 0",
2331
+ tmp,
2332
+ f64::from_bits(const_data),
2333
+ rd,
2334
+ tmp
2335
+ )
2336
+ }
2337
+ }
2338
+ &Inst::FpuRound { op, mode, rd, rn } => {
2339
+ let mode = match mode {
2340
+ FpuRoundMode::Current => 0,
2341
+ FpuRoundMode::ToNearest => 1,
2342
+ FpuRoundMode::ShorterPrecision => 3,
2343
+ FpuRoundMode::ToNearestTiesToEven => 4,
2344
+ FpuRoundMode::ToZero => 5,
2345
+ FpuRoundMode::ToPosInfinity => 6,
2346
+ FpuRoundMode::ToNegInfinity => 7,
2347
+ };
2348
+ let (opcode, opcode_fpr) = match op {
2349
+ FpuRoundOp::Cvt64To32 => ("wledb", Some("ledbra")),
2350
+ FpuRoundOp::Cvt64x2To32x4 => ("vledb", None),
2351
+ FpuRoundOp::Round32 => ("wfisb", Some("fiebr")),
2352
+ FpuRoundOp::Round64 => ("wfidb", Some("fidbr")),
2353
+ FpuRoundOp::Round32x4 => ("vfisb", None),
2354
+ FpuRoundOp::Round64x2 => ("vfidb", None),
2355
+ FpuRoundOp::ToSInt32 => ("wcfeb", None),
2356
+ FpuRoundOp::ToSInt64 => ("wcgdb", None),
2357
+ FpuRoundOp::ToUInt32 => ("wclfeb", None),
2358
+ FpuRoundOp::ToUInt64 => ("wclgdb", None),
2359
+ FpuRoundOp::ToSInt32x4 => ("vcfeb", None),
2360
+ FpuRoundOp::ToSInt64x2 => ("vcgdb", None),
2361
+ FpuRoundOp::ToUInt32x4 => ("vclfeb", None),
2362
+ FpuRoundOp::ToUInt64x2 => ("vclgdb", None),
2363
+ FpuRoundOp::FromSInt32 => ("wcefb", None),
2364
+ FpuRoundOp::FromSInt64 => ("wcdgb", None),
2365
+ FpuRoundOp::FromUInt32 => ("wcelfb", None),
2366
+ FpuRoundOp::FromUInt64 => ("wcdlgb", None),
2367
+ FpuRoundOp::FromSInt32x4 => ("vcefb", None),
2368
+ FpuRoundOp::FromSInt64x2 => ("vcdgb", None),
2369
+ FpuRoundOp::FromUInt32x4 => ("vcelfb", None),
2370
+ FpuRoundOp::FromUInt64x2 => ("vcdlgb", None),
2371
+ };
2372
+
2373
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2374
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
2375
+ if opcode_fpr.is_some() && rd_fpr.is_some() && rn_fpr.is_some() {
2376
+ format!(
2377
+ "{} {}, {}, {}{}",
2378
+ opcode_fpr.unwrap(),
2379
+ rd_fpr.unwrap(),
2380
+ mode,
2381
+ rn_fpr.unwrap(),
2382
+ if opcode_fpr.unwrap().ends_with('a') {
2383
+ ", 0"
2384
+ } else {
2385
+ ""
2386
+ }
2387
+ )
2388
+ } else if opcode.starts_with('w') {
2389
+ format!(
2390
+ "{} {}, {}, 0, {}",
2391
+ opcode,
2392
+ rd_fpr.unwrap_or(rd),
2393
+ rn_fpr.unwrap_or(rn),
2394
+ mode
2395
+ )
2396
+ } else {
2397
+ format!("{} {}, {}, 0, {}", opcode, rd, rn, mode)
2398
+ }
2399
+ }
2400
+ &Inst::VecRRR { op, rd, rn, rm } => {
2401
+ let op = match op {
2402
+ VecBinaryOp::Add8x16 => "vab",
2403
+ VecBinaryOp::Add16x8 => "vah",
2404
+ VecBinaryOp::Add32x4 => "vaf",
2405
+ VecBinaryOp::Add64x2 => "vag",
2406
+ VecBinaryOp::Add128 => "vaq",
2407
+ VecBinaryOp::Sub8x16 => "vsb",
2408
+ VecBinaryOp::Sub16x8 => "vsh",
2409
+ VecBinaryOp::Sub32x4 => "vsf",
2410
+ VecBinaryOp::Sub64x2 => "vsg",
2411
+ VecBinaryOp::Sub128 => "vsq",
2412
+ VecBinaryOp::Mul8x16 => "vmlb",
2413
+ VecBinaryOp::Mul16x8 => "vmlhw",
2414
+ VecBinaryOp::Mul32x4 => "vmlf",
2415
+ VecBinaryOp::UMulHi8x16 => "vmlhb",
2416
+ VecBinaryOp::UMulHi16x8 => "vmlhh",
2417
+ VecBinaryOp::UMulHi32x4 => "vmlhf",
2418
+ VecBinaryOp::SMulHi8x16 => "vmhb",
2419
+ VecBinaryOp::SMulHi16x8 => "vmhh",
2420
+ VecBinaryOp::SMulHi32x4 => "vmhf",
2421
+ VecBinaryOp::UMulEven8x16 => "vmleb",
2422
+ VecBinaryOp::UMulEven16x8 => "vmleh",
2423
+ VecBinaryOp::UMulEven32x4 => "vmlef",
2424
+ VecBinaryOp::SMulEven8x16 => "vmeb",
2425
+ VecBinaryOp::SMulEven16x8 => "vmeh",
2426
+ VecBinaryOp::SMulEven32x4 => "vmef",
2427
+ VecBinaryOp::UMulOdd8x16 => "vmlob",
2428
+ VecBinaryOp::UMulOdd16x8 => "vmloh",
2429
+ VecBinaryOp::UMulOdd32x4 => "vmlof",
2430
+ VecBinaryOp::SMulOdd8x16 => "vmob",
2431
+ VecBinaryOp::SMulOdd16x8 => "vmoh",
2432
+ VecBinaryOp::SMulOdd32x4 => "vmof",
2433
+ VecBinaryOp::UMax8x16 => "vmxlb",
2434
+ VecBinaryOp::UMax16x8 => "vmxlh",
2435
+ VecBinaryOp::UMax32x4 => "vmxlf",
2436
+ VecBinaryOp::UMax64x2 => "vmxlg",
2437
+ VecBinaryOp::SMax8x16 => "vmxb",
2438
+ VecBinaryOp::SMax16x8 => "vmxh",
2439
+ VecBinaryOp::SMax32x4 => "vmxf",
2440
+ VecBinaryOp::SMax64x2 => "vmxg",
2441
+ VecBinaryOp::UMin8x16 => "vmnlb",
2442
+ VecBinaryOp::UMin16x8 => "vmnlh",
2443
+ VecBinaryOp::UMin32x4 => "vmnlf",
2444
+ VecBinaryOp::UMin64x2 => "vmnlg",
2445
+ VecBinaryOp::SMin8x16 => "vmnb",
2446
+ VecBinaryOp::SMin16x8 => "vmnh",
2447
+ VecBinaryOp::SMin32x4 => "vmnf",
2448
+ VecBinaryOp::SMin64x2 => "vmng",
2449
+ VecBinaryOp::UAvg8x16 => "vavglb",
2450
+ VecBinaryOp::UAvg16x8 => "vavglh",
2451
+ VecBinaryOp::UAvg32x4 => "vavglf",
2452
+ VecBinaryOp::UAvg64x2 => "vavglg",
2453
+ VecBinaryOp::SAvg8x16 => "vavgb",
2454
+ VecBinaryOp::SAvg16x8 => "vavgh",
2455
+ VecBinaryOp::SAvg32x4 => "vavgf",
2456
+ VecBinaryOp::SAvg64x2 => "vavgg",
2457
+ VecBinaryOp::And128 => "vn",
2458
+ VecBinaryOp::Orr128 => "vo",
2459
+ VecBinaryOp::Xor128 => "vx",
2460
+ VecBinaryOp::NotAnd128 => "vnn",
2461
+ VecBinaryOp::NotOrr128 => "vno",
2462
+ VecBinaryOp::NotXor128 => "vnx",
2463
+ VecBinaryOp::AndNot128 => "vnc",
2464
+ VecBinaryOp::OrrNot128 => "voc",
2465
+ VecBinaryOp::BitPermute128 => "vbperm",
2466
+ VecBinaryOp::LShLByByte128 => "vslb",
2467
+ VecBinaryOp::LShRByByte128 => "vsrlb",
2468
+ VecBinaryOp::AShRByByte128 => "vsrab",
2469
+ VecBinaryOp::LShLByBit128 => "vsl",
2470
+ VecBinaryOp::LShRByBit128 => "vsrl",
2471
+ VecBinaryOp::AShRByBit128 => "vsra",
2472
+ VecBinaryOp::Pack16x8 => "vpkh",
2473
+ VecBinaryOp::Pack32x4 => "vpkf",
2474
+ VecBinaryOp::Pack64x2 => "vpkg",
2475
+ VecBinaryOp::PackUSat16x8 => "vpklsh",
2476
+ VecBinaryOp::PackUSat32x4 => "vpklsf",
2477
+ VecBinaryOp::PackUSat64x2 => "vpklsg",
2478
+ VecBinaryOp::PackSSat16x8 => "vpksh",
2479
+ VecBinaryOp::PackSSat32x4 => "vpksf",
2480
+ VecBinaryOp::PackSSat64x2 => "vpksg",
2481
+ VecBinaryOp::MergeLow8x16 => "vmrlb",
2482
+ VecBinaryOp::MergeLow16x8 => "vmrlh",
2483
+ VecBinaryOp::MergeLow32x4 => "vmrlf",
2484
+ VecBinaryOp::MergeLow64x2 => "vmrlg",
2485
+ VecBinaryOp::MergeHigh8x16 => "vmrhb",
2486
+ VecBinaryOp::MergeHigh16x8 => "vmrhh",
2487
+ VecBinaryOp::MergeHigh32x4 => "vmrhf",
2488
+ VecBinaryOp::MergeHigh64x2 => "vmrhg",
2489
+ };
2490
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2491
+ let rn = pretty_print_reg(rn, allocs);
2492
+ let rm = pretty_print_reg(rm, allocs);
2493
+ format!("{} {}, {}, {}", op, rd, rn, rm)
2494
+ }
2495
+ &Inst::VecRR { op, rd, rn } => {
2496
+ let op = match op {
2497
+ VecUnaryOp::Abs8x16 => "vlpb",
2498
+ VecUnaryOp::Abs16x8 => "vlph",
2499
+ VecUnaryOp::Abs32x4 => "vlpf",
2500
+ VecUnaryOp::Abs64x2 => "vlpg",
2501
+ VecUnaryOp::Neg8x16 => "vlcb",
2502
+ VecUnaryOp::Neg16x8 => "vlch",
2503
+ VecUnaryOp::Neg32x4 => "vlcf",
2504
+ VecUnaryOp::Neg64x2 => "vlcg",
2505
+ VecUnaryOp::Popcnt8x16 => "vpopctb",
2506
+ VecUnaryOp::Popcnt16x8 => "vpopcth",
2507
+ VecUnaryOp::Popcnt32x4 => "vpopctf",
2508
+ VecUnaryOp::Popcnt64x2 => "vpopctg",
2509
+ VecUnaryOp::Clz8x16 => "vclzb",
2510
+ VecUnaryOp::Clz16x8 => "vclzh",
2511
+ VecUnaryOp::Clz32x4 => "vclzf",
2512
+ VecUnaryOp::Clz64x2 => "vclzg",
2513
+ VecUnaryOp::Ctz8x16 => "vctzb",
2514
+ VecUnaryOp::Ctz16x8 => "vctzh",
2515
+ VecUnaryOp::Ctz32x4 => "vctzf",
2516
+ VecUnaryOp::Ctz64x2 => "vctzg",
2517
+ VecUnaryOp::UnpackULow8x16 => "vupllb",
2518
+ VecUnaryOp::UnpackULow16x8 => "vupllh",
2519
+ VecUnaryOp::UnpackULow32x4 => "vupllf",
2520
+ VecUnaryOp::UnpackUHigh8x16 => "vuplhb",
2521
+ VecUnaryOp::UnpackUHigh16x8 => "vuplhh",
2522
+ VecUnaryOp::UnpackUHigh32x4 => "vuplhf",
2523
+ VecUnaryOp::UnpackSLow8x16 => "vuplb",
2524
+ VecUnaryOp::UnpackSLow16x8 => "vuplh",
2525
+ VecUnaryOp::UnpackSLow32x4 => "vuplf",
2526
+ VecUnaryOp::UnpackSHigh8x16 => "vuphb",
2527
+ VecUnaryOp::UnpackSHigh16x8 => "vuphh",
2528
+ VecUnaryOp::UnpackSHigh32x4 => "vuphf",
2529
+ };
2530
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2531
+ let rn = pretty_print_reg(rn, allocs);
2532
+ format!("{} {}, {}", op, rd, rn)
2533
+ }
2534
+ &Inst::VecShiftRR {
2535
+ shift_op,
2536
+ rd,
2537
+ rn,
2538
+ shift_imm,
2539
+ shift_reg,
2540
+ } => {
2541
+ let op = match shift_op {
2542
+ VecShiftOp::RotL8x16 => "verllb",
2543
+ VecShiftOp::RotL16x8 => "verllh",
2544
+ VecShiftOp::RotL32x4 => "verllf",
2545
+ VecShiftOp::RotL64x2 => "verllg",
2546
+ VecShiftOp::LShL8x16 => "veslb",
2547
+ VecShiftOp::LShL16x8 => "veslh",
2548
+ VecShiftOp::LShL32x4 => "veslf",
2549
+ VecShiftOp::LShL64x2 => "veslg",
2550
+ VecShiftOp::LShR8x16 => "vesrlb",
2551
+ VecShiftOp::LShR16x8 => "vesrlh",
2552
+ VecShiftOp::LShR32x4 => "vesrlf",
2553
+ VecShiftOp::LShR64x2 => "vesrlg",
2554
+ VecShiftOp::AShR8x16 => "vesrab",
2555
+ VecShiftOp::AShR16x8 => "vesrah",
2556
+ VecShiftOp::AShR32x4 => "vesraf",
2557
+ VecShiftOp::AShR64x2 => "vesrag",
2558
+ };
2559
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2560
+ let rn = pretty_print_reg(rn, allocs);
2561
+ let shift_reg = if shift_reg != zero_reg() {
2562
+ format!("({})", pretty_print_reg(shift_reg, allocs))
2563
+ } else {
2564
+ "".to_string()
2565
+ };
2566
+ format!("{} {}, {}, {}{}", op, rd, rn, shift_imm, shift_reg)
2567
+ }
2568
+ &Inst::VecSelect { rd, rn, rm, ra } => {
2569
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2570
+ let rn = pretty_print_reg(rn, allocs);
2571
+ let rm = pretty_print_reg(rm, allocs);
2572
+ let ra = pretty_print_reg(ra, allocs);
2573
+ format!("vsel {}, {}, {}, {}", rd, rn, rm, ra)
2574
+ }
2575
+ &Inst::VecPermute { rd, rn, rm, ra } => {
2576
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2577
+ let rn = pretty_print_reg(rn, allocs);
2578
+ let rm = pretty_print_reg(rm, allocs);
2579
+ let ra = pretty_print_reg(ra, allocs);
2580
+ format!("vperm {}, {}, {}, {}", rd, rn, rm, ra)
2581
+ }
2582
+ &Inst::VecPermuteDWImm {
2583
+ rd,
2584
+ rn,
2585
+ rm,
2586
+ idx1,
2587
+ idx2,
2588
+ } => {
2589
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2590
+ let rn = pretty_print_reg(rn, allocs);
2591
+ let rm = pretty_print_reg(rm, allocs);
2592
+ let m4 = (idx1 & 1) * 4 + (idx2 & 1);
2593
+ format!("vpdi {}, {}, {}, {}", rd, rn, rm, m4)
2594
+ }
2595
+ &Inst::VecIntCmp { op, rd, rn, rm } | &Inst::VecIntCmpS { op, rd, rn, rm } => {
2596
+ let op = match op {
2597
+ VecIntCmpOp::CmpEq8x16 => "vceqb",
2598
+ VecIntCmpOp::CmpEq16x8 => "vceqh",
2599
+ VecIntCmpOp::CmpEq32x4 => "vceqf",
2600
+ VecIntCmpOp::CmpEq64x2 => "vceqg",
2601
+ VecIntCmpOp::SCmpHi8x16 => "vchb",
2602
+ VecIntCmpOp::SCmpHi16x8 => "vchh",
2603
+ VecIntCmpOp::SCmpHi32x4 => "vchf",
2604
+ VecIntCmpOp::SCmpHi64x2 => "vchg",
2605
+ VecIntCmpOp::UCmpHi8x16 => "vchlb",
2606
+ VecIntCmpOp::UCmpHi16x8 => "vchlh",
2607
+ VecIntCmpOp::UCmpHi32x4 => "vchlf",
2608
+ VecIntCmpOp::UCmpHi64x2 => "vchlg",
2609
+ };
2610
+ let s = match self {
2611
+ &Inst::VecIntCmp { .. } => "",
2612
+ &Inst::VecIntCmpS { .. } => "s",
2613
+ _ => unreachable!(),
2614
+ };
2615
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2616
+ let rn = pretty_print_reg(rn, allocs);
2617
+ let rm = pretty_print_reg(rm, allocs);
2618
+ format!("{}{} {}, {}, {}", op, s, rd, rn, rm)
2619
+ }
2620
+ &Inst::VecFloatCmp { op, rd, rn, rm } | &Inst::VecFloatCmpS { op, rd, rn, rm } => {
2621
+ let op = match op {
2622
+ VecFloatCmpOp::CmpEq32x4 => "vfcesb",
2623
+ VecFloatCmpOp::CmpEq64x2 => "vfcedb",
2624
+ VecFloatCmpOp::CmpHi32x4 => "vfchsb",
2625
+ VecFloatCmpOp::CmpHi64x2 => "vfchdb",
2626
+ VecFloatCmpOp::CmpHiEq32x4 => "vfchesb",
2627
+ VecFloatCmpOp::CmpHiEq64x2 => "vfchedb",
2628
+ };
2629
+ let s = match self {
2630
+ &Inst::VecFloatCmp { .. } => "",
2631
+ &Inst::VecFloatCmpS { .. } => "s",
2632
+ _ => unreachable!(),
2633
+ };
2634
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2635
+ let rn = pretty_print_reg(rn, allocs);
2636
+ let rm = pretty_print_reg(rm, allocs);
2637
+ format!("{}{} {}, {}, {}", op, s, rd, rn, rm)
2638
+ }
2639
+ &Inst::VecInt128SCmpHi { tmp, rn, rm } | &Inst::VecInt128UCmpHi { tmp, rn, rm } => {
2640
+ let op = match self {
2641
+ &Inst::VecInt128SCmpHi { .. } => "vecg",
2642
+ &Inst::VecInt128UCmpHi { .. } => "veclg",
2643
+ _ => unreachable!(),
2644
+ };
2645
+ let tmp = pretty_print_reg(tmp.to_reg(), allocs);
2646
+ let rn = pretty_print_reg(rn, allocs);
2647
+ let rm = pretty_print_reg(rm, allocs);
2648
+ format!(
2649
+ "{} {}, {} ; jne 10 ; vchlgs {}, {}, {}",
2650
+ op, rm, rn, tmp, rn, rm
2651
+ )
2652
+ }
2653
+ &Inst::VecLoad { rd, ref mem }
2654
+ | &Inst::VecLoadRev { rd, ref mem }
2655
+ | &Inst::VecLoadByte16Rev { rd, ref mem }
2656
+ | &Inst::VecLoadByte32Rev { rd, ref mem }
2657
+ | &Inst::VecLoadByte64Rev { rd, ref mem }
2658
+ | &Inst::VecLoadElt16Rev { rd, ref mem }
2659
+ | &Inst::VecLoadElt32Rev { rd, ref mem }
2660
+ | &Inst::VecLoadElt64Rev { rd, ref mem } => {
2661
+ let opcode = match self {
2662
+ &Inst::VecLoad { .. } => "vl",
2663
+ &Inst::VecLoadRev { .. } => "vlbrq",
2664
+ &Inst::VecLoadByte16Rev { .. } => "vlbrh",
2665
+ &Inst::VecLoadByte32Rev { .. } => "vlbrf",
2666
+ &Inst::VecLoadByte64Rev { .. } => "vlbrg",
2667
+ &Inst::VecLoadElt16Rev { .. } => "vlerh",
2668
+ &Inst::VecLoadElt32Rev { .. } => "vlerf",
2669
+ &Inst::VecLoadElt64Rev { .. } => "vlerg",
2670
+ _ => unreachable!(),
2671
+ };
2672
+
2673
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2674
+ let mem = mem.with_allocs(allocs);
2675
+ let (mem_str, mem) = mem_finalize_for_show(
2676
+ &mem,
2677
+ state,
2678
+ MemInstType {
2679
+ have_d12: true,
2680
+ have_d20: false,
2681
+ have_pcrel: false,
2682
+ have_unaligned_pcrel: false,
2683
+ have_index: true,
2684
+ },
2685
+ );
2686
+ let mem = mem.pretty_print_default();
2687
+ format!("{}{} {}, {}", mem_str, opcode, rd, mem)
2688
+ }
2689
+ &Inst::VecStore { rd, ref mem }
2690
+ | &Inst::VecStoreRev { rd, ref mem }
2691
+ | &Inst::VecStoreByte16Rev { rd, ref mem }
2692
+ | &Inst::VecStoreByte32Rev { rd, ref mem }
2693
+ | &Inst::VecStoreByte64Rev { rd, ref mem }
2694
+ | &Inst::VecStoreElt16Rev { rd, ref mem }
2695
+ | &Inst::VecStoreElt32Rev { rd, ref mem }
2696
+ | &Inst::VecStoreElt64Rev { rd, ref mem } => {
2697
+ let opcode = match self {
2698
+ &Inst::VecStore { .. } => "vst",
2699
+ &Inst::VecStoreRev { .. } => "vstbrq",
2700
+ &Inst::VecStoreByte16Rev { .. } => "vstbrh",
2701
+ &Inst::VecStoreByte32Rev { .. } => "vstbrf",
2702
+ &Inst::VecStoreByte64Rev { .. } => "vstbrg",
2703
+ &Inst::VecStoreElt16Rev { .. } => "vsterh",
2704
+ &Inst::VecStoreElt32Rev { .. } => "vsterf",
2705
+ &Inst::VecStoreElt64Rev { .. } => "vsterg",
2706
+ _ => unreachable!(),
2707
+ };
2708
+
2709
+ let rd = pretty_print_reg(rd, allocs);
2710
+ let mem = mem.with_allocs(allocs);
2711
+ let (mem_str, mem) = mem_finalize_for_show(
2712
+ &mem,
2713
+ state,
2714
+ MemInstType {
2715
+ have_d12: true,
2716
+ have_d20: false,
2717
+ have_pcrel: false,
2718
+ have_unaligned_pcrel: false,
2719
+ have_index: true,
2720
+ },
2721
+ );
2722
+ let mem = mem.pretty_print_default();
2723
+ format!("{}{} {}, {}", mem_str, opcode, rd, mem)
2724
+ }
2725
+ &Inst::VecLoadReplicate { size, rd, ref mem }
2726
+ | &Inst::VecLoadReplicateRev { size, rd, ref mem } => {
2727
+ let opcode = match (self, size) {
2728
+ (&Inst::VecLoadReplicate { .. }, 8) => "vlrepb",
2729
+ (&Inst::VecLoadReplicate { .. }, 16) => "vlreph",
2730
+ (&Inst::VecLoadReplicate { .. }, 32) => "vlrepf",
2731
+ (&Inst::VecLoadReplicate { .. }, 64) => "vlrepg",
2732
+ (&Inst::VecLoadReplicateRev { .. }, 16) => "vlbrreph",
2733
+ (&Inst::VecLoadReplicateRev { .. }, 32) => "vlbrrepf",
2734
+ (&Inst::VecLoadReplicateRev { .. }, 64) => "vlbrrepg",
2735
+ _ => unreachable!(),
2736
+ };
2737
+
2738
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2739
+ let mem = mem.with_allocs(allocs);
2740
+ let (mem_str, mem) = mem_finalize_for_show(
2741
+ &mem,
2742
+ state,
2743
+ MemInstType {
2744
+ have_d12: true,
2745
+ have_d20: false,
2746
+ have_pcrel: false,
2747
+ have_unaligned_pcrel: false,
2748
+ have_index: true,
2749
+ },
2750
+ );
2751
+ let mem = mem.pretty_print_default();
2752
+ format!("{}{} {}, {}", mem_str, opcode, rd, mem)
2753
+ }
2754
+ &Inst::VecMov { rd, rn } => {
2755
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2756
+ let rn = pretty_print_reg(rn, allocs);
2757
+ format!("vlr {}, {}", rd, rn)
2758
+ }
2759
+ &Inst::VecCMov { rd, cond, ri, rm } => {
2760
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
2761
+ let rm = pretty_print_reg(rm, allocs);
2762
+ let cond = cond.invert().pretty_print_default();
2763
+ format!("j{} 10 ; vlr {}, {}", cond, rd, rm)
2764
+ }
2765
+ &Inst::MovToVec128 { rd, rn, rm } => {
2766
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2767
+ let rn = pretty_print_reg(rn, allocs);
2768
+ let rm = pretty_print_reg(rm, allocs);
2769
+ format!("vlvgp {}, {}, {}", rd, rn, rm)
2770
+ }
2771
+ &Inst::VecLoadConst { rd, const_data } => {
2772
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2773
+ let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2774
+ format!(
2775
+ "bras {}, 20 ; data.u128 0x{:032x} ; vl {}, 0({})",
2776
+ tmp, const_data, rd, tmp
2777
+ )
2778
+ }
2779
+ &Inst::VecLoadConstReplicate {
2780
+ size,
2781
+ rd,
2782
+ const_data,
2783
+ } => {
2784
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2785
+ let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
2786
+ let (opcode, data) = match size {
2787
+ 32 => ("vlrepf", format!("0x{:08x}", const_data as u32)),
2788
+ 64 => ("vlrepg", format!("0x{:016x}", const_data)),
2789
+ _ => unreachable!(),
2790
+ };
2791
+ format!(
2792
+ "bras {}, {} ; data.u{} {} ; {} {}, 0({})",
2793
+ tmp,
2794
+ 4 + size / 8,
2795
+ size,
2796
+ data,
2797
+ opcode,
2798
+ rd,
2799
+ tmp
2800
+ )
2801
+ }
2802
+ &Inst::VecImmByteMask { rd, mask } => {
2803
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2804
+ format!("vgbm {}, {}", rd, mask)
2805
+ }
2806
+ &Inst::VecImmBitMask {
2807
+ size,
2808
+ rd,
2809
+ start_bit,
2810
+ end_bit,
2811
+ } => {
2812
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2813
+ let op = match size {
2814
+ 8 => "vgmb",
2815
+ 16 => "vgmh",
2816
+ 32 => "vgmf",
2817
+ 64 => "vgmg",
2818
+ _ => unreachable!(),
2819
+ };
2820
+ format!("{} {}, {}, {}", op, rd, start_bit, end_bit)
2821
+ }
2822
+ &Inst::VecImmReplicate { size, rd, imm } => {
2823
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
2824
+ let op = match size {
2825
+ 8 => "vrepib",
2826
+ 16 => "vrepih",
2827
+ 32 => "vrepif",
2828
+ 64 => "vrepig",
2829
+ _ => unreachable!(),
2830
+ };
2831
+ format!("{} {}, {}", op, rd, imm)
2832
+ }
2833
+ &Inst::VecLoadLane {
2834
+ size,
2835
+ rd,
2836
+ ri,
2837
+ ref mem,
2838
+ lane_imm,
2839
+ }
2840
+ | &Inst::VecLoadLaneRev {
2841
+ size,
2842
+ rd,
2843
+ ri,
2844
+ ref mem,
2845
+ lane_imm,
2846
+ } => {
2847
+ let opcode_vrx = match (self, size) {
2848
+ (&Inst::VecLoadLane { .. }, 8) => "vleb",
2849
+ (&Inst::VecLoadLane { .. }, 16) => "vleh",
2850
+ (&Inst::VecLoadLane { .. }, 32) => "vlef",
2851
+ (&Inst::VecLoadLane { .. }, 64) => "vleg",
2852
+ (&Inst::VecLoadLaneRev { .. }, 16) => "vlebrh",
2853
+ (&Inst::VecLoadLaneRev { .. }, 32) => "vlebrf",
2854
+ (&Inst::VecLoadLaneRev { .. }, 64) => "vlebrg",
2855
+ _ => unreachable!(),
2856
+ };
2857
+
2858
+ let (rd, _) = pretty_print_fpr(rd.to_reg(), allocs);
2859
+ let _ri = allocs.next(ri);
2860
+ let mem = mem.with_allocs(allocs);
2861
+ let (mem_str, mem) = mem_finalize_for_show(
2862
+ &mem,
2863
+ state,
2864
+ MemInstType {
2865
+ have_d12: true,
2866
+ have_d20: false,
2867
+ have_pcrel: false,
2868
+ have_unaligned_pcrel: false,
2869
+ have_index: true,
2870
+ },
2871
+ );
2872
+ let mem = mem.pretty_print_default();
2873
+ format!("{}{} {}, {}, {}", mem_str, opcode_vrx, rd, mem, lane_imm)
2874
+ }
2875
+ &Inst::VecLoadLaneUndef {
2876
+ size,
2877
+ rd,
2878
+ ref mem,
2879
+ lane_imm,
2880
+ }
2881
+ | &Inst::VecLoadLaneRevUndef {
2882
+ size,
2883
+ rd,
2884
+ ref mem,
2885
+ lane_imm,
2886
+ } => {
2887
+ let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
2888
+ (&Inst::VecLoadLaneUndef { .. }, 8) => ("vleb", None, None),
2889
+ (&Inst::VecLoadLaneUndef { .. }, 16) => ("vleh", None, None),
2890
+ (&Inst::VecLoadLaneUndef { .. }, 32) => ("vlef", Some("le"), Some("ley")),
2891
+ (&Inst::VecLoadLaneUndef { .. }, 64) => ("vleg", Some("ld"), Some("ldy")),
2892
+ (&Inst::VecLoadLaneRevUndef { .. }, 16) => ("vlebrh", None, None),
2893
+ (&Inst::VecLoadLaneRevUndef { .. }, 32) => ("vlebrf", None, None),
2894
+ (&Inst::VecLoadLaneRevUndef { .. }, 64) => ("vlebrg", None, None),
2895
+ _ => unreachable!(),
2896
+ };
2897
+
2898
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
2899
+ let mem = mem.with_allocs(allocs);
2900
+ if lane_imm == 0 && rd_fpr.is_some() && opcode_rx.is_some() {
2901
+ let (mem_str, mem) = mem_finalize_for_show(
2902
+ &mem,
2903
+ state,
2904
+ MemInstType {
2905
+ have_d12: true,
2906
+ have_d20: true,
2907
+ have_pcrel: false,
2908
+ have_unaligned_pcrel: false,
2909
+ have_index: true,
2910
+ },
2911
+ );
2912
+ let op = match &mem {
2913
+ &MemArg::BXD12 { .. } => opcode_rx,
2914
+ &MemArg::BXD20 { .. } => opcode_rxy,
2915
+ _ => unreachable!(),
2916
+ };
2917
+ let mem = mem.pretty_print_default();
2918
+ format!("{}{} {}, {}", mem_str, op.unwrap(), rd_fpr.unwrap(), mem)
2919
+ } else {
2920
+ let (mem_str, mem) = mem_finalize_for_show(
2921
+ &mem,
2922
+ state,
2923
+ MemInstType {
2924
+ have_d12: true,
2925
+ have_d20: false,
2926
+ have_pcrel: false,
2927
+ have_unaligned_pcrel: false,
2928
+ have_index: true,
2929
+ },
2930
+ );
2931
+ let mem = mem.pretty_print_default();
2932
+ format!("{}{} {}, {}, {}", mem_str, opcode_vrx, rd, mem, lane_imm)
2933
+ }
2934
+ }
2935
+ &Inst::VecStoreLane {
2936
+ size,
2937
+ rd,
2938
+ ref mem,
2939
+ lane_imm,
2940
+ }
2941
+ | &Inst::VecStoreLaneRev {
2942
+ size,
2943
+ rd,
2944
+ ref mem,
2945
+ lane_imm,
2946
+ } => {
2947
+ let (opcode_vrx, opcode_rx, opcode_rxy) = match (self, size) {
2948
+ (&Inst::VecStoreLane { .. }, 8) => ("vsteb", None, None),
2949
+ (&Inst::VecStoreLane { .. }, 16) => ("vsteh", None, None),
2950
+ (&Inst::VecStoreLane { .. }, 32) => ("vstef", Some("ste"), Some("stey")),
2951
+ (&Inst::VecStoreLane { .. }, 64) => ("vsteg", Some("std"), Some("stdy")),
2952
+ (&Inst::VecStoreLaneRev { .. }, 16) => ("vstebrh", None, None),
2953
+ (&Inst::VecStoreLaneRev { .. }, 32) => ("vstebrf", None, None),
2954
+ (&Inst::VecStoreLaneRev { .. }, 64) => ("vstebrg", None, None),
2955
+ _ => unreachable!(),
2956
+ };
2957
+
2958
+ let (rd, rd_fpr) = pretty_print_fpr(rd, allocs);
2959
+ let mem = mem.with_allocs(allocs);
2960
+ if lane_imm == 0 && rd_fpr.is_some() && opcode_rx.is_some() {
2961
+ let (mem_str, mem) = mem_finalize_for_show(
2962
+ &mem,
2963
+ state,
2964
+ MemInstType {
2965
+ have_d12: true,
2966
+ have_d20: true,
2967
+ have_pcrel: false,
2968
+ have_unaligned_pcrel: false,
2969
+ have_index: true,
2970
+ },
2971
+ );
2972
+ let op = match &mem {
2973
+ &MemArg::BXD12 { .. } => opcode_rx,
2974
+ &MemArg::BXD20 { .. } => opcode_rxy,
2975
+ _ => unreachable!(),
2976
+ };
2977
+ let mem = mem.pretty_print_default();
2978
+ format!("{}{} {}, {}", mem_str, op.unwrap(), rd_fpr.unwrap(), mem)
2979
+ } else {
2980
+ let (mem_str, mem) = mem_finalize_for_show(
2981
+ &mem,
2982
+ state,
2983
+ MemInstType {
2984
+ have_d12: true,
2985
+ have_d20: false,
2986
+ have_pcrel: false,
2987
+ have_unaligned_pcrel: false,
2988
+ have_index: true,
2989
+ },
2990
+ );
2991
+ let mem = mem.pretty_print_default();
2992
+ format!("{}{} {}, {}, {}", mem_str, opcode_vrx, rd, mem, lane_imm,)
2993
+ }
2994
+ }
2995
+ &Inst::VecInsertLane {
2996
+ size,
2997
+ rd,
2998
+ ri,
2999
+ rn,
3000
+ lane_imm,
3001
+ lane_reg,
3002
+ } => {
3003
+ let op = match size {
3004
+ 8 => "vlvgb",
3005
+ 16 => "vlvgh",
3006
+ 32 => "vlvgf",
3007
+ 64 => "vlvgg",
3008
+ _ => unreachable!(),
3009
+ };
3010
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
3011
+ let rn = pretty_print_reg(rn, allocs);
3012
+ let lane_reg = if lane_reg != zero_reg() {
3013
+ format!("({})", pretty_print_reg(lane_reg, allocs))
3014
+ } else {
3015
+ "".to_string()
3016
+ };
3017
+ format!("{} {}, {}, {}{}", op, rd, rn, lane_imm, lane_reg)
3018
+ }
3019
+ &Inst::VecInsertLaneUndef {
3020
+ size,
3021
+ rd,
3022
+ rn,
3023
+ lane_imm,
3024
+ lane_reg,
3025
+ } => {
3026
+ let (opcode_vrs, opcode_rre) = match size {
3027
+ 8 => ("vlvgb", None),
3028
+ 16 => ("vlvgh", None),
3029
+ 32 => ("vlvgf", None),
3030
+ 64 => ("vlvgg", Some("ldgr")),
3031
+ _ => unreachable!(),
3032
+ };
3033
+ let (rd, rd_fpr) = pretty_print_fpr(rd.to_reg(), allocs);
3034
+ let rn = pretty_print_reg(rn, allocs);
3035
+ let lane_reg = if lane_reg != zero_reg() {
3036
+ format!("({})", pretty_print_reg(lane_reg, allocs))
3037
+ } else {
3038
+ "".to_string()
3039
+ };
3040
+ if opcode_rre.is_some() && lane_imm == 0 && lane_reg.is_empty() && rd_fpr.is_some()
3041
+ {
3042
+ format!("{} {}, {}", opcode_rre.unwrap(), rd_fpr.unwrap(), rn)
3043
+ } else {
3044
+ format!("{} {}, {}, {}{}", opcode_vrs, rd, rn, lane_imm, lane_reg)
3045
+ }
3046
+ }
3047
+ &Inst::VecExtractLane {
3048
+ size,
3049
+ rd,
3050
+ rn,
3051
+ lane_imm,
3052
+ lane_reg,
3053
+ } => {
3054
+ let (opcode_vrs, opcode_rre) = match size {
3055
+ 8 => ("vlgvb", None),
3056
+ 16 => ("vlgvh", None),
3057
+ 32 => ("vlgvf", None),
3058
+ 64 => ("vlgvg", Some("lgdr")),
3059
+ _ => unreachable!(),
3060
+ };
3061
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
3062
+ let (rn, rn_fpr) = pretty_print_fpr(rn, allocs);
3063
+ let lane_reg = if lane_reg != zero_reg() {
3064
+ format!("({})", pretty_print_reg(lane_reg, allocs))
3065
+ } else {
3066
+ "".to_string()
3067
+ };
3068
+ if opcode_rre.is_some() && lane_imm == 0 && lane_reg.is_empty() && rn_fpr.is_some()
3069
+ {
3070
+ format!("{} {}, {}", opcode_rre.unwrap(), rd, rn_fpr.unwrap())
3071
+ } else {
3072
+ format!("{} {}, {}, {}{}", opcode_vrs, rd, rn, lane_imm, lane_reg)
3073
+ }
3074
+ }
3075
+ &Inst::VecInsertLaneImm {
3076
+ size,
3077
+ rd,
3078
+ ri,
3079
+ imm,
3080
+ lane_imm,
3081
+ } => {
3082
+ let op = match size {
3083
+ 8 => "vleib",
3084
+ 16 => "vleih",
3085
+ 32 => "vleif",
3086
+ 64 => "vleig",
3087
+ _ => unreachable!(),
3088
+ };
3089
+ let rd = pretty_print_reg_mod(rd, ri, allocs);
3090
+ format!("{} {}, {}, {}", op, rd, imm, lane_imm)
3091
+ }
3092
+ &Inst::VecReplicateLane {
3093
+ size,
3094
+ rd,
3095
+ rn,
3096
+ lane_imm,
3097
+ } => {
3098
+ let op = match size {
3099
+ 8 => "vrepb",
3100
+ 16 => "vreph",
3101
+ 32 => "vrepf",
3102
+ 64 => "vrepg",
3103
+ _ => unreachable!(),
3104
+ };
3105
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
3106
+ let rn = pretty_print_reg(rn, allocs);
3107
+ format!("{} {}, {}, {}", op, rd, rn, lane_imm)
3108
+ }
3109
+ &Inst::Extend {
3110
+ rd,
3111
+ rn,
3112
+ signed,
3113
+ from_bits,
3114
+ to_bits,
3115
+ } => {
3116
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
3117
+ let rn = pretty_print_reg(rn, allocs);
3118
+ let op = match (signed, from_bits, to_bits) {
3119
+ (_, 1, 32) => "llcr",
3120
+ (_, 1, 64) => "llgcr",
3121
+ (false, 8, 32) => "llcr",
3122
+ (false, 8, 64) => "llgcr",
3123
+ (true, 8, 32) => "lbr",
3124
+ (true, 8, 64) => "lgbr",
3125
+ (false, 16, 32) => "llhr",
3126
+ (false, 16, 64) => "llghr",
3127
+ (true, 16, 32) => "lhr",
3128
+ (true, 16, 64) => "lghr",
3129
+ (false, 32, 64) => "llgfr",
3130
+ (true, 32, 64) => "lgfr",
3131
+ _ => panic!("Unsupported Extend case: {:?}", self),
3132
+ };
3133
+ format!("{} {}, {}", op, rd, rn)
3134
+ }
3135
+ &Inst::Call { link, ref info, .. } => {
3136
+ let link = link.to_reg();
3137
+ let tls_symbol = match &info.tls_symbol {
3138
+ None => "".to_string(),
3139
+ Some(SymbolReloc::TlsGd { name }) => {
3140
+ format!(":tls_gdcall:{}", name.display(None))
3141
+ }
3142
+ _ => unreachable!(),
3143
+ };
3144
+ debug_assert_eq!(link, gpr(14));
3145
+ format!(
3146
+ "brasl {}, {}{}",
3147
+ show_reg(link),
3148
+ info.dest.display(None),
3149
+ tls_symbol
3150
+ )
3151
+ }
3152
+ &Inst::CallInd { link, ref info, .. } => {
3153
+ let link = link.to_reg();
3154
+ let rn = pretty_print_reg(info.rn, allocs);
3155
+ debug_assert_eq!(link, gpr(14));
3156
+ format!("basr {}, {}", show_reg(link), rn)
3157
+ }
3158
+ &Inst::Args { ref args } => {
3159
+ let mut s = "args".to_string();
3160
+ for arg in args {
3161
+ let preg = pretty_print_reg(arg.preg, &mut empty_allocs);
3162
+ let def = pretty_print_reg(arg.vreg.to_reg(), allocs);
3163
+ write!(&mut s, " {}={}", def, preg).unwrap();
3164
+ }
3165
+ s
3166
+ }
3167
+ &Inst::Rets { ref rets } => {
3168
+ let mut s = "rets".to_string();
3169
+ for ret in rets {
3170
+ let preg = pretty_print_reg(ret.preg, &mut empty_allocs);
3171
+ let vreg = pretty_print_reg(ret.vreg, allocs);
3172
+ write!(&mut s, " {}={}", vreg, preg).unwrap();
3173
+ }
3174
+ s
3175
+ }
3176
+ &Inst::Ret { link } => {
3177
+ debug_assert_eq!(link, gpr(14));
3178
+ let link = show_reg(link);
3179
+ format!("br {link}")
3180
+ }
3181
+ &Inst::Jump { dest } => {
3182
+ let dest = dest.to_string();
3183
+ format!("jg {}", dest)
3184
+ }
3185
+ &Inst::IndirectBr { rn, .. } => {
3186
+ let rn = pretty_print_reg(rn, allocs);
3187
+ format!("br {}", rn)
3188
+ }
3189
+ &Inst::CondBr {
3190
+ taken,
3191
+ not_taken,
3192
+ cond,
3193
+ } => {
3194
+ let taken = taken.to_string();
3195
+ let not_taken = not_taken.to_string();
3196
+ let cond = cond.pretty_print_default();
3197
+ format!("jg{} {} ; jg {}", cond, taken, not_taken)
3198
+ }
3199
+ &Inst::OneWayCondBr { target, cond } => {
3200
+ let target = target.to_string();
3201
+ let cond = cond.pretty_print_default();
3202
+ format!("jg{} {}", cond, target)
3203
+ }
3204
+ &Inst::Debugtrap => ".word 0x0001 # debugtrap".to_string(),
3205
+ &Inst::Trap { trap_code } => {
3206
+ format!(".word 0x0000 # trap={}", trap_code)
3207
+ }
3208
+ &Inst::TrapIf { cond, trap_code } => {
3209
+ let cond = cond.pretty_print_default();
3210
+ format!("jg{} .+2 # trap={}", cond, trap_code)
3211
+ }
3212
+ &Inst::JTSequence { ridx, ref targets } => {
3213
+ let ridx = pretty_print_reg(ridx, allocs);
3214
+ let rtmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
3215
+ // The first entry is the default target, which is not emitted
3216
+ // into the jump table, so we skip it here. It is only in the
3217
+ // list so MachTerminator will see the potential target.
3218
+ let jt_entries: String = targets
3219
+ .iter()
3220
+ .skip(1)
3221
+ .map(|label| format!(" {}", label.to_string()))
3222
+ .collect();
3223
+ format!(
3224
+ concat!(
3225
+ "larl {}, 14 ; ",
3226
+ "agf {}, 0({}, {}) ; ",
3227
+ "br {} ; ",
3228
+ "jt_entries{}"
3229
+ ),
3230
+ rtmp, rtmp, rtmp, ridx, rtmp, jt_entries,
3231
+ )
3232
+ }
3233
+ &Inst::LoadSymbolReloc {
3234
+ rd,
3235
+ ref symbol_reloc,
3236
+ } => {
3237
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
3238
+ let tmp = pretty_print_reg(writable_spilltmp_reg().to_reg(), &mut empty_allocs);
3239
+ let symbol = match &**symbol_reloc {
3240
+ SymbolReloc::Absolute { name, offset } => {
3241
+ format!("{} + {}", name.display(None), offset)
3242
+ }
3243
+ SymbolReloc::TlsGd { name } => format!("{}@tlsgd", name.display(None)),
3244
+ };
3245
+ format!("bras {}, 12 ; data {} ; lg {}, 0({})", tmp, symbol, rd, tmp)
3246
+ }
3247
+ &Inst::LoadAddr { rd, ref mem } => {
3248
+ let rd = pretty_print_reg(rd.to_reg(), allocs);
3249
+ let mem = mem.with_allocs(allocs);
3250
+ let (mem_str, mem) = mem_finalize_for_show(
3251
+ &mem,
3252
+ state,
3253
+ MemInstType {
3254
+ have_d12: true,
3255
+ have_d20: true,
3256
+ have_pcrel: true,
3257
+ have_unaligned_pcrel: true,
3258
+ have_index: true,
3259
+ },
3260
+ );
3261
+ let op = match &mem {
3262
+ &MemArg::BXD12 { .. } => "la",
3263
+ &MemArg::BXD20 { .. } => "lay",
3264
+ &MemArg::Label { .. } | &MemArg::Symbol { .. } => "larl",
3265
+ _ => unreachable!(),
3266
+ };
3267
+ let mem = mem.pretty_print_default();
3268
+
3269
+ format!("{}{} {}, {}", mem_str, op, rd, mem)
3270
+ }
3271
+ &Inst::Loop { ref body, cond } => {
3272
+ let body = body
3273
+ .into_iter()
3274
+ .map(|inst| inst.print_with_state(state, allocs))
3275
+ .collect::<Vec<_>>()
3276
+ .join(" ; ");
3277
+ let cond = cond.pretty_print_default();
3278
+ format!("0: {} ; jg{} 0b ; 1:", body, cond)
3279
+ }
3280
+ &Inst::CondBreak { cond } => {
3281
+ let cond = cond.pretty_print_default();
3282
+ format!("jg{} 1f", cond)
3283
+ }
3284
+ &Inst::VirtualSPOffsetAdj { offset } => {
3285
+ state.virtual_sp_offset += offset;
3286
+ format!("virtual_sp_offset_adjust {}", offset)
3287
+ }
3288
+ &Inst::Unwind { ref inst } => {
3289
+ format!("unwind {:?}", inst)
3290
+ }
3291
+ &Inst::DummyUse { reg } => {
3292
+ let reg = pretty_print_reg(reg, allocs);
3293
+ format!("dummy_use {}", reg)
3294
+ }
3295
+ }
3296
+ }
3297
+ }
3298
+
3299
+ //=============================================================================
3300
+ // Label fixups and jump veneers.
3301
+
3302
+ /// Different forms of label references for different instruction formats.
3303
+ #[derive(Clone, Copy, Debug, PartialEq, Eq)]
3304
+ pub enum LabelUse {
3305
+ #[allow(dead_code)]
3306
+ /// RI-format branch. 16-bit signed offset. PC-relative, offset is imm << 1.
3307
+ BranchRI,
3308
+ /// RIL-format branch. 32-bit signed offset. PC-relative, offset is imm << 1.
3309
+ BranchRIL,
3310
+ /// 32-bit PC relative constant offset (from address of constant itself),
3311
+ /// signed. Used in jump tables.
3312
+ PCRel32,
3313
+ /// 32-bit PC relative constant offset (from address of call instruction),
3314
+ /// signed. Offset is imm << 1. Used for call relocations.
3315
+ PCRel32Dbl,
3316
+ }
3317
+
3318
+ impl MachInstLabelUse for LabelUse {
3319
+ /// Alignment for veneer code.
3320
+ const ALIGN: CodeOffset = 2;
3321
+
3322
+ /// Maximum PC-relative range (positive), inclusive.
3323
+ fn max_pos_range(self) -> CodeOffset {
3324
+ match self {
3325
+ // 16-bit signed immediate, left-shifted by 1.
3326
+ LabelUse::BranchRI => ((1 << 15) - 1) << 1,
3327
+ // 32-bit signed immediate, left-shifted by 1.
3328
+ LabelUse::BranchRIL => 0xffff_fffe,
3329
+ // 32-bit signed immediate.
3330
+ LabelUse::PCRel32 => 0x7fff_ffff,
3331
+ // 32-bit signed immediate, left-shifted by 1, offset by 2.
3332
+ LabelUse::PCRel32Dbl => 0xffff_fffc,
3333
+ }
3334
+ }
3335
+
3336
+ /// Maximum PC-relative range (negative).
3337
+ fn max_neg_range(self) -> CodeOffset {
3338
+ match self {
3339
+ // 16-bit signed immediate, left-shifted by 1.
3340
+ LabelUse::BranchRI => (1 << 15) << 1,
3341
+ // 32-bit signed immediate, left-shifted by 1.
3342
+ // NOTE: This should be 4GB, but CodeOffset is only u32.
3343
+ LabelUse::BranchRIL => 0xffff_ffff,
3344
+ // 32-bit signed immediate.
3345
+ LabelUse::PCRel32 => 0x8000_0000,
3346
+ // 32-bit signed immediate, left-shifted by 1, offset by 2.
3347
+ // NOTE: This should be 4GB + 2, but CodeOffset is only u32.
3348
+ LabelUse::PCRel32Dbl => 0xffff_ffff,
3349
+ }
3350
+ }
3351
+
3352
+ /// Size of window into code needed to do the patch.
3353
+ fn patch_size(self) -> CodeOffset {
3354
+ match self {
3355
+ LabelUse::BranchRI => 4,
3356
+ LabelUse::BranchRIL => 6,
3357
+ LabelUse::PCRel32 => 4,
3358
+ LabelUse::PCRel32Dbl => 4,
3359
+ }
3360
+ }
3361
+
3362
+ /// Perform the patch.
3363
+ fn patch(self, buffer: &mut [u8], use_offset: CodeOffset, label_offset: CodeOffset) {
3364
+ let pc_rel = (label_offset as i64) - (use_offset as i64);
3365
+ debug_assert!(pc_rel <= self.max_pos_range() as i64);
3366
+ debug_assert!(pc_rel >= -(self.max_neg_range() as i64));
3367
+ debug_assert!(pc_rel & 1 == 0);
3368
+ let pc_rel_shifted = pc_rel >> 1;
3369
+
3370
+ match self {
3371
+ LabelUse::BranchRI => {
3372
+ buffer[2..4].clone_from_slice(&u16::to_be_bytes(pc_rel_shifted as u16));
3373
+ }
3374
+ LabelUse::BranchRIL => {
3375
+ buffer[2..6].clone_from_slice(&u32::to_be_bytes(pc_rel_shifted as u32));
3376
+ }
3377
+ LabelUse::PCRel32 => {
3378
+ let insn_word = u32::from_be_bytes([buffer[0], buffer[1], buffer[2], buffer[3]]);
3379
+ let insn_word = insn_word.wrapping_add(pc_rel as u32);
3380
+ buffer[0..4].clone_from_slice(&u32::to_be_bytes(insn_word));
3381
+ }
3382
+ LabelUse::PCRel32Dbl => {
3383
+ let insn_word = u32::from_be_bytes([buffer[0], buffer[1], buffer[2], buffer[3]]);
3384
+ let insn_word = insn_word.wrapping_add((pc_rel_shifted + 1) as u32);
3385
+ buffer[0..4].clone_from_slice(&u32::to_be_bytes(insn_word));
3386
+ }
3387
+ }
3388
+ }
3389
+
3390
+ /// Is a veneer supported for this label reference type?
3391
+ fn supports_veneer(self) -> bool {
3392
+ false
3393
+ }
3394
+
3395
+ /// How large is the veneer, if supported?
3396
+ fn veneer_size(self) -> CodeOffset {
3397
+ 0
3398
+ }
3399
+
3400
+ fn worst_case_veneer_size() -> CodeOffset {
3401
+ 0
3402
+ }
3403
+
3404
+ /// Generate a veneer into the buffer, given that this veneer is at `veneer_offset`, and return
3405
+ /// an offset and label-use for the veneer's use of the original label.
3406
+ fn generate_veneer(
3407
+ self,
3408
+ _buffer: &mut [u8],
3409
+ _veneer_offset: CodeOffset,
3410
+ ) -> (CodeOffset, LabelUse) {
3411
+ unreachable!();
3412
+ }
3413
+
3414
+ fn from_reloc(reloc: Reloc, addend: Addend) -> Option<Self> {
3415
+ match (reloc, addend) {
3416
+ (Reloc::S390xPCRel32Dbl, 2) => Some(LabelUse::PCRel32Dbl),
3417
+ (Reloc::S390xPLTRel32Dbl, 2) => Some(LabelUse::PCRel32Dbl),
3418
+ _ => None,
3419
+ }
3420
+ }
3421
+ }