@aztec/simulator 0.0.1-commit.b655e406 → 0.0.1-commit.d1f2d6c

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 (344) hide show
  1. package/README.md +2 -0
  2. package/dest/client.d.ts +1 -1
  3. package/dest/common/errors.d.ts +2 -2
  4. package/dest/common/errors.d.ts.map +1 -1
  5. package/dest/common/index.d.ts +1 -1
  6. package/dest/common/stats/index.d.ts +1 -1
  7. package/dest/common/stats/stats.d.ts +1 -1
  8. package/dest/private/acvm/acvm.d.ts +1 -1
  9. package/dest/private/acvm/acvm_types.d.ts +1 -1
  10. package/dest/private/acvm/deserialize.d.ts +2 -2
  11. package/dest/private/acvm/deserialize.d.ts.map +1 -1
  12. package/dest/private/acvm/deserialize.js +1 -1
  13. package/dest/private/acvm/index.d.ts +1 -1
  14. package/dest/private/acvm/serialize.d.ts +2 -2
  15. package/dest/private/acvm/serialize.d.ts.map +1 -1
  16. package/dest/private/acvm/serialize.js +1 -1
  17. package/dest/private/acvm_native.d.ts +1 -1
  18. package/dest/private/acvm_native.d.ts.map +1 -1
  19. package/dest/private/acvm_wasm.d.ts +1 -1
  20. package/dest/private/acvm_wasm.d.ts.map +1 -1
  21. package/dest/private/acvm_wasm_with_blobs.d.ts +1 -1
  22. package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -1
  23. package/dest/private/circuit_recording/circuit_recorder.d.ts +1 -1
  24. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
  25. package/dest/private/circuit_recording/circuit_recorder.js +16 -15
  26. package/dest/private/circuit_recording/file_circuit_recorder.d.ts +1 -1
  27. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -1
  28. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +1 -1
  29. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -1
  30. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +1 -1
  31. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -1
  32. package/dest/private/circuit_simulator.d.ts +1 -1
  33. package/dest/private/factory.d.ts +1 -1
  34. package/dest/public/avm/avm_context.d.ts +2 -2
  35. package/dest/public/avm/avm_context.d.ts.map +1 -1
  36. package/dest/public/avm/avm_contract_call_result.d.ts +2 -2
  37. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  38. package/dest/public/avm/avm_execution_environment.d.ts +5 -5
  39. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  40. package/dest/public/avm/avm_execution_environment.js +5 -8
  41. package/dest/public/avm/avm_gas.d.ts +2 -2
  42. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  43. package/dest/public/avm/avm_machine_state.d.ts +2 -2
  44. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  45. package/dest/public/avm/avm_memory_types.d.ts +14 -14
  46. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  47. package/dest/public/avm/avm_memory_types.js +4 -1
  48. package/dest/public/avm/avm_simulator.d.ts +4 -3
  49. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  50. package/dest/public/avm/avm_simulator.js +8 -7
  51. package/dest/public/avm/avm_simulator_interface.d.ts +1 -1
  52. package/dest/public/avm/errors.d.ts +8 -2
  53. package/dest/public/avm/errors.d.ts.map +1 -1
  54. package/dest/public/avm/errors.js +14 -2
  55. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
  56. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  57. package/dest/public/avm/fixtures/avm_simulation_tester.js +12 -3
  58. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +2 -2
  59. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
  60. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +1 -1
  61. package/dest/public/avm/fixtures/initializers.d.ts +2 -3
  62. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
  63. package/dest/public/avm/fixtures/initializers.js +7 -5
  64. package/dest/public/avm/fixtures/utils.d.ts +4 -3
  65. package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
  66. package/dest/public/avm/fixtures/utils.js +3 -2
  67. package/dest/public/avm/index.d.ts +1 -1
  68. package/dest/public/avm/opcodes/accrued_substate.d.ts +15 -15
  69. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  70. package/dest/public/avm/opcodes/accrued_substate.js +29 -29
  71. package/dest/public/avm/opcodes/addressing_mode.d.ts +1 -1
  72. package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
  73. package/dest/public/avm/opcodes/addressing_mode.js +2 -2
  74. package/dest/public/avm/opcodes/arithmetic.d.ts +3 -1
  75. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  76. package/dest/public/avm/opcodes/arithmetic.js +12 -2
  77. package/dest/public/avm/opcodes/bitwise.d.ts +3 -3
  78. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  79. package/dest/public/avm/opcodes/bitwise.js +5 -5
  80. package/dest/public/avm/opcodes/comparators.d.ts +1 -1
  81. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  82. package/dest/public/avm/opcodes/comparators.js +1 -1
  83. package/dest/public/avm/opcodes/contract.d.ts +3 -3
  84. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  85. package/dest/public/avm/opcodes/contract.js +8 -8
  86. package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
  87. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  88. package/dest/public/avm/opcodes/control_flow.js +4 -4
  89. package/dest/public/avm/opcodes/conversion.d.ts +3 -3
  90. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  91. package/dest/public/avm/opcodes/conversion.js +4 -4
  92. package/dest/public/avm/opcodes/ec_add.d.ts +3 -3
  93. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  94. package/dest/public/avm/opcodes/ec_add.js +17 -8
  95. package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
  96. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  97. package/dest/public/avm/opcodes/environment_getters.js +6 -6
  98. package/dest/public/avm/opcodes/external_calls.d.ts +9 -9
  99. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  100. package/dest/public/avm/opcodes/external_calls.js +17 -16
  101. package/dest/public/avm/opcodes/hashing.d.ts +7 -7
  102. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  103. package/dest/public/avm/opcodes/hashing.js +21 -16
  104. package/dest/public/avm/opcodes/index.d.ts +1 -1
  105. package/dest/public/avm/opcodes/instruction.d.ts +2 -2
  106. package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
  107. package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
  108. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  109. package/dest/public/avm/opcodes/instruction_impl.js +4 -4
  110. package/dest/public/avm/opcodes/memory.d.ts +13 -13
  111. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  112. package/dest/public/avm/opcodes/memory.js +25 -25
  113. package/dest/public/avm/opcodes/misc.d.ts +3 -3
  114. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  115. package/dest/public/avm/opcodes/misc.js +8 -8
  116. package/dest/public/avm/opcodes/storage.d.ts +14 -13
  117. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  118. package/dest/public/avm/opcodes/storage.js +34 -24
  119. package/dest/public/avm/revert_reason.d.ts +2 -2
  120. package/dest/public/avm/revert_reason.d.ts.map +1 -1
  121. package/dest/public/avm/revert_reason.js +3 -2
  122. package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -1
  123. package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
  124. package/dest/public/avm/serialization/bytecode_serialization.d.ts +1 -1
  125. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
  126. package/dest/public/avm/serialization/bytecode_serialization.js +9 -6
  127. package/dest/public/avm/serialization/instruction_serialization.d.ts +1 -1
  128. package/dest/public/avm/serialization/instruction_serialization.js +1 -1
  129. package/dest/public/avm/test_utils.d.ts +2 -2
  130. package/dest/public/avm/test_utils.d.ts.map +1 -1
  131. package/dest/public/avm/test_utils.js +1 -1
  132. package/dest/public/contracts_db_checkpoint.d.ts +16 -0
  133. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -0
  134. package/dest/public/contracts_db_checkpoint.js +30 -0
  135. package/dest/public/db_interfaces.d.ts +14 -2
  136. package/dest/public/db_interfaces.d.ts.map +1 -1
  137. package/dest/public/debug_fn_name.d.ts +15 -2
  138. package/dest/public/debug_fn_name.d.ts.map +1 -1
  139. package/dest/public/debug_fn_name.js +28 -2
  140. package/dest/public/executor_metrics.d.ts +3 -2
  141. package/dest/public/executor_metrics.d.ts.map +1 -1
  142. package/dest/public/executor_metrics.js +9 -35
  143. package/dest/public/executor_metrics_interface.d.ts +3 -2
  144. package/dest/public/executor_metrics_interface.d.ts.map +1 -1
  145. package/dest/public/fixtures/amm_test.d.ts +1 -1
  146. package/dest/public/fixtures/amm_test.js +2 -2
  147. package/dest/public/fixtures/bulk_test.d.ts +3 -3
  148. package/dest/public/fixtures/bulk_test.d.ts.map +1 -1
  149. package/dest/public/fixtures/bulk_test.js +5 -69
  150. package/dest/public/fixtures/custom_bytecode_tester.d.ts +29 -7
  151. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
  152. package/dest/public/fixtures/custom_bytecode_tester.js +36 -12
  153. package/dest/public/fixtures/custom_bytecode_tests.d.ts +11 -8
  154. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
  155. package/dest/public/fixtures/custom_bytecode_tests.js +83 -18
  156. package/dest/public/fixtures/index.d.ts +4 -2
  157. package/dest/public/fixtures/index.d.ts.map +1 -1
  158. package/dest/public/fixtures/index.js +3 -1
  159. package/dest/public/fixtures/minimal_public_tx.d.ts +2 -8
  160. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
  161. package/dest/public/fixtures/minimal_public_tx.js +6 -16
  162. package/dest/public/fixtures/opcode_spammer.d.ts +123 -0
  163. package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
  164. package/dest/public/fixtures/opcode_spammer.js +1693 -0
  165. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +24 -6
  166. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  167. package/dest/public/fixtures/public_tx_simulation_tester.js +62 -21
  168. package/dest/public/fixtures/simple_contract_data_source.d.ts +5 -4
  169. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
  170. package/dest/public/fixtures/simple_contract_data_source.js +4 -4
  171. package/dest/public/fixtures/token_test.d.ts +6 -2
  172. package/dest/public/fixtures/token_test.d.ts.map +1 -1
  173. package/dest/public/fixtures/token_test.js +13 -12
  174. package/dest/public/fixtures/utils.d.ts +2 -2
  175. package/dest/public/fixtures/utils.d.ts.map +1 -1
  176. package/dest/public/fixtures/utils.js +4 -3
  177. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
  178. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
  179. package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
  180. package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
  181. package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
  182. package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
  183. package/dest/public/hinting_db_sources.d.ts +14 -4
  184. package/dest/public/hinting_db_sources.d.ts.map +1 -1
  185. package/dest/public/hinting_db_sources.js +71 -13
  186. package/dest/public/index.d.ts +3 -2
  187. package/dest/public/index.d.ts.map +1 -1
  188. package/dest/public/index.js +1 -1
  189. package/dest/public/public_db_sources.d.ts +22 -63
  190. package/dest/public/public_db_sources.d.ts.map +1 -1
  191. package/dest/public/public_db_sources.js +74 -131
  192. package/dest/public/public_errors.d.ts +1 -1
  193. package/dest/public/public_errors.d.ts.map +1 -1
  194. package/dest/public/public_processor/guarded_merkle_tree.d.ts +6 -4
  195. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
  196. package/dest/public/public_processor/guarded_merkle_tree.js +5 -0
  197. package/dest/public/public_processor/public_processor.d.ts +12 -19
  198. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  199. package/dest/public/public_processor/public_processor.js +456 -64
  200. package/dest/public/public_processor/public_processor_metrics.d.ts +1 -1
  201. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  202. package/dest/public/public_processor/public_processor_metrics.js +12 -45
  203. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +18 -0
  204. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -0
  205. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +98 -0
  206. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +34 -22
  207. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
  208. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +93 -50
  209. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
  210. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
  211. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
  212. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
  213. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
  214. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +171 -0
  215. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +22 -0
  216. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
  217. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
  218. package/dest/public/public_tx_simulator/factories.d.ts +13 -0
  219. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
  220. package/dest/public/public_tx_simulator/factories.js +28 -0
  221. package/dest/public/public_tx_simulator/index.d.ts +5 -1
  222. package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
  223. package/dest/public/public_tx_simulator/index.js +3 -0
  224. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +14 -7
  225. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
  226. package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +5 -5
  227. package/dest/public/public_tx_simulator/public_tx_context.d.ts +6 -3
  228. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  229. package/dest/public/public_tx_simulator/public_tx_context.js +13 -5
  230. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +13 -32
  231. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  232. package/dest/public/public_tx_simulator/public_tx_simulator.js +112 -127
  233. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +25 -2
  234. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
  235. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +4 -4
  236. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
  237. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +395 -19
  238. package/dest/public/side_effect_errors.d.ts +1 -1
  239. package/dest/public/side_effect_errors.d.ts.map +1 -1
  240. package/dest/public/side_effect_trace.d.ts +2 -2
  241. package/dest/public/side_effect_trace.d.ts.map +1 -1
  242. package/dest/public/side_effect_trace.js +1 -1
  243. package/dest/public/side_effect_trace_interface.d.ts +3 -4
  244. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  245. package/dest/public/state_manager/index.d.ts +1 -1
  246. package/dest/public/state_manager/nullifiers.d.ts +2 -2
  247. package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
  248. package/dest/public/state_manager/public_storage.d.ts +2 -2
  249. package/dest/public/state_manager/public_storage.d.ts.map +1 -1
  250. package/dest/public/state_manager/public_storage.js +1 -1
  251. package/dest/public/state_manager/state_manager.d.ts +9 -11
  252. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  253. package/dest/public/state_manager/state_manager.js +12 -8
  254. package/dest/public/test_executor_metrics.d.ts +4 -3
  255. package/dest/public/test_executor_metrics.d.ts.map +1 -1
  256. package/dest/public/test_executor_metrics.js +5 -4
  257. package/dest/public/unique_class_ids.d.ts +1 -1
  258. package/dest/public/unique_class_ids.d.ts.map +1 -1
  259. package/dest/public/utils.d.ts +1 -1
  260. package/dest/server.d.ts +1 -1
  261. package/dest/testing.d.ts +1 -1
  262. package/package.json +21 -20
  263. package/src/common/errors.ts +1 -1
  264. package/src/private/acvm/deserialize.ts +1 -1
  265. package/src/private/acvm/serialize.ts +1 -1
  266. package/src/private/circuit_recording/circuit_recorder.ts +17 -16
  267. package/src/public/avm/avm_context.ts +1 -1
  268. package/src/public/avm/avm_contract_call_result.ts +1 -1
  269. package/src/public/avm/avm_execution_environment.ts +4 -6
  270. package/src/public/avm/avm_gas.ts +3 -3
  271. package/src/public/avm/avm_machine_state.ts +1 -1
  272. package/src/public/avm/avm_memory_types.ts +5 -1
  273. package/src/public/avm/avm_simulator.ts +11 -9
  274. package/src/public/avm/errors.ts +17 -3
  275. package/src/public/avm/fixtures/avm_simulation_tester.ts +10 -2
  276. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
  277. package/src/public/avm/fixtures/initializers.ts +8 -10
  278. package/src/public/avm/fixtures/utils.ts +3 -2
  279. package/src/public/avm/opcodes/accrued_substate.ts +15 -15
  280. package/src/public/avm/opcodes/addressing_mode.ts +2 -2
  281. package/src/public/avm/opcodes/arithmetic.ts +14 -2
  282. package/src/public/avm/opcodes/bitwise.ts +3 -3
  283. package/src/public/avm/opcodes/comparators.ts +1 -1
  284. package/src/public/avm/opcodes/contract.ts +4 -7
  285. package/src/public/avm/opcodes/control_flow.ts +2 -2
  286. package/src/public/avm/opcodes/conversion.ts +3 -3
  287. package/src/public/avm/opcodes/ec_add.ts +15 -6
  288. package/src/public/avm/opcodes/environment_getters.ts +7 -7
  289. package/src/public/avm/opcodes/external_calls.ts +10 -9
  290. package/src/public/avm/opcodes/hashing.ts +16 -10
  291. package/src/public/avm/opcodes/instruction_impl.ts +2 -2
  292. package/src/public/avm/opcodes/memory.ts +19 -19
  293. package/src/public/avm/opcodes/misc.ts +6 -6
  294. package/src/public/avm/opcodes/storage.ts +30 -22
  295. package/src/public/avm/revert_reason.ts +6 -3
  296. package/src/public/avm/serialization/bytecode_serialization.ts +17 -6
  297. package/src/public/avm/serialization/instruction_serialization.ts +1 -1
  298. package/src/public/avm/test_utils.ts +1 -1
  299. package/src/public/contracts_db_checkpoint.ts +41 -0
  300. package/src/public/db_interfaces.ts +16 -1
  301. package/src/public/debug_fn_name.ts +35 -3
  302. package/src/public/executor_metrics.ts +9 -35
  303. package/src/public/executor_metrics_interface.ts +2 -1
  304. package/src/public/fixtures/amm_test.ts +2 -2
  305. package/src/public/fixtures/bulk_test.ts +9 -9
  306. package/src/public/fixtures/custom_bytecode_tester.ts +54 -20
  307. package/src/public/fixtures/custom_bytecode_tests.ts +111 -18
  308. package/src/public/fixtures/index.ts +7 -1
  309. package/src/public/fixtures/minimal_public_tx.ts +7 -17
  310. package/src/public/fixtures/opcode_spammer.ts +1754 -0
  311. package/src/public/fixtures/public_tx_simulation_tester.ts +85 -21
  312. package/src/public/fixtures/simple_contract_data_source.ts +8 -9
  313. package/src/public/fixtures/token_test.ts +18 -10
  314. package/src/public/fixtures/utils.ts +2 -3
  315. package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
  316. package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
  317. package/src/public/hinting_db_sources.ts +112 -10
  318. package/src/public/index.ts +6 -4
  319. package/src/public/public_db_sources.ts +93 -172
  320. package/src/public/public_processor/guarded_merkle_tree.ts +8 -3
  321. package/src/public/public_processor/public_processor.ts +86 -59
  322. package/src/public/public_processor/public_processor_metrics.ts +11 -45
  323. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +121 -0
  324. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +137 -57
  325. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +132 -0
  326. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +237 -0
  327. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +81 -0
  328. package/src/public/public_tx_simulator/factories.ts +41 -0
  329. package/src/public/public_tx_simulator/index.ts +4 -0
  330. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +10 -14
  331. package/src/public/public_tx_simulator/public_tx_context.ts +9 -3
  332. package/src/public/public_tx_simulator/public_tx_simulator.ts +163 -193
  333. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +24 -2
  334. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +3 -3
  335. package/src/public/side_effect_trace.ts +1 -1
  336. package/src/public/side_effect_trace_interface.ts +1 -1
  337. package/src/public/state_manager/nullifiers.ts +1 -1
  338. package/src/public/state_manager/public_storage.ts +1 -1
  339. package/src/public/state_manager/state_manager.ts +16 -30
  340. package/src/public/test_executor_metrics.ts +7 -5
  341. package/dest/public/tx_contract_cache.d.ts +0 -41
  342. package/dest/public/tx_contract_cache.d.ts.map +0 -1
  343. package/dest/public/tx_contract_cache.js +0 -49
  344. package/src/public/tx_contract_cache.ts +0 -69
@@ -1,5 +1,5 @@
1
1
  import { CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS } from '@aztec/constants';
2
- import { Fr } from '@aztec/foundation/fields';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { createLogger } from '@aztec/foundation/log';
4
4
  import { ProtocolContractAddress } from '@aztec/protocol-contracts';
5
5
  import { getCanonicalAuthRegistry } from '@aztec/protocol-contracts/auth-registry';
@@ -1,6 +1,8 @@
1
- import { AVM_MAX_PROCESSABLE_L2_GAS, DEFAULT_MAX_DEBUG_LOG_MEMORY_READS } from '@aztec/constants';
1
+ import { AVM_MAX_PROCESSABLE_L2_GAS } from '@aztec/constants';
2
+ import { BlockNumber, SlotNumber } from '@aztec/foundation/branded-types';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
4
  import { EthAddress } from '@aztec/foundation/eth-address';
3
- import { Fr } from '@aztec/foundation/fields';
5
+ import { PublicSimulatorConfig } from '@aztec/stdlib/avm';
4
6
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
5
7
  import { GasFees } from '@aztec/stdlib/gas';
6
8
  import { GlobalVariables } from '@aztec/stdlib/tx';
@@ -43,7 +45,6 @@ export function initPersistableStateManager(overrides?: {
43
45
  trace?: PublicSideEffectTraceInterface;
44
46
  publicStorage?: PublicStorage;
45
47
  nullifiers?: NullifierManager;
46
- doMerkleOperations?: boolean;
47
48
  firstNullifier?: Fr;
48
49
  timestamp?: UInt64;
49
50
  }): PublicPersistableStateManager {
@@ -54,9 +55,7 @@ export function initPersistableStateManager(overrides?: {
54
55
  overrides?.trace || mock<PublicSideEffectTraceInterface>(),
55
56
  overrides?.firstNullifier || new Fr(27),
56
57
  overrides?.timestamp || DEFAULT_TIMESTAMP,
57
- overrides?.doMerkleOperations || false,
58
- overrides?.publicStorage,
59
- overrides?.nullifiers,
58
+ /*doMerkleOperations=*/ false,
60
59
  );
61
60
  }
62
61
 
@@ -72,8 +71,7 @@ export function initExecutionEnvironment(overrides?: Partial<AvmExecutionEnviron
72
71
  overrides?.globals ?? GlobalVariables.empty(),
73
72
  overrides?.isStaticCall ?? false,
74
73
  overrides?.calldata ?? [],
75
- overrides?.clientInitiatedSimulation ?? true, // default to true for testing even though internal default is false
76
- overrides?.maxDebugLogMemoryReads ?? DEFAULT_MAX_DEBUG_LOG_MEMORY_READS,
74
+ overrides?.config ?? PublicSimulatorConfig.empty(),
77
75
  );
78
76
  }
79
77
 
@@ -84,8 +82,8 @@ export function initGlobalVariables(overrides?: Partial<GlobalVariables>): Globa
84
82
  return new GlobalVariables(
85
83
  overrides?.chainId ?? Fr.zero(),
86
84
  overrides?.version ?? Fr.zero(),
87
- overrides?.blockNumber ?? 0,
88
- overrides?.slotNumber ?? Fr.zero(),
85
+ overrides?.blockNumber ?? BlockNumber.ZERO,
86
+ overrides?.slotNumber ?? SlotNumber.ZERO,
89
87
  overrides?.timestamp ?? 0n,
90
88
  overrides?.coinbase ?? EthAddress.ZERO,
91
89
  overrides?.feeRecipient ?? AztecAddress.zero(),
@@ -1,5 +1,6 @@
1
1
  import { CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS } from '@aztec/constants';
2
- import { Fr } from '@aztec/foundation/fields';
2
+ import { BlockNumber } from '@aztec/foundation/branded-types';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
4
  import {
4
5
  type ContractArtifact,
5
6
  type FunctionAbi,
@@ -28,7 +29,7 @@ import type { AvmRevertReason } from '../errors.js';
28
29
 
29
30
  export const PUBLIC_DISPATCH_FN_NAME = 'public_dispatch';
30
31
  export const DEFAULT_TIMESTAMP: UInt64 = 99833n;
31
- export const DEFAULT_BLOCK_NUMBER = 42;
32
+ export const DEFAULT_BLOCK_NUMBER = BlockNumber(42);
32
33
 
33
34
  /**
34
35
  * Create a new object with all the same properties as the original, except for the ones in the overrides object.
@@ -19,7 +19,7 @@ export class NoteHashExists extends Instruction {
19
19
  ];
20
20
 
21
21
  constructor(
22
- private indirect: number,
22
+ private addressingMode: number,
23
23
  private noteHashOffset: number,
24
24
  private leafIndexOffset: number,
25
25
  private existsOffset: number,
@@ -29,7 +29,7 @@ export class NoteHashExists extends Instruction {
29
29
 
30
30
  public async execute(context: AvmContext): Promise<void> {
31
31
  const memory = context.machineState.memory;
32
- const addressing = Addressing.fromWire(this.indirect);
32
+ const addressing = Addressing.fromWire(this.addressingMode);
33
33
 
34
34
  context.machineState.consumeGas(
35
35
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -55,7 +55,7 @@ export class EmitNoteHash extends Instruction {
55
55
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16];
56
56
 
57
57
  constructor(
58
- private indirect: number,
58
+ private addressingMode: number,
59
59
  private noteHashOffset: number,
60
60
  ) {
61
61
  super();
@@ -63,7 +63,7 @@ export class EmitNoteHash extends Instruction {
63
63
 
64
64
  public async execute(context: AvmContext): Promise<void> {
65
65
  const memory = context.machineState.memory;
66
- const addressing = Addressing.fromWire(this.indirect);
66
+ const addressing = Addressing.fromWire(this.addressingMode);
67
67
 
68
68
  context.machineState.consumeGas(
69
69
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -95,7 +95,7 @@ export class NullifierExists extends Instruction {
95
95
  ];
96
96
 
97
97
  constructor(
98
- private indirect: number,
98
+ private addressingMode: number,
99
99
  private nullifierOffset: number,
100
100
  private addressOffset: number,
101
101
  private existsOffset: number,
@@ -105,7 +105,7 @@ export class NullifierExists extends Instruction {
105
105
 
106
106
  public async execute(context: AvmContext): Promise<void> {
107
107
  const memory = context.machineState.memory;
108
- const addressing = Addressing.fromWire(this.indirect);
108
+ const addressing = Addressing.fromWire(this.addressingMode);
109
109
 
110
110
  context.machineState.consumeGas(
111
111
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -130,7 +130,7 @@ export class EmitNullifier extends Instruction {
130
130
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16];
131
131
 
132
132
  constructor(
133
- private indirect: number,
133
+ private addressingMode: number,
134
134
  private nullifierOffset: number,
135
135
  ) {
136
136
  super();
@@ -142,7 +142,7 @@ export class EmitNullifier extends Instruction {
142
142
  }
143
143
 
144
144
  const memory = context.machineState.memory;
145
- const addressing = Addressing.fromWire(this.indirect);
145
+ const addressing = Addressing.fromWire(this.addressingMode);
146
146
 
147
147
  context.machineState.consumeGas(
148
148
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -181,7 +181,7 @@ export class L1ToL2MessageExists extends Instruction {
181
181
  ];
182
182
 
183
183
  constructor(
184
- private indirect: number,
184
+ private addressingMode: number,
185
185
  private msgHashOffset: number,
186
186
  private msgLeafIndexOffset: number,
187
187
  private existsOffset: number,
@@ -191,7 +191,7 @@ export class L1ToL2MessageExists extends Instruction {
191
191
 
192
192
  public async execute(context: AvmContext): Promise<void> {
193
193
  const memory = context.machineState.memory;
194
- const addressing = Addressing.fromWire(this.indirect);
194
+ const addressing = Addressing.fromWire(this.addressingMode);
195
195
 
196
196
  context.machineState.consumeGas(
197
197
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -218,7 +218,7 @@ export class EmitUnencryptedLog extends Instruction {
218
218
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16, OperandType.UINT16];
219
219
 
220
220
  constructor(
221
- private indirect: number,
221
+ private addressingMode: number,
222
222
  private logSizeOffset: number,
223
223
  private logOffset: number,
224
224
  ) {
@@ -231,7 +231,7 @@ export class EmitUnencryptedLog extends Instruction {
231
231
  }
232
232
 
233
233
  const memory = context.machineState.memory;
234
- const addressing = Addressing.fromWire(this.indirect);
234
+ const addressing = Addressing.fromWire(this.addressingMode);
235
235
 
236
236
  context.machineState.consumeGas(
237
237
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -241,11 +241,11 @@ export class EmitUnencryptedLog extends Instruction {
241
241
  const [logSizeOffset, logOffset] = addressing.resolve(operands, memory);
242
242
  memory.checkTag(TypeTag.UINT32, logSizeOffset);
243
243
  const logSize = memory.get(logSizeOffset).toNumber();
244
- memory.checkTagsRange(TypeTag.FIELD, logOffset, logSize);
245
244
 
246
245
  const contractAddress = context.environment.address;
247
246
 
248
247
  context.machineState.consumeGas(this.dynamicGasCost(logSize));
248
+ memory.checkTagsRange(TypeTag.FIELD, logOffset, logSize);
249
249
  const log = memory.getSlice(logOffset, logSize).map(f => f.toFr());
250
250
  context.persistableState.writePublicLog(contractAddress, log);
251
251
  }
@@ -258,7 +258,7 @@ export class SendL2ToL1Message extends Instruction {
258
258
  static readonly wireFormat = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16, OperandType.UINT16];
259
259
 
260
260
  constructor(
261
- private indirect: number,
261
+ private addressingMode: number,
262
262
  private recipientOffset: number,
263
263
  private contentOffset: number,
264
264
  ) {
@@ -271,7 +271,7 @@ export class SendL2ToL1Message extends Instruction {
271
271
  }
272
272
 
273
273
  const memory = context.machineState.memory;
274
- const addressing = Addressing.fromWire(this.indirect);
274
+ const addressing = Addressing.fromWire(this.addressingMode);
275
275
 
276
276
  context.machineState.consumeGas(
277
277
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -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()),
@@ -9,7 +9,7 @@ abstract class ExternalCall extends Instruction {
9
9
  // Informs (de)serialization. See Instruction.deserialize.
10
10
  static readonly wireFormat: OperandType[] = [
11
11
  OperandType.UINT8,
12
- OperandType.UINT16, // Indirect
12
+ OperandType.UINT16, // addressing_mode
13
13
  OperandType.UINT16, // L2 gas offset
14
14
  OperandType.UINT16, // DA gas offset
15
15
  OperandType.UINT16, // Address offset
@@ -18,7 +18,7 @@ abstract class ExternalCall extends Instruction {
18
18
  ];
19
19
 
20
20
  constructor(
21
- private indirect: number,
21
+ private addressingMode: number,
22
22
  private l2GasOffset: number,
23
23
  private daGasOffset: number,
24
24
  private addrOffset: number,
@@ -30,7 +30,7 @@ abstract class ExternalCall extends Instruction {
30
30
 
31
31
  public async execute(context: AvmContext) {
32
32
  const memory = context.machineState.memory;
33
- const addressing = Addressing.fromWire(this.indirect);
33
+ const addressing = Addressing.fromWire(this.addressingMode);
34
34
 
35
35
  context.machineState.consumeGas(
36
36
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -45,6 +45,7 @@ abstract class ExternalCall extends Instruction {
45
45
  memory.checkTag(TypeTag.UINT32, argsSizeOffset);
46
46
 
47
47
  const calldataSize = memory.get(argsSizeOffset).toNumber();
48
+ // This is a DOS vector. CalldataSize is chosen by the bytecode, and can be arbitrarily large leading to a OOM here.
48
49
  const calldata = memory.getSlice(argsOffset, calldataSize).map(f => f.toFr());
49
50
 
50
51
  const callAddress = memory.getAs<Field>(addrOffset);
@@ -136,7 +137,7 @@ export class SuccessCopy extends Instruction {
136
137
  ];
137
138
 
138
139
  constructor(
139
- private indirect: number,
140
+ private addressingMode: number,
140
141
  private dstOffset: number,
141
142
  ) {
142
143
  super();
@@ -144,7 +145,7 @@ export class SuccessCopy extends Instruction {
144
145
 
145
146
  public async execute(context: AvmContext): Promise<void> {
146
147
  const memory = context.machineState.memory;
147
- const addressing = Addressing.fromWire(this.indirect);
148
+ const addressing = Addressing.fromWire(this.addressingMode);
148
149
 
149
150
  context.machineState.consumeGas(
150
151
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -173,7 +174,7 @@ export class Return extends Instruction {
173
174
  ];
174
175
 
175
176
  constructor(
176
- private indirect: number,
177
+ private addressingMode: number,
177
178
  private returnSizeOffset: number,
178
179
  private returnOffset: number,
179
180
  ) {
@@ -182,7 +183,7 @@ export class Return extends Instruction {
182
183
 
183
184
  public async execute(context: AvmContext): Promise<void> {
184
185
  const memory = context.machineState.memory;
185
- const addressing = Addressing.fromWire(this.indirect);
186
+ const addressing = Addressing.fromWire(this.addressingMode);
186
187
 
187
188
  context.machineState.consumeGas(
188
189
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -222,7 +223,7 @@ export class Revert extends Instruction {
222
223
  ];
223
224
 
224
225
  constructor(
225
- private indirect: number,
226
+ private addressingMode: number,
226
227
  private retSizeOffset: number,
227
228
  private returnOffset: number,
228
229
  ) {
@@ -231,7 +232,7 @@ export class Revert extends Instruction {
231
232
 
232
233
  public async execute(context: AvmContext): Promise<void> {
233
234
  const memory = context.machineState.memory;
234
- const addressing = Addressing.fromWire(this.indirect);
235
+ const addressing = Addressing.fromWire(this.addressingMode);
235
236
 
236
237
  context.machineState.consumeGas(
237
238
  this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
@@ -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));