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,2883 @@
1
+ ;; riscv64 instruction selection and CLIF-to-MachInst lowering.
2
+
3
+ ;; The main lowering constructor term: takes a clif `Inst` and returns the
4
+ ;; register(s) within which the lowered instruction's result values live.
5
+ (decl partial lower (Inst) InstOutput)
6
+
7
+ ;;;; Rules for `iconst` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
8
+
9
+ (rule (lower (has_type ty (iconst (u64_from_imm64 n))))
10
+ (imm ty n))
11
+
12
+ ;; ;;;; Rules for `vconst` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
13
+
14
+ (rule (lower (has_type (ty_vec_fits_in_register ty) (vconst n)))
15
+ (gen_constant ty (const_to_vconst n)))
16
+
17
+ ;;;; Rules for `f32const` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
18
+
19
+ (rule (lower (f32const (u32_from_ieee32 n)))
20
+ (imm $F32 n))
21
+
22
+ ;;;; Rules for `f64const` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
23
+
24
+ (rule (lower (f64const (u64_from_ieee64 n)))
25
+ (imm $F64 n))
26
+
27
+ ;;;; Rules for `null` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
28
+
29
+ (rule (lower (has_type ty (null)))
30
+ (imm ty 0))
31
+
32
+
33
+ ;;;; Rules for `iadd` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
34
+
35
+ ;; Base case, simply adding things in registers.
36
+ (rule -1 (lower (has_type (fits_in_32 (ty_int ty)) (iadd x y)))
37
+ (rv_addw x y))
38
+
39
+ (rule 0 (lower (has_type $I64 (iadd x y)))
40
+ (rv_add x y))
41
+
42
+ ;; Special cases for when one operand is an immediate that fits in 12 bits.
43
+ (rule 1 (lower (has_type (ty_int_ref_scalar_64 ty) (iadd x (imm12_from_value y))))
44
+ (alu_rr_imm12 (select_addi ty) x y))
45
+
46
+ (rule 2 (lower (has_type (ty_int_ref_scalar_64 ty) (iadd (imm12_from_value x) y)))
47
+ (alu_rr_imm12 (select_addi ty) y x))
48
+
49
+ ;; Special case when one of the operands is uextended
50
+ ;; Needs `Zba`
51
+ (rule 3 (lower (has_type $I64 (iadd x (uextend y @ (value_type $I32)))))
52
+ (if-let $true (has_zba))
53
+ (rv_adduw y x))
54
+
55
+ (rule 4 (lower (has_type $I64 (iadd (uextend x @ (value_type $I32)) y)))
56
+ (if-let $true (has_zba))
57
+ (rv_adduw x y))
58
+
59
+ ;; Add with const shift. We have a few of these instructions with `Zba`.
60
+ (decl pure partial match_shnadd (Imm64) AluOPRRR)
61
+ (rule (match_shnadd (u64_from_imm64 1)) (AluOPRRR.Sh1add))
62
+ (rule (match_shnadd (u64_from_imm64 2)) (AluOPRRR.Sh2add))
63
+ (rule (match_shnadd (u64_from_imm64 3)) (AluOPRRR.Sh3add))
64
+
65
+ (rule 3 (lower (has_type $I64 (iadd x (ishl y (maybe_uextend (iconst n))))))
66
+ (if-let $true (has_zba))
67
+ (if-let shnadd (match_shnadd n))
68
+ (alu_rrr shnadd y x))
69
+
70
+ (rule 4 (lower (has_type $I64 (iadd (ishl x (maybe_uextend (iconst n))) y)))
71
+ (if-let $true (has_zba))
72
+ (if-let shnadd (match_shnadd n))
73
+ (alu_rrr shnadd x y))
74
+
75
+
76
+ ;; Add with uextended const shift. We have a few of these instructions with `Zba`.
77
+ ;;
78
+ ;; !!! Important !!!
79
+ ;; These rules only work for (ishl (uextend _) _) and not for (uextend (ishl _ _))!
80
+ ;; Getting this wrong means a potential misscalculation of the shift amount.
81
+ ;; Additionaly we can only ensure that this is correct if the uextend is 32 to 64 bits.
82
+ (decl pure partial match_shnadd_uw (Imm64) AluOPRRR)
83
+ (rule (match_shnadd_uw (u64_from_imm64 1)) (AluOPRRR.Sh1adduw))
84
+ (rule (match_shnadd_uw (u64_from_imm64 2)) (AluOPRRR.Sh2adduw))
85
+ (rule (match_shnadd_uw (u64_from_imm64 3)) (AluOPRRR.Sh3adduw))
86
+
87
+ (rule 5 (lower (has_type $I64 (iadd x (ishl (uextend y @ (value_type $I32)) (maybe_uextend (iconst n))))))
88
+ (if-let $true (has_zba))
89
+ (if-let shnadd_uw (match_shnadd_uw n))
90
+ (alu_rrr shnadd_uw y x))
91
+
92
+ (rule 6 (lower (has_type $I64 (iadd (ishl (uextend x @ (value_type $I32)) (maybe_uextend (iconst n))) y)))
93
+ (if-let $true (has_zba))
94
+ (if-let shnadd_uw (match_shnadd_uw n))
95
+ (alu_rrr shnadd_uw x y))
96
+
97
+ ;; I128 cases
98
+ (rule 7 (lower (has_type $I128 (iadd x y)))
99
+ (let ((low XReg (rv_add (value_regs_get x 0) (value_regs_get y 0)))
100
+ ;; compute carry.
101
+ (carry XReg (rv_sltu low (value_regs_get y 0)))
102
+ ;;
103
+ (high_tmp XReg (rv_add (value_regs_get x 1) (value_regs_get y 1)))
104
+ ;; add carry.
105
+ (high XReg (rv_add high_tmp carry)))
106
+ (value_regs low high)))
107
+
108
+ ;; SIMD Vectors
109
+ (rule 8 (lower (has_type (ty_vec_fits_in_register ty) (iadd x y)))
110
+ (rv_vadd_vv x y (unmasked) ty))
111
+
112
+ (rule 9 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (splat y))))
113
+ (rv_vadd_vx x y (unmasked) ty))
114
+
115
+ (rule 10 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (splat (sextend y @ (value_type sext_ty))))))
116
+ (if-let half_ty (ty_half_width ty))
117
+ (if-let $true (ty_equal (lane_type half_ty) sext_ty))
118
+ (rv_vwadd_wx x y (unmasked) (vstate_mf2 half_ty)))
119
+
120
+ (rule 10 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (splat (uextend y @ (value_type uext_ty))))))
121
+ (if-let half_ty (ty_half_width ty))
122
+ (if-let $true (ty_equal (lane_type half_ty) uext_ty))
123
+ (rv_vwaddu_wx x y (unmasked) (vstate_mf2 half_ty)))
124
+
125
+ (rule 20 (lower (has_type (ty_vec_fits_in_register ty) (iadd x y)))
126
+ (if-let y_imm (replicated_imm5 y))
127
+ (rv_vadd_vi x y_imm (unmasked) ty))
128
+
129
+
130
+ (rule 12 (lower (has_type (ty_vec_fits_in_register ty) (iadd (splat x) y)))
131
+ (rv_vadd_vx y x (unmasked) ty))
132
+
133
+ (rule 13 (lower (has_type (ty_vec_fits_in_register ty) (iadd (splat (sextend x @ (value_type sext_ty))) y)))
134
+ (if-let half_ty (ty_half_width ty))
135
+ (if-let $true (ty_equal (lane_type half_ty) sext_ty))
136
+ (rv_vwadd_wx y x (unmasked) (vstate_mf2 half_ty)))
137
+
138
+ (rule 13 (lower (has_type (ty_vec_fits_in_register ty) (iadd (splat (uextend x @ (value_type uext_ty))) y)))
139
+ (if-let half_ty (ty_half_width ty))
140
+ (if-let $true (ty_equal (lane_type half_ty) uext_ty))
141
+ (rv_vwaddu_wx y x (unmasked) (vstate_mf2 half_ty)))
142
+
143
+ (rule 21 (lower (has_type (ty_vec_fits_in_register ty) (iadd x y)))
144
+ (if-let x_imm (replicated_imm5 x))
145
+ (rv_vadd_vi y x_imm (unmasked) ty))
146
+
147
+ ;; Signed Widening Low Additions
148
+
149
+ (rule 9 (lower (has_type (ty_vec_fits_in_register _) (iadd x (swiden_low y @ (value_type in_ty)))))
150
+ (rv_vwadd_wv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
151
+
152
+ (rule 12 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_low x @ (value_type in_ty)) y)))
153
+ (rv_vwadd_wv y x (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
154
+
155
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_low x @ (value_type in_ty))
156
+ (swiden_low y))))
157
+ (rv_vwadd_vv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
158
+
159
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_low x @ (value_type in_ty))
160
+ (splat (sextend y @ (value_type sext_ty))))))
161
+ (if-let $true (ty_equal (lane_type in_ty) sext_ty))
162
+ (rv_vwadd_vx x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
163
+
164
+ (rule 15 (lower (has_type (ty_vec_fits_in_register _) (iadd (splat (sextend x @ (value_type sext_ty)))
165
+ (swiden_low y @ (value_type in_ty)))))
166
+ (if-let $true (ty_equal (lane_type in_ty) sext_ty))
167
+ (rv_vwadd_vx y x (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
168
+
169
+ ;; Signed Widening High Additions
170
+ ;; These are the same as the low additions, but we first slide down the inputs.
171
+
172
+ (rule 9 (lower (has_type (ty_vec_fits_in_register _) (iadd x (swiden_high y @ (value_type in_ty)))))
173
+ (rv_vwadd_wv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
174
+
175
+ (rule 12 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_high x @ (value_type in_ty)) y)))
176
+ (rv_vwadd_wv y (gen_slidedown_half in_ty x) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
177
+
178
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_high x @ (value_type in_ty))
179
+ (swiden_high y))))
180
+ (rv_vwadd_vv (gen_slidedown_half in_ty x) (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
181
+
182
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_high x @ (value_type in_ty))
183
+ (splat (sextend y @ (value_type sext_ty))))))
184
+ (if-let $true (ty_equal (lane_type in_ty) sext_ty))
185
+ (rv_vwadd_vx (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
186
+
187
+ (rule 15 (lower (has_type (ty_vec_fits_in_register _) (iadd (splat (sextend x @ (value_type sext_ty)))
188
+ (swiden_high y @ (value_type in_ty)))))
189
+ (if-let $true (ty_equal (lane_type in_ty) sext_ty))
190
+ (rv_vwadd_vx (gen_slidedown_half in_ty y) x (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
191
+
192
+ ;; Unsigned Widening Low Additions
193
+
194
+ (rule 9 (lower (has_type (ty_vec_fits_in_register _) (iadd x (uwiden_low y @ (value_type in_ty)))))
195
+ (rv_vwaddu_wv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
196
+
197
+ (rule 12 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_low x @ (value_type in_ty)) y)))
198
+ (rv_vwaddu_wv y x (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
199
+
200
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_low x @ (value_type in_ty))
201
+ (uwiden_low y))))
202
+ (rv_vwaddu_vv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
203
+
204
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_low x @ (value_type in_ty))
205
+ (splat (uextend y @ (value_type uext_ty))))))
206
+ (if-let $true (ty_equal (lane_type in_ty) uext_ty))
207
+ (rv_vwaddu_vx x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
208
+
209
+ (rule 15 (lower (has_type (ty_vec_fits_in_register _) (iadd (splat (uextend x @ (value_type uext_ty)))
210
+ (uwiden_low y @ (value_type in_ty)))))
211
+ (if-let $true (ty_equal (lane_type in_ty) uext_ty))
212
+ (rv_vwaddu_vx y x (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
213
+
214
+ ;; Unsigned Widening High Additions
215
+ ;; These are the same as the low additions, but we first slide down the inputs.
216
+
217
+ (rule 9 (lower (has_type (ty_vec_fits_in_register _) (iadd x (uwiden_high y @ (value_type in_ty)))))
218
+ (rv_vwaddu_wv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
219
+
220
+ (rule 12 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_high x @ (value_type in_ty)) y)))
221
+ (rv_vwaddu_wv y (gen_slidedown_half in_ty x) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
222
+
223
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_high x @ (value_type in_ty))
224
+ (uwiden_high y))))
225
+ (rv_vwaddu_vv (gen_slidedown_half in_ty x) (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
226
+
227
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_high x @ (value_type in_ty))
228
+ (splat (uextend y @ (value_type uext_ty))))))
229
+ (if-let $true (ty_equal (lane_type in_ty) uext_ty))
230
+ (rv_vwaddu_vx (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
231
+
232
+ (rule 15 (lower (has_type (ty_vec_fits_in_register _) (iadd (splat (uextend y @ (value_type uext_ty)))
233
+ (uwiden_high x @ (value_type in_ty)))))
234
+ (if-let $true (ty_equal (lane_type in_ty) uext_ty))
235
+ (rv_vwaddu_vx (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
236
+
237
+ ;; Signed Widening Mixed High/Low Additions
238
+
239
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_low x @ (value_type in_ty))
240
+ (swiden_high y))))
241
+ (rv_vwadd_vv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
242
+
243
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (swiden_high x @ (value_type in_ty))
244
+ (swiden_low y))))
245
+ (rv_vwadd_vv (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
246
+
247
+ ;; Unsigned Widening Mixed High/Low Additions
248
+
249
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_low x @ (value_type in_ty))
250
+ (uwiden_high y))))
251
+ (rv_vwaddu_vv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
252
+
253
+ (rule 13 (lower (has_type (ty_vec_fits_in_register _) (iadd (uwiden_high x @ (value_type in_ty))
254
+ (uwiden_low y))))
255
+ (rv_vwaddu_vv (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
256
+
257
+ ;; Fused Multiply Accumulate Rules `vmacc`
258
+ ;;
259
+ ;; I dont think we can use `vmadd`/`vmnsub` here since it just modifies the multiplication
260
+ ;; register instead of the addition one. The actual pattern matched seems to be
261
+ ;; exactly the same.
262
+
263
+ (rule 9 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (imul y z))))
264
+ (rv_vmacc_vv x y z (unmasked) ty))
265
+
266
+ (rule 10 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (imul y (splat z)))))
267
+ (rv_vmacc_vx x y z (unmasked) ty))
268
+
269
+ (rule 11 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (imul (splat y) z))))
270
+ (rv_vmacc_vx x z y (unmasked) ty))
271
+
272
+ (rule 12 (lower (has_type (ty_vec_fits_in_register ty) (iadd (imul x y) z)))
273
+ (rv_vmacc_vv z x y (unmasked) ty))
274
+
275
+ (rule 13 (lower (has_type (ty_vec_fits_in_register ty) (iadd (imul x (splat y)) z)))
276
+ (rv_vmacc_vx z x y (unmasked) ty))
277
+
278
+ (rule 14 (lower (has_type (ty_vec_fits_in_register ty) (iadd (imul (splat x) y) z)))
279
+ (rv_vmacc_vx z y x (unmasked) ty))
280
+
281
+ ;; Fused Multiply Subtract Rules `vnmsac`
282
+
283
+ (rule 9 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (ineg (imul y z)))))
284
+ (rv_vnmsac_vv x y z (unmasked) ty))
285
+
286
+ (rule 10 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (ineg (imul y (splat z))))))
287
+ (rv_vnmsac_vx x y z (unmasked) ty))
288
+
289
+ (rule 11 (lower (has_type (ty_vec_fits_in_register ty) (iadd x (ineg (imul (splat y) z)))))
290
+ (rv_vnmsac_vx x z y (unmasked) ty))
291
+
292
+ (rule 12 (lower (has_type (ty_vec_fits_in_register ty) (iadd (ineg (imul x y)) z)))
293
+ (rv_vnmsac_vv z x y (unmasked) ty))
294
+
295
+ (rule 13 (lower (has_type (ty_vec_fits_in_register ty) (iadd (ineg (imul x (splat y))) z)))
296
+ (rv_vnmsac_vx z x y (unmasked) ty))
297
+
298
+ (rule 14 (lower (has_type (ty_vec_fits_in_register ty) (iadd (ineg (imul (splat x) y)) z)))
299
+ (rv_vnmsac_vx z y x (unmasked) ty))
300
+
301
+ ;;; Rules for `uadd_overflow_trap` ;;;;;;;;;;;;;
302
+ (rule 0 (lower (has_type (fits_in_32 ty) (uadd_overflow_trap x y tc)))
303
+ (let ((tmp_x XReg (zext x))
304
+ (tmp_y XReg (zext y))
305
+ (sum XReg (rv_add tmp_x tmp_y))
306
+ (test XReg (rv_srli sum (imm12_const (ty_bits ty))))
307
+ (_ InstOutput (gen_trapnz test tc)))
308
+ sum))
309
+
310
+ (rule 1 (lower (has_type $I64 (uadd_overflow_trap x y tc)))
311
+ (let ((tmp XReg (rv_add x y))
312
+ (_ InstOutput (gen_trapif (IntCC.UnsignedLessThan) tmp x tc)))
313
+ tmp))
314
+
315
+ ;;;; Rules for `isub` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
316
+ ;; Base case, simply subtracting things in registers.
317
+
318
+ (rule 0 (lower (has_type (fits_in_32 (ty_int ty)) (isub x y)))
319
+ (rv_subw x y))
320
+
321
+ (rule 1 (lower (has_type $I64 (isub x y)))
322
+ (rv_sub x y))
323
+
324
+ (rule 2 (lower (has_type $I128 (isub x y)))
325
+ (i128_sub x y))
326
+
327
+ ;; Switch to an `addi` by a negative if we can fit the value in an `imm12`.
328
+ (rule 3 (lower (has_type (ty_int_ref_scalar_64 ty) (isub x y)))
329
+ (if-let imm12_neg (imm12_from_negated_value y))
330
+ (alu_rr_imm12 (select_addi ty) x imm12_neg))
331
+
332
+ ;; SIMD Vectors
333
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (isub x y)))
334
+ (rv_vsub_vv x y (unmasked) ty))
335
+
336
+ (rule 5 (lower (has_type (ty_vec_fits_in_register ty) (isub x (splat y))))
337
+ (rv_vsub_vx x y (unmasked) ty))
338
+
339
+ (rule 6 (lower (has_type (ty_vec_fits_in_register ty) (isub x (splat (sextend y @ (value_type sext_ty))))))
340
+ (if-let half_ty (ty_half_width ty))
341
+ (if-let $true (ty_equal (lane_type half_ty) sext_ty))
342
+ (rv_vwsub_wx x y (unmasked) (vstate_mf2 half_ty)))
343
+
344
+ (rule 6 (lower (has_type (ty_vec_fits_in_register ty) (isub x (splat (uextend y @ (value_type uext_ty))))))
345
+ (if-let half_ty (ty_half_width ty))
346
+ (if-let $true (ty_equal (lane_type half_ty) uext_ty))
347
+ (rv_vwsubu_wx x y (unmasked) (vstate_mf2 half_ty)))
348
+
349
+ (rule 7 (lower (has_type (ty_vec_fits_in_register ty) (isub (splat x) y)))
350
+ (rv_vrsub_vx y x (unmasked) ty))
351
+
352
+ (rule 8 (lower (has_type (ty_vec_fits_in_register ty) (isub x y)))
353
+ (if-let imm5_neg (negated_replicated_imm5 y))
354
+ (rv_vadd_vi x imm5_neg (unmasked) ty))
355
+
356
+ (rule 9 (lower (has_type (ty_vec_fits_in_register ty) (isub x y)))
357
+ (if-let x_imm (replicated_imm5 x))
358
+ (rv_vrsub_vi y x_imm (unmasked) ty))
359
+
360
+
361
+ ;; Signed Widening Low Subtractions
362
+
363
+ (rule 6 (lower (has_type (ty_vec_fits_in_register _) (isub x (swiden_low y @ (value_type in_ty)))))
364
+ (rv_vwsub_wv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
365
+
366
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (swiden_low x @ (value_type in_ty))
367
+ (swiden_low y))))
368
+ (rv_vwsub_vv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
369
+
370
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (swiden_low x @ (value_type in_ty))
371
+ (splat (sextend y @ (value_type sext_ty))))))
372
+ (if-let $true (ty_equal (lane_type in_ty) sext_ty))
373
+ (rv_vwsub_vx x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
374
+
375
+ ;; Signed Widening High Subtractions
376
+ ;; These are the same as the low widenings, but we first slide down the inputs.
377
+
378
+ (rule 6 (lower (has_type (ty_vec_fits_in_register _) (isub x (swiden_high y @ (value_type in_ty)))))
379
+ (rv_vwsub_wv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
380
+
381
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (swiden_high x @ (value_type in_ty))
382
+ (swiden_high y))))
383
+ (rv_vwsub_vv (gen_slidedown_half in_ty x) (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
384
+
385
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (swiden_high x @ (value_type in_ty))
386
+ (splat (sextend y @ (value_type sext_ty))))))
387
+ (if-let $true (ty_equal (lane_type in_ty) sext_ty))
388
+ (rv_vwsub_vx (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
389
+
390
+ ;; Unsigned Widening Low Subtractions
391
+
392
+ (rule 6 (lower (has_type (ty_vec_fits_in_register _) (isub x (uwiden_low y @ (value_type in_ty)))))
393
+ (rv_vwsubu_wv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
394
+
395
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (uwiden_low x @ (value_type in_ty))
396
+ (uwiden_low y))))
397
+ (rv_vwsubu_vv x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
398
+
399
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (uwiden_low x @ (value_type in_ty))
400
+ (splat (uextend y @ (value_type uext_ty))))))
401
+ (if-let $true (ty_equal (lane_type in_ty) uext_ty))
402
+ (rv_vwsubu_vx x y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
403
+
404
+ ;; Unsigned Widening High Subtractions
405
+ ;; These are the same as the low widenings, but we first slide down the inputs.
406
+
407
+ (rule 6 (lower (has_type (ty_vec_fits_in_register _) (isub x (uwiden_high y @ (value_type in_ty)))))
408
+ (rv_vwsubu_wv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
409
+
410
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (uwiden_high x @ (value_type in_ty))
411
+ (uwiden_high y))))
412
+ (rv_vwsubu_vv (gen_slidedown_half in_ty x) (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
413
+
414
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (uwiden_high x @ (value_type in_ty))
415
+ (splat (uextend y @ (value_type uext_ty))))))
416
+ (if-let $true (ty_equal (lane_type in_ty) uext_ty))
417
+ (rv_vwsubu_vx (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
418
+
419
+ ;; Signed Widening Mixed High/Low Subtractions
420
+
421
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (swiden_low x @ (value_type in_ty))
422
+ (swiden_high y))))
423
+ (rv_vwsub_vv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
424
+
425
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (swiden_high x @ (value_type in_ty))
426
+ (swiden_low y))))
427
+ (rv_vwsub_vv (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
428
+
429
+ ;; Unsigned Widening Mixed High/Low Subtractions
430
+
431
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (uwiden_low x @ (value_type in_ty))
432
+ (uwiden_high y))))
433
+ (rv_vwsubu_vv x (gen_slidedown_half in_ty y) (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
434
+
435
+ (rule 10 (lower (has_type (ty_vec_fits_in_register _) (isub (uwiden_high x @ (value_type in_ty))
436
+ (uwiden_low y))))
437
+ (rv_vwsubu_vv (gen_slidedown_half in_ty x) y (unmasked) (vstate_mf2 (ty_half_lanes in_ty))))
438
+
439
+
440
+ ;;;; Rules for `ineg` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
441
+
442
+ (rule (lower (has_type (ty_int ty) (ineg val)))
443
+ (neg ty val))
444
+
445
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (ineg x)))
446
+ (rv_vneg_v x (unmasked) ty))
447
+
448
+
449
+ ;;;; Rules for `imul` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
450
+
451
+ (rule 0 (lower (has_type (ty_int_ref_scalar_64 ty) (imul x y)))
452
+ (rv_mul x y))
453
+
454
+ (rule 1 (lower (has_type (fits_in_32 (ty_int ty)) (imul x y)))
455
+ (rv_mulw x y))
456
+
457
+ ;; for I128
458
+ (rule 2 (lower (has_type $I128 (imul x y)))
459
+ (let
460
+ ((x_regs ValueRegs x)
461
+ (x_lo XReg (value_regs_get x_regs 0))
462
+ (x_hi XReg (value_regs_get x_regs 1))
463
+
464
+ ;; Get the high/low registers for `y`.
465
+ (y_regs ValueRegs y)
466
+ (y_lo XReg (value_regs_get y_regs 0))
467
+ (y_hi XReg (value_regs_get y_regs 1))
468
+
469
+ ;; 128bit mul formula:
470
+ ;; dst_lo = x_lo * y_lo
471
+ ;; dst_hi = mulhu(x_lo, y_lo) + (x_lo * y_hi) + (x_hi * y_lo)
472
+ ;;
473
+ ;; We can convert the above formula into the following
474
+ ;; mulhu dst_hi, x_lo, y_lo
475
+ ;; madd dst_hi, x_lo, y_hi, dst_hi
476
+ ;; madd dst_hi, x_hi, y_lo, dst_hi
477
+ ;; madd dst_lo, x_lo, y_lo, zero
478
+ (dst_hi1 XReg (rv_mulhu x_lo y_lo))
479
+ (dst_hi2 XReg (madd x_lo y_hi dst_hi1))
480
+ (dst_hi XReg (madd x_hi y_lo dst_hi2))
481
+ (dst_lo XReg (madd x_lo y_lo (zero_reg))))
482
+ (value_regs dst_lo dst_hi)))
483
+
484
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (imul x y)))
485
+ (rv_vmul_vv x y (unmasked) ty))
486
+
487
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (imul (splat x) y)))
488
+ (rv_vmul_vx y x (unmasked) ty))
489
+
490
+ (rule 5 (lower (has_type (ty_vec_fits_in_register ty) (imul x (splat y))))
491
+ (rv_vmul_vx x y (unmasked) ty))
492
+
493
+ ;;;; Rules for `smulhi` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
494
+ (rule 0 (lower (has_type (ty_int_ref_scalar_64 ty) (smulhi x y)))
495
+ (lower_smlhi ty (sext x) (sext y)))
496
+
497
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (smulhi x y)))
498
+ (rv_vmulh_vv x y (unmasked) ty))
499
+
500
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (smulhi (splat x) y)))
501
+ (rv_vmulh_vx y x (unmasked) ty))
502
+
503
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (smulhi x (splat y))))
504
+ (rv_vmulh_vx x y (unmasked) ty))
505
+
506
+ ;;;; Rules for `umulhi` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
507
+ (rule 0 (lower (has_type (fits_in_32 ty) (umulhi x y)))
508
+ (let ((tmp XReg (rv_mul (zext x) (zext y))))
509
+ (rv_srli tmp (imm12_const (ty_bits ty)))))
510
+
511
+ (rule 1 (lower (has_type $I64 (umulhi x y)))
512
+ (rv_mulhu x y))
513
+
514
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (umulhi x y)))
515
+ (rv_vmulhu_vv x y (unmasked) ty))
516
+
517
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (umulhi (splat x) y)))
518
+ (rv_vmulhu_vx y x (unmasked) ty))
519
+
520
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (umulhi x (splat y))))
521
+ (rv_vmulhu_vx x y (unmasked) ty))
522
+
523
+ ;;;; Rules for `udiv` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
524
+
525
+ (rule 0 (lower (has_type (fits_in_16 ty) (udiv x y)))
526
+ (if-let $true (has_m))
527
+ (rv_divuw (zext x) (nonzero_divisor (zext y))))
528
+
529
+ (rule 1 (lower (has_type (fits_in_16 ty) (udiv x y @ (iconst imm))))
530
+ (if-let $true (has_m))
531
+ (if (safe_divisor_from_imm64 ty imm))
532
+ (rv_divuw (zext x) (zext y)))
533
+
534
+ (rule 2 (lower (has_type $I32 (udiv x y)))
535
+ (if-let $true (has_m))
536
+ (rv_divuw x (nonzero_divisor (zext y))))
537
+
538
+ (rule 3 (lower (has_type $I32 (udiv x y @ (iconst imm))))
539
+ (if-let $true (has_m))
540
+ (if (safe_divisor_from_imm64 $I32 imm))
541
+ (rv_divuw x y))
542
+
543
+ (rule 2 (lower (has_type $I64 (udiv x y)))
544
+ (if-let $true (has_m))
545
+ (rv_divu x (nonzero_divisor y)))
546
+
547
+ (rule 3 (lower (has_type $I64 (udiv x y @ (iconst imm))))
548
+ (if-let $true (has_m))
549
+ (if (safe_divisor_from_imm64 $I64 imm))
550
+ (rv_divu x y))
551
+
552
+ ;; Traps if the input register is zero, otherwise returns the same register.
553
+ (decl nonzero_divisor (XReg) XReg)
554
+ (rule (nonzero_divisor val)
555
+ (let ((_ InstOutput (gen_trapif (IntCC.Equal) val (zero_reg) (TrapCode.IntegerDivisionByZero))))
556
+ val))
557
+
558
+ ;;;; Rules for `sdiv` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
559
+
560
+ (rule 0 (lower (has_type (fits_in_16 ty) (sdiv x y)))
561
+ (if-let $true (has_m))
562
+ (let ((x XReg (sext x)))
563
+ (rv_divw x (safe_sdiv_divisor ty x (sext y)))))
564
+
565
+ (rule 1 (lower (has_type (fits_in_16 ty) (sdiv x y @ (iconst imm))))
566
+ (if-let $true (has_m))
567
+ (if (safe_divisor_from_imm64 ty imm))
568
+ (rv_divw (sext x) (sext y)))
569
+
570
+ (rule 2 (lower (has_type $I32 (sdiv x y)))
571
+ (if-let $true (has_m))
572
+ (let ((x XReg (sext x)))
573
+ (rv_divw x (safe_sdiv_divisor $I32 x (sext y)))))
574
+
575
+ (rule 3 (lower (has_type $I32 (sdiv x y @ (iconst imm))))
576
+ (if-let $true (has_m))
577
+ (if (safe_divisor_from_imm64 $I32 imm))
578
+ (rv_divw x y))
579
+
580
+ (rule 2 (lower (has_type $I64 (sdiv x y)))
581
+ (if-let $true (has_m))
582
+ (rv_div x (safe_sdiv_divisor $I64 x y)))
583
+
584
+ (rule 3 (lower (has_type $I64 (sdiv x y @ (iconst imm))))
585
+ (if-let $true (has_m))
586
+ (if (safe_divisor_from_imm64 $I64 imm))
587
+ (rv_div x y))
588
+
589
+ ;; Check for two trapping conditions:
590
+ ;;
591
+ ;; * the divisor is 0, or...
592
+ ;; * the divisor is -1 and the dividend is $ty::MIN
593
+ (decl safe_sdiv_divisor (Type XReg XReg) XReg)
594
+ (rule (safe_sdiv_divisor ty x y)
595
+ (let (
596
+ (y XReg (nonzero_divisor y))
597
+ (min XReg (imm $I64 (u64_shl 0xffffffff_ffffffff (u64_sub (ty_bits ty) 1))))
598
+ (x_is_not_min XReg (rv_xor x min))
599
+ (y_is_not_neg_one XReg (rv_not y))
600
+ (no_int_overflow XReg (rv_or x_is_not_min y_is_not_neg_one))
601
+ (_ InstOutput (gen_trapif
602
+ (IntCC.Equal)
603
+ no_int_overflow (zero_reg)
604
+ (TrapCode.IntegerOverflow))))
605
+ y))
606
+
607
+ ;;;; Rules for `urem` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
608
+
609
+ (rule 0 (lower (has_type (fits_in_16 ty) (urem x y)))
610
+ (if-let $true (has_m))
611
+ (rv_remuw (zext x) (nonzero_divisor (zext y))))
612
+
613
+ (rule 1 (lower (has_type (fits_in_16 ty) (urem x y @ (iconst imm))))
614
+ (if-let $true (has_m))
615
+ (if (safe_divisor_from_imm64 ty imm))
616
+ (rv_remuw (zext x) (zext y)))
617
+
618
+ (rule 2 (lower (has_type $I32 (urem x y)))
619
+ (if-let $true (has_m))
620
+ (rv_remuw x (nonzero_divisor (zext y))))
621
+
622
+ (rule 3 (lower (has_type $I32 (urem x y @ (iconst imm))))
623
+ (if-let $true (has_m))
624
+ (if (safe_divisor_from_imm64 $I32 imm))
625
+ (rv_remuw x y))
626
+
627
+ (rule 2 (lower (has_type $I64 (urem x y)))
628
+ (if-let $true (has_m))
629
+ (rv_remu x (nonzero_divisor y)))
630
+
631
+ (rule 3 (lower (has_type $I64 (urem x y @ (iconst imm))))
632
+ (if-let $true (has_m))
633
+ (if (safe_divisor_from_imm64 $I64 imm))
634
+ (rv_remu x y))
635
+
636
+ ;;;; Rules for `srem` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
637
+
638
+ (rule 0 (lower (has_type (fits_in_16 ty) (srem x y)))
639
+ (if-let $true (has_m))
640
+ (rv_remw (sext x) (nonzero_divisor (sext y))))
641
+
642
+ (rule 1 (lower (has_type (fits_in_16 ty) (srem x y @ (iconst imm))))
643
+ (if-let $true (has_m))
644
+ (if (safe_divisor_from_imm64 ty imm))
645
+ (rv_remw (sext x) (sext y)))
646
+
647
+ (rule 2 (lower (has_type $I32 (srem x y)))
648
+ (if-let $true (has_m))
649
+ (rv_remw x (nonzero_divisor (sext y))))
650
+
651
+ (rule 3 (lower (has_type $I32 (srem x y @ (iconst imm))))
652
+ (if-let $true (has_m))
653
+ (if (safe_divisor_from_imm64 $I32 imm))
654
+ (rv_remw x y))
655
+
656
+ (rule 2 (lower (has_type $I64 (srem x y)))
657
+ (if-let $true (has_m))
658
+ (rv_rem x (nonzero_divisor y)))
659
+
660
+ (rule 3 (lower (has_type $I64 (srem x y @ (iconst imm))))
661
+ (if-let $true (has_m))
662
+ (if (safe_divisor_from_imm64 $I64 imm))
663
+ (rv_rem x y))
664
+
665
+ ;;;; Rules for `and` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
666
+ (rule -1 (lower (has_type (fits_in_64 ty) (band x y)))
667
+ (rv_and x y))
668
+
669
+ (rule 0 (lower (has_type $I128 (band x y)))
670
+ (value_regs
671
+ (rv_and (value_regs_get x 0) (value_regs_get y 0))
672
+ (rv_and (value_regs_get x 1) (value_regs_get y 1))))
673
+
674
+ ;; Special cases for when one operand is an immediate that fits in 12 bits.
675
+ (rule 1 (lower (has_type (fits_in_64 (ty_int ty)) (band x (imm12_from_value y))))
676
+ (rv_andi x y))
677
+
678
+ (rule 2 (lower (has_type (fits_in_64 (ty_int ty)) (band (imm12_from_value x) y)))
679
+ (rv_andi y x))
680
+
681
+ (rule 3 (lower (has_type (ty_scalar_float ty) (band x y)))
682
+ (lower_float_binary (AluOPRRR.And) x y ty))
683
+
684
+ ;; Specialized lowerings for `(band x (bnot y))` which is additionally produced
685
+ ;; by Cranelift's `band_not` instruction that is legalized into the simpler
686
+ ;; forms early on.
687
+
688
+ (rule 4 (lower (has_type (fits_in_64 (ty_int ty)) (band x (bnot y))))
689
+ (if-let $true (has_zbb))
690
+ (rv_andn x y))
691
+
692
+ (rule 5 (lower (has_type (fits_in_64 (ty_int ty)) (band (bnot y) x)))
693
+ (if-let $true (has_zbb))
694
+ (rv_andn x y))
695
+
696
+ (rule 6 (lower (has_type $I128 (band x (bnot y))))
697
+ (if-let $true (has_zbb))
698
+ (let ((low XReg (rv_andn (value_regs_get x 0) (value_regs_get y 0)))
699
+ (high XReg (rv_andn (value_regs_get x 1) (value_regs_get y 1))))
700
+ (value_regs low high)))
701
+
702
+ (rule 7 (lower (has_type $I128 (band (bnot y) x)))
703
+ (if-let $true (has_zbb))
704
+ (let ((low XReg (rv_andn (value_regs_get x 0) (value_regs_get y 0)))
705
+ (high XReg (rv_andn (value_regs_get x 1) (value_regs_get y 1))))
706
+ (value_regs low high)))
707
+
708
+ (rule 8 (lower (has_type (ty_vec_fits_in_register ty) (band x y)))
709
+ (rv_vand_vv x y (unmasked) ty))
710
+
711
+ (rule 9 (lower (has_type (ty_vec_fits_in_register ty) (band x (splat y))))
712
+ (if (ty_vector_not_float ty))
713
+ (rv_vand_vx x y (unmasked) ty))
714
+
715
+ (rule 10 (lower (has_type (ty_vec_fits_in_register ty) (band (splat x) y)))
716
+ (if (ty_vector_not_float ty))
717
+ (rv_vand_vx y x (unmasked) ty))
718
+
719
+ (rule 11 (lower (has_type (ty_vec_fits_in_register ty) (band x y)))
720
+ (if-let y_imm (replicated_imm5 y))
721
+ (rv_vand_vi x y_imm (unmasked) ty))
722
+
723
+ (rule 12 (lower (has_type (ty_vec_fits_in_register ty) (band x y)))
724
+ (if-let x_imm (replicated_imm5 x))
725
+ (rv_vand_vi y x_imm (unmasked) ty))
726
+
727
+ ;; `bclr{,i}` specializations from `zbs`
728
+
729
+ (rule 13 (lower (has_type (fits_in_32 ty) (band x (bnot (ishl (i64_from_iconst 1) y)))))
730
+ (if-let $true (has_zbs))
731
+ (rv_bclr x (rv_andi y (imm12_const (u8_sub (ty_bits ty) 1)))))
732
+ (rule 14 (lower (has_type (fits_in_32 ty) (band (bnot (ishl (i64_from_iconst 1) y)) x)))
733
+ (if-let $true (has_zbs))
734
+ (rv_bclr x (rv_andi y (imm12_const (u8_sub (ty_bits ty) 1)))))
735
+
736
+ (rule 15 (lower (has_type $I64 (band x (bnot (ishl (i64_from_iconst 1) y)))))
737
+ (if-let $true (has_zbs))
738
+ (rv_bclr x y))
739
+ (rule 16 (lower (has_type $I64 (band (bnot (ishl (i64_from_iconst 1) y)) x)))
740
+ (if-let $true (has_zbs))
741
+ (rv_bclr x y))
742
+
743
+ (rule 17 (lower (has_type (fits_in_64 ty) (band x (u64_from_iconst n))))
744
+ (if-let $true (has_zbs))
745
+ (if-let imm (bclr_imm ty n))
746
+ (rv_bclri x imm))
747
+ (rule 18 (lower (has_type (fits_in_64 ty) (band (u64_from_iconst n) x)))
748
+ (if-let $true (has_zbs))
749
+ (if-let imm (bclr_imm ty n))
750
+ (rv_bclri x imm))
751
+
752
+ (decl pure partial bclr_imm (Type u64) Imm12)
753
+ (extern constructor bclr_imm bclr_imm)
754
+
755
+ ;; `bext{,i}` specializations from `zbs`
756
+
757
+ (rule 19 (lower (has_type $I32 (band (ushr x y) (u64_from_iconst 1))))
758
+ (if-let $true (has_zbs))
759
+ (rv_bext x (rv_andi y (imm12_const 31))))
760
+ (rule 19 (lower (has_type $I32 (band (sshr x y) (u64_from_iconst 1))))
761
+ (if-let $true (has_zbs))
762
+ (rv_bext x (rv_andi y (imm12_const 31))))
763
+ (rule 19 (lower (has_type $I32 (band (u64_from_iconst 1) (ushr x y))))
764
+ (if-let $true (has_zbs))
765
+ (rv_bext x (rv_andi y (imm12_const 31))))
766
+ (rule 19 (lower (has_type $I32 (band (u64_from_iconst 1) (sshr x y))))
767
+ (if-let $true (has_zbs))
768
+ (rv_bext x (rv_andi y (imm12_const 31))))
769
+
770
+ (rule 19 (lower (has_type $I64 (band (ushr x y) (u64_from_iconst 1))))
771
+ (if-let $true (has_zbs))
772
+ (rv_bext x y))
773
+ (rule 19 (lower (has_type $I64 (band (sshr x y) (u64_from_iconst 1))))
774
+ (if-let $true (has_zbs))
775
+ (rv_bext x y))
776
+ (rule 19 (lower (has_type $I64 (band (u64_from_iconst 1) (ushr x y))))
777
+ (if-let $true (has_zbs))
778
+ (rv_bext x y))
779
+ (rule 19 (lower (has_type $I64 (band (u64_from_iconst 1) (sshr x y))))
780
+ (if-let $true (has_zbs))
781
+ (rv_bext x y))
782
+
783
+ (rule 20 (lower (has_type $I32 (band (ushr x (imm12_from_value y)) (u64_from_iconst 1))))
784
+ (if-let $true (has_zbs))
785
+ (rv_bexti x (imm12_and y 31)))
786
+ (rule 20 (lower (has_type $I32 (band (sshr x (imm12_from_value y)) (u64_from_iconst 1))))
787
+ (if-let $true (has_zbs))
788
+ (rv_bexti x (imm12_and y 31)))
789
+ (rule 20 (lower (has_type $I64 (band (ushr x (imm12_from_value y)) (u64_from_iconst 1))))
790
+ (if-let $true (has_zbs))
791
+ (rv_bexti x (imm12_and y 63)))
792
+ (rule 20 (lower (has_type $I64 (band (sshr x (imm12_from_value y)) (u64_from_iconst 1))))
793
+ (if-let $true (has_zbs))
794
+ (rv_bexti x (imm12_and y 63)))
795
+
796
+ ;;;; Rules for `or` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
797
+ (rule 0 (lower (has_type (ty_int ty) (bor x y)))
798
+ (gen_or ty x y))
799
+
800
+ ;; Special cases for when one operand is an immediate that fits in 12 bits.
801
+ (rule 1 (lower (has_type (fits_in_64 (ty_int ty)) (bor x (imm12_from_value y))))
802
+ (rv_ori x y))
803
+
804
+ (rule 2 (lower (has_type (fits_in_64 (ty_int ty)) (bor (imm12_from_value x) y)))
805
+ (rv_ori y x))
806
+
807
+ (rule 3 (lower (has_type (ty_scalar_float ty) (bor x y)))
808
+ (lower_float_binary (AluOPRRR.Or) x y ty))
809
+
810
+ ;; Specialized lowerings for `(bor x (bnot y))` which is additionally produced
811
+ ;; by Cranelift's `bor_not` instruction that is legalized into the simpler
812
+ ;; forms early on.
813
+
814
+ (rule 4 (lower (has_type (fits_in_64 (ty_int ty)) (bor x (bnot y))))
815
+ (if-let $true (has_zbb))
816
+ (rv_orn x y))
817
+
818
+ (rule 5 (lower (has_type (fits_in_64 (ty_int ty)) (bor (bnot y) x)))
819
+ (if-let $true (has_zbb))
820
+ (rv_orn x y))
821
+
822
+ (rule 6 (lower (has_type $I128 (bor x (bnot y))))
823
+ (if-let $true (has_zbb))
824
+ (let ((low XReg (rv_orn (value_regs_get x 0) (value_regs_get y 0)))
825
+ (high XReg (rv_orn (value_regs_get x 1) (value_regs_get y 1))))
826
+ (value_regs low high)))
827
+
828
+ (rule 7 (lower (has_type $I128 (bor (bnot y) x)))
829
+ (if-let $true (has_zbb))
830
+ (let ((low XReg (rv_orn (value_regs_get x 0) (value_regs_get y 0)))
831
+ (high XReg (rv_orn (value_regs_get x 1) (value_regs_get y 1))))
832
+ (value_regs low high)))
833
+
834
+ (rule 8 (lower (has_type (ty_vec_fits_in_register ty) (bor x y)))
835
+ (rv_vor_vv x y (unmasked) ty))
836
+
837
+ (rule 9 (lower (has_type (ty_vec_fits_in_register ty) (bor x (splat y))))
838
+ (if (ty_vector_not_float ty))
839
+ (rv_vor_vx x y (unmasked) ty))
840
+
841
+ (rule 10 (lower (has_type (ty_vec_fits_in_register ty) (bor (splat x) y)))
842
+ (if (ty_vector_not_float ty))
843
+ (rv_vor_vx y x (unmasked) ty))
844
+
845
+ (rule 11 (lower (has_type (ty_vec_fits_in_register ty) (bor x y)))
846
+ (if-let y_imm (replicated_imm5 y))
847
+ (rv_vor_vi x y_imm (unmasked) ty))
848
+
849
+ (rule 12 (lower (has_type (ty_vec_fits_in_register ty) (bor x y)))
850
+ (if-let x_imm (replicated_imm5 x))
851
+ (rv_vor_vi y x_imm (unmasked) ty))
852
+
853
+ ;; `bset{,i}` specializations from `zbs`
854
+
855
+ (rule 13 (lower (has_type $I32 (bor x (ishl (i64_from_iconst 1) y))))
856
+ (if-let $true (has_zbs))
857
+ (rv_bset x (rv_andi y (imm12_const 31))))
858
+ (rule 14 (lower (has_type $I32 (bor (ishl (i64_from_iconst 1) y) x)))
859
+ (if-let $true (has_zbs))
860
+ (rv_bset x (rv_andi y (imm12_const 31))))
861
+
862
+ (rule 13 (lower (has_type $I64 (bor x (ishl (i64_from_iconst 1) y))))
863
+ (if-let $true (has_zbs))
864
+ (rv_bset x y))
865
+ (rule 14 (lower (has_type $I64 (bor (ishl (i64_from_iconst 1) y) x)))
866
+ (if-let $true (has_zbs))
867
+ (rv_bset x y))
868
+
869
+ (rule 15 (lower (has_type (fits_in_64 _) (bor x (u64_from_iconst n))))
870
+ (if-let $true (has_zbs))
871
+ (if-let imm (bseti_imm n))
872
+ (rv_bseti x imm))
873
+ (rule 16 (lower (has_type (fits_in_64 _) (bor (u64_from_iconst n) x)))
874
+ (if-let $true (has_zbs))
875
+ (if-let imm (bseti_imm n))
876
+ (rv_bseti x imm))
877
+
878
+ (decl pure partial bseti_imm (u64) Imm12)
879
+ (extern constructor bseti_imm bseti_imm)
880
+
881
+ ;;;; Rules for `xor` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
882
+ (rule 0 (lower (has_type (fits_in_64 (ty_int ty)) (bxor x y)))
883
+ (rv_xor x y))
884
+
885
+ ;; Special cases for when one operand is an immediate that fits in 12 bits.
886
+ (rule 1 (lower (has_type (fits_in_64 (ty_int ty)) (bxor x (imm12_from_value y))))
887
+ (rv_xori x y))
888
+
889
+ (rule 2 (lower (has_type (fits_in_64 (ty_int ty)) (bxor (imm12_from_value x) y)))
890
+ (rv_xori y x))
891
+
892
+ (rule 3 (lower (has_type $I128 (bxor x y)))
893
+ (lower_b128_binary (AluOPRRR.Xor) x y))
894
+
895
+ (rule 4 (lower (has_type (ty_scalar_float ty) (bxor x y)))
896
+ (lower_float_binary (AluOPRRR.Xor) x y ty))
897
+
898
+ (rule 5 (lower (has_type (ty_vec_fits_in_register ty) (bxor x y)))
899
+ (rv_vxor_vv x y (unmasked) ty))
900
+
901
+ (rule 6 (lower (has_type (ty_vec_fits_in_register ty) (bxor x (splat y))))
902
+ (if (ty_vector_not_float ty))
903
+ (rv_vxor_vx x y (unmasked) ty))
904
+
905
+ (rule 7 (lower (has_type (ty_vec_fits_in_register ty) (bxor (splat x) y)))
906
+ (if (ty_vector_not_float ty))
907
+ (rv_vxor_vx y x (unmasked) ty))
908
+
909
+ (rule 8 (lower (has_type (ty_vec_fits_in_register ty) (bxor x y)))
910
+ (if-let y_imm (replicated_imm5 y))
911
+ (rv_vxor_vi x y_imm (unmasked) ty))
912
+
913
+ (rule 9 (lower (has_type (ty_vec_fits_in_register ty) (bxor x y)))
914
+ (if-let x_imm (replicated_imm5 x))
915
+ (rv_vxor_vi y x_imm (unmasked) ty))
916
+
917
+ ;; `binv{,i}` specializations from `zbs`
918
+
919
+ (rule 13 (lower (has_type $I32 (bxor x (ishl (i64_from_iconst 1) y))))
920
+ (if-let $true (has_zbs))
921
+ (rv_binv x (rv_andi y (imm12_const 31))))
922
+ (rule 14 (lower (has_type $I32 (bxor (ishl (i64_from_iconst 1) y) x)))
923
+ (if-let $true (has_zbs))
924
+ (rv_binv x (rv_andi y (imm12_const 31))))
925
+
926
+ (rule 13 (lower (has_type $I64 (bxor x (ishl (i64_from_iconst 1) y))))
927
+ (if-let $true (has_zbs))
928
+ (rv_binv x y))
929
+ (rule 14 (lower (has_type $I64 (bxor (ishl (i64_from_iconst 1) y) x)))
930
+ (if-let $true (has_zbs))
931
+ (rv_binv x y))
932
+
933
+ (rule 15 (lower (has_type (fits_in_64 _) (bxor x (u64_from_iconst n))))
934
+ (if-let $true (has_zbs))
935
+ (if-let imm (binvi_imm n))
936
+ (rv_binvi x imm))
937
+ (rule 16 (lower (has_type (fits_in_64 _) (bxor (u64_from_iconst n) x)))
938
+ (if-let $true (has_zbs))
939
+ (if-let imm (binvi_imm n))
940
+ (rv_binvi x imm))
941
+
942
+ (decl pure partial binvi_imm (u64) Imm12)
943
+ (extern constructor binvi_imm binvi_imm)
944
+
945
+ ;;;; Rules for `bnot` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
946
+
947
+ (rule 0 (lower (has_type (ty_int_ref_scalar_64 _) (bnot x)))
948
+ (rv_not x))
949
+
950
+ (rule 1 (lower (has_type (ty_scalar_float ty) (bnot x)))
951
+ (move_x_to_f (rv_not (move_f_to_x x ty)) (float_int_of_same_size ty)))
952
+
953
+ (rule 2 (lower (has_type $I128 (bnot x)))
954
+ (value_regs
955
+ (rv_not (value_regs_get x 0))
956
+ (rv_not (value_regs_get x 1))))
957
+
958
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (bnot x)))
959
+ (rv_vnot_v x (unmasked) ty))
960
+
961
+ (rule 4 (lower (has_type (ty_int_ref_scalar_64 _) (bnot (bxor x y))))
962
+ (if-let $true (has_zbb))
963
+ (rv_xnor x y))
964
+
965
+ ;;;; Rules for `bit_reverse` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
966
+
967
+ (rule 0 (lower (has_type (ty_int_ref_scalar_64 ty) (bitrev x)))
968
+ (gen_bitrev ty x))
969
+
970
+ (rule 1 (lower (has_type $I128 (bitrev x)))
971
+ (value_regs
972
+ (gen_bitrev $I64 (value_regs_get x 1))
973
+ (gen_bitrev $I64 (value_regs_get x 0))))
974
+
975
+
976
+ ;; Constructs a sequence of instructions that reverse all bits in `x` up to
977
+ ;; the given type width.
978
+ (decl gen_bitrev (Type XReg) XReg)
979
+
980
+ (rule 0 (gen_bitrev (ty_16_or_32 (ty_int ty)) x)
981
+ (if-let shift_amt (u64_to_imm12 (u64_sub 64 (ty_bits ty))))
982
+ (rv_srli (gen_bitrev $I64 x) shift_amt))
983
+
984
+ (rule 1 (gen_bitrev $I8 x)
985
+ (gen_brev8 x $I8))
986
+
987
+ (rule 1 (gen_bitrev $I64 x)
988
+ (gen_brev8 (gen_bswap $I64 x) $I64))
989
+
990
+
991
+ ;;;; Rules for `bswap` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
992
+
993
+ (rule 1 (lower (has_type (fits_in_64 (ty_int ty)) (bswap x)))
994
+ (gen_bswap ty x))
995
+
996
+ (rule 2 (lower (has_type $I128 (bswap x)))
997
+ (value_regs
998
+ (gen_bswap $I64 (value_regs_get x 1))
999
+ (gen_bswap $I64 (value_regs_get x 0))))
1000
+
1001
+ ;; Builds a sequence of instructions that swaps the bytes in `x` up to the given
1002
+ ;; type width.
1003
+ (decl gen_bswap (Type XReg) XReg)
1004
+
1005
+ ;; This is only here to make the rule below work. bswap.i8 isn't valid
1006
+ (rule 0 (gen_bswap $I8 x) x)
1007
+ (rule 1 (gen_bswap (ty_int_ref_16_to_64 ty) x)
1008
+ (if-let half_ty (ty_half_width ty))
1009
+ (if-let half_size (u64_to_imm12 (ty_bits half_ty)))
1010
+ (let (;; This swaps the top bytes and zeroes the bottom bytes, so that
1011
+ ;; we can or it with the bottom bytes later.
1012
+ (swap_top XReg (gen_bswap half_ty x))
1013
+ (top XReg (rv_slli swap_top half_size))
1014
+
1015
+ ;; Get the top half, swap it, and zero extend it so we can `or` it
1016
+ ;; with the bottom half. Note that zero extension here already knows
1017
+ ;; that `zbb` isn't available and that `half_ty` is not `$I64`, so this
1018
+ ;; falls back to the shift-then-shift sequence.
1019
+ (shifted XReg (rv_srli x half_size))
1020
+ (swap_bot XReg (gen_bswap half_ty shifted))
1021
+ (shift Imm12 (imm_from_bits (u64_sub 64 (ty_bits half_ty))))
1022
+ (bot_shifted_left XReg (rv_slli swap_bot shift))
1023
+ (bot XReg (rv_srli bot_shifted_left shift)))
1024
+ (rv_or top bot)))
1025
+
1026
+ (rule 2 (gen_bswap (ty_16_or_32 (ty_int ty)) x)
1027
+ (if-let $true (has_zbb))
1028
+ (if-let shift_amt (u64_to_imm12 (u64_sub 64 (ty_bits ty))))
1029
+ (rv_srli (rv_rev8 x) shift_amt))
1030
+
1031
+ (rule 3 (gen_bswap $I64 x)
1032
+ (if-let $true (has_zbb))
1033
+ (rv_rev8 x))
1034
+
1035
+ ;;;; Rules for `ctz` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1036
+ (rule (lower (has_type (fits_in_64 ty) (ctz x)))
1037
+ (lower_ctz ty x))
1038
+
1039
+ (rule 1 (lower (has_type $I128 (ctz x)))
1040
+ (let ((x_lo XReg (value_regs_get x 0))
1041
+ (x_hi XReg (value_regs_get x 1))
1042
+ ;; Count both halves
1043
+ (high XReg (lower_ctz $I64 x_hi))
1044
+ (low XReg (lower_ctz $I64 x_lo))
1045
+ ;; Only add the top half if the bottom is zero
1046
+ (high XReg (gen_select_xreg (cmp_eqz x_lo) high (zero_reg)))
1047
+ (result XReg (rv_add low high)))
1048
+ (value_regs result (imm $I64 0))))
1049
+
1050
+ ;;;; Rules for `clz` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1051
+ (rule 0 (lower (has_type (fits_in_64 ty) (clz x)))
1052
+ (gen_cltz $true x ty))
1053
+
1054
+ (rule 1 (lower (has_type $I128 (clz x)))
1055
+ (let ((x_lo XReg (value_regs_get x 0))
1056
+ (x_hi XReg (value_regs_get x 1))
1057
+ ;; Count both halves
1058
+ (high XReg (gen_clz x_hi))
1059
+ (low XReg (gen_clz x_lo))
1060
+ ;; Only add the bottom zeros if the top half is zero
1061
+ (low XReg (gen_select_xreg (cmp_eqz x_hi) low (zero_reg))))
1062
+ (value_regs (rv_add high low) (imm $I64 0))))
1063
+
1064
+ (rule 2 (lower (has_type (fits_in_16 ty) (clz x)))
1065
+ (if-let $true (has_zbb))
1066
+ (let ((tmp XReg (zext x))
1067
+ (count XReg (rv_clz tmp)))
1068
+ ;; We always do the operation on the full 64-bit register, so subtract 64 from the result.
1069
+ (rv_addi count (imm12_const_add (ty_bits ty) -64))))
1070
+
1071
+ (rule 3 (lower (has_type $I32 (clz x)))
1072
+ (if-let $true (has_zbb))
1073
+ (rv_clzw x))
1074
+
1075
+ (rule 3 (lower (has_type $I64 (clz x)))
1076
+ (if-let $true (has_zbb))
1077
+ (rv_clz x))
1078
+
1079
+ (decl gen_clz (XReg) XReg)
1080
+ (rule 0 (gen_clz rs)
1081
+ (gen_cltz $true rs $I64))
1082
+ (rule 1 (gen_clz rs)
1083
+ (if-let $true (has_zbb))
1084
+ (rv_clz rs))
1085
+
1086
+ ;;;; Rules for `cls` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1087
+
1088
+ (rule (lower (has_type (fits_in_64 ty) (cls x)))
1089
+ (let ((tmp XReg (sext x))
1090
+ (tmp2 XReg (gen_select_xreg (cmp_ltz tmp) (rv_not tmp) tmp))
1091
+ (tmp3 XReg (gen_clz tmp2)))
1092
+ ;; clz counted the full register width, so subtract (64-$width), and then
1093
+ ;; additionally subtract one more, meaning here -65+width is added.
1094
+ (rv_addi tmp3 (imm12_const_add (ty_bits ty) -65))))
1095
+
1096
+ ;; If the sign bit is set, we count the leading zeros of the inverted value.
1097
+ ;; Otherwise we can just count the leading zeros of the original value.
1098
+ ;; Subtract 1 since the sign bit does not count.
1099
+ (rule 1 (lower (has_type $I128 (cls x)))
1100
+ (let ((low XReg (value_regs_get x 0))
1101
+ (high XReg (value_regs_get x 1))
1102
+ (low XReg (gen_select_xreg (cmp_ltz high) (rv_not low) low))
1103
+ (high XReg (gen_select_xreg (cmp_ltz high) (rv_not high) high))
1104
+
1105
+ ;; Count both halves
1106
+ (high_cnt XReg (gen_clz high))
1107
+ (low_cnt XReg (gen_clz low))
1108
+ ;; Only add the bottom zeros if the top half is zero
1109
+ (low_cnt XReg (gen_select_xreg (cmp_eqz high) low_cnt (zero_reg)))
1110
+ (count XReg (rv_add high_cnt low_cnt))
1111
+ (result XReg (rv_addi count (imm12_const -1))))
1112
+ (value_regs result (imm $I64 0))))
1113
+
1114
+
1115
+ ;;;; Rules for `uextend` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1116
+ (rule 0 (lower (has_type (fits_in_64 _) (uextend val)))
1117
+ (zext val))
1118
+ (rule 1 (lower (has_type $I128 (uextend val)))
1119
+ (value_regs (zext val) (imm $I64 0)))
1120
+
1121
+ ;;;; Rules for `sextend` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1122
+ (rule 0 (lower (has_type (fits_in_64 _) (sextend val @ (value_type in_ty))))
1123
+ (sext val))
1124
+ (rule 1 (lower (has_type $I128 (sextend val @ (value_type in_ty))))
1125
+ (let ((lo XReg (sext val)))
1126
+ (value_regs lo (rv_srai lo (imm12_const 63)))))
1127
+
1128
+ ;;;; Rules for `popcnt` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1129
+
1130
+ (rule 0 (lower (has_type (fits_in_64 _) (popcnt x)))
1131
+ (gen_popcnt (zext x)))
1132
+
1133
+ (rule 1 (lower (has_type $I128 (popcnt x)))
1134
+ (let
1135
+ ((x ValueRegs x)
1136
+ (low XReg (gen_popcnt (value_regs_get x 0)))
1137
+ (high XReg (gen_popcnt (value_regs_get x 1)))
1138
+ (result XReg (rv_add low high)))
1139
+ (value_regs result (imm $I64 0))))
1140
+
1141
+ (rule 2 (lower (has_type (fits_in_64 _) (popcnt x)))
1142
+ (if-let $true (has_zbb))
1143
+ (rv_cpop (zext x)))
1144
+
1145
+ (rule 3 (lower (has_type $I32 (popcnt x)))
1146
+ (if-let $true (has_zbb))
1147
+ (rv_cpopw x))
1148
+
1149
+ (rule 3 (lower (has_type $I128 (popcnt x)))
1150
+ (if-let $true (has_zbb))
1151
+ (let
1152
+ ((x ValueRegs x)
1153
+ (low XReg (rv_cpop (value_regs_get x 0)))
1154
+ (high XReg (rv_cpop (value_regs_get x 1)))
1155
+ (result XReg (rv_add low high)))
1156
+ (value_regs result (imm $I64 0))))
1157
+
1158
+ ;; Popcount using multiply.
1159
+ ;; This is popcount64c() from
1160
+ ;; http://en.wikipedia.org/wiki/Hamming_weight
1161
+ ;;
1162
+ ;; Here's the C version for 32 bits:
1163
+ ;; x = x - ((x>> 1) & 0x55555555);
1164
+ ;; x = (x & 0x33333333) + ((x >> 2) & 0x33333333);
1165
+ ;; x = ((x + (x >> 4)) & 0x0F0F0F0F);
1166
+ ;; return (x * 0x01010101) >> 24; // Here 24 is the type width - 8.
1167
+ ;;
1168
+ ;; TODO: LLVM generates a much better implementation for I8X16. See: https://godbolt.org/z/qr6vf9Gr3
1169
+ ;; For the other types it seems to be largely the same.
1170
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (popcnt x)))
1171
+ (if-let one (u64_to_uimm5 1))
1172
+ (if-let two (u64_to_uimm5 2))
1173
+ (if-let four (u64_to_uimm5 4))
1174
+
1175
+ (let (;; x = x - ((x >> 1) & 0x55555555);
1176
+ (mask_55 XReg (imm (lane_type ty) (u64_and 0x5555555555555555 (ty_mask (lane_type ty)))))
1177
+ (count2_shr VReg (rv_vsrl_vi x one (unmasked) ty))
1178
+ (count2_and VReg (rv_vand_vx count2_shr mask_55 (unmasked) ty))
1179
+ (count2 VReg (rv_vsub_vv x count2_and (unmasked) ty))
1180
+
1181
+ ;; x = (x & 0x33333333) + ((x >> 2) & 0x33333333);
1182
+ (mask_33 XReg (imm (lane_type ty) (u64_and 0x3333333333333333 (ty_mask (lane_type ty)))))
1183
+ (count4_shr VReg (rv_vsrl_vi count2 two (unmasked) ty))
1184
+ (count4_and VReg (rv_vand_vx count4_shr mask_33 (unmasked) ty))
1185
+ (count4_lhs VReg (rv_vand_vx count2 mask_33 (unmasked) ty))
1186
+ (count4 VReg (rv_vadd_vv count4_lhs count4_and (unmasked) ty))
1187
+
1188
+ ;; x = (x + (x >> 4)) & 0x0F0F0F0F;
1189
+ (mask_0f XReg (imm (lane_type ty) (u64_and 0x0f0f0f0f0f0f0f0f (ty_mask (lane_type ty)))))
1190
+ (count8_shr VReg (rv_vsrl_vi count4 four (unmasked) ty))
1191
+ (count8_add VReg (rv_vadd_vv count4 count8_shr (unmasked) ty))
1192
+ (count8 VReg (rv_vand_vx count8_add mask_0f (unmasked) ty))
1193
+
1194
+ ;; (x * 0x01010101) >> (<ty_width> - 8)
1195
+ (mask_01 XReg (imm (lane_type ty) (u64_and 0x0101010101010101 (ty_mask (lane_type ty)))))
1196
+ (mul VReg (rv_vmul_vx count8 mask_01 (unmasked) ty))
1197
+ (shift XReg (imm $I64 (u64_sub (ty_bits (lane_type ty)) 8)))
1198
+ (res VReg (rv_vsrl_vx mul shift (unmasked) ty)))
1199
+ res))
1200
+
1201
+ ;;;; Rules for `ishl` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1202
+
1203
+ ;; 8/16 bit types need a mask on the shift amount
1204
+ (rule 0 (lower (has_type (ty_int (ty_8_or_16 ty)) (ishl x y)))
1205
+ (if-let mask (u64_to_imm12 (ty_shift_mask ty)))
1206
+ (rv_sllw x (rv_andi (value_regs_get y 0) mask)))
1207
+
1208
+ ;; Using the 32bit version of `sll` automatically masks the shift amount.
1209
+ (rule 1 (lower (has_type $I32 (ishl x y)))
1210
+ (rv_sllw x (value_regs_get y 0)))
1211
+
1212
+ ;; Similarly, the 64bit version does the right thing.
1213
+ (rule 1 (lower (has_type $I64 (ishl x y)))
1214
+ (rv_sll x (value_regs_get y 0)))
1215
+
1216
+ ;; If the shift amount is known. We can mask it and encode it in the instruction.
1217
+ (rule 2 (lower (has_type (int_fits_in_32 ty) (ishl x (maybe_uextend (imm12_from_value y)))))
1218
+ (rv_slliw x (imm12_and y (ty_shift_mask ty))))
1219
+
1220
+ ;; We technically don't need to mask the shift amount here. The instruction
1221
+ ;; does the right thing. But it's neater when pretty printing it.
1222
+ (rule 3 (lower (has_type ty @ $I64 (ishl x (maybe_uextend (imm12_from_value y)))))
1223
+ (rv_slli x (imm12_and y (ty_shift_mask ty))))
1224
+
1225
+ ;; With `Zba` we have a shift that zero extends the LHS argument.
1226
+ (rule 4 (lower (has_type $I64 (ishl (uextend x @ (value_type $I32)) (maybe_uextend (imm12_from_value y)))))
1227
+ (if-let $true (has_zba))
1228
+ (rv_slliuw x y))
1229
+
1230
+ ;; I128 cases
1231
+ (rule 4 (lower (has_type $I128 (ishl x y)))
1232
+ (let ((tmp ValueRegs (gen_shamt $I128 (value_regs_get y 0)))
1233
+ (shamt XReg (value_regs_get tmp 0))
1234
+ (len_sub_shamt XReg (value_regs_get tmp 1))
1235
+ ;;
1236
+ (low XReg (rv_sll (value_regs_get x 0) shamt))
1237
+ ;; high part.
1238
+ (high_part1 XReg (rv_srl (value_regs_get x 0) len_sub_shamt))
1239
+ (high_part2 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) high_part1))
1240
+ ;;
1241
+ (high_part3 XReg (rv_sll (value_regs_get x 1) shamt))
1242
+ (high XReg (rv_or high_part2 high_part3))
1243
+ ;;
1244
+ (const64 XReg (imm $I64 64))
1245
+ (shamt_128 XReg (rv_andi (value_regs_get y 0) (imm12_const 127))))
1246
+ (gen_select_regs
1247
+ (cmp_geu shamt_128 const64)
1248
+ (value_regs (zero_reg) low)
1249
+ (value_regs low high))))
1250
+
1251
+ ;; SIMD Cases
1252
+ ;; We don't need to mask anything since it is done by the instruction according to SEW.
1253
+
1254
+ (rule 5 (lower (has_type (ty_vec_fits_in_register ty) (ishl x y)))
1255
+ (rv_vsll_vx x (value_regs_get y 0) (unmasked) ty))
1256
+
1257
+ (rule 6 (lower (has_type (ty_vec_fits_in_register ty) (ishl x (maybe_uextend (uimm5_from_value y)))))
1258
+ (rv_vsll_vi x y (unmasked) ty))
1259
+
1260
+ ;;;; Rules for `ushr` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1261
+
1262
+ ;; 8/16 bit types need a mask on the shift amount, and the LHS needs to be
1263
+ ;; zero extended.
1264
+ (rule 0 (lower (has_type (ty_int (fits_in_16 ty)) (ushr x y)))
1265
+ (if-let mask (u64_to_imm12 (ty_shift_mask ty)))
1266
+ (rv_srlw (zext x) (rv_andi (value_regs_get y 0) mask)))
1267
+
1268
+ ;; Using the 32bit version of `srl` automatically masks the shift amount.
1269
+ (rule 1 (lower (has_type $I32 (ushr x y)))
1270
+ (rv_srlw x (value_regs_get y 0)))
1271
+
1272
+ ;; Similarly, the 64bit version does the right thing.
1273
+ (rule 1 (lower (has_type $I64 (ushr x y)))
1274
+ (rv_srl x (value_regs_get y 0)))
1275
+
1276
+ ;; When the RHS is known we can just encode it in the instruction.
1277
+ (rule 2 (lower (has_type (ty_int (fits_in_16 ty)) (ushr x (maybe_uextend (imm12_from_value y)))))
1278
+ (rv_srliw (zext x) (imm12_and y (ty_shift_mask ty))))
1279
+
1280
+ (rule 3 (lower (has_type $I32 (ushr x (maybe_uextend (imm12_from_value y)))))
1281
+ (rv_srliw x y))
1282
+
1283
+ (rule 3 (lower (has_type $I64 (ushr x (maybe_uextend (imm12_from_value y)))))
1284
+ (rv_srli x y))
1285
+
1286
+ (rule 3 (lower (has_type $I128 (ushr x y)))
1287
+ (let ((tmp ValueRegs (gen_shamt $I128 (value_regs_get y 0)))
1288
+ (shamt XReg (value_regs_get tmp 0))
1289
+ (len_sub_shamt XReg (value_regs_get tmp 1))
1290
+ ;; low part.
1291
+ (low_part1 XReg (rv_sll (value_regs_get x 1) len_sub_shamt))
1292
+ (low_part2 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) low_part1))
1293
+ ;;
1294
+ (low_part3 XReg (rv_srl (value_regs_get x 0) shamt))
1295
+ (low XReg (rv_or low_part2 low_part3))
1296
+ ;;
1297
+ (const64 XReg (imm $I64 64))
1298
+ ;;
1299
+ (high XReg (rv_srl (value_regs_get x 1) shamt))
1300
+ (shamt_128 XReg (rv_andi (value_regs_get y 0) (imm12_const 127))))
1301
+ (gen_select_regs
1302
+ (cmp_geu shamt_128 const64)
1303
+ (value_regs high (zero_reg))
1304
+ (value_regs low high))))
1305
+
1306
+ ;; SIMD Cases
1307
+ ;; We don't need to mask or extend anything since it is done by the instruction according to SEW.
1308
+
1309
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (ushr x y)))
1310
+ (rv_vsrl_vx x (value_regs_get y 0) (unmasked) ty))
1311
+
1312
+ (rule 5 (lower (has_type (ty_vec_fits_in_register ty) (ushr x (maybe_uextend (uimm5_from_value y)))))
1313
+ (rv_vsrl_vi x y (unmasked) ty))
1314
+
1315
+ ;;;; Rules for `sshr` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1316
+
1317
+ ;; 8/16 bit types need a mask on the shift amount, and the LHS needs to be
1318
+ ;; zero extended.
1319
+ (rule 0 (lower (has_type (ty_int (fits_in_16 ty)) (sshr x y)))
1320
+ (if-let mask (u64_to_imm12 (ty_shift_mask ty)))
1321
+ (rv_sraw (sext x) (rv_andi (value_regs_get y 0) mask)))
1322
+
1323
+ ;; Using the 32bit version of `sra` automatically masks the shift amount.
1324
+ (rule 1 (lower (has_type $I32 (sshr x y)))
1325
+ (rv_sraw x (value_regs_get y 0)))
1326
+
1327
+ ;; Similarly, the 64bit version does the right thing.
1328
+ (rule 1 (lower (has_type $I64 (sshr x y)))
1329
+ (rv_sra x (value_regs_get y 0)))
1330
+
1331
+ ;; When the RHS is known we can just encode it in the instruction.
1332
+ (rule 2 (lower (has_type (ty_int (fits_in_16 ty)) (sshr x (maybe_uextend (imm12_from_value y)))))
1333
+ (rv_sraiw (sext x) (imm12_and y (ty_shift_mask ty))))
1334
+
1335
+ (rule 3 (lower (has_type $I32 (sshr x (maybe_uextend (imm12_from_value y)))))
1336
+ (rv_sraiw x y))
1337
+
1338
+ (rule 3 (lower (has_type $I64 (sshr x (maybe_uextend (imm12_from_value y)))))
1339
+ (rv_srai x y))
1340
+
1341
+ (rule 3 (lower (has_type $I128 (sshr x y)))
1342
+ (let ((tmp ValueRegs (gen_shamt $I128 (value_regs_get y 0)))
1343
+ (shamt XReg (value_regs_get tmp 0))
1344
+ (len_sub_shamt XReg (value_regs_get tmp 1))
1345
+ ;; low part.
1346
+ (low_part1 XReg (rv_sll (value_regs_get x 1) len_sub_shamt))
1347
+ (low_part2 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) low_part1))
1348
+ ;;
1349
+ (low_part3 XReg (rv_srl (value_regs_get x 0) shamt))
1350
+ (low XReg (rv_or low_part2 low_part3))
1351
+ ;;
1352
+ (const64 XReg (imm $I64 64))
1353
+ ;;
1354
+ (high XReg (rv_sra (value_regs_get x 1) shamt))
1355
+ ;;
1356
+ (const_neg_1 XReg (imm $I64 (i64_as_u64 -1)))
1357
+ ;;
1358
+ (high_replacement XReg (gen_select_xreg (cmp_ltz (value_regs_get x 1)) const_neg_1 (zero_reg)))
1359
+ (const64 XReg (imm $I64 64))
1360
+ (shamt_128 XReg (rv_andi (value_regs_get y 0) (imm12_const 127))))
1361
+ (gen_select_regs
1362
+ (cmp_geu shamt_128 const64)
1363
+ (value_regs high high_replacement)
1364
+ (value_regs low high))))
1365
+
1366
+ ;; SIMD Cases
1367
+ ;; We don't need to mask or extend anything since it is done by the instruction according to SEW.
1368
+
1369
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (sshr x y)))
1370
+ (rv_vsra_vx x (value_regs_get y 0) (unmasked) ty))
1371
+
1372
+ (rule 5 (lower (has_type (ty_vec_fits_in_register ty) (sshr x (maybe_uextend (uimm5_from_value y)))))
1373
+ (rv_vsra_vi x y (unmasked) ty))
1374
+
1375
+
1376
+ ;;;; Rules for `rotl` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1377
+
1378
+ (rule 0 (lower (has_type (fits_in_64 ty) (rotl rs amount)))
1379
+ (let
1380
+ ((rs XReg (zext rs))
1381
+ (amount XReg (value_regs_get amount 0))
1382
+ (x ValueRegs (gen_shamt ty amount))
1383
+ (shamt XReg (value_regs_get x 0))
1384
+ (len_sub_shamt Reg (value_regs_get x 1))
1385
+ (part1 Reg (rv_sll rs shamt))
1386
+ (part2 Reg (rv_srl rs len_sub_shamt))
1387
+ (part3 Reg (gen_select_xreg (cmp_eqz shamt) (zero_reg) part2)))
1388
+ (rv_or part1 part3)))
1389
+
1390
+ (rule 1 (lower (has_type $I32 (rotl rs amount)))
1391
+ (if-let $true (has_zbb))
1392
+ (rv_rolw rs (value_regs_get amount 0)))
1393
+
1394
+ (rule 2 (lower (has_type $I32 (rotl rs (u64_from_iconst n))))
1395
+ (if-let $true (has_zbb))
1396
+ (if-let (imm12_from_u64 imm) (u64_sub 32 (u64_and n 31)))
1397
+ (rv_roriw rs imm))
1398
+
1399
+ (rule 1 (lower (has_type $I64 (rotl rs amount)))
1400
+ (if-let $true (has_zbb))
1401
+ (rv_rol rs (value_regs_get amount 0)))
1402
+
1403
+ (rule 2 (lower (has_type $I64 (rotl rs (u64_from_iconst n))))
1404
+ (if-let $true (has_zbb))
1405
+ (if-let (imm12_from_u64 imm) (u64_sub 64 (u64_and n 63)))
1406
+ (rv_rori rs imm))
1407
+
1408
+ (rule 1 (lower (has_type $I128 (rotl x y)))
1409
+ (let
1410
+ ((tmp ValueRegs (gen_shamt $I128 (value_regs_get y 0)))
1411
+ (shamt XReg (value_regs_get tmp 0))
1412
+ (len_sub_shamt XReg (value_regs_get tmp 1))
1413
+ (low_part1 XReg (rv_sll (value_regs_get x 0) shamt))
1414
+ (low_part2 XReg (rv_srl (value_regs_get x 1) len_sub_shamt))
1415
+ ;;; if shamt == 0 low_part2 will overflow we should zero instead.
1416
+ (low_part3 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) low_part2))
1417
+ (low XReg (rv_or low_part1 low_part3))
1418
+ (high_part1 XReg (rv_sll (value_regs_get x 1) shamt))
1419
+ (high_part2 XReg (rv_srl (value_regs_get x 0) len_sub_shamt))
1420
+ (high_part3 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) high_part2))
1421
+ (high XReg (rv_or high_part1 high_part3))
1422
+ (const64 XReg (imm $I64 64))
1423
+ (shamt_128 XReg (rv_andi (value_regs_get y 0) (imm12_const 127))))
1424
+ ;; right now we only rotate less than 64 bits.
1425
+ ;; if shamt is greater than or equal 64 , we should switch low and high.
1426
+ (gen_select_regs
1427
+ (cmp_geu shamt_128 const64)
1428
+ (value_regs high low)
1429
+ (value_regs low high)
1430
+ )))
1431
+
1432
+ ;;;; Rules for `rotr` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1433
+
1434
+ (rule (lower (has_type (fits_in_64 ty) (rotr rs amount)))
1435
+ (let
1436
+ ((rs XReg (zext rs))
1437
+ (amount XReg (value_regs_get amount 0))
1438
+ (x ValueRegs (gen_shamt ty amount))
1439
+ (shamt XReg (value_regs_get x 0))
1440
+ (len_sub_shamt XReg (value_regs_get x 1))
1441
+ (part1 XReg (rv_srl rs shamt))
1442
+ (part2 XReg (rv_sll rs len_sub_shamt))
1443
+ (part3 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) part2)))
1444
+ (rv_or part1 part3)))
1445
+
1446
+ (rule 1 (lower (has_type $I32 (rotr rs amount)))
1447
+ (if-let $true (has_zbb))
1448
+ (rv_rorw rs (value_regs_get amount 0)))
1449
+
1450
+ (rule 2 (lower (has_type $I32 (rotr rs (imm12_from_value n))))
1451
+ (if-let $true (has_zbb))
1452
+ (rv_roriw rs n))
1453
+
1454
+ (rule 1 (lower (has_type $I64 (rotr rs amount)))
1455
+ (if-let $true (has_zbb))
1456
+ (rv_ror rs (value_regs_get amount 0)))
1457
+
1458
+ (rule 2 (lower (has_type $I64 (rotr rs (imm12_from_value n))))
1459
+ (if-let $true (has_zbb))
1460
+ (rv_rori rs n))
1461
+
1462
+ (rule 1 (lower (has_type $I128 (rotr x y)))
1463
+ (let
1464
+ ((tmp ValueRegs (gen_shamt $I128 (value_regs_get y 0)))
1465
+ (shamt XReg (value_regs_get tmp 0))
1466
+ (len_sub_shamt XReg (value_regs_get tmp 1))
1467
+ (low_part1 XReg (rv_srl (value_regs_get x 0) shamt))
1468
+ (low_part2 XReg (rv_sll (value_regs_get x 1) len_sub_shamt))
1469
+ ;;; if shamt == 0 low_part2 will overflow we should zero instead.
1470
+ (low_part3 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) low_part2))
1471
+ (low XReg (rv_or low_part1 low_part3))
1472
+ (high_part1 XReg (rv_srl (value_regs_get x 1) shamt))
1473
+ (high_part2 XReg (rv_sll (value_regs_get x 0) len_sub_shamt))
1474
+ (high_part3 XReg (gen_select_xreg (cmp_eqz shamt) (zero_reg) high_part2))
1475
+ (high XReg (rv_or high_part1 high_part3))
1476
+ (const64 XReg (imm $I64 64))
1477
+ (shamt_128 XReg (rv_andi (value_regs_get y 0) (imm12_const 127))))
1478
+ ;; right now we only rotate less than 64 bits.
1479
+ ;; if shamt is greater than or equal 64 , we should switch low and high.
1480
+ (gen_select_regs
1481
+ (cmp_geu shamt_128 const64)
1482
+ (value_regs high low)
1483
+ (value_regs low high)
1484
+ )))
1485
+
1486
+ ;;;; Rules for `fabs` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1487
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fabs x)))
1488
+ (rv_fabs ty x))
1489
+
1490
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fabs x)))
1491
+ (rv_vfabs_v x (unmasked) ty))
1492
+
1493
+ ;;;; Rules for `fneg` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1494
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fneg x)))
1495
+ (rv_fneg ty x))
1496
+
1497
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fneg x)))
1498
+ (rv_vfneg_v x (unmasked) ty))
1499
+
1500
+ ;;;; Rules for `fcopysign` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1501
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fcopysign x y)))
1502
+ (rv_fsgnj ty x y))
1503
+
1504
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fcopysign x y)))
1505
+ (rv_vfsgnj_vv x y (unmasked) ty))
1506
+
1507
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fcopysign x (splat y))))
1508
+ (rv_vfsgnj_vf x y (unmasked) ty))
1509
+
1510
+ ;;;; Rules for `fma` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1511
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fma x y z)))
1512
+ (rv_fmadd ty (FRM.RNE) x y z))
1513
+
1514
+ ;; (fma x y z) computes x * y + z
1515
+ ;; vfmacc computes vd[i] = +(vs1[i] * vs2[i]) + vd[i]
1516
+ ;; We need to reverse the order of the arguments
1517
+
1518
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fma x y z)))
1519
+ (rv_vfmacc_vv z y x (unmasked) ty))
1520
+
1521
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fma (splat x) y z)))
1522
+ (rv_vfmacc_vf z y x (unmasked) ty))
1523
+
1524
+ ;; vfmsac computes vd[i] = +(vs1[i] * vs2[i]) - vd[i]
1525
+
1526
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (fma x y (fneg z))))
1527
+ (rv_vfmsac_vv z y x (unmasked) ty))
1528
+
1529
+ (rule 6 (lower (has_type (ty_vec_fits_in_register ty) (fma (splat x) y (fneg z))))
1530
+ (rv_vfmsac_vf z y x (unmasked) ty))
1531
+
1532
+ ;; vfnmacc computes vd[i] = -(vs1[i] * vs2[i]) - vd[i]
1533
+
1534
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (fma (fneg x) y (fneg z))))
1535
+ (rv_vfnmacc_vv z y x (unmasked) ty))
1536
+
1537
+ (rule 6 (lower (has_type (ty_vec_fits_in_register ty) (fma (fneg (splat x)) y (fneg z))))
1538
+ (rv_vfnmacc_vf z y x (unmasked) ty))
1539
+
1540
+ ;; vfnmsac computes vd[i] = -(vs1[i] * vs2[i]) + vd[i]
1541
+
1542
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fma (fneg x) y z)))
1543
+ (rv_vfnmsac_vv z y x (unmasked) ty))
1544
+
1545
+ (rule 5 (lower (has_type (ty_vec_fits_in_register ty) (fma (fneg (splat x)) y z)))
1546
+ (rv_vfnmsac_vf z y x (unmasked) ty))
1547
+
1548
+
1549
+ ;;;; Rules for `sqrt` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1550
+ (rule 0 (lower (has_type (ty_scalar_float ty) (sqrt x)))
1551
+ (rv_fsqrt ty (FRM.RNE) x))
1552
+
1553
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (sqrt x)))
1554
+ (rv_vfsqrt_v x (unmasked) ty))
1555
+
1556
+ ;;;; Rules for `AtomicRMW` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1557
+ (rule -1
1558
+ ;;
1559
+ (lower
1560
+ (has_type (valid_atomic_transaction ty) (atomic_rmw flags op addr x)))
1561
+ (gen_atomic (get_atomic_rmw_op ty op) addr x (atomic_amo)))
1562
+
1563
+ ;;; for I8 and I16
1564
+ (rule 1
1565
+ (lower
1566
+ (has_type (valid_atomic_transaction (fits_in_16 ty)) (atomic_rmw flags op addr x)))
1567
+ (gen_atomic_rmw_loop op ty addr x))
1568
+
1569
+ ;;;special for I8 and I16 max min etc.
1570
+ ;;;because I need uextend or sextend the value.
1571
+ (rule 2
1572
+ (lower
1573
+ (has_type (valid_atomic_transaction (fits_in_16 ty)) (atomic_rmw flags (is_atomic_rmw_max_etc op $true) addr x)))
1574
+ (gen_atomic_rmw_loop op ty addr (sext x)))
1575
+
1576
+
1577
+ (rule 2
1578
+ ;;
1579
+ (lower
1580
+ (has_type (valid_atomic_transaction (fits_in_16 ty)) (atomic_rmw flags (is_atomic_rmw_max_etc op $false) addr x)))
1581
+ ;;
1582
+ (gen_atomic_rmw_loop op ty addr (zext x)))
1583
+
1584
+ ;;;;; Rules for `AtomicRmwOp.Sub`
1585
+ (rule
1586
+ (lower
1587
+ (has_type (valid_atomic_transaction ty) (atomic_rmw flags (AtomicRmwOp.Sub) addr x)))
1588
+ (let
1589
+ ((tmp WritableReg (temp_writable_reg ty))
1590
+ (x2 Reg (rv_neg x)))
1591
+ (gen_atomic (get_atomic_rmw_op ty (AtomicRmwOp.Add)) addr x2 (atomic_amo))))
1592
+
1593
+ (decl gen_atomic_rmw_loop (AtomicRmwOp Type XReg XReg) XReg)
1594
+ (rule
1595
+ (gen_atomic_rmw_loop op ty addr x)
1596
+ (let
1597
+ ((dst WritableXReg (temp_writable_xreg))
1598
+ (t0 WritableXReg (temp_writable_xreg))
1599
+ (_ Unit (emit (MInst.AtomicRmwLoop (gen_atomic_offset addr ty) op dst ty (gen_atomic_p addr ty) x t0))))
1600
+ (writable_reg_to_reg dst)))
1601
+
1602
+ ;;;;; Rules for `AtomicRmwOp.Nand`
1603
+ (rule
1604
+ (lower
1605
+ (has_type (valid_atomic_transaction ty) (atomic_rmw flags (AtomicRmwOp.Nand) addr x)))
1606
+ (gen_atomic_rmw_loop (AtomicRmwOp.Nand) ty addr x))
1607
+
1608
+ (decl is_atomic_rmw_max_etc (AtomicRmwOp bool) AtomicRmwOp)
1609
+ (extern extractor is_atomic_rmw_max_etc is_atomic_rmw_max_etc)
1610
+
1611
+ ;;;;; Rules for `atomic load`;;;;;;;;;;;;;;;;;
1612
+ (rule
1613
+ (lower (has_type (valid_atomic_transaction ty) (atomic_load flags p)))
1614
+ (gen_atomic_load p ty))
1615
+
1616
+
1617
+ ;;;;; Rules for `atomic store`;;;;;;;;;;;;;;;;;
1618
+ (rule
1619
+ (lower (atomic_store flags src @ (value_type (valid_atomic_transaction ty)) p))
1620
+ (gen_atomic_store p ty src))
1621
+
1622
+ (decl gen_atomic_offset (XReg Type) XReg)
1623
+ (rule 1 (gen_atomic_offset p (fits_in_16 ty))
1624
+ (rv_slli (rv_andi p (imm12_const 3)) (imm12_const 3)))
1625
+
1626
+ (rule (gen_atomic_offset p _)
1627
+ (zero_reg))
1628
+
1629
+ (decl gen_atomic_p (XReg Type) XReg)
1630
+ (rule 1 (gen_atomic_p p (fits_in_16 ty))
1631
+ (rv_andi p (imm12_const -4)))
1632
+
1633
+ (rule (gen_atomic_p p _)
1634
+ p)
1635
+
1636
+
1637
+ ;;;;; Rules for `atomic cas`;;;;;;;;;;;;;;;;;
1638
+ (rule
1639
+ (lower (has_type (valid_atomic_transaction ty) (atomic_cas flags p e x)))
1640
+ (let
1641
+ ((t0 WritableReg (temp_writable_reg ty))
1642
+ (dst WritableReg (temp_writable_reg ty))
1643
+ (_ Unit (emit (MInst.AtomicCas (gen_atomic_offset p ty) t0 dst (zext e) (gen_atomic_p p ty) x ty))))
1644
+ (writable_reg_to_reg dst)))
1645
+
1646
+ ;;;;; Rules for `ireduce`;;;;;;;;;;;;;;;;;
1647
+ (rule
1648
+ (lower (has_type ty (ireduce x)))
1649
+ (value_regs_get x 0))
1650
+
1651
+ ;;;;; Rules for `fpromote`;;;;;;;;;;;;;;;;;
1652
+ (rule (lower (fpromote x))
1653
+ (rv_fcvtds x))
1654
+
1655
+ ;;;;; Rules for `fvpromote_low`;;;;;;;;;;;;
1656
+
1657
+ (rule (lower (has_type (ty_vec_fits_in_register ty) (fvpromote_low x)))
1658
+ (if-let half_ty (ty_half_width ty))
1659
+ (rv_vfwcvt_f_f_v x (unmasked) (vstate_mf2 half_ty)))
1660
+
1661
+ ;;;;; Rules for `fdemote`;;;;;;;;;;;;;;;;;;
1662
+ (rule (lower (fdemote x))
1663
+ (rv_fcvtsd (FRM.RNE) x))
1664
+
1665
+ ;;;;; Rules for `fvdemote`;;;;;;;;;;;;;;;;;
1666
+
1667
+ ;; `vfncvt...` leaves the upper bits of the register undefined so
1668
+ ;; we need to zero them out.
1669
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $F32X4) (fvdemote x)))
1670
+ (if-let zero (i8_to_imm5 0))
1671
+ (let ((narrow VReg (rv_vfncvt_f_f_w x (unmasked) (vstate_mf2 ty)))
1672
+ (mask VReg (gen_vec_mask 0xC)))
1673
+ (rv_vmerge_vim narrow zero mask ty)))
1674
+
1675
+
1676
+ ;;;;; Rules for for float arithmetic
1677
+
1678
+
1679
+ ;;;; Rules for `fadd` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1680
+
1681
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fadd x y)))
1682
+ (rv_fadd ty (FRM.RNE) x y))
1683
+
1684
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fadd x y)))
1685
+ (rv_vfadd_vv x y (unmasked) ty))
1686
+
1687
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fadd x (splat y))))
1688
+ (rv_vfadd_vf x y (unmasked) ty))
1689
+
1690
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (fadd (splat x) y)))
1691
+ (rv_vfadd_vf y x (unmasked) ty))
1692
+
1693
+
1694
+ ;;;; Rules for `fsub` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1695
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fsub x y)))
1696
+ (rv_fsub ty (FRM.RNE) x y))
1697
+
1698
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fsub x y)))
1699
+ (rv_vfsub_vv x y (unmasked) ty))
1700
+
1701
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fsub x (splat y))))
1702
+ (rv_vfsub_vf x y (unmasked) ty))
1703
+
1704
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (fsub (splat x) y)))
1705
+ (rv_vfrsub_vf y x (unmasked) ty))
1706
+
1707
+ ;;;; Rules for `fmul` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1708
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fmul x y)))
1709
+ (rv_fmul ty (FRM.RNE) x y))
1710
+
1711
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fmul x y)))
1712
+ (rv_vfmul_vv x y (unmasked) ty))
1713
+
1714
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fmul x (splat y))))
1715
+ (rv_vfmul_vf x y (unmasked) ty))
1716
+
1717
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (fmul (splat x) y)))
1718
+ (rv_vfmul_vf y x (unmasked) ty))
1719
+
1720
+
1721
+ ;;;; Rules for `fdiv` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1722
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fdiv x y)))
1723
+ (rv_fdiv ty (FRM.RNE) x y))
1724
+
1725
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (fdiv x y)))
1726
+ (rv_vfdiv_vv x y (unmasked) ty))
1727
+
1728
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fdiv x (splat y))))
1729
+ (rv_vfdiv_vf x y (unmasked) ty))
1730
+
1731
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (fdiv (splat x) y)))
1732
+ (rv_vfrdiv_vf y x (unmasked) ty))
1733
+
1734
+ ;;;; Rules for `fmin` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1735
+
1736
+ ;; RISC-V's `fmin` instruction returns the number input if one of inputs is a
1737
+ ;; NaN. We handle this by manually checking if one of the inputs is a NaN
1738
+ ;; and selecting based on that result.
1739
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fmin x y)))
1740
+ (let (;; Check if both inputs are not nan.
1741
+ (is_ordered FloatCompare (fcmp_to_float_compare (FloatCC.Ordered) ty x y))
1742
+ ;; `fadd` returns a nan if any of the inputs is a NaN.
1743
+ (nan FReg (rv_fadd ty (FRM.RNE) x y))
1744
+ (min FReg (rv_fmin ty x y)))
1745
+ (gen_select_freg is_ordered min nan)))
1746
+
1747
+ ;; With Zfa we can use the special `fminm` that precisely matches the expected
1748
+ ;; NaN behavior.
1749
+ (rule 1 (lower (has_type (ty_scalar_float ty) (fmin x y)))
1750
+ (if-let $true (has_zfa))
1751
+ (rv_fminm ty x y))
1752
+
1753
+ ;; vfmin does almost the right thing, but it does not handle NaN's correctly.
1754
+ ;; We should return a NaN if any of the inputs is a NaN, but vfmin returns the
1755
+ ;; number input instead.
1756
+ ;;
1757
+ ;; TODO: We can improve this by using a masked `fmin` instruction that modifies
1758
+ ;; the canonical nan register. That way we could avoid the `vmerge.vv` instruction.
1759
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fmin x y)))
1760
+ (let ((is_not_nan VReg (gen_fcmp_mask ty (FloatCC.Ordered) x y))
1761
+ (nan XReg (imm $I64 (canonical_nan_u64 (lane_type ty))))
1762
+ (vec_nan VReg (rv_vmv_vx nan ty))
1763
+ (min VReg (rv_vfmin_vv x y (unmasked) ty)))
1764
+ (rv_vmerge_vvm vec_nan min is_not_nan ty)))
1765
+
1766
+ ;;;; Rules for `fmax` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1767
+
1768
+ ;; RISC-V's `fmax` instruction returns the number input if one of inputs is a
1769
+ ;; NaN. We handle this by manually checking if one of the inputs is a NaN
1770
+ ;; and selecting based on that result.
1771
+ (rule 0 (lower (has_type (ty_scalar_float ty) (fmax x y)))
1772
+ (let (;; Check if both inputs are not nan.
1773
+ (is_ordered FloatCompare (fcmp_to_float_compare (FloatCC.Ordered) ty x y))
1774
+ ;; `fadd` returns a NaN if any of the inputs is a NaN.
1775
+ (nan FReg (rv_fadd ty (FRM.RNE) x y))
1776
+ (max FReg (rv_fmax ty x y)))
1777
+ (gen_select_freg is_ordered max nan)))
1778
+
1779
+ ;; With Zfa we can use the special `fmaxm` that precisely matches the expected
1780
+ ;; NaN behavior.
1781
+ (rule 1 (lower (has_type (ty_scalar_float ty) (fmax x y)))
1782
+ (if-let $true (has_zfa))
1783
+ (rv_fmaxm ty x y))
1784
+
1785
+ ;; vfmax does almost the right thing, but it does not handle NaN's correctly.
1786
+ ;; We should return a NaN if any of the inputs is a NaN, but vfmax returns the
1787
+ ;; number input instead.
1788
+ ;;
1789
+ ;; TODO: We can improve this by using a masked `fmax` instruction that modifies
1790
+ ;; the canonical nan register. That way we could avoid the `vmerge.vv` instruction.
1791
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (fmax x y)))
1792
+ (let ((is_not_nan VReg (gen_fcmp_mask ty (FloatCC.Ordered) x y))
1793
+ (nan XReg (imm $I64 (canonical_nan_u64 (lane_type ty))))
1794
+ (vec_nan VReg (rv_vmv_vx nan ty))
1795
+ (max VReg (rv_vfmax_vv x y (unmasked) ty)))
1796
+ (rv_vmerge_vvm vec_nan max is_not_nan ty)))
1797
+
1798
+ ;;;;; Rules for `stack_addr`;;;;;;;;;
1799
+ (rule
1800
+ (lower (stack_addr ss offset))
1801
+ (gen_stack_addr ss offset))
1802
+
1803
+ ;;;;; Rules for `is_null`;;;;;;;;;
1804
+
1805
+ ;; Null references are represented by the constant value `0`.
1806
+ (rule (lower (is_null v))
1807
+ (rv_seqz v))
1808
+
1809
+ ;;;;; Rules for `is_invalid`;;;;;;;;;
1810
+
1811
+ ;; Invalid references are represented by the constant value `-1`.
1812
+ (rule (lower (is_invalid v))
1813
+ (rv_seqz (rv_addi v (imm12_const 1))))
1814
+
1815
+ ;;;;; Rules for `select`;;;;;;;;;
1816
+ (rule 0 (lower (has_type (ty_int_ref_scalar_64 _) (select c x y)))
1817
+ (gen_select_xreg (is_nonzero_cmp c) x y))
1818
+
1819
+ (rule 1 (lower (has_type $I128 (select c x y)))
1820
+ (gen_select_regs (is_nonzero_cmp c) x y))
1821
+
1822
+ (rule 2 (lower (has_type (ty_vec_fits_in_register _) (select c x y)))
1823
+ (gen_select_vreg (is_nonzero_cmp c) x y))
1824
+
1825
+ (rule 3 (lower (has_type (ty_scalar_float _) (select c x y)))
1826
+ (gen_select_freg (is_nonzero_cmp c) x y))
1827
+
1828
+ ;;;;; Rules for `bitselect`;;;;;;;;;
1829
+
1830
+ ;; Do a (c & x) | (~c & y) operation.
1831
+ (rule 0 (lower (has_type (ty_int_ref_scalar_64 ty) (bitselect c x y)))
1832
+ (let ((tmp_x XReg (rv_and c x))
1833
+ (c_inverse XReg (rv_not c))
1834
+ (tmp_y XReg (rv_and c_inverse y)))
1835
+ (rv_or tmp_x tmp_y)))
1836
+
1837
+ ;; For vectors, we also do the same operation.
1838
+ ;; We can technically use any type in the bitwise operations, but prefer
1839
+ ;; using the type of the inputs so that we avoid emitting unnecessary
1840
+ ;; `vsetvl` instructions. it's likeley that the vector unit is already
1841
+ ;; configured for that type.
1842
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (bitselect c x y)))
1843
+ (let ((tmp_x VReg (rv_vand_vv c x (unmasked) ty))
1844
+ (c_inverse VReg (rv_vnot_v c (unmasked) ty))
1845
+ (tmp_y VReg (rv_vand_vv c_inverse y (unmasked) ty)))
1846
+ (rv_vor_vv tmp_x tmp_y (unmasked) ty)))
1847
+
1848
+ ;; Special case for bitselects with cmp's as an input.
1849
+ ;;
1850
+ ;; This allows us to skip the mask expansion step and use the more efficient
1851
+ ;; vmerge.vvm instruction.
1852
+ ;;
1853
+ ;; We should be careful to ensure that the mask and the vmerge have the
1854
+ ;; same type. So that we don't generate a mask with length 16 (i.e. for i8x16), and then
1855
+ ;; only copy the first few lanes of the result to the destination register because
1856
+ ;; the bitselect has a different length (i.e. i64x2).
1857
+ ;;
1858
+ ;; See: https://github.com/bytecodealliance/wasmtime/issues/8131
1859
+
1860
+ (rule 2 (lower (has_type (ty_vec_fits_in_register _ty) (bitselect (icmp cc a @ (value_type (ty_vec_fits_in_register cmp_ty)) b) x y)))
1861
+ (let ((mask VReg (gen_icmp_mask cmp_ty cc a b)))
1862
+ (rv_vmerge_vvm y x mask cmp_ty)))
1863
+
1864
+ (rule 2 (lower (has_type (ty_vec_fits_in_register _ty) (bitselect (fcmp cc a @ (value_type (ty_vec_fits_in_register cmp_ty)) b) x y)))
1865
+ (let ((mask VReg (gen_fcmp_mask cmp_ty cc a b)))
1866
+ (rv_vmerge_vvm y x mask cmp_ty)))
1867
+
1868
+ (rule 2 (lower (has_type (ty_vec_fits_in_register _ty) (bitselect (bitcast _ (fcmp cc a @ (value_type (ty_vec_fits_in_register cmp_ty)) b)) x y)))
1869
+ (let ((mask VReg (gen_fcmp_mask cmp_ty cc a b)))
1870
+ (rv_vmerge_vvm y x mask cmp_ty)))
1871
+
1872
+ (rule 2 (lower (has_type (ty_vec_fits_in_register _ty) (bitselect (bitcast _ (icmp cc a @ (value_type (ty_vec_fits_in_register cmp_ty)) b)) x y)))
1873
+ (let ((mask VReg (gen_icmp_mask cmp_ty cc a b)))
1874
+ (rv_vmerge_vvm y x mask cmp_ty)))
1875
+
1876
+
1877
+ ;;;;; Rules for `isplit`;;;;;;;;;
1878
+ (rule
1879
+ (lower (isplit x))
1880
+ (let
1881
+ ((t1 XReg (value_regs_get x 0))
1882
+ (t2 XReg (value_regs_get x 1)))
1883
+ (output_pair t1 t2)))
1884
+
1885
+ ;;;;; Rules for `iconcat`;;;;;;;;;
1886
+ (rule
1887
+ (lower (has_type $I128 (iconcat x y)))
1888
+ (let
1889
+ ((t1 XReg x)
1890
+ (t2 XReg y))
1891
+ (value_regs t1 t2)))
1892
+
1893
+
1894
+ ;;;;; Rules for `smax`;;;;;;;;;
1895
+
1896
+ (rule 0 (lower (has_type (fits_in_64 ty) (smax x y)))
1897
+ (let ((x XReg (sext x))
1898
+ (y XReg (sext y)))
1899
+ (gen_select_xreg (cmp_gt x y) x y)))
1900
+
1901
+ (rule 1 (lower (has_type $I128 (smax x y)))
1902
+ (gen_select_regs (icmp_to_int_compare (IntCC.SignedGreaterThan) x y) x y))
1903
+
1904
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (smax x y)))
1905
+ (rv_vmax_vv x y (unmasked) ty))
1906
+
1907
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (smax x (splat y))))
1908
+ (rv_vmax_vx x y (unmasked) ty))
1909
+
1910
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (smax (splat x) y)))
1911
+ (rv_vmax_vx y x (unmasked) ty))
1912
+
1913
+ ;;;;; Rules for `smin`;;;;;;;;;
1914
+
1915
+ (rule 0 (lower (has_type (fits_in_64 ty) (smin x y)))
1916
+ (let ((x XReg (sext x))
1917
+ (y XReg (sext y)))
1918
+ (gen_select_xreg (cmp_lt x y) x y)))
1919
+
1920
+ (rule 1 (lower (has_type $I128 (smin x y)))
1921
+ (gen_select_regs (icmp_to_int_compare (IntCC.SignedLessThan) x y) x y))
1922
+
1923
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (smin x y)))
1924
+ (rv_vmin_vv x y (unmasked) ty))
1925
+
1926
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (smin x (splat y))))
1927
+ (rv_vmin_vx x y (unmasked) ty))
1928
+
1929
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (smin (splat x) y)))
1930
+ (rv_vmin_vx y x (unmasked) ty))
1931
+
1932
+ ;;;;; Rules for `umax`;;;;;;;;;
1933
+
1934
+ (rule 0 (lower (has_type (fits_in_64 ty) (umax x y)))
1935
+ (let ((x XReg (zext x))
1936
+ (y XReg (zext y)))
1937
+ (gen_select_xreg (cmp_gtu x y) x y)))
1938
+
1939
+ (rule 1 (lower (has_type $I128 (umax x y)))
1940
+ (gen_select_regs (icmp_to_int_compare (IntCC.UnsignedGreaterThan) x y) x y))
1941
+
1942
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (umax x y)))
1943
+ (rv_vmaxu_vv x y (unmasked) ty))
1944
+
1945
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (umax x (splat y))))
1946
+ (rv_vmaxu_vx x y (unmasked) ty))
1947
+
1948
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (umax (splat x) y)))
1949
+ (rv_vmaxu_vx y x (unmasked) ty))
1950
+
1951
+ ;;;;; Rules for `umin`;;;;;;;;;
1952
+
1953
+ (rule 0 (lower (has_type (fits_in_64 ty) (umin x y)))
1954
+ (let ((x XReg (zext x))
1955
+ (y XReg (zext y)))
1956
+ (gen_select_xreg (cmp_ltu x y) x y)))
1957
+
1958
+ (rule 1 (lower (has_type $I128 (umin x y)))
1959
+ (gen_select_regs (icmp_to_int_compare (IntCC.UnsignedLessThan) x y) x y))
1960
+
1961
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (umin x y)))
1962
+ (rv_vminu_vv x y (unmasked) ty))
1963
+
1964
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (umin x (splat y))))
1965
+ (rv_vminu_vx x y (unmasked) ty))
1966
+
1967
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (umin (splat x) y)))
1968
+ (rv_vminu_vx y x (unmasked) ty))
1969
+
1970
+
1971
+ ;;;;; Rules for `debugtrap`;;;;;;;;;
1972
+ (rule
1973
+ (lower (debugtrap))
1974
+ (side_effect (SideEffectNoResult.Inst (MInst.EBreak))))
1975
+
1976
+ ;;;;; Rules for `fence`;;;;;;;;;
1977
+ (rule
1978
+ (lower (fence))
1979
+ (side_effect (SideEffectNoResult.Inst (MInst.Fence 15 15))))
1980
+
1981
+ ;;;;; Rules for `trap`;;;;;;;;;
1982
+ (rule
1983
+ (lower (trap code))
1984
+ (udf code))
1985
+
1986
+ ;;;;; Rules for `resumable_trap`;;;;;;;;;
1987
+ (rule
1988
+ (lower (resumable_trap code))
1989
+ (udf code))
1990
+
1991
+ ;;;;; Rules for `uload8`;;;;;;;;;
1992
+ (rule (lower (uload8 flags addr offset))
1993
+ (gen_load (amode addr offset) (LoadOP.Lbu) flags))
1994
+
1995
+ ;;;;; Rules for `sload8`;;;;;;;;;
1996
+ (rule (lower (sload8 flags addr offset))
1997
+ (gen_load (amode addr offset) (LoadOP.Lb) flags))
1998
+
1999
+ ;;;;; Rules for `uload16`;;;;;;;;;
2000
+ (rule (lower (uload16 flags addr offset))
2001
+ (gen_load (amode addr offset) (LoadOP.Lhu) flags))
2002
+
2003
+ ;;;;; Rules for `iload16`;;;;;;;;;
2004
+ (rule (lower (sload16 flags addr offset))
2005
+ (gen_load (amode addr offset) (LoadOP.Lh) flags))
2006
+
2007
+ ;;;;; Rules for `uload32`;;;;;;;;;
2008
+ (rule (lower (uload32 flags addr offset))
2009
+ (gen_load (amode addr offset) (LoadOP.Lwu) flags))
2010
+
2011
+ ;;;;; Rules for `sload32`;;;;;;;;;
2012
+ (rule (lower (sload32 flags addr offset))
2013
+ (gen_load (amode addr offset) (LoadOP.Lw) flags))
2014
+
2015
+ ;;;;; Rules for `load`;;;;;;;;;
2016
+ (rule (lower (has_type ty (load flags addr offset)))
2017
+ (gen_load (amode addr offset) (load_op ty) flags))
2018
+
2019
+ (rule 1 (lower (has_type $I128 (load flags addr offset)))
2020
+ (if-let offset_plus_8 (s32_add_fallible offset 8))
2021
+ (let ((lo XReg (gen_load (amode addr offset) (LoadOP.Ld) flags))
2022
+ (hi XReg (gen_load (amode addr offset_plus_8) (LoadOP.Ld) flags)))
2023
+ (value_regs lo hi)))
2024
+
2025
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (load flags addr offset)))
2026
+ (let ((eew VecElementWidth (element_width_from_type ty))
2027
+ (amode AMode (amode addr offset)))
2028
+ (vec_load eew (VecAMode.UnitStride amode) flags (unmasked) ty)))
2029
+
2030
+ ;;;;; Rules for Load + Extend Combos ;;;;;;;;;
2031
+
2032
+ ;; These rules cover the special loads that load a 64bit value and do some sort of extension.
2033
+ ;; We don't have any special instructions to do this, so just load the 64 bits as a vector, and
2034
+ ;; do a SEW/2 extension. This only reads half width elements from the source vector register
2035
+ ;; extends it, and writes the back the full register.
2036
+
2037
+ (decl gen_load64_extend (Type ExtendOp MemFlags AMode) VReg)
2038
+
2039
+ (rule (gen_load64_extend ty (ExtendOp.Signed) flags amode)
2040
+ (let ((eew VecElementWidth (element_width_from_type $I64))
2041
+ (load_state VState (vstate_from_type $I64))
2042
+ (loaded VReg (vec_load eew (VecAMode.UnitStride amode) flags (unmasked) load_state)))
2043
+ (rv_vsext_vf2 loaded (unmasked) ty)))
2044
+
2045
+ (rule (gen_load64_extend ty (ExtendOp.Zero) flags amode)
2046
+ (let ((eew VecElementWidth (element_width_from_type $I64))
2047
+ (load_state VState (vstate_from_type $I64))
2048
+ (loaded VReg (vec_load eew (VecAMode.UnitStride amode) flags (unmasked) load_state)))
2049
+ (rv_vzext_vf2 loaded (unmasked) ty)))
2050
+
2051
+ ;;;;; Rules for `uload8x8`;;;;;;;;;;
2052
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $I16X8) (uload8x8 flags addr offset)))
2053
+ (gen_load64_extend ty (ExtendOp.Zero) flags (amode addr offset)))
2054
+
2055
+ ;;;;; Rules for `uload16x4`;;;;;;;;;
2056
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $I32X4) (uload16x4 flags addr offset)))
2057
+ (gen_load64_extend ty (ExtendOp.Zero) flags (amode addr offset)))
2058
+
2059
+ ;;;;; Rules for `uload32x2`;;;;;;;;;
2060
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $I64X2) (uload32x2 flags addr offset)))
2061
+ (gen_load64_extend ty (ExtendOp.Zero) flags (amode addr offset)))
2062
+
2063
+ ;;;;; Rules for `sload8x8`;;;;;;;;;;
2064
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $I16X8) (sload8x8 flags addr offset)))
2065
+ (gen_load64_extend ty (ExtendOp.Signed) flags (amode addr offset)))
2066
+
2067
+ ;;;;; Rules for `sload16x4`;;;;;;;;;
2068
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $I32X4) (sload16x4 flags addr offset)))
2069
+ (gen_load64_extend ty (ExtendOp.Signed) flags (amode addr offset)))
2070
+
2071
+ ;;;;; Rules for `sload32x2`;;;;;;;;;
2072
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $I64X2) (sload32x2 flags addr offset)))
2073
+ (gen_load64_extend ty (ExtendOp.Signed) flags (amode addr offset)))
2074
+
2075
+ ;;;;; Rules for `istore8`;;;;;;;;;
2076
+ (rule (lower (istore8 flags src addr offset))
2077
+ (gen_store (amode addr offset) (StoreOP.Sb) flags src))
2078
+
2079
+ ;;;;; Rules for `istore16`;;;;;;;;;
2080
+ (rule (lower (istore16 flags src addr offset))
2081
+ (gen_store (amode addr offset) (StoreOP.Sh) flags src))
2082
+
2083
+ ;;;;; Rules for `istore32`;;;;;;;;;
2084
+ (rule (lower (istore32 flags src addr offset))
2085
+ (gen_store (amode addr offset) (StoreOP.Sw) flags src))
2086
+
2087
+ ;;;;; Rules for `store`;;;;;;;;;
2088
+ (rule (lower (store flags src @ (value_type ty) addr offset))
2089
+ (gen_store (amode addr offset) (store_op ty) flags src))
2090
+
2091
+ (rule 1 (lower (store flags src @ (value_type $I128) addr offset))
2092
+ (if-let offset_plus_8 (s32_add_fallible offset 8))
2093
+ (let ((_ InstOutput (gen_store (amode addr offset) (StoreOP.Sd) flags (value_regs_get src 0))))
2094
+ (gen_store (amode addr offset_plus_8) (StoreOP.Sd) flags (value_regs_get src 1))))
2095
+
2096
+ (rule 2 (lower (store flags src @ (value_type (ty_vec_fits_in_register ty)) addr offset))
2097
+ (let ((eew VecElementWidth (element_width_from_type ty))
2098
+ (amode AMode (amode addr offset)))
2099
+ (vec_store eew (VecAMode.UnitStride amode) src flags (unmasked) ty)))
2100
+
2101
+
2102
+ ;;;;; Rules for `icmp`;;;;;;;;;
2103
+
2104
+ ;; 8-64 bit comparisons. Mostly fall back onto `IntegerCompare` and then
2105
+ ;; materializing that, but before that happens try to match some
2106
+ ;; constant-related patterns
2107
+
2108
+ (rule 0 (lower (icmp cc x @ (value_type (fits_in_64 ty)) y))
2109
+ (lower_icmp cc x y))
2110
+
2111
+ (decl lower_icmp (IntCC Value Value) XReg)
2112
+ (rule 0 (lower_icmp cc x y)
2113
+ (lower_int_compare (icmp_to_int_compare cc x y)))
2114
+
2115
+ ;; a == $imm => seqz(xori(..))
2116
+ (rule 1 (lower_icmp (IntCC.Equal) x y)
2117
+ (if-let (i64_from_iconst (i64_nonzero (imm12_from_i64 imm))) y)
2118
+ (rv_seqz (rv_xori (sext x) imm)))
2119
+ (rule 2 (lower_icmp (IntCC.Equal) x y)
2120
+ (if-let (i64_from_iconst (i64_nonzero (imm12_from_i64 imm))) x)
2121
+ (rv_seqz (rv_xori (sext y) imm)))
2122
+
2123
+ ;; a != $imm => snez(xori(..))
2124
+ (rule 1 (lower_icmp (IntCC.NotEqual) x y)
2125
+ (if-let (i64_from_iconst (i64_nonzero (imm12_from_i64 imm))) y)
2126
+ (rv_snez (rv_xori (sext x) imm)))
2127
+ (rule 2 (lower_icmp (IntCC.NotEqual) x y)
2128
+ (if-let (i64_from_iconst (i64_nonzero (imm12_from_i64 imm))) x)
2129
+ (rv_snez (rv_xori (sext y) imm)))
2130
+
2131
+ ;; a < $imm => slti(..)
2132
+ (rule 1 (lower_icmp (IntCC.SignedLessThan) x y)
2133
+ (if-let (i64_from_iconst (i64_nonzero (imm12_from_i64 imm))) y)
2134
+ (rv_slti (sext x) imm))
2135
+ (rule 1 (lower_icmp (IntCC.SignedGreaterThan) x y)
2136
+ (if-let (i64_from_iconst (i64_nonzero (imm12_from_i64 imm))) x)
2137
+ (rv_slti (sext y) imm))
2138
+ (rule 1 (lower_icmp (IntCC.UnsignedLessThan) x y)
2139
+ (if-let (u64_from_iconst (u64_nonzero (imm12_from_u64 imm))) y)
2140
+ (rv_sltiu (zext x) imm))
2141
+ (rule 1 (lower_icmp (IntCC.UnsignedGreaterThan) x y)
2142
+ (if-let (u64_from_iconst (u64_nonzero (imm12_from_u64 imm))) x)
2143
+ (rv_sltiu (zext y) imm))
2144
+
2145
+ ;; a >= $imm => !(a < $imm)
2146
+ (rule 2 (lower_icmp cc @ (IntCC.SignedGreaterThanOrEqual) x y)
2147
+ (if-let (i64_from_iconst (i64_nonzero (imm12_from_i64 _))) y)
2148
+ (rv_xori (lower_icmp (intcc_complement cc) x y) (imm12_const 1)))
2149
+ (rule 2 (lower_icmp cc @ (IntCC.UnsignedGreaterThanOrEqual) x y)
2150
+ (if-let (u64_from_iconst (u64_nonzero (imm12_from_u64 _))) y)
2151
+ (rv_xori (lower_icmp (intcc_complement cc) x y) (imm12_const 1)))
2152
+
2153
+ ;; Materializes an `IntegerCompare` bundle directly into an `XReg` with a 0
2154
+ ;; or 1 value.
2155
+ (decl lower_int_compare (IntegerCompare) XReg)
2156
+
2157
+ ;; x == y => x ^ y == 0
2158
+ (rule 0 (lower_int_compare (int_compare_decompose (IntCC.Equal) x y))
2159
+ (rv_seqz (rv_xor x y)))
2160
+ (rule 1 (lower_int_compare (int_compare_decompose (IntCC.Equal) x (zero_reg)))
2161
+ (rv_seqz x))
2162
+ (rule 2 (lower_int_compare (int_compare_decompose (IntCC.Equal) (zero_reg) y))
2163
+ (rv_seqz y))
2164
+ ;; x != y => x ^ y != 0
2165
+ (rule 0 (lower_int_compare (int_compare_decompose (IntCC.NotEqual) x y))
2166
+ (rv_snez (rv_xor x y)))
2167
+ (rule 1 (lower_int_compare (int_compare_decompose (IntCC.NotEqual) x (zero_reg)))
2168
+ (rv_snez x))
2169
+ (rule 2 (lower_int_compare (int_compare_decompose (IntCC.NotEqual) (zero_reg) x))
2170
+ (rv_snez x))
2171
+ ;; x < y => x < y
2172
+ (rule (lower_int_compare (int_compare_decompose (IntCC.SignedLessThan) x y))
2173
+ (rv_slt x y))
2174
+ (rule (lower_int_compare (int_compare_decompose (IntCC.UnsignedLessThan) x y))
2175
+ (rv_sltu x y))
2176
+ ;; x > y => y < x
2177
+ (rule (lower_int_compare (int_compare_decompose (IntCC.SignedGreaterThan) x y))
2178
+ (rv_slt y x))
2179
+ (rule (lower_int_compare (int_compare_decompose (IntCC.UnsignedGreaterThan) x y))
2180
+ (rv_sltu y x))
2181
+ ;; x <= y => !(y < x)
2182
+ (rule (lower_int_compare (int_compare_decompose (IntCC.SignedLessThanOrEqual) x y))
2183
+ (rv_xori (rv_slt y x) (imm12_const 1)))
2184
+ (rule (lower_int_compare (int_compare_decompose (IntCC.UnsignedLessThanOrEqual) x y))
2185
+ (rv_xori (rv_sltu y x) (imm12_const 1)))
2186
+ ;; x >= y => !(x < y)
2187
+ (rule (lower_int_compare (int_compare_decompose (IntCC.SignedGreaterThanOrEqual) x y))
2188
+ (rv_xori (rv_slt x y) (imm12_const 1)))
2189
+ (rule (lower_int_compare (int_compare_decompose (IntCC.UnsignedGreaterThanOrEqual) x y))
2190
+ (rv_xori (rv_sltu x y) (imm12_const 1)))
2191
+
2192
+ ;; 128-bit comparisons.
2193
+ ;;
2194
+ ;; Currently only `==`, `!=`, and `<` are implemented, and everything else
2195
+ ;; delegates to one of those.
2196
+
2197
+ (rule 20 (lower (icmp cc x @ (value_type $I128) y))
2198
+ (lower_icmp_i128 cc x y))
2199
+
2200
+ (decl lower_icmp_i128 (IntCC ValueRegs ValueRegs) XReg)
2201
+ (rule 0 (lower_icmp_i128 (IntCC.Equal) x y)
2202
+ (let ((lo XReg (rv_xor (value_regs_get x 0) (value_regs_get y 0)))
2203
+ (hi XReg (rv_xor (value_regs_get x 1) (value_regs_get y 1))))
2204
+ (rv_seqz (rv_or lo hi))))
2205
+ (rule 0 (lower_icmp_i128 (IntCC.NotEqual) x y)
2206
+ (let ((lo XReg (rv_xor (value_regs_get x 0) (value_regs_get y 0)))
2207
+ (hi XReg (rv_xor (value_regs_get x 1) (value_regs_get y 1))))
2208
+ (rv_snez (rv_or lo hi))))
2209
+
2210
+ ;; swap args for `>` to use `<` instead
2211
+ (rule 0 (lower_icmp_i128 cc @ (IntCC.SignedGreaterThan) x y)
2212
+ (lower_icmp_i128 (intcc_swap_args cc) y x))
2213
+ (rule 0 (lower_icmp_i128 cc @ (IntCC.UnsignedGreaterThan) x y)
2214
+ (lower_icmp_i128 (intcc_swap_args cc) y x))
2215
+
2216
+ ;; complement `=`-related conditions to get ones that don't use `=`.
2217
+ (rule 0 (lower_icmp_i128 cc @ (IntCC.SignedLessThanOrEqual) x y)
2218
+ (rv_xori (lower_icmp_i128 (intcc_complement cc) x y) (imm12_const 1)))
2219
+ (rule 0 (lower_icmp_i128 cc @ (IntCC.SignedGreaterThanOrEqual) x y)
2220
+ (rv_xori (lower_icmp_i128 (intcc_complement cc) x y) (imm12_const 1)))
2221
+ (rule 0 (lower_icmp_i128 cc @ (IntCC.UnsignedLessThanOrEqual) x y)
2222
+ (rv_xori (lower_icmp_i128 (intcc_complement cc) x y) (imm12_const 1)))
2223
+ (rule 0 (lower_icmp_i128 cc @ (IntCC.UnsignedGreaterThanOrEqual) x y)
2224
+ (rv_xori (lower_icmp_i128 (intcc_complement cc) x y) (imm12_const 1)))
2225
+
2226
+ ;; Compare both the bottom and upper halves of the 128-bit values. If
2227
+ ;; the top half is equal use the bottom comparison, otherwise use the upper
2228
+ ;; comparison. Note that the lower comparison is always unsigned since if it's
2229
+ ;; used the top halves are all zeros and the semantic values are positive.
2230
+ (rule 1 (lower_icmp_i128 cc x y)
2231
+ (if-let (IntCC.UnsignedLessThan) (intcc_unsigned cc))
2232
+ (let ((x_lo Reg (value_regs_get x 0))
2233
+ (x_hi Reg (value_regs_get x 1))
2234
+ (y_lo Reg (value_regs_get y 0))
2235
+ (y_hi Reg (value_regs_get y 1))
2236
+ (top_cmp XReg (lower_int_compare (int_compare cc x_hi y_hi)))
2237
+ (bottom_cmp XReg (rv_sltu x_lo y_lo)))
2238
+ (gen_select_xreg (cmp_eqz (rv_xor x_hi y_hi)) bottom_cmp top_cmp)))
2239
+
2240
+ ;; vector icmp comparisons
2241
+
2242
+ (rule 30 (lower (icmp cc x @ (value_type (ty_vec_fits_in_register ty)) y))
2243
+ (gen_expand_mask ty (gen_icmp_mask ty cc x y)))
2244
+
2245
+ ;;;;; Rules for `fcmp`;;;;;;;;;
2246
+ (rule 0 (lower (fcmp cc x @ (value_type (ty_scalar_float ty)) y))
2247
+ (lower_float_compare (fcmp_to_float_compare cc ty x y)))
2248
+
2249
+ (decl lower_float_compare (FloatCompare) XReg)
2250
+ (rule (lower_float_compare (FloatCompare.One r)) r)
2251
+ (rule (lower_float_compare (FloatCompare.Zero r)) (rv_seqz r))
2252
+
2253
+ (rule 1 (lower (fcmp cc x @ (value_type (ty_vec_fits_in_register ty)) y))
2254
+ (gen_expand_mask ty (gen_fcmp_mask ty cc x y)))
2255
+
2256
+ ;;;;; Rules for `func_addr`;;;;;;;;;
2257
+ (rule
2258
+ (lower (func_addr (func_ref_data _ name _)))
2259
+ (load_ext_name name 0))
2260
+
2261
+ ;;;;; Rules for `fcvt_to_uint`;;;;;;;;;
2262
+
2263
+ ;; RISC-V float-to-integer conversion does not trap, but Cranelift semantics are
2264
+ ;; to trap. This manually performs checks for NaN and out-of-bounds values and
2265
+ ;; traps in such cases.
2266
+ ;;
2267
+ ;; TODO: could this perhaps be more optimal through inspection of the `fcsr`?
2268
+ ;; Unsure whether that needs to be preserved across function calls and/or would
2269
+ ;; cause other problems. Also unsure whether it's actually more performant.
2270
+ (rule (lower (has_type ity (fcvt_to_uint v @ (value_type fty))))
2271
+ (let ((_ InstOutput (gen_trapz (rv_feq fty v v) (TrapCode.BadConversionToInteger)))
2272
+ (min FReg (imm fty (fcvt_umin_bound fty $false)))
2273
+ (_ InstOutput (gen_trapnz (rv_fle fty v min) (TrapCode.IntegerOverflow)))
2274
+ (max FReg (imm fty (fcvt_umax_bound fty ity $false)))
2275
+ (_ InstOutput (gen_trapnz (rv_fge fty v max) (TrapCode.IntegerOverflow))))
2276
+ (lower_inbounds_fcvt_to_uint ity fty v)))
2277
+
2278
+ (decl lower_inbounds_fcvt_to_uint (Type Type FReg) XReg)
2279
+ (rule 0 (lower_inbounds_fcvt_to_uint (fits_in_32 _) fty v)
2280
+ (rv_fcvtwu fty (FRM.RTZ) v))
2281
+ (rule 1 (lower_inbounds_fcvt_to_uint $I64 fty v)
2282
+ (rv_fcvtlu fty (FRM.RTZ) v))
2283
+
2284
+ ;;;;; Rules for `fcvt_to_sint`;;;;;;;;;
2285
+
2286
+ ;; NB: see above with `fcvt_to_uint` as this is similar
2287
+ (rule (lower (has_type ity (fcvt_to_sint v @ (value_type fty))))
2288
+ (let ((_ InstOutput (gen_trapz (rv_feq fty v v) (TrapCode.BadConversionToInteger)))
2289
+ (min FReg (imm fty (fcvt_smin_bound fty ity $false)))
2290
+ (_ InstOutput (gen_trapnz (rv_fle fty v min) (TrapCode.IntegerOverflow)))
2291
+ (max FReg (imm fty (fcvt_smax_bound fty ity $false)))
2292
+ (_ InstOutput (gen_trapnz (rv_fge fty v max) (TrapCode.IntegerOverflow))))
2293
+ (lower_inbounds_fcvt_to_sint ity fty v)))
2294
+
2295
+ (decl lower_inbounds_fcvt_to_sint (Type Type FReg) XReg)
2296
+ (rule 0 (lower_inbounds_fcvt_to_sint (fits_in_32 _) fty v)
2297
+ (rv_fcvtw fty (FRM.RTZ) v))
2298
+ (rule 1 (lower_inbounds_fcvt_to_sint $I64 fty v)
2299
+ (rv_fcvtl fty (FRM.RTZ) v))
2300
+
2301
+ ;;;;; Rules for `fcvt_to_sint_sat`;;;;;;;;;
2302
+
2303
+ (rule 0 (lower (has_type to (fcvt_to_sint_sat v @ (value_type (ty_scalar_float from)))))
2304
+ (handle_fcvt_to_int_nan from v (lower_fcvt_to_sint_sat from to v)))
2305
+
2306
+ ;; Lowers to a `rv_fcvt*` instruction but handles 8/16-bit cases where the
2307
+ ;; float is clamped before the conversion.
2308
+ (decl lower_fcvt_to_sint_sat (Type Type FReg) XReg)
2309
+ (rule 0 (lower_fcvt_to_sint_sat ty (fits_in_16 out_ty) v)
2310
+ (let ((max FReg (imm ty (fcvt_smax_bound ty out_ty $true)))
2311
+ (min FReg (imm ty (fcvt_smin_bound ty out_ty $true)))
2312
+ (clamped FReg (rv_fmin ty max (rv_fmax ty min v))))
2313
+ (rv_fcvtw ty (FRM.RTZ) clamped)))
2314
+ (rule 1 (lower_fcvt_to_sint_sat ty $I32 v) (rv_fcvtw ty (FRM.RTZ) v))
2315
+ (rule 1 (lower_fcvt_to_sint_sat ty $I64 v) (rv_fcvtl ty (FRM.RTZ) v))
2316
+
2317
+ (decl fcvt_smax_bound (Type Type bool) u64)
2318
+ (extern constructor fcvt_smax_bound fcvt_smax_bound)
2319
+ (decl fcvt_smin_bound (Type Type bool) u64)
2320
+ (extern constructor fcvt_smin_bound fcvt_smin_bound)
2321
+
2322
+ ;; RISC-V float-to-int conversions generate the same output for NaN and +Inf,
2323
+ ;; but Cranelift semantics are to produce 0 for NaN instead. This helper
2324
+ ;; translates these semantics by taking the float being converted (with the type
2325
+ ;; specified) and the native RISC-V output as an `XReg`. The returned `XReg`
2326
+ ;; will be zeroed out if the float is NaN.
2327
+ ;;
2328
+ ;; This is done by comparing the float to itself, generating 0 if it's NaN. This
2329
+ ;; bit is then negated to become either all-ones or all-zeros which is then
2330
+ ;; and-ed against the native output. That'll produce all zeros if the input is
2331
+ ;; NaN or the native output otherwise.
2332
+ (decl handle_fcvt_to_int_nan (Type FReg XReg) XReg)
2333
+ (rule (handle_fcvt_to_int_nan ty freg xreg)
2334
+ (let ((is_not_nan XReg (rv_feq ty freg freg))
2335
+ (not_nan_mask XReg (rv_neg is_not_nan)))
2336
+ (rv_and xreg not_nan_mask)))
2337
+
2338
+ (rule 1 (lower (has_type (ty_vec_fits_in_register _) (fcvt_to_sint_sat v @ (value_type from_ty))))
2339
+ (if-let zero (i8_to_imm5 0))
2340
+ (let ((is_nan VReg (rv_vmfne_vv v v (unmasked) from_ty))
2341
+ (cvt VReg (rv_vfcvt_rtz_x_f_v v (unmasked) from_ty)))
2342
+ (rv_vmerge_vim cvt zero is_nan from_ty)))
2343
+
2344
+ ;;;;; Rules for `fcvt_to_uint_sat`;;;;;;;;;
2345
+
2346
+ (rule 0 (lower (has_type to (fcvt_to_uint_sat v @ (value_type (ty_scalar_float from)))))
2347
+ (handle_fcvt_to_int_nan from v (lower_fcvt_to_uint_sat from to v)))
2348
+
2349
+ ;; Lowers to a `rv_fcvt*` instruction but handles 8/16-bit cases where the
2350
+ ;; float is clamped before the conversion.
2351
+ (decl lower_fcvt_to_uint_sat (Type Type FReg) XReg)
2352
+ (rule 0 (lower_fcvt_to_uint_sat ty (fits_in_16 out_ty) v)
2353
+ (let ((max FReg (imm ty (fcvt_umax_bound ty out_ty $true)))
2354
+ (min FReg (rv_fmvdx (zero_reg)))
2355
+ (clamped FReg (rv_fmin ty max (rv_fmax ty min v))))
2356
+ (rv_fcvtwu ty (FRM.RTZ) clamped)))
2357
+ (rule 1 (lower_fcvt_to_uint_sat ty $I32 v) (rv_fcvtwu ty (FRM.RTZ) v))
2358
+ (rule 1 (lower_fcvt_to_uint_sat ty $I64 v) (rv_fcvtlu ty (FRM.RTZ) v))
2359
+
2360
+ (decl fcvt_umax_bound (Type Type bool) u64)
2361
+ (extern constructor fcvt_umax_bound fcvt_umax_bound)
2362
+ (decl fcvt_umin_bound (Type bool) u64)
2363
+ (extern constructor fcvt_umin_bound fcvt_umin_bound)
2364
+
2365
+ (rule 1 (lower (has_type (ty_vec_fits_in_register _) (fcvt_to_uint_sat v @ (value_type from_ty))))
2366
+ (if-let zero (i8_to_imm5 0))
2367
+ (let ((is_nan VReg (rv_vmfne_vv v v (unmasked) from_ty))
2368
+ (cvt VReg (rv_vfcvt_rtz_xu_f_v v (unmasked) from_ty)))
2369
+ (rv_vmerge_vim cvt zero is_nan from_ty)))
2370
+
2371
+ ;;;;; Rules for `fcvt_from_sint`;;;;;;;;;
2372
+ (rule 0 (lower (has_type $F32 (fcvt_from_sint v @ (value_type (fits_in_16 ty)))))
2373
+ (rv_fcvtsl (FRM.RNE) (sext v)))
2374
+
2375
+ (rule 1 (lower (has_type $F32 (fcvt_from_sint v @ (value_type $I32))))
2376
+ (rv_fcvtsw (FRM.RNE) v))
2377
+
2378
+ (rule 1 (lower (has_type $F32 (fcvt_from_sint v @ (value_type $I64))))
2379
+ (rv_fcvtsl (FRM.RNE) v))
2380
+
2381
+ (rule 0 (lower (has_type $F64 (fcvt_from_sint v @ (value_type (fits_in_16 ty)))))
2382
+ (rv_fcvtdl (FRM.RNE) (sext v)))
2383
+
2384
+ (rule 1 (lower (has_type $F64 (fcvt_from_sint v @ (value_type $I32))))
2385
+ (rv_fcvtdw v))
2386
+
2387
+ (rule 1 (lower (has_type $F64 (fcvt_from_sint v @ (value_type $I64))))
2388
+ (rv_fcvtdl (FRM.RNE) v))
2389
+
2390
+ (rule 2 (lower (has_type (ty_vec_fits_in_register _) (fcvt_from_sint v @ (value_type from_ty))))
2391
+ (rv_vfcvt_f_x_v v (unmasked) from_ty))
2392
+
2393
+ ;;;;; Rules for `fcvt_from_uint`;;;;;;;;;
2394
+ (rule 0 (lower (has_type $F32 (fcvt_from_uint v @ (value_type (fits_in_16 ty)))))
2395
+ (rv_fcvtslu (FRM.RNE) (zext v)))
2396
+
2397
+ (rule 1 (lower (has_type $F32 (fcvt_from_uint v @ (value_type $I32))))
2398
+ (rv_fcvtswu (FRM.RNE) v))
2399
+
2400
+ (rule 1 (lower (has_type $F32 (fcvt_from_uint v @ (value_type $I64))))
2401
+ (rv_fcvtslu (FRM.RNE) v))
2402
+
2403
+ (rule 0 (lower (has_type $F64 (fcvt_from_uint v @ (value_type (fits_in_16 ty)))))
2404
+ (rv_fcvtdlu (FRM.RNE) (zext v)))
2405
+
2406
+ (rule 1 (lower (has_type $F64 (fcvt_from_uint v @ (value_type $I32))))
2407
+ (rv_fcvtdwu v))
2408
+
2409
+ (rule 1 (lower (has_type $F64 (fcvt_from_uint v @ (value_type $I64))))
2410
+ (rv_fcvtdlu (FRM.RNE) v))
2411
+
2412
+ (rule 2 (lower (has_type (ty_vec_fits_in_register _) (fcvt_from_uint v @ (value_type from_ty))))
2413
+ (rv_vfcvt_f_xu_v v (unmasked) from_ty))
2414
+
2415
+ ;;;;; Rules for `symbol_value`;;;;;;;;;
2416
+ (rule
2417
+ (lower (symbol_value (symbol_value_data name _ offset)))
2418
+ (load_ext_name name offset))
2419
+
2420
+ ;;;;; Rules for `tls_value` ;;;;;;;;;;;;;;
2421
+
2422
+ (rule (lower (has_type (tls_model (TlsModel.ElfGd)) (tls_value (symbol_value_data name _ _))))
2423
+ (elf_tls_get_addr name))
2424
+
2425
+ ;;;;; Rules for `bitcast`;;;;;;;;;
2426
+ (rule
2427
+ (lower (has_type out_ty (bitcast _ v @ (value_type in_ty))))
2428
+ (gen_bitcast v in_ty out_ty))
2429
+
2430
+ ;;;;; Rules for `ceil`;;;;;;;;;
2431
+ (rule 0 (lower (has_type (ty_scalar_float ty) (ceil x)))
2432
+ (gen_float_round (FRM.RUP) x ty))
2433
+
2434
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (ceil x)))
2435
+ (gen_vec_round x (FRM.RUP) ty))
2436
+
2437
+ ;;;;; Rules for `floor`;;;;;;;;;
2438
+ (rule 0 (lower (has_type (ty_scalar_float ty) (floor x)))
2439
+ (gen_float_round (FRM.RDN) x ty))
2440
+
2441
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (floor x)))
2442
+ (gen_vec_round x (FRM.RDN) ty))
2443
+
2444
+ ;;;;; Rules for `trunc`;;;;;;;;;
2445
+ (rule 0 (lower (has_type (ty_scalar_float ty) (trunc x)))
2446
+ (gen_float_round (FRM.RTZ) x ty))
2447
+
2448
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (trunc x)))
2449
+ (gen_vec_round x (FRM.RTZ) ty))
2450
+
2451
+ ;;;;; Rules for `nearest`;;;;;;;;;
2452
+ (rule 0 (lower (has_type (ty_scalar_float ty) (nearest x)))
2453
+ (gen_float_round (FRM.RNE) x ty))
2454
+
2455
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (nearest x)))
2456
+ (gen_vec_round x (FRM.RNE) ty))
2457
+
2458
+
2459
+ ;;;;; Rules for `select_spectre_guard`;;;;;;;;;
2460
+
2461
+ ;; SelectSpectreGuard is equivalent to Select, but we should not use a branch based
2462
+ ;; lowering for it. Instead we use a conditional move based lowering.
2463
+ ;;
2464
+ ;; We don't have cmov's in RISC-V either, but we can emulate those using bitwise
2465
+ ;; operations, which is what we do below.
2466
+
2467
+ ;; Base case: use `gen_bmask` to generate a 0 mask or -1 mask from the value of
2468
+ ;; `cmp`. This is then used with some bit twiddling to produce the final result.
2469
+ (rule 0 (lower (has_type (fits_in_64 _) (select_spectre_guard cmp x y)))
2470
+ (let ((mask XReg (gen_bmask cmp)))
2471
+ (rv_or (rv_and mask x) (rv_andn y mask))))
2472
+ (rule 1 (lower (has_type $I128 (select_spectre_guard cmp x y)))
2473
+ (let ((mask XReg (gen_bmask cmp)))
2474
+ (value_regs
2475
+ (rv_or (rv_and mask (value_regs_get x 0)) (rv_andn (value_regs_get y 0) mask))
2476
+ (rv_or (rv_and mask (value_regs_get x 1)) (rv_andn (value_regs_get y 1) mask)))))
2477
+
2478
+ ;; Special case when an argument is the constant zero as some ands and ors
2479
+ ;; can be folded away.
2480
+ (rule 2 (lower (has_type (fits_in_64 _) (select_spectre_guard cmp (i64_from_iconst 0) y)))
2481
+ (rv_andn y (gen_bmask cmp)))
2482
+ (rule 3 (lower (has_type (fits_in_64 _) (select_spectre_guard cmp x (i64_from_iconst 0))))
2483
+ (rv_and x (gen_bmask cmp)))
2484
+
2485
+ ;;;;; Rules for `bmask`;;;;;;;;;
2486
+ (rule
2487
+ (lower (has_type oty (bmask x)))
2488
+ (lower_bmask x oty))
2489
+
2490
+ ;; N.B.: the Ret itself is generated by the ABI.
2491
+ (rule (lower (return args))
2492
+ (lower_return args))
2493
+
2494
+ ;;; Rules for `get_{frame,stack}_pointer` and `get_return_address` ;;;;;;;;;;;;;
2495
+
2496
+ (rule (lower (get_frame_pointer))
2497
+ (gen_mov_from_preg (fp_reg)))
2498
+
2499
+ (rule (lower (get_stack_pointer))
2500
+ (gen_mov_from_preg (sp_reg)))
2501
+
2502
+ (rule (lower (get_return_address))
2503
+ (load_ra))
2504
+
2505
+ ;;; Rules for `iabs` ;;;;;;;;;;;;;
2506
+
2507
+ ;; I64 and lower
2508
+ ;; Generate the following code:
2509
+ ;; sext.{b,h,w} a0, a0
2510
+ ;; neg a1, a0
2511
+ ;; max a0, a0, a1
2512
+ (rule 0 (lower (has_type (ty_int_ref_scalar_64 ty) (iabs x)))
2513
+ (let ((extended XReg (sext x))
2514
+ (negated XReg (rv_neg extended)))
2515
+ (gen_select_xreg (cmp_gt extended negated) extended negated)))
2516
+
2517
+ ;; For vectors we generate the same code, but with vector instructions
2518
+ ;; we can skip the sign extension, since the vector unit will only process
2519
+ ;; Element Sized chunks.
2520
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (iabs x)))
2521
+ (let ((negated VReg (rv_vneg_v x (unmasked) ty)))
2522
+ (rv_vmax_vv x negated (unmasked) ty)))
2523
+
2524
+ ;;;; Rules for calls ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2525
+
2526
+ (rule (lower (call (func_ref_data sig_ref extname dist) inputs))
2527
+ (gen_call sig_ref extname dist inputs))
2528
+
2529
+ (rule (lower (call_indirect sig_ref val inputs))
2530
+ (gen_call_indirect sig_ref val inputs))
2531
+
2532
+ ;;;; Rules for `return_call` and `return_call_indirect` ;;;;;;;;;;;;;;;;;;;;;;;;
2533
+
2534
+ (rule (lower (return_call (func_ref_data sig_ref extname dist) args))
2535
+ (gen_return_call sig_ref extname dist args))
2536
+
2537
+ (rule (lower (return_call_indirect sig_ref callee args))
2538
+ (gen_return_call_indirect sig_ref callee args))
2539
+
2540
+
2541
+ ;;;; Rules for `extractlane` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2542
+
2543
+ (rule (lower (extractlane x @ (value_type ty) (u8_from_uimm8 idx)))
2544
+ (gen_extractlane ty x idx))
2545
+
2546
+ ;;;; Rules for `insertlane` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2547
+
2548
+ ;; We can insert a lane by using a masked splat from an X register.
2549
+ ;; Build a mask that is only enabled in the lane we want to insert.
2550
+ ;; Then use a masked splat (vmerge) to insert the value.
2551
+ (rule 0 (lower (insertlane vec @ (value_type (ty_vec_fits_in_register ty))
2552
+ val @ (value_type (ty_int _))
2553
+ (u8_from_uimm8 lane)))
2554
+ (let ((mask VReg (gen_vec_mask (u64_shl 1 lane))))
2555
+ (rv_vmerge_vxm vec val mask ty)))
2556
+
2557
+ ;; Similar to above, but using the float variants of the instructions.
2558
+ (rule 1 (lower (insertlane vec @ (value_type (ty_vec_fits_in_register ty))
2559
+ val @ (value_type (ty_scalar_float _))
2560
+ (u8_from_uimm8 lane)))
2561
+ (let ((mask VReg (gen_vec_mask (u64_shl 1 lane))))
2562
+ (rv_vfmerge_vfm vec val mask ty)))
2563
+
2564
+ ;; If we are inserting from an Imm5 const we can use the immediate
2565
+ ;; variant of vmerge.
2566
+ (rule 2 (lower (insertlane vec @ (value_type (ty_vec_fits_in_register ty))
2567
+ (i64_from_iconst (imm5_from_i64 imm))
2568
+ (u8_from_uimm8 lane)))
2569
+ (let ((mask VReg (gen_vec_mask (u64_shl 1 lane))))
2570
+ (rv_vmerge_vim vec imm mask ty)))
2571
+
2572
+ ;;;; Rules for `splat` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2573
+
2574
+ (rule 0 (lower (has_type ty (splat n @ (value_type (ty_scalar_float _)))))
2575
+ (rv_vfmv_vf n ty))
2576
+
2577
+ (rule 1 (lower (has_type ty (splat n @ (value_type (ty_int_ref_scalar_64 _)))))
2578
+ (rv_vmv_vx n ty))
2579
+
2580
+ (rule 2 (lower (has_type ty (splat (iconst (u64_from_imm64 (imm5_from_u64 imm))))))
2581
+ (rv_vmv_vi imm ty))
2582
+
2583
+ ;; TODO: We can splat out more patterns by using for example a vmv.v.i i8x16 for
2584
+ ;; a i64x2 const with a compatible bit pattern. The AArch64 Backend does something
2585
+ ;; similar in its splat rules.
2586
+ ;; TODO: Look through bitcasts when splatting out registers. We can use
2587
+ ;; `vmv.v.x` in a `(splat.f32x4 (bitcast.f32 val))`. And vice versa for integers.
2588
+
2589
+ ;;;; Rules for `uadd_sat` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2590
+
2591
+ (rule 0 (lower (has_type (ty_vec_fits_in_register ty) (uadd_sat x y)))
2592
+ (rv_vsaddu_vv x y (unmasked) ty))
2593
+
2594
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (uadd_sat x (splat y))))
2595
+ (rv_vsaddu_vx x y (unmasked) ty))
2596
+
2597
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (uadd_sat (splat x) y)))
2598
+ (rv_vsaddu_vx y x (unmasked) ty))
2599
+
2600
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (uadd_sat x y)))
2601
+ (if-let y_imm (replicated_imm5 y))
2602
+ (rv_vsaddu_vi x y_imm (unmasked) ty))
2603
+
2604
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (uadd_sat x y)))
2605
+ (if-let x_imm (replicated_imm5 x))
2606
+ (rv_vsaddu_vi y x_imm (unmasked) ty))
2607
+
2608
+ ;;;; Rules for `sadd_sat` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2609
+
2610
+ (rule 0 (lower (has_type (ty_vec_fits_in_register ty) (sadd_sat x y)))
2611
+ (rv_vsadd_vv x y (unmasked) ty))
2612
+
2613
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (sadd_sat x (splat y))))
2614
+ (rv_vsadd_vx x y (unmasked) ty))
2615
+
2616
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (sadd_sat (splat x) y)))
2617
+ (rv_vsadd_vx y x (unmasked) ty))
2618
+
2619
+ (rule 3 (lower (has_type (ty_vec_fits_in_register ty) (sadd_sat x y)))
2620
+ (if-let y_imm (replicated_imm5 y))
2621
+ (rv_vsadd_vi x y_imm (unmasked) ty))
2622
+
2623
+ (rule 4 (lower (has_type (ty_vec_fits_in_register ty) (sadd_sat x y)))
2624
+ (if-let x_imm (replicated_imm5 x))
2625
+ (rv_vsadd_vi y x_imm (unmasked) ty))
2626
+
2627
+ ;;;; Rules for `usub_sat` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2628
+
2629
+ (rule 0 (lower (has_type (ty_vec_fits_in_register ty) (usub_sat x y)))
2630
+ (rv_vssubu_vv x y (unmasked) ty))
2631
+
2632
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (usub_sat x (splat y))))
2633
+ (rv_vssubu_vx x y (unmasked) ty))
2634
+
2635
+ ;;;; Rules for `ssub_sat` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2636
+
2637
+ (rule 0 (lower (has_type (ty_vec_fits_in_register ty) (ssub_sat x y)))
2638
+ (rv_vssub_vv x y (unmasked) ty))
2639
+
2640
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (ssub_sat x (splat y))))
2641
+ (rv_vssub_vx x y (unmasked) ty))
2642
+
2643
+ ;;;; Rules for `vall_true` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2644
+
2645
+ ;; Here we do a Vector Reduce operation. Get the unsigned minimum value of any
2646
+ ;; lane in the vector. The fixed input to the reduce operation is a 1.
2647
+ ;; This way, if any lane is 0, the result will be 0. Otherwise, the result will
2648
+ ;; be a 1.
2649
+ ;; The reduce operation leaves the result in the lowest lane, we then move it
2650
+ ;; into the destination X register.
2651
+ (rule (lower (vall_true x @ (value_type (ty_vec_fits_in_register ty))))
2652
+ (if-let one (i8_to_imm5 1))
2653
+ ;; We don't need to broadcast the immediate into all lanes, only into lane 0.
2654
+ ;; I did it this way since it uses one less instruction than with a vmv.s.x.
2655
+ (let ((fixed VReg (rv_vmv_vi one ty))
2656
+ (min VReg (rv_vredminu_vs x fixed (unmasked) ty)))
2657
+ (rv_vmv_xs min ty)))
2658
+
2659
+
2660
+ ;;;; Rules for `vany_true` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2661
+
2662
+ ;; Here we do a Vector Reduce operation. Get the unsigned maximum value of the
2663
+ ;; input vector register. Move the max to an X register, and do a `snez` on it
2664
+ ;; to ensure its either 1 or 0.
2665
+ (rule (lower (vany_true x @ (value_type (ty_vec_fits_in_register ty))))
2666
+ (let ((max VReg (rv_vredmaxu_vs x x (unmasked) ty))
2667
+ (x_max XReg (rv_vmv_xs max ty)))
2668
+ (rv_snez x_max)))
2669
+
2670
+
2671
+ ;;;; Rules for `vhigh_bits` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2672
+
2673
+ ;; To check if the MSB of a lane is set, we do a `vmslt` with zero, this sets
2674
+ ;; the mask bit to 1 if the value is negative (MSB 1) and 0 if not. We can then
2675
+ ;; just move that mask to an X Register.
2676
+ ;;
2677
+ ;; We must ensure that the move to the X register has a SEW with enough bits
2678
+ ;; to hold the full mask. Additionally, in some cases (e.g. i64x2) we are going
2679
+ ;; to read some tail bits. These are undefined, so we need to further mask them
2680
+ ;; off.
2681
+ (rule (lower (vhigh_bits x @ (value_type (ty_vec_fits_in_register ty))))
2682
+ (let ((mask VReg (rv_vmslt_vx x (zero_reg) (unmasked) ty))
2683
+ ;; Here we only need I64X1, but emit an AVL of 2 since it
2684
+ ;; saves one vector state change in the case of I64X2.
2685
+ ;;
2686
+ ;; TODO: For types that have more lanes than element bits, we can
2687
+ ;; use the original type as a VState and avoid a state change.
2688
+ (x_mask XReg (rv_vmv_xs mask (vstate_from_type $I64X2))))
2689
+ (gen_andi x_mask (ty_lane_mask ty))))
2690
+
2691
+ ;;;; Rules for `swizzle` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2692
+
2693
+ (rule 0 (lower (has_type (ty_vec_fits_in_register ty) (swizzle x y)))
2694
+ (rv_vrgather_vv x y (unmasked) ty))
2695
+
2696
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (swizzle x (splat y))))
2697
+ (rv_vrgather_vx x y (unmasked) ty))
2698
+
2699
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (swizzle x y)))
2700
+ (if-let y_imm (replicated_uimm5 y))
2701
+ (rv_vrgather_vi x y_imm (unmasked) ty))
2702
+
2703
+ ;;;; Rules for `shuffle` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2704
+
2705
+ ;; Use a vrgather to load all 0-15 lanes from x. And then modify the mask to load all
2706
+ ;; 16-31 lanes from y. Finally, use a vor to combine the two vectors.
2707
+ ;;
2708
+ ;; vrgather will insert a 0 for lanes that are out of bounds, so we can let it load
2709
+ ;; negative and out of bounds indexes.
2710
+ (rule (lower (has_type (ty_vec_fits_in_register ty @ $I8X16) (shuffle x y (vconst_from_immediate mask))))
2711
+ (if-let neg16 (i8_to_imm5 -16))
2712
+ (let ((x_mask VReg (gen_constant ty mask))
2713
+ (x_lanes VReg (rv_vrgather_vv x x_mask (unmasked) ty))
2714
+ (y_mask VReg (rv_vadd_vi x_mask neg16 (unmasked) ty))
2715
+ (y_lanes VReg (rv_vrgather_vv y y_mask (unmasked) ty)))
2716
+ (rv_vor_vv x_lanes y_lanes (unmasked) ty)))
2717
+
2718
+ ;;;; Rules for `swiden_high` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2719
+
2720
+ ;; Slide down half the vector, and do a signed extension.
2721
+ (rule 0 (lower (has_type (ty_vec_fits_in_register out_ty) (swiden_high x @ (value_type in_ty))))
2722
+ (rv_vsext_vf2 (gen_slidedown_half in_ty x) (unmasked) out_ty))
2723
+
2724
+ (rule 1 (lower (has_type (ty_vec_fits_in_register out_ty) (swiden_high (swiden_high x @ (value_type in_ty)))))
2725
+ (if-let (uimm5_from_u64 amt) (u64_sub (ty_lane_count in_ty) (ty_lane_count out_ty)))
2726
+ (rv_vsext_vf4 (rv_vslidedown_vi x amt (unmasked) in_ty) (unmasked) out_ty))
2727
+
2728
+ (rule 2 (lower (has_type (ty_vec_fits_in_register out_ty) (swiden_high (swiden_high (swiden_high x @ (value_type in_ty))))))
2729
+ (if-let (uimm5_from_u64 amt) (u64_sub (ty_lane_count in_ty) (ty_lane_count out_ty)))
2730
+ (rv_vsext_vf8 (rv_vslidedown_vi x amt (unmasked) in_ty) (unmasked) out_ty))
2731
+
2732
+ ;;;; Rules for `uwiden_high` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2733
+
2734
+ ;; Slide down half the vector, and do a zero extension.
2735
+ (rule 0 (lower (has_type (ty_vec_fits_in_register out_ty) (uwiden_high x @ (value_type in_ty))))
2736
+ (rv_vzext_vf2 (gen_slidedown_half in_ty x) (unmasked) out_ty))
2737
+
2738
+ (rule 1 (lower (has_type (ty_vec_fits_in_register out_ty) (uwiden_high (uwiden_high x @ (value_type in_ty)))))
2739
+ (if-let (uimm5_from_u64 amt) (u64_sub (ty_lane_count in_ty) (ty_lane_count out_ty)))
2740
+ (rv_vzext_vf4 (rv_vslidedown_vi x amt (unmasked) in_ty) (unmasked) out_ty))
2741
+
2742
+ (rule 2 (lower (has_type (ty_vec_fits_in_register out_ty) (uwiden_high (uwiden_high (uwiden_high x @ (value_type in_ty))))))
2743
+ (if-let (uimm5_from_u64 amt) (u64_sub (ty_lane_count in_ty) (ty_lane_count out_ty)))
2744
+ (rv_vzext_vf8 (rv_vslidedown_vi x amt (unmasked) in_ty) (unmasked) out_ty))
2745
+
2746
+ ;;;; Rules for `swiden_low` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2747
+
2748
+ (rule 0 (lower (has_type (ty_vec_fits_in_register out_ty) (swiden_low x)))
2749
+ (rv_vsext_vf2 x (unmasked) out_ty))
2750
+
2751
+ (rule 1 (lower (has_type (ty_vec_fits_in_register out_ty) (swiden_low (swiden_low x))))
2752
+ (rv_vsext_vf4 x (unmasked) out_ty))
2753
+
2754
+ (rule 2 (lower (has_type (ty_vec_fits_in_register out_ty) (swiden_low (swiden_low (swiden_low x)))))
2755
+ (rv_vsext_vf8 x (unmasked) out_ty))
2756
+
2757
+ ;;;; Rules for `uwiden_low` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2758
+
2759
+ (rule 0 (lower (has_type (ty_vec_fits_in_register out_ty) (uwiden_low x)))
2760
+ (rv_vzext_vf2 x (unmasked) out_ty))
2761
+
2762
+ (rule 1 (lower (has_type (ty_vec_fits_in_register out_ty) (uwiden_low (uwiden_low x))))
2763
+ (rv_vzext_vf4 x (unmasked) out_ty))
2764
+
2765
+ (rule 2 (lower (has_type (ty_vec_fits_in_register out_ty) (uwiden_low (uwiden_low (uwiden_low x)))))
2766
+ (rv_vzext_vf8 x (unmasked) out_ty))
2767
+
2768
+ ;;;; Rules for `iadd_pairwise` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2769
+
2770
+ ;; We don't have a dedicated instruction for this, rearrange the register elements
2771
+ ;; and use a vadd.
2772
+ ;;
2773
+ ;; We do this by building two masks, one for the even elements and one for the odd
2774
+ ;; elements. Using vcompress we can extract the elements and group them together.
2775
+ ;;
2776
+ ;; This is likely not the optimal way of doing this. LLVM does this using a bunch
2777
+ ;; of vrgathers (See: https://godbolt.org/z/jq8Wj8WG4), that doesen't seem to be
2778
+ ;; too much better than this.
2779
+ ;;
2780
+ ;; However V8 does something better. They use 2 vcompresses using LMUL2, that means
2781
+ ;; that they can do the whole thing in 3 instructions (2 vcompress + vadd). We don't
2782
+ ;; support LMUL > 1, so we can't do that.
2783
+ (rule (lower (has_type (ty_vec_fits_in_register ty) (iadd_pairwise x y)))
2784
+ (if-let half_size (u64_to_uimm5 (u64_udiv (ty_lane_count ty) 2)))
2785
+ (let ((odd_mask VReg (gen_vec_mask 0x5555555555555555))
2786
+ (lhs_lo VReg (rv_vcompress_vm x odd_mask ty))
2787
+ (lhs_hi VReg (rv_vcompress_vm y odd_mask ty))
2788
+ (lhs VReg (rv_vslideup_vvi lhs_lo lhs_hi half_size (unmasked) ty))
2789
+
2790
+ (even_mask VReg (gen_vec_mask 0xAAAAAAAAAAAAAAAA))
2791
+ (rhs_lo VReg (rv_vcompress_vm x even_mask ty))
2792
+ (rhs_hi VReg (rv_vcompress_vm y even_mask ty))
2793
+ (rhs VReg (rv_vslideup_vvi rhs_lo rhs_hi half_size (unmasked) ty)))
2794
+ (rv_vadd_vv lhs rhs (unmasked) ty)))
2795
+
2796
+ ;;;; Rules for `avg_round` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2797
+
2798
+ ;; `avg_round` computes the unsigned average with rounding: a := (x + y + 1) // 2
2799
+ ;;
2800
+ ;; See Section "2–5 Average of Two Integers" of the Hacker's Delight book
2801
+ ;;
2802
+ ;; The floor average of two integers without overflow can be computed as:
2803
+ ;; t = (x & y) + ((x ^ y) >> 1)
2804
+ ;;
2805
+ ;; The right shift should be a logical shift if the integers are unsigned.
2806
+ ;;
2807
+ ;; We are however interested in the ceiling average (x + y + 1). For that
2808
+ ;; we use a special rounding mode in the right shift instruction.
2809
+ ;;
2810
+ ;; For the right shift instruction we use `vssrl` which is a Scaling Shift
2811
+ ;; Right Logical instruction using the `vxrm` fixed-point rouding mode. The
2812
+ ;; default rounding mode is `rnu` (round-to-nearest-up (add +0.5 LSB)).
2813
+ ;; Which is coincidentally the rounding mode we want for `avg_round`.
2814
+ (rule (lower (has_type (ty_vec_fits_in_register ty) (avg_round x y)))
2815
+ (if-let one (u64_to_uimm5 1))
2816
+ (let ((lhs VReg (rv_vand_vv x y (unmasked) ty))
2817
+ (xor VReg (rv_vxor_vv x y (unmasked) ty))
2818
+ (rhs VReg (rv_vssrl_vi xor one (unmasked) ty)))
2819
+ (rv_vadd_vv lhs rhs (unmasked) ty)))
2820
+
2821
+ ;;;; Rules for `scalar_to_vector` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2822
+
2823
+ (rule 0 (lower (has_type (ty_vec_fits_in_register ty) (scalar_to_vector x)))
2824
+ (if (ty_vector_float ty))
2825
+ (let ((zero VReg (rv_vmv_vx (zero_reg) ty))
2826
+ (elem VReg (rv_vfmv_sf x ty))
2827
+ (mask VReg (gen_vec_mask 1)))
2828
+ (rv_vmerge_vvm zero elem mask ty)))
2829
+
2830
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (scalar_to_vector x)))
2831
+ (if (ty_vector_not_float ty))
2832
+ (let ((zero VReg (rv_vmv_vx (zero_reg) ty))
2833
+ (mask VReg (gen_vec_mask 1)))
2834
+ (rv_vmerge_vxm zero x mask ty)))
2835
+
2836
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (scalar_to_vector (imm5_from_value x))))
2837
+ (let ((zero VReg (rv_vmv_vx (zero_reg) ty))
2838
+ (mask VReg (gen_vec_mask 1)))
2839
+ (rv_vmerge_vim zero x mask ty)))
2840
+
2841
+ ;;;; Rules for `sqmul_round_sat` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2842
+
2843
+ (rule 0 (lower (has_type (ty_vec_fits_in_register ty) (sqmul_round_sat x y)))
2844
+ (rv_vsmul_vv x y (unmasked) ty))
2845
+
2846
+ (rule 1 (lower (has_type (ty_vec_fits_in_register ty) (sqmul_round_sat x (splat y))))
2847
+ (rv_vsmul_vx x y (unmasked) ty))
2848
+
2849
+ (rule 2 (lower (has_type (ty_vec_fits_in_register ty) (sqmul_round_sat (splat x) y)))
2850
+ (rv_vsmul_vx y x (unmasked) ty))
2851
+
2852
+ ;;;; Rules for `snarrow` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2853
+
2854
+ (rule (lower (has_type (ty_vec_fits_in_register out_ty) (snarrow x @ (value_type in_ty) y)))
2855
+ (if-let lane_diff (u64_to_uimm5 (u64_udiv (ty_lane_count out_ty) 2)))
2856
+ (if-let zero (u64_to_uimm5 0))
2857
+ (let ((x_clip VReg (rv_vnclip_wi x zero (unmasked) (vstate_mf2 (ty_half_lanes out_ty))))
2858
+ (y_clip VReg (rv_vnclip_wi y zero (unmasked) (vstate_mf2 (ty_half_lanes out_ty)))))
2859
+ (rv_vslideup_vvi x_clip y_clip lane_diff (unmasked) out_ty)))
2860
+
2861
+ ;;;; Rules for `uunarrow` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2862
+
2863
+ (rule (lower (has_type (ty_vec_fits_in_register out_ty) (uunarrow x @ (value_type in_ty) y)))
2864
+ (if-let lane_diff (u64_to_uimm5 (u64_udiv (ty_lane_count out_ty) 2)))
2865
+ (if-let zero (u64_to_uimm5 0))
2866
+ (let ((x_clip VReg (rv_vnclipu_wi x zero (unmasked) (vstate_mf2 (ty_half_lanes out_ty))))
2867
+ (y_clip VReg (rv_vnclipu_wi y zero (unmasked) (vstate_mf2 (ty_half_lanes out_ty)))))
2868
+ (rv_vslideup_vvi x_clip y_clip lane_diff (unmasked) out_ty)))
2869
+
2870
+ ;;;; Rules for `unarrow` ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2871
+
2872
+ ;; We don't have a instruction that saturates a signed source into an unsigned destination.
2873
+ ;; To correct for this we just remove negative values using `vmax` and then use the normal
2874
+ ;; unsigned to unsigned narrowing instruction.
2875
+
2876
+ (rule (lower (has_type (ty_vec_fits_in_register out_ty) (unarrow x @ (value_type in_ty) y)))
2877
+ (if-let lane_diff (u64_to_uimm5 (u64_udiv (ty_lane_count out_ty) 2)))
2878
+ (if-let zero (u64_to_uimm5 0))
2879
+ (let ((x_pos VReg (rv_vmax_vx x (zero_reg) (unmasked) in_ty))
2880
+ (y_pos VReg (rv_vmax_vx y (zero_reg) (unmasked) in_ty))
2881
+ (x_clip VReg (rv_vnclipu_wi x_pos zero (unmasked) (vstate_mf2 (ty_half_lanes out_ty))))
2882
+ (y_clip VReg (rv_vnclipu_wi y_pos zero (unmasked) (vstate_mf2 (ty_half_lanes out_ty)))))
2883
+ (rv_vslideup_vvi x_clip y_clip lane_diff (unmasked) out_ty)))