@aztec/simulator 0.0.0-test.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (367) hide show
  1. package/README.md +49 -0
  2. package/dest/client.d.ts +5 -0
  3. package/dest/client.d.ts.map +1 -0
  4. package/dest/client.js +3 -0
  5. package/dest/common/db_interfaces.d.ts +80 -0
  6. package/dest/common/db_interfaces.d.ts.map +1 -0
  7. package/dest/common/db_interfaces.js +1 -0
  8. package/dest/common/debug_fn_name.d.ts +5 -0
  9. package/dest/common/debug_fn_name.d.ts.map +1 -0
  10. package/dest/common/debug_fn_name.js +6 -0
  11. package/dest/common/errors.d.ts +54 -0
  12. package/dest/common/errors.d.ts.map +1 -0
  13. package/dest/common/errors.js +135 -0
  14. package/dest/common/index.d.ts +4 -0
  15. package/dest/common/index.d.ts.map +1 -0
  16. package/dest/common/index.js +3 -0
  17. package/dest/common/message_load_oracle_inputs.d.ts +15 -0
  18. package/dest/common/message_load_oracle_inputs.d.ts.map +1 -0
  19. package/dest/common/message_load_oracle_inputs.js +15 -0
  20. package/dest/common/stats/index.d.ts +2 -0
  21. package/dest/common/stats/index.d.ts.map +1 -0
  22. package/dest/common/stats/index.js +1 -0
  23. package/dest/common/stats/stats.d.ts +4 -0
  24. package/dest/common/stats/stats.d.ts.map +1 -0
  25. package/dest/common/stats/stats.js +10 -0
  26. package/dest/private/acvm/acvm.d.ts +35 -0
  27. package/dest/private/acvm/acvm.d.ts.map +1 -0
  28. package/dest/private/acvm/acvm.js +70 -0
  29. package/dest/private/acvm/acvm_types.d.ts +10 -0
  30. package/dest/private/acvm/acvm_types.d.ts.map +1 -0
  31. package/dest/private/acvm/acvm_types.js +3 -0
  32. package/dest/private/acvm/deserialize.d.ts +36 -0
  33. package/dest/private/acvm/deserialize.d.ts.map +1 -0
  34. package/dest/private/acvm/deserialize.js +42 -0
  35. package/dest/private/acvm/index.d.ts +6 -0
  36. package/dest/private/acvm/index.d.ts.map +1 -0
  37. package/dest/private/acvm/index.js +5 -0
  38. package/dest/private/acvm/oracle/index.d.ts +14 -0
  39. package/dest/private/acvm/oracle/index.d.ts.map +1 -0
  40. package/dest/private/acvm/oracle/index.js +2 -0
  41. package/dest/private/acvm/oracle/oracle.d.ts +49 -0
  42. package/dest/private/acvm/oracle/oracle.d.ts.map +1 -0
  43. package/dest/private/acvm/oracle/oracle.js +263 -0
  44. package/dest/private/acvm/oracle/typed_oracle.d.ts +83 -0
  45. package/dest/private/acvm/oracle/typed_oracle.d.ts.map +1 -0
  46. package/dest/private/acvm/oracle/typed_oracle.js +132 -0
  47. package/dest/private/acvm/serialize.d.ts +24 -0
  48. package/dest/private/acvm/serialize.d.ts.map +1 -0
  49. package/dest/private/acvm/serialize.js +46 -0
  50. package/dest/private/execution_data_provider.d.ts +261 -0
  51. package/dest/private/execution_data_provider.d.ts.map +1 -0
  52. package/dest/private/execution_data_provider.js +14 -0
  53. package/dest/private/execution_note_cache.d.ts +93 -0
  54. package/dest/private/execution_note_cache.d.ts.map +1 -0
  55. package/dest/private/execution_note_cache.js +180 -0
  56. package/dest/private/hashed_values_cache.d.ts +28 -0
  57. package/dest/private/hashed_values_cache.d.ts.map +1 -0
  58. package/dest/private/hashed_values_cache.js +46 -0
  59. package/dest/private/index.d.ts +13 -0
  60. package/dest/private/index.d.ts.map +1 -0
  61. package/dest/private/index.js +12 -0
  62. package/dest/private/pick_notes.d.ts +85 -0
  63. package/dest/private/pick_notes.d.ts.map +1 -0
  64. package/dest/private/pick_notes.js +51 -0
  65. package/dest/private/private_execution.d.ts +25 -0
  66. package/dest/private/private_execution.d.ts.map +1 -0
  67. package/dest/private/private_execution.js +92 -0
  68. package/dest/private/private_execution_oracle.d.ts +215 -0
  69. package/dest/private/private_execution_oracle.d.ts.map +1 -0
  70. package/dest/private/private_execution_oracle.js +382 -0
  71. package/dest/private/providers/acvm_native.d.ts +40 -0
  72. package/dest/private/providers/acvm_native.d.ts.map +1 -0
  73. package/dest/private/providers/acvm_native.js +139 -0
  74. package/dest/private/providers/acvm_wasm.d.ts +15 -0
  75. package/dest/private/providers/acvm_wasm.d.ts.map +1 -0
  76. package/dest/private/providers/acvm_wasm.js +62 -0
  77. package/dest/private/providers/acvm_wasm_with_blobs.d.ts +19 -0
  78. package/dest/private/providers/acvm_wasm_with_blobs.d.ts.map +1 -0
  79. package/dest/private/providers/acvm_wasm_with_blobs.js +32 -0
  80. package/dest/private/providers/factory.d.ts +12 -0
  81. package/dest/private/providers/factory.d.ts.map +1 -0
  82. package/dest/private/providers/factory.js +27 -0
  83. package/dest/private/providers/simulation_provider.d.ts +19 -0
  84. package/dest/private/providers/simulation_provider.d.ts.map +1 -0
  85. package/dest/private/providers/simulation_provider.js +24 -0
  86. package/dest/private/simulator.d.ts +34 -0
  87. package/dest/private/simulator.d.ts.map +1 -0
  88. package/dest/private/simulator.js +76 -0
  89. package/dest/private/unconstrained_execution.d.ts +10 -0
  90. package/dest/private/unconstrained_execution.d.ts.map +1 -0
  91. package/dest/private/unconstrained_execution.js +27 -0
  92. package/dest/private/unconstrained_execution_oracle.d.ts +161 -0
  93. package/dest/private/unconstrained_execution_oracle.d.ts.map +1 -0
  94. package/dest/private/unconstrained_execution_oracle.js +258 -0
  95. package/dest/public/avm/avm_context.d.ts +41 -0
  96. package/dest/public/avm/avm_context.d.ts.map +1 -0
  97. package/dest/public/avm/avm_context.js +44 -0
  98. package/dest/public/avm/avm_contract_call_result.d.ts +30 -0
  99. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -0
  100. package/dest/public/avm/avm_contract_call_result.js +50 -0
  101. package/dest/public/avm/avm_execution_environment.d.ts +21 -0
  102. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -0
  103. package/dest/public/avm/avm_execution_environment.js +31 -0
  104. package/dest/public/avm/avm_gas.d.ts +60 -0
  105. package/dest/public/avm/avm_gas.d.ts.map +1 -0
  106. package/dest/public/avm/avm_gas.js +203 -0
  107. package/dest/public/avm/avm_machine_state.d.ts +95 -0
  108. package/dest/public/avm/avm_machine_state.d.ts.map +1 -0
  109. package/dest/public/avm/avm_machine_state.js +107 -0
  110. package/dest/public/avm/avm_memory_types.d.ts +264 -0
  111. package/dest/public/avm/avm_memory_types.d.ts.map +1 -0
  112. package/dest/public/avm/avm_memory_types.js +340 -0
  113. package/dest/public/avm/avm_simulator.d.ts +40 -0
  114. package/dest/public/avm/avm_simulator.d.ts.map +1 -0
  115. package/dest/public/avm/avm_simulator.js +202 -0
  116. package/dest/public/avm/bytecode_utils.d.ts +5 -0
  117. package/dest/public/avm/bytecode_utils.d.ts.map +1 -0
  118. package/dest/public/avm/bytecode_utils.js +17 -0
  119. package/dest/public/avm/errors.d.ts +122 -0
  120. package/dest/public/avm/errors.d.ts.map +1 -0
  121. package/dest/public/avm/errors.js +179 -0
  122. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +21 -0
  123. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -0
  124. package/dest/public/avm/fixtures/avm_simulation_tester.js +76 -0
  125. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +36 -0
  126. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -0
  127. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +83 -0
  128. package/dest/public/avm/fixtures/index.d.ts +84 -0
  129. package/dest/public/avm/fixtures/index.d.ts.map +1 -0
  130. package/dest/public/avm/fixtures/index.js +175 -0
  131. package/dest/public/avm/fixtures/simple_contract_data_source.d.ts +35 -0
  132. package/dest/public/avm/fixtures/simple_contract_data_source.d.ts.map +1 -0
  133. package/dest/public/avm/fixtures/simple_contract_data_source.js +74 -0
  134. package/dest/public/avm/index.d.ts +4 -0
  135. package/dest/public/avm/index.d.ts.map +1 -0
  136. package/dest/public/avm/index.js +3 -0
  137. package/dest/public/avm/journal/index.d.ts +2 -0
  138. package/dest/public/avm/journal/index.d.ts.map +1 -0
  139. package/dest/public/avm/journal/index.js +1 -0
  140. package/dest/public/avm/journal/journal.d.ts +209 -0
  141. package/dest/public/avm/journal/journal.d.ts.map +1 -0
  142. package/dest/public/avm/journal/journal.js +486 -0
  143. package/dest/public/avm/journal/nullifiers.d.ts +64 -0
  144. package/dest/public/avm/journal/nullifiers.d.ts.map +1 -0
  145. package/dest/public/avm/journal/nullifiers.js +97 -0
  146. package/dest/public/avm/journal/public_storage.d.ts +66 -0
  147. package/dest/public/avm/journal/public_storage.d.ts.map +1 -0
  148. package/dest/public/avm/journal/public_storage.js +145 -0
  149. package/dest/public/avm/opcodes/accrued_substate.d.ts +75 -0
  150. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -0
  151. package/dest/public/avm/opcodes/accrued_substate.js +252 -0
  152. package/dest/public/avm/opcodes/addressing_mode.d.ts +27 -0
  153. package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -0
  154. package/dest/public/avm/opcodes/addressing_mode.js +74 -0
  155. package/dest/public/avm/opcodes/arithmetic.d.ts +37 -0
  156. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -0
  157. package/dest/public/avm/opcodes/arithmetic.js +73 -0
  158. package/dest/public/avm/opcodes/bitwise.d.ts +50 -0
  159. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -0
  160. package/dest/public/avm/opcodes/bitwise.js +106 -0
  161. package/dest/public/avm/opcodes/comparators.d.ts +25 -0
  162. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -0
  163. package/dest/public/avm/opcodes/comparators.js +43 -0
  164. package/dest/public/avm/opcodes/contract.d.ts +21 -0
  165. package/dest/public/avm/opcodes/contract.d.ts.map +1 -0
  166. package/dest/public/avm/opcodes/contract.js +66 -0
  167. package/dest/public/avm/opcodes/control_flow.d.ts +41 -0
  168. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -0
  169. package/dest/public/avm/opcodes/control_flow.js +105 -0
  170. package/dest/public/avm/opcodes/conversion.d.ts +17 -0
  171. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -0
  172. package/dest/public/avm/opcodes/conversion.js +69 -0
  173. package/dest/public/avm/opcodes/ec_add.d.ts +19 -0
  174. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -0
  175. package/dest/public/avm/opcodes/ec_add.js +84 -0
  176. package/dest/public/avm/opcodes/environment_getters.d.ts +28 -0
  177. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -0
  178. package/dest/public/avm/opcodes/environment_getters.js +79 -0
  179. package/dest/public/avm/opcodes/external_calls.d.ts +58 -0
  180. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -0
  181. package/dest/public/avm/opcodes/external_calls.js +204 -0
  182. package/dest/public/avm/opcodes/hashing.d.ts +36 -0
  183. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -0
  184. package/dest/public/avm/opcodes/hashing.js +114 -0
  185. package/dest/public/avm/opcodes/index.d.ts +16 -0
  186. package/dest/public/avm/opcodes/index.d.ts.map +1 -0
  187. package/dest/public/avm/opcodes/index.js +15 -0
  188. package/dest/public/avm/opcodes/instruction.d.ts +70 -0
  189. package/dest/public/avm/opcodes/instruction.d.ts.map +1 -0
  190. package/dest/public/avm/opcodes/instruction.js +91 -0
  191. package/dest/public/avm/opcodes/instruction_impl.d.ts +19 -0
  192. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -0
  193. package/dest/public/avm/opcodes/instruction_impl.js +30 -0
  194. package/dest/public/avm/opcodes/memory.d.ts +74 -0
  195. package/dest/public/avm/opcodes/memory.d.ts.map +1 -0
  196. package/dest/public/avm/opcodes/memory.js +253 -0
  197. package/dest/public/avm/opcodes/misc.d.ts +17 -0
  198. package/dest/public/avm/opcodes/misc.d.ts.map +1 -0
  199. package/dest/public/avm/opcodes/misc.js +48 -0
  200. package/dest/public/avm/opcodes/storage.d.ts +24 -0
  201. package/dest/public/avm/opcodes/storage.d.ts.map +1 -0
  202. package/dest/public/avm/opcodes/storage.js +66 -0
  203. package/dest/public/avm/serialization/buffer_cursor.d.ts +28 -0
  204. package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -0
  205. package/dest/public/avm/serialization/buffer_cursor.js +99 -0
  206. package/dest/public/avm/serialization/bytecode_serialization.d.ts +21 -0
  207. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -0
  208. package/dest/public/avm/serialization/bytecode_serialization.js +332 -0
  209. package/dest/public/avm/serialization/instruction_serialization.d.ts +105 -0
  210. package/dest/public/avm/serialization/instruction_serialization.d.ts.map +1 -0
  211. package/dest/public/avm/serialization/instruction_serialization.js +226 -0
  212. package/dest/public/avm/test_utils.d.ts +18 -0
  213. package/dest/public/avm/test_utils.d.ts.map +1 -0
  214. package/dest/public/avm/test_utils.js +52 -0
  215. package/dest/public/bytecode_errors.d.ts +4 -0
  216. package/dest/public/bytecode_errors.d.ts.map +1 -0
  217. package/dest/public/bytecode_errors.js +6 -0
  218. package/dest/public/execution.d.ts +108 -0
  219. package/dest/public/execution.d.ts.map +1 -0
  220. package/dest/public/execution.js +9 -0
  221. package/dest/public/executor_metrics.d.ts +13 -0
  222. package/dest/public/executor_metrics.d.ts.map +1 -0
  223. package/dest/public/executor_metrics.js +54 -0
  224. package/dest/public/fixtures/index.d.ts +3 -0
  225. package/dest/public/fixtures/index.d.ts.map +1 -0
  226. package/dest/public/fixtures/index.js +2 -0
  227. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +32 -0
  228. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -0
  229. package/dest/public/fixtures/public_tx_simulation_tester.js +93 -0
  230. package/dest/public/fixtures/utils.d.ts +13 -0
  231. package/dest/public/fixtures/utils.d.ts.map +1 -0
  232. package/dest/public/fixtures/utils.js +126 -0
  233. package/dest/public/index.d.ts +10 -0
  234. package/dest/public/index.d.ts.map +1 -0
  235. package/dest/public/index.js +8 -0
  236. package/dest/public/public_db_sources.d.ts +129 -0
  237. package/dest/public/public_db_sources.d.ts.map +1 -0
  238. package/dest/public/public_db_sources.js +264 -0
  239. package/dest/public/public_processor/public_processor.d.ts +74 -0
  240. package/dest/public/public_processor/public_processor.d.ts.map +1 -0
  241. package/dest/public/public_processor/public_processor.js +379 -0
  242. package/dest/public/public_processor/public_processor_metrics.d.ts +27 -0
  243. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -0
  244. package/dest/public/public_processor/public_processor_metrics.js +125 -0
  245. package/dest/public/public_tx_simulator/public_tx_context.d.ts +137 -0
  246. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -0
  247. package/dest/public/public_tx_simulator/public_tx_context.js +320 -0
  248. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +102 -0
  249. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -0
  250. package/dest/public/public_tx_simulator/public_tx_simulator.js +334 -0
  251. package/dest/public/side_effect_errors.d.ts +4 -0
  252. package/dest/public/side_effect_errors.d.ts.map +1 -0
  253. package/dest/public/side_effect_errors.js +6 -0
  254. package/dest/public/side_effect_trace.d.ts +132 -0
  255. package/dest/public/side_effect_trace.d.ts.map +1 -0
  256. package/dest/public/side_effect_trace.js +249 -0
  257. package/dest/public/side_effect_trace_interface.d.ts +34 -0
  258. package/dest/public/side_effect_trace_interface.d.ts.map +1 -0
  259. package/dest/public/side_effect_trace_interface.js +1 -0
  260. package/dest/public/tx_contract_cache.d.ts +41 -0
  261. package/dest/public/tx_contract_cache.d.ts.map +1 -0
  262. package/dest/public/tx_contract_cache.js +49 -0
  263. package/dest/public/unique_class_ids.d.ts +37 -0
  264. package/dest/public/unique_class_ids.d.ts.map +1 -0
  265. package/dest/public/unique_class_ids.js +61 -0
  266. package/dest/public/utils.d.ts +5 -0
  267. package/dest/public/utils.d.ts.map +1 -0
  268. package/dest/public/utils.js +35 -0
  269. package/dest/server.d.ts +6 -0
  270. package/dest/server.d.ts.map +1 -0
  271. package/dest/server.js +4 -0
  272. package/dest/test/utils.d.ts +13 -0
  273. package/dest/test/utils.d.ts.map +1 -0
  274. package/dest/test/utils.js +22 -0
  275. package/package.json +104 -0
  276. package/src/client.ts +4 -0
  277. package/src/common/db_interfaces.ts +94 -0
  278. package/src/common/debug_fn_name.ts +18 -0
  279. package/src/common/errors.ts +183 -0
  280. package/src/common/index.ts +3 -0
  281. package/src/common/message_load_oracle_inputs.ts +15 -0
  282. package/src/common/stats/index.ts +1 -0
  283. package/src/common/stats/stats.ts +20 -0
  284. package/src/private/acvm/acvm.ts +127 -0
  285. package/src/private/acvm/acvm_types.ts +11 -0
  286. package/src/private/acvm/deserialize.ts +52 -0
  287. package/src/private/acvm/index.ts +5 -0
  288. package/src/private/acvm/oracle/index.ts +16 -0
  289. package/src/private/acvm/oracle/oracle.ts +455 -0
  290. package/src/private/acvm/oracle/typed_oracle.ts +259 -0
  291. package/src/private/acvm/serialize.ts +60 -0
  292. package/src/private/execution_data_provider.ts +323 -0
  293. package/src/private/execution_note_cache.ts +217 -0
  294. package/src/private/hashed_values_cache.ts +55 -0
  295. package/src/private/index.ts +16 -0
  296. package/src/private/pick_notes.ts +141 -0
  297. package/src/private/private_execution.ts +151 -0
  298. package/src/private/private_execution_oracle.ts +614 -0
  299. package/src/private/providers/acvm_native.ts +171 -0
  300. package/src/private/providers/acvm_wasm.ts +63 -0
  301. package/src/private/providers/acvm_wasm_with_blobs.ts +50 -0
  302. package/src/private/providers/factory.ts +38 -0
  303. package/src/private/providers/simulation_provider.ts +45 -0
  304. package/src/private/simulator.ts +147 -0
  305. package/src/private/unconstrained_execution.ts +50 -0
  306. package/src/private/unconstrained_execution_oracle.ts +373 -0
  307. package/src/public/avm/avm_context.ts +61 -0
  308. package/src/public/avm/avm_contract_call_result.ts +55 -0
  309. package/src/public/avm/avm_execution_environment.ts +39 -0
  310. package/src/public/avm/avm_gas.ts +195 -0
  311. package/src/public/avm/avm_machine_state.ts +164 -0
  312. package/src/public/avm/avm_memory_types.ts +423 -0
  313. package/src/public/avm/avm_simulator.ts +284 -0
  314. package/src/public/avm/bytecode_utils.ts +17 -0
  315. package/src/public/avm/errors.ts +232 -0
  316. package/src/public/avm/fixtures/avm_simulation_tester.ts +105 -0
  317. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +109 -0
  318. package/src/public/avm/fixtures/index.ts +296 -0
  319. package/src/public/avm/fixtures/simple_contract_data_source.ts +105 -0
  320. package/src/public/avm/index.ts +3 -0
  321. package/src/public/avm/journal/index.ts +1 -0
  322. package/src/public/avm/journal/journal.ts +742 -0
  323. package/src/public/avm/journal/nullifiers.ts +109 -0
  324. package/src/public/avm/journal/public_storage.ts +174 -0
  325. package/src/public/avm/opcodes/.eslintrc.cjs +8 -0
  326. package/src/public/avm/opcodes/accrued_substate.ts +253 -0
  327. package/src/public/avm/opcodes/addressing_mode.ts +87 -0
  328. package/src/public/avm/opcodes/arithmetic.ts +95 -0
  329. package/src/public/avm/opcodes/bitwise.ts +109 -0
  330. package/src/public/avm/opcodes/comparators.ts +52 -0
  331. package/src/public/avm/opcodes/contract.ts +72 -0
  332. package/src/public/avm/opcodes/control_flow.ts +114 -0
  333. package/src/public/avm/opcodes/conversion.ts +80 -0
  334. package/src/public/avm/opcodes/ec_add.ts +93 -0
  335. package/src/public/avm/opcodes/environment_getters.ts +82 -0
  336. package/src/public/avm/opcodes/external_calls.ts +228 -0
  337. package/src/public/avm/opcodes/hashing.ts +125 -0
  338. package/src/public/avm/opcodes/index.ts +15 -0
  339. package/src/public/avm/opcodes/instruction.ts +126 -0
  340. package/src/public/avm/opcodes/instruction_impl.ts +36 -0
  341. package/src/public/avm/opcodes/memory.ts +254 -0
  342. package/src/public/avm/opcodes/misc.ts +60 -0
  343. package/src/public/avm/opcodes/storage.ts +71 -0
  344. package/src/public/avm/serialization/buffer_cursor.ts +115 -0
  345. package/src/public/avm/serialization/bytecode_serialization.ts +206 -0
  346. package/src/public/avm/serialization/instruction_serialization.ts +208 -0
  347. package/src/public/avm/test_utils.ts +81 -0
  348. package/src/public/bytecode_errors.ts +6 -0
  349. package/src/public/execution.ts +140 -0
  350. package/src/public/executor_metrics.ts +71 -0
  351. package/src/public/fixtures/index.ts +2 -0
  352. package/src/public/fixtures/public_tx_simulation_tester.ts +179 -0
  353. package/src/public/fixtures/utils.ts +199 -0
  354. package/src/public/index.ts +9 -0
  355. package/src/public/public_db_sources.ts +369 -0
  356. package/src/public/public_processor/public_processor.ts +521 -0
  357. package/src/public/public_processor/public_processor_metrics.ts +154 -0
  358. package/src/public/public_tx_simulator/public_tx_context.ts +504 -0
  359. package/src/public/public_tx_simulator/public_tx_simulator.ts +474 -0
  360. package/src/public/side_effect_errors.ts +6 -0
  361. package/src/public/side_effect_trace.ts +516 -0
  362. package/src/public/side_effect_trace_interface.ts +76 -0
  363. package/src/public/tx_contract_cache.ts +69 -0
  364. package/src/public/unique_class_ids.ts +80 -0
  365. package/src/public/utils.ts +32 -0
  366. package/src/server.ts +5 -0
  367. package/src/test/utils.ts +36 -0
@@ -0,0 +1,66 @@
1
+ import { Fr } from '@aztec/foundation/fields';
2
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
3
+ import type { PublicStateDB } from '../../../common/db_interfaces.js';
4
+ type PublicStorageReadResult = {
5
+ value: Fr;
6
+ cached: boolean;
7
+ };
8
+ /**
9
+ * A class to manage public storage reads and writes during a contract call's AVM simulation.
10
+ * Maintains a storage write cache, and ensures that reads fall back to the correct source.
11
+ * When a contract call completes, its storage cache can be merged into its parent's.
12
+ */
13
+ export declare class PublicStorage {
14
+ /** Reference to node storage. Checked on parent cache-miss. */
15
+ private readonly hostPublicStorage;
16
+ /** Parent's storage. Checked on this' cache-miss. */
17
+ private readonly parent?;
18
+ /** Cached storage writes. */
19
+ private readonly cache;
20
+ constructor(
21
+ /** Reference to node storage. Checked on parent cache-miss. */
22
+ hostPublicStorage: PublicStateDB,
23
+ /** Parent's storage. Checked on this' cache-miss. */
24
+ parent?: PublicStorage | undefined);
25
+ /**
26
+ * Create a new public storage manager forked from this one
27
+ */
28
+ fork(): PublicStorage;
29
+ /**
30
+ * Read a storage value from this' cache or parent's (recursively).
31
+ * DOES NOT CHECK HOST STORAGE!
32
+ *
33
+ * @param contractAddress - the address of the contract whose storage is being read from
34
+ * @param slot - the slot in the contract's storage being read from
35
+ * @returns value: the latest value written according to this cache or the parent's. undefined on cache miss.
36
+ */
37
+ readHereOrParent(contractAddress: AztecAddress, slot: Fr): Fr | undefined;
38
+ /**
39
+ * Read a value from storage.
40
+ * 1. Check cache.
41
+ * 2. Check parent cache.
42
+ * 3. Fall back to the host state.
43
+ * 4. Not found! Value has never been written to before. Flag it as non-existent and return value zero.
44
+ *
45
+ * @param contractAddress - the address of the contract whose storage is being read from
46
+ * @param slot - the slot in the contract's storage being read from
47
+ * @returns exists: whether the slot has EVER been written to before, value: the latest value written to slot, or 0 if never written to before
48
+ */
49
+ read(contractAddress: AztecAddress, slot: Fr): Promise<PublicStorageReadResult>;
50
+ /**
51
+ * Stage a storage write.
52
+ *
53
+ * @param contractAddress - the address of the contract whose storage is being written to
54
+ * @param slot - the slot in the contract's storage being written to
55
+ * @param value - the value being written to the slot
56
+ */
57
+ write(contractAddress: AztecAddress, slot: Fr, value: Fr): void;
58
+ /**
59
+ * Merges another PublicStorage's cache (pending writes) into this one.
60
+ *
61
+ * @param incomingPublicStorage - the incoming public storage to merge into this instance's
62
+ */
63
+ acceptAndMerge(incomingPublicStorage: PublicStorage): void;
64
+ }
65
+ export {};
66
+ //# sourceMappingURL=public_storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"public_storage.d.ts","sourceRoot":"","sources":["../../../../src/public/avm/journal/public_storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAEhE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAEtE,KAAK,uBAAuB,GAAG;IAC7B,KAAK,EAAE,EAAE,CAAC;IACV,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF;;;;GAIG;AACH,qBAAa,aAAa;IAKtB,+DAA+D;IAC/D,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAClC,qDAAqD;IACrD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;IAP1B,6BAA6B;IAC7B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAqB;;IAGzC,+DAA+D;IAC9C,iBAAiB,EAAE,aAAa;IACjD,qDAAqD;IACpC,MAAM,CAAC,2BAAe;IAKzC;;OAEG;IACI,IAAI;IAIX;;;;;;;OAOG;IACI,gBAAgB,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,GAAG,SAAS;IAWhF;;;;;;;;;;OAUG;IACU,IAAI,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO,CAAC,uBAAuB,CAAC;IAmB5F;;;;;;OAMG;IACI,KAAK,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE;IAI/D;;;;OAIG;IACI,cAAc,CAAC,qBAAqB,EAAE,aAAa;CAG3D"}
@@ -0,0 +1,145 @@
1
+ import { Fr } from '@aztec/foundation/fields';
2
+ /**
3
+ * A class to manage public storage reads and writes during a contract call's AVM simulation.
4
+ * Maintains a storage write cache, and ensures that reads fall back to the correct source.
5
+ * When a contract call completes, its storage cache can be merged into its parent's.
6
+ */ export class PublicStorage {
7
+ hostPublicStorage;
8
+ parent;
9
+ /** Cached storage writes. */ cache;
10
+ constructor(/** Reference to node storage. Checked on parent cache-miss. */ hostPublicStorage, /** Parent's storage. Checked on this' cache-miss. */ parent){
11
+ this.hostPublicStorage = hostPublicStorage;
12
+ this.parent = parent;
13
+ this.cache = new PublicStorageCache();
14
+ }
15
+ /**
16
+ * Create a new public storage manager forked from this one
17
+ */ fork() {
18
+ return new PublicStorage(this.hostPublicStorage, this);
19
+ }
20
+ /**
21
+ * Read a storage value from this' cache or parent's (recursively).
22
+ * DOES NOT CHECK HOST STORAGE!
23
+ *
24
+ * @param contractAddress - the address of the contract whose storage is being read from
25
+ * @param slot - the slot in the contract's storage being read from
26
+ * @returns value: the latest value written according to this cache or the parent's. undefined on cache miss.
27
+ */ readHereOrParent(contractAddress, slot) {
28
+ // First try check this storage cache
29
+ let value = this.cache.read(contractAddress, slot);
30
+ // Then try parent's storage cache
31
+ if (!value && this.parent) {
32
+ // Note: this will recurse to grandparent/etc until a cache-hit is encountered.
33
+ value = this.parent.readHereOrParent(contractAddress, slot);
34
+ }
35
+ return value;
36
+ }
37
+ /**
38
+ * Read a value from storage.
39
+ * 1. Check cache.
40
+ * 2. Check parent cache.
41
+ * 3. Fall back to the host state.
42
+ * 4. Not found! Value has never been written to before. Flag it as non-existent and return value zero.
43
+ *
44
+ * @param contractAddress - the address of the contract whose storage is being read from
45
+ * @param slot - the slot in the contract's storage being read from
46
+ * @returns exists: whether the slot has EVER been written to before, value: the latest value written to slot, or 0 if never written to before
47
+ */ async read(contractAddress, slot) {
48
+ let cached = false;
49
+ // Check this cache and parent's (recursively)
50
+ let value = this.readHereOrParent(contractAddress, slot);
51
+ // Finally try the host's Aztec state (a trip to the database)
52
+ if (!value) {
53
+ // This functions returns Fr.ZERO if it has never been written to before
54
+ // we explicity coalesce to Fr.ZERO in case we have some implementations that cause this to return undefined
55
+ value = await this.hostPublicStorage.storageRead(contractAddress, slot) ?? Fr.ZERO;
56
+ // TODO(dbanks12): if value retrieved from host storage, we can cache it here
57
+ // any future reads to the same slot can read from cache instead of more expensive
58
+ // DB access
59
+ } else {
60
+ cached = true;
61
+ }
62
+ // if value is Fr.ZERO here, it that means this slot has never been written to!
63
+ return Promise.resolve({
64
+ value,
65
+ cached
66
+ });
67
+ }
68
+ /**
69
+ * Stage a storage write.
70
+ *
71
+ * @param contractAddress - the address of the contract whose storage is being written to
72
+ * @param slot - the slot in the contract's storage being written to
73
+ * @param value - the value being written to the slot
74
+ */ write(contractAddress, slot, value) {
75
+ this.cache.write(contractAddress, slot, value);
76
+ }
77
+ /**
78
+ * Merges another PublicStorage's cache (pending writes) into this one.
79
+ *
80
+ * @param incomingPublicStorage - the incoming public storage to merge into this instance's
81
+ */ acceptAndMerge(incomingPublicStorage) {
82
+ this.cache.acceptAndMerge(incomingPublicStorage.cache);
83
+ }
84
+ }
85
+ /**
86
+ * A class to cache writes to public storage during a contract call's AVM simulation.
87
+ * "Writes" update a map, "reads" check that map or return undefined.
88
+ * An instance of this class can merge another instance's staged writes into its own.
89
+ */ class PublicStorageCache {
90
+ /**
91
+ * Map for staging storage writes.
92
+ * One inner-map per contract storage address,
93
+ * mapping storage slot to latest staged write value.
94
+ */ cachePerContract = new Map();
95
+ /**
96
+ * Read a staged value from storage, if it has been previously written to.
97
+ *
98
+ * @param contractAddress - the address of the contract whose storage is being read from
99
+ * @param slot - the slot in the contract's storage being read from
100
+ * @returns the latest value written to slot, or undefined if no value has been written
101
+ */ read(contractAddress, slot) {
102
+ return this.cachePerContract.get(contractAddress.toBigInt())?.get(slot.toBigInt());
103
+ }
104
+ /**
105
+ * Stage a storage write.
106
+ *
107
+ * @param contractAddress - the address of the contract whose storage is being written to
108
+ * @param slot - the slot in the contract's storage being written to
109
+ * @param value - the value being written to the slot
110
+ */ write(contractAddress, slot, value) {
111
+ let cacheAtContract = this.cachePerContract.get(contractAddress.toBigInt());
112
+ if (!cacheAtContract) {
113
+ // If this contract's storage has no staged modifications, create a new inner map to store them
114
+ cacheAtContract = new Map();
115
+ this.cachePerContract.set(contractAddress.toBigInt(), cacheAtContract);
116
+ }
117
+ cacheAtContract.set(slot.toBigInt(), value);
118
+ }
119
+ /**
120
+ * Merges another cache's staged writes into this instance's cache.
121
+ *
122
+ * Staged modifications in "incoming" take precedence over those
123
+ * present in "this" as they are assumed to occur after this' writes.
124
+ *
125
+ * In practice, "this" is a parent call's storage cache, and "incoming" is a nested call's.
126
+ *
127
+ * @param incomingStorageCache - the incoming storage write cache to merge into this instance's
128
+ */ acceptAndMerge(incomingStorageCache) {
129
+ // Iterate over all incoming contracts with staged writes.
130
+ for (const [incomingAddress, incomingCacheAtContract] of incomingStorageCache.cachePerContract){
131
+ const thisCacheAtContract = this.cachePerContract.get(incomingAddress);
132
+ if (!thisCacheAtContract) {
133
+ // The contract has no storage writes staged here
134
+ // so just accept the incoming cache as-is for this contract.
135
+ this.cachePerContract.set(incomingAddress, incomingCacheAtContract);
136
+ } else {
137
+ // "Incoming" and "this" both have staged writes for this contract.
138
+ // Merge in incoming staged writes, giving them precedence over this'.
139
+ for (const [slot, value] of incomingCacheAtContract){
140
+ thisCacheAtContract.set(slot, value);
141
+ }
142
+ }
143
+ }
144
+ }
145
+ }
@@ -0,0 +1,75 @@
1
+ import type { AvmContext } from '../avm_context.js';
2
+ import { Opcode, OperandType } from '../serialization/instruction_serialization.js';
3
+ import { Instruction } from './instruction.js';
4
+ export declare class NoteHashExists extends Instruction {
5
+ private indirect;
6
+ private noteHashOffset;
7
+ private leafIndexOffset;
8
+ private existsOffset;
9
+ static type: string;
10
+ static readonly opcode: Opcode;
11
+ static readonly wireFormat: OperandType[];
12
+ constructor(indirect: number, noteHashOffset: number, leafIndexOffset: number, existsOffset: number);
13
+ execute(context: AvmContext): Promise<void>;
14
+ }
15
+ export declare class EmitNoteHash extends Instruction {
16
+ private indirect;
17
+ private noteHashOffset;
18
+ static type: string;
19
+ static readonly opcode: Opcode;
20
+ static readonly wireFormat: OperandType[];
21
+ constructor(indirect: number, noteHashOffset: number);
22
+ execute(context: AvmContext): Promise<void>;
23
+ }
24
+ export declare class NullifierExists extends Instruction {
25
+ private indirect;
26
+ private nullifierOffset;
27
+ private addressOffset;
28
+ private existsOffset;
29
+ static type: string;
30
+ static readonly opcode: Opcode;
31
+ static readonly wireFormat: OperandType[];
32
+ constructor(indirect: number, nullifierOffset: number, addressOffset: number, existsOffset: number);
33
+ execute(context: AvmContext): Promise<void>;
34
+ }
35
+ export declare class EmitNullifier extends Instruction {
36
+ private indirect;
37
+ private nullifierOffset;
38
+ static type: string;
39
+ static readonly opcode: Opcode;
40
+ static readonly wireFormat: OperandType[];
41
+ constructor(indirect: number, nullifierOffset: number);
42
+ execute(context: AvmContext): Promise<void>;
43
+ }
44
+ export declare class L1ToL2MessageExists extends Instruction {
45
+ private indirect;
46
+ private msgHashOffset;
47
+ private msgLeafIndexOffset;
48
+ private existsOffset;
49
+ static type: string;
50
+ static readonly opcode: Opcode;
51
+ static readonly wireFormat: OperandType[];
52
+ constructor(indirect: number, msgHashOffset: number, msgLeafIndexOffset: number, existsOffset: number);
53
+ execute(context: AvmContext): Promise<void>;
54
+ }
55
+ export declare class EmitUnencryptedLog extends Instruction {
56
+ private indirect;
57
+ private logOffset;
58
+ private logSizeOffset;
59
+ static type: string;
60
+ static readonly opcode: Opcode;
61
+ static readonly wireFormat: OperandType[];
62
+ constructor(indirect: number, logOffset: number, logSizeOffset: number);
63
+ execute(context: AvmContext): Promise<void>;
64
+ }
65
+ export declare class SendL2ToL1Message extends Instruction {
66
+ private indirect;
67
+ private recipientOffset;
68
+ private contentOffset;
69
+ static type: string;
70
+ static readonly opcode: Opcode;
71
+ static readonly wireFormat: OperandType[];
72
+ constructor(indirect: number, recipientOffset: number, contentOffset: number);
73
+ execute(context: AvmContext): Promise<void>;
74
+ }
75
+ //# sourceMappingURL=accrued_substate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"accrued_substate.d.ts","sourceRoot":"","sources":["../../../../src/public/avm/opcodes/accrued_substate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,252 @@
1
+ import { TypeTag, Uint1 } from '../avm_memory_types.js';
2
+ import { InstructionExecutionError, StaticCallAlterationError } from '../errors.js';
3
+ import { NullifierCollisionError } from '../journal/nullifiers.js';
4
+ import { Opcode, OperandType } from '../serialization/instruction_serialization.js';
5
+ import { Addressing } from './addressing_mode.js';
6
+ import { Instruction } from './instruction.js';
7
+ export class NoteHashExists extends Instruction {
8
+ indirect;
9
+ noteHashOffset;
10
+ leafIndexOffset;
11
+ existsOffset;
12
+ static type = 'NOTEHASHEXISTS';
13
+ static opcode = Opcode.NOTEHASHEXISTS;
14
+ // Informs (de)serialization. See Instruction.deserialize.
15
+ static wireFormat = [
16
+ OperandType.UINT8,
17
+ OperandType.UINT8,
18
+ OperandType.UINT16,
19
+ OperandType.UINT16,
20
+ OperandType.UINT16
21
+ ];
22
+ constructor(indirect, noteHashOffset, leafIndexOffset, existsOffset){
23
+ super(), this.indirect = indirect, this.noteHashOffset = noteHashOffset, this.leafIndexOffset = leafIndexOffset, this.existsOffset = existsOffset;
24
+ }
25
+ async execute(context) {
26
+ const memory = context.machineState.memory;
27
+ context.machineState.consumeGas(this.gasCost());
28
+ const operands = [
29
+ this.noteHashOffset,
30
+ this.leafIndexOffset,
31
+ this.existsOffset
32
+ ];
33
+ const addressing = Addressing.fromWire(this.indirect, operands.length);
34
+ const [noteHashOffset, leafIndexOffset, existsOffset] = addressing.resolve(operands, memory);
35
+ memory.checkTags(TypeTag.FIELD, noteHashOffset, leafIndexOffset);
36
+ // Note that this instruction accepts any type in memory, and converts to Field.
37
+ const noteHash = memory.get(noteHashOffset).toFr();
38
+ const leafIndex = memory.get(leafIndexOffset).toFr();
39
+ const exists = await context.persistableState.checkNoteHashExists(context.environment.address, noteHash, leafIndex);
40
+ memory.set(existsOffset, exists ? new Uint1(1) : new Uint1(0));
41
+ }
42
+ }
43
+ export class EmitNoteHash extends Instruction {
44
+ indirect;
45
+ noteHashOffset;
46
+ static type = 'EMITNOTEHASH';
47
+ static opcode = Opcode.EMITNOTEHASH;
48
+ // Informs (de)serialization. See Instruction.deserialize.
49
+ static wireFormat = [
50
+ OperandType.UINT8,
51
+ OperandType.UINT8,
52
+ OperandType.UINT16
53
+ ];
54
+ constructor(indirect, noteHashOffset){
55
+ super(), this.indirect = indirect, this.noteHashOffset = noteHashOffset;
56
+ }
57
+ async execute(context) {
58
+ const memory = context.machineState.memory;
59
+ context.machineState.consumeGas(this.gasCost());
60
+ const operands = [
61
+ this.noteHashOffset
62
+ ];
63
+ const addressing = Addressing.fromWire(this.indirect, operands.length);
64
+ const [noteHashOffset] = addressing.resolve(operands, memory);
65
+ memory.checkTag(TypeTag.FIELD, noteHashOffset);
66
+ if (context.environment.isStaticCall) {
67
+ throw new StaticCallAlterationError();
68
+ }
69
+ const noteHash = memory.get(noteHashOffset).toFr();
70
+ await context.persistableState.writeNoteHash(context.environment.address, noteHash);
71
+ }
72
+ }
73
+ export class NullifierExists extends Instruction {
74
+ indirect;
75
+ nullifierOffset;
76
+ addressOffset;
77
+ existsOffset;
78
+ static type = 'NULLIFIEREXISTS';
79
+ static opcode = Opcode.NULLIFIEREXISTS;
80
+ // Informs (de)serialization. See Instruction.deserialize.
81
+ static wireFormat = [
82
+ OperandType.UINT8,
83
+ OperandType.UINT8,
84
+ OperandType.UINT16,
85
+ OperandType.UINT16,
86
+ OperandType.UINT16
87
+ ];
88
+ constructor(indirect, nullifierOffset, addressOffset, existsOffset){
89
+ super(), this.indirect = indirect, this.nullifierOffset = nullifierOffset, this.addressOffset = addressOffset, this.existsOffset = existsOffset;
90
+ }
91
+ async execute(context) {
92
+ const memory = context.machineState.memory;
93
+ context.machineState.consumeGas(this.gasCost());
94
+ const operands = [
95
+ this.nullifierOffset,
96
+ this.addressOffset,
97
+ this.existsOffset
98
+ ];
99
+ const addressing = Addressing.fromWire(this.indirect, operands.length);
100
+ const [nullifierOffset, addressOffset, existsOffset] = addressing.resolve(operands, memory);
101
+ memory.checkTags(TypeTag.FIELD, nullifierOffset, addressOffset);
102
+ const nullifier = memory.get(nullifierOffset).toFr();
103
+ const address = memory.get(addressOffset).toAztecAddress();
104
+ const exists = await context.persistableState.checkNullifierExists(address, nullifier);
105
+ memory.set(existsOffset, exists ? new Uint1(1) : new Uint1(0));
106
+ }
107
+ }
108
+ export class EmitNullifier extends Instruction {
109
+ indirect;
110
+ nullifierOffset;
111
+ static type = 'EMITNULLIFIER';
112
+ static opcode = Opcode.EMITNULLIFIER;
113
+ // Informs (de)serialization. See Instruction.deserialize.
114
+ static wireFormat = [
115
+ OperandType.UINT8,
116
+ OperandType.UINT8,
117
+ OperandType.UINT16
118
+ ];
119
+ constructor(indirect, nullifierOffset){
120
+ super(), this.indirect = indirect, this.nullifierOffset = nullifierOffset;
121
+ }
122
+ async execute(context) {
123
+ if (context.environment.isStaticCall) {
124
+ throw new StaticCallAlterationError();
125
+ }
126
+ const memory = context.machineState.memory;
127
+ context.machineState.consumeGas(this.gasCost());
128
+ const operands = [
129
+ this.nullifierOffset
130
+ ];
131
+ const addressing = Addressing.fromWire(this.indirect, operands.length);
132
+ const [nullifierOffset] = addressing.resolve(operands, memory);
133
+ memory.checkTag(TypeTag.FIELD, nullifierOffset);
134
+ const nullifier = memory.get(nullifierOffset).toFr();
135
+ try {
136
+ await context.persistableState.writeNullifier(context.environment.address, nullifier);
137
+ } catch (e) {
138
+ if (e instanceof NullifierCollisionError) {
139
+ // Error is known/expected, raise as InstructionExecutionError that the will lead the simulator to revert this call
140
+ throw new InstructionExecutionError(`Attempted to emit duplicate nullifier ${nullifier} (contract address: ${context.environment.address}).`);
141
+ } else {
142
+ throw e;
143
+ }
144
+ }
145
+ }
146
+ }
147
+ export class L1ToL2MessageExists extends Instruction {
148
+ indirect;
149
+ msgHashOffset;
150
+ msgLeafIndexOffset;
151
+ existsOffset;
152
+ static type = 'L1TOL2MSGEXISTS';
153
+ static opcode = Opcode.L1TOL2MSGEXISTS;
154
+ // Informs (de)serialization. See Instruction.deserialize.
155
+ static wireFormat = [
156
+ OperandType.UINT8,
157
+ OperandType.UINT8,
158
+ OperandType.UINT16,
159
+ OperandType.UINT16,
160
+ OperandType.UINT16
161
+ ];
162
+ constructor(indirect, msgHashOffset, msgLeafIndexOffset, existsOffset){
163
+ super(), this.indirect = indirect, this.msgHashOffset = msgHashOffset, this.msgLeafIndexOffset = msgLeafIndexOffset, this.existsOffset = existsOffset;
164
+ }
165
+ async execute(context) {
166
+ const memory = context.machineState.memory;
167
+ context.machineState.consumeGas(this.gasCost());
168
+ const operands = [
169
+ this.msgHashOffset,
170
+ this.msgLeafIndexOffset,
171
+ this.existsOffset
172
+ ];
173
+ const addressing = Addressing.fromWire(this.indirect, operands.length);
174
+ const [msgHashOffset, msgLeafIndexOffset, existsOffset] = addressing.resolve(operands, memory);
175
+ memory.checkTags(TypeTag.FIELD, msgHashOffset, msgLeafIndexOffset);
176
+ const msgHash = memory.get(msgHashOffset).toFr();
177
+ const msgLeafIndex = memory.get(msgLeafIndexOffset).toFr();
178
+ const exists = await context.persistableState.checkL1ToL2MessageExists(context.environment.address, msgHash, msgLeafIndex);
179
+ memory.set(existsOffset, exists ? new Uint1(1) : new Uint1(0));
180
+ }
181
+ }
182
+ export class EmitUnencryptedLog extends Instruction {
183
+ indirect;
184
+ logOffset;
185
+ logSizeOffset;
186
+ // TODO(#11124): rename unencrypted -> public
187
+ static type = 'EMITUNENCRYPTEDLOG';
188
+ static opcode = Opcode.EMITUNENCRYPTEDLOG;
189
+ // Informs (de)serialization. See Instruction.deserialize.
190
+ static wireFormat = [
191
+ OperandType.UINT8,
192
+ OperandType.UINT8,
193
+ OperandType.UINT16,
194
+ OperandType.UINT16
195
+ ];
196
+ constructor(indirect, logOffset, logSizeOffset){
197
+ super(), this.indirect = indirect, this.logOffset = logOffset, this.logSizeOffset = logSizeOffset;
198
+ }
199
+ async execute(context) {
200
+ if (context.environment.isStaticCall) {
201
+ throw new StaticCallAlterationError();
202
+ }
203
+ const memory = context.machineState.memory;
204
+ const operands = [
205
+ this.logOffset,
206
+ this.logSizeOffset
207
+ ];
208
+ const addressing = Addressing.fromWire(this.indirect, operands.length);
209
+ const [logOffset, logSizeOffset] = addressing.resolve(operands, memory);
210
+ memory.checkTag(TypeTag.UINT32, logSizeOffset);
211
+ const logSize = memory.get(logSizeOffset).toNumber();
212
+ memory.checkTagsRange(TypeTag.FIELD, logOffset, logSize);
213
+ const contractAddress = context.environment.address;
214
+ context.machineState.consumeGas(this.gasCost(logSize));
215
+ const log = memory.getSlice(logOffset, logSize).map((f)=>f.toFr());
216
+ context.persistableState.writePublicLog(contractAddress, log);
217
+ }
218
+ }
219
+ export class SendL2ToL1Message extends Instruction {
220
+ indirect;
221
+ recipientOffset;
222
+ contentOffset;
223
+ static type = 'SENDL2TOL1MSG';
224
+ static opcode = Opcode.SENDL2TOL1MSG;
225
+ // Informs (de)serialization. See Instruction.deserialize.
226
+ static wireFormat = [
227
+ OperandType.UINT8,
228
+ OperandType.UINT8,
229
+ OperandType.UINT16,
230
+ OperandType.UINT16
231
+ ];
232
+ constructor(indirect, recipientOffset, contentOffset){
233
+ super(), this.indirect = indirect, this.recipientOffset = recipientOffset, this.contentOffset = contentOffset;
234
+ }
235
+ async execute(context) {
236
+ if (context.environment.isStaticCall) {
237
+ throw new StaticCallAlterationError();
238
+ }
239
+ const memory = context.machineState.memory;
240
+ context.machineState.consumeGas(this.gasCost());
241
+ const operands = [
242
+ this.recipientOffset,
243
+ this.contentOffset
244
+ ];
245
+ const addressing = Addressing.fromWire(this.indirect, operands.length);
246
+ const [recipientOffset, contentOffset] = addressing.resolve(operands, memory);
247
+ memory.checkTags(TypeTag.FIELD, recipientOffset, contentOffset);
248
+ const recipient = memory.get(recipientOffset).toFr();
249
+ const content = memory.get(contentOffset).toFr();
250
+ context.persistableState.writeL2ToL1Message(context.environment.address, recipient, content);
251
+ }
252
+ }
@@ -0,0 +1,27 @@
1
+ import { type TaggedMemoryInterface } from '../avm_memory_types.js';
2
+ export declare enum AddressingMode {
3
+ DIRECT = 0,
4
+ INDIRECT = 1,
5
+ RELATIVE = 2,
6
+ INDIRECT_RELATIVE = 3
7
+ }
8
+ /** A class to represent the addressing mode of an instruction. */
9
+ export declare class Addressing {
10
+ /** The addressing mode for each operand. The length of this array is the number of operands of the instruction. */
11
+ private readonly modePerOperand;
12
+ constructor(
13
+ /** The addressing mode for each operand. The length of this array is the number of operands of the instruction. */
14
+ modePerOperand: AddressingMode[]);
15
+ static fromWire(wireModes: number, numOperands?: number): Addressing;
16
+ toWire(): number;
17
+ /** Returns how many operands use the given addressing mode. */
18
+ count(mode: AddressingMode): number;
19
+ /**
20
+ * Resolves the offsets using the addressing mode.
21
+ * @param offsets The offsets to resolve.
22
+ * @param mem The memory to use for resolution.
23
+ * @returns The resolved offsets. The length of the returned array is the same as the length of the input array.
24
+ */
25
+ resolve(offsets: number[], mem: TaggedMemoryInterface): number[];
26
+ }
27
+ //# sourceMappingURL=addressing_mode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addressing_mode.d.ts","sourceRoot":"","sources":["../../../../src/public/avm/opcodes/addressing_mode.ts"],"names":[],"mappings":"AAEA,OAAO,EAAgB,KAAK,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAGlF,oBAAY,cAAc;IACxB,MAAM,IAAI;IACV,QAAQ,IAAI;IACZ,QAAQ,IAAI;IACZ,iBAAiB,IAAI;CACtB;AAED,kEAAkE;AAClE,qBAAa,UAAU;IAEnB,mHAAmH;IACnH,OAAO,CAAC,QAAQ,CAAC,cAAc;;IAD/B,mHAAmH;IAClG,cAAc,EAAE,cAAc,EAAE;WAIrC,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,WAAW,GAAE,MAAU,GAAG,UAAU;IAYvE,MAAM,IAAI,MAAM;IAevB,+DAA+D;IACxD,KAAK,CAAC,IAAI,EAAE,cAAc,GAAG,MAAM;IAI1C;;;;;OAKG;IACI,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,GAAG,EAAE,qBAAqB,GAAG,MAAM,EAAE;CA4BxE"}
@@ -0,0 +1,74 @@
1
+ import { strict as assert } from 'assert';
2
+ import { TaggedMemory } from '../avm_memory_types.js';
3
+ import { RelativeAddressOutOfRangeError } from '../errors.js';
4
+ export var AddressingMode = /*#__PURE__*/ function(AddressingMode) {
5
+ AddressingMode[AddressingMode["DIRECT"] = 0] = "DIRECT";
6
+ AddressingMode[AddressingMode["INDIRECT"] = 1] = "INDIRECT";
7
+ AddressingMode[AddressingMode["RELATIVE"] = 2] = "RELATIVE";
8
+ AddressingMode[AddressingMode["INDIRECT_RELATIVE"] = 3] = "INDIRECT_RELATIVE";
9
+ return AddressingMode;
10
+ }({});
11
+ /** A class to represent the addressing mode of an instruction. */ export class Addressing {
12
+ modePerOperand;
13
+ constructor(/** The addressing mode for each operand. The length of this array is the number of operands of the instruction. */ modePerOperand){
14
+ this.modePerOperand = modePerOperand;
15
+ }
16
+ // TODO(facundo): 8 for backwards compatibility.
17
+ static fromWire(wireModes, numOperands = 8) {
18
+ // The modes are stored in the wire format as a byte, with each bit representing the mode for an operand.
19
+ // The least significant bit represents the zeroth operand, and the most significant bit represents the last operand.
20
+ const modes = new Array(numOperands);
21
+ for(let i = 0; i < numOperands; i++){
22
+ modes[i] = (wireModes >> i & 1) * 1 | (wireModes >> i + numOperands & 1) * 2;
23
+ }
24
+ return new Addressing(modes);
25
+ }
26
+ toWire() {
27
+ // The modes are stored in the wire format as a byte, with each bit representing the mode for an operand.
28
+ // The least significant bit represents the zeroth operand, and the least significant bit represents the last operand.
29
+ let wire = 0;
30
+ for(let i = 0; i < this.modePerOperand.length; i++){
31
+ if (this.modePerOperand[i] & 1) {
32
+ wire |= 1 << i;
33
+ }
34
+ if (this.modePerOperand[i] & 2) {
35
+ wire |= 1 << this.modePerOperand.length + i;
36
+ }
37
+ }
38
+ return wire;
39
+ }
40
+ /** Returns how many operands use the given addressing mode. */ count(mode) {
41
+ return this.modePerOperand.filter((m)=>(m & mode) !== 0).length;
42
+ }
43
+ /**
44
+ * Resolves the offsets using the addressing mode.
45
+ * @param offsets The offsets to resolve.
46
+ * @param mem The memory to use for resolution.
47
+ * @returns The resolved offsets. The length of the returned array is the same as the length of the input array.
48
+ */ resolve(offsets, mem) {
49
+ assert(offsets.length <= this.modePerOperand.length);
50
+ const resolved = new Array(offsets.length);
51
+ let didRelativeOnce = false;
52
+ let baseAddr = 0;
53
+ for (const [i, offset] of offsets.entries()){
54
+ const mode = this.modePerOperand[i];
55
+ resolved[i] = offset;
56
+ if (mode & 2) {
57
+ if (!didRelativeOnce) {
58
+ mem.checkIsValidMemoryOffsetTag(0);
59
+ baseAddr = Number(mem.get(0).toBigInt());
60
+ didRelativeOnce = true;
61
+ }
62
+ resolved[i] += baseAddr;
63
+ if (resolved[i] >= TaggedMemory.MAX_MEMORY_SIZE) {
64
+ throw new RelativeAddressOutOfRangeError(baseAddr, offset);
65
+ }
66
+ }
67
+ if (mode & 1) {
68
+ mem.checkIsValidMemoryOffsetTag(resolved[i]);
69
+ resolved[i] = Number(mem.get(resolved[i]).toBigInt());
70
+ }
71
+ }
72
+ return resolved;
73
+ }
74
+ }