@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.
- package/README.md +2 -0
- package/dest/client.d.ts +1 -1
- package/dest/common/errors.d.ts +2 -2
- package/dest/common/errors.d.ts.map +1 -1
- package/dest/common/index.d.ts +1 -1
- package/dest/common/stats/index.d.ts +1 -1
- package/dest/common/stats/stats.d.ts +1 -1
- package/dest/private/acvm/acvm.d.ts +1 -1
- package/dest/private/acvm/acvm_types.d.ts +1 -1
- package/dest/private/acvm/deserialize.d.ts +2 -2
- package/dest/private/acvm/deserialize.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.js +1 -1
- package/dest/private/acvm/index.d.ts +1 -1
- package/dest/private/acvm/serialize.d.ts +2 -2
- package/dest/private/acvm/serialize.d.ts.map +1 -1
- package/dest/private/acvm/serialize.js +1 -1
- package/dest/private/acvm_native.d.ts +1 -1
- package/dest/private/acvm_native.d.ts.map +1 -1
- package/dest/private/acvm_wasm.d.ts +1 -1
- package/dest/private/acvm_wasm.d.ts.map +1 -1
- package/dest/private/acvm_wasm_with_blobs.d.ts +1 -1
- package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -1
- package/dest/private/circuit_recording/circuit_recorder.d.ts +1 -1
- package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
- package/dest/private/circuit_recording/circuit_recorder.js +16 -15
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts +1 -1
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -1
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +1 -1
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -1
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +1 -1
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -1
- package/dest/private/circuit_simulator.d.ts +1 -1
- package/dest/private/factory.d.ts +1 -1
- package/dest/public/avm/avm_context.d.ts +2 -2
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +2 -2
- package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.d.ts +5 -5
- package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.js +5 -8
- package/dest/public/avm/avm_gas.d.ts +2 -2
- package/dest/public/avm/avm_gas.d.ts.map +1 -1
- package/dest/public/avm/avm_machine_state.d.ts +2 -2
- package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
- package/dest/public/avm/avm_memory_types.d.ts +14 -14
- package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
- package/dest/public/avm/avm_memory_types.js +4 -1
- package/dest/public/avm/avm_simulator.d.ts +4 -3
- package/dest/public/avm/avm_simulator.d.ts.map +1 -1
- package/dest/public/avm/avm_simulator.js +8 -7
- package/dest/public/avm/avm_simulator_interface.d.ts +1 -1
- package/dest/public/avm/errors.d.ts +8 -2
- package/dest/public/avm/errors.d.ts.map +1 -1
- package/dest/public/avm/errors.js +14 -2
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.js +12 -3
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +2 -2
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/base_avm_simulation_tester.js +1 -1
- package/dest/public/avm/fixtures/initializers.d.ts +2 -3
- package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
- package/dest/public/avm/fixtures/initializers.js +7 -5
- package/dest/public/avm/fixtures/utils.d.ts +4 -3
- package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
- package/dest/public/avm/fixtures/utils.js +3 -2
- package/dest/public/avm/index.d.ts +1 -1
- package/dest/public/avm/opcodes/accrued_substate.d.ts +15 -15
- package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
- package/dest/public/avm/opcodes/accrued_substate.js +29 -29
- package/dest/public/avm/opcodes/addressing_mode.d.ts +1 -1
- package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
- package/dest/public/avm/opcodes/addressing_mode.js +2 -2
- package/dest/public/avm/opcodes/arithmetic.d.ts +3 -1
- package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
- package/dest/public/avm/opcodes/arithmetic.js +12 -2
- package/dest/public/avm/opcodes/bitwise.d.ts +3 -3
- package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
- package/dest/public/avm/opcodes/bitwise.js +5 -5
- package/dest/public/avm/opcodes/comparators.d.ts +1 -1
- package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
- package/dest/public/avm/opcodes/comparators.js +1 -1
- package/dest/public/avm/opcodes/contract.d.ts +3 -3
- package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
- package/dest/public/avm/opcodes/contract.js +8 -8
- package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
- package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
- package/dest/public/avm/opcodes/control_flow.js +4 -4
- package/dest/public/avm/opcodes/conversion.d.ts +3 -3
- package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
- package/dest/public/avm/opcodes/conversion.js +4 -4
- package/dest/public/avm/opcodes/ec_add.d.ts +3 -3
- package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
- package/dest/public/avm/opcodes/ec_add.js +17 -8
- package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
- package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
- package/dest/public/avm/opcodes/environment_getters.js +6 -6
- package/dest/public/avm/opcodes/external_calls.d.ts +9 -9
- package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
- package/dest/public/avm/opcodes/external_calls.js +17 -16
- package/dest/public/avm/opcodes/hashing.d.ts +7 -7
- package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
- package/dest/public/avm/opcodes/hashing.js +21 -16
- package/dest/public/avm/opcodes/index.d.ts +1 -1
- package/dest/public/avm/opcodes/instruction.d.ts +2 -2
- package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
- package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
- package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
- package/dest/public/avm/opcodes/instruction_impl.js +4 -4
- package/dest/public/avm/opcodes/memory.d.ts +13 -13
- package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.js +25 -25
- package/dest/public/avm/opcodes/misc.d.ts +3 -3
- package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
- package/dest/public/avm/opcodes/misc.js +8 -8
- package/dest/public/avm/opcodes/storage.d.ts +14 -13
- package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
- package/dest/public/avm/opcodes/storage.js +34 -24
- package/dest/public/avm/revert_reason.d.ts +2 -2
- package/dest/public/avm/revert_reason.d.ts.map +1 -1
- package/dest/public/avm/revert_reason.js +3 -2
- package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -1
- package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.js +9 -6
- package/dest/public/avm/serialization/instruction_serialization.d.ts +1 -1
- package/dest/public/avm/serialization/instruction_serialization.js +1 -1
- package/dest/public/avm/test_utils.d.ts +2 -2
- package/dest/public/avm/test_utils.d.ts.map +1 -1
- package/dest/public/avm/test_utils.js +1 -1
- package/dest/public/contracts_db_checkpoint.d.ts +16 -0
- package/dest/public/contracts_db_checkpoint.d.ts.map +1 -0
- package/dest/public/contracts_db_checkpoint.js +30 -0
- package/dest/public/db_interfaces.d.ts +14 -2
- package/dest/public/db_interfaces.d.ts.map +1 -1
- package/dest/public/debug_fn_name.d.ts +15 -2
- package/dest/public/debug_fn_name.d.ts.map +1 -1
- package/dest/public/debug_fn_name.js +28 -2
- package/dest/public/executor_metrics.d.ts +3 -2
- package/dest/public/executor_metrics.d.ts.map +1 -1
- package/dest/public/executor_metrics.js +9 -35
- package/dest/public/executor_metrics_interface.d.ts +3 -2
- package/dest/public/executor_metrics_interface.d.ts.map +1 -1
- package/dest/public/fixtures/amm_test.d.ts +1 -1
- package/dest/public/fixtures/amm_test.js +2 -2
- package/dest/public/fixtures/bulk_test.d.ts +3 -3
- package/dest/public/fixtures/bulk_test.d.ts.map +1 -1
- package/dest/public/fixtures/bulk_test.js +5 -69
- package/dest/public/fixtures/custom_bytecode_tester.d.ts +29 -7
- package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
- package/dest/public/fixtures/custom_bytecode_tester.js +36 -12
- package/dest/public/fixtures/custom_bytecode_tests.d.ts +11 -8
- package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
- package/dest/public/fixtures/custom_bytecode_tests.js +83 -18
- package/dest/public/fixtures/index.d.ts +4 -2
- package/dest/public/fixtures/index.d.ts.map +1 -1
- package/dest/public/fixtures/index.js +3 -1
- package/dest/public/fixtures/minimal_public_tx.d.ts +2 -8
- package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
- package/dest/public/fixtures/minimal_public_tx.js +6 -16
- package/dest/public/fixtures/opcode_spammer.d.ts +123 -0
- package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
- package/dest/public/fixtures/opcode_spammer.js +1693 -0
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts +24 -6
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
- package/dest/public/fixtures/public_tx_simulation_tester.js +62 -21
- package/dest/public/fixtures/simple_contract_data_source.d.ts +5 -4
- package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
- package/dest/public/fixtures/simple_contract_data_source.js +4 -4
- package/dest/public/fixtures/token_test.d.ts +6 -2
- package/dest/public/fixtures/token_test.d.ts.map +1 -1
- package/dest/public/fixtures/token_test.js +13 -12
- package/dest/public/fixtures/utils.d.ts +2 -2
- package/dest/public/fixtures/utils.d.ts.map +1 -1
- package/dest/public/fixtures/utils.js +4 -3
- package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
- package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
- package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
- package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
- package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
- package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
- package/dest/public/hinting_db_sources.d.ts +14 -4
- package/dest/public/hinting_db_sources.d.ts.map +1 -1
- package/dest/public/hinting_db_sources.js +71 -13
- package/dest/public/index.d.ts +3 -2
- package/dest/public/index.d.ts.map +1 -1
- package/dest/public/index.js +1 -1
- package/dest/public/public_db_sources.d.ts +22 -63
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +74 -131
- package/dest/public/public_errors.d.ts +1 -1
- package/dest/public/public_errors.d.ts.map +1 -1
- package/dest/public/public_processor/guarded_merkle_tree.d.ts +6 -4
- package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
- package/dest/public/public_processor/guarded_merkle_tree.js +5 -0
- package/dest/public/public_processor/public_processor.d.ts +12 -19
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +456 -64
- package/dest/public/public_processor/public_processor_metrics.d.ts +1 -1
- package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor_metrics.js +12 -45
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +18 -0
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +98 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +34 -22
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +93 -50
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
- package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
- package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +171 -0
- package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +22 -0
- package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
- package/dest/public/public_tx_simulator/factories.d.ts +13 -0
- package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/factories.js +28 -0
- package/dest/public/public_tx_simulator/index.d.ts +5 -1
- package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/index.js +3 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +14 -7
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +5 -5
- package/dest/public/public_tx_simulator/public_tx_context.d.ts +6 -3
- package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_context.js +13 -5
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +13 -32
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_simulator.js +112 -127
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +25 -2
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +4 -4
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +395 -19
- package/dest/public/side_effect_errors.d.ts +1 -1
- package/dest/public/side_effect_errors.d.ts.map +1 -1
- package/dest/public/side_effect_trace.d.ts +2 -2
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +1 -1
- package/dest/public/side_effect_trace_interface.d.ts +3 -4
- package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
- package/dest/public/state_manager/index.d.ts +1 -1
- package/dest/public/state_manager/nullifiers.d.ts +2 -2
- package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
- package/dest/public/state_manager/public_storage.d.ts +2 -2
- package/dest/public/state_manager/public_storage.d.ts.map +1 -1
- package/dest/public/state_manager/public_storage.js +1 -1
- package/dest/public/state_manager/state_manager.d.ts +9 -11
- package/dest/public/state_manager/state_manager.d.ts.map +1 -1
- package/dest/public/state_manager/state_manager.js +12 -8
- package/dest/public/test_executor_metrics.d.ts +4 -3
- package/dest/public/test_executor_metrics.d.ts.map +1 -1
- package/dest/public/test_executor_metrics.js +5 -4
- package/dest/public/unique_class_ids.d.ts +1 -1
- package/dest/public/unique_class_ids.d.ts.map +1 -1
- package/dest/public/utils.d.ts +1 -1
- package/dest/server.d.ts +1 -1
- package/dest/testing.d.ts +1 -1
- package/package.json +21 -20
- package/src/common/errors.ts +1 -1
- package/src/private/acvm/deserialize.ts +1 -1
- package/src/private/acvm/serialize.ts +1 -1
- package/src/private/circuit_recording/circuit_recorder.ts +17 -16
- package/src/public/avm/avm_context.ts +1 -1
- package/src/public/avm/avm_contract_call_result.ts +1 -1
- package/src/public/avm/avm_execution_environment.ts +4 -6
- package/src/public/avm/avm_gas.ts +3 -3
- package/src/public/avm/avm_machine_state.ts +1 -1
- package/src/public/avm/avm_memory_types.ts +5 -1
- package/src/public/avm/avm_simulator.ts +11 -9
- package/src/public/avm/errors.ts +17 -3
- package/src/public/avm/fixtures/avm_simulation_tester.ts +10 -2
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
- package/src/public/avm/fixtures/initializers.ts +8 -10
- package/src/public/avm/fixtures/utils.ts +3 -2
- package/src/public/avm/opcodes/accrued_substate.ts +15 -15
- package/src/public/avm/opcodes/addressing_mode.ts +2 -2
- package/src/public/avm/opcodes/arithmetic.ts +14 -2
- package/src/public/avm/opcodes/bitwise.ts +3 -3
- package/src/public/avm/opcodes/comparators.ts +1 -1
- package/src/public/avm/opcodes/contract.ts +4 -7
- package/src/public/avm/opcodes/control_flow.ts +2 -2
- package/src/public/avm/opcodes/conversion.ts +3 -3
- package/src/public/avm/opcodes/ec_add.ts +15 -6
- package/src/public/avm/opcodes/environment_getters.ts +7 -7
- package/src/public/avm/opcodes/external_calls.ts +10 -9
- package/src/public/avm/opcodes/hashing.ts +16 -10
- package/src/public/avm/opcodes/instruction_impl.ts +2 -2
- package/src/public/avm/opcodes/memory.ts +19 -19
- package/src/public/avm/opcodes/misc.ts +6 -6
- package/src/public/avm/opcodes/storage.ts +30 -22
- package/src/public/avm/revert_reason.ts +6 -3
- package/src/public/avm/serialization/bytecode_serialization.ts +17 -6
- package/src/public/avm/serialization/instruction_serialization.ts +1 -1
- package/src/public/avm/test_utils.ts +1 -1
- package/src/public/contracts_db_checkpoint.ts +41 -0
- package/src/public/db_interfaces.ts +16 -1
- package/src/public/debug_fn_name.ts +35 -3
- package/src/public/executor_metrics.ts +9 -35
- package/src/public/executor_metrics_interface.ts +2 -1
- package/src/public/fixtures/amm_test.ts +2 -2
- package/src/public/fixtures/bulk_test.ts +9 -9
- package/src/public/fixtures/custom_bytecode_tester.ts +54 -20
- package/src/public/fixtures/custom_bytecode_tests.ts +111 -18
- package/src/public/fixtures/index.ts +7 -1
- package/src/public/fixtures/minimal_public_tx.ts +7 -17
- package/src/public/fixtures/opcode_spammer.ts +1754 -0
- package/src/public/fixtures/public_tx_simulation_tester.ts +85 -21
- package/src/public/fixtures/simple_contract_data_source.ts +8 -9
- package/src/public/fixtures/token_test.ts +18 -10
- package/src/public/fixtures/utils.ts +2 -3
- package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
- package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
- package/src/public/hinting_db_sources.ts +112 -10
- package/src/public/index.ts +6 -4
- package/src/public/public_db_sources.ts +93 -172
- package/src/public/public_processor/guarded_merkle_tree.ts +8 -3
- package/src/public/public_processor/public_processor.ts +86 -59
- package/src/public/public_processor/public_processor_metrics.ts +11 -45
- package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +121 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +137 -57
- package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +132 -0
- package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +237 -0
- package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +81 -0
- package/src/public/public_tx_simulator/factories.ts +41 -0
- package/src/public/public_tx_simulator/index.ts +4 -0
- package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +10 -14
- package/src/public/public_tx_simulator/public_tx_context.ts +9 -3
- package/src/public/public_tx_simulator/public_tx_simulator.ts +163 -193
- package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +24 -2
- package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +3 -3
- package/src/public/side_effect_trace.ts +1 -1
- package/src/public/side_effect_trace_interface.ts +1 -1
- package/src/public/state_manager/nullifiers.ts +1 -1
- package/src/public/state_manager/public_storage.ts +1 -1
- package/src/public/state_manager/state_manager.ts +16 -30
- package/src/public/test_executor_metrics.ts +7 -5
- package/dest/public/tx_contract_cache.d.ts +0 -41
- package/dest/public/tx_contract_cache.d.ts.map +0 -1
- package/dest/public/tx_contract_cache.js +0 -49
- package/src/public/tx_contract_cache.ts +0 -69
|
@@ -19,14 +19,14 @@ export const ThreeOperandWireFormat16 = [
|
|
|
19
19
|
|
|
20
20
|
/**
|
|
21
21
|
* Covers (de)serialization for an instruction with:
|
|
22
|
-
*
|
|
22
|
+
* addressing mode, inTag, and three operands.
|
|
23
23
|
*/
|
|
24
24
|
export abstract class ThreeOperandInstruction extends Instruction {
|
|
25
25
|
static readonly wireFormat8: OperandType[] = ThreeOperandWireFormat8;
|
|
26
26
|
static readonly wireFormat16: OperandType[] = ThreeOperandWireFormat16;
|
|
27
27
|
|
|
28
28
|
constructor(
|
|
29
|
-
protected
|
|
29
|
+
protected addressingMode: number,
|
|
30
30
|
protected aOffset: number,
|
|
31
31
|
protected bOffset: number,
|
|
32
32
|
protected dstOffset: number,
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Fr } from '@aztec/foundation/
|
|
1
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
2
|
|
|
3
3
|
import { strict as assert } from 'assert';
|
|
4
4
|
|
|
@@ -15,49 +15,49 @@ export class Set extends Instruction {
|
|
|
15
15
|
|
|
16
16
|
public static readonly wireFormat8: OperandType[] = [
|
|
17
17
|
OperandType.UINT8, // opcode
|
|
18
|
-
OperandType.UINT8, //
|
|
18
|
+
OperandType.UINT8, // addressing_mode
|
|
19
19
|
OperandType.UINT8, // dstOffset
|
|
20
20
|
OperandType.TAG, // tag
|
|
21
21
|
OperandType.UINT8, // const (value)
|
|
22
22
|
];
|
|
23
23
|
public static readonly wireFormat16: OperandType[] = [
|
|
24
24
|
OperandType.UINT8, // opcode
|
|
25
|
-
OperandType.UINT8, //
|
|
25
|
+
OperandType.UINT8, // addressing_mode
|
|
26
26
|
OperandType.UINT16, // dstOffset
|
|
27
27
|
OperandType.TAG, // tag
|
|
28
28
|
OperandType.UINT16, // const (value)
|
|
29
29
|
];
|
|
30
30
|
public static readonly wireFormat32: OperandType[] = [
|
|
31
31
|
OperandType.UINT8, // opcode
|
|
32
|
-
OperandType.UINT8, //
|
|
32
|
+
OperandType.UINT8, // addressing_mode
|
|
33
33
|
OperandType.UINT16, // dstOffset
|
|
34
34
|
OperandType.TAG, // tag
|
|
35
35
|
OperandType.UINT32, // const (value)
|
|
36
36
|
];
|
|
37
37
|
public static readonly wireFormat64: OperandType[] = [
|
|
38
38
|
OperandType.UINT8, // opcode
|
|
39
|
-
OperandType.UINT8, //
|
|
39
|
+
OperandType.UINT8, // addressing_mode
|
|
40
40
|
OperandType.UINT16, // dstOffset
|
|
41
41
|
OperandType.TAG, // tag
|
|
42
42
|
OperandType.UINT64, // const (value)
|
|
43
43
|
];
|
|
44
44
|
public static readonly wireFormat128: OperandType[] = [
|
|
45
45
|
OperandType.UINT8, // opcode
|
|
46
|
-
OperandType.UINT8, //
|
|
46
|
+
OperandType.UINT8, // addressing_mode
|
|
47
47
|
OperandType.UINT16, // dstOffset
|
|
48
48
|
OperandType.TAG, // tag
|
|
49
49
|
OperandType.UINT128, // const (value)
|
|
50
50
|
];
|
|
51
51
|
public static readonly wireFormatFF: OperandType[] = [
|
|
52
52
|
OperandType.UINT8, // opcode
|
|
53
|
-
OperandType.UINT8, //
|
|
53
|
+
OperandType.UINT8, // addressing_mode
|
|
54
54
|
OperandType.UINT16, // dstOffset
|
|
55
55
|
OperandType.TAG, // tag
|
|
56
56
|
OperandType.FF, // const (value)
|
|
57
57
|
];
|
|
58
58
|
|
|
59
59
|
constructor(
|
|
60
|
-
private
|
|
60
|
+
private addressingMode: number,
|
|
61
61
|
private dstOffset: number,
|
|
62
62
|
private inTag: number,
|
|
63
63
|
private value: bigint | number,
|
|
@@ -72,7 +72,7 @@ export class Set extends Instruction {
|
|
|
72
72
|
const res = TaggedMemory.buildFromTagTruncating(this.value, this.inTag);
|
|
73
73
|
|
|
74
74
|
const memory = context.machineState.memory;
|
|
75
|
-
const addressing = Addressing.fromWire(this.
|
|
75
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
76
76
|
|
|
77
77
|
context.machineState.consumeGas(
|
|
78
78
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
@@ -104,7 +104,7 @@ export class Cast extends Instruction {
|
|
|
104
104
|
];
|
|
105
105
|
|
|
106
106
|
constructor(
|
|
107
|
-
private
|
|
107
|
+
private addressingMode: number,
|
|
108
108
|
private srcOffset: number,
|
|
109
109
|
private dstOffset: number,
|
|
110
110
|
private dstTag: number,
|
|
@@ -114,7 +114,7 @@ export class Cast extends Instruction {
|
|
|
114
114
|
|
|
115
115
|
public async execute(context: AvmContext): Promise<void> {
|
|
116
116
|
const memory = context.machineState.memory;
|
|
117
|
-
const addressing = Addressing.fromWire(this.
|
|
117
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
118
118
|
|
|
119
119
|
context.machineState.consumeGas(
|
|
120
120
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
@@ -150,7 +150,7 @@ export class Mov extends Instruction {
|
|
|
150
150
|
];
|
|
151
151
|
|
|
152
152
|
constructor(
|
|
153
|
-
private
|
|
153
|
+
private addressingMode: number,
|
|
154
154
|
private srcOffset: number,
|
|
155
155
|
private dstOffset: number,
|
|
156
156
|
) {
|
|
@@ -159,7 +159,7 @@ export class Mov extends Instruction {
|
|
|
159
159
|
|
|
160
160
|
public async execute(context: AvmContext): Promise<void> {
|
|
161
161
|
const memory = context.machineState.memory;
|
|
162
|
-
const addressing = Addressing.fromWire(this.
|
|
162
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
163
163
|
|
|
164
164
|
context.machineState.consumeGas(
|
|
165
165
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
@@ -185,7 +185,7 @@ export class CalldataCopy extends Instruction {
|
|
|
185
185
|
];
|
|
186
186
|
|
|
187
187
|
constructor(
|
|
188
|
-
private
|
|
188
|
+
private addressingMode: number,
|
|
189
189
|
private copySizeOffset: number,
|
|
190
190
|
private cdStartOffset: number,
|
|
191
191
|
private dstOffset: number,
|
|
@@ -195,7 +195,7 @@ export class CalldataCopy extends Instruction {
|
|
|
195
195
|
|
|
196
196
|
public async execute(context: AvmContext): Promise<void> {
|
|
197
197
|
const memory = context.machineState.memory;
|
|
198
|
-
const addressing = Addressing.fromWire(this.
|
|
198
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
199
199
|
|
|
200
200
|
context.machineState.consumeGas(
|
|
201
201
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
@@ -225,7 +225,7 @@ export class ReturndataSize extends Instruction {
|
|
|
225
225
|
static readonly wireFormat: OperandType[] = [OperandType.UINT8, OperandType.UINT8, OperandType.UINT16];
|
|
226
226
|
|
|
227
227
|
constructor(
|
|
228
|
-
private
|
|
228
|
+
private addressingMode: number,
|
|
229
229
|
private dstOffset: number,
|
|
230
230
|
) {
|
|
231
231
|
super();
|
|
@@ -233,7 +233,7 @@ export class ReturndataSize extends Instruction {
|
|
|
233
233
|
|
|
234
234
|
public async execute(context: AvmContext): Promise<void> {
|
|
235
235
|
const memory = context.machineState.memory;
|
|
236
|
-
const addressing = Addressing.fromWire(this.
|
|
236
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
237
237
|
|
|
238
238
|
context.machineState.consumeGas(
|
|
239
239
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
@@ -259,7 +259,7 @@ export class ReturndataCopy extends Instruction {
|
|
|
259
259
|
];
|
|
260
260
|
|
|
261
261
|
constructor(
|
|
262
|
-
private
|
|
262
|
+
private addressingMode: number,
|
|
263
263
|
private copySizeOffset: number,
|
|
264
264
|
private rdStartOffset: number,
|
|
265
265
|
private dstOffset: number,
|
|
@@ -269,7 +269,7 @@ export class ReturndataCopy extends Instruction {
|
|
|
269
269
|
|
|
270
270
|
public async execute(context: AvmContext): Promise<void> {
|
|
271
271
|
const memory = context.machineState.memory;
|
|
272
|
-
const addressing = Addressing.fromWire(this.
|
|
272
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
273
273
|
|
|
274
274
|
context.machineState.consumeGas(
|
|
275
275
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
@@ -23,7 +23,7 @@ export class DebugLog extends Instruction {
|
|
|
23
23
|
];
|
|
24
24
|
|
|
25
25
|
constructor(
|
|
26
|
-
private
|
|
26
|
+
private addressingMode: number,
|
|
27
27
|
private levelOffset: number,
|
|
28
28
|
private messageOffset: number,
|
|
29
29
|
private fieldsOffset: number,
|
|
@@ -35,7 +35,7 @@ export class DebugLog extends Instruction {
|
|
|
35
35
|
|
|
36
36
|
public async execute(context: AvmContext): Promise<void> {
|
|
37
37
|
const memory = context.machineState.memory;
|
|
38
|
-
const addressing = Addressing.fromWire(this.
|
|
38
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
39
39
|
|
|
40
40
|
context.machineState.consumeGas(
|
|
41
41
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
@@ -44,10 +44,10 @@ export class DebugLog extends Instruction {
|
|
|
44
44
|
const operands = [this.levelOffset, this.messageOffset, this.fieldsOffset, this.fieldsSizeOffset];
|
|
45
45
|
const [levelOffset, messageOffset, fieldsOffset, fieldsSizeOffset] = addressing.resolve(operands, memory);
|
|
46
46
|
|
|
47
|
-
// DebugLog is a no-op except
|
|
47
|
+
// DebugLog is a no-op except unless the config is set to collect debug logs.
|
|
48
48
|
// Note that we still do address resolution and basic tag-checking (above)
|
|
49
49
|
// To avoid a special-case in the witness generator and circuit.
|
|
50
|
-
if (context.environment.
|
|
50
|
+
if (context.environment.config.collectDebugLogs) {
|
|
51
51
|
memory.checkTag(TypeTag.UINT8, levelOffset);
|
|
52
52
|
const levelNumber = memory.get(levelOffset).toNumber();
|
|
53
53
|
memory.checkTag(TypeTag.UINT32, fieldsSizeOffset);
|
|
@@ -56,11 +56,11 @@ export class DebugLog extends Instruction {
|
|
|
56
56
|
const memoryReads = 1 /* level */ + 1 /* fieldsSize */ + this.messageSize /* message */ + fieldsSize; /* fields */
|
|
57
57
|
if (
|
|
58
58
|
context.persistableState.getDebugLogMemoryReads() + memoryReads >
|
|
59
|
-
context.environment.maxDebugLogMemoryReads
|
|
59
|
+
context.environment.config.collectionLimits.maxDebugLogMemoryReads
|
|
60
60
|
) {
|
|
61
61
|
// Regular error on purpose: this is not a recoverable error.
|
|
62
62
|
throw new Error(
|
|
63
|
-
`Max debug log memory reads exceeded: ${context.persistableState.getDebugLogMemoryReads() + memoryReads} > ${context.environment.maxDebugLogMemoryReads}`,
|
|
63
|
+
`Max debug log memory reads exceeded: ${context.persistableState.getDebugLogMemoryReads() + memoryReads} > ${context.environment.config.collectionLimits.maxDebugLogMemoryReads}`,
|
|
64
64
|
);
|
|
65
65
|
}
|
|
66
66
|
context.persistableState.writeDebugLogMemoryReads(memoryReads);
|
|
@@ -5,7 +5,9 @@ import { Opcode, OperandType } from '../serialization/instruction_serialization.
|
|
|
5
5
|
import { Addressing } from './addressing_mode.js';
|
|
6
6
|
import { Instruction } from './instruction.js';
|
|
7
7
|
|
|
8
|
-
|
|
8
|
+
export class SStore extends Instruction {
|
|
9
|
+
static readonly type: string = 'SSTORE';
|
|
10
|
+
static readonly opcode = Opcode.SSTORE;
|
|
9
11
|
// Informs (de)serialization. See Instruction.deserialize.
|
|
10
12
|
public static readonly wireFormat: OperandType[] = [
|
|
11
13
|
OperandType.UINT8,
|
|
@@ -15,21 +17,12 @@ abstract class BaseStorageInstruction extends Instruction {
|
|
|
15
17
|
];
|
|
16
18
|
|
|
17
19
|
constructor(
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
20
|
+
private addressingMode: number,
|
|
21
|
+
private srcOffset: number,
|
|
22
|
+
private slotOffset: number,
|
|
21
23
|
) {
|
|
22
24
|
super();
|
|
23
25
|
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export class SStore extends BaseStorageInstruction {
|
|
27
|
-
static readonly type: string = 'SSTORE';
|
|
28
|
-
static readonly opcode = Opcode.SSTORE;
|
|
29
|
-
|
|
30
|
-
constructor(indirect: number, srcOffset: number, slotOffset: number) {
|
|
31
|
-
super(indirect, srcOffset, slotOffset);
|
|
32
|
-
}
|
|
33
26
|
|
|
34
27
|
public async execute(context: AvmContext): Promise<void> {
|
|
35
28
|
if (context.environment.isStaticCall) {
|
|
@@ -37,13 +30,13 @@ export class SStore extends BaseStorageInstruction {
|
|
|
37
30
|
}
|
|
38
31
|
|
|
39
32
|
const memory = context.machineState.memory;
|
|
40
|
-
const addressing = Addressing.fromWire(this.
|
|
33
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
41
34
|
|
|
42
35
|
context.machineState.consumeGas(
|
|
43
36
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
44
37
|
);
|
|
45
38
|
|
|
46
|
-
const operands = [this.
|
|
39
|
+
const operands = [this.srcOffset, this.slotOffset];
|
|
47
40
|
const [srcOffset, slotOffset] = addressing.resolve(operands, memory);
|
|
48
41
|
// We read before tag checking since it's needed for gas cost calculation
|
|
49
42
|
const slot = memory.get(slotOffset).toFr();
|
|
@@ -60,28 +53,43 @@ export class SStore extends BaseStorageInstruction {
|
|
|
60
53
|
}
|
|
61
54
|
}
|
|
62
55
|
|
|
63
|
-
export class SLoad extends
|
|
56
|
+
export class SLoad extends Instruction {
|
|
64
57
|
static readonly type: string = 'SLOAD';
|
|
65
58
|
static readonly opcode = Opcode.SLOAD;
|
|
59
|
+
// Informs (de)serialization. See Instruction.deserialize.
|
|
60
|
+
public static readonly wireFormat: OperandType[] = [
|
|
61
|
+
OperandType.UINT8,
|
|
62
|
+
OperandType.UINT8,
|
|
63
|
+
OperandType.UINT16,
|
|
64
|
+
OperandType.UINT16,
|
|
65
|
+
OperandType.UINT16,
|
|
66
|
+
];
|
|
66
67
|
|
|
67
|
-
constructor(
|
|
68
|
-
|
|
68
|
+
constructor(
|
|
69
|
+
private addressingMode: number,
|
|
70
|
+
private slotOffset: number,
|
|
71
|
+
private contractAddressOffset: number,
|
|
72
|
+
private dstOffset: number,
|
|
73
|
+
) {
|
|
74
|
+
super();
|
|
69
75
|
}
|
|
70
76
|
|
|
71
77
|
public async execute(context: AvmContext): Promise<void> {
|
|
72
78
|
const memory = context.machineState.memory;
|
|
73
|
-
const addressing = Addressing.fromWire(this.
|
|
79
|
+
const addressing = Addressing.fromWire(this.addressingMode);
|
|
74
80
|
|
|
75
81
|
context.machineState.consumeGas(
|
|
76
82
|
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
77
83
|
);
|
|
78
84
|
|
|
79
|
-
const operands = [this.
|
|
80
|
-
const [slotOffset, dstOffset] = addressing.resolve(operands, memory);
|
|
85
|
+
const operands = [this.slotOffset, this.contractAddressOffset, this.dstOffset];
|
|
86
|
+
const [slotOffset, contractAddressOffset, dstOffset] = addressing.resolve(operands, memory);
|
|
81
87
|
memory.checkTag(TypeTag.FIELD, slotOffset);
|
|
88
|
+
memory.checkTag(TypeTag.FIELD, contractAddressOffset);
|
|
82
89
|
|
|
83
90
|
const slot = memory.get(slotOffset).toFr();
|
|
84
|
-
const
|
|
91
|
+
const contractAddress = memory.get(contractAddressOffset).toAztecAddress();
|
|
92
|
+
const value = await context.persistableState.readStorage(contractAddress, slot);
|
|
85
93
|
memory.set(dstOffset, new Field(value));
|
|
86
94
|
}
|
|
87
95
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Fr } from '@aztec/foundation/
|
|
1
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
2
|
|
|
3
3
|
import type { AvmContext } from './avm_context.js';
|
|
4
4
|
import { type AvmExecutionError, AvmRevertReason } from './errors.js';
|
|
@@ -18,13 +18,16 @@ async function createRevertReason(message: string, revertData: Fr[], context: Av
|
|
|
18
18
|
message = context.machineState.collectedRevertInfo.recursiveRevertReason.message;
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
-
const
|
|
21
|
+
const { functionSelector, functionName } = await context.persistableState.getPublicFunctionSelectorAndName(
|
|
22
|
+
context.environment,
|
|
23
|
+
);
|
|
22
24
|
|
|
23
25
|
return new AvmRevertReason(
|
|
24
26
|
message,
|
|
25
27
|
/*failingFunction=*/ {
|
|
26
28
|
contractAddress: context.environment.address,
|
|
27
|
-
|
|
29
|
+
functionSelector,
|
|
30
|
+
functionName,
|
|
28
31
|
},
|
|
29
32
|
/*noirCallStack=*/ [...internalCallStack, context.machineState.pc].map(pc => `0.${pc}`),
|
|
30
33
|
/*options=*/ { cause: nestedError },
|
|
@@ -1,6 +1,13 @@
|
|
|
1
1
|
import { type Bufferable, serializeToBuffer } from '@aztec/foundation/serialize';
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import {
|
|
4
|
+
AvmExecutionError,
|
|
5
|
+
AvmParsingError,
|
|
6
|
+
InvalidOpcodeError,
|
|
7
|
+
InvalidProgramCounterError,
|
|
8
|
+
InvalidTagValueError,
|
|
9
|
+
duringInstrFetch,
|
|
10
|
+
} from '../errors.js';
|
|
4
11
|
import {
|
|
5
12
|
Add,
|
|
6
13
|
And,
|
|
@@ -172,7 +179,7 @@ export function decodeInstructionFromBytecode(
|
|
|
172
179
|
instructionSet: InstructionSet = INSTRUCTION_SET,
|
|
173
180
|
): [Instruction, number] {
|
|
174
181
|
if (pc >= bytecode.length) {
|
|
175
|
-
throw new InvalidProgramCounterError(pc, bytecode.length);
|
|
182
|
+
throw new InvalidProgramCounterError(pc, bytecode.length - 1);
|
|
176
183
|
}
|
|
177
184
|
|
|
178
185
|
try {
|
|
@@ -182,7 +189,7 @@ export function decodeInstructionFromBytecode(
|
|
|
182
189
|
|
|
183
190
|
if (opcode > MAX_OPCODE_VALUE) {
|
|
184
191
|
throw new InvalidOpcodeError(
|
|
185
|
-
`Opcode ${opcode} (0x${opcode.toString(16)}) value is not in the range of valid opcodes.`,
|
|
192
|
+
`Opcode ${opcode} (0x${opcode.toString(16)}) value is not in the range of valid opcodes (at PC ${pc}).`,
|
|
186
193
|
);
|
|
187
194
|
}
|
|
188
195
|
|
|
@@ -192,13 +199,17 @@ export function decodeInstructionFromBytecode(
|
|
|
192
199
|
}
|
|
193
200
|
|
|
194
201
|
const instructionDeserializer: InstructionDeserializer = instructionDeserializerOrUndef;
|
|
202
|
+
|
|
195
203
|
const instruction = instructionDeserializer(cursor);
|
|
196
204
|
return [instruction, cursor.position() - startingPosition];
|
|
197
205
|
} catch (error) {
|
|
198
|
-
if (error instanceof
|
|
199
|
-
throw error;
|
|
206
|
+
if (error instanceof InvalidTagValueError || error instanceof InvalidOpcodeError) {
|
|
207
|
+
throw duringInstrFetch(error, pc);
|
|
208
|
+
} else if (error instanceof AvmExecutionError) {
|
|
209
|
+
throw new AvmParsingError(`Instruction parsing error at pc ${pc}: ${error.message}`);
|
|
200
210
|
} else {
|
|
201
|
-
|
|
211
|
+
const msg = error instanceof Error ? `: ${error.message}` : '';
|
|
212
|
+
throw new AvmParsingError(`Instruction fetching error at pc ${pc}${msg}`);
|
|
202
213
|
}
|
|
203
214
|
}
|
|
204
215
|
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
|
+
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
3
|
+
import type { ContractClassPublic, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
4
|
+
|
|
5
|
+
export class ContractsDbCheckpoint {
|
|
6
|
+
private instances: Map<string, ContractInstanceWithAddress> = new Map();
|
|
7
|
+
private classes: Map<string, ContractClassPublic> = new Map();
|
|
8
|
+
private bytecodeCommitments: Map<string, Fr> = new Map();
|
|
9
|
+
|
|
10
|
+
public addInstance(address: AztecAddress, instance: ContractInstanceWithAddress): void {
|
|
11
|
+
this.instances.set(address.toString(), instance);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
public addClass(classId: Fr, contractClass: ContractClassPublic): void {
|
|
15
|
+
this.classes.set(classId.toString(), contractClass);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
public addBytecodeCommitment(classId: Fr, commitment: Fr): void {
|
|
19
|
+
this.bytecodeCommitments.set(classId.toString(), commitment);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
public getInstance(address: AztecAddress): ContractInstanceWithAddress | undefined {
|
|
23
|
+
return this.instances.get(address.toString());
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
public getClass(classId: Fr): ContractClassPublic | undefined {
|
|
27
|
+
return this.classes.get(classId.toString());
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
public getBytecodeCommitment(classId: Fr): Fr | undefined {
|
|
31
|
+
return this.bytecodeCommitments.get(classId.toString());
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
public deepCopy(): ContractsDbCheckpoint {
|
|
35
|
+
const copy = new ContractsDbCheckpoint();
|
|
36
|
+
this.instances.forEach((value, key) => copy.instances.set(key, value));
|
|
37
|
+
this.classes.forEach((value, key) => copy.classes.set(key, value));
|
|
38
|
+
this.bytecodeCommitments.forEach((value, key) => copy.bytecodeCommitments.set(key, value));
|
|
39
|
+
return copy;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Fr } from '@aztec/foundation/
|
|
1
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
2
|
import type { FunctionSelector } from '@aztec/stdlib/abi';
|
|
3
3
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
4
4
|
import type { ContractClassPublic, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
@@ -58,4 +58,19 @@ export interface PublicContractsDBInterface {
|
|
|
58
58
|
* @returns The name of the function or undefined if not found.
|
|
59
59
|
*/
|
|
60
60
|
getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector): Promise<string | undefined>;
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Creates a checkpoint of the current contract state.
|
|
64
|
+
*/
|
|
65
|
+
createCheckpoint(): void;
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Commits the current checkpoint, merging its state with the parent.
|
|
69
|
+
*/
|
|
70
|
+
commitCheckpoint(): void;
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Reverts the current checkpoint, discarding its state.
|
|
74
|
+
*/
|
|
75
|
+
revertCheckpoint(): void;
|
|
61
76
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Fr } from '@aztec/foundation/
|
|
1
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
2
|
import { FunctionSelector } from '@aztec/stdlib/abi';
|
|
3
3
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
4
4
|
|
|
@@ -13,6 +13,38 @@ export async function getPublicFunctionDebugName(
|
|
|
13
13
|
if (!calldata[0]) {
|
|
14
14
|
return `<calldata[0] undefined> (Contract Address: ${contractAddress})`;
|
|
15
15
|
}
|
|
16
|
-
const
|
|
17
|
-
|
|
16
|
+
const fallbackName = `<calldata[0]:${calldata[0].toString()}> (Contract Address: ${contractAddress})`;
|
|
17
|
+
const selector = FunctionSelector.fromFieldOrUndefined(calldata[0]);
|
|
18
|
+
if (!selector) {
|
|
19
|
+
return fallbackName;
|
|
20
|
+
}
|
|
21
|
+
return (await db.getDebugFunctionName(contractAddress, selector)) ?? fallbackName;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Get the function selector and optional debug name for a public function.
|
|
26
|
+
* Returns the selector and name separately, with name only populated if a debug name is available.
|
|
27
|
+
* @param db - The contracts database
|
|
28
|
+
* @param contractAddress - The contract address
|
|
29
|
+
* @param calldata - The calldata (selector is in calldata[0])
|
|
30
|
+
* @returns An object with functionSelector (always if calldata[0] exists) and functionName (only if debug name found)
|
|
31
|
+
*/
|
|
32
|
+
export async function getPublicFunctionSelectorAndName(
|
|
33
|
+
db: PublicContractsDBInterface,
|
|
34
|
+
contractAddress: AztecAddress,
|
|
35
|
+
calldata: Fr[],
|
|
36
|
+
): Promise<{ functionSelector?: FunctionSelector; functionName?: string }> {
|
|
37
|
+
// Public function is dispatched and therefore the target function is passed in the first argument.
|
|
38
|
+
if (!calldata[0]) {
|
|
39
|
+
return {};
|
|
40
|
+
}
|
|
41
|
+
const selector = FunctionSelector.fromFieldOrUndefined(calldata[0]);
|
|
42
|
+
if (!selector) {
|
|
43
|
+
return {};
|
|
44
|
+
}
|
|
45
|
+
const debugName = await db.getDebugFunctionName(contractAddress, selector);
|
|
46
|
+
return {
|
|
47
|
+
functionSelector: selector,
|
|
48
|
+
functionName: debugName ?? undefined,
|
|
49
|
+
};
|
|
18
50
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { RevertCode } from '@aztec/stdlib/avm';
|
|
2
|
+
import type { GasUsed } from '@aztec/stdlib/gas';
|
|
2
3
|
import {
|
|
3
4
|
Attributes,
|
|
4
5
|
type Histogram,
|
|
@@ -6,7 +7,6 @@ import {
|
|
|
6
7
|
type TelemetryClient,
|
|
7
8
|
type Tracer,
|
|
8
9
|
type UpDownCounter,
|
|
9
|
-
ValueType,
|
|
10
10
|
} from '@aztec/telemetry-client';
|
|
11
11
|
|
|
12
12
|
import type { ExecutorMetricsInterface } from './executor_metrics_interface.js';
|
|
@@ -25,52 +25,26 @@ export class ExecutorMetrics implements ExecutorMetricsInterface {
|
|
|
25
25
|
this.tracer = client.getTracer(name);
|
|
26
26
|
const meter = client.getMeter(name);
|
|
27
27
|
|
|
28
|
-
this.fnCount = meter.createUpDownCounter(Metrics.PUBLIC_EXECUTOR_SIMULATION_COUNT
|
|
29
|
-
description: 'Number of functions executed',
|
|
30
|
-
});
|
|
28
|
+
this.fnCount = meter.createUpDownCounter(Metrics.PUBLIC_EXECUTOR_SIMULATION_COUNT);
|
|
31
29
|
|
|
32
|
-
this.fnDuration = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_DURATION
|
|
33
|
-
description: 'How long it takes to execute a function',
|
|
34
|
-
unit: 'ms',
|
|
35
|
-
valueType: ValueType.INT,
|
|
36
|
-
});
|
|
30
|
+
this.fnDuration = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_DURATION);
|
|
37
31
|
|
|
38
|
-
this.manaPerSecond = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_MANA_PER_SECOND
|
|
39
|
-
description: 'Mana used per second',
|
|
40
|
-
unit: 'mana/s',
|
|
41
|
-
valueType: ValueType.INT,
|
|
42
|
-
});
|
|
32
|
+
this.manaPerSecond = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_MANA_PER_SECOND);
|
|
43
33
|
|
|
44
|
-
this.manaUsed = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_MANA_USED
|
|
45
|
-
description: 'Total mana used',
|
|
46
|
-
unit: 'mana',
|
|
47
|
-
valueType: ValueType.INT,
|
|
48
|
-
});
|
|
34
|
+
this.manaUsed = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_MANA_USED);
|
|
49
35
|
|
|
50
|
-
this.totalInstructionsExecuted = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_TOTAL_INSTRUCTIONS
|
|
51
|
-
description: 'Total number of instructions executed',
|
|
52
|
-
unit: '#instructions',
|
|
53
|
-
valueType: ValueType.INT,
|
|
54
|
-
});
|
|
36
|
+
this.totalInstructionsExecuted = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_SIMULATION_TOTAL_INSTRUCTIONS);
|
|
55
37
|
|
|
56
|
-
this.txHashing = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_TX_HASHING
|
|
57
|
-
description: 'Tx hashing time',
|
|
58
|
-
unit: 'ms',
|
|
59
|
-
valueType: ValueType.INT,
|
|
60
|
-
});
|
|
38
|
+
this.txHashing = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_TX_HASHING);
|
|
61
39
|
|
|
62
|
-
this.privateEffectsInsertions = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_PRIVATE_EFFECTS_INSERTION
|
|
63
|
-
description: 'Private effects insertion time',
|
|
64
|
-
unit: 'us',
|
|
65
|
-
valueType: ValueType.INT,
|
|
66
|
-
});
|
|
40
|
+
this.privateEffectsInsertions = meter.createHistogram(Metrics.PUBLIC_EXECUTOR_PRIVATE_EFFECTS_INSERTION);
|
|
67
41
|
}
|
|
68
42
|
|
|
69
43
|
startRecordingTxSimulation(_txLabel: string) {
|
|
70
44
|
// do nothing (unimplemented)
|
|
71
45
|
}
|
|
72
46
|
|
|
73
|
-
stopRecordingTxSimulation(_txLabel: string, _revertedCode?: RevertCode) {
|
|
47
|
+
stopRecordingTxSimulation(_txLabel: string, _gasUsed?: GasUsed, _revertedCode?: RevertCode) {
|
|
74
48
|
// do nothing (unimplemented)
|
|
75
49
|
}
|
|
76
50
|
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import type { RevertCode } from '@aztec/stdlib/avm';
|
|
2
|
+
import type { GasUsed } from '@aztec/stdlib/gas';
|
|
2
3
|
|
|
3
4
|
export interface ExecutorMetricsInterface {
|
|
4
5
|
startRecordingTxSimulation(txLabel: string): void;
|
|
5
|
-
stopRecordingTxSimulation(txLabel: string, revertedCode?: RevertCode): void;
|
|
6
|
+
stopRecordingTxSimulation(txLabel: string, gasUsed?: GasUsed, revertedCode?: RevertCode): void;
|
|
6
7
|
recordEnqueuedCallSimulation(fnName: string, durationMs: number, manaUsed: number, totalInstructions: number): void;
|
|
7
8
|
recordEnqueuedCallSimulationFailure(
|
|
8
9
|
fnName: string,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { GeneratorIndex } from '@aztec/constants';
|
|
2
|
-
import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto';
|
|
3
|
-
import { Fr } from '@aztec/foundation/
|
|
2
|
+
import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
|
|
3
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
4
|
import type { Logger } from '@aztec/foundation/log';
|
|
5
5
|
import { Timer } from '@aztec/foundation/timer';
|
|
6
6
|
import type { ContractArtifact } from '@aztec/stdlib/abi';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Fr } from '@aztec/foundation/
|
|
1
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
2
|
import type { Logger } from '@aztec/foundation/log';
|
|
3
3
|
import { Timer } from '@aztec/foundation/timer';
|
|
4
4
|
import type { ContractArtifact } from '@aztec/stdlib/abi';
|
|
@@ -118,10 +118,10 @@ export async function megaBulkTest(
|
|
|
118
118
|
const argsField2 = [5, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
119
119
|
const argsField3 = [7, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
120
120
|
const argsField4 = [9, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
121
|
-
const argsField5 = [11, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
122
|
-
const argsField6 = [13, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
123
|
-
const argsField7 = [15, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
124
|
-
const argsField8 = [17, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
121
|
+
//const argsField5 = [11, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
122
|
+
//const argsField6 = [13, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
123
|
+
//const argsField7 = [15, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
124
|
+
//const argsField8 = [17, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
125
125
|
const argsU8 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(x => new Fr(x));
|
|
126
126
|
const genArgs = (argsField: Fr[]) => [
|
|
127
127
|
argsField,
|
|
@@ -144,10 +144,10 @@ export async function megaBulkTest(
|
|
|
144
144
|
{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField2) },
|
|
145
145
|
{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField3) },
|
|
146
146
|
{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField4) },
|
|
147
|
-
{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField5) },
|
|
148
|
-
{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField6) },
|
|
149
|
-
{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField7) },
|
|
150
|
-
{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField8) },
|
|
147
|
+
//{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField5) },
|
|
148
|
+
//{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField6) },
|
|
149
|
+
//{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField7) },
|
|
150
|
+
//{ address: avmTestContract.address, fnName: 'bulk_testing', args: genArgs(argsField8) },
|
|
151
151
|
],
|
|
152
152
|
/*teardownCall=*/ undefined,
|
|
153
153
|
/*feePayer*/ undefined,
|