@aztec/simulator 0.0.1-commit.9b94fc1 → 0.0.1-commit.9d2bcf6d

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 (323) hide show
  1. package/README.md +2 -0
  2. package/dest/common/errors.d.ts +8 -2
  3. package/dest/common/errors.d.ts.map +1 -1
  4. package/dest/private/acvm/acvm.d.ts +4 -2
  5. package/dest/private/acvm/acvm.d.ts.map +1 -1
  6. package/dest/private/acvm/acvm.js +4 -3
  7. package/dest/private/acvm/deserialize.d.ts +2 -2
  8. package/dest/private/acvm/deserialize.d.ts.map +1 -1
  9. package/dest/private/acvm/deserialize.js +1 -1
  10. package/dest/private/acvm/serialize.d.ts +2 -2
  11. package/dest/private/acvm/serialize.d.ts.map +1 -1
  12. package/dest/private/acvm/serialize.js +1 -1
  13. package/dest/private/acvm_native.d.ts +5 -3
  14. package/dest/private/acvm_native.d.ts.map +1 -1
  15. package/dest/private/acvm_native.js +8 -6
  16. package/dest/private/acvm_wasm.d.ts +4 -3
  17. package/dest/private/acvm_wasm.d.ts.map +1 -1
  18. package/dest/private/acvm_wasm.js +4 -4
  19. package/dest/private/circuit_recording/circuit_recorder.d.ts +4 -3
  20. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
  21. package/dest/private/circuit_recording/circuit_recorder.js +21 -18
  22. package/dest/private/circuit_recording/file_circuit_recorder.d.ts +3 -2
  23. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -1
  24. package/dest/private/circuit_recording/file_circuit_recorder.js +2 -2
  25. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +7 -2
  26. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -1
  27. package/dest/private/circuit_recording/memory_circuit_recorder.js +4 -4
  28. package/dest/private/factory.d.ts +3 -3
  29. package/dest/private/factory.d.ts.map +1 -1
  30. package/dest/private/factory.js +7 -4
  31. package/dest/public/avm/avm_context.d.ts +3 -3
  32. package/dest/public/avm/avm_context.d.ts.map +1 -1
  33. package/dest/public/avm/avm_contract_call_result.d.ts +6 -6
  34. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  35. package/dest/public/avm/avm_contract_call_result.js +3 -3
  36. package/dest/public/avm/avm_execution_environment.d.ts +7 -6
  37. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  38. package/dest/public/avm/avm_execution_environment.js +1 -1
  39. package/dest/public/avm/avm_gas.d.ts +1 -1
  40. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  41. package/dest/public/avm/avm_machine_state.d.ts +7 -6
  42. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  43. package/dest/public/avm/avm_machine_state.js +3 -2
  44. package/dest/public/avm/avm_memory_types.d.ts +2 -2
  45. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  46. package/dest/public/avm/avm_memory_types.js +4 -1
  47. package/dest/public/avm/avm_simulator.d.ts +4 -3
  48. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  49. package/dest/public/avm/avm_simulator.js +11 -9
  50. package/dest/public/avm/calldata.d.ts +51 -0
  51. package/dest/public/avm/calldata.d.ts.map +1 -0
  52. package/dest/public/avm/calldata.js +63 -0
  53. package/dest/public/avm/errors.d.ts +8 -2
  54. package/dest/public/avm/errors.d.ts.map +1 -1
  55. package/dest/public/avm/errors.js +14 -2
  56. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
  57. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  58. package/dest/public/avm/fixtures/avm_simulation_tester.js +4 -3
  59. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +2 -2
  60. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
  61. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +1 -1
  62. package/dest/public/avm/fixtures/initializers.d.ts +2 -2
  63. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
  64. package/dest/public/avm/fixtures/initializers.js +5 -4
  65. package/dest/public/avm/fixtures/utils.d.ts +4 -3
  66. package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
  67. package/dest/public/avm/fixtures/utils.js +3 -2
  68. package/dest/public/avm/opcodes/accrued_substate.d.ts +16 -17
  69. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  70. package/dest/public/avm/opcodes/accrued_substate.js +39 -39
  71. package/dest/public/avm/opcodes/addressing_mode.js +2 -2
  72. package/dest/public/avm/opcodes/arithmetic.d.ts +10 -8
  73. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  74. package/dest/public/avm/opcodes/arithmetic.js +12 -2
  75. package/dest/public/avm/opcodes/bitwise.d.ts +7 -7
  76. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  77. package/dest/public/avm/opcodes/bitwise.js +5 -5
  78. package/dest/public/avm/opcodes/comparators.d.ts +4 -4
  79. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  80. package/dest/public/avm/opcodes/comparators.js +1 -1
  81. package/dest/public/avm/opcodes/contract.d.ts +3 -3
  82. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  83. package/dest/public/avm/opcodes/contract.js +8 -8
  84. package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
  85. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  86. package/dest/public/avm/opcodes/control_flow.js +4 -4
  87. package/dest/public/avm/opcodes/conversion.d.ts +3 -3
  88. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  89. package/dest/public/avm/opcodes/conversion.js +4 -4
  90. package/dest/public/avm/opcodes/ec_add.d.ts +4 -4
  91. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  92. package/dest/public/avm/opcodes/ec_add.js +17 -8
  93. package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
  94. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  95. package/dest/public/avm/opcodes/environment_getters.js +6 -6
  96. package/dest/public/avm/opcodes/external_calls.d.ts +9 -9
  97. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  98. package/dest/public/avm/opcodes/external_calls.js +23 -22
  99. package/dest/public/avm/opcodes/hashing.d.ts +8 -8
  100. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  101. package/dest/public/avm/opcodes/hashing.js +21 -16
  102. package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
  103. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  104. package/dest/public/avm/opcodes/instruction_impl.js +4 -4
  105. package/dest/public/avm/opcodes/memory.d.ts +14 -14
  106. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  107. package/dest/public/avm/opcodes/memory.js +26 -26
  108. package/dest/public/avm/opcodes/misc.d.ts +3 -3
  109. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  110. package/dest/public/avm/opcodes/misc.js +6 -6
  111. package/dest/public/avm/opcodes/storage.d.ts +16 -15
  112. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  113. package/dest/public/avm/opcodes/storage.js +34 -24
  114. package/dest/public/avm/revert_reason.d.ts +2 -2
  115. package/dest/public/avm/revert_reason.d.ts.map +1 -1
  116. package/dest/public/avm/revert_reason.js +3 -2
  117. package/dest/public/avm/serialization/bytecode_serialization.d.ts +1 -1
  118. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
  119. package/dest/public/avm/serialization/bytecode_serialization.js +9 -6
  120. package/dest/public/avm/serialization/instruction_serialization.js +1 -1
  121. package/dest/public/avm/test_utils.d.ts +2 -2
  122. package/dest/public/avm/test_utils.d.ts.map +1 -1
  123. package/dest/public/avm/test_utils.js +1 -1
  124. package/dest/public/contracts_db_checkpoint.d.ts +2 -2
  125. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -1
  126. package/dest/public/db_interfaces.d.ts +2 -2
  127. package/dest/public/db_interfaces.d.ts.map +1 -1
  128. package/dest/public/debug_fn_name.d.ts +16 -3
  129. package/dest/public/debug_fn_name.d.ts.map +1 -1
  130. package/dest/public/debug_fn_name.js +31 -3
  131. package/dest/public/executor_metrics.d.ts +1 -1
  132. package/dest/public/executor_metrics.d.ts.map +1 -1
  133. package/dest/public/executor_metrics.js +12 -33
  134. package/dest/public/fixtures/amm_test.js +2 -2
  135. package/dest/public/fixtures/bulk_test.d.ts +3 -3
  136. package/dest/public/fixtures/bulk_test.d.ts.map +1 -1
  137. package/dest/public/fixtures/bulk_test.js +5 -69
  138. package/dest/public/fixtures/custom_bytecode_tester.d.ts +28 -6
  139. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
  140. package/dest/public/fixtures/custom_bytecode_tester.js +36 -12
  141. package/dest/public/fixtures/custom_bytecode_tests.d.ts +11 -8
  142. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
  143. package/dest/public/fixtures/custom_bytecode_tests.js +83 -18
  144. package/dest/public/fixtures/index.d.ts +4 -2
  145. package/dest/public/fixtures/index.d.ts.map +1 -1
  146. package/dest/public/fixtures/index.js +3 -1
  147. package/dest/public/fixtures/minimal_public_tx.d.ts +2 -7
  148. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
  149. package/dest/public/fixtures/minimal_public_tx.js +4 -14
  150. package/dest/public/fixtures/opcode_spammer.d.ts +122 -0
  151. package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
  152. package/dest/public/fixtures/opcode_spammer.js +1653 -0
  153. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +22 -3
  154. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  155. package/dest/public/fixtures/public_tx_simulation_tester.js +50 -13
  156. package/dest/public/fixtures/simple_contract_data_source.d.ts +5 -4
  157. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
  158. package/dest/public/fixtures/simple_contract_data_source.js +4 -4
  159. package/dest/public/fixtures/token_test.d.ts +6 -2
  160. package/dest/public/fixtures/token_test.d.ts.map +1 -1
  161. package/dest/public/fixtures/token_test.js +13 -11
  162. package/dest/public/fixtures/utils.d.ts +2 -2
  163. package/dest/public/fixtures/utils.d.ts.map +1 -1
  164. package/dest/public/fixtures/utils.js +4 -3
  165. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
  166. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
  167. package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
  168. package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
  169. package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
  170. package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
  171. package/dest/public/hinting_db_sources.d.ts +5 -3
  172. package/dest/public/hinting_db_sources.d.ts.map +1 -1
  173. package/dest/public/hinting_db_sources.js +7 -2
  174. package/dest/public/index.d.ts +2 -2
  175. package/dest/public/index.d.ts.map +1 -1
  176. package/dest/public/index.js +1 -1
  177. package/dest/public/public_db_sources.d.ts +5 -4
  178. package/dest/public/public_db_sources.d.ts.map +1 -1
  179. package/dest/public/public_db_sources.js +5 -5
  180. package/dest/public/public_processor/guarded_merkle_tree.d.ts +4 -2
  181. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
  182. package/dest/public/public_processor/guarded_merkle_tree.js +5 -0
  183. package/dest/public/public_processor/public_processor.d.ts +9 -7
  184. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  185. package/dest/public/public_processor/public_processor.js +444 -47
  186. package/dest/public/public_processor/public_processor_metrics.d.ts +2 -2
  187. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  188. package/dest/public/public_processor/public_processor_metrics.js +28 -45
  189. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +3 -14
  190. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -1
  191. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +20 -55
  192. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +24 -37
  193. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
  194. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +67 -145
  195. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
  196. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
  197. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
  198. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
  199. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
  200. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +171 -0
  201. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +23 -0
  202. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
  203. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
  204. package/dest/public/public_tx_simulator/factories.d.ts +14 -0
  205. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
  206. package/dest/public/public_tx_simulator/factories.js +28 -0
  207. package/dest/public/public_tx_simulator/index.d.ts +4 -1
  208. package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
  209. package/dest/public/public_tx_simulator/index.js +3 -0
  210. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +3 -3
  211. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
  212. package/dest/public/public_tx_simulator/public_tx_context.d.ts +5 -4
  213. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  214. package/dest/public/public_tx_simulator/public_tx_context.js +9 -9
  215. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +8 -6
  216. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  217. package/dest/public/public_tx_simulator/public_tx_simulator.js +23 -12
  218. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +24 -1
  219. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
  220. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +2 -2
  221. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
  222. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +395 -19
  223. package/dest/public/side_effect_trace.d.ts +6 -5
  224. package/dest/public/side_effect_trace.d.ts.map +1 -1
  225. package/dest/public/side_effect_trace.js +4 -4
  226. package/dest/public/side_effect_trace_interface.d.ts +2 -2
  227. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  228. package/dest/public/state_manager/nullifiers.d.ts +2 -2
  229. package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
  230. package/dest/public/state_manager/public_storage.d.ts +2 -2
  231. package/dest/public/state_manager/public_storage.d.ts.map +1 -1
  232. package/dest/public/state_manager/public_storage.js +1 -1
  233. package/dest/public/state_manager/state_manager.d.ts +16 -5
  234. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  235. package/dest/public/state_manager/state_manager.js +19 -9
  236. package/dest/public/test_executor_metrics.d.ts +3 -2
  237. package/dest/public/test_executor_metrics.d.ts.map +1 -1
  238. package/dest/public/test_executor_metrics.js +2 -2
  239. package/package.json +20 -20
  240. package/src/common/errors.ts +1 -1
  241. package/src/private/acvm/acvm.ts +4 -3
  242. package/src/private/acvm/deserialize.ts +1 -1
  243. package/src/private/acvm/serialize.ts +1 -1
  244. package/src/private/acvm_native.ts +11 -5
  245. package/src/private/acvm_wasm.ts +7 -3
  246. package/src/private/circuit_recording/circuit_recorder.ts +22 -19
  247. package/src/private/circuit_recording/file_circuit_recorder.ts +7 -2
  248. package/src/private/circuit_recording/memory_circuit_recorder.ts +6 -4
  249. package/src/private/factory.ts +7 -4
  250. package/src/public/avm/avm_context.ts +2 -2
  251. package/src/public/avm/avm_contract_call_result.ts +8 -6
  252. package/src/public/avm/avm_execution_environment.ts +10 -5
  253. package/src/public/avm/avm_gas.ts +3 -3
  254. package/src/public/avm/avm_machine_state.ts +7 -6
  255. package/src/public/avm/avm_memory_types.ts +5 -1
  256. package/src/public/avm/avm_simulator.ts +16 -10
  257. package/src/public/avm/calldata.ts +100 -0
  258. package/src/public/avm/errors.ts +17 -3
  259. package/src/public/avm/fixtures/avm_simulation_tester.ts +9 -3
  260. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
  261. package/src/public/avm/fixtures/initializers.ts +5 -4
  262. package/src/public/avm/fixtures/utils.ts +3 -2
  263. package/src/public/avm/opcodes/accrued_substate.ts +28 -30
  264. package/src/public/avm/opcodes/addressing_mode.ts +2 -2
  265. package/src/public/avm/opcodes/arithmetic.ts +14 -2
  266. package/src/public/avm/opcodes/bitwise.ts +3 -3
  267. package/src/public/avm/opcodes/comparators.ts +1 -1
  268. package/src/public/avm/opcodes/contract.ts +4 -7
  269. package/src/public/avm/opcodes/control_flow.ts +2 -2
  270. package/src/public/avm/opcodes/conversion.ts +3 -3
  271. package/src/public/avm/opcodes/ec_add.ts +15 -6
  272. package/src/public/avm/opcodes/environment_getters.ts +7 -7
  273. package/src/public/avm/opcodes/external_calls.ts +17 -15
  274. package/src/public/avm/opcodes/hashing.ts +16 -10
  275. package/src/public/avm/opcodes/instruction_impl.ts +2 -2
  276. package/src/public/avm/opcodes/memory.ts +20 -20
  277. package/src/public/avm/opcodes/misc.ts +4 -4
  278. package/src/public/avm/opcodes/storage.ts +30 -22
  279. package/src/public/avm/revert_reason.ts +6 -3
  280. package/src/public/avm/serialization/bytecode_serialization.ts +17 -6
  281. package/src/public/avm/serialization/instruction_serialization.ts +1 -1
  282. package/src/public/avm/test_utils.ts +1 -1
  283. package/src/public/contracts_db_checkpoint.ts +1 -1
  284. package/src/public/db_interfaces.ts +1 -1
  285. package/src/public/debug_fn_name.ts +39 -5
  286. package/src/public/executor_metrics.ts +9 -33
  287. package/src/public/fixtures/amm_test.ts +2 -2
  288. package/src/public/fixtures/bulk_test.ts +9 -9
  289. package/src/public/fixtures/custom_bytecode_tester.ts +53 -19
  290. package/src/public/fixtures/custom_bytecode_tests.ts +111 -18
  291. package/src/public/fixtures/index.ts +7 -1
  292. package/src/public/fixtures/minimal_public_tx.ts +6 -15
  293. package/src/public/fixtures/opcode_spammer.ts +1721 -0
  294. package/src/public/fixtures/public_tx_simulation_tester.ts +69 -13
  295. package/src/public/fixtures/simple_contract_data_source.ts +8 -9
  296. package/src/public/fixtures/token_test.ts +18 -9
  297. package/src/public/fixtures/utils.ts +2 -3
  298. package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
  299. package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
  300. package/src/public/hinting_db_sources.ts +8 -3
  301. package/src/public/index.ts +7 -1
  302. package/src/public/public_db_sources.ts +16 -6
  303. package/src/public/public_processor/guarded_merkle_tree.ts +6 -1
  304. package/src/public/public_processor/public_processor.ts +63 -33
  305. package/src/public/public_processor/public_processor_metrics.ts +16 -44
  306. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +25 -63
  307. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +83 -178
  308. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +134 -0
  309. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +239 -0
  310. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +83 -0
  311. package/src/public/public_tx_simulator/factories.ts +43 -0
  312. package/src/public/public_tx_simulator/index.ts +3 -0
  313. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +1 -1
  314. package/src/public/public_tx_simulator/public_tx_context.ts +14 -7
  315. package/src/public/public_tx_simulator/public_tx_simulator.ts +42 -16
  316. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +23 -0
  317. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +1 -1
  318. package/src/public/side_effect_trace.ts +6 -3
  319. package/src/public/side_effect_trace_interface.ts +1 -1
  320. package/src/public/state_manager/nullifiers.ts +1 -1
  321. package/src/public/state_manager/public_storage.ts +1 -1
  322. package/src/public/state_manager/state_manager.ts +39 -23
  323. package/src/public/test_executor_metrics.ts +3 -3
@@ -1,3 +1,5 @@
1
+ import { MAX_ETH_ADDRESS_VALUE } from '@aztec/constants';
2
+
1
3
  import { NullifierCollisionError } from '../../side_effect_errors.js';
2
4
  import type { AvmContext } from '../avm_context.js';
3
5
  import { TypeTag, Uint1 } from '../avm_memory_types.js';
@@ -19,7 +21,7 @@ export class NoteHashExists extends Instruction {
19
21
  ];
20
22
 
21
23
  constructor(
22
- private indirect: number,
24
+ private addressingMode: number,
23
25
  private noteHashOffset: number,
24
26
  private leafIndexOffset: number,
25
27
  private existsOffset: number,
@@ -29,7 +31,7 @@ export class NoteHashExists extends Instruction {
29
31
 
30
32
  public async execute(context: AvmContext): Promise<void> {
31
33
  const memory = context.machineState.memory;
32
- const addressing = Addressing.fromWire(this.indirect);
34
+ const addressing = Addressing.fromWire(this.addressingMode);
33
35
 
34
36
  context.machineState.consumeGas(
35
37
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -55,7 +57,7 @@ export class EmitNoteHash extends Instruction {
55
57
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16];
56
58
 
57
59
  constructor(
58
- private indirect: number,
60
+ private addressingMode: number,
59
61
  private noteHashOffset: number,
60
62
  ) {
61
63
  super();
@@ -63,7 +65,7 @@ export class EmitNoteHash extends Instruction {
63
65
 
64
66
  public async execute(context: AvmContext): Promise<void> {
65
67
  const memory = context.machineState.memory;
66
- const addressing = Addressing.fromWire(this.indirect);
68
+ const addressing = Addressing.fromWire(this.addressingMode);
67
69
 
68
70
  context.machineState.consumeGas(
69
71
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -86,18 +88,11 @@ export class NullifierExists extends Instruction {
86
88
  static type: string = 'NULLIFIEREXISTS';
87
89
  static readonly opcode: Opcode = Opcode.NULLIFIEREXISTS;
88
90
  // Informs (de)serialization. See Instruction.deserialize.
89
- static readonly wireFormat = [
90
- OperandType.UINT8,
91
- OperandType.UINT8,
92
- OperandType.UINT16,
93
- OperandType.UINT16,
94
- OperandType.UINT16,
95
- ];
91
+ static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16, OperandType.UINT16];
96
92
 
97
93
  constructor(
98
- private indirect: number,
99
- private nullifierOffset: number,
100
- private addressOffset: number,
94
+ private addressingMode: number,
95
+ private siloedNullifierOffset: number,
101
96
  private existsOffset: number,
102
97
  ) {
103
98
  super();
@@ -105,19 +100,18 @@ export class NullifierExists extends Instruction {
105
100
 
106
101
  public async execute(context: AvmContext): Promise<void> {
107
102
  const memory = context.machineState.memory;
108
- const addressing = Addressing.fromWire(this.indirect);
103
+ const addressing = Addressing.fromWire(this.addressingMode);
109
104
 
110
105
  context.machineState.consumeGas(
111
106
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
112
107
  );
113
108
 
114
- const operands = [this.nullifierOffset, this.addressOffset, this.existsOffset];
115
- const [nullifierOffset, addressOffset, existsOffset] = addressing.resolve(operands, memory);
116
- memory.checkTags(TypeTag.FIELD, nullifierOffset, addressOffset);
109
+ const operands = [this.siloedNullifierOffset, this.existsOffset];
110
+ const [siloedNullifierOffset, existsOffset] = addressing.resolve(operands, memory);
111
+ memory.checkTag(TypeTag.FIELD, siloedNullifierOffset);
117
112
 
118
- const nullifier = memory.get(nullifierOffset).toFr();
119
- const address = memory.get(addressOffset).toAztecAddress();
120
- const exists = await context.persistableState.checkNullifierExists(address, nullifier);
113
+ const siloedNullifier = memory.get(siloedNullifierOffset).toFr();
114
+ const exists = await context.persistableState.checkSiloedNullifierExists(siloedNullifier);
121
115
 
122
116
  memory.set(existsOffset, exists ? new Uint1(1) : new Uint1(0));
123
117
  }
@@ -130,7 +124,7 @@ export class EmitNullifier extends Instruction {
130
124
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16];
131
125
 
132
126
  constructor(
133
- private indirect: number,
127
+ private addressingMode: number,
134
128
  private nullifierOffset: number,
135
129
  ) {
136
130
  super();
@@ -142,7 +136,7 @@ export class EmitNullifier extends Instruction {
142
136
  }
143
137
 
144
138
  const memory = context.machineState.memory;
145
- const addressing = Addressing.fromWire(this.indirect);
139
+ const addressing = Addressing.fromWire(this.addressingMode);
146
140
 
147
141
  context.machineState.consumeGas(
148
142
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -181,7 +175,7 @@ export class L1ToL2MessageExists extends Instruction {
181
175
  ];
182
176
 
183
177
  constructor(
184
- private indirect: number,
178
+ private addressingMode: number,
185
179
  private msgHashOffset: number,
186
180
  private msgLeafIndexOffset: number,
187
181
  private existsOffset: number,
@@ -191,7 +185,7 @@ export class L1ToL2MessageExists extends Instruction {
191
185
 
192
186
  public async execute(context: AvmContext): Promise<void> {
193
187
  const memory = context.machineState.memory;
194
- const addressing = Addressing.fromWire(this.indirect);
188
+ const addressing = Addressing.fromWire(this.addressingMode);
195
189
 
196
190
  context.machineState.consumeGas(
197
191
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -218,7 +212,7 @@ export class EmitUnencryptedLog extends Instruction {
218
212
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16, OperandType.UINT16];
219
213
 
220
214
  constructor(
221
- private indirect: number,
215
+ private addressingMode: number,
222
216
  private logSizeOffset: number,
223
217
  private logOffset: number,
224
218
  ) {
@@ -231,7 +225,7 @@ export class EmitUnencryptedLog extends Instruction {
231
225
  }
232
226
 
233
227
  const memory = context.machineState.memory;
234
- const addressing = Addressing.fromWire(this.indirect);
228
+ const addressing = Addressing.fromWire(this.addressingMode);
235
229
 
236
230
  context.machineState.consumeGas(
237
231
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -241,11 +235,11 @@ export class EmitUnencryptedLog extends Instruction {
241
235
  const [logSizeOffset, logOffset] = addressing.resolve(operands, memory);
242
236
  memory.checkTag(TypeTag.UINT32, logSizeOffset);
243
237
  const logSize = memory.get(logSizeOffset).toNumber();
244
- memory.checkTagsRange(TypeTag.FIELD, logOffset, logSize);
245
238
 
246
239
  const contractAddress = context.environment.address;
247
240
 
248
241
  context.machineState.consumeGas(this.dynamicGasCost(logSize));
242
+ memory.checkTagsRange(TypeTag.FIELD, logOffset, logSize);
249
243
  const log = memory.getSlice(logOffset, logSize).map(f => f.toFr());
250
244
  context.persistableState.writePublicLog(contractAddress, log);
251
245
  }
@@ -258,7 +252,7 @@ export class SendL2ToL1Message extends Instruction {
258
252
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16, OperandType.UINT16];
259
253
 
260
254
  constructor(
261
- private indirect: number,
255
+ private addressingMode: number,
262
256
  private recipientOffset: number,
263
257
  private contentOffset: number,
264
258
  ) {
@@ -271,7 +265,7 @@ export class SendL2ToL1Message extends Instruction {
271
265
  }
272
266
 
273
267
  const memory = context.machineState.memory;
274
- const addressing = Addressing.fromWire(this.indirect);
268
+ const addressing = Addressing.fromWire(this.addressingMode);
275
269
 
276
270
  context.machineState.consumeGas(
277
271
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -282,6 +276,10 @@ export class SendL2ToL1Message extends Instruction {
282
276
  memory.checkTags(TypeTag.FIELD, recipientOffset, contentOffset);
283
277
 
284
278
  const recipient = memory.get(recipientOffset).toFr();
279
+
280
+ if (recipient.toBigInt() > MAX_ETH_ADDRESS_VALUE) {
281
+ throw new InstructionExecutionError(`SENDL2TOL1MSG: Recipient address is too large`);
282
+ }
285
283
  const content = memory.get(contentOffset).toFr();
286
284
  context.persistableState.writeL2ToL1Message(context.environment.address, recipient, content);
287
285
  }
@@ -83,7 +83,7 @@ export class Addressing {
83
83
  baseAddr = mem.get(0);
84
84
  const baseAddrTag = baseAddr.getTag();
85
85
  if (!TaggedMemory.isValidMemoryAddressTag(baseAddrTag!)) {
86
- throw TagCheckError.forOffset(0, TypeTag[baseAddrTag!], TypeTag[TypeTag.UINT32]);
86
+ throw TagCheckError.forBaseAddress(TypeTag[baseAddrTag!]);
87
87
  }
88
88
  }
89
89
  // Here we know that resolved[i] is at most 32 bits and baseAddr is at most 32 bits.
@@ -100,7 +100,7 @@ export class Addressing {
100
100
 
101
101
  // Final check.
102
102
  if (!TaggedMemory.isValidMemoryAddressTag(resolvedTag)) {
103
- throw TagCheckError.forOffset(resolved[i], TypeTag[resolvedTag], TypeTag[TypeTag.UINT32]);
103
+ throw TagCheckError.forIndirectAddress(resolved[i], TypeTag[resolvedTag]);
104
104
  }
105
105
 
106
106
  resolved[i] = Number(resolvedValue.toBigInt());
@@ -15,7 +15,7 @@ import { ThreeOperandInstruction } from './instruction_impl.js';
15
15
  export abstract class ThreeOperandArithmeticInstruction extends ThreeOperandInstruction {
16
16
  public async execute(context: AvmContext): Promise<void> {
17
17
  const memory = context.machineState.memory;
18
- const addressing = Addressing.fromWire(this.indirect);
18
+ const addressing = Addressing.fromWire(this.addressingMode);
19
19
 
20
20
  context.machineState.consumeGas(
21
21
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -88,7 +88,9 @@ export class FieldDiv extends ThreeOperandArithmeticInstruction {
88
88
  static readonly opcode = Opcode.FDIV_8; // FIXME: needed for gas.
89
89
 
90
90
  protected compute(a: Field, b: Field): Field {
91
- // return (a as Field).fdiv(b as Field);
91
+ if (b.toBigInt() === 0n) {
92
+ throw new ArithmeticError('Division by zero');
93
+ }
92
94
  return a.fdiv(b);
93
95
  }
94
96
 
@@ -105,6 +107,11 @@ export class Shl extends ThreeOperandArithmeticInstruction {
105
107
  protected override compute(a: IntegralValue, b: IntegralValue): IntegralValue {
106
108
  return a.shl(b);
107
109
  }
110
+
111
+ protected override checkTags(memory: TaggedMemoryInterface, aOffset: number, bOffset: number) {
112
+ memory.checkTagsAreSame(aOffset, bOffset);
113
+ TaggedMemory.checkIsIntegralTag(memory.getTag(aOffset)); // Follows that bOffset tag is also of integral type
114
+ }
108
115
  }
109
116
 
110
117
  export class Shr extends ThreeOperandArithmeticInstruction {
@@ -114,4 +121,9 @@ export class Shr extends ThreeOperandArithmeticInstruction {
114
121
  protected override compute(a: IntegralValue, b: IntegralValue): IntegralValue {
115
122
  return a.shr(b);
116
123
  }
124
+
125
+ protected override checkTags(memory: TaggedMemoryInterface, aOffset: number, bOffset: number) {
126
+ memory.checkTagsAreSame(aOffset, bOffset);
127
+ TaggedMemory.checkIsIntegralTag(memory.getTag(aOffset)); // Follows that bOffset tag is also of integral type
128
+ }
117
129
  }
@@ -9,7 +9,7 @@ import { ThreeOperandInstruction } from './instruction_impl.js';
9
9
  abstract class ThreeOperandBitwiseInstruction extends ThreeOperandInstruction {
10
10
  public async execute(context: AvmContext): Promise<void> {
11
11
  const memory = context.machineState.memory;
12
- const addressing = Addressing.fromWire(this.indirect);
12
+ const addressing = Addressing.fromWire(this.addressingMode);
13
13
 
14
14
  context.machineState.consumeGas(
15
15
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -87,7 +87,7 @@ export class Not extends Instruction {
87
87
  static readonly wireFormat16 = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16, OperandType.UINT16];
88
88
 
89
89
  constructor(
90
- private indirect: number,
90
+ private addressingMode: number,
91
91
  private srcOffset: number,
92
92
  private dstOffset: number,
93
93
  ) {
@@ -96,7 +96,7 @@ export class Not extends Instruction {
96
96
 
97
97
  public async execute(context: AvmContext): Promise<void> {
98
98
  const memory = context.machineState.memory;
99
- const addressing = Addressing.fromWire(this.indirect);
99
+ const addressing = Addressing.fromWire(this.addressingMode);
100
100
 
101
101
  context.machineState.consumeGas(
102
102
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -7,7 +7,7 @@ import { ThreeOperandInstruction } from './instruction_impl.js';
7
7
  abstract class ComparatorInstruction extends ThreeOperandInstruction {
8
8
  public async execute(context: AvmContext): Promise<void> {
9
9
  const memory = context.machineState.memory;
10
- const addressing = Addressing.fromWire(this.indirect);
10
+ const addressing = Addressing.fromWire(this.addressingMode);
11
11
 
12
12
  context.machineState.consumeGas(
13
13
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -17,14 +17,14 @@ export class GetContractInstance extends Instruction {
17
17
  // Informs (de)serialization. See Instruction.deserialize.
18
18
  static readonly wireFormat: OperandType[] = [
19
19
  OperandType.UINT8, // opcode
20
- OperandType.UINT8, // indirect bits
20
+ OperandType.UINT8, // addressing_mode bits
21
21
  OperandType.UINT16, // addressOffset
22
22
  OperandType.UINT16, // dstOffset
23
23
  OperandType.UINT8, // member enum (immediate)
24
24
  ];
25
25
 
26
26
  constructor(
27
- private indirect: number,
27
+ private addressingMode: number,
28
28
  private addressOffset: number,
29
29
  private dstOffset: number,
30
30
  private memberEnum: number,
@@ -34,7 +34,7 @@ export class GetContractInstance extends Instruction {
34
34
 
35
35
  async execute(context: AvmContext): Promise<void> {
36
36
  const memory = context.machineState.memory;
37
- const addressing = Addressing.fromWire(this.indirect);
37
+ const addressing = Addressing.fromWire(this.addressingMode);
38
38
 
39
39
  context.machineState.consumeGas(
40
40
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -67,9 +67,6 @@ export class GetContractInstance extends Instruction {
67
67
  }
68
68
  }
69
69
 
70
- const existsOffset = dstOffset;
71
- const memberValueOffset = dstOffset + 1;
72
- memory.set(existsOffset, new Uint1(exists ? 1 : 0));
73
- memory.set(memberValueOffset, memberValue);
70
+ memory.setSlice(dstOffset, [new Uint1(exists ? 1 : 0), memberValue]);
74
71
  }
75
72
  }
@@ -39,7 +39,7 @@ export class JumpI extends Instruction {
39
39
  ];
40
40
 
41
41
  constructor(
42
- private indirect: number,
42
+ private addressingMode: number,
43
43
  private condOffset: number,
44
44
  private loc: number,
45
45
  ) {
@@ -48,7 +48,7 @@ export class JumpI extends Instruction {
48
48
 
49
49
  public async execute(context: AvmContext): Promise<void> {
50
50
  const memory = context.machineState.memory;
51
- const addressing = Addressing.fromWire(this.indirect);
51
+ const addressing = Addressing.fromWire(this.addressingMode);
52
52
 
53
53
  context.machineState.consumeGas(
54
54
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -12,7 +12,7 @@ export class ToRadixBE extends Instruction {
12
12
  // Informs (de)serialization. See Instruction.deserialize.
13
13
  static readonly wireFormat: OperandType[] = [
14
14
  OperandType.UINT8, // Opcode
15
- OperandType.UINT16, // Indirect
15
+ OperandType.UINT16, // addressing_mode
16
16
  OperandType.UINT16, // src memory address
17
17
  OperandType.UINT16, // radix memory address
18
18
  OperandType.UINT16, // number of limbs address
@@ -21,7 +21,7 @@ export class ToRadixBE extends Instruction {
21
21
  ];
22
22
 
23
23
  constructor(
24
- private indirect: number,
24
+ private addressingMode: number,
25
25
  private srcOffset: number,
26
26
  private radixOffset: number,
27
27
  private numLimbsOffset: number,
@@ -33,7 +33,7 @@ export class ToRadixBE extends Instruction {
33
33
 
34
34
  public async execute(context: AvmContext): Promise<void> {
35
35
  const memory = context.machineState.memory;
36
- const addressing = Addressing.fromWire(this.indirect);
36
+ const addressing = Addressing.fromWire(this.addressingMode);
37
37
 
38
38
  context.machineState.consumeGas(
39
39
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -1,5 +1,5 @@
1
- import { Grumpkin } from '@aztec/foundation/crypto';
2
- import { Point } from '@aztec/foundation/fields';
1
+ import { Grumpkin } from '@aztec/foundation/crypto/grumpkin';
2
+ import { Point } from '@aztec/foundation/curves/grumpkin';
3
3
 
4
4
  import type { AvmContext } from '../avm_context.js';
5
5
  import { Field, TypeTag, Uint1 } from '../avm_memory_types.js';
@@ -26,7 +26,7 @@ export class EcAdd extends Instruction {
26
26
  ];
27
27
 
28
28
  constructor(
29
- private indirect: number,
29
+ private addressingMode: number,
30
30
  private p1XOffset: number,
31
31
  private p1YOffset: number,
32
32
  private p1IsInfiniteOffset: number,
@@ -40,7 +40,7 @@ export class EcAdd extends Instruction {
40
40
 
41
41
  public async execute(context: AvmContext): Promise<void> {
42
42
  const memory = context.machineState.memory;
43
- const addressing = Addressing.fromWire(this.indirect);
43
+ const addressing = Addressing.fromWire(this.addressingMode);
44
44
 
45
45
  context.machineState.consumeGas(
46
46
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -79,12 +79,21 @@ export class EcAdd extends Instruction {
79
79
  }
80
80
 
81
81
  let dest;
82
- if (p1IsInfinite) {
82
+ if (p1IsInfinite && p2IsInfinite) {
83
+ dest = Point.ZERO;
84
+ } else if (p1IsInfinite) {
83
85
  dest = p2;
84
86
  } else if (p2IsInfinite) {
85
87
  dest = p1;
86
88
  } else {
87
- dest = await Grumpkin.add(p1, p2);
89
+ // TS<>BB ecc add communication is broken for points that add up to infinity.
90
+ // However, here we know that both points are on the curve, and that none is infinity
91
+ // so we can check for the case where you add p + (-p) = infinity.
92
+ if (p1.x.equals(p2.x) && !p1.y.equals(p2.y)) {
93
+ dest = Point.ZERO;
94
+ } else {
95
+ dest = await Grumpkin.add(p1, p2);
96
+ }
88
97
  }
89
98
 
90
99
  // Important to use setSlice() and not set() in the two following statements as
@@ -13,8 +13,8 @@ export enum EnvironmentVariable {
13
13
  VERSION,
14
14
  BLOCKNUMBER,
15
15
  TIMESTAMP,
16
- BASEFEEPERL2GAS,
17
- BASEFEEPERDAGAS,
16
+ MINFEEPERL2GAS,
17
+ MINFEEPERDAGAS,
18
18
  ISSTATICCALL,
19
19
  L2GASLEFT,
20
20
  DAGASLEFT,
@@ -36,9 +36,9 @@ function getValue(varEnum: EnvironmentVariable, ctx: AvmContext) {
36
36
  return new Uint32(ctx.environment.globals.blockNumber);
37
37
  case EnvironmentVariable.TIMESTAMP:
38
38
  return new Uint64(ctx.environment.globals.timestamp);
39
- case EnvironmentVariable.BASEFEEPERL2GAS:
39
+ case EnvironmentVariable.MINFEEPERL2GAS:
40
40
  return new Uint128(ctx.environment.globals.gasFees.feePerL2Gas);
41
- case EnvironmentVariable.BASEFEEPERDAGAS:
41
+ case EnvironmentVariable.MINFEEPERDAGAS:
42
42
  return new Uint128(ctx.environment.globals.gasFees.feePerDaGas);
43
43
  case EnvironmentVariable.ISSTATICCALL:
44
44
  return new Uint1(ctx.environment.isStaticCall ? 1 : 0);
@@ -56,13 +56,13 @@ export class GetEnvVar extends Instruction {
56
56
  public static readonly opcode: Opcode = Opcode.GETENVVAR_16;
57
57
  static readonly wireFormat16: OperandType[] = [
58
58
  OperandType.UINT8, // opcode
59
- OperandType.UINT8, // indirect
59
+ OperandType.UINT8, // addressing_mode
60
60
  OperandType.UINT16, // dstOffset
61
61
  OperandType.UINT8, // variable enum (immediate)
62
62
  ];
63
63
 
64
64
  constructor(
65
- private indirect: number,
65
+ private addressingMode: number,
66
66
  private dstOffset: number,
67
67
  private varEnum: number,
68
68
  ) {
@@ -71,7 +71,7 @@ export class GetEnvVar extends Instruction {
71
71
 
72
72
  public async execute(context: AvmContext): Promise<void> {
73
73
  const memory = context.machineState.memory;
74
- const addressing = Addressing.fromWire(this.indirect);
74
+ const addressing = Addressing.fromWire(this.addressingMode);
75
75
 
76
76
  context.machineState.consumeGas(
77
77
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -1,6 +1,7 @@
1
1
  import type { AvmContext } from '../avm_context.js';
2
2
  import type { AvmContractCallResult } from '../avm_contract_call_result.js';
3
3
  import { type Field, TypeTag, Uint1 } from '../avm_memory_types.js';
4
+ import { CallDataMemory, ReturnDataMemory } from '../calldata.js';
4
5
  import { Opcode, OperandType } from '../serialization/instruction_serialization.js';
5
6
  import { Addressing } from './addressing_mode.js';
6
7
  import { Instruction } from './instruction.js';
@@ -9,7 +10,7 @@ abstract class ExternalCall extends Instruction {
9
10
  // Informs (de)serialization. See Instruction.deserialize.
10
11
  static readonly wireFormat: OperandType[] = [
11
12
  OperandType.UINT8,
12
- OperandType.UINT16, // Indirect
13
+ OperandType.UINT16, // addressing_mode
13
14
  OperandType.UINT16, // L2 gas offset
14
15
  OperandType.UINT16, // DA gas offset
15
16
  OperandType.UINT16, // Address offset
@@ -18,7 +19,7 @@ abstract class ExternalCall extends Instruction {
18
19
  ];
19
20
 
20
21
  constructor(
21
- private indirect: number,
22
+ private addressingMode: number,
22
23
  private l2GasOffset: number,
23
24
  private daGasOffset: number,
24
25
  private addrOffset: number,
@@ -30,7 +31,7 @@ abstract class ExternalCall extends Instruction {
30
31
 
31
32
  public async execute(context: AvmContext) {
32
33
  const memory = context.machineState.memory;
33
- const addressing = Addressing.fromWire(this.indirect);
34
+ const addressing = Addressing.fromWire(this.addressingMode);
34
35
 
35
36
  context.machineState.consumeGas(
36
37
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -45,7 +46,8 @@ abstract class ExternalCall extends Instruction {
45
46
  memory.checkTag(TypeTag.UINT32, argsSizeOffset);
46
47
 
47
48
  const calldataSize = memory.get(argsSizeOffset).toNumber();
48
- const calldata = memory.getSlice(argsOffset, calldataSize).map(f => f.toFr());
49
+
50
+ const calldata = new CallDataMemory(memory, argsOffset, calldataSize);
49
51
 
50
52
  const callAddress = memory.getAs<Field>(addrOffset);
51
53
  // If we are already in a static call, we propagate the environment.
@@ -72,8 +74,8 @@ abstract class ExternalCall extends Instruction {
72
74
  const success = !nestedCallResults.reverted;
73
75
 
74
76
  // Save return/revert data for later.
75
- const fullReturnData = nestedCallResults.output;
76
- context.machineState.nestedReturndata = fullReturnData;
77
+ const returnData = nestedCallResults.output;
78
+ context.machineState.nestedReturndata = returnData;
77
79
 
78
80
  // Track the success status directly
79
81
  context.machineState.nestedCallSuccess = success;
@@ -88,7 +90,7 @@ abstract class ExternalCall extends Instruction {
88
90
  // (in Noir code).
89
91
  if (!success) {
90
92
  context.machineState.collectedRevertInfo = {
91
- revertDataRepresentative: fullReturnData,
93
+ revertDataRepresentative: returnData.bestEffortReadAll(),
92
94
  recursiveRevertReason: nestedCallResults.revertReason!,
93
95
  };
94
96
  }
@@ -136,7 +138,7 @@ export class SuccessCopy extends Instruction {
136
138
  ];
137
139
 
138
140
  constructor(
139
- private indirect: number,
141
+ private addressingMode: number,
140
142
  private dstOffset: number,
141
143
  ) {
142
144
  super();
@@ -144,7 +146,7 @@ export class SuccessCopy extends Instruction {
144
146
 
145
147
  public async execute(context: AvmContext): Promise<void> {
146
148
  const memory = context.machineState.memory;
147
- const addressing = Addressing.fromWire(this.indirect);
149
+ const addressing = Addressing.fromWire(this.addressingMode);
148
150
 
149
151
  context.machineState.consumeGas(
150
152
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -173,7 +175,7 @@ export class Return extends Instruction {
173
175
  ];
174
176
 
175
177
  constructor(
176
- private indirect: number,
178
+ private addressingMode: number,
177
179
  private returnSizeOffset: number,
178
180
  private returnOffset: number,
179
181
  ) {
@@ -182,7 +184,7 @@ export class Return extends Instruction {
182
184
 
183
185
  public async execute(context: AvmContext): Promise<void> {
184
186
  const memory = context.machineState.memory;
185
- const addressing = Addressing.fromWire(this.indirect);
187
+ const addressing = Addressing.fromWire(this.addressingMode);
186
188
 
187
189
  context.machineState.consumeGas(
188
190
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -194,7 +196,7 @@ export class Return extends Instruction {
194
196
  memory.checkTag(TypeTag.UINT32, returnSizeOffset);
195
197
  const returnSize = memory.get(returnSizeOffset).toNumber();
196
198
 
197
- const output = memory.getSlice(returnOffset, returnSize).map(word => word.toFr());
199
+ const output = new ReturnDataMemory(memory, returnOffset, returnSize);
198
200
 
199
201
  context.machineState.return(output);
200
202
  }
@@ -222,7 +224,7 @@ export class Revert extends Instruction {
222
224
  ];
223
225
 
224
226
  constructor(
225
- private indirect: number,
227
+ private addressingMode: number,
226
228
  private retSizeOffset: number,
227
229
  private returnOffset: number,
228
230
  ) {
@@ -231,7 +233,7 @@ export class Revert extends Instruction {
231
233
 
232
234
  public async execute(context: AvmContext): Promise<void> {
233
235
  const memory = context.machineState.memory;
234
- const addressing = Addressing.fromWire(this.indirect);
236
+ const addressing = Addressing.fromWire(this.addressingMode);
235
237
 
236
238
  context.machineState.consumeGas(
237
239
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -242,7 +244,7 @@ export class Revert extends Instruction {
242
244
 
243
245
  memory.checkTag(TypeTag.UINT32, retSizeOffset);
244
246
  const retSize = memory.get(retSizeOffset).toNumber();
245
- const output = memory.getSlice(returnOffset, retSize).map(word => word.toFr());
247
+ const output = new ReturnDataMemory(memory, returnOffset, retSize);
246
248
 
247
249
  context.machineState.revert(output);
248
250
  }
@@ -1,4 +1,6 @@
1
- import { keccakf1600, poseidon2Permutation, sha256Compression } from '@aztec/foundation/crypto';
1
+ import { keccakf1600 } from '@aztec/foundation/crypto/keccak';
2
+ import { poseidon2Permutation } from '@aztec/foundation/crypto/poseidon';
3
+ import { sha256Compression } from '@aztec/foundation/crypto/sha256';
2
4
 
3
5
  import type { AvmContext } from '../avm_context.js';
4
6
  import { Field, TypeTag, Uint32, Uint64 } from '../avm_memory_types.js';
@@ -20,7 +22,7 @@ export class Poseidon2 extends Instruction {
20
22
  ];
21
23
 
22
24
  constructor(
23
- private indirect: number,
25
+ private addressingMode: number,
24
26
  private inputStateOffset: number,
25
27
  private outputStateOffset: number,
26
28
  ) {
@@ -29,7 +31,7 @@ export class Poseidon2 extends Instruction {
29
31
 
30
32
  public async execute(context: AvmContext): Promise<void> {
31
33
  const memory = context.machineState.memory;
32
- const addressing = Addressing.fromWire(this.indirect);
34
+ const addressing = Addressing.fromWire(this.addressingMode);
33
35
 
34
36
  context.machineState.consumeGas(
35
37
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -63,7 +65,7 @@ export class KeccakF1600 extends Instruction {
63
65
  ];
64
66
 
65
67
  constructor(
66
- private indirect: number,
68
+ private addressingMode: number,
67
69
  private dstOffset: number,
68
70
  private inputOffset: number,
69
71
  ) {
@@ -74,7 +76,7 @@ export class KeccakF1600 extends Instruction {
74
76
  public async execute(context: AvmContext): Promise<void> {
75
77
  const inputSize = 25;
76
78
  const memory = context.machineState.memory;
77
- const addressing = Addressing.fromWire(this.indirect);
79
+ const addressing = Addressing.fromWire(this.addressingMode);
78
80
 
79
81
  context.machineState.consumeGas(
80
82
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -107,7 +109,7 @@ export class Sha256Compression extends Instruction {
107
109
  ];
108
110
 
109
111
  constructor(
110
- private indirect: number,
112
+ private addressingMode: number,
111
113
  private outputOffset: number,
112
114
  private stateOffset: number,
113
115
  private inputsOffset: number,
@@ -120,7 +122,7 @@ export class Sha256Compression extends Instruction {
120
122
  const INPUTS_SIZE = 16;
121
123
 
122
124
  const memory = context.machineState.memory;
123
- const addressing = Addressing.fromWire(this.indirect);
125
+ const addressing = Addressing.fromWire(this.addressingMode);
124
126
 
125
127
  context.machineState.consumeGas(
126
128
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -130,13 +132,17 @@ export class Sha256Compression extends Instruction {
130
132
  const [outputOffset, stateOffset, inputsOffset] = addressing.resolve(operands, memory);
131
133
 
132
134
  // Note: size of output is same as size of state
133
- const inputs = Uint32Array.from(memory.getSlice(inputsOffset, INPUTS_SIZE).map(word => word.toNumber()));
134
- const state = Uint32Array.from(memory.getSlice(stateOffset, STATE_SIZE).map(word => word.toNumber()));
135
+ const inputs = memory.getSlice(inputsOffset, INPUTS_SIZE).map(word => word.toBigInt());
136
+ const state = memory.getSlice(stateOffset, STATE_SIZE).map(word => word.toBigInt());
135
137
 
136
138
  memory.checkTagsRange(TypeTag.UINT32, inputsOffset, INPUTS_SIZE);
137
139
  memory.checkTagsRange(TypeTag.UINT32, stateOffset, STATE_SIZE);
138
140
 
139
- const output = sha256Compression(state, inputs);
141
+ // At this point both state and inputs are Uint32Array-compatible
142
+ const inputsArray = new Uint32Array(inputs.map(i => Number(i)));
143
+ const stateArray = new Uint32Array(state.map(i => Number(i)));
144
+
145
+ const output = sha256Compression(stateArray, inputsArray);
140
146
 
141
147
  // Conversion required from Uint32Array to Uint32[] (can't map directly, need `...`)
142
148
  const res = [...output].map(word => new Uint32(word));