wasmtime 16.0.0 → 17.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1111) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +103 -79
  3. data/ext/Cargo.toml +7 -6
  4. data/ext/cargo-vendor/cranelift-bforest-0.104.0/.cargo-checksum.json +1 -0
  5. data/ext/cargo-vendor/cranelift-bforest-0.104.0/Cargo.toml +40 -0
  6. data/ext/cargo-vendor/cranelift-codegen-0.104.0/.cargo-checksum.json +1 -0
  7. data/ext/cargo-vendor/cranelift-codegen-0.104.0/Cargo.toml +175 -0
  8. data/ext/cargo-vendor/cranelift-codegen-0.104.0/build.rs +392 -0
  9. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/isa/aarch64/inst.isle +4197 -0
  10. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/isa/aarch64/lower/isle.rs +882 -0
  11. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/isa/x64/abi.rs +1305 -0
  12. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/isle_prelude.rs +957 -0
  13. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/machinst/isle.rs +908 -0
  14. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/machinst/mod.rs +558 -0
  15. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/machinst/pcc.rs +159 -0
  16. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/arithmetic.isle +169 -0
  17. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/bitops.isle +188 -0
  18. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/cprop.isle +248 -0
  19. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/extends.isle +116 -0
  20. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/icmp.isle +197 -0
  21. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/selects.isle +77 -0
  22. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/shifts.isle +307 -0
  23. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts/spaceship.isle +194 -0
  24. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/opts.rs +265 -0
  25. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/prelude.isle +641 -0
  26. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/prelude_lower.isle +1073 -0
  27. data/ext/cargo-vendor/cranelift-codegen-0.104.0/src/prelude_opt.isle +134 -0
  28. data/ext/cargo-vendor/cranelift-codegen-meta-0.104.0/.cargo-checksum.json +1 -0
  29. data/ext/cargo-vendor/cranelift-codegen-meta-0.104.0/Cargo.toml +35 -0
  30. data/ext/cargo-vendor/cranelift-codegen-shared-0.104.0/.cargo-checksum.json +1 -0
  31. data/ext/cargo-vendor/cranelift-codegen-shared-0.104.0/Cargo.toml +22 -0
  32. data/ext/cargo-vendor/cranelift-control-0.104.0/.cargo-checksum.json +1 -0
  33. data/ext/cargo-vendor/cranelift-control-0.104.0/Cargo.toml +30 -0
  34. data/ext/cargo-vendor/cranelift-entity-0.104.0/.cargo-checksum.json +1 -0
  35. data/ext/cargo-vendor/cranelift-entity-0.104.0/Cargo.toml +50 -0
  36. data/ext/cargo-vendor/cranelift-entity-0.104.0/src/primary.rs +541 -0
  37. data/ext/cargo-vendor/cranelift-frontend-0.104.0/.cargo-checksum.json +1 -0
  38. data/ext/cargo-vendor/cranelift-frontend-0.104.0/Cargo.toml +68 -0
  39. data/ext/cargo-vendor/cranelift-isle-0.104.0/.cargo-checksum.json +1 -0
  40. data/ext/cargo-vendor/cranelift-isle-0.104.0/Cargo.toml +46 -0
  41. data/ext/cargo-vendor/cranelift-native-0.104.0/.cargo-checksum.json +1 -0
  42. data/ext/cargo-vendor/cranelift-native-0.104.0/Cargo.toml +43 -0
  43. data/ext/cargo-vendor/cranelift-wasm-0.104.0/.cargo-checksum.json +1 -0
  44. data/ext/cargo-vendor/cranelift-wasm-0.104.0/Cargo.toml +106 -0
  45. data/ext/cargo-vendor/cranelift-wasm-0.104.0/src/code_translator.rs +3646 -0
  46. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/.cargo-checksum.json +1 -0
  47. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/Cargo.toml +49 -0
  48. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/README.md +52 -0
  49. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/src/clocks.rs +56 -0
  50. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/src/lib.rs +24 -0
  51. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/src/noop_scheduler.rs +25 -0
  52. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/tests/clocks.rs +33 -0
  53. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/tests/common/mod.rs +33 -0
  54. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/tests/random.rs +17 -0
  55. data/ext/cargo-vendor/deterministic-wasi-ctx-0.1.18/tests/scheduler.rs +24 -0
  56. data/ext/cargo-vendor/rand_pcg-0.3.1/.cargo-checksum.json +1 -0
  57. data/ext/cargo-vendor/rand_pcg-0.3.1/CHANGELOG.md +37 -0
  58. data/ext/cargo-vendor/rand_pcg-0.3.1/COPYRIGHT +12 -0
  59. data/ext/cargo-vendor/rand_pcg-0.3.1/Cargo.toml +37 -0
  60. data/ext/cargo-vendor/rand_pcg-0.3.1/LICENSE-APACHE +201 -0
  61. data/ext/cargo-vendor/rand_pcg-0.3.1/LICENSE-MIT +26 -0
  62. data/ext/cargo-vendor/rand_pcg-0.3.1/README.md +42 -0
  63. data/ext/cargo-vendor/rand_pcg-0.3.1/src/lib.rs +45 -0
  64. data/ext/cargo-vendor/rand_pcg-0.3.1/src/pcg128.rs +296 -0
  65. data/ext/cargo-vendor/rand_pcg-0.3.1/src/pcg64.rs +166 -0
  66. data/ext/cargo-vendor/rand_pcg-0.3.1/tests/lcg128xsl64.rs +77 -0
  67. data/ext/cargo-vendor/rand_pcg-0.3.1/tests/lcg64xsh32.rs +70 -0
  68. data/ext/cargo-vendor/rand_pcg-0.3.1/tests/mcg128xsl64.rs +75 -0
  69. data/ext/cargo-vendor/wasi-cap-std-sync-17.0.0/.cargo-checksum.json +1 -0
  70. data/ext/cargo-vendor/wasi-cap-std-sync-17.0.0/Cargo.toml +102 -0
  71. data/ext/cargo-vendor/wasi-common-17.0.0/.cargo-checksum.json +1 -0
  72. data/ext/cargo-vendor/wasi-common-17.0.0/Cargo.toml +131 -0
  73. data/ext/cargo-vendor/wasi-common-17.0.0/src/error.rs +26 -0
  74. data/ext/cargo-vendor/wasi-common-17.0.0/src/snapshots/preview_1/error.rs +266 -0
  75. data/ext/cargo-vendor/wasmtime-17.0.0/.cargo-checksum.json +1 -0
  76. data/ext/cargo-vendor/wasmtime-17.0.0/Cargo.toml +211 -0
  77. data/ext/cargo-vendor/wasmtime-17.0.0/src/component/component.rs +545 -0
  78. data/ext/cargo-vendor/wasmtime-17.0.0/src/component/instance.rs +815 -0
  79. data/ext/cargo-vendor/wasmtime-17.0.0/src/component/linker.rs +580 -0
  80. data/ext/cargo-vendor/wasmtime-17.0.0/src/component/matching.rs +215 -0
  81. data/ext/cargo-vendor/wasmtime-17.0.0/src/component/mod.rs +351 -0
  82. data/ext/cargo-vendor/wasmtime-17.0.0/src/component/resource_table.rs +350 -0
  83. data/ext/cargo-vendor/wasmtime-17.0.0/src/component/resources.rs +823 -0
  84. data/ext/cargo-vendor/wasmtime-17.0.0/src/config.rs +2428 -0
  85. data/ext/cargo-vendor/wasmtime-17.0.0/src/func/typed.rs +638 -0
  86. data/ext/cargo-vendor/wasmtime-17.0.0/src/lib.rs +526 -0
  87. data/ext/cargo-vendor/wasmtime-17.0.0/src/store.rs +2389 -0
  88. data/ext/cargo-vendor/wasmtime-asm-macros-17.0.0/.cargo-checksum.json +1 -0
  89. data/ext/cargo-vendor/wasmtime-asm-macros-17.0.0/Cargo.toml +22 -0
  90. data/ext/cargo-vendor/wasmtime-cache-17.0.0/.cargo-checksum.json +1 -0
  91. data/ext/cargo-vendor/wasmtime-cache-17.0.0/Cargo.toml +81 -0
  92. data/ext/cargo-vendor/wasmtime-component-macro-17.0.0/.cargo-checksum.json +1 -0
  93. data/ext/cargo-vendor/wasmtime-component-macro-17.0.0/Cargo.toml +67 -0
  94. data/ext/cargo-vendor/wasmtime-component-macro-17.0.0/src/bindgen.rs +371 -0
  95. data/ext/cargo-vendor/wasmtime-component-macro-17.0.0/tests/codegen/multiversion/root.wit +8 -0
  96. data/ext/cargo-vendor/wasmtime-component-util-17.0.0/.cargo-checksum.json +1 -0
  97. data/ext/cargo-vendor/wasmtime-component-util-17.0.0/Cargo.toml +25 -0
  98. data/ext/cargo-vendor/wasmtime-cranelift-17.0.0/.cargo-checksum.json +1 -0
  99. data/ext/cargo-vendor/wasmtime-cranelift-17.0.0/Cargo.toml +112 -0
  100. data/ext/cargo-vendor/wasmtime-cranelift-shared-17.0.0/.cargo-checksum.json +1 -0
  101. data/ext/cargo-vendor/wasmtime-cranelift-shared-17.0.0/Cargo.toml +71 -0
  102. data/ext/cargo-vendor/wasmtime-environ-17.0.0/.cargo-checksum.json +1 -0
  103. data/ext/cargo-vendor/wasmtime-environ-17.0.0/Cargo.lock +726 -0
  104. data/ext/cargo-vendor/wasmtime-environ-17.0.0/Cargo.toml +125 -0
  105. data/ext/cargo-vendor/wasmtime-environ-17.0.0/examples/factc.rs +205 -0
  106. data/ext/cargo-vendor/wasmtime-fiber-17.0.0/.cargo-checksum.json +1 -0
  107. data/ext/cargo-vendor/wasmtime-fiber-17.0.0/Cargo.toml +63 -0
  108. data/ext/cargo-vendor/wasmtime-jit-17.0.0/.cargo-checksum.json +1 -0
  109. data/ext/cargo-vendor/wasmtime-jit-17.0.0/Cargo.toml +125 -0
  110. data/ext/cargo-vendor/wasmtime-jit-debug-17.0.0/.cargo-checksum.json +1 -0
  111. data/ext/cargo-vendor/wasmtime-jit-debug-17.0.0/Cargo.toml +67 -0
  112. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-17.0.0/.cargo-checksum.json +1 -0
  113. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-17.0.0/Cargo.toml +46 -0
  114. data/ext/cargo-vendor/wasmtime-runtime-17.0.0/.cargo-checksum.json +1 -0
  115. data/ext/cargo-vendor/wasmtime-runtime-17.0.0/Cargo.toml +139 -0
  116. data/ext/cargo-vendor/wasmtime-runtime-17.0.0/src/instance/allocator/pooling/memory_pool.rs +997 -0
  117. data/ext/cargo-vendor/wasmtime-runtime-17.0.0/src/instance/allocator/pooling.rs +658 -0
  118. data/ext/cargo-vendor/wasmtime-runtime-17.0.0/src/memory.rs +973 -0
  119. data/ext/cargo-vendor/wasmtime-runtime-17.0.0/src/parking_spot.rs +622 -0
  120. data/ext/cargo-vendor/wasmtime-runtime-17.0.0/src/sys/windows/mmap.rs +216 -0
  121. data/ext/cargo-vendor/wasmtime-types-17.0.0/.cargo-checksum.json +1 -0
  122. data/ext/cargo-vendor/wasmtime-types-17.0.0/Cargo.toml +36 -0
  123. data/ext/cargo-vendor/wasmtime-versioned-export-macros-17.0.0/.cargo-checksum.json +1 -0
  124. data/ext/cargo-vendor/wasmtime-versioned-export-macros-17.0.0/Cargo.toml +32 -0
  125. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/.cargo-checksum.json +1 -0
  126. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/Cargo.toml +261 -0
  127. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/ctx.rs +333 -0
  128. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/filesystem.rs +325 -0
  129. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/host/clocks.rs +103 -0
  130. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/host/filesystem.rs +1069 -0
  131. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/host/instance_network.rs +15 -0
  132. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/host/network.rs +625 -0
  133. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/host/tcp.rs +605 -0
  134. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/host/udp.rs +530 -0
  135. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/mod.rs +327 -0
  136. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/network.rs +108 -0
  137. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/poll.rs +175 -0
  138. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/preview1.rs +2362 -0
  139. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/stream.rs +181 -0
  140. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/tcp.rs +335 -0
  141. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/src/preview2/udp.rs +125 -0
  142. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/tests/all/api.rs +217 -0
  143. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/tests/all/async_.rs +364 -0
  144. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/tests/all/main.rs +112 -0
  145. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/tests/all/preview1.rs +243 -0
  146. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/tests/all/sync.rs +303 -0
  147. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/command-extended.wit +6 -0
  148. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/cli/command.wit +7 -0
  149. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/cli/imports.wit +20 -0
  150. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/cli/stdio.wit +17 -0
  151. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/cli/terminal.wit +49 -0
  152. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/clocks/monotonic-clock.wit +45 -0
  153. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/clocks/wall-clock.wit +42 -0
  154. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/clocks/world.wit +6 -0
  155. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/filesystem/preopens.wit +8 -0
  156. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/filesystem/types.wit +634 -0
  157. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/filesystem/world.wit +6 -0
  158. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/http/proxy.wit +32 -0
  159. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/http/types.wit +570 -0
  160. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/io/error.wit +34 -0
  161. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/io/poll.wit +41 -0
  162. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/io/streams.wit +251 -0
  163. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/io/world.wit +6 -0
  164. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/random/insecure-seed.wit +25 -0
  165. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/random/insecure.wit +22 -0
  166. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/random/random.wit +26 -0
  167. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/random/world.wit +7 -0
  168. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/sockets/ip-name-lookup.wit +51 -0
  169. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/sockets/network.wit +145 -0
  170. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/sockets/tcp-create-socket.wit +27 -0
  171. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/sockets/tcp.wit +309 -0
  172. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/sockets/udp-create-socket.wit +27 -0
  173. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/sockets/udp.wit +264 -0
  174. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/deps/sockets/world.wit +11 -0
  175. data/ext/cargo-vendor/wasmtime-wasi-17.0.0/wit/test.wit +22 -0
  176. data/ext/cargo-vendor/wasmtime-winch-17.0.0/.cargo-checksum.json +1 -0
  177. data/ext/cargo-vendor/wasmtime-winch-17.0.0/Cargo.toml +77 -0
  178. data/ext/cargo-vendor/wasmtime-wit-bindgen-17.0.0/.cargo-checksum.json +1 -0
  179. data/ext/cargo-vendor/wasmtime-wit-bindgen-17.0.0/Cargo.toml +41 -0
  180. data/ext/cargo-vendor/wasmtime-wit-bindgen-17.0.0/src/lib.rs +2097 -0
  181. data/ext/cargo-vendor/wasmtime-wmemcheck-17.0.0/.cargo-checksum.json +1 -0
  182. data/ext/cargo-vendor/wasmtime-wmemcheck-17.0.0/Cargo.toml +29 -0
  183. data/ext/cargo-vendor/wiggle-17.0.0/.cargo-checksum.json +1 -0
  184. data/ext/cargo-vendor/wiggle-17.0.0/Cargo.toml +115 -0
  185. data/ext/cargo-vendor/wiggle-generate-17.0.0/.cargo-checksum.json +1 -0
  186. data/ext/cargo-vendor/wiggle-generate-17.0.0/Cargo.toml +65 -0
  187. data/ext/cargo-vendor/wiggle-macro-17.0.0/.cargo-checksum.json +1 -0
  188. data/ext/cargo-vendor/wiggle-macro-17.0.0/Cargo.toml +55 -0
  189. data/ext/cargo-vendor/winch-codegen-0.15.0/.cargo-checksum.json +1 -0
  190. data/ext/cargo-vendor/winch-codegen-0.15.0/Cargo.toml +76 -0
  191. data/ext/cargo-vendor/winch-codegen-0.15.0/src/codegen/context.rs +553 -0
  192. data/ext/cargo-vendor/winch-codegen-0.15.0/src/codegen/env.rs +309 -0
  193. data/ext/cargo-vendor/winch-codegen-0.15.0/src/isa/aarch64/masm.rs +457 -0
  194. data/ext/cargo-vendor/winch-codegen-0.15.0/src/isa/x64/asm.rs +1149 -0
  195. data/ext/cargo-vendor/winch-codegen-0.15.0/src/isa/x64/masm.rs +1044 -0
  196. data/ext/cargo-vendor/winch-codegen-0.15.0/src/masm.rs +708 -0
  197. data/ext/cargo-vendor/winch-codegen-0.15.0/src/stack.rs +452 -0
  198. data/ext/cargo-vendor/winch-codegen-0.15.0/src/visitor.rs +1617 -0
  199. data/ext/src/helpers/mod.rs +4 -0
  200. data/ext/src/helpers/nogvl.rs +29 -0
  201. data/ext/src/helpers/tmplock.rs +45 -0
  202. data/ext/src/ruby_api/engine.rs +7 -3
  203. data/ext/src/ruby_api/mod.rs +3 -0
  204. data/ext/src/ruby_api/module.rs +22 -8
  205. data/ext/src/ruby_api/store.rs +66 -12
  206. data/ext/src/ruby_api/wasi_ctx.rs +110 -0
  207. data/ext/src/ruby_api/wasi_ctx_builder.rs +10 -7
  208. data/lib/wasmtime/version.rb +1 -1
  209. metadata +931 -904
  210. data/ext/cargo-vendor/cranelift-bforest-0.103.0/.cargo-checksum.json +0 -1
  211. data/ext/cargo-vendor/cranelift-bforest-0.103.0/Cargo.toml +0 -40
  212. data/ext/cargo-vendor/cranelift-codegen-0.103.0/.cargo-checksum.json +0 -1
  213. data/ext/cargo-vendor/cranelift-codegen-0.103.0/Cargo.toml +0 -175
  214. data/ext/cargo-vendor/cranelift-codegen-0.103.0/build.rs +0 -391
  215. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/isa/aarch64/inst.isle +0 -4193
  216. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/isa/aarch64/lower/isle.rs +0 -874
  217. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/isa/x64/abi.rs +0 -1300
  218. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/isle_prelude.rs +0 -977
  219. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/machinst/isle.rs +0 -896
  220. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/machinst/mod.rs +0 -557
  221. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/machinst/pcc.rs +0 -160
  222. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts/arithmetic.isle +0 -152
  223. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts/bitops.isle +0 -198
  224. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts/cprop.isle +0 -237
  225. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts/extends.isle +0 -34
  226. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts/icmp.isle +0 -199
  227. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts/selects.isle +0 -76
  228. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts/shifts.isle +0 -310
  229. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/opts.rs +0 -172
  230. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/prelude.isle +0 -649
  231. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/prelude_lower.isle +0 -1061
  232. data/ext/cargo-vendor/cranelift-codegen-0.103.0/src/prelude_opt.isle +0 -58
  233. data/ext/cargo-vendor/cranelift-codegen-meta-0.103.0/.cargo-checksum.json +0 -1
  234. data/ext/cargo-vendor/cranelift-codegen-meta-0.103.0/Cargo.toml +0 -35
  235. data/ext/cargo-vendor/cranelift-codegen-shared-0.103.0/.cargo-checksum.json +0 -1
  236. data/ext/cargo-vendor/cranelift-codegen-shared-0.103.0/Cargo.toml +0 -22
  237. data/ext/cargo-vendor/cranelift-control-0.103.0/.cargo-checksum.json +0 -1
  238. data/ext/cargo-vendor/cranelift-control-0.103.0/Cargo.toml +0 -30
  239. data/ext/cargo-vendor/cranelift-entity-0.103.0/.cargo-checksum.json +0 -1
  240. data/ext/cargo-vendor/cranelift-entity-0.103.0/Cargo.toml +0 -50
  241. data/ext/cargo-vendor/cranelift-entity-0.103.0/src/primary.rs +0 -516
  242. data/ext/cargo-vendor/cranelift-frontend-0.103.0/.cargo-checksum.json +0 -1
  243. data/ext/cargo-vendor/cranelift-frontend-0.103.0/Cargo.toml +0 -68
  244. data/ext/cargo-vendor/cranelift-isle-0.103.0/.cargo-checksum.json +0 -1
  245. data/ext/cargo-vendor/cranelift-isle-0.103.0/Cargo.toml +0 -46
  246. data/ext/cargo-vendor/cranelift-native-0.103.0/.cargo-checksum.json +0 -1
  247. data/ext/cargo-vendor/cranelift-native-0.103.0/Cargo.toml +0 -43
  248. data/ext/cargo-vendor/cranelift-wasm-0.103.0/.cargo-checksum.json +0 -1
  249. data/ext/cargo-vendor/cranelift-wasm-0.103.0/Cargo.toml +0 -106
  250. data/ext/cargo-vendor/cranelift-wasm-0.103.0/src/code_translator.rs +0 -3646
  251. data/ext/cargo-vendor/wasi-cap-std-sync-16.0.0/.cargo-checksum.json +0 -1
  252. data/ext/cargo-vendor/wasi-cap-std-sync-16.0.0/Cargo.toml +0 -102
  253. data/ext/cargo-vendor/wasi-common-16.0.0/.cargo-checksum.json +0 -1
  254. data/ext/cargo-vendor/wasi-common-16.0.0/Cargo.toml +0 -131
  255. data/ext/cargo-vendor/wasi-common-16.0.0/src/error.rs +0 -26
  256. data/ext/cargo-vendor/wasi-common-16.0.0/src/snapshots/preview_1/error.rs +0 -265
  257. data/ext/cargo-vendor/wasmtime-16.0.0/.cargo-checksum.json +0 -1
  258. data/ext/cargo-vendor/wasmtime-16.0.0/Cargo.toml +0 -211
  259. data/ext/cargo-vendor/wasmtime-16.0.0/src/component/component.rs +0 -505
  260. data/ext/cargo-vendor/wasmtime-16.0.0/src/component/instance.rs +0 -797
  261. data/ext/cargo-vendor/wasmtime-16.0.0/src/component/linker.rs +0 -523
  262. data/ext/cargo-vendor/wasmtime-16.0.0/src/component/matching.rs +0 -215
  263. data/ext/cargo-vendor/wasmtime-16.0.0/src/component/mod.rs +0 -349
  264. data/ext/cargo-vendor/wasmtime-16.0.0/src/component/resources.rs +0 -725
  265. data/ext/cargo-vendor/wasmtime-16.0.0/src/config.rs +0 -2422
  266. data/ext/cargo-vendor/wasmtime-16.0.0/src/func/typed.rs +0 -638
  267. data/ext/cargo-vendor/wasmtime-16.0.0/src/lib.rs +0 -520
  268. data/ext/cargo-vendor/wasmtime-16.0.0/src/store.rs +0 -2388
  269. data/ext/cargo-vendor/wasmtime-asm-macros-16.0.0/.cargo-checksum.json +0 -1
  270. data/ext/cargo-vendor/wasmtime-asm-macros-16.0.0/Cargo.toml +0 -22
  271. data/ext/cargo-vendor/wasmtime-cache-16.0.0/.cargo-checksum.json +0 -1
  272. data/ext/cargo-vendor/wasmtime-cache-16.0.0/Cargo.toml +0 -81
  273. data/ext/cargo-vendor/wasmtime-component-macro-16.0.0/.cargo-checksum.json +0 -1
  274. data/ext/cargo-vendor/wasmtime-component-macro-16.0.0/Cargo.toml +0 -67
  275. data/ext/cargo-vendor/wasmtime-component-macro-16.0.0/src/bindgen.rs +0 -371
  276. data/ext/cargo-vendor/wasmtime-component-macro-16.0.0/tests/codegen/multiversion/root.wit +0 -7
  277. data/ext/cargo-vendor/wasmtime-component-util-16.0.0/.cargo-checksum.json +0 -1
  278. data/ext/cargo-vendor/wasmtime-component-util-16.0.0/Cargo.toml +0 -25
  279. data/ext/cargo-vendor/wasmtime-cranelift-16.0.0/.cargo-checksum.json +0 -1
  280. data/ext/cargo-vendor/wasmtime-cranelift-16.0.0/Cargo.toml +0 -112
  281. data/ext/cargo-vendor/wasmtime-cranelift-shared-16.0.0/.cargo-checksum.json +0 -1
  282. data/ext/cargo-vendor/wasmtime-cranelift-shared-16.0.0/Cargo.toml +0 -71
  283. data/ext/cargo-vendor/wasmtime-environ-16.0.0/.cargo-checksum.json +0 -1
  284. data/ext/cargo-vendor/wasmtime-environ-16.0.0/Cargo.lock +0 -660
  285. data/ext/cargo-vendor/wasmtime-environ-16.0.0/Cargo.toml +0 -125
  286. data/ext/cargo-vendor/wasmtime-environ-16.0.0/examples/factc.rs +0 -205
  287. data/ext/cargo-vendor/wasmtime-fiber-16.0.0/.cargo-checksum.json +0 -1
  288. data/ext/cargo-vendor/wasmtime-fiber-16.0.0/Cargo.toml +0 -63
  289. data/ext/cargo-vendor/wasmtime-jit-16.0.0/.cargo-checksum.json +0 -1
  290. data/ext/cargo-vendor/wasmtime-jit-16.0.0/Cargo.toml +0 -125
  291. data/ext/cargo-vendor/wasmtime-jit-debug-16.0.0/.cargo-checksum.json +0 -1
  292. data/ext/cargo-vendor/wasmtime-jit-debug-16.0.0/Cargo.toml +0 -67
  293. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-16.0.0/.cargo-checksum.json +0 -1
  294. data/ext/cargo-vendor/wasmtime-jit-icache-coherence-16.0.0/Cargo.toml +0 -46
  295. data/ext/cargo-vendor/wasmtime-runtime-16.0.0/.cargo-checksum.json +0 -1
  296. data/ext/cargo-vendor/wasmtime-runtime-16.0.0/Cargo.toml +0 -139
  297. data/ext/cargo-vendor/wasmtime-runtime-16.0.0/src/instance/allocator/pooling/memory_pool.rs +0 -1005
  298. data/ext/cargo-vendor/wasmtime-runtime-16.0.0/src/instance/allocator/pooling.rs +0 -698
  299. data/ext/cargo-vendor/wasmtime-runtime-16.0.0/src/memory.rs +0 -968
  300. data/ext/cargo-vendor/wasmtime-runtime-16.0.0/src/parking_spot.rs +0 -520
  301. data/ext/cargo-vendor/wasmtime-runtime-16.0.0/src/sys/windows/mmap.rs +0 -211
  302. data/ext/cargo-vendor/wasmtime-types-16.0.0/.cargo-checksum.json +0 -1
  303. data/ext/cargo-vendor/wasmtime-types-16.0.0/Cargo.toml +0 -36
  304. data/ext/cargo-vendor/wasmtime-versioned-export-macros-16.0.0/.cargo-checksum.json +0 -1
  305. data/ext/cargo-vendor/wasmtime-versioned-export-macros-16.0.0/Cargo.toml +0 -32
  306. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/.cargo-checksum.json +0 -1
  307. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/Cargo.toml +0 -261
  308. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/ctx.rs +0 -325
  309. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/filesystem.rs +0 -326
  310. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/host/clocks.rs +0 -103
  311. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/host/filesystem.rs +0 -1069
  312. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/host/instance_network.rs +0 -15
  313. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/host/network.rs +0 -570
  314. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/host/tcp.rs +0 -632
  315. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/host/udp.rs +0 -550
  316. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/mod.rs +0 -328
  317. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/network.rs +0 -57
  318. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/poll.rs +0 -175
  319. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/preview1.rs +0 -2348
  320. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/stream.rs +0 -182
  321. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/table.rs +0 -337
  322. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/tcp.rs +0 -338
  323. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/src/preview2/udp.rs +0 -118
  324. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/tests/all/api.rs +0 -218
  325. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/tests/all/async_.rs +0 -360
  326. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/tests/all/main.rs +0 -113
  327. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/tests/all/preview1.rs +0 -239
  328. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/tests/all/sync.rs +0 -299
  329. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/command-extended.wit +0 -6
  330. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/cli/command.wit +0 -7
  331. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/cli/imports.wit +0 -20
  332. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/cli/stdio.wit +0 -17
  333. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/cli/terminal.wit +0 -47
  334. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/clocks/monotonic-clock.wit +0 -45
  335. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/clocks/wall-clock.wit +0 -42
  336. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/clocks/world.wit +0 -6
  337. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/filesystem/preopens.wit +0 -8
  338. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/filesystem/types.wit +0 -634
  339. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/filesystem/world.wit +0 -6
  340. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/http/proxy.wit +0 -32
  341. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/http/types.wit +0 -570
  342. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/io/error.wit +0 -34
  343. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/io/poll.wit +0 -41
  344. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/io/streams.wit +0 -251
  345. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/io/world.wit +0 -6
  346. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/random/insecure-seed.wit +0 -25
  347. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/random/insecure.wit +0 -22
  348. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/random/random.wit +0 -26
  349. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/random/world.wit +0 -7
  350. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/sockets/ip-name-lookup.wit +0 -51
  351. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/sockets/network.wit +0 -147
  352. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/sockets/tcp-create-socket.wit +0 -26
  353. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/sockets/tcp.wit +0 -321
  354. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/sockets/udp-create-socket.wit +0 -26
  355. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/sockets/udp.wit +0 -277
  356. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/deps/sockets/world.wit +0 -11
  357. data/ext/cargo-vendor/wasmtime-wasi-16.0.0/wit/test.wit +0 -22
  358. data/ext/cargo-vendor/wasmtime-winch-16.0.0/.cargo-checksum.json +0 -1
  359. data/ext/cargo-vendor/wasmtime-winch-16.0.0/Cargo.toml +0 -77
  360. data/ext/cargo-vendor/wasmtime-wit-bindgen-16.0.0/.cargo-checksum.json +0 -1
  361. data/ext/cargo-vendor/wasmtime-wit-bindgen-16.0.0/Cargo.toml +0 -41
  362. data/ext/cargo-vendor/wasmtime-wit-bindgen-16.0.0/src/lib.rs +0 -2095
  363. data/ext/cargo-vendor/wasmtime-wmemcheck-16.0.0/.cargo-checksum.json +0 -1
  364. data/ext/cargo-vendor/wasmtime-wmemcheck-16.0.0/Cargo.toml +0 -29
  365. data/ext/cargo-vendor/wiggle-16.0.0/.cargo-checksum.json +0 -1
  366. data/ext/cargo-vendor/wiggle-16.0.0/Cargo.toml +0 -115
  367. data/ext/cargo-vendor/wiggle-generate-16.0.0/.cargo-checksum.json +0 -1
  368. data/ext/cargo-vendor/wiggle-generate-16.0.0/Cargo.toml +0 -65
  369. data/ext/cargo-vendor/wiggle-macro-16.0.0/.cargo-checksum.json +0 -1
  370. data/ext/cargo-vendor/wiggle-macro-16.0.0/Cargo.toml +0 -55
  371. data/ext/cargo-vendor/winch-codegen-0.14.0/.cargo-checksum.json +0 -1
  372. data/ext/cargo-vendor/winch-codegen-0.14.0/Cargo.toml +0 -76
  373. data/ext/cargo-vendor/winch-codegen-0.14.0/src/codegen/context.rs +0 -545
  374. data/ext/cargo-vendor/winch-codegen-0.14.0/src/codegen/env.rs +0 -251
  375. data/ext/cargo-vendor/winch-codegen-0.14.0/src/isa/aarch64/masm.rs +0 -444
  376. data/ext/cargo-vendor/winch-codegen-0.14.0/src/isa/x64/asm.rs +0 -1117
  377. data/ext/cargo-vendor/winch-codegen-0.14.0/src/isa/x64/masm.rs +0 -994
  378. data/ext/cargo-vendor/winch-codegen-0.14.0/src/masm.rs +0 -679
  379. data/ext/cargo-vendor/winch-codegen-0.14.0/src/stack.rs +0 -436
  380. data/ext/cargo-vendor/winch-codegen-0.14.0/src/visitor.rs +0 -1383
  381. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/LICENSE +0 -0
  382. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/README.md +0 -0
  383. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/src/lib.rs +0 -0
  384. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/src/map.rs +0 -0
  385. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/src/node.rs +0 -0
  386. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/src/path.rs +0 -0
  387. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/src/pool.rs +0 -0
  388. /data/ext/cargo-vendor/{cranelift-bforest-0.103.0 → cranelift-bforest-0.104.0}/src/set.rs +0 -0
  389. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/LICENSE +0 -0
  390. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/README.md +0 -0
  391. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/benches/x64-evex-encoding.rs +0 -0
  392. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/alias_analysis.rs +0 -0
  393. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/binemit/mod.rs +0 -0
  394. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/binemit/stack_map.rs +0 -0
  395. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/bitset.rs +0 -0
  396. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/cfg_printer.rs +0 -0
  397. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/constant_hash.rs +0 -0
  398. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/context.rs +0 -0
  399. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ctxhash.rs +0 -0
  400. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/cursor.rs +0 -0
  401. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/data_value.rs +0 -0
  402. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/dbg.rs +0 -0
  403. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/dce.rs +0 -0
  404. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/dominator_tree.rs +0 -0
  405. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/egraph/cost.rs +0 -0
  406. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/egraph/domtree.rs +0 -0
  407. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/egraph/elaborate.rs +0 -0
  408. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/egraph.rs +0 -0
  409. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/flowgraph.rs +0 -0
  410. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/fx.rs +0 -0
  411. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/incremental_cache.rs +0 -0
  412. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/inst_predicates.rs +0 -0
  413. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/atomic_rmw_op.rs +0 -0
  414. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/builder.rs +0 -0
  415. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/condcodes.rs +0 -0
  416. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/constant.rs +0 -0
  417. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/dfg.rs +0 -0
  418. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/dynamic_type.rs +0 -0
  419. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/entities.rs +0 -0
  420. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/extfunc.rs +0 -0
  421. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/extname.rs +0 -0
  422. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/function.rs +0 -0
  423. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/globalvalue.rs +0 -0
  424. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/immediates.rs +0 -0
  425. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/instructions.rs +0 -0
  426. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/jumptable.rs +0 -0
  427. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/known_symbol.rs +0 -0
  428. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/layout.rs +0 -0
  429. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/libcall.rs +0 -0
  430. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/memflags.rs +0 -0
  431. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/memtype.rs +0 -0
  432. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/mod.rs +0 -0
  433. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/pcc.rs +0 -0
  434. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/progpoint.rs +0 -0
  435. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/sourceloc.rs +0 -0
  436. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/stackslot.rs +0 -0
  437. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/table.rs +0 -0
  438. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/trapcode.rs +0 -0
  439. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/ir/types.rs +0 -0
  440. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/abi.rs +0 -0
  441. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/args.rs +0 -0
  442. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/emit.rs +0 -0
  443. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/emit_tests.rs +0 -0
  444. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/imms.rs +0 -0
  445. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/mod.rs +0 -0
  446. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/regs.rs +0 -0
  447. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/unwind/systemv.rs +0 -0
  448. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst/unwind.rs +0 -0
  449. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/inst_neon.isle +0 -0
  450. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/lower/isle/generated_code.rs +0 -0
  451. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/lower.isle +0 -0
  452. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/lower.rs +0 -0
  453. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/lower_dynamic_neon.isle +0 -0
  454. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/mod.rs +0 -0
  455. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/pcc.rs +0 -0
  456. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/aarch64/settings.rs +0 -0
  457. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/call_conv.rs +0 -0
  458. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/mod.rs +0 -0
  459. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/abi.rs +0 -0
  460. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/args.rs +0 -0
  461. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/emit.rs +0 -0
  462. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/emit_tests.rs +0 -0
  463. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/encode.rs +0 -0
  464. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/imms.rs +0 -0
  465. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/mod.rs +0 -0
  466. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/regs.rs +0 -0
  467. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/unwind/systemv.rs +0 -0
  468. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/unwind.rs +0 -0
  469. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst/vector.rs +0 -0
  470. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst.isle +0 -0
  471. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/inst_vector.isle +0 -0
  472. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/lower/isle/generated_code.rs +0 -0
  473. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/lower/isle.rs +0 -0
  474. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/lower.isle +0 -0
  475. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/lower.rs +0 -0
  476. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/mod.rs +0 -0
  477. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/riscv64/settings.rs +0 -0
  478. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/abi.rs +0 -0
  479. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/args.rs +0 -0
  480. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/emit.rs +0 -0
  481. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/emit_tests.rs +0 -0
  482. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/imms.rs +0 -0
  483. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/mod.rs +0 -0
  484. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/regs.rs +0 -0
  485. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/unwind/systemv.rs +0 -0
  486. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst/unwind.rs +0 -0
  487. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/inst.isle +0 -0
  488. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/lower/isle/generated_code.rs +0 -0
  489. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/lower/isle.rs +0 -0
  490. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/lower.isle +0 -0
  491. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/lower.rs +0 -0
  492. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/mod.rs +0 -0
  493. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/s390x/settings.rs +0 -0
  494. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/unwind/systemv.rs +0 -0
  495. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/unwind/winx64.rs +0 -0
  496. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/unwind.rs +0 -0
  497. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/encoding/evex.rs +0 -0
  498. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/encoding/mod.rs +0 -0
  499. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/encoding/rex.rs +0 -0
  500. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/encoding/vex.rs +0 -0
  501. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/args.rs +0 -0
  502. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/emit.rs +0 -0
  503. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/emit_state.rs +0 -0
  504. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/emit_tests.rs +0 -0
  505. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/mod.rs +0 -0
  506. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/regs.rs +0 -0
  507. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/unwind/systemv.rs +0 -0
  508. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/unwind/winx64.rs +0 -0
  509. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst/unwind.rs +0 -0
  510. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/inst.isle +0 -0
  511. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/lower/isle/generated_code.rs +0 -0
  512. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/lower/isle.rs +0 -0
  513. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/lower.isle +0 -0
  514. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/lower.rs +0 -0
  515. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/mod.rs +0 -0
  516. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/pcc.rs +0 -0
  517. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/isa/x64/settings.rs +0 -0
  518. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/iterators.rs +0 -0
  519. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/legalizer/globalvalue.rs +0 -0
  520. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/legalizer/mod.rs +0 -0
  521. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/legalizer/table.rs +0 -0
  522. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/lib.rs +0 -0
  523. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/loop_analysis.rs +0 -0
  524. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/abi.rs +0 -0
  525. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/blockorder.rs +0 -0
  526. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/buffer.rs +0 -0
  527. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/compile.rs +0 -0
  528. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/helpers.rs +0 -0
  529. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/inst_common.rs +0 -0
  530. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/lower.rs +0 -0
  531. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/reg.rs +0 -0
  532. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/valueregs.rs +0 -0
  533. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/machinst/vcode.rs +0 -0
  534. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/nan_canonicalization.rs +0 -0
  535. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/opts/README.md +0 -0
  536. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/opts/generated_code.rs +0 -0
  537. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/opts/remat.isle +0 -0
  538. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/opts/vector.isle +0 -0
  539. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/print_errors.rs +0 -0
  540. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/remove_constant_phis.rs +0 -0
  541. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/result.rs +0 -0
  542. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/scoped_hash_map.rs +0 -0
  543. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/settings.rs +0 -0
  544. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/souper_harvest.rs +0 -0
  545. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/timing.rs +0 -0
  546. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/unionfind.rs +0 -0
  547. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/unreachable_code.rs +0 -0
  548. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/value_label.rs +0 -0
  549. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/verifier/mod.rs +0 -0
  550. /data/ext/cargo-vendor/{cranelift-codegen-0.103.0 → cranelift-codegen-0.104.0}/src/write.rs +0 -0
  551. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/LICENSE +0 -0
  552. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/README.md +0 -0
  553. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/formats.rs +0 -0
  554. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/instructions.rs +0 -0
  555. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/isa.rs +0 -0
  556. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/mod.rs +0 -0
  557. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/operands.rs +0 -0
  558. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/settings.rs +0 -0
  559. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/types.rs +0 -0
  560. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/cdsl/typevar.rs +0 -0
  561. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/constant_hash.rs +0 -0
  562. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/error.rs +0 -0
  563. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/gen_inst.rs +0 -0
  564. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/gen_settings.rs +0 -0
  565. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/gen_types.rs +0 -0
  566. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/isa/arm64.rs +0 -0
  567. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/isa/mod.rs +0 -0
  568. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/isa/riscv64.rs +0 -0
  569. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/isa/s390x.rs +0 -0
  570. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/isa/x86.rs +0 -0
  571. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/lib.rs +0 -0
  572. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/shared/entities.rs +0 -0
  573. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/shared/formats.rs +0 -0
  574. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/shared/immediates.rs +0 -0
  575. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/shared/instructions.rs +0 -0
  576. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/shared/mod.rs +0 -0
  577. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/shared/settings.rs +0 -0
  578. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/shared/types.rs +0 -0
  579. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/srcgen.rs +0 -0
  580. /data/ext/cargo-vendor/{cranelift-codegen-meta-0.103.0 → cranelift-codegen-meta-0.104.0}/src/unique_table.rs +0 -0
  581. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.103.0 → cranelift-codegen-shared-0.104.0}/LICENSE +0 -0
  582. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.103.0 → cranelift-codegen-shared-0.104.0}/README.md +0 -0
  583. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.103.0 → cranelift-codegen-shared-0.104.0}/src/constant_hash.rs +0 -0
  584. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.103.0 → cranelift-codegen-shared-0.104.0}/src/constants.rs +0 -0
  585. /data/ext/cargo-vendor/{cranelift-codegen-shared-0.103.0 → cranelift-codegen-shared-0.104.0}/src/lib.rs +0 -0
  586. /data/ext/cargo-vendor/{cranelift-control-0.103.0 → cranelift-control-0.104.0}/LICENSE +0 -0
  587. /data/ext/cargo-vendor/{cranelift-control-0.103.0 → cranelift-control-0.104.0}/README.md +0 -0
  588. /data/ext/cargo-vendor/{cranelift-control-0.103.0 → cranelift-control-0.104.0}/src/chaos.rs +0 -0
  589. /data/ext/cargo-vendor/{cranelift-control-0.103.0 → cranelift-control-0.104.0}/src/lib.rs +0 -0
  590. /data/ext/cargo-vendor/{cranelift-control-0.103.0 → cranelift-control-0.104.0}/src/zero_sized.rs +0 -0
  591. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/LICENSE +0 -0
  592. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/README.md +0 -0
  593. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/boxed_slice.rs +0 -0
  594. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/iter.rs +0 -0
  595. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/keys.rs +0 -0
  596. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/lib.rs +0 -0
  597. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/list.rs +0 -0
  598. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/map.rs +0 -0
  599. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/packed_option.rs +0 -0
  600. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/set.rs +0 -0
  601. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/sparse.rs +0 -0
  602. /data/ext/cargo-vendor/{cranelift-entity-0.103.0 → cranelift-entity-0.104.0}/src/unsigned.rs +0 -0
  603. /data/ext/cargo-vendor/{cranelift-frontend-0.103.0 → cranelift-frontend-0.104.0}/LICENSE +0 -0
  604. /data/ext/cargo-vendor/{cranelift-frontend-0.103.0 → cranelift-frontend-0.104.0}/README.md +0 -0
  605. /data/ext/cargo-vendor/{cranelift-frontend-0.103.0 → cranelift-frontend-0.104.0}/src/frontend.rs +0 -0
  606. /data/ext/cargo-vendor/{cranelift-frontend-0.103.0 → cranelift-frontend-0.104.0}/src/lib.rs +0 -0
  607. /data/ext/cargo-vendor/{cranelift-frontend-0.103.0 → cranelift-frontend-0.104.0}/src/ssa.rs +0 -0
  608. /data/ext/cargo-vendor/{cranelift-frontend-0.103.0 → cranelift-frontend-0.104.0}/src/switch.rs +0 -0
  609. /data/ext/cargo-vendor/{cranelift-frontend-0.103.0 → cranelift-frontend-0.104.0}/src/variable.rs +0 -0
  610. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/README.md +0 -0
  611. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/build.rs +0 -0
  612. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/bad_converters.isle +0 -0
  613. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/bound_var_type_mismatch.isle +0 -0
  614. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/converter_extractor_constructor.isle +0 -0
  615. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/error1.isle +0 -0
  616. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/extra_parens.isle +0 -0
  617. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/impure_expression.isle +0 -0
  618. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/impure_rhs.isle +0 -0
  619. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/multi_internal_etor.isle +0 -0
  620. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/fail/multi_prio.isle +0 -0
  621. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/borrows.isle +0 -0
  622. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/borrows_main.rs +0 -0
  623. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/iflets.isle +0 -0
  624. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/iflets_main.rs +0 -0
  625. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/multi_constructor.isle +0 -0
  626. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/multi_constructor_main.rs +0 -0
  627. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/multi_extractor.isle +0 -0
  628. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/multi_extractor_main.rs +0 -0
  629. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/test.isle +0 -0
  630. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/link/test_main.rs +0 -0
  631. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/bound_var.isle +0 -0
  632. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/construct_and_extract.isle +0 -0
  633. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/conversions.isle +0 -0
  634. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/conversions_extern.isle +0 -0
  635. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/let.isle +0 -0
  636. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/nodebug.isle +0 -0
  637. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/prio_trie_bug.isle +0 -0
  638. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/test2.isle +0 -0
  639. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/test3.isle +0 -0
  640. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/test4.isle +0 -0
  641. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/pass/tutorial.isle +0 -0
  642. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/run/iconst.isle +0 -0
  643. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/run/iconst_main.rs +0 -0
  644. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/run/let_shadowing.isle +0 -0
  645. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/isle_examples/run/let_shadowing_main.rs +0 -0
  646. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/ast.rs +0 -0
  647. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/codegen.rs +0 -0
  648. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/compile.rs +0 -0
  649. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/error.rs +0 -0
  650. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/lexer.rs +0 -0
  651. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/lib.rs +0 -0
  652. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/log.rs +0 -0
  653. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/overlap.rs +0 -0
  654. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/parser.rs +0 -0
  655. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/sema.rs +0 -0
  656. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/serialize.rs +0 -0
  657. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/src/trie_again.rs +0 -0
  658. /data/ext/cargo-vendor/{cranelift-isle-0.103.0 → cranelift-isle-0.104.0}/tests/run_tests.rs +0 -0
  659. /data/ext/cargo-vendor/{cranelift-native-0.103.0 → cranelift-native-0.104.0}/LICENSE +0 -0
  660. /data/ext/cargo-vendor/{cranelift-native-0.103.0 → cranelift-native-0.104.0}/README.md +0 -0
  661. /data/ext/cargo-vendor/{cranelift-native-0.103.0 → cranelift-native-0.104.0}/src/lib.rs +0 -0
  662. /data/ext/cargo-vendor/{cranelift-native-0.103.0 → cranelift-native-0.104.0}/src/riscv.rs +0 -0
  663. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/LICENSE +0 -0
  664. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/README.md +0 -0
  665. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/code_translator/bounds_checks.rs +0 -0
  666. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/environ/dummy.rs +0 -0
  667. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/environ/mod.rs +0 -0
  668. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/environ/spec.rs +0 -0
  669. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/func_translator.rs +0 -0
  670. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/heap.rs +0 -0
  671. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/lib.rs +0 -0
  672. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/module_translator.rs +0 -0
  673. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/sections_translator.rs +0 -0
  674. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/state.rs +0 -0
  675. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/src/translation_utils.rs +0 -0
  676. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/tests/wasm_testsuite.rs +0 -0
  677. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/arith.wat +0 -0
  678. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/br_table.wat +0 -0
  679. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/call-simd.wat +0 -0
  680. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/call.wat +0 -0
  681. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/embenchen_fannkuch.wat +0 -0
  682. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/embenchen_fasta.wat +0 -0
  683. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/embenchen_ifs.wat +0 -0
  684. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/embenchen_primes.wat +0 -0
  685. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/fac-multi-value.wat +0 -0
  686. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/fibonacci.wat +0 -0
  687. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/globals.wat +0 -0
  688. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/icall-simd.wat +0 -0
  689. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/icall.wat +0 -0
  690. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-reachability-translation-0.wat +0 -0
  691. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-reachability-translation-1.wat +0 -0
  692. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-reachability-translation-2.wat +0 -0
  693. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-reachability-translation-3.wat +0 -0
  694. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-reachability-translation-4.wat +0 -0
  695. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-reachability-translation-5.wat +0 -0
  696. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-reachability-translation-6.wat +0 -0
  697. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-unreachable-else-params-2.wat +0 -0
  698. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/if-unreachable-else-params.wat +0 -0
  699. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/issue-1306-name-section-with-u32-max-function-index.wasm +0 -0
  700. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/memory.wat +0 -0
  701. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-0.wat +0 -0
  702. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-1.wat +0 -0
  703. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-10.wat +0 -0
  704. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-11.wat +0 -0
  705. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-12.wat +0 -0
  706. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-13.wat +0 -0
  707. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-14.wat +0 -0
  708. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-15.wat +0 -0
  709. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-16.wat +0 -0
  710. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-17.wat +0 -0
  711. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-2.wat +0 -0
  712. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-3.wat +0 -0
  713. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-4.wat +0 -0
  714. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-5.wat +0 -0
  715. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-6.wat +0 -0
  716. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-7.wat +0 -0
  717. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-8.wat +0 -0
  718. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/multi-9.wat +0 -0
  719. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/nullref.wat +0 -0
  720. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/passive-data.wat +0 -0
  721. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/pr2303.wat +0 -0
  722. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/pr2559.wat +0 -0
  723. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/ref-func-0.wat +0 -0
  724. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/rust_fannkuch.wat +0 -0
  725. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/select.wat +0 -0
  726. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/simd-store.wat +0 -0
  727. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/simd.wat +0 -0
  728. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/table-copy.wat +0 -0
  729. /data/ext/cargo-vendor/{cranelift-wasm-0.103.0 → cranelift-wasm-0.104.0}/wasmtests/unreachable_code.wat +0 -0
  730. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/LICENSE +0 -0
  731. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/README.md +0 -0
  732. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/clocks.rs +0 -0
  733. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/dir.rs +0 -0
  734. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/file.rs +0 -0
  735. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/lib.rs +0 -0
  736. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/net.rs +0 -0
  737. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/sched/unix.rs +0 -0
  738. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/sched/windows.rs +0 -0
  739. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/sched.rs +0 -0
  740. /data/ext/cargo-vendor/{wasi-cap-std-sync-16.0.0 → wasi-cap-std-sync-17.0.0}/src/stdio.rs +0 -0
  741. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/LICENSE +0 -0
  742. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/README.md +0 -0
  743. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/README.md +0 -0
  744. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/docs/README.md +0 -0
  745. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/README.md +0 -0
  746. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/docs.md +0 -0
  747. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/typenames.witx +0 -0
  748. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_args.witx +0 -0
  749. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_clock.witx +0 -0
  750. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_environ.witx +0 -0
  751. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_fd.witx +0 -0
  752. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_path.witx +0 -0
  753. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_poll.witx +0 -0
  754. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_proc.witx +0 -0
  755. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_random.witx +0 -0
  756. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_sched.witx +0 -0
  757. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/ephemeral/witx/wasi_ephemeral_sock.witx +0 -0
  758. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/old/snapshot_0/docs.md +0 -0
  759. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/old/snapshot_0/witx/typenames.witx +0 -0
  760. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/old/snapshot_0/witx/wasi_unstable.witx +0 -0
  761. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/snapshot/docs.html +0 -0
  762. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/snapshot/docs.md +0 -0
  763. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/snapshot/witx/typenames.witx +0 -0
  764. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/phases/snapshot/witx/wasi_snapshot_preview1.witx +0 -0
  765. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/proposal-template/README.md +0 -0
  766. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/proposals/README.md +0 -0
  767. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/snapshots/README.md +0 -0
  768. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/WASI/standard/README.md +0 -0
  769. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/build.rs +0 -0
  770. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/clocks.rs +0 -0
  771. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/ctx.rs +0 -0
  772. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/dir.rs +0 -0
  773. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/file.rs +0 -0
  774. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/lib.rs +0 -0
  775. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/pipe.rs +0 -0
  776. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/random.rs +0 -0
  777. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/sched/subscription.rs +0 -0
  778. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/sched.rs +0 -0
  779. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/snapshots/mod.rs +0 -0
  780. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/snapshots/preview_0.rs +0 -0
  781. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/snapshots/preview_1.rs +0 -0
  782. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/string_array.rs +0 -0
  783. /data/ext/cargo-vendor/{wasi-common-16.0.0 → wasi-common-17.0.0}/src/table.rs +0 -0
  784. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/LICENSE +0 -0
  785. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/README.md +0 -0
  786. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/code.rs +0 -0
  787. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/compiler.rs +0 -0
  788. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/func/host.rs +0 -0
  789. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/func/options.rs +0 -0
  790. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/func/typed.rs +0 -0
  791. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/func.rs +0 -0
  792. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/storage.rs +0 -0
  793. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/store.rs +0 -0
  794. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/types.rs +0 -0
  795. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/component/values.rs +0 -0
  796. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/coredump.rs +0 -0
  797. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/engine/serialization.rs +0 -0
  798. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/engine.rs +0 -0
  799. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/externals/global.rs +0 -0
  800. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/externals/table.rs +0 -0
  801. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/externals.rs +0 -0
  802. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/func.rs +0 -0
  803. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/instance.rs +0 -0
  804. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/limits.rs +0 -0
  805. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/linker.rs +0 -0
  806. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/memory.rs +0 -0
  807. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/module/registry.rs +0 -0
  808. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/module.rs +0 -0
  809. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/profiling.rs +0 -0
  810. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/ref.rs +0 -0
  811. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/resources.rs +0 -0
  812. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/signatures.rs +0 -0
  813. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/stack.rs +0 -0
  814. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/store/context.rs +0 -0
  815. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/store/data.rs +0 -0
  816. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/store/func_refs.rs +0 -0
  817. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/trampoline/func.rs +0 -0
  818. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/trampoline/global.rs +0 -0
  819. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/trampoline/memory.rs +0 -0
  820. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/trampoline/table.rs +0 -0
  821. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/trampoline.rs +0 -0
  822. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/trap.rs +0 -0
  823. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/types/matching.rs +0 -0
  824. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/types.rs +0 -0
  825. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/unix.rs +0 -0
  826. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/v128.rs +0 -0
  827. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/values.rs +0 -0
  828. /data/ext/cargo-vendor/{wasmtime-16.0.0 → wasmtime-17.0.0}/src/windows.rs +0 -0
  829. /data/ext/cargo-vendor/{wasmtime-asm-macros-16.0.0 → wasmtime-asm-macros-17.0.0}/src/lib.rs +0 -0
  830. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/LICENSE +0 -0
  831. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/build.rs +0 -0
  832. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/src/config/tests.rs +0 -0
  833. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/src/config.rs +0 -0
  834. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/src/lib.rs +0 -0
  835. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/src/tests.rs +0 -0
  836. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/src/worker/tests/system_time_stub.rs +0 -0
  837. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/src/worker/tests.rs +0 -0
  838. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/src/worker.rs +0 -0
  839. /data/ext/cargo-vendor/{wasmtime-cache-16.0.0 → wasmtime-cache-17.0.0}/tests/cache_write_default_config.rs +0 -0
  840. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/src/component.rs +0 -0
  841. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/src/lib.rs +0 -0
  842. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/char.wit +0 -0
  843. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/conventions.wit +0 -0
  844. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/direct-import.wit +0 -0
  845. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/empty.wit +0 -0
  846. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/flags.wit +0 -0
  847. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/floats.wit +0 -0
  848. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/function-new.wit +0 -0
  849. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/integers.wit +0 -0
  850. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/lists.wit +0 -0
  851. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/many-arguments.wit +0 -0
  852. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/multi-return.wit +0 -0
  853. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/multiversion/deps/v1/root.wit +0 -0
  854. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/multiversion/deps/v2/root.wit +0 -0
  855. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/records.wit +0 -0
  856. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/rename.wit +0 -0
  857. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/resources-export.wit +0 -0
  858. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/resources-import.wit +0 -0
  859. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/share-types.wit +0 -0
  860. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/simple-functions.wit +0 -0
  861. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/simple-lists.wit +0 -0
  862. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/simple-wasi.wit +0 -0
  863. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/small-anonymous.wit +0 -0
  864. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/smoke-default.wit +0 -0
  865. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/smoke-export.wit +0 -0
  866. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/smoke.wit +0 -0
  867. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/strings.wit +0 -0
  868. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/use-paths.wit +0 -0
  869. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/variants.wit +0 -0
  870. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen/worlds-with-types.wit +0 -0
  871. /data/ext/cargo-vendor/{wasmtime-component-macro-16.0.0 → wasmtime-component-macro-17.0.0}/tests/codegen.rs +0 -0
  872. /data/ext/cargo-vendor/{wasmtime-component-util-16.0.0 → wasmtime-component-util-17.0.0}/src/lib.rs +0 -0
  873. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/LICENSE +0 -0
  874. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/SECURITY.md +0 -0
  875. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/builder.rs +0 -0
  876. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/compiler/component.rs +0 -0
  877. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/compiler.rs +0 -0
  878. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/gc.rs +0 -0
  879. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/address_transform.rs +0 -0
  880. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/attr.rs +0 -0
  881. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/expression.rs +0 -0
  882. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/line_program.rs +0 -0
  883. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/mod.rs +0 -0
  884. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/range_info_builder.rs +0 -0
  885. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/refs.rs +0 -0
  886. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/simulate.rs +0 -0
  887. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/unit.rs +0 -0
  888. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/transform/utils.rs +0 -0
  889. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug/write_debuginfo.rs +0 -0
  890. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/debug.rs +0 -0
  891. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/func_environ.rs +0 -0
  892. /data/ext/cargo-vendor/{wasmtime-cranelift-16.0.0 → wasmtime-cranelift-17.0.0}/src/lib.rs +0 -0
  893. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-16.0.0 → wasmtime-cranelift-shared-17.0.0}/src/compiled_function.rs +0 -0
  894. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-16.0.0 → wasmtime-cranelift-shared-17.0.0}/src/isa_builder.rs +0 -0
  895. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-16.0.0 → wasmtime-cranelift-shared-17.0.0}/src/lib.rs +0 -0
  896. /data/ext/cargo-vendor/{wasmtime-cranelift-shared-16.0.0 → wasmtime-cranelift-shared-17.0.0}/src/obj.rs +0 -0
  897. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/LICENSE +0 -0
  898. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/address_map.rs +0 -0
  899. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/builtin.rs +0 -0
  900. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/compilation.rs +0 -0
  901. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/compiler.rs +0 -0
  902. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/dfg.rs +0 -0
  903. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/info.rs +0 -0
  904. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/translate/adapt.rs +0 -0
  905. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/translate/inline.rs +0 -0
  906. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/translate.rs +0 -0
  907. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/types/resources.rs +0 -0
  908. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/types.rs +0 -0
  909. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component/vmcomponent_offsets.rs +0 -0
  910. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/component.rs +0 -0
  911. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/fact/core_types.rs +0 -0
  912. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/fact/signature.rs +0 -0
  913. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/fact/trampoline.rs +0 -0
  914. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/fact/transcode.rs +0 -0
  915. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/fact/traps.rs +0 -0
  916. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/fact.rs +0 -0
  917. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/lib.rs +0 -0
  918. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/module.rs +0 -0
  919. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/module_environ.rs +0 -0
  920. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/module_types.rs +0 -0
  921. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/obj.rs +0 -0
  922. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/ref_bits.rs +0 -0
  923. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/scopevec.rs +0 -0
  924. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/stack_map.rs +0 -0
  925. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/trap_encoding.rs +0 -0
  926. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/tunables.rs +0 -0
  927. /data/ext/cargo-vendor/{wasmtime-environ-16.0.0 → wasmtime-environ-17.0.0}/src/vmoffsets.rs +0 -0
  928. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/LICENSE +0 -0
  929. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/build.rs +0 -0
  930. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/lib.rs +0 -0
  931. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/unix/aarch64.rs +0 -0
  932. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/unix/arm.rs +0 -0
  933. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/unix/riscv64.rs +0 -0
  934. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/unix/s390x.S +0 -0
  935. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/unix/x86.rs +0 -0
  936. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/unix/x86_64.rs +0 -0
  937. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/unix.rs +0 -0
  938. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/windows.c +0 -0
  939. /data/ext/cargo-vendor/{wasmtime-fiber-16.0.0 → wasmtime-fiber-17.0.0}/src/windows.rs +0 -0
  940. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/LICENSE +0 -0
  941. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/code_memory.rs +0 -0
  942. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/debug.rs +0 -0
  943. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/demangling.rs +0 -0
  944. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/instantiate.rs +0 -0
  945. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/lib.rs +0 -0
  946. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/profiling/jitdump.rs +0 -0
  947. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/profiling/perfmap.rs +0 -0
  948. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/profiling/vtune.rs +0 -0
  949. /data/ext/cargo-vendor/{wasmtime-jit-16.0.0 → wasmtime-jit-17.0.0}/src/profiling.rs +0 -0
  950. /data/ext/cargo-vendor/{wasmtime-jit-debug-16.0.0 → wasmtime-jit-debug-17.0.0}/README.md +0 -0
  951. /data/ext/cargo-vendor/{wasmtime-jit-debug-16.0.0 → wasmtime-jit-debug-17.0.0}/src/gdb_jit_int.rs +0 -0
  952. /data/ext/cargo-vendor/{wasmtime-jit-debug-16.0.0 → wasmtime-jit-debug-17.0.0}/src/lib.rs +0 -0
  953. /data/ext/cargo-vendor/{wasmtime-jit-debug-16.0.0 → wasmtime-jit-debug-17.0.0}/src/perf_jitdump.rs +0 -0
  954. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-16.0.0 → wasmtime-jit-icache-coherence-17.0.0}/src/lib.rs +0 -0
  955. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-16.0.0 → wasmtime-jit-icache-coherence-17.0.0}/src/libc.rs +0 -0
  956. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-16.0.0 → wasmtime-jit-icache-coherence-17.0.0}/src/miri.rs +0 -0
  957. /data/ext/cargo-vendor/{wasmtime-jit-icache-coherence-16.0.0 → wasmtime-jit-icache-coherence-17.0.0}/src/win.rs +0 -0
  958. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/LICENSE +0 -0
  959. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/build.rs +0 -0
  960. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/proptest-regressions/instance/allocator/pooling/memory_pool.txt +0 -0
  961. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/arch/aarch64.rs +0 -0
  962. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/arch/mod.rs +0 -0
  963. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/arch/riscv64.rs +0 -0
  964. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/arch/s390x.S +0 -0
  965. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/arch/s390x.rs +0 -0
  966. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/arch/x86_64.rs +0 -0
  967. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/component/libcalls.rs +0 -0
  968. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/component/resources.rs +0 -0
  969. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/component.rs +0 -0
  970. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/cow.rs +0 -0
  971. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/debug_builtins.rs +0 -0
  972. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/export.rs +0 -0
  973. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/externref.rs +0 -0
  974. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/helpers.c +0 -0
  975. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/imports.rs +0 -0
  976. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/instance/allocator/on_demand.rs +0 -0
  977. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/instance/allocator/pooling/index_allocator.rs +0 -0
  978. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/instance/allocator/pooling/stack_pool.rs +0 -0
  979. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/instance/allocator/pooling/table_pool.rs +0 -0
  980. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/instance/allocator.rs +0 -0
  981. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/instance.rs +0 -0
  982. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/lib.rs +0 -0
  983. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/libcalls.rs +0 -0
  984. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/mmap.rs +0 -0
  985. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/mmap_vec.rs +0 -0
  986. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/module_id.rs +0 -0
  987. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/mpk/disabled.rs +0 -0
  988. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/mpk/enabled.rs +0 -0
  989. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/mpk/mod.rs +0 -0
  990. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/mpk/pkru.rs +0 -0
  991. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/mpk/sys.rs +0 -0
  992. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/send_sync_ptr.rs +0 -0
  993. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/store_box.rs +0 -0
  994. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/miri/mmap.rs +0 -0
  995. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/miri/mod.rs +0 -0
  996. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/miri/traphandlers.rs +0 -0
  997. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/miri/unwind.rs +0 -0
  998. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/miri/vm.rs +0 -0
  999. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/mod.rs +0 -0
  1000. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/unix/machports.rs +0 -0
  1001. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/unix/macos_traphandlers.rs +0 -0
  1002. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/unix/mmap.rs +0 -0
  1003. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/unix/mod.rs +0 -0
  1004. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/unix/signals.rs +0 -0
  1005. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/unix/unwind.rs +0 -0
  1006. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/unix/vm.rs +0 -0
  1007. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/windows/mod.rs +0 -0
  1008. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/windows/traphandlers.rs +0 -0
  1009. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/windows/unwind.rs +0 -0
  1010. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/sys/windows/vm.rs +0 -0
  1011. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/table.rs +0 -0
  1012. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/traphandlers/backtrace.rs +0 -0
  1013. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/traphandlers/coredump.rs +0 -0
  1014. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/traphandlers.rs +0 -0
  1015. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/vmcontext/vm_host_func_context.rs +0 -0
  1016. /data/ext/cargo-vendor/{wasmtime-runtime-16.0.0 → wasmtime-runtime-17.0.0}/src/vmcontext.rs +0 -0
  1017. /data/ext/cargo-vendor/{wasmtime-types-16.0.0 → wasmtime-types-17.0.0}/LICENSE +0 -0
  1018. /data/ext/cargo-vendor/{wasmtime-types-16.0.0 → wasmtime-types-17.0.0}/src/error.rs +0 -0
  1019. /data/ext/cargo-vendor/{wasmtime-types-16.0.0 → wasmtime-types-17.0.0}/src/lib.rs +0 -0
  1020. /data/ext/cargo-vendor/{wasmtime-versioned-export-macros-16.0.0 → wasmtime-versioned-export-macros-17.0.0}/src/lib.rs +0 -0
  1021. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/LICENSE +0 -0
  1022. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/README.md +0 -0
  1023. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/build.rs +0 -0
  1024. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/lib.rs +0 -0
  1025. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/clocks/host.rs +0 -0
  1026. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/clocks.rs +0 -0
  1027. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/command.rs +0 -0
  1028. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/error.rs +0 -0
  1029. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/env.rs +0 -0
  1030. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/exit.rs +0 -0
  1031. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/filesystem/sync.rs +0 -0
  1032. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/io.rs +0 -0
  1033. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/mod.rs +0 -0
  1034. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/random.rs +0 -0
  1035. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/tcp_create_socket.rs +0 -0
  1036. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/host/udp_create_socket.rs +0 -0
  1037. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/ip_name_lookup.rs +0 -0
  1038. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/pipe.rs +0 -0
  1039. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/preview0.rs +0 -0
  1040. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/random.rs +0 -0
  1041. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/stdio/worker_thread_stdin.rs +0 -0
  1042. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/stdio.rs +0 -0
  1043. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/src/preview2/write_stream.rs +0 -0
  1044. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/tests/process_stdin.rs +0 -0
  1045. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/wit/deps/cli/environment.wit +0 -0
  1046. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/wit/deps/cli/exit.wit +0 -0
  1047. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/wit/deps/cli/run.wit +0 -0
  1048. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/wit/deps/http/handler.wit +0 -0
  1049. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/wit/deps/sockets/instance-network.wit +0 -0
  1050. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/witx/preview0/typenames.witx +0 -0
  1051. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/witx/preview0/wasi_unstable.witx +0 -0
  1052. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/witx/preview1/typenames.witx +0 -0
  1053. /data/ext/cargo-vendor/{wasmtime-wasi-16.0.0 → wasmtime-wasi-17.0.0}/witx/preview1/wasi_snapshot_preview1.witx +0 -0
  1054. /data/ext/cargo-vendor/{wasmtime-winch-16.0.0 → wasmtime-winch-17.0.0}/LICENSE +0 -0
  1055. /data/ext/cargo-vendor/{wasmtime-winch-16.0.0 → wasmtime-winch-17.0.0}/src/builder.rs +0 -0
  1056. /data/ext/cargo-vendor/{wasmtime-winch-16.0.0 → wasmtime-winch-17.0.0}/src/compiler.rs +0 -0
  1057. /data/ext/cargo-vendor/{wasmtime-winch-16.0.0 → wasmtime-winch-17.0.0}/src/lib.rs +0 -0
  1058. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-16.0.0 → wasmtime-wit-bindgen-17.0.0}/src/rust.rs +0 -0
  1059. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-16.0.0 → wasmtime-wit-bindgen-17.0.0}/src/source.rs +0 -0
  1060. /data/ext/cargo-vendor/{wasmtime-wit-bindgen-16.0.0 → wasmtime-wit-bindgen-17.0.0}/src/types.rs +0 -0
  1061. /data/ext/cargo-vendor/{wasmtime-wmemcheck-16.0.0 → wasmtime-wmemcheck-17.0.0}/src/lib.rs +0 -0
  1062. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/LICENSE +0 -0
  1063. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/README.md +0 -0
  1064. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/src/borrow.rs +0 -0
  1065. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/src/error.rs +0 -0
  1066. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/src/guest_type.rs +0 -0
  1067. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/src/lib.rs +0 -0
  1068. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/src/region.rs +0 -0
  1069. /data/ext/cargo-vendor/{wiggle-16.0.0 → wiggle-17.0.0}/src/wasmtime.rs +0 -0
  1070. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/LICENSE +0 -0
  1071. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/README.md +0 -0
  1072. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/codegen_settings.rs +0 -0
  1073. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/config.rs +0 -0
  1074. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/funcs.rs +0 -0
  1075. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/lib.rs +0 -0
  1076. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/lifetimes.rs +0 -0
  1077. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/module_trait.rs +0 -0
  1078. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/names.rs +0 -0
  1079. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/types/error.rs +0 -0
  1080. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/types/flags.rs +0 -0
  1081. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/types/handle.rs +0 -0
  1082. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/types/mod.rs +0 -0
  1083. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/types/record.rs +0 -0
  1084. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/types/variant.rs +0 -0
  1085. /data/ext/cargo-vendor/{wiggle-generate-16.0.0 → wiggle-generate-17.0.0}/src/wasmtime.rs +0 -0
  1086. /data/ext/cargo-vendor/{wiggle-macro-16.0.0 → wiggle-macro-17.0.0}/LICENSE +0 -0
  1087. /data/ext/cargo-vendor/{wiggle-macro-16.0.0 → wiggle-macro-17.0.0}/src/lib.rs +0 -0
  1088. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/LICENSE +0 -0
  1089. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/build.rs +0 -0
  1090. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/abi/local.rs +0 -0
  1091. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/abi/mod.rs +0 -0
  1092. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/codegen/builtin.rs +0 -0
  1093. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/codegen/call.rs +0 -0
  1094. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/codegen/control.rs +0 -0
  1095. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/codegen/mod.rs +0 -0
  1096. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/frame/mod.rs +0 -0
  1097. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/aarch64/abi.rs +0 -0
  1098. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/aarch64/address.rs +0 -0
  1099. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/aarch64/asm.rs +0 -0
  1100. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/aarch64/mod.rs +0 -0
  1101. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/aarch64/regs.rs +0 -0
  1102. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/mod.rs +0 -0
  1103. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/reg.rs +0 -0
  1104. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/x64/abi.rs +0 -0
  1105. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/x64/address.rs +0 -0
  1106. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/x64/mod.rs +0 -0
  1107. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/isa/x64/regs.rs +0 -0
  1108. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/lib.rs +0 -0
  1109. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/regalloc.rs +0 -0
  1110. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/regset.rs +0 -0
  1111. /data/ext/cargo-vendor/{winch-codegen-0.14.0 → winch-codegen-0.15.0}/src/trampoline.rs +0 -0
@@ -0,0 +1,4197 @@
1
+ ;; Instruction formats.
2
+ (type MInst
3
+ (enum
4
+ ;; A no-op of zero size.
5
+ (Nop0)
6
+
7
+ ;; A no-op that is one instruction large.
8
+ (Nop4)
9
+
10
+ ;; An ALU operation with two register sources and a register destination.
11
+ (AluRRR
12
+ (alu_op ALUOp)
13
+ (size OperandSize)
14
+ (rd WritableReg)
15
+ (rn Reg)
16
+ (rm Reg))
17
+
18
+ ;; An ALU operation with three register sources and a register destination.
19
+ (AluRRRR
20
+ (alu_op ALUOp3)
21
+ (size OperandSize)
22
+ (rd WritableReg)
23
+ (rn Reg)
24
+ (rm Reg)
25
+ (ra Reg))
26
+
27
+ ;; An ALU operation with a register source and an immediate-12 source, and a register
28
+ ;; destination.
29
+ (AluRRImm12
30
+ (alu_op ALUOp)
31
+ (size OperandSize)
32
+ (rd WritableReg)
33
+ (rn Reg)
34
+ (imm12 Imm12))
35
+
36
+ ;; An ALU operation with a register source and an immediate-logic source, and a register destination.
37
+ (AluRRImmLogic
38
+ (alu_op ALUOp)
39
+ (size OperandSize)
40
+ (rd WritableReg)
41
+ (rn Reg)
42
+ (imml ImmLogic))
43
+
44
+ ;; An ALU operation with a register source and an immediate-shiftamt source, and a register destination.
45
+ (AluRRImmShift
46
+ (alu_op ALUOp)
47
+ (size OperandSize)
48
+ (rd WritableReg)
49
+ (rn Reg)
50
+ (immshift ImmShift))
51
+
52
+ ;; An ALU operation with two register sources, one of which can be shifted, and a register
53
+ ;; destination.
54
+ (AluRRRShift
55
+ (alu_op ALUOp)
56
+ (size OperandSize)
57
+ (rd WritableReg)
58
+ (rn Reg)
59
+ (rm Reg)
60
+ (shiftop ShiftOpAndAmt))
61
+
62
+ ;; An ALU operation with two register sources, one of which can be {zero,sign}-extended and
63
+ ;; shifted, and a register destination.
64
+ (AluRRRExtend
65
+ (alu_op ALUOp)
66
+ (size OperandSize)
67
+ (rd WritableReg)
68
+ (rn Reg)
69
+ (rm Reg)
70
+ (extendop ExtendOp))
71
+
72
+ ;; A bit op instruction with a single register source.
73
+ (BitRR
74
+ (op BitOp)
75
+ (size OperandSize)
76
+ (rd WritableReg)
77
+ (rn Reg))
78
+
79
+ ;; An unsigned (zero-extending) 8-bit load.
80
+ (ULoad8
81
+ (rd WritableReg)
82
+ (mem AMode)
83
+ (flags MemFlags))
84
+
85
+ ;; A signed (sign-extending) 8-bit load.
86
+ (SLoad8
87
+ (rd WritableReg)
88
+ (mem AMode)
89
+ (flags MemFlags))
90
+
91
+ ;; An unsigned (zero-extending) 16-bit load.
92
+ (ULoad16
93
+ (rd WritableReg)
94
+ (mem AMode)
95
+ (flags MemFlags))
96
+
97
+ ;; A signed (sign-extending) 16-bit load.
98
+ (SLoad16
99
+ (rd WritableReg)
100
+ (mem AMode)
101
+ (flags MemFlags))
102
+
103
+ ;; An unsigned (zero-extending) 32-bit load.
104
+ (ULoad32
105
+ (rd WritableReg)
106
+ (mem AMode)
107
+ (flags MemFlags))
108
+
109
+ ;; A signed (sign-extending) 32-bit load.
110
+ (SLoad32
111
+ (rd WritableReg)
112
+ (mem AMode)
113
+ (flags MemFlags))
114
+
115
+ ;; A 64-bit load.
116
+ (ULoad64
117
+ (rd WritableReg)
118
+ (mem AMode)
119
+ (flags MemFlags))
120
+
121
+ ;; An 8-bit store.
122
+ (Store8
123
+ (rd Reg)
124
+ (mem AMode)
125
+ (flags MemFlags))
126
+
127
+ ;; A 16-bit store.
128
+ (Store16
129
+ (rd Reg)
130
+ (mem AMode)
131
+ (flags MemFlags))
132
+
133
+ ;; A 32-bit store.
134
+ (Store32
135
+ (rd Reg)
136
+ (mem AMode)
137
+ (flags MemFlags))
138
+
139
+ ;; A 64-bit store.
140
+ (Store64
141
+ (rd Reg)
142
+ (mem AMode)
143
+ (flags MemFlags))
144
+
145
+ ;; A store of a pair of registers.
146
+ (StoreP64
147
+ (rt Reg)
148
+ (rt2 Reg)
149
+ (mem PairAMode)
150
+ (flags MemFlags))
151
+
152
+ ;; A load of a pair of registers.
153
+ (LoadP64
154
+ (rt WritableReg)
155
+ (rt2 WritableReg)
156
+ (mem PairAMode)
157
+ (flags MemFlags))
158
+
159
+ ;; A MOV instruction. These are encoded as ORR's (AluRRR form).
160
+ ;; The 32-bit version zeroes the top 32 bits of the
161
+ ;; destination, which is effectively an alias for an unsigned
162
+ ;; 32-to-64-bit extension.
163
+ (Mov
164
+ (size OperandSize)
165
+ (rd WritableReg)
166
+ (rm Reg))
167
+
168
+ ;; Like `Move` but with a particular `PReg` source (for implementing CLIF
169
+ ;; instructions like `get_stack_pointer`).
170
+ (MovFromPReg
171
+ (rd WritableReg)
172
+ (rm PReg))
173
+
174
+ ;; Like `Move` but with a particular `PReg` destination (for
175
+ ;; implementing CLIF instructions like `set_pinned_reg`).
176
+ (MovToPReg
177
+ (rd PReg)
178
+ (rm Reg))
179
+
180
+ ;; A MOV[Z,N] with a 16-bit immediate.
181
+ (MovWide
182
+ (op MoveWideOp)
183
+ (rd WritableReg)
184
+ (imm MoveWideConst)
185
+ (size OperandSize))
186
+
187
+ ;; A MOVK with a 16-bit immediate. Modifies its register; we
188
+ ;; model this with a seprate input `rn` and output `rd` virtual
189
+ ;; register, with a regalloc constraint to tie them together.
190
+ (MovK
191
+ (rd WritableReg)
192
+ (rn Reg)
193
+ (imm MoveWideConst)
194
+ (size OperandSize))
195
+
196
+
197
+ ;; A sign- or zero-extend operation.
198
+ (Extend
199
+ (rd WritableReg)
200
+ (rn Reg)
201
+ (signed bool)
202
+ (from_bits u8)
203
+ (to_bits u8))
204
+
205
+ ;; A conditional-select operation.
206
+ (CSel
207
+ (rd WritableReg)
208
+ (cond Cond)
209
+ (rn Reg)
210
+ (rm Reg))
211
+
212
+ ;; A conditional-select negation operation.
213
+ (CSNeg
214
+ (rd WritableReg)
215
+ (cond Cond)
216
+ (rn Reg)
217
+ (rm Reg))
218
+
219
+ ;; A conditional-set operation.
220
+ (CSet
221
+ (rd WritableReg)
222
+ (cond Cond))
223
+
224
+ ;; A conditional-set-mask operation.
225
+ (CSetm
226
+ (rd WritableReg)
227
+ (cond Cond))
228
+
229
+ ;; A conditional comparison with a second register.
230
+ (CCmp
231
+ (size OperandSize)
232
+ (rn Reg)
233
+ (rm Reg)
234
+ (nzcv NZCV)
235
+ (cond Cond))
236
+
237
+ ;; A conditional comparison with an immediate.
238
+ (CCmpImm
239
+ (size OperandSize)
240
+ (rn Reg)
241
+ (imm UImm5)
242
+ (nzcv NZCV)
243
+ (cond Cond))
244
+
245
+ ;; A synthetic insn, which is a load-linked store-conditional loop, that has the overall
246
+ ;; effect of atomically modifying a memory location in a particular way. Because we have
247
+ ;; no way to explain to the regalloc about earlyclobber registers, this instruction has
248
+ ;; completely fixed operand registers, and we rely on the RA's coalescing to remove copies
249
+ ;; in the surrounding code to the extent it can. Load- and store-exclusive instructions,
250
+ ;; with acquire-release semantics, are used to access memory. The operand conventions are:
251
+ ;;
252
+ ;; x25 (rd) address
253
+ ;; x26 (rd) second operand for `op`
254
+ ;; x27 (wr) old value
255
+ ;; x24 (wr) scratch reg; value afterwards has no meaning
256
+ ;; x28 (wr) scratch reg; value afterwards has no meaning
257
+ (AtomicRMWLoop
258
+ (ty Type) ;; I8, I16, I32 or I64
259
+ (op AtomicRMWLoopOp)
260
+ (flags MemFlags)
261
+ (addr Reg)
262
+ (operand Reg)
263
+ (oldval WritableReg)
264
+ (scratch1 WritableReg)
265
+ (scratch2 WritableReg))
266
+
267
+ ;; Similar to AtomicRMWLoop, a compare-and-swap operation implemented using a load-linked
268
+ ;; store-conditional loop, with acquire-release semantics.
269
+ ;; Note that the operand conventions, although very similar to AtomicRMWLoop, are different:
270
+ ;;
271
+ ;; x25 (rd) address
272
+ ;; x26 (rd) expected value
273
+ ;; x28 (rd) replacement value
274
+ ;; x27 (wr) old value
275
+ ;; x24 (wr) scratch reg; value afterwards has no meaning
276
+ (AtomicCASLoop
277
+ (ty Type) ;; I8, I16, I32 or I64
278
+ (flags MemFlags)
279
+ (addr Reg)
280
+ (expected Reg)
281
+ (replacement Reg)
282
+ (oldval WritableReg)
283
+ (scratch WritableReg))
284
+
285
+ ;; An atomic read-modify-write operation. These instructions require the
286
+ ;; Large System Extension (LSE) ISA support (FEAT_LSE). The instructions have
287
+ ;; acquire-release semantics.
288
+ (AtomicRMW
289
+ (op AtomicRMWOp)
290
+ (rs Reg)
291
+ (rt WritableReg)
292
+ (rn Reg)
293
+ (ty Type)
294
+ (flags MemFlags))
295
+
296
+ ;; An atomic compare-and-swap operation. These instructions require the
297
+ ;; Large System Extension (LSE) ISA support (FEAT_LSE). The instructions have
298
+ ;; acquire-release semantics.
299
+ (AtomicCAS
300
+ ;; `rd` is really `rs` in the encoded instruction (so `rd` == `rs`); we separate
301
+ ;; them here to have separate use and def vregs for regalloc.
302
+ (rd WritableReg)
303
+ (rs Reg)
304
+ (rt Reg)
305
+ (rn Reg)
306
+ (ty Type)
307
+ (flags MemFlags))
308
+
309
+ ;; Read `access_ty` bits from address `rt`, either 8, 16, 32 or 64-bits, and put
310
+ ;; it in `rn`, optionally zero-extending to fill a word or double word result.
311
+ ;; This instruction is sequentially consistent.
312
+ (LoadAcquire
313
+ (access_ty Type) ;; I8, I16, I32 or I64
314
+ (rt WritableReg)
315
+ (rn Reg)
316
+ (flags MemFlags))
317
+
318
+ ;; Write the lowest `ty` bits of `rt` to address `rn`.
319
+ ;; This instruction is sequentially consistent.
320
+ (StoreRelease
321
+ (access_ty Type) ;; I8, I16, I32 or I64
322
+ (rt Reg)
323
+ (rn Reg)
324
+ (flags MemFlags))
325
+
326
+ ;; A memory fence. This must provide ordering to ensure that, at a minimum, neither loads
327
+ ;; nor stores may move forwards or backwards across the fence. Currently emitted as "dmb
328
+ ;; ish". This instruction is sequentially consistent.
329
+ (Fence)
330
+
331
+ ;; Consumption of speculative data barrier.
332
+ (Csdb)
333
+
334
+ ;; FPU move. Note that this is distinct from a vector-register
335
+ ;; move; moving just 64 bits seems to be significantly faster.
336
+ (FpuMove64
337
+ (rd WritableReg)
338
+ (rn Reg))
339
+
340
+ ;; Vector register move.
341
+ (FpuMove128
342
+ (rd WritableReg)
343
+ (rn Reg))
344
+
345
+ ;; Move to scalar from a vector element.
346
+ (FpuMoveFromVec
347
+ (rd WritableReg)
348
+ (rn Reg)
349
+ (idx u8)
350
+ (size VectorSize))
351
+
352
+ ;; Zero-extend a SIMD & FP scalar to the full width of a vector register.
353
+ ;; 16-bit scalars require half-precision floating-point support (FEAT_FP16).
354
+ (FpuExtend
355
+ (rd WritableReg)
356
+ (rn Reg)
357
+ (size ScalarSize))
358
+
359
+ ;; 1-op FPU instruction.
360
+ (FpuRR
361
+ (fpu_op FPUOp1)
362
+ (size ScalarSize)
363
+ (rd WritableReg)
364
+ (rn Reg))
365
+
366
+ ;; 2-op FPU instruction.
367
+ (FpuRRR
368
+ (fpu_op FPUOp2)
369
+ (size ScalarSize)
370
+ (rd WritableReg)
371
+ (rn Reg)
372
+ (rm Reg))
373
+
374
+ (FpuRRI
375
+ (fpu_op FPUOpRI)
376
+ (rd WritableReg)
377
+ (rn Reg))
378
+
379
+ ;; Variant of FpuRRI that modifies its `rd`, and so we name the
380
+ ;; input state `ri` (for "input") and constrain the two
381
+ ;; together.
382
+ (FpuRRIMod
383
+ (fpu_op FPUOpRIMod)
384
+ (rd WritableReg)
385
+ (ri Reg)
386
+ (rn Reg))
387
+
388
+
389
+ ;; 3-op FPU instruction.
390
+ ;; 16-bit scalars require half-precision floating-point support (FEAT_FP16).
391
+ (FpuRRRR
392
+ (fpu_op FPUOp3)
393
+ (size ScalarSize)
394
+ (rd WritableReg)
395
+ (rn Reg)
396
+ (rm Reg)
397
+ (ra Reg))
398
+
399
+ ;; FPU comparison.
400
+ (FpuCmp
401
+ (size ScalarSize)
402
+ (rn Reg)
403
+ (rm Reg))
404
+
405
+ ;; Floating-point load, single-precision (32 bit).
406
+ (FpuLoad32
407
+ (rd WritableReg)
408
+ (mem AMode)
409
+ (flags MemFlags))
410
+
411
+ ;; Floating-point store, single-precision (32 bit).
412
+ (FpuStore32
413
+ (rd Reg)
414
+ (mem AMode)
415
+ (flags MemFlags))
416
+
417
+ ;; Floating-point load, double-precision (64 bit).
418
+ (FpuLoad64
419
+ (rd WritableReg)
420
+ (mem AMode)
421
+ (flags MemFlags))
422
+
423
+ ;; Floating-point store, double-precision (64 bit).
424
+ (FpuStore64
425
+ (rd Reg)
426
+ (mem AMode)
427
+ (flags MemFlags))
428
+
429
+ ;; Floating-point/vector load, 128 bit.
430
+ (FpuLoad128
431
+ (rd WritableReg)
432
+ (mem AMode)
433
+ (flags MemFlags))
434
+
435
+ ;; Floating-point/vector store, 128 bit.
436
+ (FpuStore128
437
+ (rd Reg)
438
+ (mem AMode)
439
+ (flags MemFlags))
440
+
441
+ ;; A load of a pair of floating-point registers, double precision (64-bit).
442
+ (FpuLoadP64
443
+ (rt WritableReg)
444
+ (rt2 WritableReg)
445
+ (mem PairAMode)
446
+ (flags MemFlags))
447
+
448
+ ;; A store of a pair of floating-point registers, double precision (64-bit).
449
+ (FpuStoreP64
450
+ (rt Reg)
451
+ (rt2 Reg)
452
+ (mem PairAMode)
453
+ (flags MemFlags))
454
+
455
+ ;; A load of a pair of floating-point registers, 128-bit.
456
+ (FpuLoadP128
457
+ (rt WritableReg)
458
+ (rt2 WritableReg)
459
+ (mem PairAMode)
460
+ (flags MemFlags))
461
+
462
+ ;; A store of a pair of floating-point registers, 128-bit.
463
+ (FpuStoreP128
464
+ (rt Reg)
465
+ (rt2 Reg)
466
+ (mem PairAMode)
467
+ (flags MemFlags))
468
+
469
+ ;; Conversion: FP -> integer.
470
+ (FpuToInt
471
+ (op FpuToIntOp)
472
+ (rd WritableReg)
473
+ (rn Reg))
474
+
475
+ ;; Conversion: integer -> FP.
476
+ (IntToFpu
477
+ (op IntToFpuOp)
478
+ (rd WritableReg)
479
+ (rn Reg))
480
+
481
+ ;; FP conditional select, 32 bit.
482
+ (FpuCSel32
483
+ (rd WritableReg)
484
+ (rn Reg)
485
+ (rm Reg)
486
+ (cond Cond))
487
+
488
+ ;; FP conditional select, 64 bit.
489
+ (FpuCSel64
490
+ (rd WritableReg)
491
+ (rn Reg)
492
+ (rm Reg)
493
+ (cond Cond))
494
+
495
+ ;; Round to integer.
496
+ (FpuRound
497
+ (op FpuRoundMode)
498
+ (rd WritableReg)
499
+ (rn Reg))
500
+
501
+ ;; Move from a GPR to a vector register. The scalar value is parked in the lowest lane
502
+ ;; of the destination, and all other lanes are zeroed out. Currently only 32- and 64-bit
503
+ ;; transactions are supported.
504
+ (MovToFpu
505
+ (rd WritableReg)
506
+ (rn Reg)
507
+ (size ScalarSize))
508
+
509
+ ;; Loads a floating-point immediate.
510
+ (FpuMoveFPImm
511
+ (rd WritableReg)
512
+ (imm ASIMDFPModImm)
513
+ (size ScalarSize))
514
+
515
+ ;; Move to a vector element from a GPR.
516
+ (MovToVec
517
+ (rd WritableReg)
518
+ (ri Reg)
519
+ (rn Reg)
520
+ (idx u8)
521
+ (size VectorSize))
522
+
523
+ ;; Unsigned move from a vector element to a GPR.
524
+ (MovFromVec
525
+ (rd WritableReg)
526
+ (rn Reg)
527
+ (idx u8)
528
+ (size ScalarSize))
529
+
530
+ ;; Signed move from a vector element to a GPR.
531
+ (MovFromVecSigned
532
+ (rd WritableReg)
533
+ (rn Reg)
534
+ (idx u8)
535
+ (size VectorSize)
536
+ (scalar_size OperandSize))
537
+
538
+ ;; Duplicate general-purpose register to vector.
539
+ (VecDup
540
+ (rd WritableReg)
541
+ (rn Reg)
542
+ (size VectorSize))
543
+
544
+ ;; Duplicate scalar to vector.
545
+ (VecDupFromFpu
546
+ (rd WritableReg)
547
+ (rn Reg)
548
+ (size VectorSize)
549
+ (lane u8))
550
+
551
+ ;; Duplicate FP immediate to vector.
552
+ (VecDupFPImm
553
+ (rd WritableReg)
554
+ (imm ASIMDFPModImm)
555
+ (size VectorSize))
556
+
557
+ ;; Duplicate immediate to vector.
558
+ (VecDupImm
559
+ (rd WritableReg)
560
+ (imm ASIMDMovModImm)
561
+ (invert bool)
562
+ (size VectorSize))
563
+
564
+ ;; Vector extend.
565
+ (VecExtend
566
+ (t VecExtendOp)
567
+ (rd WritableReg)
568
+ (rn Reg)
569
+ (high_half bool)
570
+ (lane_size ScalarSize))
571
+
572
+ ;; Move vector element to another vector element.
573
+ (VecMovElement
574
+ (rd WritableReg)
575
+ (ri Reg)
576
+ (rn Reg)
577
+ (dest_idx u8)
578
+ (src_idx u8)
579
+ (size VectorSize))
580
+
581
+ ;; Vector widening operation.
582
+ (VecRRLong
583
+ (op VecRRLongOp)
584
+ (rd WritableReg)
585
+ (rn Reg)
586
+ (high_half bool))
587
+
588
+ ;; Vector narrowing operation -- low half.
589
+ (VecRRNarrowLow
590
+ (op VecRRNarrowOp)
591
+ (rd WritableReg)
592
+ (rn Reg)
593
+ (lane_size ScalarSize))
594
+
595
+ ;; Vector narrowing operation -- high half.
596
+ (VecRRNarrowHigh
597
+ (op VecRRNarrowOp)
598
+ (rd WritableReg)
599
+ (ri Reg)
600
+ (rn Reg)
601
+ (lane_size ScalarSize))
602
+
603
+ ;; 1-operand vector instruction that operates on a pair of elements.
604
+ (VecRRPair
605
+ (op VecPairOp)
606
+ (rd WritableReg)
607
+ (rn Reg))
608
+
609
+ ;; 2-operand vector instruction that produces a result with twice the
610
+ ;; lane width and half the number of lanes.
611
+ (VecRRRLong
612
+ (alu_op VecRRRLongOp)
613
+ (rd WritableReg)
614
+ (rn Reg)
615
+ (rm Reg)
616
+ (high_half bool))
617
+
618
+ ;; 2-operand vector instruction that produces a result with
619
+ ;; twice the lane width and half the number of lanes. Variant
620
+ ;; that modifies `rd` (so takes its initial state as `ri`).
621
+ (VecRRRLongMod
622
+ (alu_op VecRRRLongModOp)
623
+ (rd WritableReg)
624
+ (ri Reg)
625
+ (rn Reg)
626
+ (rm Reg)
627
+ (high_half bool))
628
+
629
+ ;; 1-operand vector instruction that extends elements of the input
630
+ ;; register and operates on a pair of elements. The output lane width
631
+ ;; is double that of the input.
632
+ (VecRRPairLong
633
+ (op VecRRPairLongOp)
634
+ (rd WritableReg)
635
+ (rn Reg))
636
+
637
+ ;; A vector ALU op.
638
+ (VecRRR
639
+ (alu_op VecALUOp)
640
+ (rd WritableReg)
641
+ (rn Reg)
642
+ (rm Reg)
643
+ (size VectorSize))
644
+
645
+ ;; A vector ALU op modifying a source register.
646
+ (VecRRRMod
647
+ (alu_op VecALUModOp)
648
+ (rd WritableReg)
649
+ (ri Reg)
650
+ (rn Reg)
651
+ (rm Reg)
652
+ (size VectorSize))
653
+
654
+ ;; A vector ALU op modifying a source register.
655
+ (VecFmlaElem
656
+ (alu_op VecALUModOp)
657
+ (rd WritableReg)
658
+ (ri Reg)
659
+ (rn Reg)
660
+ (rm Reg)
661
+ (size VectorSize)
662
+ (idx u8))
663
+
664
+ ;; Vector two register miscellaneous instruction.
665
+ (VecMisc
666
+ (op VecMisc2)
667
+ (rd WritableReg)
668
+ (rn Reg)
669
+ (size VectorSize))
670
+
671
+ ;; Vector instruction across lanes.
672
+ (VecLanes
673
+ (op VecLanesOp)
674
+ (rd WritableReg)
675
+ (rn Reg)
676
+ (size VectorSize))
677
+
678
+ ;; Vector shift by immediate Shift Left (immediate), Unsigned Shift Right (immediate)
679
+ ;; Signed Shift Right (immediate). These are somewhat unusual in that, for right shifts,
680
+ ;; the allowed range of `imm` values is 1 to lane-size-in-bits, inclusive. A zero
681
+ ;; right-shift cannot be encoded. Left shifts are "normal", though, having valid `imm`
682
+ ;; values from 0 to lane-size-in-bits - 1 inclusive.
683
+ (VecShiftImm
684
+ (op VecShiftImmOp)
685
+ (rd WritableReg)
686
+ (rn Reg)
687
+ (size VectorSize)
688
+ (imm u8))
689
+
690
+ ;; Destructive vector shift by immediate.
691
+ (VecShiftImmMod
692
+ (op VecShiftImmModOp)
693
+ (rd WritableReg)
694
+ (ri Reg)
695
+ (rn Reg)
696
+ (size VectorSize)
697
+ (imm u8))
698
+
699
+ ;; Vector extract - create a new vector, being the concatenation of the lowest `imm4` bytes
700
+ ;; of `rm` followed by the uppermost `16 - imm4` bytes of `rn`.
701
+ (VecExtract
702
+ (rd WritableReg)
703
+ (rn Reg)
704
+ (rm Reg)
705
+ (imm4 u8))
706
+
707
+ ;; Table vector lookup - single register table. The table
708
+ ;; consists of 8-bit elements and is stored in `rn`, while `rm`
709
+ ;; contains 8-bit element indices. This variant emits `TBL`,
710
+ ;; which sets elements that correspond to out-of-range indices
711
+ ;; (greater than 15) to 0.
712
+ (VecTbl
713
+ (rd WritableReg)
714
+ (rn Reg)
715
+ (rm Reg))
716
+
717
+ ;; Table vector lookup - single register table. The table
718
+ ;; consists of 8-bit elements and is stored in `rn`, while `rm`
719
+ ;; contains 8-bit element indices. This variant emits `TBX`,
720
+ ;; which leaves elements that correspond to out-of-range indices
721
+ ;; (greater than 15) unmodified. Hence, it takes an input vreg in
722
+ ;; `ri` that is constrained to the same allocation as `rd`.
723
+ (VecTblExt
724
+ (rd WritableReg)
725
+ (ri Reg)
726
+ (rn Reg)
727
+ (rm Reg))
728
+
729
+ ;; Table vector lookup - two register table. The table consists
730
+ ;; of 8-bit elements and is stored in `rn` and `rn2`, while
731
+ ;; `rm` contains 8-bit element indices. The table registers
732
+ ;; `rn` and `rn2` must have consecutive numbers modulo 32, that
733
+ ;; is v31 and v0 (in that order) are consecutive registers.
734
+ ;; This variant emits `TBL`, which sets out-of-range results to
735
+ ;; 0.
736
+ (VecTbl2
737
+ (rd WritableReg)
738
+ (rn Reg)
739
+ (rn2 Reg)
740
+ (rm Reg))
741
+
742
+ ;; Table vector lookup - two register table. The table consists
743
+ ;; of 8-bit elements and is stored in `rn` and `rn2`, while
744
+ ;; `rm` contains 8-bit element indices. The table registers
745
+ ;; `rn` and `rn2` must have consecutive numbers modulo 32, that
746
+ ;; is v31 and v0 (in that order) are consecutive registers.
747
+ ;; This variant emits `TBX`, which leaves out-of-range results
748
+ ;; unmodified, hence takes the initial state of the result
749
+ ;; register in vreg `ri`.
750
+ (VecTbl2Ext
751
+ (rd WritableReg)
752
+ (ri Reg)
753
+ (rn Reg)
754
+ (rn2 Reg)
755
+ (rm Reg))
756
+
757
+ ;; Load an element and replicate to all lanes of a vector.
758
+ (VecLoadReplicate
759
+ (rd WritableReg)
760
+ (rn Reg)
761
+ (size VectorSize)
762
+ (flags MemFlags))
763
+
764
+ ;; Vector conditional select, 128 bit. A synthetic instruction, which generates a 4-insn
765
+ ;; control-flow diamond.
766
+ (VecCSel
767
+ (rd WritableReg)
768
+ (rn Reg)
769
+ (rm Reg)
770
+ (cond Cond))
771
+
772
+ ;; Move to the NZCV flags (actually a `MSR NZCV, Xn` insn).
773
+ (MovToNZCV
774
+ (rn Reg))
775
+
776
+ ;; Move from the NZCV flags (actually a `MRS Xn, NZCV` insn).
777
+ (MovFromNZCV
778
+ (rd WritableReg))
779
+
780
+ ;; A machine call instruction. N.B.: this allows only a +/- 128MB offset (it uses a relocation
781
+ ;; of type `Reloc::Arm64Call`); if the destination distance is not `RelocDistance::Near`, the
782
+ ;; code should use a `LoadExtName` / `CallInd` sequence instead, allowing an arbitrary 64-bit
783
+ ;; target.
784
+ (Call
785
+ (info BoxCallInfo))
786
+
787
+ ;; A machine indirect-call instruction.
788
+ (CallInd
789
+ (info BoxCallIndInfo))
790
+
791
+ ;; A return-call macro instruction.
792
+ (ReturnCall
793
+ (callee BoxExternalName)
794
+ (info BoxReturnCallInfo))
795
+
796
+ ;; An indirect return-call macro instruction.
797
+ (ReturnCallInd
798
+ (callee Reg)
799
+ (info BoxReturnCallInfo))
800
+
801
+ ;; A pseudo-instruction that captures register arguments in vregs.
802
+ (Args
803
+ (args VecArgPair))
804
+
805
+ ;; A pseudo-instruction that moves vregs to return registers.
806
+ (Rets
807
+ (rets VecRetPair))
808
+
809
+ ;; ---- branches (exactly one must appear at end of BB) ----
810
+
811
+ ;; A machine return instruction.
812
+ (Ret)
813
+
814
+ ;; A machine return instruction with pointer authentication using SP as the
815
+ ;; modifier. This instruction requires pointer authentication support
816
+ ;; (FEAT_PAuth) unless `is_hint` is true, in which case it is equivalent to
817
+ ;; the combination of a no-op and a return instruction on platforms without
818
+ ;; the relevant support.
819
+ (AuthenticatedRet
820
+ (key APIKey)
821
+ (is_hint bool))
822
+
823
+ ;; An unconditional branch.
824
+ (Jump
825
+ (dest BranchTarget))
826
+
827
+ ;; A conditional branch. Contains two targets; at emission time, both are emitted, but
828
+ ;; the MachBuffer knows to truncate the trailing branch if fallthrough. We optimize the
829
+ ;; choice of taken/not_taken (inverting the branch polarity as needed) based on the
830
+ ;; fallthrough at the time of lowering.
831
+ (CondBr
832
+ (taken BranchTarget)
833
+ (not_taken BranchTarget)
834
+ (kind CondBrKind))
835
+
836
+ ;; A conditional branch which tests the `bit` of `rn` and branches
837
+ ;; depending on `kind`.
838
+ (TestBitAndBranch
839
+ (kind TestBitAndBranchKind)
840
+ (taken BranchTarget)
841
+ (not_taken BranchTarget)
842
+ (rn Reg)
843
+ (bit u8))
844
+
845
+ ;; A conditional trap: execute a `udf` if the condition is true. This is
846
+ ;; one VCode instruction because it uses embedded control flow; it is
847
+ ;; logically a single-in, single-out region, but needs to appear as one
848
+ ;; unit to the register allocator.
849
+ ;;
850
+ ;; The `CondBrKind` gives the conditional-branch condition that will
851
+ ;; *execute* the embedded `Inst`. (In the emitted code, we use the inverse
852
+ ;; of this condition in a branch that skips the trap instruction.)
853
+ (TrapIf
854
+ (kind CondBrKind)
855
+ (trap_code TrapCode))
856
+
857
+ ;; An indirect branch through a register, augmented with set of all
858
+ ;; possible successors.
859
+ (IndirectBr
860
+ (rn Reg)
861
+ (targets VecMachLabel))
862
+
863
+ ;; A "break" instruction, used for e.g. traps and debug breakpoints.
864
+ (Brk)
865
+
866
+ ;; An instruction guaranteed to always be undefined and to trigger an illegal instruction at
867
+ ;; runtime.
868
+ (Udf
869
+ (trap_code TrapCode))
870
+
871
+ ;; Compute the address (using a PC-relative offset) of a memory location, using the `ADR`
872
+ ;; instruction. Note that we take a simple offset, not a `MemLabel`, here, because `Adr` is
873
+ ;; only used for now in fixed lowering sequences with hardcoded offsets. In the future we may
874
+ ;; need full `MemLabel` support.
875
+ (Adr
876
+ (rd WritableReg)
877
+ ;; Offset in range -2^20 .. 2^20.
878
+ (off i32))
879
+
880
+ ;; Compute the address (using a PC-relative offset) of a 4KB page.
881
+ (Adrp
882
+ (rd WritableReg)
883
+ (off i32))
884
+
885
+ ;; Raw 32-bit word, used for inline constants and jump-table entries.
886
+ (Word4
887
+ (data u32))
888
+
889
+ ;; Raw 64-bit word, used for inline constants.
890
+ (Word8
891
+ (data u64))
892
+
893
+ ;; Jump-table sequence, as one compound instruction (see note in lower_inst.rs for rationale).
894
+ (JTSequence
895
+ (default MachLabel)
896
+ (targets BoxVecMachLabel)
897
+ (ridx Reg)
898
+ (rtmp1 WritableReg)
899
+ (rtmp2 WritableReg))
900
+
901
+ ;; Load an inline symbol reference.
902
+ (LoadExtName
903
+ (rd WritableReg)
904
+ (name BoxExternalName)
905
+ (offset i64))
906
+
907
+ ;; Load address referenced by `mem` into `rd`.
908
+ (LoadAddr
909
+ (rd WritableReg)
910
+ (mem AMode))
911
+
912
+ ;; Pointer authentication code for instruction address with modifier in SP;
913
+ ;; equivalent to a no-op if Pointer authentication (FEAT_PAuth) is not
914
+ ;; supported.
915
+ (Paci
916
+ (key APIKey))
917
+
918
+ ;; Strip pointer authentication code from instruction address in LR;
919
+ ;; equivalent to a no-op if Pointer authentication (FEAT_PAuth) is not
920
+ ;; supported.
921
+ (Xpaclri)
922
+
923
+ ;; Branch target identification; equivalent to a no-op if Branch Target
924
+ ;; Identification (FEAT_BTI) is not supported.
925
+ (Bti
926
+ (targets BranchTargetType))
927
+
928
+ ;; Marker, no-op in generated code: SP "virtual offset" is adjusted. This
929
+ ;; controls how AMode::NominalSPOffset args are lowered.
930
+ (VirtualSPOffsetAdj
931
+ (offset i64))
932
+
933
+ ;; Meta-insn, no-op in generated code: emit constant/branch veneer island
934
+ ;; at this point (with a guard jump around it) if less than the needed
935
+ ;; space is available before the next branch deadline. See the `MachBuffer`
936
+ ;; implementation in `machinst/buffer.rs` for the overall algorithm. In
937
+ ;; brief, we retain a set of "pending/unresolved label references" from
938
+ ;; branches as we scan forward through instructions to emit machine code;
939
+ ;; if we notice we're about to go out of range on an unresolved reference,
940
+ ;; we stop, emit a bunch of "veneers" (branches in a form that has a longer
941
+ ;; range, e.g. a 26-bit-offset unconditional jump), and point the original
942
+ ;; label references to those. This is an "island" because it comes in the
943
+ ;; middle of the code.
944
+ ;;
945
+ ;; This meta-instruction is a necessary part of the logic that determines
946
+ ;; where to place islands. Ordinarily, we want to place them between basic
947
+ ;; blocks, so we compute the worst-case size of each block, and emit the
948
+ ;; island before starting a block if we would exceed a deadline before the
949
+ ;; end of the block. However, some sequences (such as an inline jumptable)
950
+ ;; are variable-length and not accounted for by this logic; so these
951
+ ;; lowered sequences include an `EmitIsland` to trigger island generation
952
+ ;; where necessary.
953
+ (EmitIsland
954
+ ;; The needed space before the next deadline.
955
+ (needed_space CodeOffset))
956
+
957
+ ;; A call to the `ElfTlsGetAddr` libcall. Returns address of TLS symbol in x0.
958
+ (ElfTlsGetAddr
959
+ (symbol BoxExternalName)
960
+ (rd WritableReg)
961
+ (tmp WritableReg))
962
+
963
+ (MachOTlsGetAddr
964
+ (symbol ExternalName)
965
+ (rd WritableReg))
966
+
967
+ ;; An unwind pseudo-instruction.
968
+ (Unwind
969
+ (inst UnwindInst))
970
+
971
+ ;; A dummy use, useful to keep a value alive.
972
+ (DummyUse
973
+ (reg Reg))
974
+
975
+ ;; Emits an inline stack probe loop.
976
+ ;;
977
+ ;; Note that this is emitted post-regalloc so `start` and `end` can be
978
+ ;; temporary registers such as the spilltmp and tmp2 registers. This also
979
+ ;; means that the internal codegen can't use these registers.
980
+ (StackProbeLoop (start WritableReg)
981
+ (end Reg)
982
+ (step Imm12))))
983
+
984
+ ;; An ALU operation. This can be paired with several instruction formats
985
+ ;; below (see `Inst`) in any combination.
986
+ (type ALUOp
987
+ (enum
988
+ (Add)
989
+ (Sub)
990
+ (Orr)
991
+ (OrrNot)
992
+ (And)
993
+ (AndS)
994
+ (AndNot)
995
+ ;; XOR (AArch64 calls this "EOR")
996
+ (Eor)
997
+ ;; XNOR (AArch64 calls this "EOR-NOT")
998
+ (EorNot)
999
+ ;; Add, setting flags
1000
+ (AddS)
1001
+ ;; Sub, setting flags
1002
+ (SubS)
1003
+ ;; Signed multiply, high-word result
1004
+ (SMulH)
1005
+ ;; Unsigned multiply, high-word result
1006
+ (UMulH)
1007
+ (SDiv)
1008
+ (UDiv)
1009
+ (RotR)
1010
+ (Lsr)
1011
+ (Asr)
1012
+ (Lsl)
1013
+ ;; Add with carry
1014
+ (Adc)
1015
+ ;; Add with carry, settings flags
1016
+ (AdcS)
1017
+ ;; Subtract with carry
1018
+ (Sbc)
1019
+ ;; Subtract with carry, settings flags
1020
+ (SbcS)
1021
+ ))
1022
+
1023
+ ;; An ALU operation with three arguments.
1024
+ (type ALUOp3
1025
+ (enum
1026
+ ;; Multiply-add
1027
+ (MAdd)
1028
+ ;; Multiply-sub
1029
+ (MSub)
1030
+ ;; Unsigned-Multiply-add
1031
+ (UMAddL)
1032
+ ;; Signed-Multiply-add
1033
+ (SMAddL)
1034
+ ))
1035
+
1036
+ (type MoveWideOp
1037
+ (enum
1038
+ (MovZ)
1039
+ (MovN)
1040
+ ))
1041
+
1042
+ (type UImm5 (primitive UImm5))
1043
+ (type Imm12 (primitive Imm12))
1044
+ (type ImmLogic (primitive ImmLogic))
1045
+ (type ImmShift (primitive ImmShift))
1046
+ (type ShiftOpAndAmt (primitive ShiftOpAndAmt))
1047
+ (type MoveWideConst (primitive MoveWideConst))
1048
+ (type NZCV (primitive NZCV))
1049
+ (type ASIMDFPModImm (primitive ASIMDFPModImm))
1050
+ (type ASIMDMovModImm (primitive ASIMDMovModImm))
1051
+ (type SImm7Scaled (primitive SImm7Scaled))
1052
+
1053
+ (type BoxCallInfo (primitive BoxCallInfo))
1054
+ (type BoxCallIndInfo (primitive BoxCallIndInfo))
1055
+ (type BoxReturnCallInfo (primitive BoxReturnCallInfo))
1056
+ (type CondBrKind (primitive CondBrKind))
1057
+ (type BranchTarget (primitive BranchTarget))
1058
+ (type BoxJTSequenceInfo (primitive BoxJTSequenceInfo))
1059
+ (type CodeOffset (primitive CodeOffset))
1060
+ (type VecMachLabel extern (enum))
1061
+
1062
+ (type ExtendOp extern
1063
+ (enum
1064
+ (UXTB)
1065
+ (UXTH)
1066
+ (UXTW)
1067
+ (UXTX)
1068
+ (SXTB)
1069
+ (SXTH)
1070
+ (SXTW)
1071
+ (SXTX)
1072
+ ))
1073
+
1074
+ ;; An operation on the bits of a register. This can be paired with several instruction formats
1075
+ ;; below (see `Inst`) in any combination.
1076
+ (type BitOp
1077
+ (enum
1078
+ ;; Bit reverse
1079
+ (RBit)
1080
+ (Clz)
1081
+ (Cls)
1082
+ ;; Byte reverse
1083
+ (Rev16)
1084
+ (Rev32)
1085
+ (Rev64)
1086
+ ))
1087
+
1088
+ (type MemLabel extern (enum))
1089
+ (type SImm9 extern (enum))
1090
+ (type UImm12Scaled extern (enum))
1091
+
1092
+ ;; An addressing mode specified for a load/store operation.
1093
+ (type AMode
1094
+ (enum
1095
+ ;;
1096
+ ;; Real ARM64 addressing modes:
1097
+ ;;
1098
+ ;; "post-indexed" mode as per AArch64 docs: postincrement reg after
1099
+ ;; address computation.
1100
+ ;; Specialized here to SP so we don't have to emit regalloc metadata.
1101
+ (SPPostIndexed
1102
+ (simm9 SImm9))
1103
+
1104
+ ;; "pre-indexed" mode as per AArch64 docs: preincrement reg before
1105
+ ;; address computation.
1106
+ ;; Specialized here to SP so we don't have to emit regalloc metadata.
1107
+ (SPPreIndexed
1108
+ (simm9 SImm9))
1109
+
1110
+ ;; N.B.: RegReg, RegScaled, and RegScaledExtended all correspond to
1111
+ ;; what the ISA calls the "register offset" addressing mode. We split
1112
+ ;; out several options here for more ergonomic codegen.
1113
+ ;;
1114
+ ;; Register plus register offset.
1115
+ (RegReg
1116
+ (rn Reg)
1117
+ (rm Reg))
1118
+
1119
+ ;; Register plus register offset, scaled by type's size.
1120
+ (RegScaled
1121
+ (rn Reg)
1122
+ (rm Reg)
1123
+ (ty Type))
1124
+
1125
+ ;; Register plus register offset, scaled by type's size, with index
1126
+ ;; sign- or zero-extended first.
1127
+ (RegScaledExtended
1128
+ (rn Reg)
1129
+ (rm Reg)
1130
+ (ty Type)
1131
+ (extendop ExtendOp))
1132
+
1133
+ ;; Register plus register offset, with index sign- or zero-extended
1134
+ ;; first.
1135
+ (RegExtended
1136
+ (rn Reg)
1137
+ (rm Reg)
1138
+ (extendop ExtendOp))
1139
+
1140
+ ;; Unscaled signed 9-bit immediate offset from reg.
1141
+ (Unscaled
1142
+ (rn Reg)
1143
+ (simm9 SImm9))
1144
+
1145
+ ;; Scaled (by size of a type) unsigned 12-bit immediate offset from reg.
1146
+ (UnsignedOffset
1147
+ (rn Reg)
1148
+ (uimm12 UImm12Scaled))
1149
+
1150
+ ;; virtual addressing modes that are lowered at emission time:
1151
+ ;;
1152
+ ;; Reference to a "label": e.g., a symbol.
1153
+ (Label
1154
+ (label MemLabel))
1155
+
1156
+ ;; Arbitrary offset from a register. Converted to generation of large
1157
+ ;; offsets with multiple instructions as necessary during code emission.
1158
+ (RegOffset
1159
+ (rn Reg)
1160
+ (off i64)
1161
+ (ty Type))
1162
+
1163
+ ;; Offset from the stack pointer.
1164
+ (SPOffset
1165
+ (off i64)
1166
+ (ty Type))
1167
+
1168
+ ;; Offset from the frame pointer.
1169
+ (FPOffset
1170
+ (off i64)
1171
+ (ty Type))
1172
+
1173
+ ;; A reference to a constant which is placed outside of the function's
1174
+ ;; body, typically at the end.
1175
+ (Const
1176
+ (addr VCodeConstant))
1177
+
1178
+ ;; Offset from the "nominal stack pointer", which is where the real SP is
1179
+ ;; just after stack and spill slots are allocated in the function prologue.
1180
+ ;; At emission time, this is converted to `SPOffset` with a fixup added to
1181
+ ;; the offset constant. The fixup is a running value that is tracked as
1182
+ ;; emission iterates through instructions in linear order, and can be
1183
+ ;; adjusted up and down with [Inst::VirtualSPOffsetAdj].
1184
+ ;;
1185
+ ;; The standard ABI is in charge of handling this (by emitting the
1186
+ ;; adjustment meta-instructions). It maintains the invariant that "nominal
1187
+ ;; SP" is where the actual SP is after the function prologue and before
1188
+ ;; clobber pushes. See the diagram in the documentation for
1189
+ ;; [crate::isa::aarch64::abi](the ABI module) for more details.
1190
+ (NominalSPOffset
1191
+ (off i64)
1192
+ (ty Type))))
1193
+
1194
+ ;; A memory argument to a load/store-pair.
1195
+ (type PairAMode (enum
1196
+ ;; Signed, scaled 7-bit offset from a register.
1197
+ (SignedOffset
1198
+ (reg Reg)
1199
+ (simm7 SImm7Scaled))
1200
+
1201
+ ;; Pre-increment register before address computation.
1202
+ (SPPreIndexed (simm7 SImm7Scaled))
1203
+
1204
+ ;; Post-increment register after address computation.
1205
+ (SPPostIndexed (simm7 SImm7Scaled))
1206
+ ))
1207
+
1208
+ (type FPUOpRI extern (enum))
1209
+ (type FPUOpRIMod extern (enum))
1210
+
1211
+ (type OperandSize extern
1212
+ (enum Size32
1213
+ Size64))
1214
+
1215
+ (type TestBitAndBranchKind (enum (Z) (NZ)))
1216
+
1217
+ ;; Helper for calculating the `OperandSize` corresponding to a type
1218
+ (decl operand_size (Type) OperandSize)
1219
+ (rule 1 (operand_size (fits_in_32 _ty)) (OperandSize.Size32))
1220
+ (rule (operand_size (fits_in_64 _ty)) (OperandSize.Size64))
1221
+
1222
+ (type ScalarSize extern
1223
+ (enum Size8
1224
+ Size16
1225
+ Size32
1226
+ Size64
1227
+ Size128))
1228
+
1229
+ ;; Helper for calculating the `ScalarSize` corresponding to a type
1230
+ (decl scalar_size (Type) ScalarSize)
1231
+
1232
+ (rule (scalar_size $I8) (ScalarSize.Size8))
1233
+ (rule (scalar_size $I16) (ScalarSize.Size16))
1234
+ (rule (scalar_size $I32) (ScalarSize.Size32))
1235
+ (rule (scalar_size $I64) (ScalarSize.Size64))
1236
+ (rule (scalar_size $I128) (ScalarSize.Size128))
1237
+
1238
+ (rule (scalar_size $F32) (ScalarSize.Size32))
1239
+ (rule (scalar_size $F64) (ScalarSize.Size64))
1240
+
1241
+ ;; Helper for calculating the `ScalarSize` lane type from vector type
1242
+ (decl lane_size (Type) ScalarSize)
1243
+ (rule 1 (lane_size (multi_lane 8 _)) (ScalarSize.Size8))
1244
+ (rule 1 (lane_size (multi_lane 16 _)) (ScalarSize.Size16))
1245
+ (rule 1 (lane_size (multi_lane 32 _)) (ScalarSize.Size32))
1246
+ (rule 1 (lane_size (multi_lane 64 _)) (ScalarSize.Size64))
1247
+ (rule (lane_size (dynamic_lane 8 _)) (ScalarSize.Size8))
1248
+ (rule (lane_size (dynamic_lane 16 _)) (ScalarSize.Size16))
1249
+ (rule (lane_size (dynamic_lane 32 _)) (ScalarSize.Size32))
1250
+ (rule (lane_size (dynamic_lane 64 _)) (ScalarSize.Size64))
1251
+
1252
+ ;; Helper for extracting the size of a lane from the input `VectorSize`
1253
+ (decl pure vector_lane_size (VectorSize) ScalarSize)
1254
+ (rule (vector_lane_size (VectorSize.Size8x16)) (ScalarSize.Size8))
1255
+ (rule (vector_lane_size (VectorSize.Size8x8)) (ScalarSize.Size8))
1256
+ (rule (vector_lane_size (VectorSize.Size16x8)) (ScalarSize.Size16))
1257
+ (rule (vector_lane_size (VectorSize.Size16x4)) (ScalarSize.Size16))
1258
+ (rule (vector_lane_size (VectorSize.Size32x4)) (ScalarSize.Size32))
1259
+ (rule (vector_lane_size (VectorSize.Size32x2)) (ScalarSize.Size32))
1260
+ (rule (vector_lane_size (VectorSize.Size64x2)) (ScalarSize.Size64))
1261
+
1262
+ (type Cond extern
1263
+ (enum
1264
+ (Eq)
1265
+ (Ne)
1266
+ (Hs)
1267
+ (Lo)
1268
+ (Mi)
1269
+ (Pl)
1270
+ (Vs)
1271
+ (Vc)
1272
+ (Hi)
1273
+ (Ls)
1274
+ (Ge)
1275
+ (Lt)
1276
+ (Gt)
1277
+ (Le)
1278
+ (Al)
1279
+ (Nv)
1280
+ ))
1281
+
1282
+ (type VectorSize extern
1283
+ (enum
1284
+ (Size8x8)
1285
+ (Size8x16)
1286
+ (Size16x4)
1287
+ (Size16x8)
1288
+ (Size32x2)
1289
+ (Size32x4)
1290
+ (Size64x2)
1291
+ ))
1292
+
1293
+ ;; Helper for calculating the `VectorSize` corresponding to a type
1294
+ (decl vector_size (Type) VectorSize)
1295
+ (rule 1 (vector_size (multi_lane 8 8)) (VectorSize.Size8x8))
1296
+ (rule 1 (vector_size (multi_lane 8 16)) (VectorSize.Size8x16))
1297
+ (rule 1 (vector_size (multi_lane 16 4)) (VectorSize.Size16x4))
1298
+ (rule 1 (vector_size (multi_lane 16 8)) (VectorSize.Size16x8))
1299
+ (rule 1 (vector_size (multi_lane 32 2)) (VectorSize.Size32x2))
1300
+ (rule 1 (vector_size (multi_lane 32 4)) (VectorSize.Size32x4))
1301
+ (rule 1 (vector_size (multi_lane 64 2)) (VectorSize.Size64x2))
1302
+ (rule (vector_size (dynamic_lane 8 8)) (VectorSize.Size8x8))
1303
+ (rule (vector_size (dynamic_lane 8 16)) (VectorSize.Size8x16))
1304
+ (rule (vector_size (dynamic_lane 16 4)) (VectorSize.Size16x4))
1305
+ (rule (vector_size (dynamic_lane 16 8)) (VectorSize.Size16x8))
1306
+ (rule (vector_size (dynamic_lane 32 2)) (VectorSize.Size32x2))
1307
+ (rule (vector_size (dynamic_lane 32 4)) (VectorSize.Size32x4))
1308
+ (rule (vector_size (dynamic_lane 64 2)) (VectorSize.Size64x2))
1309
+
1310
+ ;; A floating-point unit (FPU) operation with one arg.
1311
+ (type FPUOp1
1312
+ (enum
1313
+ (Abs)
1314
+ (Neg)
1315
+ (Sqrt)
1316
+ (Cvt32To64)
1317
+ (Cvt64To32)
1318
+ ))
1319
+
1320
+ ;; A floating-point unit (FPU) operation with two args.
1321
+ (type FPUOp2
1322
+ (enum
1323
+ (Add)
1324
+ (Sub)
1325
+ (Mul)
1326
+ (Div)
1327
+ (Max)
1328
+ (Min)
1329
+ ))
1330
+
1331
+ ;; A floating-point unit (FPU) operation with three args.
1332
+ (type FPUOp3
1333
+ (enum
1334
+ (MAdd)
1335
+ ))
1336
+
1337
+ ;; A conversion from an FP to an integer value.
1338
+ (type FpuToIntOp
1339
+ (enum
1340
+ (F32ToU32)
1341
+ (F32ToI32)
1342
+ (F32ToU64)
1343
+ (F32ToI64)
1344
+ (F64ToU32)
1345
+ (F64ToI32)
1346
+ (F64ToU64)
1347
+ (F64ToI64)
1348
+ ))
1349
+
1350
+ ;; A conversion from an integer to an FP value.
1351
+ (type IntToFpuOp
1352
+ (enum
1353
+ (U32ToF32)
1354
+ (I32ToF32)
1355
+ (U32ToF64)
1356
+ (I32ToF64)
1357
+ (U64ToF32)
1358
+ (I64ToF32)
1359
+ (U64ToF64)
1360
+ (I64ToF64)
1361
+ ))
1362
+
1363
+ ;; Modes for FP rounding ops: round down (floor) or up (ceil), or toward zero (trunc), or to
1364
+ ;; nearest, and for 32- or 64-bit FP values.
1365
+ (type FpuRoundMode
1366
+ (enum
1367
+ (Minus32)
1368
+ (Minus64)
1369
+ (Plus32)
1370
+ (Plus64)
1371
+ (Zero32)
1372
+ (Zero64)
1373
+ (Nearest32)
1374
+ (Nearest64)
1375
+ ))
1376
+
1377
+ ;; Type of vector element extensions.
1378
+ (type VecExtendOp
1379
+ (enum
1380
+ ;; Signed extension
1381
+ (Sxtl)
1382
+ ;; Unsigned extension
1383
+ (Uxtl)
1384
+ ))
1385
+
1386
+ ;; A vector ALU operation.
1387
+ (type VecALUOp
1388
+ (enum
1389
+ ;; Signed saturating add
1390
+ (Sqadd)
1391
+ ;; Unsigned saturating add
1392
+ (Uqadd)
1393
+ ;; Signed saturating subtract
1394
+ (Sqsub)
1395
+ ;; Unsigned saturating subtract
1396
+ (Uqsub)
1397
+ ;; Compare bitwise equal
1398
+ (Cmeq)
1399
+ ;; Compare signed greater than or equal
1400
+ (Cmge)
1401
+ ;; Compare signed greater than
1402
+ (Cmgt)
1403
+ ;; Compare unsigned higher
1404
+ (Cmhs)
1405
+ ;; Compare unsigned higher or same
1406
+ (Cmhi)
1407
+ ;; Floating-point compare equal
1408
+ (Fcmeq)
1409
+ ;; Floating-point compare greater than
1410
+ (Fcmgt)
1411
+ ;; Floating-point compare greater than or equal
1412
+ (Fcmge)
1413
+ ;; Bitwise and
1414
+ (And)
1415
+ ;; Bitwise bit clear
1416
+ (Bic)
1417
+ ;; Bitwise inclusive or
1418
+ (Orr)
1419
+ ;; Bitwise exclusive or
1420
+ (Eor)
1421
+ ;; Unsigned maximum pairwise
1422
+ (Umaxp)
1423
+ ;; Add
1424
+ (Add)
1425
+ ;; Subtract
1426
+ (Sub)
1427
+ ;; Multiply
1428
+ (Mul)
1429
+ ;; Signed shift left
1430
+ (Sshl)
1431
+ ;; Unsigned shift left
1432
+ (Ushl)
1433
+ ;; Unsigned minimum
1434
+ (Umin)
1435
+ ;; Signed minimum
1436
+ (Smin)
1437
+ ;; Unsigned maximum
1438
+ (Umax)
1439
+ ;; Signed maximum
1440
+ (Smax)
1441
+ ;; Unsigned rounding halving add
1442
+ (Urhadd)
1443
+ ;; Floating-point add
1444
+ (Fadd)
1445
+ ;; Floating-point subtract
1446
+ (Fsub)
1447
+ ;; Floating-point divide
1448
+ (Fdiv)
1449
+ ;; Floating-point maximum
1450
+ (Fmax)
1451
+ ;; Floating-point minimum
1452
+ (Fmin)
1453
+ ;; Floating-point multiply
1454
+ (Fmul)
1455
+ ;; Add pairwise
1456
+ (Addp)
1457
+ ;; Zip vectors (primary) [meaning, high halves]
1458
+ (Zip1)
1459
+ ;; Zip vectors (secondary)
1460
+ (Zip2)
1461
+ ;; Signed saturating rounding doubling multiply returning high half
1462
+ (Sqrdmulh)
1463
+ ;; Unzip vectors (primary)
1464
+ (Uzp1)
1465
+ ;; Unzip vectors (secondary)
1466
+ (Uzp2)
1467
+ ;; Transpose vectors (primary)
1468
+ (Trn1)
1469
+ ;; Transpose vectors (secondary)
1470
+ (Trn2)
1471
+ ))
1472
+
1473
+ ;; A Vector ALU operation which modifies a source register.
1474
+ (type VecALUModOp
1475
+ (enum
1476
+ ;; Bitwise select
1477
+ (Bsl)
1478
+ ;; Floating-point fused multiply-add vectors
1479
+ (Fmla)
1480
+ ;; Floating-point fused multiply-subtract vectors
1481
+ (Fmls)
1482
+ ))
1483
+
1484
+ ;; A Vector miscellaneous operation with two registers.
1485
+ (type VecMisc2
1486
+ (enum
1487
+ ;; Bitwise NOT
1488
+ (Not)
1489
+ ;; Negate
1490
+ (Neg)
1491
+ ;; Absolute value
1492
+ (Abs)
1493
+ ;; Floating-point absolute value
1494
+ (Fabs)
1495
+ ;; Floating-point negate
1496
+ (Fneg)
1497
+ ;; Floating-point square root
1498
+ (Fsqrt)
1499
+ ;; Reverse elements in 16-bit lanes
1500
+ (Rev16)
1501
+ ;; Reverse elements in 32-bit lanes
1502
+ (Rev32)
1503
+ ;; Reverse elements in 64-bit doublewords
1504
+ (Rev64)
1505
+ ;; Floating-point convert to signed integer, rounding toward zero
1506
+ (Fcvtzs)
1507
+ ;; Floating-point convert to unsigned integer, rounding toward zero
1508
+ (Fcvtzu)
1509
+ ;; Signed integer convert to floating-point
1510
+ (Scvtf)
1511
+ ;; Unsigned integer convert to floating-point
1512
+ (Ucvtf)
1513
+ ;; Floating point round to integral, rounding towards nearest
1514
+ (Frintn)
1515
+ ;; Floating point round to integral, rounding towards zero
1516
+ (Frintz)
1517
+ ;; Floating point round to integral, rounding towards minus infinity
1518
+ (Frintm)
1519
+ ;; Floating point round to integral, rounding towards plus infinity
1520
+ (Frintp)
1521
+ ;; Population count per byte
1522
+ (Cnt)
1523
+ ;; Compare bitwise equal to 0
1524
+ (Cmeq0)
1525
+ ;; Compare signed greater than or equal to 0
1526
+ (Cmge0)
1527
+ ;; Compare signed greater than 0
1528
+ (Cmgt0)
1529
+ ;; Compare signed less than or equal to 0
1530
+ (Cmle0)
1531
+ ;; Compare signed less than 0
1532
+ (Cmlt0)
1533
+ ;; Floating point compare equal to 0
1534
+ (Fcmeq0)
1535
+ ;; Floating point compare greater than or equal to 0
1536
+ (Fcmge0)
1537
+ ;; Floating point compare greater than 0
1538
+ (Fcmgt0)
1539
+ ;; Floating point compare less than or equal to 0
1540
+ (Fcmle0)
1541
+ ;; Floating point compare less than 0
1542
+ (Fcmlt0)
1543
+ ))
1544
+
1545
+ ;; A vector widening operation with one argument.
1546
+ (type VecRRLongOp
1547
+ (enum
1548
+ ;; Floating-point convert to higher precision long, 16-bit elements
1549
+ (Fcvtl16)
1550
+ ;; Floating-point convert to higher precision long, 32-bit elements
1551
+ (Fcvtl32)
1552
+ ;; Shift left long (by element size), 8-bit elements
1553
+ (Shll8)
1554
+ ;; Shift left long (by element size), 16-bit elements
1555
+ (Shll16)
1556
+ ;; Shift left long (by element size), 32-bit elements
1557
+ (Shll32)
1558
+ ))
1559
+
1560
+ ;; A vector narrowing operation with one argument.
1561
+ (type VecRRNarrowOp
1562
+ (enum
1563
+ ;; Extract narrow.
1564
+ (Xtn)
1565
+ ;; Signed saturating extract narrow.
1566
+ (Sqxtn)
1567
+ ;; Signed saturating extract unsigned narrow.
1568
+ (Sqxtun)
1569
+ ;; Unsigned saturating extract narrow.
1570
+ (Uqxtn)
1571
+ ;; Floating-point convert to lower precision narrow.
1572
+ (Fcvtn)
1573
+ ))
1574
+
1575
+ (type VecRRRLongOp
1576
+ (enum
1577
+ ;; Signed multiply long.
1578
+ (Smull8)
1579
+ (Smull16)
1580
+ (Smull32)
1581
+ ;; Unsigned multiply long.
1582
+ (Umull8)
1583
+ (Umull16)
1584
+ (Umull32)
1585
+ ))
1586
+
1587
+ (type VecRRRLongModOp
1588
+ (enum
1589
+ ;; Unsigned multiply add long
1590
+ (Umlal8)
1591
+ (Umlal16)
1592
+ (Umlal32)
1593
+ ))
1594
+
1595
+ ;; A vector operation on a pair of elements with one register.
1596
+ (type VecPairOp
1597
+ (enum
1598
+ ;; Add pair of elements
1599
+ (Addp)
1600
+ ))
1601
+
1602
+ ;; 1-operand vector instruction that extends elements of the input register
1603
+ ;; and operates on a pair of elements.
1604
+ (type VecRRPairLongOp
1605
+ (enum
1606
+ ;; Sign extend and add pair of elements
1607
+ (Saddlp8)
1608
+ (Saddlp16)
1609
+ ;; Unsigned extend and add pair of elements
1610
+ (Uaddlp8)
1611
+ (Uaddlp16)
1612
+ ))
1613
+
1614
+ ;; An operation across the lanes of vectors.
1615
+ (type VecLanesOp
1616
+ (enum
1617
+ ;; Integer addition across a vector
1618
+ (Addv)
1619
+ ;; Unsigned minimum across a vector
1620
+ (Uminv)
1621
+ ))
1622
+
1623
+ ;; A shift-by-immediate operation on each lane of a vector.
1624
+ (type VecShiftImmOp
1625
+ (enum
1626
+ ;; Unsigned shift left
1627
+ (Shl)
1628
+ ;; Unsigned shift right
1629
+ (Ushr)
1630
+ ;; Signed shift right
1631
+ (Sshr)
1632
+ ))
1633
+
1634
+ ;; Destructive shift-by-immediate operation on each lane of a vector.
1635
+ (type VecShiftImmModOp
1636
+ (enum
1637
+ ;; Shift left and insert
1638
+ (Sli)
1639
+ ))
1640
+
1641
+ ;; Atomic read-modify-write operations with acquire-release semantics
1642
+ (type AtomicRMWOp
1643
+ (enum
1644
+ (Add)
1645
+ (Clr)
1646
+ (Eor)
1647
+ (Set)
1648
+ (Smax)
1649
+ (Smin)
1650
+ (Umax)
1651
+ (Umin)
1652
+ (Swp)
1653
+ ))
1654
+
1655
+ ;; Atomic read-modify-write operations, with acquire-release semantics,
1656
+ ;; implemented with a loop.
1657
+ (type AtomicRMWLoopOp
1658
+ (enum
1659
+ (Add)
1660
+ (Sub)
1661
+ (And)
1662
+ (Nand)
1663
+ (Eor)
1664
+ (Orr)
1665
+ (Smax)
1666
+ (Smin)
1667
+ (Umax)
1668
+ (Umin)
1669
+ (Xchg)
1670
+ ))
1671
+
1672
+ ;; Keys for instruction address PACs
1673
+ (type APIKey
1674
+ (enum
1675
+ ;; API key A with the modifier of SP
1676
+ (ASP)
1677
+ ;; API key B with the modifier of SP
1678
+ (BSP)
1679
+ ;; API key A with the modifier of zero
1680
+ (AZ)
1681
+ ;; API key B with the modifier of zero
1682
+ (BZ)
1683
+ ))
1684
+
1685
+ ;; Branch target types
1686
+ (type BranchTargetType
1687
+ (enum
1688
+ (None)
1689
+ (C)
1690
+ (J)
1691
+ (JC)
1692
+ ))
1693
+
1694
+ ;; Extractors for target features ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1695
+ (decl pure partial sign_return_address_disabled () Unit)
1696
+ (extern constructor sign_return_address_disabled sign_return_address_disabled)
1697
+
1698
+ (decl use_lse () Inst)
1699
+ (extern extractor use_lse use_lse)
1700
+
1701
+ ;; Extractor helpers for various immmediate constants ;;;;;;;;;;;;;;;;;;;;;;;;;;
1702
+
1703
+ (decl pure partial move_wide_const_from_u64 (Type u64) MoveWideConst)
1704
+ (extern constructor move_wide_const_from_u64 move_wide_const_from_u64)
1705
+
1706
+ (decl pure partial move_wide_const_from_inverted_u64 (Type u64) MoveWideConst)
1707
+ (extern constructor move_wide_const_from_inverted_u64 move_wide_const_from_inverted_u64)
1708
+
1709
+ (decl pure partial imm_logic_from_u64 (Type u64) ImmLogic)
1710
+ (extern constructor imm_logic_from_u64 imm_logic_from_u64)
1711
+
1712
+ (decl pure partial imm_size_from_type (Type) u16)
1713
+ (extern constructor imm_size_from_type imm_size_from_type)
1714
+
1715
+ (decl pure partial imm_logic_from_imm64 (Type Imm64) ImmLogic)
1716
+ (extern constructor imm_logic_from_imm64 imm_logic_from_imm64)
1717
+
1718
+ (decl pure partial imm_shift_from_imm64 (Type Imm64) ImmShift)
1719
+ (extern constructor imm_shift_from_imm64 imm_shift_from_imm64)
1720
+
1721
+ (decl imm_shift_from_u8 (u8) ImmShift)
1722
+ (extern constructor imm_shift_from_u8 imm_shift_from_u8)
1723
+
1724
+ (decl imm12_from_u64 (Imm12) u64)
1725
+ (extern extractor imm12_from_u64 imm12_from_u64)
1726
+
1727
+ (decl u8_into_uimm5 (u8) UImm5)
1728
+ (extern constructor u8_into_uimm5 u8_into_uimm5)
1729
+
1730
+ (decl u8_into_imm12 (u8) Imm12)
1731
+ (extern constructor u8_into_imm12 u8_into_imm12)
1732
+
1733
+ (decl u64_into_imm_logic (Type u64) ImmLogic)
1734
+ (extern constructor u64_into_imm_logic u64_into_imm_logic)
1735
+
1736
+ (decl branch_target (MachLabel) BranchTarget)
1737
+ (extern constructor branch_target branch_target)
1738
+ (convert MachLabel BranchTarget branch_target)
1739
+
1740
+ (decl targets_jt_space (BoxVecMachLabel) CodeOffset)
1741
+ (extern constructor targets_jt_space targets_jt_space)
1742
+
1743
+ ;; Calculate the minimum floating-point bound for a conversion to floating
1744
+ ;; point from an integer type.
1745
+ ;; Accepts whether the output is signed, the size of the input
1746
+ ;; floating point type in bits, and the size of the output integer type
1747
+ ;; in bits.
1748
+ (decl min_fp_value (bool u8 u8) Reg)
1749
+ (extern constructor min_fp_value min_fp_value)
1750
+
1751
+ ;; Calculate the maximum floating-point bound for a conversion to floating
1752
+ ;; point from an integer type.
1753
+ ;; Accepts whether the output is signed, the size of the input
1754
+ ;; floating point type in bits, and the size of the output integer type
1755
+ ;; in bits.
1756
+ (decl max_fp_value (bool u8 u8) Reg)
1757
+ (extern constructor max_fp_value max_fp_value)
1758
+
1759
+ ;; Constructs an FPUOpRI.Ushr* given the size in bits of the value (or lane)
1760
+ ;; and the amount to shift by.
1761
+ (decl fpu_op_ri_ushr (u8 u8) FPUOpRI)
1762
+ (extern constructor fpu_op_ri_ushr fpu_op_ri_ushr)
1763
+
1764
+ ;; Constructs an FPUOpRIMod.Sli* given the size in bits of the value (or lane)
1765
+ ;; and the amount to shift by.
1766
+ (decl fpu_op_ri_sli (u8 u8) FPUOpRIMod)
1767
+ (extern constructor fpu_op_ri_sli fpu_op_ri_sli)
1768
+
1769
+ (decl pure partial lshr_from_u64 (Type u64) ShiftOpAndAmt)
1770
+ (extern constructor lshr_from_u64 lshr_from_u64)
1771
+
1772
+ (decl pure partial lshl_from_imm64 (Type Imm64) ShiftOpAndAmt)
1773
+ (extern constructor lshl_from_imm64 lshl_from_imm64)
1774
+
1775
+ (decl pure partial lshl_from_u64 (Type u64) ShiftOpAndAmt)
1776
+ (extern constructor lshl_from_u64 lshl_from_u64)
1777
+
1778
+ (decl pure partial ashr_from_u64 (Type u64) ShiftOpAndAmt)
1779
+ (extern constructor ashr_from_u64 ashr_from_u64)
1780
+
1781
+ (decl integral_ty (Type) Type)
1782
+ (extern extractor integral_ty integral_ty)
1783
+
1784
+ (decl valid_atomic_transaction (Type) Type)
1785
+ (extern extractor valid_atomic_transaction valid_atomic_transaction)
1786
+
1787
+ (decl pure partial is_zero_simm9 (SImm9) Unit)
1788
+ (extern constructor is_zero_simm9 is_zero_simm9)
1789
+
1790
+ (decl pure partial is_zero_uimm12 (UImm12Scaled) Unit)
1791
+ (extern constructor is_zero_uimm12 is_zero_uimm12)
1792
+
1793
+ ;; Helper to go directly from a `Value`, when it's an `iconst`, to an `Imm12`.
1794
+ (decl imm12_from_value (Imm12) Value)
1795
+ (extractor
1796
+ (imm12_from_value n)
1797
+ (iconst (u64_from_imm64 (imm12_from_u64 n))))
1798
+
1799
+ ;; Conceptually the same as `imm12_from_value`, but tries negating the constant
1800
+ ;; value (first sign-extending to handle narrow widths).
1801
+ (decl pure partial imm12_from_negated_value (Value) Imm12)
1802
+ (rule
1803
+ (imm12_from_negated_value (has_type ty (iconst n)))
1804
+ (if-let (imm12_from_u64 imm) (i64_as_u64 (i64_neg (i64_sextend_imm64 ty n))))
1805
+ imm)
1806
+
1807
+ ;; Helper type to represent a value and an extend operation fused together.
1808
+ (type ExtendedValue extern (enum))
1809
+ (decl extended_value_from_value (ExtendedValue) Value)
1810
+ (extern extractor extended_value_from_value extended_value_from_value)
1811
+
1812
+ ;; Constructors used to poke at the fields of an `ExtendedValue`.
1813
+ (decl put_extended_in_reg (ExtendedValue) Reg)
1814
+ (extern constructor put_extended_in_reg put_extended_in_reg)
1815
+ (decl get_extended_op (ExtendedValue) ExtendOp)
1816
+ (extern constructor get_extended_op get_extended_op)
1817
+
1818
+ (decl nzcv (bool bool bool bool) NZCV)
1819
+ (extern constructor nzcv nzcv)
1820
+
1821
+ (decl cond_br_zero (Reg) CondBrKind)
1822
+ (extern constructor cond_br_zero cond_br_zero)
1823
+
1824
+ (decl cond_br_not_zero (Reg) CondBrKind)
1825
+ (extern constructor cond_br_not_zero cond_br_not_zero)
1826
+
1827
+ (decl cond_br_cond (Cond) CondBrKind)
1828
+ (extern constructor cond_br_cond cond_br_cond)
1829
+
1830
+ ;; Instruction creation helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
1831
+
1832
+ ;; Helper for creating the zero register.
1833
+ (decl zero_reg () Reg)
1834
+ (extern constructor zero_reg zero_reg)
1835
+
1836
+ (decl fp_reg () Reg)
1837
+ (extern constructor fp_reg fp_reg)
1838
+
1839
+ (decl stack_reg () Reg)
1840
+ (extern constructor stack_reg stack_reg)
1841
+
1842
+ (decl writable_link_reg () WritableReg)
1843
+ (extern constructor writable_link_reg writable_link_reg)
1844
+
1845
+ (decl writable_zero_reg () WritableReg)
1846
+ (extern constructor writable_zero_reg writable_zero_reg)
1847
+
1848
+ (decl value_regs_zero () ValueRegs)
1849
+ (rule (value_regs_zero)
1850
+ (value_regs
1851
+ (imm $I64 (ImmExtend.Zero) 0)
1852
+ (imm $I64 (ImmExtend.Zero) 0)))
1853
+
1854
+
1855
+ ;; Helper for emitting `MInst.Mov` instructions.
1856
+ (decl mov (Reg Type) Reg)
1857
+ (rule (mov src ty)
1858
+ (let ((dst WritableReg (temp_writable_reg $I64))
1859
+ (_ Unit (emit (MInst.Mov (operand_size ty) dst src))))
1860
+ dst))
1861
+
1862
+ ;; Helper for emitting `MInst.MovZ` instructions.
1863
+ (decl movz (MoveWideConst OperandSize) Reg)
1864
+ (rule (movz imm size)
1865
+ (let ((dst WritableReg (temp_writable_reg $I64))
1866
+ (_ Unit (emit (MInst.MovWide (MoveWideOp.MovZ) dst imm size))))
1867
+ dst))
1868
+
1869
+ ;; Helper for emitting `MInst.MovN` instructions.
1870
+ (decl movn (MoveWideConst OperandSize) Reg)
1871
+ (rule (movn imm size)
1872
+ (let ((dst WritableReg (temp_writable_reg $I64))
1873
+ (_ Unit (emit (MInst.MovWide (MoveWideOp.MovN) dst imm size))))
1874
+ dst))
1875
+
1876
+ ;; Helper for emitting `MInst.AluRRImmLogic` instructions.
1877
+ (decl alu_rr_imm_logic (ALUOp Type Reg ImmLogic) Reg)
1878
+ (rule (alu_rr_imm_logic op ty src imm)
1879
+ (let ((dst WritableReg (temp_writable_reg $I64))
1880
+ (_ Unit (emit (MInst.AluRRImmLogic op (operand_size ty) dst src imm))))
1881
+ dst))
1882
+
1883
+ ;; Helper for emitting `MInst.AluRRImmShift` instructions.
1884
+ (decl alu_rr_imm_shift (ALUOp Type Reg ImmShift) Reg)
1885
+ (rule (alu_rr_imm_shift op ty src imm)
1886
+ (let ((dst WritableReg (temp_writable_reg $I64))
1887
+ (_ Unit (emit (MInst.AluRRImmShift op (operand_size ty) dst src imm))))
1888
+ dst))
1889
+
1890
+ ;; Helper for emitting `MInst.AluRRR` instructions.
1891
+ (decl alu_rrr (ALUOp Type Reg Reg) Reg)
1892
+ (rule (alu_rrr op ty src1 src2)
1893
+ (let ((dst WritableReg (temp_writable_reg $I64))
1894
+ (_ Unit (emit (MInst.AluRRR op (operand_size ty) dst src1 src2))))
1895
+ dst))
1896
+
1897
+ ;; Helper for emitting `MInst.VecRRR` instructions.
1898
+ (decl vec_rrr (VecALUOp Reg Reg VectorSize) Reg)
1899
+ (rule (vec_rrr op src1 src2 size)
1900
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1901
+ (_ Unit (emit (MInst.VecRRR op dst src1 src2 size))))
1902
+ dst))
1903
+
1904
+ ;; Helper for emitting `MInst.FpuRR` instructions.
1905
+ (decl fpu_rr (FPUOp1 Reg ScalarSize) Reg)
1906
+ (rule (fpu_rr op src size)
1907
+ (let ((dst WritableReg (temp_writable_reg $F64))
1908
+ (_ Unit (emit (MInst.FpuRR op size dst src))))
1909
+ dst))
1910
+
1911
+ ;; Helper for emitting `MInst.VecRRRMod` instructions which use three registers,
1912
+ ;; one of which is both source and output.
1913
+ (decl vec_rrr_mod (VecALUModOp Reg Reg Reg VectorSize) Reg)
1914
+ (rule (vec_rrr_mod op src1 src2 src3 size)
1915
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1916
+ (_1 Unit (emit (MInst.VecRRRMod op dst src1 src2 src3 size))))
1917
+ dst))
1918
+
1919
+ ;; Helper for emitting `MInst.VecFmlaElem` instructions which use three registers,
1920
+ ;; one of which is both source and output.
1921
+ (decl vec_fmla_elem (VecALUModOp Reg Reg Reg VectorSize u8) Reg)
1922
+ (rule (vec_fmla_elem op src1 src2 src3 size idx)
1923
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1924
+ (_1 Unit (emit (MInst.VecFmlaElem op dst src1 src2 src3 size idx))))
1925
+ dst))
1926
+
1927
+ (decl fpu_rri (FPUOpRI Reg) Reg)
1928
+ (rule (fpu_rri op src)
1929
+ (let ((dst WritableReg (temp_writable_reg $F64))
1930
+ (_ Unit (emit (MInst.FpuRRI op dst src))))
1931
+ dst))
1932
+
1933
+ (decl fpu_rri_mod (FPUOpRIMod Reg Reg) Reg)
1934
+ (rule (fpu_rri_mod op dst_src src)
1935
+ (let ((dst WritableReg (temp_writable_reg $F64))
1936
+ (_ Unit (emit (MInst.FpuRRIMod op dst dst_src src))))
1937
+ dst))
1938
+
1939
+ ;; Helper for emitting `MInst.FpuRRR` instructions.
1940
+ (decl fpu_rrr (FPUOp2 Reg Reg ScalarSize) Reg)
1941
+ (rule (fpu_rrr op src1 src2 size)
1942
+ (let ((dst WritableReg (temp_writable_reg $F64))
1943
+ (_ Unit (emit (MInst.FpuRRR op size dst src1 src2))))
1944
+ dst))
1945
+
1946
+ ;; Helper for emitting `MInst.FpuRRRR` instructions.
1947
+ (decl fpu_rrrr (FPUOp3 ScalarSize Reg Reg Reg) Reg)
1948
+ (rule (fpu_rrrr size op src1 src2 src3)
1949
+ (let ((dst WritableReg (temp_writable_reg $F64))
1950
+ (_ Unit (emit (MInst.FpuRRRR size op dst src1 src2 src3))))
1951
+ dst))
1952
+
1953
+ ;; Helper for emitting `MInst.FpuCmp` instructions.
1954
+ (decl fpu_cmp (ScalarSize Reg Reg) ProducesFlags)
1955
+ (rule (fpu_cmp size rn rm)
1956
+ (ProducesFlags.ProducesFlagsSideEffect
1957
+ (MInst.FpuCmp size rn rm)))
1958
+
1959
+ ;; Helper for emitting `MInst.VecLanes` instructions.
1960
+ (decl vec_lanes (VecLanesOp Reg VectorSize) Reg)
1961
+ (rule (vec_lanes op src size)
1962
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1963
+ (_ Unit (emit (MInst.VecLanes op dst src size))))
1964
+ dst))
1965
+
1966
+ ;; Helper for emitting `MInst.VecShiftImm` instructions.
1967
+ (decl vec_shift_imm (VecShiftImmOp u8 Reg VectorSize) Reg)
1968
+ (rule (vec_shift_imm op imm src size)
1969
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1970
+ (_ Unit (emit (MInst.VecShiftImm op dst src size imm))))
1971
+ dst))
1972
+
1973
+ ;; Helper for emitting `MInst.VecDup` instructions.
1974
+ (decl vec_dup (Reg VectorSize) Reg)
1975
+ (rule (vec_dup src size)
1976
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1977
+ (_ Unit (emit (MInst.VecDup dst src size))))
1978
+ dst))
1979
+
1980
+ ;; Helper for emitting `MInst.VecDupFromFpu` instructions.
1981
+ (decl vec_dup_from_fpu (Reg VectorSize u8) Reg)
1982
+ (rule (vec_dup_from_fpu src size lane)
1983
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1984
+ (_ Unit (emit (MInst.VecDupFromFpu dst src size lane))))
1985
+ dst))
1986
+
1987
+ ;; Helper for emitting `MInst.VecDupImm` instructions.
1988
+ (decl vec_dup_imm (ASIMDMovModImm bool VectorSize) Reg)
1989
+ (rule (vec_dup_imm imm invert size)
1990
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
1991
+ (_ Unit (emit (MInst.VecDupImm dst imm invert size))))
1992
+ dst))
1993
+
1994
+ ;; Helper for emitting `MInst.AluRRImm12` instructions.
1995
+ (decl alu_rr_imm12 (ALUOp Type Reg Imm12) Reg)
1996
+ (rule (alu_rr_imm12 op ty src imm)
1997
+ (let ((dst WritableReg (temp_writable_reg $I64))
1998
+ (_ Unit (emit (MInst.AluRRImm12 op (operand_size ty) dst src imm))))
1999
+ dst))
2000
+
2001
+ ;; Helper for emitting `MInst.AluRRRShift` instructions.
2002
+ (decl alu_rrr_shift (ALUOp Type Reg Reg ShiftOpAndAmt) Reg)
2003
+ (rule (alu_rrr_shift op ty src1 src2 shift)
2004
+ (let ((dst WritableReg (temp_writable_reg $I64))
2005
+ (_ Unit (emit (MInst.AluRRRShift op (operand_size ty) dst src1 src2 shift))))
2006
+ dst))
2007
+
2008
+ ;; Helper for emitting `cmp` instructions, setting flags, with a right-shifted
2009
+ ;; second operand register.
2010
+ (decl cmp_rr_shift (OperandSize Reg Reg u64) ProducesFlags)
2011
+ (rule (cmp_rr_shift size src1 src2 shift_amount)
2012
+ (if-let shift (lshr_from_u64 $I64 shift_amount))
2013
+ (ProducesFlags.ProducesFlagsSideEffect
2014
+ (MInst.AluRRRShift (ALUOp.SubS) size (writable_zero_reg)
2015
+ src1 src2 shift)))
2016
+
2017
+ ;; Helper for emitting `cmp` instructions, setting flags, with an arithmetic right-shifted
2018
+ ;; second operand register.
2019
+ (decl cmp_rr_shift_asr (OperandSize Reg Reg u64) ProducesFlags)
2020
+ (rule (cmp_rr_shift_asr size src1 src2 shift_amount)
2021
+ (if-let shift (ashr_from_u64 $I64 shift_amount))
2022
+ (ProducesFlags.ProducesFlagsSideEffect
2023
+ (MInst.AluRRRShift (ALUOp.SubS) size (writable_zero_reg)
2024
+ src1 src2 shift)))
2025
+
2026
+ ;; Helper for emitting `MInst.AluRRRExtend` instructions.
2027
+ (decl alu_rrr_extend (ALUOp Type Reg Reg ExtendOp) Reg)
2028
+ (rule (alu_rrr_extend op ty src1 src2 extend)
2029
+ (let ((dst WritableReg (temp_writable_reg $I64))
2030
+ (_ Unit (emit (MInst.AluRRRExtend op (operand_size ty) dst src1 src2 extend))))
2031
+ dst))
2032
+
2033
+ ;; Same as `alu_rrr_extend`, but takes an `ExtendedValue` packed "pair" instead
2034
+ ;; of a `Reg` and an `ExtendOp`.
2035
+ (decl alu_rr_extend_reg (ALUOp Type Reg ExtendedValue) Reg)
2036
+ (rule (alu_rr_extend_reg op ty src1 extended_reg)
2037
+ (let ((src2 Reg (put_extended_in_reg extended_reg))
2038
+ (extend ExtendOp (get_extended_op extended_reg)))
2039
+ (alu_rrr_extend op ty src1 src2 extend)))
2040
+
2041
+ ;; Helper for emitting `MInst.AluRRRR` instructions.
2042
+ (decl alu_rrrr (ALUOp3 Type Reg Reg Reg) Reg)
2043
+ (rule (alu_rrrr op ty src1 src2 src3)
2044
+ (let ((dst WritableReg (temp_writable_reg $I64))
2045
+ (_ Unit (emit (MInst.AluRRRR op (operand_size ty) dst src1 src2 src3))))
2046
+ dst))
2047
+
2048
+ ;; Helper for emitting paired `MInst.AluRRR` instructions
2049
+ (decl alu_rrr_with_flags_paired (Type Reg Reg ALUOp) ProducesFlags)
2050
+ (rule (alu_rrr_with_flags_paired ty src1 src2 alu_op)
2051
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2052
+ (ProducesFlags.ProducesFlagsReturnsResultWithConsumer
2053
+ (MInst.AluRRR alu_op (operand_size ty) dst src1 src2)
2054
+ dst)))
2055
+
2056
+ ;; Should only be used for AdcS and SbcS
2057
+ (decl alu_rrr_with_flags_chained (Type Reg Reg ALUOp) ConsumesAndProducesFlags)
2058
+ (rule (alu_rrr_with_flags_chained ty src1 src2 alu_op)
2059
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2060
+ (ConsumesAndProducesFlags.ReturnsReg
2061
+ (MInst.AluRRR alu_op (operand_size ty) dst src1 src2)
2062
+ dst)))
2063
+
2064
+ ;; Helper for emitting `MInst.BitRR` instructions.
2065
+ (decl bit_rr (BitOp Type Reg) Reg)
2066
+ (rule (bit_rr op ty src)
2067
+ (let ((dst WritableReg (temp_writable_reg $I64))
2068
+ (_ Unit (emit (MInst.BitRR op (operand_size ty) dst src))))
2069
+ dst))
2070
+
2071
+ ;; Helper for emitting `adds` instructions.
2072
+ (decl add_with_flags_paired (Type Reg Reg) ProducesFlags)
2073
+ (rule (add_with_flags_paired ty src1 src2)
2074
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2075
+ (ProducesFlags.ProducesFlagsReturnsResultWithConsumer
2076
+ (MInst.AluRRR (ALUOp.AddS) (operand_size ty) dst src1 src2)
2077
+ dst)))
2078
+
2079
+ ;; Helper for emitting `adc` instructions.
2080
+ (decl adc_paired (Type Reg Reg) ConsumesFlags)
2081
+ (rule (adc_paired ty src1 src2)
2082
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2083
+ (ConsumesFlags.ConsumesFlagsReturnsResultWithProducer
2084
+ (MInst.AluRRR (ALUOp.Adc) (operand_size ty) dst src1 src2)
2085
+ dst)))
2086
+
2087
+ ;; Helper for emitting `subs` instructions.
2088
+ (decl sub_with_flags_paired (Type Reg Reg) ProducesFlags)
2089
+ (rule (sub_with_flags_paired ty src1 src2)
2090
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2091
+ (ProducesFlags.ProducesFlagsReturnsResultWithConsumer
2092
+ (MInst.AluRRR (ALUOp.SubS) (operand_size ty) dst src1 src2)
2093
+ dst)))
2094
+
2095
+ ;; Helper for materializing a boolean value into a register from
2096
+ ;; flags.
2097
+ (decl materialize_bool_result (Cond) ConsumesFlags)
2098
+ (rule (materialize_bool_result cond)
2099
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2100
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2101
+ (MInst.CSet dst cond)
2102
+ dst)))
2103
+
2104
+ (decl cmn_imm (OperandSize Reg Imm12) ProducesFlags)
2105
+ (rule (cmn_imm size src1 src2)
2106
+ (ProducesFlags.ProducesFlagsSideEffect
2107
+ (MInst.AluRRImm12 (ALUOp.AddS) size (writable_zero_reg)
2108
+ src1 src2)))
2109
+
2110
+ (decl cmp (OperandSize Reg Reg) ProducesFlags)
2111
+ (rule (cmp size src1 src2)
2112
+ (ProducesFlags.ProducesFlagsSideEffect
2113
+ (MInst.AluRRR (ALUOp.SubS) size (writable_zero_reg)
2114
+ src1 src2)))
2115
+
2116
+ (decl cmp_imm (OperandSize Reg Imm12) ProducesFlags)
2117
+ (rule (cmp_imm size src1 src2)
2118
+ (ProducesFlags.ProducesFlagsSideEffect
2119
+ (MInst.AluRRImm12 (ALUOp.SubS) size (writable_zero_reg)
2120
+ src1 src2)))
2121
+
2122
+ (decl cmp64_imm (Reg Imm12) ProducesFlags)
2123
+ (rule (cmp64_imm src1 src2)
2124
+ (cmp_imm (OperandSize.Size64) src1 src2))
2125
+
2126
+ (decl cmp_extend (OperandSize Reg Reg ExtendOp) ProducesFlags)
2127
+ (rule (cmp_extend size src1 src2 extend)
2128
+ (ProducesFlags.ProducesFlagsSideEffect
2129
+ (MInst.AluRRRExtend (ALUOp.SubS) size (writable_zero_reg)
2130
+ src1 src2 extend)))
2131
+
2132
+ ;; Helper for emitting `sbc` instructions.
2133
+ (decl sbc_paired (Type Reg Reg) ConsumesFlags)
2134
+ (rule (sbc_paired ty src1 src2)
2135
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2136
+ (ConsumesFlags.ConsumesFlagsReturnsResultWithProducer
2137
+ (MInst.AluRRR (ALUOp.Sbc) (operand_size ty) dst src1 src2)
2138
+ dst)))
2139
+
2140
+ ;; Helper for emitting `MInst.VecMisc` instructions.
2141
+ (decl vec_misc (VecMisc2 Reg VectorSize) Reg)
2142
+ (rule (vec_misc op src size)
2143
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2144
+ (_ Unit (emit (MInst.VecMisc op dst src size))))
2145
+ dst))
2146
+
2147
+ ;; Helper for emitting `MInst.VecTbl` instructions.
2148
+ (decl vec_tbl (Reg Reg) Reg)
2149
+ (rule (vec_tbl rn rm)
2150
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2151
+ (_ Unit (emit (MInst.VecTbl dst rn rm))))
2152
+ dst))
2153
+
2154
+ (decl vec_tbl_ext (Reg Reg Reg) Reg)
2155
+ (rule (vec_tbl_ext ri rn rm)
2156
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2157
+ (_ Unit (emit (MInst.VecTblExt dst ri rn rm))))
2158
+ dst))
2159
+
2160
+ ;; Helper for emitting `MInst.VecTbl2` instructions.
2161
+ (decl vec_tbl2 (Reg Reg Reg Type) Reg)
2162
+ (rule (vec_tbl2 rn rn2 rm ty)
2163
+ (let (
2164
+ (dst WritableReg (temp_writable_reg $I8X16))
2165
+ (_ Unit (emit (MInst.VecTbl2 dst rn rn2 rm)))
2166
+ )
2167
+ dst))
2168
+
2169
+ ;; Helper for emitting `MInst.VecTbl2Ext` instructions.
2170
+ (decl vec_tbl2_ext (Reg Reg Reg Reg Type) Reg)
2171
+ (rule (vec_tbl2_ext ri rn rn2 rm ty)
2172
+ (let (
2173
+ (dst WritableReg (temp_writable_reg $I8X16))
2174
+ (_ Unit (emit (MInst.VecTbl2Ext dst ri rn rn2 rm)))
2175
+ )
2176
+ dst))
2177
+
2178
+ ;; Helper for emitting `MInst.VecRRRLong` instructions.
2179
+ (decl vec_rrr_long (VecRRRLongOp Reg Reg bool) Reg)
2180
+ (rule (vec_rrr_long op src1 src2 high_half)
2181
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2182
+ (_ Unit (emit (MInst.VecRRRLong op dst src1 src2 high_half))))
2183
+ dst))
2184
+
2185
+ ;; Helper for emitting `MInst.VecRRPairLong` instructions.
2186
+ (decl vec_rr_pair_long (VecRRPairLongOp Reg) Reg)
2187
+ (rule (vec_rr_pair_long op src)
2188
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2189
+ (_ Unit (emit (MInst.VecRRPairLong op dst src))))
2190
+ dst))
2191
+
2192
+ ;; Helper for emitting `MInst.VecRRRLongMod` instructions.
2193
+ (decl vec_rrrr_long (VecRRRLongModOp Reg Reg Reg bool) Reg)
2194
+ (rule (vec_rrrr_long op src1 src2 src3 high_half)
2195
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2196
+ (_ Unit (emit (MInst.VecRRRLongMod op dst src1 src2 src3 high_half))))
2197
+ dst))
2198
+
2199
+ ;; Helper for emitting `MInst.VecRRNarrow` instructions.
2200
+ (decl vec_rr_narrow_low (VecRRNarrowOp Reg ScalarSize) Reg)
2201
+ (rule (vec_rr_narrow_low op src size)
2202
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2203
+ (_ Unit (emit (MInst.VecRRNarrowLow op dst src size))))
2204
+ dst))
2205
+
2206
+ ;; Helper for emitting `MInst.VecRRNarrow` instructions which update the
2207
+ ;; high half of the destination register.
2208
+ (decl vec_rr_narrow_high (VecRRNarrowOp Reg Reg ScalarSize) Reg)
2209
+ (rule (vec_rr_narrow_high op mod src size)
2210
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2211
+ (_ Unit (emit (MInst.VecRRNarrowHigh op dst mod src size))))
2212
+ dst))
2213
+
2214
+ ;; Helper for emitting `MInst.VecRRLong` instructions.
2215
+ (decl vec_rr_long (VecRRLongOp Reg bool) Reg)
2216
+ (rule (vec_rr_long op src high_half)
2217
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2218
+ (_ Unit (emit (MInst.VecRRLong op dst src high_half))))
2219
+ dst))
2220
+
2221
+ ;; Helper for emitting `MInst.FpuCSel32` / `MInst.FpuCSel64`
2222
+ ;; instructions.
2223
+ (decl fpu_csel (Type Cond Reg Reg) ConsumesFlags)
2224
+ (rule (fpu_csel $F32 cond if_true if_false)
2225
+ (let ((dst WritableReg (temp_writable_reg $F32)))
2226
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2227
+ (MInst.FpuCSel32 dst if_true if_false cond)
2228
+ dst)))
2229
+
2230
+ (rule (fpu_csel $F64 cond if_true if_false)
2231
+ (let ((dst WritableReg (temp_writable_reg $F64)))
2232
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2233
+ (MInst.FpuCSel64 dst if_true if_false cond)
2234
+ dst)))
2235
+
2236
+ ;; Helper for emitting `MInst.VecCSel` instructions.
2237
+ (decl vec_csel (Cond Reg Reg) ConsumesFlags)
2238
+ (rule (vec_csel cond if_true if_false)
2239
+ (let ((dst WritableReg (temp_writable_reg $I8X16)))
2240
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2241
+ (MInst.VecCSel dst if_true if_false cond)
2242
+ dst)))
2243
+
2244
+ ;; Helper for emitting `MInst.FpuRound` instructions.
2245
+ (decl fpu_round (FpuRoundMode Reg) Reg)
2246
+ (rule (fpu_round op rn)
2247
+ (let ((dst WritableReg (temp_writable_reg $F64))
2248
+ (_ Unit (emit (MInst.FpuRound op dst rn))))
2249
+ dst))
2250
+
2251
+ ;; Helper for emitting `MInst.FpuMove64` and `MInst.FpuMove128` instructions.
2252
+ (decl fpu_move (Type Reg) Reg)
2253
+ (rule (fpu_move _ src)
2254
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2255
+ (_ Unit (emit (MInst.FpuMove128 dst src))))
2256
+ dst))
2257
+ (rule 1 (fpu_move (fits_in_64 _) src)
2258
+ (let ((dst WritableReg (temp_writable_reg $F64))
2259
+ (_ Unit (emit (MInst.FpuMove64 dst src))))
2260
+ dst))
2261
+
2262
+ ;; Helper for emitting `MInst.MovToFpu` instructions.
2263
+ (decl mov_to_fpu (Reg ScalarSize) Reg)
2264
+ (rule (mov_to_fpu x size)
2265
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2266
+ (_ Unit (emit (MInst.MovToFpu dst x size))))
2267
+ dst))
2268
+
2269
+ ;; Helper for emitting `MInst.FpuMoveFPImm` instructions.
2270
+ (decl fpu_move_fp_imm (ASIMDFPModImm ScalarSize) Reg)
2271
+ (rule (fpu_move_fp_imm imm size)
2272
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2273
+ (_ Unit (emit (MInst.FpuMoveFPImm dst imm size))))
2274
+ dst))
2275
+
2276
+ ;; Helper for emitting `MInst.MovToVec` instructions.
2277
+ (decl mov_to_vec (Reg Reg u8 VectorSize) Reg)
2278
+ (rule (mov_to_vec src1 src2 lane size)
2279
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2280
+ (_ Unit (emit (MInst.MovToVec dst src1 src2 lane size))))
2281
+ dst))
2282
+
2283
+ ;; Helper for emitting `MInst.VecMovElement` instructions.
2284
+ (decl mov_vec_elem (Reg Reg u8 u8 VectorSize) Reg)
2285
+ (rule (mov_vec_elem src1 src2 dst_idx src_idx size)
2286
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2287
+ (_ Unit (emit (MInst.VecMovElement dst src1 src2 dst_idx src_idx size))))
2288
+ dst))
2289
+
2290
+ ;; Helper for emitting `MInst.MovFromVec` instructions.
2291
+ (decl mov_from_vec (Reg u8 ScalarSize) Reg)
2292
+ (rule (mov_from_vec rn idx size)
2293
+ (let ((dst WritableReg (temp_writable_reg $I64))
2294
+ (_ Unit (emit (MInst.MovFromVec dst rn idx size))))
2295
+ dst))
2296
+
2297
+ ;; Helper for emitting `MInst.MovFromVecSigned` instructions.
2298
+ (decl mov_from_vec_signed (Reg u8 VectorSize OperandSize) Reg)
2299
+ (rule (mov_from_vec_signed rn idx size scalar_size)
2300
+ (let ((dst WritableReg (temp_writable_reg $I64))
2301
+ (_ Unit (emit (MInst.MovFromVecSigned dst rn idx size scalar_size))))
2302
+ dst))
2303
+
2304
+ (decl fpu_move_from_vec (Reg u8 VectorSize) Reg)
2305
+ (rule (fpu_move_from_vec rn idx size)
2306
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2307
+ (_ Unit (emit (MInst.FpuMoveFromVec dst rn idx size))))
2308
+ dst))
2309
+
2310
+ ;; Helper for emitting `MInst.Extend` instructions.
2311
+ (decl extend (Reg bool u8 u8) Reg)
2312
+ (rule (extend rn signed from_bits to_bits)
2313
+ (let ((dst WritableReg (temp_writable_reg $I64))
2314
+ (_ Unit (emit (MInst.Extend dst rn signed from_bits to_bits))))
2315
+ dst))
2316
+
2317
+ ;; Helper for emitting `MInst.FpuExtend` instructions.
2318
+ (decl fpu_extend (Reg ScalarSize) Reg)
2319
+ (rule (fpu_extend src size)
2320
+ (let ((dst WritableReg (temp_writable_reg $F32X4))
2321
+ (_ Unit (emit (MInst.FpuExtend dst src size))))
2322
+ dst))
2323
+
2324
+ ;; Helper for emitting `MInst.VecExtend` instructions.
2325
+ (decl vec_extend (VecExtendOp Reg bool ScalarSize) Reg)
2326
+ (rule (vec_extend op src high_half size)
2327
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2328
+ (_ Unit (emit (MInst.VecExtend op dst src high_half size))))
2329
+ dst))
2330
+
2331
+ ;; Helper for emitting `MInst.VecExtract` instructions.
2332
+ (decl vec_extract (Reg Reg u8) Reg)
2333
+ (rule (vec_extract src1 src2 idx)
2334
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
2335
+ (_ Unit (emit (MInst.VecExtract dst src1 src2 idx))))
2336
+ dst))
2337
+
2338
+ ;; Helper for emitting `MInst.LoadAcquire` instructions.
2339
+ (decl load_acquire (Type MemFlags Reg) Reg)
2340
+ (rule (load_acquire ty flags addr)
2341
+ (let ((dst WritableReg (temp_writable_reg $I64))
2342
+ (_ Unit (emit (MInst.LoadAcquire ty dst addr flags))))
2343
+ dst))
2344
+
2345
+ ;; Helper for emitting `MInst.StoreRelease` instructions.
2346
+ (decl store_release (Type MemFlags Reg Reg) SideEffectNoResult)
2347
+ (rule (store_release ty flags src addr)
2348
+ (SideEffectNoResult.Inst (MInst.StoreRelease ty src addr flags)))
2349
+
2350
+ ;; Helper for generating a `tst` instruction.
2351
+ ;;
2352
+ ;; Produces a `ProducesFlags` rather than a register or emitted instruction
2353
+ ;; which must be paired with `with_flags*` helpers.
2354
+ (decl tst_imm (Type Reg ImmLogic) ProducesFlags)
2355
+ (rule (tst_imm ty reg imm)
2356
+ (ProducesFlags.ProducesFlagsSideEffect
2357
+ (MInst.AluRRImmLogic (ALUOp.AndS)
2358
+ (operand_size ty)
2359
+ (writable_zero_reg)
2360
+ reg
2361
+ imm)))
2362
+
2363
+ ;; Helper for generating a `CSel` instruction.
2364
+ ;;
2365
+ ;; Note that this doesn't actually emit anything, instead it produces a
2366
+ ;; `ConsumesFlags` instruction which must be consumed with `with_flags*`
2367
+ ;; helpers.
2368
+ (decl csel (Cond Reg Reg) ConsumesFlags)
2369
+ (rule (csel cond if_true if_false)
2370
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2371
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2372
+ (MInst.CSel dst cond if_true if_false)
2373
+ dst)))
2374
+
2375
+ ;; Helper for constructing `cset` instructions.
2376
+ (decl cset (Cond) ConsumesFlags)
2377
+ (rule (cset cond)
2378
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2379
+ (ConsumesFlags.ConsumesFlagsReturnsReg (MInst.CSet dst cond) dst)))
2380
+
2381
+ ;; Helper for constructing `cset` instructions, when the flags producer will
2382
+ ;; also return a value.
2383
+ (decl cset_paired (Cond) ConsumesFlags)
2384
+ (rule (cset_paired cond)
2385
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2386
+ (ConsumesFlags.ConsumesFlagsReturnsResultWithProducer (MInst.CSet dst cond) dst)))
2387
+
2388
+ ;; Helper for constructing `csetm` instructions.
2389
+ (decl csetm (Cond) ConsumesFlags)
2390
+ (rule (csetm cond)
2391
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2392
+ (ConsumesFlags.ConsumesFlagsReturnsReg (MInst.CSetm dst cond) dst)))
2393
+
2394
+ ;; Helper for generating a `CSNeg` instruction.
2395
+ ;;
2396
+ ;; Note that this doesn't actually emit anything, instead it produces a
2397
+ ;; `ConsumesFlags` instruction which must be consumed with `with_flags*`
2398
+ ;; helpers.
2399
+ (decl csneg (Cond Reg Reg) ConsumesFlags)
2400
+ (rule (csneg cond if_true if_false)
2401
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2402
+ (ConsumesFlags.ConsumesFlagsReturnsReg
2403
+ (MInst.CSNeg dst cond if_true if_false)
2404
+ dst)))
2405
+
2406
+ ;; Helper for generating `MInst.CCmp` instructions.
2407
+ ;; Creates a new `ProducesFlags` from the supplied `ProducesFlags` followed
2408
+ ;; immediately by the `MInst.CCmp` instruction.
2409
+ (decl ccmp (OperandSize Reg Reg NZCV Cond ProducesFlags) ProducesFlags)
2410
+ (rule (ccmp size rn rm nzcv cond inst_input)
2411
+ (produces_flags_concat inst_input (ProducesFlags.ProducesFlagsSideEffect (MInst.CCmp size rn rm nzcv cond))))
2412
+
2413
+ ;; Helper for generating `MInst.CCmpImm` instructions.
2414
+ (decl ccmp_imm (OperandSize Reg UImm5 NZCV Cond) ConsumesFlags)
2415
+ (rule 1 (ccmp_imm size rn imm nzcv cond)
2416
+ (let ((dst WritableReg (temp_writable_reg $I64)))
2417
+ (ConsumesFlags.ConsumesFlagsTwiceReturnsValueRegs
2418
+ (MInst.CCmpImm size rn imm nzcv cond)
2419
+ (MInst.CSet dst cond)
2420
+ (value_reg dst))))
2421
+
2422
+ ;; Helpers for generating `add` instructions.
2423
+
2424
+ (decl add (Type Reg Reg) Reg)
2425
+ (rule (add ty x y) (alu_rrr (ALUOp.Add) ty x y))
2426
+
2427
+ (decl add_imm (Type Reg Imm12) Reg)
2428
+ (rule (add_imm ty x y) (alu_rr_imm12 (ALUOp.Add) ty x y))
2429
+
2430
+ (decl add_extend (Type Reg ExtendedValue) Reg)
2431
+ (rule (add_extend ty x y) (alu_rr_extend_reg (ALUOp.Add) ty x y))
2432
+
2433
+ (decl add_extend_op (Type Reg Reg ExtendOp) Reg)
2434
+ (rule (add_extend_op ty x y extend) (alu_rrr_extend (ALUOp.Add) ty x y extend))
2435
+
2436
+ (decl add_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2437
+ (rule (add_shift ty x y z) (alu_rrr_shift (ALUOp.Add) ty x y z))
2438
+
2439
+ (decl add_vec (Reg Reg VectorSize) Reg)
2440
+ (rule (add_vec x y size) (vec_rrr (VecALUOp.Add) x y size))
2441
+
2442
+ ;; Helpers for generating `sub` instructions.
2443
+
2444
+ (decl sub (Type Reg Reg) Reg)
2445
+ (rule (sub ty x y) (alu_rrr (ALUOp.Sub) ty x y))
2446
+
2447
+ (decl sub_imm (Type Reg Imm12) Reg)
2448
+ (rule (sub_imm ty x y) (alu_rr_imm12 (ALUOp.Sub) ty x y))
2449
+
2450
+ (decl sub_extend (Type Reg ExtendedValue) Reg)
2451
+ (rule (sub_extend ty x y) (alu_rr_extend_reg (ALUOp.Sub) ty x y))
2452
+
2453
+ (decl sub_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2454
+ (rule (sub_shift ty x y z) (alu_rrr_shift (ALUOp.Sub) ty x y z))
2455
+
2456
+ (decl sub_vec (Reg Reg VectorSize) Reg)
2457
+ (rule (sub_vec x y size) (vec_rrr (VecALUOp.Sub) x y size))
2458
+
2459
+ (decl sub_i128 (ValueRegs ValueRegs) ValueRegs)
2460
+ (rule (sub_i128 x y)
2461
+ (let
2462
+ ;; Get the high/low registers for `x`.
2463
+ ((x_regs ValueRegs x)
2464
+ (x_lo Reg (value_regs_get x_regs 0))
2465
+ (x_hi Reg (value_regs_get x_regs 1))
2466
+
2467
+ ;; Get the high/low registers for `y`.
2468
+ (y_regs ValueRegs y)
2469
+ (y_lo Reg (value_regs_get y_regs 0))
2470
+ (y_hi Reg (value_regs_get y_regs 1)))
2471
+ ;; the actual subtraction is `subs` followed by `sbc` which comprises
2472
+ ;; the low/high bits of the result
2473
+ (with_flags
2474
+ (sub_with_flags_paired $I64 x_lo y_lo)
2475
+ (sbc_paired $I64 x_hi y_hi))))
2476
+
2477
+ ;; Helpers for generating `madd` instructions.
2478
+
2479
+ (decl madd (Type Reg Reg Reg) Reg)
2480
+ (rule (madd ty x y z) (alu_rrrr (ALUOp3.MAdd) ty x y z))
2481
+
2482
+ ;; Helpers for generating `msub` instructions.
2483
+
2484
+ (decl msub (Type Reg Reg Reg) Reg)
2485
+ (rule (msub ty x y z) (alu_rrrr (ALUOp3.MSub) ty x y z))
2486
+
2487
+ ;; Helpers for generating `umaddl` instructions
2488
+ (decl umaddl (Reg Reg Reg) Reg)
2489
+ (rule (umaddl x y z) (alu_rrrr (ALUOp3.UMAddL) $I32 x y z))
2490
+
2491
+ ;; Helpers for generating `smaddl` instructions
2492
+ (decl smaddl (Reg Reg Reg) Reg)
2493
+ (rule (smaddl x y z) (alu_rrrr (ALUOp3.SMAddL) $I32 x y z))
2494
+
2495
+ ;; Helper for generating `uqadd` instructions.
2496
+ (decl uqadd (Reg Reg VectorSize) Reg)
2497
+ (rule (uqadd x y size) (vec_rrr (VecALUOp.Uqadd) x y size))
2498
+
2499
+ ;; Helper for generating `sqadd` instructions.
2500
+ (decl sqadd (Reg Reg VectorSize) Reg)
2501
+ (rule (sqadd x y size) (vec_rrr (VecALUOp.Sqadd) x y size))
2502
+
2503
+ ;; Helper for generating `uqsub` instructions.
2504
+ (decl uqsub (Reg Reg VectorSize) Reg)
2505
+ (rule (uqsub x y size) (vec_rrr (VecALUOp.Uqsub) x y size))
2506
+
2507
+ ;; Helper for generating `sqsub` instructions.
2508
+ (decl sqsub (Reg Reg VectorSize) Reg)
2509
+ (rule (sqsub x y size) (vec_rrr (VecALUOp.Sqsub) x y size))
2510
+
2511
+ ;; Helper for generating `umulh` instructions.
2512
+ (decl umulh (Type Reg Reg) Reg)
2513
+ (rule (umulh ty x y) (alu_rrr (ALUOp.UMulH) ty x y))
2514
+
2515
+ ;; Helper for generating `smulh` instructions.
2516
+ (decl smulh (Type Reg Reg) Reg)
2517
+ (rule (smulh ty x y) (alu_rrr (ALUOp.SMulH) ty x y))
2518
+
2519
+ ;; Helper for generating `mul` instructions.
2520
+ (decl mul (Reg Reg VectorSize) Reg)
2521
+ (rule (mul x y size) (vec_rrr (VecALUOp.Mul) x y size))
2522
+
2523
+ ;; Helper for generating `neg` instructions.
2524
+ (decl neg (Reg VectorSize) Reg)
2525
+ (rule (neg x size) (vec_misc (VecMisc2.Neg) x size))
2526
+
2527
+ ;; Helper for generating `rev16` instructions.
2528
+ (decl rev16 (Reg VectorSize) Reg)
2529
+ (rule (rev16 x size) (vec_misc (VecMisc2.Rev16) x size))
2530
+
2531
+ ;; Helper for generating `rev32` instructions.
2532
+ (decl rev32 (Reg VectorSize) Reg)
2533
+ (rule (rev32 x size) (vec_misc (VecMisc2.Rev32) x size))
2534
+
2535
+ ;; Helper for generating `rev64` instructions.
2536
+ (decl rev64 (Reg VectorSize) Reg)
2537
+ (rule (rev64 x size) (vec_misc (VecMisc2.Rev64) x size))
2538
+
2539
+ ;; Helper for generating `xtn` instructions.
2540
+ (decl xtn (Reg ScalarSize) Reg)
2541
+ (rule (xtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Xtn) x size))
2542
+
2543
+ ;; Helper for generating `fcvtn` instructions.
2544
+ (decl fcvtn (Reg ScalarSize) Reg)
2545
+ (rule (fcvtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Fcvtn) x size))
2546
+
2547
+ ;; Helper for generating `sqxtn` instructions.
2548
+ (decl sqxtn (Reg ScalarSize) Reg)
2549
+ (rule (sqxtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Sqxtn) x size))
2550
+
2551
+ ;; Helper for generating `sqxtn2` instructions.
2552
+ (decl sqxtn2 (Reg Reg ScalarSize) Reg)
2553
+ (rule (sqxtn2 x y size) (vec_rr_narrow_high (VecRRNarrowOp.Sqxtn) x y size))
2554
+
2555
+ ;; Helper for generating `sqxtun` instructions.
2556
+ (decl sqxtun (Reg ScalarSize) Reg)
2557
+ (rule (sqxtun x size) (vec_rr_narrow_low (VecRRNarrowOp.Sqxtun) x size))
2558
+
2559
+ ;; Helper for generating `sqxtun2` instructions.
2560
+ (decl sqxtun2 (Reg Reg ScalarSize) Reg)
2561
+ (rule (sqxtun2 x y size) (vec_rr_narrow_high (VecRRNarrowOp.Sqxtun) x y size))
2562
+
2563
+ ;; Helper for generating `uqxtn` instructions.
2564
+ (decl uqxtn (Reg ScalarSize) Reg)
2565
+ (rule (uqxtn x size) (vec_rr_narrow_low (VecRRNarrowOp.Uqxtn) x size))
2566
+
2567
+ ;; Helper for generating `uqxtn2` instructions.
2568
+ (decl uqxtn2 (Reg Reg ScalarSize) Reg)
2569
+ (rule (uqxtn2 x y size) (vec_rr_narrow_high (VecRRNarrowOp.Uqxtn) x y size))
2570
+
2571
+ ;; Helper for generating `fence` instructions.
2572
+ (decl aarch64_fence () SideEffectNoResult)
2573
+ (rule (aarch64_fence)
2574
+ (SideEffectNoResult.Inst (MInst.Fence)))
2575
+
2576
+ ;; Helper for generating `csdb` instructions.
2577
+ (decl csdb () SideEffectNoResult)
2578
+ (rule (csdb)
2579
+ (SideEffectNoResult.Inst (MInst.Csdb)))
2580
+
2581
+ ;; Helper for generating `brk` instructions.
2582
+ (decl brk () SideEffectNoResult)
2583
+ (rule (brk)
2584
+ (SideEffectNoResult.Inst (MInst.Brk)))
2585
+
2586
+ ;; Helper for generating `addp` instructions.
2587
+ (decl addp (Reg Reg VectorSize) Reg)
2588
+ (rule (addp x y size) (vec_rrr (VecALUOp.Addp) x y size))
2589
+
2590
+ ;; Helper for generating `zip1` instructions.
2591
+ (decl zip1 (Reg Reg VectorSize) Reg)
2592
+ (rule (zip1 x y size) (vec_rrr (VecALUOp.Zip1) x y size))
2593
+
2594
+ ;; Helper for generating vector `abs` instructions.
2595
+ (decl vec_abs (Reg VectorSize) Reg)
2596
+ (rule (vec_abs x size) (vec_misc (VecMisc2.Abs) x size))
2597
+
2598
+ ;; Helper for generating instruction sequences to calculate a scalar absolute
2599
+ ;; value.
2600
+ (decl abs (OperandSize Reg) Reg)
2601
+ (rule (abs size x)
2602
+ (value_regs_get (with_flags (cmp_imm size x (u8_into_imm12 0))
2603
+ (csneg (Cond.Gt) x x)) 0))
2604
+
2605
+ ;; Helper for generating `addv` instructions.
2606
+ (decl addv (Reg VectorSize) Reg)
2607
+ (rule (addv x size) (vec_lanes (VecLanesOp.Addv) x size))
2608
+
2609
+ ;; Helper for generating `shll32` instructions.
2610
+ (decl shll32 (Reg bool) Reg)
2611
+ (rule (shll32 x high_half) (vec_rr_long (VecRRLongOp.Shll32) x high_half))
2612
+
2613
+ ;; Helpers for generating `addlp` instructions.
2614
+
2615
+ (decl saddlp8 (Reg) Reg)
2616
+ (rule (saddlp8 x) (vec_rr_pair_long (VecRRPairLongOp.Saddlp8) x))
2617
+
2618
+ (decl saddlp16 (Reg) Reg)
2619
+ (rule (saddlp16 x) (vec_rr_pair_long (VecRRPairLongOp.Saddlp16) x))
2620
+
2621
+ (decl uaddlp8 (Reg) Reg)
2622
+ (rule (uaddlp8 x) (vec_rr_pair_long (VecRRPairLongOp.Uaddlp8) x))
2623
+
2624
+ (decl uaddlp16 (Reg) Reg)
2625
+ (rule (uaddlp16 x) (vec_rr_pair_long (VecRRPairLongOp.Uaddlp16) x))
2626
+
2627
+ ;; Helper for generating `umlal32` instructions.
2628
+ (decl umlal32 (Reg Reg Reg bool) Reg)
2629
+ (rule (umlal32 x y z high_half) (vec_rrrr_long (VecRRRLongModOp.Umlal32) x y z high_half))
2630
+
2631
+ ;; Helper for generating `smull8` instructions.
2632
+ (decl smull8 (Reg Reg bool) Reg)
2633
+ (rule (smull8 x y high_half) (vec_rrr_long (VecRRRLongOp.Smull8) x y high_half))
2634
+
2635
+ ;; Helper for generating `umull8` instructions.
2636
+ (decl umull8 (Reg Reg bool) Reg)
2637
+ (rule (umull8 x y high_half) (vec_rrr_long (VecRRRLongOp.Umull8) x y high_half))
2638
+
2639
+ ;; Helper for generating `smull16` instructions.
2640
+ (decl smull16 (Reg Reg bool) Reg)
2641
+ (rule (smull16 x y high_half) (vec_rrr_long (VecRRRLongOp.Smull16) x y high_half))
2642
+
2643
+ ;; Helper for generating `umull16` instructions.
2644
+ (decl umull16 (Reg Reg bool) Reg)
2645
+ (rule (umull16 x y high_half) (vec_rrr_long (VecRRRLongOp.Umull16) x y high_half))
2646
+
2647
+ ;; Helper for generating `smull32` instructions.
2648
+ (decl smull32 (Reg Reg bool) Reg)
2649
+ (rule (smull32 x y high_half) (vec_rrr_long (VecRRRLongOp.Smull32) x y high_half))
2650
+
2651
+ ;; Helper for generating `umull32` instructions.
2652
+ (decl umull32 (Reg Reg bool) Reg)
2653
+ (rule (umull32 x y high_half) (vec_rrr_long (VecRRRLongOp.Umull32) x y high_half))
2654
+
2655
+ ;; Helper for generating `asr` instructions.
2656
+ (decl asr (Type Reg Reg) Reg)
2657
+ (rule (asr ty x y) (alu_rrr (ALUOp.Asr) ty x y))
2658
+
2659
+ (decl asr_imm (Type Reg ImmShift) Reg)
2660
+ (rule (asr_imm ty x imm) (alu_rr_imm_shift (ALUOp.Asr) ty x imm))
2661
+
2662
+ ;; Helper for generating `lsr` instructions.
2663
+ (decl lsr (Type Reg Reg) Reg)
2664
+ (rule (lsr ty x y) (alu_rrr (ALUOp.Lsr) ty x y))
2665
+
2666
+ (decl lsr_imm (Type Reg ImmShift) Reg)
2667
+ (rule (lsr_imm ty x imm) (alu_rr_imm_shift (ALUOp.Lsr) ty x imm))
2668
+
2669
+ ;; Helper for generating `lsl` instructions.
2670
+ (decl lsl (Type Reg Reg) Reg)
2671
+ (rule (lsl ty x y) (alu_rrr (ALUOp.Lsl) ty x y))
2672
+
2673
+ (decl lsl_imm (Type Reg ImmShift) Reg)
2674
+ (rule (lsl_imm ty x imm) (alu_rr_imm_shift (ALUOp.Lsl) ty x imm))
2675
+
2676
+ ;; Helper for generating `udiv` instructions.
2677
+ (decl a64_udiv (Type Reg Reg) Reg)
2678
+ (rule (a64_udiv ty x y) (alu_rrr (ALUOp.UDiv) ty x y))
2679
+
2680
+ ;; Helper for generating `sdiv` instructions.
2681
+ (decl a64_sdiv (Type Reg Reg) Reg)
2682
+ (rule (a64_sdiv ty x y) (alu_rrr (ALUOp.SDiv) ty x y))
2683
+
2684
+ ;; Helper for generating `not` instructions.
2685
+ (decl not (Reg VectorSize) Reg)
2686
+ (rule (not x size) (vec_misc (VecMisc2.Not) x size))
2687
+
2688
+ ;; Helpers for generating `orr_not` instructions.
2689
+
2690
+ (decl orr_not (Type Reg Reg) Reg)
2691
+ (rule (orr_not ty x y) (alu_rrr (ALUOp.OrrNot) ty x y))
2692
+
2693
+ (decl orr_not_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2694
+ (rule (orr_not_shift ty x y shift) (alu_rrr_shift (ALUOp.OrrNot) ty x y shift))
2695
+
2696
+ ;; Helpers for generating `orr` instructions.
2697
+
2698
+ (decl orr (Type Reg Reg) Reg)
2699
+ (rule (orr ty x y) (alu_rrr (ALUOp.Orr) ty x y))
2700
+
2701
+ (decl orr_imm (Type Reg ImmLogic) Reg)
2702
+ (rule (orr_imm ty x y) (alu_rr_imm_logic (ALUOp.Orr) ty x y))
2703
+
2704
+ (decl orr_shift (Type Reg Reg ShiftOpAndAmt) Reg)
2705
+ (rule (orr_shift ty x y shift) (alu_rrr_shift (ALUOp.Orr) ty x y shift))
2706
+
2707
+ (decl orr_vec (Reg Reg VectorSize) Reg)
2708
+ (rule (orr_vec x y size) (vec_rrr (VecALUOp.Orr) x y size))
2709
+
2710
+ ;; Helpers for generating `and` instructions.
2711
+
2712
+ (decl and_reg (Type Reg Reg) Reg)
2713
+ (rule (and_reg ty x y) (alu_rrr (ALUOp.And) ty x y))
2714
+
2715
+ (decl and_imm (Type Reg ImmLogic) Reg)
2716
+ (rule (and_imm ty x y) (alu_rr_imm_logic (ALUOp.And) ty x y))
2717
+
2718
+ (decl and_vec (Reg Reg VectorSize) Reg)
2719
+ (rule (and_vec x y size) (vec_rrr (VecALUOp.And) x y size))
2720
+
2721
+ ;; Helpers for generating `eor` instructions.
2722
+ (decl eor (Type Reg Reg) Reg)
2723
+ (rule (eor ty x y) (alu_rrr (ALUOp.Eor) ty x y))
2724
+
2725
+ (decl eor_vec (Reg Reg VectorSize) Reg)
2726
+ (rule (eor_vec x y size) (vec_rrr (VecALUOp.Eor) x y size))
2727
+
2728
+ ;; Helpers for generating `bic` instructions.
2729
+
2730
+ (decl bic (Type Reg Reg) Reg)
2731
+ (rule (bic ty x y) (alu_rrr (ALUOp.AndNot) ty x y))
2732
+
2733
+ (decl bic_vec (Reg Reg VectorSize) Reg)
2734
+ (rule (bic_vec x y size) (vec_rrr (VecALUOp.Bic) x y size))
2735
+
2736
+ ;; Helpers for generating `sshl` instructions.
2737
+ (decl sshl (Reg Reg VectorSize) Reg)
2738
+ (rule (sshl x y size) (vec_rrr (VecALUOp.Sshl) x y size))
2739
+
2740
+ ;; Helpers for generating `ushl` instructions.
2741
+ (decl ushl (Reg Reg VectorSize) Reg)
2742
+ (rule (ushl x y size) (vec_rrr (VecALUOp.Ushl) x y size))
2743
+
2744
+ ;; Helpers for generating `ushl` instructions.
2745
+ (decl ushl_vec_imm (Reg u8 VectorSize) Reg)
2746
+ (rule (ushl_vec_imm x amt size) (vec_shift_imm (VecShiftImmOp.Shl) amt x size))
2747
+
2748
+ ;; Helpers for generating `ushr` instructions.
2749
+ (decl ushr_vec_imm (Reg u8 VectorSize) Reg)
2750
+ (rule (ushr_vec_imm x amt size) (vec_shift_imm (VecShiftImmOp.Ushr) amt x size))
2751
+
2752
+ ;; Helpers for generating `sshr` instructions.
2753
+ (decl sshr_vec_imm (Reg u8 VectorSize) Reg)
2754
+ (rule (sshr_vec_imm x amt size) (vec_shift_imm (VecShiftImmOp.Sshr) amt x size))
2755
+
2756
+ ;; Helpers for generating `rotr` instructions.
2757
+
2758
+ (decl a64_rotr (Type Reg Reg) Reg)
2759
+ (rule (a64_rotr ty x y) (alu_rrr (ALUOp.RotR) ty x y))
2760
+
2761
+ (decl a64_rotr_imm (Type Reg ImmShift) Reg)
2762
+ (rule (a64_rotr_imm ty x y) (alu_rr_imm_shift (ALUOp.RotR) ty x y))
2763
+
2764
+ ;; Helpers for generating `rbit` instructions.
2765
+
2766
+ (decl rbit (Type Reg) Reg)
2767
+ (rule (rbit ty x) (bit_rr (BitOp.RBit) ty x))
2768
+
2769
+ ;; Helpers for generating `clz` instructions.
2770
+
2771
+ (decl a64_clz (Type Reg) Reg)
2772
+ (rule (a64_clz ty x) (bit_rr (BitOp.Clz) ty x))
2773
+
2774
+ ;; Helpers for generating `cls` instructions.
2775
+
2776
+ (decl a64_cls (Type Reg) Reg)
2777
+ (rule (a64_cls ty x) (bit_rr (BitOp.Cls) ty x))
2778
+
2779
+ ;; Helpers for generating `rev` instructions
2780
+
2781
+ (decl a64_rev16 (Type Reg) Reg)
2782
+ (rule (a64_rev16 ty x) (bit_rr (BitOp.Rev16) ty x))
2783
+
2784
+ (decl a64_rev32 (Type Reg) Reg)
2785
+ (rule (a64_rev32 ty x) (bit_rr (BitOp.Rev32) ty x))
2786
+
2787
+ (decl a64_rev64 (Type Reg) Reg)
2788
+ (rule (a64_rev64 ty x) (bit_rr (BitOp.Rev64) ty x))
2789
+
2790
+ ;; Helpers for generating `eon` instructions.
2791
+
2792
+ (decl eon (Type Reg Reg) Reg)
2793
+ (rule (eon ty x y) (alu_rrr (ALUOp.EorNot) ty x y))
2794
+
2795
+ ;; Helpers for generating `cnt` instructions.
2796
+
2797
+ (decl vec_cnt (Reg VectorSize) Reg)
2798
+ (rule (vec_cnt x size) (vec_misc (VecMisc2.Cnt) x size))
2799
+
2800
+ ;; Helpers for generating a `bsl` instruction.
2801
+
2802
+ (decl bsl (Type Reg Reg Reg) Reg)
2803
+ (rule (bsl ty c x y)
2804
+ (vec_rrr_mod (VecALUModOp.Bsl) c x y (vector_size ty)))
2805
+
2806
+ ;; Helper for generating a `udf` instruction.
2807
+
2808
+ (decl udf (TrapCode) SideEffectNoResult)
2809
+ (rule (udf trap_code)
2810
+ (SideEffectNoResult.Inst (MInst.Udf trap_code)))
2811
+
2812
+ ;; Helpers for generating various load instructions, with varying
2813
+ ;; widths and sign/zero-extending properties.
2814
+ (decl aarch64_uload8 (AMode MemFlags) Reg)
2815
+ (rule (aarch64_uload8 amode flags)
2816
+ (let ((dst WritableReg (temp_writable_reg $I64))
2817
+ (_ Unit (emit (MInst.ULoad8 dst amode flags))))
2818
+ dst))
2819
+ (decl aarch64_sload8 (AMode MemFlags) Reg)
2820
+ (rule (aarch64_sload8 amode flags)
2821
+ (let ((dst WritableReg (temp_writable_reg $I64))
2822
+ (_ Unit (emit (MInst.SLoad8 dst amode flags))))
2823
+ dst))
2824
+ (decl aarch64_uload16 (AMode MemFlags) Reg)
2825
+ (rule (aarch64_uload16 amode flags)
2826
+ (let ((dst WritableReg (temp_writable_reg $I64))
2827
+ (_ Unit (emit (MInst.ULoad16 dst amode flags))))
2828
+ dst))
2829
+ (decl aarch64_sload16 (AMode MemFlags) Reg)
2830
+ (rule (aarch64_sload16 amode flags)
2831
+ (let ((dst WritableReg (temp_writable_reg $I64))
2832
+ (_ Unit (emit (MInst.SLoad16 dst amode flags))))
2833
+ dst))
2834
+ (decl aarch64_uload32 (AMode MemFlags) Reg)
2835
+ (rule (aarch64_uload32 amode flags)
2836
+ (let ((dst WritableReg (temp_writable_reg $I64))
2837
+ (_ Unit (emit (MInst.ULoad32 dst amode flags))))
2838
+ dst))
2839
+ (decl aarch64_sload32 (AMode MemFlags) Reg)
2840
+ (rule (aarch64_sload32 amode flags)
2841
+ (let ((dst WritableReg (temp_writable_reg $I64))
2842
+ (_ Unit (emit (MInst.SLoad32 dst amode flags))))
2843
+ dst))
2844
+ (decl aarch64_uload64 (AMode MemFlags) Reg)
2845
+ (rule (aarch64_uload64 amode flags)
2846
+ (let ((dst WritableReg (temp_writable_reg $I64))
2847
+ (_ Unit (emit (MInst.ULoad64 dst amode flags))))
2848
+ dst))
2849
+ (decl aarch64_fpuload32 (AMode MemFlags) Reg)
2850
+ (rule (aarch64_fpuload32 amode flags)
2851
+ (let ((dst WritableReg (temp_writable_reg $F64))
2852
+ (_ Unit (emit (MInst.FpuLoad32 dst amode flags))))
2853
+ dst))
2854
+ (decl aarch64_fpuload64 (AMode MemFlags) Reg)
2855
+ (rule (aarch64_fpuload64 amode flags)
2856
+ (let ((dst WritableReg (temp_writable_reg $F64))
2857
+ (_ Unit (emit (MInst.FpuLoad64 dst amode flags))))
2858
+ dst))
2859
+ (decl aarch64_fpuload128 (AMode MemFlags) Reg)
2860
+ (rule (aarch64_fpuload128 amode flags)
2861
+ (let ((dst WritableReg (temp_writable_reg $F64X2))
2862
+ (_ Unit (emit (MInst.FpuLoad128 dst amode flags))))
2863
+ dst))
2864
+ (decl aarch64_loadp64 (PairAMode MemFlags) ValueRegs)
2865
+ (rule (aarch64_loadp64 amode flags)
2866
+ (let ((dst1 WritableReg (temp_writable_reg $I64))
2867
+ (dst2 WritableReg (temp_writable_reg $I64))
2868
+ (_ Unit (emit (MInst.LoadP64 dst1 dst2 amode flags))))
2869
+ (value_regs dst1 dst2)))
2870
+
2871
+ ;; Helpers for generating various store instructions with varying
2872
+ ;; widths.
2873
+ (decl aarch64_store8 (AMode MemFlags Reg) SideEffectNoResult)
2874
+ (rule (aarch64_store8 amode flags val)
2875
+ (SideEffectNoResult.Inst (MInst.Store8 val amode flags)))
2876
+ (decl aarch64_store16 (AMode MemFlags Reg) SideEffectNoResult)
2877
+ (rule (aarch64_store16 amode flags val)
2878
+ (SideEffectNoResult.Inst (MInst.Store16 val amode flags)))
2879
+ (decl aarch64_store32 (AMode MemFlags Reg) SideEffectNoResult)
2880
+ (rule (aarch64_store32 amode flags val)
2881
+ (SideEffectNoResult.Inst (MInst.Store32 val amode flags)))
2882
+ (decl aarch64_store64 (AMode MemFlags Reg) SideEffectNoResult)
2883
+ (rule (aarch64_store64 amode flags val)
2884
+ (SideEffectNoResult.Inst (MInst.Store64 val amode flags)))
2885
+ (decl aarch64_fpustore32 (AMode MemFlags Reg) SideEffectNoResult)
2886
+ (rule (aarch64_fpustore32 amode flags val)
2887
+ (SideEffectNoResult.Inst (MInst.FpuStore32 val amode flags)))
2888
+ (decl aarch64_fpustore64 (AMode MemFlags Reg) SideEffectNoResult)
2889
+ (rule (aarch64_fpustore64 amode flags val)
2890
+ (SideEffectNoResult.Inst (MInst.FpuStore64 val amode flags)))
2891
+ (decl aarch64_fpustore128 (AMode MemFlags Reg) SideEffectNoResult)
2892
+ (rule (aarch64_fpustore128 amode flags val)
2893
+ (SideEffectNoResult.Inst (MInst.FpuStore128 val amode flags)))
2894
+ (decl aarch64_storep64 (PairAMode MemFlags Reg Reg) SideEffectNoResult)
2895
+ (rule (aarch64_storep64 amode flags val1 val2)
2896
+ (SideEffectNoResult.Inst (MInst.StoreP64 val1 val2 amode flags)))
2897
+
2898
+ ;; Helper for generating a `trapif` instruction.
2899
+
2900
+ (decl trap_if (ProducesFlags TrapCode Cond) InstOutput)
2901
+ (rule (trap_if flags trap_code cond)
2902
+ (side_effect
2903
+ (with_flags_side_effect flags
2904
+ (ConsumesFlags.ConsumesFlagsSideEffect
2905
+ (MInst.TrapIf (cond_br_cond cond) trap_code)))))
2906
+
2907
+ ;; Immediate value helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2908
+
2909
+ ;; Type of extension performed by an immediate helper
2910
+ (type ImmExtend
2911
+ (enum
2912
+ (Sign)
2913
+ (Zero)))
2914
+
2915
+ ;; Arguments:
2916
+ ;; * Immediate type
2917
+ ;; * Way to extend the immediate value to the full width of the destination
2918
+ ;; register
2919
+ ;; * Immediate value - only the bits that fit within the type are used and
2920
+ ;; extended, while the rest are ignored
2921
+ ;;
2922
+ ;; Note that, unlike the convention in the AArch64 backend, this helper leaves
2923
+ ;; all bits in the destination register in a defined state, i.e. smaller types
2924
+ ;; such as `I8` are either sign- or zero-extended.
2925
+ (decl imm (Type ImmExtend u64) Reg)
2926
+
2927
+ ;; Move wide immediate instructions; to simplify, we only match when we
2928
+ ;; are zero-extending the value.
2929
+ (rule 3 (imm (integral_ty ty) (ImmExtend.Zero) k)
2930
+ (if-let n (move_wide_const_from_u64 ty k))
2931
+ (add_range_fact
2932
+ (movz n (operand_size ty))
2933
+ 64 k k))
2934
+ (rule 2 (imm (integral_ty (ty_32_or_64 ty)) (ImmExtend.Zero) k)
2935
+ (if-let n (move_wide_const_from_inverted_u64 ty k))
2936
+ (add_range_fact
2937
+ (movn n (operand_size ty))
2938
+ 64 k k))
2939
+
2940
+ ;; Weird logical-instruction immediate in ORI using zero register; to simplify,
2941
+ ;; we only match when we are zero-extending the value.
2942
+ (rule 1 (imm (integral_ty ty) (ImmExtend.Zero) k)
2943
+ (if-let n (imm_logic_from_u64 ty k))
2944
+ (if-let m (imm_size_from_type ty))
2945
+ (add_range_fact
2946
+ (orr_imm ty (zero_reg) n)
2947
+ m k k))
2948
+
2949
+ (decl load_constant64_full (Type ImmExtend u64) Reg)
2950
+ (extern constructor load_constant64_full load_constant64_full)
2951
+
2952
+ ;; Fallback for integral 64-bit constants
2953
+ (rule (imm (integral_ty ty) extend n)
2954
+ (load_constant64_full ty extend n))
2955
+
2956
+ ;; Sign extension helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2957
+
2958
+ ;; Place a `Value` into a register, sign extending it to 32-bits
2959
+ (decl put_in_reg_sext32 (Value) Reg)
2960
+ (rule -1 (put_in_reg_sext32 val @ (value_type (fits_in_32 ty)))
2961
+ (extend val $true (ty_bits ty) 32))
2962
+
2963
+ ;; 32/64-bit passthrough.
2964
+ (rule (put_in_reg_sext32 val @ (value_type $I32)) val)
2965
+ (rule (put_in_reg_sext32 val @ (value_type $I64)) val)
2966
+
2967
+ ;; Place a `Value` into a register, zero extending it to 32-bits
2968
+ (decl put_in_reg_zext32 (Value) Reg)
2969
+ (rule -1 (put_in_reg_zext32 val @ (value_type (fits_in_32 ty)))
2970
+ (extend val $false (ty_bits ty) 32))
2971
+
2972
+ ;; 32/64-bit passthrough.
2973
+ (rule (put_in_reg_zext32 val @ (value_type $I32)) val)
2974
+ (rule (put_in_reg_zext32 val @ (value_type $I64)) val)
2975
+
2976
+ ;; Place a `Value` into a register, sign extending it to 64-bits
2977
+ (decl put_in_reg_sext64 (Value) Reg)
2978
+ (rule 1 (put_in_reg_sext64 val @ (value_type (fits_in_32 ty)))
2979
+ (extend val $true (ty_bits ty) 64))
2980
+
2981
+ ;; 64-bit passthrough.
2982
+ (rule (put_in_reg_sext64 val @ (value_type $I64)) val)
2983
+
2984
+ ;; Place a `Value` into a register, zero extending it to 64-bits
2985
+ (decl put_in_reg_zext64 (Value) Reg)
2986
+ (rule 1 (put_in_reg_zext64 val @ (value_type (fits_in_32 ty)))
2987
+ (extend val $false (ty_bits ty) 64))
2988
+
2989
+ ;; 64-bit passthrough.
2990
+ (rule (put_in_reg_zext64 val @ (value_type $I64)) val)
2991
+
2992
+ ;; Misc instruction helpers ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2993
+
2994
+ (decl trap_if_zero_divisor (Reg) Reg)
2995
+ (rule (trap_if_zero_divisor reg)
2996
+ (let ((_ Unit (emit (MInst.TrapIf (cond_br_zero reg) (trap_code_division_by_zero)))))
2997
+ reg))
2998
+
2999
+ (decl size_from_ty (Type) OperandSize)
3000
+ (rule 1 (size_from_ty (fits_in_32 _ty)) (OperandSize.Size32))
3001
+ (rule (size_from_ty $I64) (OperandSize.Size64))
3002
+
3003
+ ;; Check for signed overflow. The only case is min_value / -1.
3004
+ ;; The following checks must be done in 32-bit or 64-bit, depending
3005
+ ;; on the input type.
3006
+ (decl trap_if_div_overflow (Type Reg Reg) Reg)
3007
+ (rule (trap_if_div_overflow ty x y)
3008
+ (let (
3009
+ ;; Check RHS is -1.
3010
+ (_ Unit (emit (MInst.AluRRImm12 (ALUOp.AddS) (operand_size ty) (writable_zero_reg) y (u8_into_imm12 1))))
3011
+
3012
+ ;; Check LHS is min_value, by subtracting 1 and branching if
3013
+ ;; there is overflow.
3014
+ (_ Unit (emit (MInst.CCmpImm (size_from_ty ty)
3015
+ x
3016
+ (u8_into_uimm5 1)
3017
+ (nzcv $false $false $false $false)
3018
+ (Cond.Eq))))
3019
+ (_ Unit (emit (MInst.TrapIf (cond_br_cond (Cond.Vs))
3020
+ (trap_code_integer_overflow))))
3021
+ )
3022
+ x))
3023
+
3024
+ ;; Check for unsigned overflow.
3025
+ (decl trap_if_overflow (ProducesFlags TrapCode) Reg)
3026
+ (rule (trap_if_overflow producer tc)
3027
+ (with_flags_reg
3028
+ producer
3029
+ (ConsumesFlags.ConsumesFlagsSideEffect
3030
+ (MInst.TrapIf (cond_br_cond (Cond.Hs)) tc))))
3031
+
3032
+ (decl sink_atomic_load (Inst) Reg)
3033
+ (rule (sink_atomic_load x @ (atomic_load _ addr))
3034
+ (let ((_ Unit (sink_inst x)))
3035
+ (put_in_reg addr)))
3036
+
3037
+ ;; Helper for generating either an `AluRRR`, `AluRRRShift`, or `AluRRImmLogic`
3038
+ ;; instruction depending on the input. Note that this requires that the `ALUOp`
3039
+ ;; specified is commutative.
3040
+ (decl alu_rs_imm_logic_commutative (ALUOp Type Value Value) Reg)
3041
+
3042
+ ;; Base case of operating on registers.
3043
+ (rule -1 (alu_rs_imm_logic_commutative op ty x y)
3044
+ (alu_rrr op ty x y))
3045
+
3046
+ ;; Special cases for when one operand is a constant.
3047
+ (rule (alu_rs_imm_logic_commutative op ty x (iconst k))
3048
+ (if-let imm (imm_logic_from_imm64 ty k))
3049
+ (alu_rr_imm_logic op ty x imm))
3050
+ (rule 1 (alu_rs_imm_logic_commutative op ty (iconst k) x)
3051
+ (if-let imm (imm_logic_from_imm64 ty k))
3052
+ (alu_rr_imm_logic op ty x imm))
3053
+
3054
+ ;; Special cases for when one operand is shifted left by a constant.
3055
+ (rule (alu_rs_imm_logic_commutative op ty x (ishl y (iconst k)))
3056
+ (if-let amt (lshl_from_imm64 ty k))
3057
+ (alu_rrr_shift op ty x y amt))
3058
+ (rule 1 (alu_rs_imm_logic_commutative op ty (ishl x (iconst k)) y)
3059
+ (if-let amt (lshl_from_imm64 ty k))
3060
+ (alu_rrr_shift op ty y x amt))
3061
+
3062
+ ;; Same as `alu_rs_imm_logic_commutative` above, except that it doesn't require
3063
+ ;; that the operation is commutative.
3064
+ (decl alu_rs_imm_logic (ALUOp Type Value Value) Reg)
3065
+ (rule -1 (alu_rs_imm_logic op ty x y)
3066
+ (alu_rrr op ty x y))
3067
+ (rule (alu_rs_imm_logic op ty x (iconst k))
3068
+ (if-let imm (imm_logic_from_imm64 ty k))
3069
+ (alu_rr_imm_logic op ty x imm))
3070
+ (rule (alu_rs_imm_logic op ty x (ishl y (iconst k)))
3071
+ (if-let amt (lshl_from_imm64 ty k))
3072
+ (alu_rrr_shift op ty x y amt))
3073
+
3074
+ ;; Helper for generating i128 bitops which simply do the same operation to the
3075
+ ;; hi/lo registers.
3076
+ ;;
3077
+ ;; TODO: Support immlogic here
3078
+ (decl i128_alu_bitop (ALUOp Type Value Value) ValueRegs)
3079
+ (rule (i128_alu_bitop op ty x y)
3080
+ (let (
3081
+ (x_regs ValueRegs (put_in_regs x))
3082
+ (x_lo Reg (value_regs_get x_regs 0))
3083
+ (x_hi Reg (value_regs_get x_regs 1))
3084
+ (y_regs ValueRegs (put_in_regs y))
3085
+ (y_lo Reg (value_regs_get y_regs 0))
3086
+ (y_hi Reg (value_regs_get y_regs 1))
3087
+ )
3088
+ (value_regs
3089
+ (alu_rrr op ty x_lo y_lo)
3090
+ (alu_rrr op ty x_hi y_hi))))
3091
+
3092
+ ;; Helper for emitting `MInst.VecLoadReplicate` instructions.
3093
+ (decl ld1r (Reg VectorSize MemFlags) Reg)
3094
+ (rule (ld1r src size flags)
3095
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
3096
+ (_ Unit (emit (MInst.VecLoadReplicate dst src size flags))))
3097
+ dst))
3098
+
3099
+ ;; Helper for emitting `MInst.LoadExtName` instructions.
3100
+ (decl load_ext_name (BoxExternalName i64) Reg)
3101
+ (rule (load_ext_name extname offset)
3102
+ (let ((dst WritableReg (temp_writable_reg $I64))
3103
+ (_ Unit (emit (MInst.LoadExtName dst extname offset))))
3104
+ dst))
3105
+
3106
+ ;; Lower the address of a load or a store.
3107
+ ;;
3108
+ ;; This will create an `AMode` representing the address of the `Value` provided
3109
+ ;; at runtime plus the immediate offset `i32` provided. The `Type` here is used
3110
+ ;; to represent the size of the value being loaded or stored for offset scaling
3111
+ ;; if necessary.
3112
+ ;;
3113
+ ;; Note that this is broken up into two phases. In the first phase this attempts
3114
+ ;; to find constants within the `val` provided and fold them in to the `offset`
3115
+ ;; provided. Afterwards though the `amode_no_more_iconst` helper is used at
3116
+ ;; which pointer constants are no longer pattern-matched and instead only
3117
+ ;; various modes are generated. This in theory would not be necessary with
3118
+ ;; mid-end optimizations that fold constants into load/store immediate offsets
3119
+ ;; instead, but for now each backend needs to do this.
3120
+ (decl amode (Type Value i32) AMode)
3121
+ (rule 0 (amode ty val offset)
3122
+ (amode_no_more_iconst ty val offset))
3123
+ (rule 1 (amode ty (iadd x (iconst (simm32 y))) offset)
3124
+ (if-let new_offset (s32_add_fallible y offset))
3125
+ (amode_no_more_iconst ty x new_offset))
3126
+ (rule 2 (amode ty (iadd (iconst (simm32 x)) y) offset)
3127
+ (if-let new_offset (s32_add_fallible x offset))
3128
+ (amode_no_more_iconst ty y new_offset))
3129
+
3130
+ (decl amode_no_more_iconst (Type Value i32) AMode)
3131
+ ;; Base case: move the `offset` into a register and add it to `val` via the
3132
+ ;; amode
3133
+ (rule 0 (amode_no_more_iconst ty val offset)
3134
+ (AMode.RegReg val (imm $I64 (ImmExtend.Zero) (i64_as_u64 offset))))
3135
+
3136
+ ;; Optimize cases where the `offset` provided fits into a immediates of
3137
+ ;; various kinds of addressing modes.
3138
+ (rule 1 (amode_no_more_iconst ty val offset)
3139
+ (if-let simm9 (simm9_from_i64 offset))
3140
+ (AMode.Unscaled val simm9))
3141
+ (rule 2 (amode_no_more_iconst ty val offset)
3142
+ (if-let uimm12 (uimm12_scaled_from_i64 offset ty))
3143
+ (AMode.UnsignedOffset val uimm12))
3144
+
3145
+ ;; Optimizations where addition can fold some operations into the `amode`.
3146
+ ;;
3147
+ ;; Note that here these take higher priority than constants because an
3148
+ ;; add-of-extend can be folded into an amode, representing 2 otherwise emitted
3149
+ ;; instructions. Constants on the other hand added to the amode represent only
3150
+ ;; a single instruction folded in, so fewer instructions should be generated
3151
+ ;; with these higher priority than the rules above.
3152
+ (rule 3 (amode_no_more_iconst ty (iadd x y) offset)
3153
+ (AMode.RegReg (amode_add x offset) y))
3154
+ (rule 4 (amode_no_more_iconst ty (iadd x (uextend y @ (value_type $I32))) offset)
3155
+ (AMode.RegExtended (amode_add x offset) y (ExtendOp.UXTW)))
3156
+ (rule 4 (amode_no_more_iconst ty (iadd x (sextend y @ (value_type $I32))) offset)
3157
+ (AMode.RegExtended (amode_add x offset) y (ExtendOp.SXTW)))
3158
+ (rule 5 (amode_no_more_iconst ty (iadd (uextend x @ (value_type $I32)) y) offset)
3159
+ (AMode.RegExtended (amode_add y offset) x (ExtendOp.UXTW)))
3160
+ (rule 5 (amode_no_more_iconst ty (iadd (sextend x @ (value_type $I32)) y) offset)
3161
+ (AMode.RegExtended (amode_add y offset) x (ExtendOp.SXTW)))
3162
+
3163
+ ;; `RegScaled*` rules where this matches an addition of an "index register" to a
3164
+ ;; base register. The index register is shifted by the size of the type loaded
3165
+ ;; in bytes to enable this mode matching.
3166
+ ;;
3167
+ ;; Note that this can additionally bundle an extending operation but the
3168
+ ;; extension must happen before the shift. This will pattern-match the shift
3169
+ ;; first and then if that succeeds afterwards try to find an extend.
3170
+ (rule 6 (amode_no_more_iconst ty (iadd x (ishl y (iconst (u64_from_imm64 n)))) offset)
3171
+ (if-let $true (u64_eq (ty_bytes ty) (u64_shl 1 n)))
3172
+ (amode_reg_scaled (amode_add x offset) y ty))
3173
+ (rule 7 (amode_no_more_iconst ty (iadd (ishl y (iconst (u64_from_imm64 n))) x) offset)
3174
+ (if-let $true (u64_eq (ty_bytes ty) (u64_shl 1 n)))
3175
+ (amode_reg_scaled (amode_add x offset) y ty))
3176
+
3177
+ (decl amode_reg_scaled (Reg Value Type) AMode)
3178
+ (rule 0 (amode_reg_scaled base index ty)
3179
+ (AMode.RegScaled base index ty))
3180
+ (rule 1 (amode_reg_scaled base (uextend index @ (value_type $I32)) ty)
3181
+ (AMode.RegScaledExtended base index ty (ExtendOp.UXTW)))
3182
+ (rule 2 (amode_reg_scaled base (sextend index @ (value_type $I32)) ty)
3183
+ (AMode.RegScaledExtended base index ty (ExtendOp.SXTW)))
3184
+
3185
+ ;; Helper to add a 32-bit signed immediate to the register provided. This will
3186
+ ;; select an appropriate `add` instruction to use.
3187
+ (decl amode_add (Reg i32) Reg)
3188
+ (rule 0 (amode_add x y)
3189
+ (add $I64 x (imm $I64 (ImmExtend.Zero) (i64_as_u64 y))))
3190
+ (rule 1 (amode_add x y)
3191
+ (if-let (imm12_from_u64 imm12) (i64_as_u64 y))
3192
+ (add_imm $I64 x imm12))
3193
+ (rule 2 (amode_add x 0) x)
3194
+
3195
+ ;; Creates a `PairAMode` for the `Value` provided plus the `i32` constant
3196
+ ;; offset provided.
3197
+ (decl pair_amode (Value i32) PairAMode)
3198
+
3199
+ ;; Base case where `val` and `offset` are combined with an `add`
3200
+ (rule 0 (pair_amode val offset)
3201
+ (if-let simm7 (simm7_scaled_from_i64 0 $I64))
3202
+ (PairAMode.SignedOffset (amode_add val offset) simm7))
3203
+
3204
+ ;; Optimization when `offset` can fit into a `SImm7Scaled`.
3205
+ (rule 1 (pair_amode val offset)
3206
+ (if-let simm7 (simm7_scaled_from_i64 offset $I64))
3207
+ (PairAMode.SignedOffset val simm7))
3208
+
3209
+ (decl pure partial simm7_scaled_from_i64 (i64 Type) SImm7Scaled)
3210
+ (extern constructor simm7_scaled_from_i64 simm7_scaled_from_i64)
3211
+
3212
+ (decl pure partial uimm12_scaled_from_i64 (i64 Type) UImm12Scaled)
3213
+ (extern constructor uimm12_scaled_from_i64 uimm12_scaled_from_i64)
3214
+
3215
+ (decl pure partial simm9_from_i64 (i64) SImm9)
3216
+ (extern constructor simm9_from_i64 simm9_from_i64)
3217
+
3218
+
3219
+ (decl sink_load_into_addr (Type Inst) Reg)
3220
+ (rule (sink_load_into_addr ty x @ (load _ addr (offset32 offset)))
3221
+ (let ((_ Unit (sink_inst x)))
3222
+ (add_imm_to_addr addr (i64_as_u64 offset))))
3223
+
3224
+ (decl add_imm_to_addr (Reg u64) Reg)
3225
+ (rule 2 (add_imm_to_addr val 0) val)
3226
+ (rule 1 (add_imm_to_addr val (imm12_from_u64 imm)) (add_imm $I64 val imm))
3227
+ (rule 0 (add_imm_to_addr val offset) (add $I64 val (imm $I64 (ImmExtend.Zero) offset)))
3228
+
3229
+ ;; Lower a constant f32.
3230
+ ;;
3231
+ ;; Note that we must make sure that all bits outside the lowest 32 are set to 0
3232
+ ;; because this function is also used to load wider constants (that have zeros
3233
+ ;; in their most significant bits).
3234
+ (decl constant_f32 (u32) Reg)
3235
+ (rule 2 (constant_f32 0)
3236
+ (vec_dup_imm (asimd_mov_mod_imm_zero (ScalarSize.Size32))
3237
+ $false
3238
+ (VectorSize.Size32x2)))
3239
+ (rule 1 (constant_f32 n)
3240
+ (if-let imm (asimd_fp_mod_imm_from_u64 n (ScalarSize.Size32)))
3241
+ (fpu_move_fp_imm imm (ScalarSize.Size32)))
3242
+ (rule (constant_f32 n)
3243
+ (mov_to_fpu (imm $I32 (ImmExtend.Zero) n) (ScalarSize.Size32)))
3244
+
3245
+ ;; Lower a constant f64.
3246
+ ;;
3247
+ ;; Note that we must make sure that all bits outside the lowest 64 are set to 0
3248
+ ;; because this function is also used to load wider constants (that have zeros
3249
+ ;; in their most significant bits).
3250
+ ;; TODO: Treat as half of a 128 bit vector and consider replicated patterns.
3251
+ ;; Scalar MOVI might also be an option.
3252
+ (decl constant_f64 (u64) Reg)
3253
+ (rule 4 (constant_f64 0)
3254
+ (vec_dup_imm (asimd_mov_mod_imm_zero (ScalarSize.Size32))
3255
+ $false
3256
+ (VectorSize.Size32x2)))
3257
+ (rule 3 (constant_f64 n)
3258
+ (if-let imm (asimd_fp_mod_imm_from_u64 n (ScalarSize.Size64)))
3259
+ (fpu_move_fp_imm imm (ScalarSize.Size64)))
3260
+ (rule 2 (constant_f64 (u64_as_u32 n))
3261
+ (constant_f32 n))
3262
+ (rule 1 (constant_f64 (u64_low32_bits_unset n))
3263
+ (mov_to_fpu (imm $I64 (ImmExtend.Zero) n) (ScalarSize.Size64)))
3264
+ (rule (constant_f64 n)
3265
+ (fpu_load64 (AMode.Const (emit_u64_le_const n)) (mem_flags_trusted)))
3266
+
3267
+ ;; Tests whether the low 32 bits in the input are all zero.
3268
+ (decl u64_low32_bits_unset (u64) u64)
3269
+ (extern extractor u64_low32_bits_unset u64_low32_bits_unset)
3270
+
3271
+ ;; Lower a constant f128.
3272
+ (decl constant_f128 (u128) Reg)
3273
+ (rule 3 (constant_f128 0)
3274
+ (vec_dup_imm (asimd_mov_mod_imm_zero (ScalarSize.Size8))
3275
+ $false
3276
+ (VectorSize.Size8x16)))
3277
+
3278
+ ;; If the upper 64-bits are all zero then defer to `constant_f64`.
3279
+ (rule 2 (constant_f128 (u128_as_u64 n)) (constant_f64 n))
3280
+
3281
+ ;; If the low half of the u128 equals the high half then delegate to the splat
3282
+ ;; logic as a splat of a 64-bit value.
3283
+ (rule 1 (constant_f128 (u128_replicated_u64 n))
3284
+ (splat_const n (VectorSize.Size64x2)))
3285
+
3286
+ ;; Base case is to load the constant from memory.
3287
+ (rule (constant_f128 n)
3288
+ (fpu_load128 (AMode.Const (emit_u128_le_const n)) (mem_flags_trusted)))
3289
+
3290
+ ;; Lower a vector splat with a constant parameter.
3291
+ ;;
3292
+ ;; The 64-bit input here only uses the low bits for the lane size in
3293
+ ;; `VectorSize` and all other bits are ignored.
3294
+ (decl splat_const (u64 VectorSize) Reg)
3295
+
3296
+ ;; If the splat'd constant can itself be reduced in size then attempt to do so
3297
+ ;; as it will make it easier to create the immediates in the instructions below.
3298
+ (rule 5 (splat_const (u64_replicated_u32 n) (VectorSize.Size64x2))
3299
+ (splat_const n (VectorSize.Size32x4)))
3300
+ (rule 5 (splat_const (u32_replicated_u16 n) (VectorSize.Size32x4))
3301
+ (splat_const n (VectorSize.Size16x8)))
3302
+ (rule 5 (splat_const (u32_replicated_u16 n) (VectorSize.Size32x2))
3303
+ (splat_const n (VectorSize.Size16x4)))
3304
+ (rule 5 (splat_const (u16_replicated_u8 n) (VectorSize.Size16x8))
3305
+ (splat_const n (VectorSize.Size8x16)))
3306
+ (rule 5 (splat_const (u16_replicated_u8 n) (VectorSize.Size16x4))
3307
+ (splat_const n (VectorSize.Size8x8)))
3308
+
3309
+ ;; Special cases for `vec_dup_imm` instructions where the input is either
3310
+ ;; negated or not.
3311
+ (rule 4 (splat_const n size)
3312
+ (if-let imm (asimd_mov_mod_imm_from_u64 n (vector_lane_size size)))
3313
+ (vec_dup_imm imm $false size))
3314
+ (rule 3 (splat_const n size)
3315
+ (if-let imm (asimd_mov_mod_imm_from_u64 (u64_not n) (vector_lane_size size)))
3316
+ (vec_dup_imm imm $true size))
3317
+
3318
+ ;; Special case a 32-bit splat where an immediate can be created by
3319
+ ;; concatenating the 32-bit constant into a 64-bit value
3320
+ (rule 2 (splat_const n (VectorSize.Size32x4))
3321
+ (if-let imm (asimd_mov_mod_imm_from_u64 (u64_or n (u64_shl n 32)) (ScalarSize.Size64)))
3322
+ (vec_dup_imm imm $false (VectorSize.Size64x2)))
3323
+ (rule 2 (splat_const n (VectorSize.Size32x2))
3324
+ (if-let imm (asimd_mov_mod_imm_from_u64 (u64_or n (u64_shl n 32)) (ScalarSize.Size64)))
3325
+ (fpu_extend (vec_dup_imm imm $false (VectorSize.Size64x2)) (ScalarSize.Size64)))
3326
+
3327
+ (rule 1 (splat_const n size)
3328
+ (if-let imm (asimd_fp_mod_imm_from_u64 n (vector_lane_size size)))
3329
+ (vec_dup_fp_imm imm size))
3330
+
3331
+ ;; The base case for splat is to use `vec_dup` with the immediate loaded into a
3332
+ ;; register.
3333
+ (rule (splat_const n size)
3334
+ (vec_dup (imm $I64 (ImmExtend.Zero) n) size))
3335
+
3336
+ ;; Lower a FloatCC to a Cond.
3337
+ (decl fp_cond_code (FloatCC) Cond)
3338
+ ;; TODO: Port lower_fp_condcode() to ISLE.
3339
+ (extern constructor fp_cond_code fp_cond_code)
3340
+
3341
+ ;; Lower an integer cond code.
3342
+ (decl cond_code (IntCC) Cond)
3343
+ ;; TODO: Port lower_condcode() to ISLE.
3344
+ (extern constructor cond_code cond_code)
3345
+
3346
+ ;; Invert a condition code.
3347
+ (decl invert_cond (Cond) Cond)
3348
+ ;; TODO: Port cond.invert() to ISLE.
3349
+ (extern constructor invert_cond invert_cond)
3350
+
3351
+ ;; Generate comparison to zero operator from input condition code
3352
+ (decl float_cc_cmp_zero_to_vec_misc_op (FloatCC) VecMisc2)
3353
+ (extern constructor float_cc_cmp_zero_to_vec_misc_op float_cc_cmp_zero_to_vec_misc_op)
3354
+
3355
+ (decl float_cc_cmp_zero_to_vec_misc_op_swap (FloatCC) VecMisc2)
3356
+ (extern constructor float_cc_cmp_zero_to_vec_misc_op_swap float_cc_cmp_zero_to_vec_misc_op_swap)
3357
+
3358
+ ;; Match valid generic compare to zero cases
3359
+ (decl fcmp_zero_cond (FloatCC) FloatCC)
3360
+ (extern extractor fcmp_zero_cond fcmp_zero_cond)
3361
+
3362
+ ;; Match not equal compare to zero separately as it requires two output instructions
3363
+ (decl fcmp_zero_cond_not_eq (FloatCC) FloatCC)
3364
+ (extern extractor fcmp_zero_cond_not_eq fcmp_zero_cond_not_eq)
3365
+
3366
+ ;; Helper for generating float compare to zero instructions where 2nd argument is zero
3367
+ (decl float_cmp_zero (FloatCC Reg VectorSize) Reg)
3368
+ (rule (float_cmp_zero cond rn size)
3369
+ (vec_misc (float_cc_cmp_zero_to_vec_misc_op cond) rn size))
3370
+
3371
+ ;; Helper for generating float compare to zero instructions in case where 1st argument is zero
3372
+ (decl float_cmp_zero_swap (FloatCC Reg VectorSize) Reg)
3373
+ (rule (float_cmp_zero_swap cond rn size)
3374
+ (vec_misc (float_cc_cmp_zero_to_vec_misc_op_swap cond) rn size))
3375
+
3376
+ ;; Helper for generating float compare equal to zero instruction
3377
+ (decl fcmeq0 (Reg VectorSize) Reg)
3378
+ (rule (fcmeq0 rn size)
3379
+ (vec_misc (VecMisc2.Fcmeq0) rn size))
3380
+
3381
+ ;; Generate comparison to zero operator from input condition code
3382
+ (decl int_cc_cmp_zero_to_vec_misc_op (IntCC) VecMisc2)
3383
+ (extern constructor int_cc_cmp_zero_to_vec_misc_op int_cc_cmp_zero_to_vec_misc_op)
3384
+
3385
+ (decl int_cc_cmp_zero_to_vec_misc_op_swap (IntCC) VecMisc2)
3386
+ (extern constructor int_cc_cmp_zero_to_vec_misc_op_swap int_cc_cmp_zero_to_vec_misc_op_swap)
3387
+
3388
+ ;; Match valid generic compare to zero cases
3389
+ (decl icmp_zero_cond (IntCC) IntCC)
3390
+ (extern extractor icmp_zero_cond icmp_zero_cond)
3391
+
3392
+ ;; Match not equal compare to zero separately as it requires two output instructions
3393
+ (decl icmp_zero_cond_not_eq (IntCC) IntCC)
3394
+ (extern extractor icmp_zero_cond_not_eq icmp_zero_cond_not_eq)
3395
+
3396
+ ;; Helper for generating int compare to zero instructions where 2nd argument is zero
3397
+ (decl int_cmp_zero (IntCC Reg VectorSize) Reg)
3398
+ (rule (int_cmp_zero cond rn size)
3399
+ (vec_misc (int_cc_cmp_zero_to_vec_misc_op cond) rn size))
3400
+
3401
+ ;; Helper for generating int compare to zero instructions in case where 1st argument is zero
3402
+ (decl int_cmp_zero_swap (IntCC Reg VectorSize) Reg)
3403
+ (rule (int_cmp_zero_swap cond rn size)
3404
+ (vec_misc (int_cc_cmp_zero_to_vec_misc_op_swap cond) rn size))
3405
+
3406
+ ;; Helper for generating int compare equal to zero instruction
3407
+ (decl cmeq0 (Reg VectorSize) Reg)
3408
+ (rule (cmeq0 rn size)
3409
+ (vec_misc (VecMisc2.Cmeq0) rn size))
3410
+
3411
+ ;; Helper for emitting `MInst.AtomicRMW` instructions.
3412
+ (decl lse_atomic_rmw (AtomicRMWOp Value Reg Type MemFlags) Reg)
3413
+ (rule (lse_atomic_rmw op p r_arg2 ty flags)
3414
+ (let (
3415
+ (r_addr Reg p)
3416
+ (dst WritableReg (temp_writable_reg ty))
3417
+ (_ Unit (emit (MInst.AtomicRMW op r_arg2 dst r_addr ty flags)))
3418
+ )
3419
+ dst))
3420
+
3421
+ ;; Helper for emitting `MInst.AtomicCAS` instructions.
3422
+ (decl lse_atomic_cas (Reg Reg Reg Type MemFlags) Reg)
3423
+ (rule (lse_atomic_cas addr expect replace ty flags)
3424
+ (let (
3425
+ (dst WritableReg (temp_writable_reg ty))
3426
+ (_ Unit (emit (MInst.AtomicCAS dst expect replace addr ty flags)))
3427
+ )
3428
+ dst))
3429
+
3430
+ ;; Helper for emitting `MInst.AtomicRMWLoop` instructions.
3431
+ ;; - Make sure that both args are in virtual regs, since in effect
3432
+ ;; we have to do a parallel copy to get them safely to the AtomicRMW input
3433
+ ;; regs, and that's not guaranteed safe if either is in a real reg.
3434
+ ;; - Move the args to the preordained AtomicRMW input regs
3435
+ ;; - And finally, copy the preordained AtomicRMW output reg to its destination.
3436
+ (decl atomic_rmw_loop (AtomicRMWLoopOp Reg Reg Type MemFlags) Reg)
3437
+ (rule (atomic_rmw_loop op addr operand ty flags)
3438
+ (let ((dst WritableReg (temp_writable_reg $I64))
3439
+ (scratch1 WritableReg (temp_writable_reg $I64))
3440
+ (scratch2 WritableReg (temp_writable_reg $I64))
3441
+ (_ Unit (emit (MInst.AtomicRMWLoop ty op flags addr operand dst scratch1 scratch2))))
3442
+ dst))
3443
+
3444
+ ;; Helper for emitting `MInst.AtomicCASLoop` instructions.
3445
+ ;; This is very similar to, but not identical to, the AtomicRmw case. Note
3446
+ ;; that the AtomicCASLoop sequence does its own masking, so we don't need to worry
3447
+ ;; about zero-extending narrow (I8/I16/I32) values here.
3448
+ ;; Make sure that all three args are in virtual regs. See corresponding comment
3449
+ ;; for `atomic_rmw_loop` above.
3450
+ (decl atomic_cas_loop (Reg Reg Reg Type MemFlags) Reg)
3451
+ (rule (atomic_cas_loop addr expect replace ty flags)
3452
+ (let ((dst WritableReg (temp_writable_reg $I64))
3453
+ (scratch WritableReg (temp_writable_reg $I64))
3454
+ (_ Unit (emit (MInst.AtomicCASLoop ty flags addr expect replace dst scratch))))
3455
+ dst))
3456
+
3457
+ ;; Helper for emitting `MInst.MovPReg` instructions.
3458
+ (decl mov_from_preg (PReg) Reg)
3459
+ (rule (mov_from_preg src)
3460
+ (let ((dst WritableReg (temp_writable_reg $I64))
3461
+ (_ Unit (emit (MInst.MovFromPReg dst src))))
3462
+ dst))
3463
+
3464
+ (decl mov_to_preg (PReg Reg) SideEffectNoResult)
3465
+ (rule (mov_to_preg dst src)
3466
+ (SideEffectNoResult.Inst (MInst.MovToPReg dst src)))
3467
+
3468
+ (decl preg_sp () PReg)
3469
+ (extern constructor preg_sp preg_sp)
3470
+
3471
+ (decl preg_fp () PReg)
3472
+ (extern constructor preg_fp preg_fp)
3473
+
3474
+ (decl preg_link () PReg)
3475
+ (extern constructor preg_link preg_link)
3476
+
3477
+ (decl preg_pinned () PReg)
3478
+ (extern constructor preg_pinned preg_pinned)
3479
+
3480
+ (decl aarch64_sp () Reg)
3481
+ (rule (aarch64_sp)
3482
+ (mov_from_preg (preg_sp)))
3483
+
3484
+ (decl aarch64_fp () Reg)
3485
+ (rule (aarch64_fp)
3486
+ (mov_from_preg (preg_fp)))
3487
+
3488
+ (decl aarch64_link () Reg)
3489
+ (rule 1 (aarch64_link)
3490
+ (if (preserve_frame_pointers))
3491
+ (if (sign_return_address_disabled))
3492
+ (let ((dst WritableReg (temp_writable_reg $I64))
3493
+ ;; Even though LR is not an allocatable register, whether it
3494
+ ;; contains the return address for the current function is
3495
+ ;; unknown at this point. For example, this operation may come
3496
+ ;; immediately after a call, in which case LR would not have a
3497
+ ;; valid value. That's why we must obtain the return address from
3498
+ ;; the frame record that corresponds to the current subroutine on
3499
+ ;; the stack; the presence of the record is guaranteed by the
3500
+ ;; `preserve_frame_pointers` setting.
3501
+ (addr AMode (AMode.FPOffset 8 $I64))
3502
+ (_ Unit (emit (MInst.ULoad64 dst addr (mem_flags_trusted)))))
3503
+ dst))
3504
+
3505
+ (rule (aarch64_link)
3506
+ (if (preserve_frame_pointers))
3507
+ ;; Similarly to the rule above, we must load the return address from the
3508
+ ;; the frame record. Furthermore, we can use LR as a scratch register
3509
+ ;; because the function will set it to the return address immediately
3510
+ ;; before returning.
3511
+ (let ((addr AMode (AMode.FPOffset 8 $I64))
3512
+ (lr WritableReg (writable_link_reg))
3513
+ (_ Unit (emit (MInst.ULoad64 lr addr (mem_flags_trusted))))
3514
+ (_ Unit (emit (MInst.Xpaclri))))
3515
+ (mov_from_preg (preg_link))))
3516
+
3517
+ ;; Helper for getting the maximum shift amount for a type.
3518
+
3519
+ (decl max_shift (Type) u8)
3520
+ (rule (max_shift $F64) 63)
3521
+ (rule (max_shift $F32) 31)
3522
+
3523
+ ;; Helper for generating `fcopysign` instruction sequences.
3524
+
3525
+ (decl fcopy_sign (Reg Reg Type) Reg)
3526
+ (rule 1 (fcopy_sign x y (ty_scalar_float ty))
3527
+ (let ((dst WritableReg (temp_writable_reg $F64))
3528
+ (tmp Reg (fpu_rri (fpu_op_ri_ushr (ty_bits ty) (max_shift ty)) y))
3529
+ (_ Unit (emit (MInst.FpuRRIMod (fpu_op_ri_sli (ty_bits ty) (max_shift ty)) dst x tmp))))
3530
+ dst))
3531
+ (rule (fcopy_sign x y ty @ (multi_lane _ _))
3532
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
3533
+ (tmp Reg (ushr_vec_imm y (max_shift (lane_type ty)) (vector_size ty)))
3534
+ (_ Unit (emit (MInst.VecShiftImmMod (VecShiftImmModOp.Sli) dst x tmp (vector_size ty) (max_shift (lane_type ty))))))
3535
+ dst))
3536
+
3537
+ ;; Helpers for generating `MInst.FpuToInt` instructions.
3538
+
3539
+ (decl fpu_to_int_nan_check (ScalarSize Reg) Reg)
3540
+ (rule (fpu_to_int_nan_check size src)
3541
+ (let ((r ValueRegs
3542
+ (with_flags (fpu_cmp size src src)
3543
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3544
+ (MInst.TrapIf (cond_br_cond (Cond.Vs))
3545
+ (trap_code_bad_conversion_to_integer))
3546
+ src))))
3547
+ (value_regs_get r 0)))
3548
+
3549
+ ;; Checks that the value is not less than the minimum bound,
3550
+ ;; accepting a boolean (whether the type is signed), input type,
3551
+ ;; output type, and registers containing the source and minimum bound.
3552
+ (decl fpu_to_int_underflow_check (bool Type Type Reg Reg) Reg)
3553
+ (rule (fpu_to_int_underflow_check $true $F32 (fits_in_16 out_ty) src min)
3554
+ (let ((r ValueRegs
3555
+ (with_flags (fpu_cmp (ScalarSize.Size32) src min)
3556
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3557
+ (MInst.TrapIf (cond_br_cond (Cond.Le))
3558
+ (trap_code_integer_overflow))
3559
+ src))))
3560
+ (value_regs_get r 0)))
3561
+ (rule (fpu_to_int_underflow_check $true $F64 (fits_in_32 out_ty) src min)
3562
+ (let ((r ValueRegs
3563
+ (with_flags (fpu_cmp (ScalarSize.Size64) src min)
3564
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3565
+ (MInst.TrapIf (cond_br_cond (Cond.Le))
3566
+ (trap_code_integer_overflow))
3567
+ src))))
3568
+ (value_regs_get r 0)))
3569
+ (rule -1 (fpu_to_int_underflow_check $true in_ty _out_ty src min)
3570
+ (let ((r ValueRegs
3571
+ (with_flags (fpu_cmp (scalar_size in_ty) src min)
3572
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3573
+ (MInst.TrapIf (cond_br_cond (Cond.Lt))
3574
+ (trap_code_integer_overflow))
3575
+ src))))
3576
+ (value_regs_get r 0)))
3577
+ (rule (fpu_to_int_underflow_check $false in_ty _out_ty src min)
3578
+ (let ((r ValueRegs
3579
+ (with_flags (fpu_cmp (scalar_size in_ty) src min)
3580
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3581
+ (MInst.TrapIf (cond_br_cond (Cond.Le))
3582
+ (trap_code_integer_overflow))
3583
+ src))))
3584
+ (value_regs_get r 0)))
3585
+
3586
+ (decl fpu_to_int_overflow_check (ScalarSize Reg Reg) Reg)
3587
+ (rule (fpu_to_int_overflow_check size src max)
3588
+ (let ((r ValueRegs
3589
+ (with_flags (fpu_cmp size src max)
3590
+ (ConsumesFlags.ConsumesFlagsReturnsReg
3591
+ (MInst.TrapIf (cond_br_cond (Cond.Ge))
3592
+ (trap_code_integer_overflow))
3593
+ src))))
3594
+ (value_regs_get r 0)))
3595
+
3596
+ ;; Emits the appropriate instruction sequence to convert a
3597
+ ;; floating-point value to an integer, trapping if the value
3598
+ ;; is a NaN or does not fit in the target type.
3599
+ ;; Accepts the specific conversion op, the source register,
3600
+ ;; whether the input is signed, and finally the input and output
3601
+ ;; types.
3602
+ (decl fpu_to_int_cvt (FpuToIntOp Reg bool Type Type) Reg)
3603
+ (rule (fpu_to_int_cvt op src signed in_ty out_ty)
3604
+ (let ((size ScalarSize (scalar_size in_ty))
3605
+ (in_bits u8 (ty_bits in_ty))
3606
+ (out_bits u8 (ty_bits out_ty))
3607
+ (src Reg (fpu_to_int_nan_check size src))
3608
+ (min Reg (min_fp_value signed in_bits out_bits))
3609
+ (src Reg (fpu_to_int_underflow_check signed in_ty out_ty src min))
3610
+ (max Reg (max_fp_value signed in_bits out_bits))
3611
+ (src Reg (fpu_to_int_overflow_check size src max)))
3612
+ (fpu_to_int op src)))
3613
+
3614
+ ;; Emits the appropriate instruction sequence to convert a
3615
+ ;; floating-point value to an integer, saturating if the value
3616
+ ;; does not fit in the target type.
3617
+ ;; Accepts the specific conversion op, the source register,
3618
+ ;; whether the input is signed, and finally the output type.
3619
+ (decl fpu_to_int_cvt_sat (FpuToIntOp Reg bool Type) Reg)
3620
+ (rule 1 (fpu_to_int_cvt_sat op src _ $I64)
3621
+ (fpu_to_int op src))
3622
+ (rule 1 (fpu_to_int_cvt_sat op src _ $I32)
3623
+ (fpu_to_int op src))
3624
+ (rule (fpu_to_int_cvt_sat op src $false (fits_in_16 out_ty))
3625
+ (let ((result Reg (fpu_to_int op src))
3626
+ (max Reg (imm out_ty (ImmExtend.Zero) (ty_mask out_ty))))
3627
+ (with_flags_reg
3628
+ (cmp (OperandSize.Size32) result max)
3629
+ (csel (Cond.Hi) max result))))
3630
+ (rule (fpu_to_int_cvt_sat op src $true (fits_in_16 out_ty))
3631
+ (let ((result Reg (fpu_to_int op src))
3632
+ (max Reg (signed_max out_ty))
3633
+ (min Reg (signed_min out_ty))
3634
+ (result Reg (with_flags_reg
3635
+ (cmp (operand_size out_ty) result max)
3636
+ (csel (Cond.Gt) max result)))
3637
+ (result Reg (with_flags_reg
3638
+ (cmp (operand_size out_ty) result min)
3639
+ (csel (Cond.Lt) min result))))
3640
+ result))
3641
+
3642
+ (decl signed_min (Type) Reg)
3643
+ (rule (signed_min $I8) (imm $I8 (ImmExtend.Sign) 0x80))
3644
+ (rule (signed_min $I16) (imm $I16 (ImmExtend.Sign) 0x8000))
3645
+
3646
+ (decl signed_max (Type) Reg)
3647
+ (rule (signed_max $I8) (imm $I8 (ImmExtend.Sign) 0x7F))
3648
+ (rule (signed_max $I16) (imm $I16 (ImmExtend.Sign) 0x7FFF))
3649
+
3650
+ (decl fpu_to_int (FpuToIntOp Reg) Reg)
3651
+ (rule (fpu_to_int op src)
3652
+ (let ((dst WritableReg (temp_writable_reg $I64))
3653
+ (_ Unit (emit (MInst.FpuToInt op dst src))))
3654
+ dst))
3655
+
3656
+ ;; Helper for generating `MInst.IntToFpu` instructions.
3657
+
3658
+ (decl int_to_fpu (IntToFpuOp Reg) Reg)
3659
+ (rule (int_to_fpu op src)
3660
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
3661
+ (_ Unit (emit (MInst.IntToFpu op dst src))))
3662
+ dst))
3663
+
3664
+ ;;;; Helpers for Emitting Calls ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3665
+
3666
+ (decl gen_call (SigRef ExternalName RelocDistance ValueSlice) InstOutput)
3667
+ (extern constructor gen_call gen_call)
3668
+
3669
+ (decl gen_call_indirect (SigRef Value ValueSlice) InstOutput)
3670
+ (extern constructor gen_call_indirect gen_call_indirect)
3671
+
3672
+ ;; Helpers for pinned register manipulation.
3673
+
3674
+ (decl write_pinned_reg (Reg) SideEffectNoResult)
3675
+ (rule (write_pinned_reg val)
3676
+ (mov_to_preg (preg_pinned) val))
3677
+
3678
+ ;; Helpers for stackslot effective address generation.
3679
+
3680
+ (decl compute_stack_addr (StackSlot Offset32) Reg)
3681
+ (rule (compute_stack_addr stack_slot offset)
3682
+ (let ((dst WritableReg (temp_writable_reg $I64))
3683
+ (_ Unit (emit (abi_stackslot_addr dst stack_slot offset))))
3684
+ dst))
3685
+
3686
+ ;; Helper for emitting instruction sequences to perform a vector comparison.
3687
+
3688
+ (decl vec_cmp_vc (Reg Reg VectorSize) Reg)
3689
+ (rule (vec_cmp_vc rn rm size)
3690
+ (let ((dst Reg (vec_rrr (VecALUOp.Fcmeq) rn rn size))
3691
+ (tmp Reg (vec_rrr (VecALUOp.Fcmeq) rm rm size))
3692
+ (dst Reg (vec_rrr (VecALUOp.And) dst tmp size)))
3693
+ dst))
3694
+
3695
+ (decl vec_cmp (Reg Reg Type Cond) Reg)
3696
+
3697
+ ;; Floating point Vs / Vc
3698
+ (rule (vec_cmp rn rm ty (Cond.Vc))
3699
+ (if (ty_vector_float ty))
3700
+ (vec_cmp_vc rn rm (vector_size ty)))
3701
+ (rule (vec_cmp rn rm ty (Cond.Vs))
3702
+ (if (ty_vector_float ty))
3703
+ (let ((tmp Reg (vec_cmp_vc rn rm (vector_size ty))))
3704
+ (vec_misc (VecMisc2.Not) tmp (vector_size ty))))
3705
+
3706
+ ;; 'Less than' operations are implemented by swapping the order of
3707
+ ;; operands and using the 'greater than' instructions.
3708
+ ;; 'Not equal' is implemented with 'equal' and inverting the result.
3709
+
3710
+ ;; Floating-point
3711
+ (rule (vec_cmp rn rm ty (Cond.Eq))
3712
+ (if (ty_vector_float ty))
3713
+ (vec_rrr (VecALUOp.Fcmeq) rn rm (vector_size ty)))
3714
+ (rule (vec_cmp rn rm ty (Cond.Ne))
3715
+ (if (ty_vector_float ty))
3716
+ (let ((tmp Reg (vec_rrr (VecALUOp.Fcmeq) rn rm (vector_size ty))))
3717
+ (vec_misc (VecMisc2.Not) tmp (vector_size ty))))
3718
+ (rule (vec_cmp rn rm ty (Cond.Ge))
3719
+ (if (ty_vector_float ty))
3720
+ (vec_rrr (VecALUOp.Fcmge) rn rm (vector_size ty)))
3721
+ (rule (vec_cmp rn rm ty (Cond.Gt))
3722
+ (if (ty_vector_float ty))
3723
+ (vec_rrr (VecALUOp.Fcmgt) rn rm (vector_size ty)))
3724
+ ;; Floating-point swapped-operands
3725
+ (rule (vec_cmp rn rm ty (Cond.Mi))
3726
+ (if (ty_vector_float ty))
3727
+ (vec_rrr (VecALUOp.Fcmgt) rm rn (vector_size ty)))
3728
+ (rule (vec_cmp rn rm ty (Cond.Ls))
3729
+ (if (ty_vector_float ty))
3730
+ (vec_rrr (VecALUOp.Fcmge) rm rn (vector_size ty)))
3731
+
3732
+ ;; Integer
3733
+ (rule 1 (vec_cmp rn rm ty (Cond.Eq))
3734
+ (if (ty_vector_not_float ty))
3735
+ (vec_rrr (VecALUOp.Cmeq) rn rm (vector_size ty)))
3736
+ (rule 1 (vec_cmp rn rm ty (Cond.Ne))
3737
+ (if (ty_vector_not_float ty))
3738
+ (let ((tmp Reg (vec_rrr (VecALUOp.Cmeq) rn rm (vector_size ty))))
3739
+ (vec_misc (VecMisc2.Not) tmp (vector_size ty))))
3740
+ (rule 1 (vec_cmp rn rm ty (Cond.Ge))
3741
+ (if (ty_vector_not_float ty))
3742
+ (vec_rrr (VecALUOp.Cmge) rn rm (vector_size ty)))
3743
+ (rule 1 (vec_cmp rn rm ty (Cond.Gt))
3744
+ (if (ty_vector_not_float ty))
3745
+ (vec_rrr (VecALUOp.Cmgt) rn rm (vector_size ty)))
3746
+ (rule (vec_cmp rn rm ty (Cond.Hs))
3747
+ (if (ty_vector_not_float ty))
3748
+ (vec_rrr (VecALUOp.Cmhs) rn rm (vector_size ty)))
3749
+ (rule (vec_cmp rn rm ty (Cond.Hi))
3750
+ (if (ty_vector_not_float ty))
3751
+ (vec_rrr (VecALUOp.Cmhi) rn rm (vector_size ty)))
3752
+ ;; Integer swapped-operands
3753
+ (rule (vec_cmp rn rm ty (Cond.Le))
3754
+ (if (ty_vector_not_float ty))
3755
+ (vec_rrr (VecALUOp.Cmge) rm rn (vector_size ty)))
3756
+ (rule (vec_cmp rn rm ty (Cond.Lt))
3757
+ (if (ty_vector_not_float ty))
3758
+ (vec_rrr (VecALUOp.Cmgt) rm rn (vector_size ty)))
3759
+ (rule 1 (vec_cmp rn rm ty (Cond.Ls))
3760
+ (if (ty_vector_not_float ty))
3761
+ (vec_rrr (VecALUOp.Cmhs) rm rn (vector_size ty)))
3762
+ (rule (vec_cmp rn rm ty (Cond.Lo))
3763
+ (if (ty_vector_not_float ty))
3764
+ (vec_rrr (VecALUOp.Cmhi) rm rn (vector_size ty)))
3765
+
3766
+ ;; Helper for determining if any value in a vector is true.
3767
+ ;; This operation is implemented by using umaxp to create a scalar value, which
3768
+ ;; is then compared against zero.
3769
+ ;;
3770
+ ;; umaxp vn.4s, vm.4s, vm.4s
3771
+ ;; mov xm, vn.d[0]
3772
+ ;; cmp xm, #0
3773
+ (decl vanytrue (Reg Type) ProducesFlags)
3774
+ (rule 1 (vanytrue src (ty_vec128 ty))
3775
+ (let ((src Reg (vec_rrr (VecALUOp.Umaxp) src src (VectorSize.Size32x4)))
3776
+ (src Reg (mov_from_vec src 0 (ScalarSize.Size64))))
3777
+ (cmp_imm (OperandSize.Size64) src (u8_into_imm12 0))))
3778
+ (rule (vanytrue src ty)
3779
+ (if (ty_vec64 ty))
3780
+ (let ((src Reg (mov_from_vec src 0 (ScalarSize.Size64))))
3781
+ (cmp_imm (OperandSize.Size64) src (u8_into_imm12 0))))
3782
+
3783
+ ;;;; TLS Values ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3784
+
3785
+ ;; Helper for emitting ElfTlsGetAddr.
3786
+ (decl elf_tls_get_addr (ExternalName) Reg)
3787
+ (rule (elf_tls_get_addr name)
3788
+ (let ((dst WritableReg (temp_writable_reg $I64))
3789
+ (tmp WritableReg (temp_writable_reg $I64))
3790
+ (_ Unit (emit (MInst.ElfTlsGetAddr (box_external_name name) dst tmp))))
3791
+ dst))
3792
+
3793
+ (decl macho_tls_get_addr (ExternalName) Reg)
3794
+ (rule (macho_tls_get_addr name)
3795
+ (let ((dst WritableReg (temp_writable_reg $I64))
3796
+ (_ Unit (emit (MInst.MachOTlsGetAddr name dst))))
3797
+ dst))
3798
+
3799
+ ;; A tuple of `ProducesFlags` and `IntCC`.
3800
+ (type FlagsAndCC (enum (FlagsAndCC (flags ProducesFlags)
3801
+ (cc IntCC))))
3802
+
3803
+ ;; Helper constructor for `FlagsAndCC`.
3804
+ (decl flags_and_cc (ProducesFlags IntCC) FlagsAndCC)
3805
+ (rule (flags_and_cc flags cc) (FlagsAndCC.FlagsAndCC flags cc))
3806
+
3807
+ ;; Materialize a `FlagsAndCC` into a boolean `ValueRegs`.
3808
+ (decl flags_and_cc_to_bool (FlagsAndCC) ValueRegs)
3809
+ (rule (flags_and_cc_to_bool (FlagsAndCC.FlagsAndCC flags cc))
3810
+ (with_flags flags (materialize_bool_result (cond_code cc))))
3811
+
3812
+ ;; Get the `ProducesFlags` out of a `FlagsAndCC`.
3813
+ (decl flags_and_cc_flags (FlagsAndCC) ProducesFlags)
3814
+ (rule (flags_and_cc_flags (FlagsAndCC.FlagsAndCC flags _cc)) flags)
3815
+
3816
+ ;; Get the `IntCC` out of a `FlagsAndCC`.
3817
+ (decl flags_and_cc_cc (FlagsAndCC) IntCC)
3818
+ (rule (flags_and_cc_cc (FlagsAndCC.FlagsAndCC _flags cc)) cc)
3819
+
3820
+ ;; Helpers for lowering `icmp` sequences.
3821
+ ;; `lower_icmp` contains shared functionality for lowering `icmp`
3822
+ ;; sequences, which `lower_icmp_into_{reg,flags}` extend from.
3823
+ (decl lower_icmp (IntCC Value Value Type) FlagsAndCC)
3824
+ (decl lower_icmp_into_reg (IntCC Value Value Type Type) ValueRegs)
3825
+ (decl lower_icmp_into_flags (IntCC Value Value Type) FlagsAndCC)
3826
+ (decl lower_icmp_const (IntCC Value u64 Type) FlagsAndCC)
3827
+ ;; For most cases, `lower_icmp_into_flags` is the same as `lower_icmp`,
3828
+ ;; except for some I128 cases (see below).
3829
+ (rule -1 (lower_icmp_into_flags cond x y ty) (lower_icmp cond x y ty))
3830
+
3831
+ ;; Vectors.
3832
+ ;; `icmp` into flags for vectors is invalid.
3833
+ (rule 1 (lower_icmp_into_reg cond x y in_ty @ (multi_lane _ _) _out_ty)
3834
+ (let ((cond Cond (cond_code cond))
3835
+ (rn Reg (put_in_reg x))
3836
+ (rm Reg (put_in_reg y)))
3837
+ (vec_cmp rn rm in_ty cond)))
3838
+
3839
+ ;; Determines the appropriate extend op given the value type and the given ArgumentExtension.
3840
+ (decl lower_extend_op (Type ArgumentExtension) ExtendOp)
3841
+ (rule (lower_extend_op $I8 (ArgumentExtension.Sext)) (ExtendOp.SXTB))
3842
+ (rule (lower_extend_op $I16 (ArgumentExtension.Sext)) (ExtendOp.SXTH))
3843
+ (rule (lower_extend_op $I8 (ArgumentExtension.Uext)) (ExtendOp.UXTB))
3844
+ (rule (lower_extend_op $I16 (ArgumentExtension.Uext)) (ExtendOp.UXTH))
3845
+
3846
+ ;; Integers <= 64-bits.
3847
+ (rule -2 (lower_icmp_into_reg cond rn rm in_ty out_ty)
3848
+ (if (ty_int_ref_scalar_64 in_ty))
3849
+ (let ((cc Cond (cond_code cond)))
3850
+ (flags_and_cc_to_bool (lower_icmp cond rn rm in_ty))))
3851
+
3852
+ (rule 1 (lower_icmp cond rn rm (fits_in_16 ty))
3853
+ (if (signed_cond_code cond))
3854
+ (let ((rn Reg (put_in_reg_sext32 rn)))
3855
+ (flags_and_cc (cmp_extend (operand_size ty) rn rm (lower_extend_op ty (ArgumentExtension.Sext))) cond)))
3856
+ (rule -1 (lower_icmp cond rn (imm12_from_value rm) (fits_in_16 ty))
3857
+ (let ((rn Reg (put_in_reg_zext32 rn)))
3858
+ (flags_and_cc (cmp_imm (operand_size ty) rn rm) cond)))
3859
+ (rule -2 (lower_icmp cond rn rm (fits_in_16 ty))
3860
+ (let ((rn Reg (put_in_reg_zext32 rn)))
3861
+ (flags_and_cc (cmp_extend (operand_size ty) rn rm (lower_extend_op ty (ArgumentExtension.Uext))) cond)))
3862
+ (rule -3 (lower_icmp cond rn (u64_from_iconst c) ty)
3863
+ (if (ty_int_ref_scalar_64 ty))
3864
+ (lower_icmp_const cond rn c ty))
3865
+ (rule -4 (lower_icmp cond rn rm ty)
3866
+ (if (ty_int_ref_scalar_64 ty))
3867
+ (flags_and_cc (cmp (operand_size ty) rn rm) cond))
3868
+
3869
+ ;; We get better encodings when testing against an immediate that's even instead
3870
+ ;; of odd, so rewrite comparisons to use even immediates:
3871
+ ;;
3872
+ ;; A >= B + 1
3873
+ ;; ==> A - 1 >= B
3874
+ ;; ==> A > B
3875
+ (rule (lower_icmp_const (IntCC.UnsignedGreaterThanOrEqual) a b ty)
3876
+ (if (ty_int_ref_scalar_64 ty))
3877
+ (if-let $true (u64_is_odd b))
3878
+ (if-let (imm12_from_u64 imm) (u64_sub b 1))
3879
+ (flags_and_cc (cmp_imm (operand_size ty) a imm) (IntCC.UnsignedGreaterThan)))
3880
+ (rule (lower_icmp_const (IntCC.SignedGreaterThanOrEqual) a b ty)
3881
+ (if (ty_int_ref_scalar_64 ty))
3882
+ (if-let $true (u64_is_odd b))
3883
+ (if-let (imm12_from_u64 imm) (u64_sub b 1))
3884
+ (flags_and_cc (cmp_imm (operand_size ty) a imm) (IntCC.SignedGreaterThan)))
3885
+
3886
+ (rule -1 (lower_icmp_const cond rn (imm12_from_u64 c) ty)
3887
+ (if (ty_int_ref_scalar_64 ty))
3888
+ (flags_and_cc (cmp_imm (operand_size ty) rn c) cond))
3889
+ (rule -2 (lower_icmp_const cond rn c ty)
3890
+ (if (ty_int_ref_scalar_64 ty))
3891
+ (flags_and_cc (cmp (operand_size ty) rn (imm ty (ImmExtend.Zero) c)) cond))
3892
+
3893
+
3894
+ ;; 128-bit integers.
3895
+ (rule (lower_icmp_into_reg cond @ (IntCC.Equal) rn rm $I128 $I8)
3896
+ (let ((cc Cond (cond_code cond)))
3897
+ (flags_and_cc_to_bool
3898
+ (lower_icmp cond rn rm $I128))))
3899
+ (rule (lower_icmp_into_reg cond @ (IntCC.NotEqual) rn rm $I128 $I8)
3900
+ (let ((cc Cond (cond_code cond)))
3901
+ (flags_and_cc_to_bool
3902
+ (lower_icmp cond rn rm $I128))))
3903
+
3904
+ ;; cmp lhs_lo, rhs_lo
3905
+ ;; ccmp lhs_hi, rhs_hi, #0, eq
3906
+ (decl lower_icmp_i128_eq_ne (Value Value) ProducesFlags)
3907
+ (rule (lower_icmp_i128_eq_ne lhs rhs)
3908
+ (let ((lhs ValueRegs (put_in_regs lhs))
3909
+ (rhs ValueRegs (put_in_regs rhs))
3910
+ (lhs_lo Reg (value_regs_get lhs 0))
3911
+ (lhs_hi Reg (value_regs_get lhs 1))
3912
+ (rhs_lo Reg (value_regs_get rhs 0))
3913
+ (rhs_hi Reg (value_regs_get rhs 1))
3914
+ (cmp_inst ProducesFlags (cmp (OperandSize.Size64) lhs_lo rhs_lo)))
3915
+ (ccmp (OperandSize.Size64) lhs_hi rhs_hi
3916
+ (nzcv $false $false $false $false) (Cond.Eq) cmp_inst)))
3917
+
3918
+ (rule (lower_icmp (IntCC.Equal) lhs rhs $I128)
3919
+ (flags_and_cc (lower_icmp_i128_eq_ne lhs rhs) (IntCC.Equal)))
3920
+ (rule (lower_icmp (IntCC.NotEqual) lhs rhs $I128)
3921
+ (flags_and_cc (lower_icmp_i128_eq_ne lhs rhs) (IntCC.NotEqual)))
3922
+
3923
+ ;; cmp lhs_lo, rhs_lo
3924
+ ;; cset tmp1, unsigned_cond
3925
+ ;; cmp lhs_hi, rhs_hi
3926
+ ;; cset tmp2, cond
3927
+ ;; csel dst, tmp1, tmp2, eq
3928
+ (rule -1 (lower_icmp_into_reg cond lhs rhs $I128 $I8)
3929
+ (let ((unsigned_cond Cond (cond_code (intcc_unsigned cond)))
3930
+ (cond Cond (cond_code cond))
3931
+ (lhs ValueRegs (put_in_regs lhs))
3932
+ (rhs ValueRegs (put_in_regs rhs))
3933
+ (lhs_lo Reg (value_regs_get lhs 0))
3934
+ (lhs_hi Reg (value_regs_get lhs 1))
3935
+ (rhs_lo Reg (value_regs_get rhs 0))
3936
+ (rhs_hi Reg (value_regs_get rhs 1))
3937
+ (tmp1 Reg (with_flags_reg (cmp (OperandSize.Size64) lhs_lo rhs_lo)
3938
+ (materialize_bool_result unsigned_cond))))
3939
+ (with_flags (cmp (OperandSize.Size64) lhs_hi rhs_hi)
3940
+ (lower_icmp_i128_consumer cond tmp1))))
3941
+
3942
+ (decl lower_icmp_i128_consumer (Cond Reg) ConsumesFlags)
3943
+ (rule (lower_icmp_i128_consumer cond tmp1)
3944
+ (let ((tmp2 WritableReg (temp_writable_reg $I64))
3945
+ (dst WritableReg (temp_writable_reg $I64)))
3946
+ (ConsumesFlags.ConsumesFlagsTwiceReturnsValueRegs
3947
+ (MInst.CSet tmp2 cond)
3948
+ (MInst.CSel dst (Cond.Eq) tmp1 tmp2)
3949
+ (value_reg dst))))
3950
+
3951
+ (decl lower_bmask (Type Type ValueRegs) ValueRegs)
3952
+
3953
+
3954
+ ;; For conversions that exactly fit a register, we can use csetm.
3955
+ ;;
3956
+ ;; cmp val, #0
3957
+ ;; csetm res, ne
3958
+ (rule 0
3959
+ (lower_bmask (fits_in_64 _) (ty_32_or_64 in_ty) val)
3960
+ (with_flags_reg
3961
+ (cmp_imm (operand_size in_ty) (value_regs_get val 0) (u8_into_imm12 0))
3962
+ (csetm (Cond.Ne))))
3963
+
3964
+ ;; For conversions from a 128-bit value into a 64-bit or smaller one, we or the
3965
+ ;; two registers of the 128-bit value together, and then recurse with the
3966
+ ;; combined value as a 64-bit test.
3967
+ ;;
3968
+ ;; orr val, lo, hi
3969
+ ;; cmp val, #0
3970
+ ;; csetm res, ne
3971
+ (rule 1
3972
+ (lower_bmask (fits_in_64 ty) $I128 val)
3973
+ (let ((lo Reg (value_regs_get val 0))
3974
+ (hi Reg (value_regs_get val 1))
3975
+ (combined Reg (orr $I64 lo hi)))
3976
+ (lower_bmask ty $I64 (value_reg combined))))
3977
+
3978
+ ;; For converting from any type into i128, duplicate the result of
3979
+ ;; converting to i64.
3980
+ (rule 2
3981
+ (lower_bmask $I128 in_ty val)
3982
+ (let ((res ValueRegs (lower_bmask $I64 in_ty val))
3983
+ (res Reg (value_regs_get res 0)))
3984
+ (value_regs res res)))
3985
+
3986
+ ;; For conversions smaller than a register, we need to mask off the high bits, and then
3987
+ ;; we can recurse into the general case.
3988
+ ;;
3989
+ ;; and tmp, val, #ty_mask
3990
+ ;; cmp tmp, #0
3991
+ ;; csetm res, ne
3992
+ (rule 3
3993
+ (lower_bmask out_ty (fits_in_16 in_ty) val)
3994
+ ; This if-let can't fail due to ty_mask always producing 8/16 consecutive 1s.
3995
+ (if-let mask_bits (imm_logic_from_u64 $I32 (ty_mask in_ty)))
3996
+ (let ((masked Reg (and_imm $I32 (value_regs_get val 0) mask_bits)))
3997
+ (lower_bmask out_ty $I32 masked)))
3998
+
3999
+ ;; Exceptional `lower_icmp_into_flags` rules.
4000
+ ;; We need to guarantee that the flags for `cond` are correct, so we
4001
+ ;; compare `dst` with 1.
4002
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedGreaterThanOrEqual) lhs rhs $I128)
4003
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4004
+ (dst Reg (value_regs_get dst 0))
4005
+ (tmp Reg (imm $I64 (ImmExtend.Sign) 1))) ;; mov tmp, #1
4006
+ (flags_and_cc (cmp (OperandSize.Size64) dst tmp) cond)))
4007
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedGreaterThanOrEqual) lhs rhs $I128)
4008
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4009
+ (dst Reg (value_regs_get dst 0))
4010
+ (tmp Reg (imm $I64 (ImmExtend.Zero) 1)))
4011
+ (flags_and_cc (cmp (OperandSize.Size64) dst tmp) cond)))
4012
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedLessThanOrEqual) lhs rhs $I128)
4013
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4014
+ (dst Reg (value_regs_get dst 0))
4015
+ (tmp Reg (imm $I64 (ImmExtend.Sign) 1)))
4016
+ (flags_and_cc (cmp (OperandSize.Size64) tmp dst) cond)))
4017
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedLessThanOrEqual) lhs rhs $I128)
4018
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4019
+ (dst Reg (value_regs_get dst 0))
4020
+ (tmp Reg (imm $I64 (ImmExtend.Zero) 1)))
4021
+ (flags_and_cc (cmp (OperandSize.Size64) tmp dst) cond)))
4022
+ ;; For strict comparisons, we compare with 0.
4023
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedGreaterThan) lhs rhs $I128)
4024
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4025
+ (dst Reg (value_regs_get dst 0)))
4026
+ (flags_and_cc (cmp (OperandSize.Size64) dst (zero_reg)) cond)))
4027
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedGreaterThan) lhs rhs $I128)
4028
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4029
+ (dst Reg (value_regs_get dst 0)))
4030
+ (flags_and_cc (cmp (OperandSize.Size64) dst (zero_reg)) cond)))
4031
+ (rule (lower_icmp_into_flags cond @ (IntCC.SignedLessThan) lhs rhs $I128)
4032
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4033
+ (dst Reg (value_regs_get dst 0)))
4034
+ (flags_and_cc (cmp (OperandSize.Size64) (zero_reg) dst) cond)))
4035
+ (rule (lower_icmp_into_flags cond @ (IntCC.UnsignedLessThan) lhs rhs $I128)
4036
+ (let ((dst ValueRegs (lower_icmp_into_reg cond lhs rhs $I128 $I8))
4037
+ (dst Reg (value_regs_get dst 0)))
4038
+ (flags_and_cc (cmp (OperandSize.Size64) (zero_reg) dst) cond)))
4039
+
4040
+ ;; Helpers for generating select instruction sequences.
4041
+ (decl lower_select (ProducesFlags Cond Type Value Value) ValueRegs)
4042
+ (rule 2 (lower_select flags cond (ty_scalar_float ty) rn rm)
4043
+ (with_flags flags (fpu_csel ty cond rn rm)))
4044
+ (rule 3 (lower_select flags cond (ty_vec128 ty) rn rm)
4045
+ (with_flags flags (vec_csel cond rn rm)))
4046
+ (rule (lower_select flags cond ty rn rm)
4047
+ (if (ty_vec64 ty))
4048
+ (with_flags flags (fpu_csel $F64 cond rn rm)))
4049
+ (rule 4 (lower_select flags cond $I128 rn rm)
4050
+ (let ((dst_lo WritableReg (temp_writable_reg $I64))
4051
+ (dst_hi WritableReg (temp_writable_reg $I64))
4052
+ (rn ValueRegs (put_in_regs rn))
4053
+ (rm ValueRegs (put_in_regs rm))
4054
+ (rn_lo Reg (value_regs_get rn 0))
4055
+ (rn_hi Reg (value_regs_get rn 1))
4056
+ (rm_lo Reg (value_regs_get rm 0))
4057
+ (rm_hi Reg (value_regs_get rm 1)))
4058
+ (with_flags flags
4059
+ (ConsumesFlags.ConsumesFlagsTwiceReturnsValueRegs
4060
+ (MInst.CSel dst_lo cond rn_lo rm_lo)
4061
+ (MInst.CSel dst_hi cond rn_hi rm_hi)
4062
+ (value_regs dst_lo dst_hi)))))
4063
+ (rule 1 (lower_select flags cond ty rn rm)
4064
+ (if (ty_int_ref_scalar_64 ty))
4065
+ (with_flags flags (csel cond rn rm)))
4066
+
4067
+ ;; Helper for emitting `MInst.Jump` instructions.
4068
+ (decl aarch64_jump (BranchTarget) SideEffectNoResult)
4069
+ (rule (aarch64_jump target)
4070
+ (SideEffectNoResult.Inst (MInst.Jump target)))
4071
+
4072
+ ;; Helper for emitting `MInst.JTSequence` instructions.
4073
+ ;; Emit the compound instruction that does:
4074
+ ;;
4075
+ ;; b.hs default
4076
+ ;; csel rB, xzr, rIndex, hs
4077
+ ;; csdb
4078
+ ;; adr rA, jt
4079
+ ;; ldrsw rB, [rA, rB, uxtw #2]
4080
+ ;; add rA, rA, rB
4081
+ ;; br rA
4082
+ ;; [jt entries]
4083
+ ;;
4084
+ ;; This must be *one* instruction in the vcode because
4085
+ ;; we cannot allow regalloc to insert any spills/fills
4086
+ ;; in the middle of the sequence; otherwise, the ADR's
4087
+ ;; PC-rel offset to the jumptable would be incorrect.
4088
+ ;; (The alternative is to introduce a relocation pass
4089
+ ;; for inlined jumptables, which is much worse, IMHO.)
4090
+ (decl jt_sequence (Reg MachLabel BoxVecMachLabel) ConsumesFlags)
4091
+ (rule (jt_sequence ridx default targets)
4092
+ (let ((rtmp1 WritableReg (temp_writable_reg $I64))
4093
+ (rtmp2 WritableReg (temp_writable_reg $I64)))
4094
+ (ConsumesFlags.ConsumesFlagsSideEffect
4095
+ (MInst.JTSequence default targets ridx rtmp1 rtmp2))))
4096
+
4097
+ ;; Helper for emitting `MInst.CondBr` instructions.
4098
+ (decl cond_br (BranchTarget BranchTarget CondBrKind) ConsumesFlags)
4099
+ (rule (cond_br taken not_taken kind)
4100
+ (ConsumesFlags.ConsumesFlagsSideEffect
4101
+ (MInst.CondBr taken not_taken kind)))
4102
+
4103
+ ;; Helper for emitting `MInst.TestBitAndBranch` instructions.
4104
+ (decl test_branch (TestBitAndBranchKind BranchTarget BranchTarget Reg u8) SideEffectNoResult)
4105
+ (rule (test_branch kind taken not_taken rn bit)
4106
+ (SideEffectNoResult.Inst (MInst.TestBitAndBranch kind taken not_taken rn bit)))
4107
+
4108
+ ;; Helper for emitting `tbnz` instructions.
4109
+ (decl tbnz (BranchTarget BranchTarget Reg u8) SideEffectNoResult)
4110
+ (rule (tbnz taken not_taken rn bit)
4111
+ (test_branch (TestBitAndBranchKind.NZ) taken not_taken rn bit))
4112
+
4113
+ ;; Helper for emitting `tbz` instructions.
4114
+ (decl tbz (BranchTarget BranchTarget Reg u8) SideEffectNoResult)
4115
+ (rule (tbz taken not_taken rn bit)
4116
+ (test_branch (TestBitAndBranchKind.Z) taken not_taken rn bit))
4117
+
4118
+ ;; Helper for emitting `MInst.MovToNZCV` instructions.
4119
+ (decl mov_to_nzcv (Reg) ProducesFlags)
4120
+ (rule (mov_to_nzcv rn)
4121
+ (ProducesFlags.ProducesFlagsSideEffect
4122
+ (MInst.MovToNZCV rn)))
4123
+
4124
+ ;; Helper for emitting `MInst.EmitIsland` instructions.
4125
+ (decl emit_island (CodeOffset) SideEffectNoResult)
4126
+ (rule (emit_island needed_space)
4127
+ (SideEffectNoResult.Inst
4128
+ (MInst.EmitIsland needed_space)))
4129
+
4130
+ ;; Helper for emitting `br_table` sequences.
4131
+ (decl br_table_impl (u64 Reg MachLabel BoxVecMachLabel) Unit)
4132
+ (rule (br_table_impl (imm12_from_u64 jt_size) ridx default targets)
4133
+ (emit_side_effect (with_flags_side_effect
4134
+ (cmp_imm (OperandSize.Size32) ridx jt_size)
4135
+ (jt_sequence ridx default targets))))
4136
+ (rule -1 (br_table_impl jt_size ridx default targets)
4137
+ (let ((jt_size Reg (imm $I64 (ImmExtend.Zero) jt_size)))
4138
+ (emit_side_effect (with_flags_side_effect
4139
+ (cmp (OperandSize.Size32) ridx jt_size)
4140
+ (jt_sequence ridx default targets)))))
4141
+
4142
+ ;; Helper for emitting the `uzp1` instruction
4143
+ (decl vec_uzp1 (Reg Reg VectorSize) Reg)
4144
+ (rule (vec_uzp1 rn rm size) (vec_rrr (VecALUOp.Uzp1) rn rm size))
4145
+
4146
+ ;; Helper for emitting the `uzp2` instruction
4147
+ (decl vec_uzp2 (Reg Reg VectorSize) Reg)
4148
+ (rule (vec_uzp2 rn rm size) (vec_rrr (VecALUOp.Uzp2) rn rm size))
4149
+
4150
+ ;; Helper for emitting the `zip1` instruction
4151
+ (decl vec_zip1 (Reg Reg VectorSize) Reg)
4152
+ (rule (vec_zip1 rn rm size) (vec_rrr (VecALUOp.Zip1) rn rm size))
4153
+
4154
+ ;; Helper for emitting the `zip2` instruction
4155
+ (decl vec_zip2 (Reg Reg VectorSize) Reg)
4156
+ (rule (vec_zip2 rn rm size) (vec_rrr (VecALUOp.Zip2) rn rm size))
4157
+
4158
+ ;; Helper for emitting the `trn1` instruction
4159
+ (decl vec_trn1 (Reg Reg VectorSize) Reg)
4160
+ (rule (vec_trn1 rn rm size) (vec_rrr (VecALUOp.Trn1) rn rm size))
4161
+
4162
+ ;; Helper for emitting the `trn2` instruction
4163
+ (decl vec_trn2 (Reg Reg VectorSize) Reg)
4164
+ (rule (vec_trn2 rn rm size) (vec_rrr (VecALUOp.Trn2) rn rm size))
4165
+
4166
+ ;; Helper for creating a zero value `ASIMDMovModImm` immediate.
4167
+ (decl asimd_mov_mod_imm_zero (ScalarSize) ASIMDMovModImm)
4168
+ (extern constructor asimd_mov_mod_imm_zero asimd_mov_mod_imm_zero)
4169
+
4170
+ ;; Helper for fallibly creating an `ASIMDMovModImm` immediate from its parts.
4171
+ (decl pure partial asimd_mov_mod_imm_from_u64 (u64 ScalarSize) ASIMDMovModImm)
4172
+ (extern constructor asimd_mov_mod_imm_from_u64 asimd_mov_mod_imm_from_u64)
4173
+
4174
+ ;; Helper for fallibly creating an `ASIMDFPModImm` immediate from its parts.
4175
+ (decl pure partial asimd_fp_mod_imm_from_u64 (u64 ScalarSize) ASIMDFPModImm)
4176
+ (extern constructor asimd_fp_mod_imm_from_u64 asimd_fp_mod_imm_from_u64)
4177
+
4178
+ ;; Helper for creating a `VecDupFPImm` instruction
4179
+ (decl vec_dup_fp_imm (ASIMDFPModImm VectorSize) Reg)
4180
+ (rule (vec_dup_fp_imm imm size)
4181
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
4182
+ (_ Unit (emit (MInst.VecDupFPImm dst imm size))))
4183
+ dst))
4184
+
4185
+ ;; Helper for creating a `FpuLoad64` instruction
4186
+ (decl fpu_load64 (AMode MemFlags) Reg)
4187
+ (rule (fpu_load64 amode flags)
4188
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
4189
+ (_ Unit (emit (MInst.FpuLoad64 dst amode flags))))
4190
+ dst))
4191
+
4192
+ ;; Helper for creating a `FpuLoad128` instruction
4193
+ (decl fpu_load128 (AMode MemFlags) Reg)
4194
+ (rule (fpu_load128 amode flags)
4195
+ (let ((dst WritableReg (temp_writable_reg $I8X16))
4196
+ (_ Unit (emit (MInst.FpuLoad128 dst amode flags))))
4197
+ dst))