@aztec/simulator 0.0.0-test.1 → 0.0.1-commit.5daedc8
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 +6 -0
- package/dest/client.d.ts +6 -4
- package/dest/client.d.ts.map +1 -1
- package/dest/client.js +4 -2
- package/dest/common/errors.d.ts +5 -14
- package/dest/common/errors.d.ts.map +1 -1
- package/dest/common/errors.js +51 -32
- package/dest/common/index.d.ts +1 -2
- package/dest/common/index.d.ts.map +1 -1
- package/dest/common/index.js +0 -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 +12 -6
- package/dest/private/acvm/acvm.d.ts.map +1 -1
- package/dest/private/acvm/acvm.js +10 -16
- package/dest/private/acvm/acvm_types.d.ts +2 -2
- package/dest/private/acvm/acvm_types.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.d.ts +18 -19
- package/dest/private/acvm/deserialize.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.js +31 -23
- package/dest/private/acvm/index.d.ts +1 -2
- package/dest/private/acvm/index.d.ts.map +1 -1
- package/dest/private/acvm/index.js +0 -1
- package/dest/private/acvm/serialize.d.ts +20 -3
- package/dest/private/acvm/serialize.d.ts.map +1 -1
- package/dest/private/acvm/serialize.js +53 -0
- package/dest/private/acvm_native.d.ts +39 -0
- package/dest/private/acvm_native.d.ts.map +1 -0
- package/dest/private/{providers/acvm_native.js → acvm_native.js} +26 -20
- package/dest/private/acvm_wasm.d.ts +15 -0
- package/dest/private/acvm_wasm.d.ts.map +1 -0
- package/dest/private/{providers/acvm_wasm.js → acvm_wasm.js} +22 -19
- package/dest/private/acvm_wasm_with_blobs.d.ts +20 -0
- package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -0
- package/dest/private/acvm_wasm_with_blobs.js +35 -0
- package/dest/private/circuit_recording/circuit_recorder.d.ts +108 -0
- package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/circuit_recorder.js +209 -0
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts +31 -0
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/file_circuit_recorder.js +135 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +5 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.js +9 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +21 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.js +44 -0
- package/dest/private/circuit_simulator.d.ts +35 -0
- package/dest/private/circuit_simulator.d.ts.map +1 -0
- package/dest/private/circuit_simulator.js +43 -0
- package/dest/private/factory.d.ts +12 -0
- package/dest/private/factory.d.ts.map +1 -0
- package/dest/private/{providers/factory.js → factory.js} +2 -2
- package/dest/public/avm/avm_context.d.ts +6 -6
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +5 -3
- package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.js +11 -7
- package/dest/public/avm/avm_execution_environment.d.ts +4 -2
- package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.js +4 -2
- package/dest/public/avm/avm_gas.d.ts +5 -21
- package/dest/public/avm/avm_gas.d.ts.map +1 -1
- package/dest/public/avm/avm_gas.js +27 -35
- package/dest/public/avm/avm_machine_state.d.ts +3 -1
- package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
- package/dest/public/avm/avm_machine_state.js +2 -0
- package/dest/public/avm/avm_memory_types.d.ts +99 -88
- package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
- package/dest/public/avm/avm_memory_types.js +17 -6
- package/dest/public/avm/avm_simulator.d.ts +6 -6
- package/dest/public/avm/avm_simulator.d.ts.map +1 -1
- package/dest/public/avm/avm_simulator.js +23 -35
- package/dest/public/avm/avm_simulator_interface.d.ts +9 -0
- package/dest/public/avm/avm_simulator_interface.d.ts.map +1 -0
- package/dest/public/avm/avm_simulator_interface.js +3 -0
- package/dest/public/avm/errors.d.ts +7 -31
- package/dest/public/avm/errors.d.ts.map +1 -1
- package/dest/public/avm/errors.js +7 -57
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +6 -5
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.js +22 -15
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +7 -5
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/base_avm_simulation_tester.js +37 -14
- package/dest/public/avm/fixtures/initializers.d.ts +42 -0
- package/dest/public/avm/fixtures/initializers.d.ts.map +1 -0
- package/dest/public/avm/fixtures/initializers.js +44 -0
- package/dest/public/avm/fixtures/utils.d.ts +38 -0
- package/dest/public/avm/fixtures/utils.d.ts.map +1 -0
- package/dest/public/avm/fixtures/utils.js +95 -0
- package/dest/public/avm/index.d.ts +1 -3
- package/dest/public/avm/index.d.ts.map +1 -1
- package/dest/public/avm/index.js +0 -2
- package/dest/public/avm/opcodes/accrued_substate.d.ts +3 -3
- package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
- package/dest/public/avm/opcodes/accrued_substate.js +28 -25
- package/dest/public/avm/opcodes/addressing_mode.d.ts +12 -8
- package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
- package/dest/public/avm/opcodes/addressing_mode.js +46 -26
- package/dest/public/avm/opcodes/arithmetic.d.ts +17 -7
- package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
- package/dest/public/avm/opcodes/arithmetic.js +16 -2
- package/dest/public/avm/opcodes/bitwise.d.ts +10 -18
- package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
- package/dest/public/avm/opcodes/bitwise.js +19 -26
- package/dest/public/avm/opcodes/comparators.d.ts +4 -4
- package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
- package/dest/public/avm/opcodes/comparators.js +3 -3
- package/dest/public/avm/opcodes/contract.d.ts +2 -3
- package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
- package/dest/public/avm/opcodes/contract.js +9 -10
- package/dest/public/avm/opcodes/control_flow.d.ts +1 -1
- package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
- package/dest/public/avm/opcodes/control_flow.js +10 -8
- package/dest/public/avm/opcodes/conversion.d.ts +2 -1
- package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
- package/dest/public/avm/opcodes/conversion.js +267 -3
- package/dest/public/avm/opcodes/ec_add.d.ts +2 -2
- package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
- package/dest/public/avm/opcodes/ec_add.js +6 -6
- package/dest/public/avm/opcodes/environment_getters.d.ts +3 -3
- package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
- package/dest/public/avm/opcodes/environment_getters.js +17 -19
- package/dest/public/avm/opcodes/external_calls.d.ts +9 -8
- package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
- package/dest/public/avm/opcodes/external_calls.js +39 -34
- package/dest/public/avm/opcodes/hashing.d.ts +2 -2
- package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
- package/dest/public/avm/opcodes/hashing.js +6 -6
- package/dest/public/avm/opcodes/index.d.ts +1 -1
- package/dest/public/avm/opcodes/instruction.d.ts +15 -11
- package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
- package/dest/public/avm/opcodes/instruction.js +23 -19
- package/dest/public/avm/opcodes/instruction_impl.d.ts +1 -1
- package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.d.ts +6 -6
- package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.js +37 -33
- package/dest/public/avm/opcodes/misc.d.ts +3 -2
- package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
- package/dest/public/avm/opcodes/misc.js +41 -16
- package/dest/public/avm/opcodes/storage.d.ts +3 -3
- package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
- package/dest/public/avm/opcodes/storage.js +7 -5
- package/dest/public/avm/revert_reason.d.ts +18 -0
- package/dest/public/avm/revert_reason.d.ts.map +1 -0
- package/dest/public/avm/revert_reason.js +38 -0
- package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -3
- package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts +3 -7
- package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.js +70 -69
- package/dest/public/avm/serialization/instruction_serialization.d.ts +14 -5
- package/dest/public/avm/serialization/instruction_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/instruction_serialization.js +70 -35
- package/dest/public/avm/test_utils.d.ts +11 -14
- package/dest/public/avm/test_utils.d.ts.map +1 -1
- package/dest/public/avm/test_utils.js +16 -24
- 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 +68 -0
- package/dest/public/db_interfaces.d.ts.map +1 -0
- package/dest/public/db_interfaces.js +3 -0
- package/dest/public/debug_fn_name.d.ts +5 -0
- package/dest/public/debug_fn_name.d.ts.map +1 -0
- package/dest/public/debug_fn_name.js +9 -0
- package/dest/public/executor_metrics.d.ts +12 -4
- package/dest/public/executor_metrics.d.ts.map +1 -1
- package/dest/public/executor_metrics.js +37 -6
- package/dest/public/executor_metrics_interface.d.ts +10 -0
- package/dest/public/executor_metrics_interface.d.ts.map +1 -0
- package/dest/public/executor_metrics_interface.js +1 -0
- package/dest/public/fixtures/amm_test.d.ts +10 -0
- package/dest/public/fixtures/amm_test.d.ts.map +1 -0
- package/dest/public/fixtures/amm_test.js +213 -0
- package/dest/public/fixtures/bulk_test.d.ts +6 -0
- package/dest/public/fixtures/bulk_test.d.ts.map +1 -0
- package/dest/public/fixtures/bulk_test.js +326 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts +12 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tester.js +29 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts +9 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tests.js +109 -0
- package/dest/public/fixtures/index.d.ts +8 -1
- package/dest/public/fixtures/index.d.ts.map +1 -1
- package/dest/public/fixtures/index.js +7 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts +9 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -0
- package/dest/public/fixtures/minimal_public_tx.js +29 -0
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts +35 -14
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
- package/dest/public/fixtures/public_tx_simulation_tester.js +100 -71
- package/dest/public/fixtures/simple_contract_data_source.d.ts +35 -0
- package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -0
- package/dest/public/{avm/fixtures → fixtures}/simple_contract_data_source.js +31 -10
- package/dest/public/fixtures/token_test.d.ts +8 -0
- package/dest/public/fixtures/token_test.d.ts.map +1 -0
- package/dest/public/fixtures/token_test.js +94 -0
- package/dest/public/fixtures/utils.d.ts +17 -4
- package/dest/public/fixtures/utils.d.ts.map +1 -1
- package/dest/public/fixtures/utils.js +100 -58
- package/dest/public/hinting_db_sources.d.ts +78 -0
- package/dest/public/hinting_db_sources.d.ts.map +1 -0
- package/dest/public/hinting_db_sources.js +350 -0
- package/dest/public/index.d.ts +6 -9
- package/dest/public/index.d.ts.map +1 -1
- package/dest/public/index.js +4 -7
- package/dest/public/public_db_sources.d.ts +51 -101
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +219 -192
- package/dest/public/public_errors.d.ts +12 -0
- package/dest/public/public_errors.d.ts.map +1 -0
- package/dest/public/public_errors.js +13 -0
- package/dest/public/public_processor/guarded_merkle_tree.d.ts +49 -0
- package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -0
- package/dest/public/public_processor/guarded_merkle_tree.js +108 -0
- package/dest/public/public_processor/public_processor.d.ts +25 -37
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +154 -111
- package/dest/public/public_processor/public_processor_metrics.d.ts +3 -3
- package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor_metrics.js +1 -1
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +30 -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 +133 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +66 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +210 -0
- package/dest/public/public_tx_simulator/index.d.ts +5 -0
- package/dest/public/public_tx_simulator/index.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/index.js +2 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +31 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +51 -0
- package/dest/public/public_tx_simulator/public_tx_context.d.ts +23 -30
- package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_context.js +71 -91
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +36 -58
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_simulator.js +208 -206
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +9 -0
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.js +1 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +21 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +39 -0
- package/dest/public/side_effect_errors.d.ts +42 -2
- package/dest/public/side_effect_errors.d.ts.map +1 -1
- package/dest/public/side_effect_errors.js +70 -1
- package/dest/public/side_effect_trace.d.ts +21 -67
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +71 -121
- package/dest/public/side_effect_trace_interface.d.ts +12 -24
- package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
- package/dest/public/state_manager/index.d.ts +2 -0
- package/dest/public/state_manager/index.d.ts.map +1 -0
- package/dest/public/state_manager/index.js +1 -0
- package/dest/public/{avm/journal → state_manager}/nullifiers.d.ts +3 -6
- package/dest/public/state_manager/nullifiers.d.ts.map +1 -0
- package/dest/public/{avm/journal → state_manager}/nullifiers.js +3 -8
- package/dest/public/{avm/journal → state_manager}/public_storage.d.ts +3 -3
- package/dest/public/state_manager/public_storage.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.d.ts +159 -0
- package/dest/public/state_manager/state_manager.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.js +392 -0
- package/dest/public/test_executor_metrics.d.ts +55 -0
- package/dest/public/test_executor_metrics.d.ts.map +1 -0
- package/dest/public/test_executor_metrics.js +307 -0
- 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 +3 -5
- package/dest/public/utils.d.ts.map +1 -1
- package/dest/public/utils.js +4 -21
- package/dest/server.d.ts +7 -4
- package/dest/server.d.ts.map +1 -1
- package/dest/server.js +5 -2
- package/dest/testing.d.ts +2 -0
- package/dest/testing.d.ts.map +1 -0
- package/dest/testing.js +1 -0
- package/package.json +39 -33
- package/src/client.ts +5 -3
- package/src/common/errors.ts +79 -44
- package/src/common/index.ts +0 -1
- package/src/private/acvm/acvm.ts +17 -32
- package/src/private/acvm/acvm_types.ts +1 -1
- package/src/private/acvm/deserialize.ts +35 -29
- package/src/private/acvm/index.ts +0 -1
- package/src/private/acvm/serialize.ts +63 -0
- package/src/private/{providers/acvm_native.ts → acvm_native.ts} +47 -24
- package/src/private/acvm_wasm.ts +72 -0
- package/src/private/acvm_wasm_with_blobs.ts +54 -0
- package/src/private/circuit_recording/circuit_recorder.ts +260 -0
- package/src/private/circuit_recording/file_circuit_recorder.ts +158 -0
- package/src/private/circuit_recording/memory_circuit_recorder.ts +11 -0
- package/src/private/circuit_recording/simulator_recorder_wrapper.ts +91 -0
- package/src/private/circuit_simulator.ts +90 -0
- package/src/private/{providers/factory.ts → factory.ts} +6 -6
- package/src/public/avm/avm_context.ts +4 -4
- package/src/public/avm/avm_contract_call_result.ts +17 -5
- package/src/public/avm/avm_execution_environment.ts +8 -1
- package/src/public/avm/avm_gas.ts +23 -35
- package/src/public/avm/avm_machine_state.ts +5 -0
- package/src/public/avm/avm_memory_types.ts +19 -6
- package/src/public/avm/avm_simulator.ts +43 -54
- package/src/public/avm/avm_simulator_interface.ts +8 -0
- package/src/public/avm/errors.ts +8 -77
- package/src/public/avm/fixtures/avm_simulation_tester.ts +32 -21
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +45 -12
- package/src/public/avm/fixtures/initializers.ts +102 -0
- package/src/public/avm/fixtures/utils.ts +150 -0
- package/src/public/avm/index.ts +0 -2
- package/src/public/avm/opcodes/accrued_substate.ts +64 -29
- package/src/public/avm/opcodes/addressing_mode.ts +56 -32
- package/src/public/avm/opcodes/arithmetic.ts +24 -2
- package/src/public/avm/opcodes/bitwise.ts +33 -29
- package/src/public/avm/opcodes/comparators.ts +6 -3
- package/src/public/avm/opcodes/contract.ts +10 -7
- package/src/public/avm/opcodes/control_flow.ts +19 -10
- package/src/public/avm/opcodes/conversion.ts +27 -3
- package/src/public/avm/opcodes/ec_add.ts +9 -6
- package/src/public/avm/opcodes/environment_getters.ts +27 -22
- package/src/public/avm/opcodes/external_calls.ts +61 -29
- package/src/public/avm/opcodes/hashing.ts +28 -8
- package/src/public/avm/opcodes/instruction.ts +31 -21
- package/src/public/avm/opcodes/memory.ts +71 -32
- package/src/public/avm/opcodes/misc.ts +60 -18
- package/src/public/avm/opcodes/storage.ts +22 -6
- package/src/public/avm/revert_reason.ts +55 -0
- package/src/public/avm/serialization/buffer_cursor.ts +4 -1
- package/src/public/avm/serialization/bytecode_serialization.ts +72 -74
- package/src/public/avm/serialization/instruction_serialization.ts +75 -34
- package/src/public/avm/test_utils.ts +24 -41
- package/src/public/contracts_db_checkpoint.ts +41 -0
- package/src/public/db_interfaces.ts +76 -0
- package/src/{common → public}/debug_fn_name.ts +7 -7
- package/src/public/executor_metrics.ts +56 -6
- package/src/public/executor_metrics_interface.ts +15 -0
- package/src/public/fixtures/amm_test.ts +331 -0
- package/src/public/fixtures/bulk_test.ts +169 -0
- package/src/public/fixtures/custom_bytecode_tester.ts +49 -0
- package/src/public/fixtures/custom_bytecode_tests.ts +135 -0
- package/src/public/fixtures/index.ts +7 -0
- package/src/public/fixtures/minimal_public_tx.ts +35 -0
- package/src/public/fixtures/public_tx_simulation_tester.ts +166 -113
- package/src/public/{avm/fixtures → fixtures}/simple_contract_data_source.ts +36 -18
- package/src/public/fixtures/token_test.ts +139 -0
- package/src/public/fixtures/utils.ts +141 -68
- package/src/public/hinting_db_sources.ts +602 -0
- package/src/public/index.ts +5 -8
- package/src/public/public_db_sources.ts +278 -258
- package/src/public/public_errors.ts +14 -0
- package/src/public/public_processor/guarded_merkle_tree.ts +153 -0
- package/src/public/public_processor/public_processor.ts +212 -164
- package/src/public/public_processor/public_processor_metrics.ts +2 -2
- package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +162 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +306 -0
- package/src/public/public_tx_simulator/index.ts +4 -0
- package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +105 -0
- package/src/public/public_tx_simulator/public_tx_context.ts +167 -194
- package/src/public/public_tx_simulator/public_tx_simulator.ts +292 -265
- package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +10 -0
- package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +63 -0
- package/src/public/side_effect_errors.ts +91 -1
- package/src/public/side_effect_trace.ts +94 -320
- package/src/public/side_effect_trace_interface.ts +10 -58
- package/src/public/state_manager/index.ts +1 -0
- package/src/public/{avm/journal → state_manager}/nullifiers.ts +5 -11
- package/src/public/{avm/journal → state_manager}/public_storage.ts +2 -2
- package/src/public/state_manager/state_manager.ts +553 -0
- package/src/public/test_executor_metrics.ts +397 -0
- package/src/public/utils.ts +5 -21
- package/src/server.ts +6 -3
- package/src/testing.ts +1 -0
- package/dest/common/db_interfaces.d.ts +0 -80
- package/dest/common/db_interfaces.d.ts.map +0 -1
- package/dest/common/db_interfaces.js +0 -1
- package/dest/common/debug_fn_name.d.ts +0 -5
- package/dest/common/debug_fn_name.d.ts.map +0 -1
- package/dest/common/debug_fn_name.js +0 -6
- package/dest/common/message_load_oracle_inputs.d.ts +0 -15
- package/dest/common/message_load_oracle_inputs.d.ts.map +0 -1
- package/dest/common/message_load_oracle_inputs.js +0 -15
- package/dest/private/acvm/oracle/index.d.ts +0 -14
- package/dest/private/acvm/oracle/index.d.ts.map +0 -1
- package/dest/private/acvm/oracle/index.js +0 -2
- package/dest/private/acvm/oracle/oracle.d.ts +0 -49
- package/dest/private/acvm/oracle/oracle.d.ts.map +0 -1
- package/dest/private/acvm/oracle/oracle.js +0 -263
- package/dest/private/acvm/oracle/typed_oracle.d.ts +0 -83
- package/dest/private/acvm/oracle/typed_oracle.d.ts.map +0 -1
- package/dest/private/acvm/oracle/typed_oracle.js +0 -132
- package/dest/private/execution_data_provider.d.ts +0 -261
- package/dest/private/execution_data_provider.d.ts.map +0 -1
- package/dest/private/execution_data_provider.js +0 -14
- package/dest/private/execution_note_cache.d.ts +0 -93
- package/dest/private/execution_note_cache.d.ts.map +0 -1
- package/dest/private/execution_note_cache.js +0 -180
- package/dest/private/hashed_values_cache.d.ts +0 -28
- package/dest/private/hashed_values_cache.d.ts.map +0 -1
- package/dest/private/hashed_values_cache.js +0 -46
- package/dest/private/index.d.ts +0 -13
- package/dest/private/index.d.ts.map +0 -1
- package/dest/private/index.js +0 -12
- package/dest/private/pick_notes.d.ts +0 -85
- package/dest/private/pick_notes.d.ts.map +0 -1
- package/dest/private/pick_notes.js +0 -51
- package/dest/private/private_execution.d.ts +0 -25
- package/dest/private/private_execution.d.ts.map +0 -1
- package/dest/private/private_execution.js +0 -92
- package/dest/private/private_execution_oracle.d.ts +0 -215
- package/dest/private/private_execution_oracle.d.ts.map +0 -1
- package/dest/private/private_execution_oracle.js +0 -382
- package/dest/private/providers/acvm_native.d.ts +0 -40
- package/dest/private/providers/acvm_native.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm.d.ts +0 -15
- package/dest/private/providers/acvm_wasm.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm_with_blobs.d.ts +0 -19
- package/dest/private/providers/acvm_wasm_with_blobs.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm_with_blobs.js +0 -32
- package/dest/private/providers/factory.d.ts +0 -12
- package/dest/private/providers/factory.d.ts.map +0 -1
- package/dest/private/providers/simulation_provider.d.ts +0 -19
- package/dest/private/providers/simulation_provider.d.ts.map +0 -1
- package/dest/private/providers/simulation_provider.js +0 -24
- package/dest/private/simulator.d.ts +0 -34
- package/dest/private/simulator.d.ts.map +0 -1
- package/dest/private/simulator.js +0 -76
- package/dest/private/unconstrained_execution.d.ts +0 -10
- package/dest/private/unconstrained_execution.d.ts.map +0 -1
- package/dest/private/unconstrained_execution.js +0 -27
- package/dest/private/unconstrained_execution_oracle.d.ts +0 -161
- package/dest/private/unconstrained_execution_oracle.d.ts.map +0 -1
- package/dest/private/unconstrained_execution_oracle.js +0 -258
- package/dest/public/avm/bytecode_utils.d.ts +0 -5
- package/dest/public/avm/bytecode_utils.d.ts.map +0 -1
- package/dest/public/avm/bytecode_utils.js +0 -17
- package/dest/public/avm/fixtures/index.d.ts +0 -84
- package/dest/public/avm/fixtures/index.d.ts.map +0 -1
- package/dest/public/avm/fixtures/index.js +0 -175
- package/dest/public/avm/fixtures/simple_contract_data_source.d.ts +0 -35
- package/dest/public/avm/fixtures/simple_contract_data_source.d.ts.map +0 -1
- package/dest/public/avm/journal/index.d.ts +0 -2
- package/dest/public/avm/journal/index.d.ts.map +0 -1
- package/dest/public/avm/journal/index.js +0 -1
- package/dest/public/avm/journal/journal.d.ts +0 -209
- package/dest/public/avm/journal/journal.d.ts.map +0 -1
- package/dest/public/avm/journal/journal.js +0 -486
- package/dest/public/avm/journal/nullifiers.d.ts.map +0 -1
- package/dest/public/avm/journal/public_storage.d.ts.map +0 -1
- package/dest/public/bytecode_errors.d.ts +0 -4
- package/dest/public/bytecode_errors.d.ts.map +0 -1
- package/dest/public/bytecode_errors.js +0 -6
- package/dest/public/execution.d.ts +0 -108
- package/dest/public/execution.d.ts.map +0 -1
- package/dest/public/execution.js +0 -9
- 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/dest/test/utils.d.ts +0 -13
- package/dest/test/utils.d.ts.map +0 -1
- package/dest/test/utils.js +0 -22
- package/src/common/db_interfaces.ts +0 -94
- package/src/common/message_load_oracle_inputs.ts +0 -15
- package/src/private/acvm/oracle/index.ts +0 -16
- package/src/private/acvm/oracle/oracle.ts +0 -455
- package/src/private/acvm/oracle/typed_oracle.ts +0 -259
- package/src/private/execution_data_provider.ts +0 -323
- package/src/private/execution_note_cache.ts +0 -217
- package/src/private/hashed_values_cache.ts +0 -55
- package/src/private/index.ts +0 -16
- package/src/private/pick_notes.ts +0 -141
- package/src/private/private_execution.ts +0 -151
- package/src/private/private_execution_oracle.ts +0 -614
- package/src/private/providers/acvm_wasm.ts +0 -63
- package/src/private/providers/acvm_wasm_with_blobs.ts +0 -50
- package/src/private/providers/simulation_provider.ts +0 -45
- package/src/private/simulator.ts +0 -147
- package/src/private/unconstrained_execution.ts +0 -50
- package/src/private/unconstrained_execution_oracle.ts +0 -373
- package/src/public/avm/bytecode_utils.ts +0 -17
- package/src/public/avm/fixtures/index.ts +0 -296
- package/src/public/avm/journal/index.ts +0 -1
- package/src/public/avm/journal/journal.ts +0 -742
- package/src/public/avm/opcodes/.eslintrc.cjs +0 -8
- package/src/public/bytecode_errors.ts +0 -6
- package/src/public/execution.ts +0 -140
- package/src/public/tx_contract_cache.ts +0 -69
- package/src/test/utils.ts +0 -36
- /package/dest/public/{avm/journal → state_manager}/public_storage.js +0 -0
|
@@ -33,8 +33,13 @@ 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);
|
|
37
|
+
|
|
38
|
+
context.machineState.consumeGas(
|
|
39
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
40
|
+
);
|
|
41
|
+
|
|
36
42
|
const operands = [this.srcOffset, this.radixOffset, this.numLimbsOffset, this.outputBitsOffset, this.dstOffset];
|
|
37
|
-
const addressing = Addressing.fromWire(this.indirect, operands.length);
|
|
38
43
|
const [srcOffset, radixOffset, numLimbsOffset, outputBitsOffset, dstOffset] = addressing.resolve(operands, memory);
|
|
39
44
|
|
|
40
45
|
// The radix gadget only takes in a Field
|
|
@@ -44,11 +49,13 @@ export class ToRadixBE extends Instruction {
|
|
|
44
49
|
memory.checkTag(TypeTag.UINT1, outputBitsOffset);
|
|
45
50
|
|
|
46
51
|
const numLimbs = memory.get(numLimbsOffset).toNumber();
|
|
47
|
-
|
|
52
|
+
const radix: bigint = memory.get(radixOffset).toBigInt();
|
|
53
|
+
context.machineState.consumeGas(
|
|
54
|
+
this.dynamicGasCost(Math.max(numLimbs, radix > 256n ? 32 : MODULUS_LIMBS_PER_RADIX[Number(radix)])),
|
|
55
|
+
);
|
|
48
56
|
const outputBits = memory.get(outputBitsOffset).toNumber();
|
|
49
57
|
|
|
50
58
|
let value: bigint = memory.get(srcOffset).toBigInt();
|
|
51
|
-
const radix: bigint = memory.get(radixOffset).toBigInt();
|
|
52
59
|
|
|
53
60
|
if (radix < 2 || radix > 256) {
|
|
54
61
|
throw new InvalidToRadixInputsError(`ToRadixBE instruction's radix should be in range [2,256] (was ${radix}).`);
|
|
@@ -73,8 +80,25 @@ export class ToRadixBE extends Instruction {
|
|
|
73
80
|
value /= radixBN;
|
|
74
81
|
}
|
|
75
82
|
|
|
83
|
+
if (value !== 0n) {
|
|
84
|
+
throw new InvalidToRadixInputsError(`Field failed to decompose in ${numLimbs} limbs.`);
|
|
85
|
+
}
|
|
86
|
+
|
|
76
87
|
const outputType = outputBits != 0 ? Uint1 : Uint8;
|
|
77
88
|
const res = limbArray.map(byte => new outputType(byte));
|
|
78
89
|
memory.setSlice(dstOffset, res);
|
|
79
90
|
}
|
|
80
91
|
}
|
|
92
|
+
|
|
93
|
+
// First two are for radix = 0 and 1, which are invalid, so we have 0 limbs for those cases.
|
|
94
|
+
export const MODULUS_LIMBS_PER_RADIX: number[] = [
|
|
95
|
+
0, 0, 254, 161, 127, 110, 99, 91, 85, 81, 77, 74, 71, 69, 67, 65, 64, 63, 61, 60, 59, 58, 57, 57, 56, 55, 54, 54, 53,
|
|
96
|
+
53, 52, 52, 51, 51, 50, 50, 50, 49, 49, 48, 48, 48, 48, 47, 47, 47, 46, 46, 46, 46, 45, 45, 45, 45, 45, 44, 44, 44,
|
|
97
|
+
44, 44, 43, 43, 43, 43, 43, 43, 42, 42, 42, 42, 42, 42, 42, 41, 41, 41, 41, 41, 41, 41, 41, 41, 40, 40, 40, 40, 40,
|
|
98
|
+
40, 40, 40, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 38, 38, 38, 38, 38, 38, 38, 38, 38, 38, 38, 38, 38,
|
|
99
|
+
37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 36, 36, 36, 36, 36, 36, 36, 36, 36, 36, 36, 36, 36,
|
|
100
|
+
36, 36, 36, 36, 36, 36, 36, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35, 35,
|
|
101
|
+
35, 35, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34, 34,
|
|
102
|
+
34, 34, 34, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
|
|
103
|
+
33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 33, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32,
|
|
104
|
+
];
|
|
@@ -3,6 +3,7 @@ import { Point } from '@aztec/foundation/fields';
|
|
|
3
3
|
|
|
4
4
|
import type { AvmContext } from '../avm_context.js';
|
|
5
5
|
import { Field, TypeTag, Uint1 } from '../avm_memory_types.js';
|
|
6
|
+
import { EcAddPointNotOnCurveError } from '../errors.js';
|
|
6
7
|
import { Opcode, OperandType } from '../serialization/instruction_serialization.js';
|
|
7
8
|
import { Addressing } from './addressing_mode.js';
|
|
8
9
|
import { Instruction } from './instruction.js';
|
|
@@ -39,7 +40,11 @@ export class EcAdd extends Instruction {
|
|
|
39
40
|
|
|
40
41
|
public async execute(context: AvmContext): Promise<void> {
|
|
41
42
|
const memory = context.machineState.memory;
|
|
42
|
-
|
|
43
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
44
|
+
|
|
45
|
+
context.machineState.consumeGas(
|
|
46
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
47
|
+
);
|
|
43
48
|
|
|
44
49
|
const operands = [
|
|
45
50
|
this.p1XOffset,
|
|
@@ -50,7 +55,6 @@ export class EcAdd extends Instruction {
|
|
|
50
55
|
this.p2IsInfiniteOffset,
|
|
51
56
|
this.dstOffset,
|
|
52
57
|
];
|
|
53
|
-
const addressing = Addressing.fromWire(this.indirect, operands.length);
|
|
54
58
|
const [p1XOffset, p1YOffset, p1IsInfiniteOffset, p2XOffset, p2YOffset, p2IsInfiniteOffset, dstOffset] =
|
|
55
59
|
addressing.resolve(operands, memory);
|
|
56
60
|
|
|
@@ -62,7 +66,7 @@ export class EcAdd extends Instruction {
|
|
|
62
66
|
const p1IsInfinite = memory.get(p1IsInfiniteOffset).toNumber() === 1;
|
|
63
67
|
const p1 = new Point(p1X.toFr(), p1Y.toFr(), p1IsInfinite);
|
|
64
68
|
if (!p1.isOnGrumpkin()) {
|
|
65
|
-
throw new
|
|
69
|
+
throw new EcAddPointNotOnCurveError(/*pointIndex=*/ 1, p1);
|
|
66
70
|
}
|
|
67
71
|
|
|
68
72
|
const p2X = memory.get(p2XOffset);
|
|
@@ -71,17 +75,16 @@ export class EcAdd extends Instruction {
|
|
|
71
75
|
const p2IsInfinite = memory.get(p2IsInfiniteOffset).toNumber() === 1;
|
|
72
76
|
const p2 = new Point(p2X.toFr(), p2Y.toFr(), p2IsInfinite);
|
|
73
77
|
if (!p2.isOnGrumpkin()) {
|
|
74
|
-
throw new
|
|
78
|
+
throw new EcAddPointNotOnCurveError(/*pointIndex=*/ 2, p2);
|
|
75
79
|
}
|
|
76
80
|
|
|
77
|
-
const grumpkin = new Grumpkin();
|
|
78
81
|
let dest;
|
|
79
82
|
if (p1IsInfinite) {
|
|
80
83
|
dest = p2;
|
|
81
84
|
} else if (p2IsInfinite) {
|
|
82
85
|
dest = p1;
|
|
83
86
|
} else {
|
|
84
|
-
dest = await
|
|
87
|
+
dest = await Grumpkin.add(p1, p2);
|
|
85
88
|
}
|
|
86
89
|
|
|
87
90
|
// Important to use setSlice() and not set() in the two following statements as
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { AvmContext } from '../avm_context.js';
|
|
2
|
-
import { Field, Uint64 } from '../avm_memory_types.js';
|
|
2
|
+
import { Field, Uint1, Uint32, Uint64, Uint128 } from '../avm_memory_types.js';
|
|
3
3
|
import { InstructionExecutionError } from '../errors.js';
|
|
4
4
|
import { Opcode, OperandType } from '../serialization/instruction_serialization.js';
|
|
5
5
|
import { Addressing } from './addressing_mode.js';
|
|
@@ -13,15 +13,15 @@ export enum EnvironmentVariable {
|
|
|
13
13
|
VERSION,
|
|
14
14
|
BLOCKNUMBER,
|
|
15
15
|
TIMESTAMP,
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
BASEFEEPERL2GAS,
|
|
17
|
+
BASEFEEPERDAGAS,
|
|
18
18
|
ISSTATICCALL,
|
|
19
19
|
L2GASLEFT,
|
|
20
20
|
DAGASLEFT,
|
|
21
21
|
}
|
|
22
22
|
|
|
23
|
-
function getValue(
|
|
24
|
-
switch (
|
|
23
|
+
function getValue(varEnum: EnvironmentVariable, ctx: AvmContext) {
|
|
24
|
+
switch (varEnum) {
|
|
25
25
|
case EnvironmentVariable.ADDRESS:
|
|
26
26
|
return new Field(ctx.environment.address.toField());
|
|
27
27
|
case EnvironmentVariable.SENDER:
|
|
@@ -33,21 +33,21 @@ function getValue(e: EnvironmentVariable, ctx: AvmContext) {
|
|
|
33
33
|
case EnvironmentVariable.VERSION:
|
|
34
34
|
return new Field(ctx.environment.globals.version);
|
|
35
35
|
case EnvironmentVariable.BLOCKNUMBER:
|
|
36
|
-
return new
|
|
36
|
+
return new Uint32(ctx.environment.globals.blockNumber);
|
|
37
37
|
case EnvironmentVariable.TIMESTAMP:
|
|
38
|
-
return new Uint64(ctx.environment.globals.timestamp
|
|
39
|
-
case EnvironmentVariable.
|
|
40
|
-
return new
|
|
41
|
-
case EnvironmentVariable.
|
|
42
|
-
return new
|
|
38
|
+
return new Uint64(ctx.environment.globals.timestamp);
|
|
39
|
+
case EnvironmentVariable.BASEFEEPERL2GAS:
|
|
40
|
+
return new Uint128(ctx.environment.globals.gasFees.feePerL2Gas);
|
|
41
|
+
case EnvironmentVariable.BASEFEEPERDAGAS:
|
|
42
|
+
return new Uint128(ctx.environment.globals.gasFees.feePerDaGas);
|
|
43
43
|
case EnvironmentVariable.ISSTATICCALL:
|
|
44
|
-
return new
|
|
44
|
+
return new Uint1(ctx.environment.isStaticCall ? 1 : 0);
|
|
45
45
|
case EnvironmentVariable.L2GASLEFT:
|
|
46
|
-
return new
|
|
46
|
+
return new Uint32(ctx.machineState.l2GasLeft);
|
|
47
47
|
case EnvironmentVariable.DAGASLEFT:
|
|
48
|
-
return new
|
|
48
|
+
return new Uint32(ctx.machineState.daGasLeft);
|
|
49
49
|
default:
|
|
50
|
-
throw new
|
|
50
|
+
throw new InstructionExecutionError(`Invalid GETENVVAR var enum ${varEnum}`);
|
|
51
51
|
}
|
|
52
52
|
}
|
|
53
53
|
|
|
@@ -61,22 +61,27 @@ export class GetEnvVar extends Instruction {
|
|
|
61
61
|
OperandType.UINT8, // variable enum (immediate)
|
|
62
62
|
];
|
|
63
63
|
|
|
64
|
-
constructor(
|
|
64
|
+
constructor(
|
|
65
|
+
private indirect: number,
|
|
66
|
+
private dstOffset: number,
|
|
67
|
+
private varEnum: number,
|
|
68
|
+
) {
|
|
65
69
|
super();
|
|
66
70
|
}
|
|
67
71
|
|
|
68
72
|
public async execute(context: AvmContext): Promise<void> {
|
|
69
73
|
const memory = context.machineState.memory;
|
|
70
|
-
|
|
74
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
71
75
|
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
76
|
+
context.machineState.consumeGas(
|
|
77
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
78
|
+
);
|
|
75
79
|
|
|
76
80
|
const operands = [this.dstOffset];
|
|
77
|
-
const addressing = Addressing.fromWire(this.indirect, operands.length);
|
|
78
81
|
const [dstOffset] = addressing.resolve(operands, memory);
|
|
79
82
|
|
|
80
|
-
|
|
83
|
+
const value = getValue(this.varEnum as EnvironmentVariable, context);
|
|
84
|
+
|
|
85
|
+
memory.set(dstOffset, value);
|
|
81
86
|
}
|
|
82
87
|
}
|
|
@@ -9,49 +9,57 @@ 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.
|
|
13
|
-
OperandType.UINT16,
|
|
14
|
-
OperandType.UINT16,
|
|
15
|
-
OperandType.UINT16,
|
|
16
|
-
OperandType.UINT16,
|
|
12
|
+
OperandType.UINT16, // Indirect
|
|
13
|
+
OperandType.UINT16, // L2 gas offset
|
|
14
|
+
OperandType.UINT16, // DA gas offset
|
|
15
|
+
OperandType.UINT16, // Address offset
|
|
16
|
+
OperandType.UINT16, // Args offset
|
|
17
|
+
OperandType.UINT16, // Args size offset
|
|
17
18
|
];
|
|
18
19
|
|
|
19
20
|
constructor(
|
|
20
21
|
private indirect: number,
|
|
21
|
-
private
|
|
22
|
+
private l2GasOffset: number,
|
|
23
|
+
private daGasOffset: number,
|
|
22
24
|
private addrOffset: number,
|
|
23
|
-
private argsOffset: number,
|
|
24
25
|
private argsSizeOffset: number,
|
|
26
|
+
private argsOffset: number,
|
|
25
27
|
) {
|
|
26
28
|
super();
|
|
27
29
|
}
|
|
28
30
|
|
|
29
31
|
public async execute(context: AvmContext) {
|
|
30
32
|
const memory = context.machineState.memory;
|
|
31
|
-
const
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
33
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
34
|
+
|
|
35
|
+
context.machineState.consumeGas(
|
|
36
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
const operands = [this.l2GasOffset, this.daGasOffset, this.addrOffset, this.argsSizeOffset, this.argsOffset];
|
|
40
|
+
const [l2GasOffset, daGasOffset, addrOffset, argsSizeOffset, argsOffset] = addressing.resolve(operands, memory);
|
|
41
|
+
|
|
42
|
+
memory.checkTags(TypeTag.UINT32, l2GasOffset);
|
|
43
|
+
memory.checkTags(TypeTag.UINT32, daGasOffset);
|
|
35
44
|
memory.checkTag(TypeTag.FIELD, addrOffset);
|
|
36
45
|
memory.checkTag(TypeTag.UINT32, argsSizeOffset);
|
|
37
46
|
|
|
38
47
|
const calldataSize = memory.get(argsSizeOffset).toNumber();
|
|
39
48
|
const calldata = memory.getSlice(argsOffset, calldataSize).map(f => f.toFr());
|
|
40
|
-
memory.checkTagsRange(TypeTag.FIELD, argsOffset, calldataSize);
|
|
41
49
|
|
|
42
50
|
const callAddress = memory.getAs<Field>(addrOffset);
|
|
43
51
|
// If we are already in a static call, we propagate the environment.
|
|
44
52
|
const callType = context.environment.isStaticCall ? 'STATICCALL' : this.type;
|
|
45
53
|
|
|
46
|
-
//
|
|
47
|
-
context.machineState.consumeGas(this.gasCost(calldataSize));
|
|
48
|
-
// Then we consume the gas allocated for the nested call. The excess will be refunded later.
|
|
54
|
+
// We consume the gas allocated for the nested call. The excess will be refunded later.
|
|
49
55
|
// Gas allocation is capped by the amount of gas left in the current context.
|
|
50
56
|
// We have to do some dancing here because the gas allocation is a field,
|
|
51
57
|
// but in the machine state we track gas as a number.
|
|
52
|
-
const allocatedL2Gas = Number(
|
|
58
|
+
const allocatedL2Gas = Number(
|
|
59
|
+
BigIntMin(memory.get(l2GasOffset).toBigInt(), BigInt(context.machineState.l2GasLeft)),
|
|
60
|
+
);
|
|
53
61
|
const allocatedDaGas = Number(
|
|
54
|
-
BigIntMin(memory.get(
|
|
62
|
+
BigIntMin(memory.get(daGasOffset).toBigInt(), BigInt(context.machineState.daGasLeft)),
|
|
55
63
|
);
|
|
56
64
|
const allocatedGas = { l2Gas: allocatedL2Gas, daGas: allocatedDaGas };
|
|
57
65
|
context.machineState.consumeGas(allocatedGas);
|
|
@@ -70,6 +78,9 @@ abstract class ExternalCall extends Instruction {
|
|
|
70
78
|
// Track the success status directly
|
|
71
79
|
context.machineState.nestedCallSuccess = success;
|
|
72
80
|
|
|
81
|
+
// Account for all instructions executed in the nested call
|
|
82
|
+
context.machineState.instrCounter += nestedCallResults.totalInstructions;
|
|
83
|
+
|
|
73
84
|
// If the nested call reverted, we try to save the reason and the revert data.
|
|
74
85
|
// This will be used by the caller to try to reconstruct the call stack.
|
|
75
86
|
// This is only a heuristic and may not always work. It is intended to work
|
|
@@ -124,15 +135,22 @@ export class SuccessCopy extends Instruction {
|
|
|
124
135
|
OperandType.UINT16, // dstOffset (16-bit)
|
|
125
136
|
];
|
|
126
137
|
|
|
127
|
-
constructor(
|
|
138
|
+
constructor(
|
|
139
|
+
private indirect: number,
|
|
140
|
+
private dstOffset: number,
|
|
141
|
+
) {
|
|
128
142
|
super();
|
|
129
143
|
}
|
|
130
144
|
|
|
131
145
|
public async execute(context: AvmContext): Promise<void> {
|
|
132
146
|
const memory = context.machineState.memory;
|
|
147
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
148
|
+
|
|
149
|
+
context.machineState.consumeGas(
|
|
150
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
151
|
+
);
|
|
133
152
|
|
|
134
153
|
const operands = [this.dstOffset];
|
|
135
|
-
const addressing = Addressing.fromWire(this.indirect, operands.length);
|
|
136
154
|
const [dstOffset] = addressing.resolve(operands, memory);
|
|
137
155
|
|
|
138
156
|
// Use the direct success tracking property
|
|
@@ -154,20 +172,27 @@ export class Return extends Instruction {
|
|
|
154
172
|
OperandType.UINT16,
|
|
155
173
|
];
|
|
156
174
|
|
|
157
|
-
constructor(
|
|
175
|
+
constructor(
|
|
176
|
+
private indirect: number,
|
|
177
|
+
private returnSizeOffset: number,
|
|
178
|
+
private returnOffset: number,
|
|
179
|
+
) {
|
|
158
180
|
super();
|
|
159
181
|
}
|
|
160
182
|
|
|
161
183
|
public async execute(context: AvmContext): Promise<void> {
|
|
162
184
|
const memory = context.machineState.memory;
|
|
185
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
163
186
|
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
187
|
+
context.machineState.consumeGas(
|
|
188
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
189
|
+
);
|
|
190
|
+
|
|
191
|
+
const operands = [this.returnSizeOffset, this.returnOffset];
|
|
192
|
+
const [returnSizeOffset, returnOffset] = addressing.resolve(operands, memory);
|
|
167
193
|
|
|
168
194
|
memory.checkTag(TypeTag.UINT32, returnSizeOffset);
|
|
169
195
|
const returnSize = memory.get(returnSizeOffset).toNumber();
|
|
170
|
-
context.machineState.consumeGas(this.gasCost(returnSize));
|
|
171
196
|
|
|
172
197
|
const output = memory.getSlice(returnOffset, returnSize).map(word => word.toFr());
|
|
173
198
|
|
|
@@ -196,20 +221,27 @@ export class Revert extends Instruction {
|
|
|
196
221
|
OperandType.UINT16,
|
|
197
222
|
];
|
|
198
223
|
|
|
199
|
-
constructor(
|
|
224
|
+
constructor(
|
|
225
|
+
private indirect: number,
|
|
226
|
+
private retSizeOffset: number,
|
|
227
|
+
private returnOffset: number,
|
|
228
|
+
) {
|
|
200
229
|
super();
|
|
201
230
|
}
|
|
202
231
|
|
|
203
232
|
public async execute(context: AvmContext): Promise<void> {
|
|
204
233
|
const memory = context.machineState.memory;
|
|
234
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
235
|
+
|
|
236
|
+
context.machineState.consumeGas(
|
|
237
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
238
|
+
);
|
|
205
239
|
|
|
206
|
-
const operands = [this.
|
|
207
|
-
const
|
|
208
|
-
const [returnOffset, retSizeOffset] = addressing.resolve(operands, memory);
|
|
240
|
+
const operands = [this.retSizeOffset, this.returnOffset];
|
|
241
|
+
const [retSizeOffset, returnOffset] = addressing.resolve(operands, memory);
|
|
209
242
|
|
|
210
243
|
memory.checkTag(TypeTag.UINT32, retSizeOffset);
|
|
211
244
|
const retSize = memory.get(retSizeOffset).toNumber();
|
|
212
|
-
context.machineState.consumeGas(this.gasCost(retSize));
|
|
213
245
|
const output = memory.getSlice(returnOffset, retSize).map(word => word.toFr());
|
|
214
246
|
|
|
215
247
|
context.machineState.revert(output);
|
|
@@ -19,16 +19,24 @@ export class Poseidon2 extends Instruction {
|
|
|
19
19
|
OperandType.UINT16,
|
|
20
20
|
];
|
|
21
21
|
|
|
22
|
-
constructor(
|
|
22
|
+
constructor(
|
|
23
|
+
private indirect: number,
|
|
24
|
+
private inputStateOffset: number,
|
|
25
|
+
private outputStateOffset: number,
|
|
26
|
+
) {
|
|
23
27
|
super();
|
|
24
28
|
}
|
|
25
29
|
|
|
26
30
|
public async execute(context: AvmContext): Promise<void> {
|
|
27
31
|
const memory = context.machineState.memory;
|
|
28
|
-
|
|
32
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
33
|
+
|
|
34
|
+
context.machineState.consumeGas(
|
|
35
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
36
|
+
);
|
|
29
37
|
|
|
30
38
|
const operands = [this.inputStateOffset, this.outputStateOffset];
|
|
31
|
-
|
|
39
|
+
|
|
32
40
|
const [inputOffset, outputOffset] = addressing.resolve(operands, memory);
|
|
33
41
|
|
|
34
42
|
const inputState = memory.getSlice(inputOffset, Poseidon2.stateSize);
|
|
@@ -54,7 +62,11 @@ export class KeccakF1600 extends Instruction {
|
|
|
54
62
|
OperandType.UINT16,
|
|
55
63
|
];
|
|
56
64
|
|
|
57
|
-
constructor(
|
|
65
|
+
constructor(
|
|
66
|
+
private indirect: number,
|
|
67
|
+
private dstOffset: number,
|
|
68
|
+
private inputOffset: number,
|
|
69
|
+
) {
|
|
58
70
|
super();
|
|
59
71
|
}
|
|
60
72
|
|
|
@@ -62,10 +74,14 @@ export class KeccakF1600 extends Instruction {
|
|
|
62
74
|
public async execute(context: AvmContext): Promise<void> {
|
|
63
75
|
const inputSize = 25;
|
|
64
76
|
const memory = context.machineState.memory;
|
|
77
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
78
|
+
|
|
79
|
+
context.machineState.consumeGas(
|
|
80
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
81
|
+
);
|
|
82
|
+
|
|
65
83
|
const operands = [this.dstOffset, this.inputOffset];
|
|
66
|
-
const addressing = Addressing.fromWire(this.indirect, operands.length);
|
|
67
84
|
const [dstOffset, inputOffset] = addressing.resolve(operands, memory);
|
|
68
|
-
context.machineState.consumeGas(this.gasCost());
|
|
69
85
|
|
|
70
86
|
const stateData = memory.getSlice(inputOffset, inputSize).map(word => word.toBigInt());
|
|
71
87
|
memory.checkTagsRange(TypeTag.UINT64, inputOffset, inputSize);
|
|
@@ -104,12 +120,16 @@ export class Sha256Compression extends Instruction {
|
|
|
104
120
|
const INPUTS_SIZE = 16;
|
|
105
121
|
|
|
106
122
|
const memory = context.machineState.memory;
|
|
123
|
+
const addressing = Addressing.fromWire(this.indirect);
|
|
124
|
+
|
|
125
|
+
context.machineState.consumeGas(
|
|
126
|
+
this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()),
|
|
127
|
+
);
|
|
128
|
+
|
|
107
129
|
const operands = [this.outputOffset, this.stateOffset, this.inputsOffset];
|
|
108
|
-
const addressing = Addressing.fromWire(this.indirect, operands.length);
|
|
109
130
|
const [outputOffset, stateOffset, inputsOffset] = addressing.resolve(operands, memory);
|
|
110
131
|
|
|
111
132
|
// Note: size of output is same as size of state
|
|
112
|
-
context.machineState.consumeGas(this.gasCost());
|
|
113
133
|
const inputs = Uint32Array.from(memory.getSlice(inputsOffset, INPUTS_SIZE).map(word => word.toNumber()));
|
|
114
134
|
const state = Uint32Array.from(memory.getSlice(stateOffset, STATE_SIZE).map(word => word.toNumber()));
|
|
115
135
|
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
+
import type { Bufferable } from '@aztec/foundation/serialize';
|
|
2
|
+
|
|
1
3
|
import { strict as assert } from 'assert';
|
|
2
4
|
|
|
3
5
|
import type { AvmContext } from '../avm_context.js';
|
|
4
|
-
import { type Gas, getBaseGasCost, getDynamicGasCost, mulGas, sumGas } from '../avm_gas.js';
|
|
6
|
+
import { type Gas, computeAddressingCost, getBaseGasCost, getDynamicGasCost, mulGas, sumGas } from '../avm_gas.js';
|
|
5
7
|
import type { BufferCursor } from '../serialization/buffer_cursor.js';
|
|
6
|
-
import type { Serializable } from '../serialization/bytecode_serialization.js';
|
|
7
8
|
import { Opcode, type OperandType, deserialize, serializeAs } from '../serialization/instruction_serialization.js';
|
|
8
9
|
|
|
9
10
|
type InstructionConstructor = {
|
|
@@ -35,6 +36,8 @@ export abstract class Instruction {
|
|
|
35
36
|
* @returns Thee string representation.
|
|
36
37
|
*/
|
|
37
38
|
public toString(): string {
|
|
39
|
+
// Note: we could have this be the actual wire opcode if `bytecode_serialization.ts` were to
|
|
40
|
+
// pass it into the class' static `Instruction.as(this, wireFormat)` method.
|
|
38
41
|
let instructionStr = this.constructor.name + ': ';
|
|
39
42
|
// assumes that all properties are flags or operands
|
|
40
43
|
for (const prop of Object.getOwnPropertyNames(this) as (keyof Instruction)[]) {
|
|
@@ -44,19 +47,19 @@ export abstract class Instruction {
|
|
|
44
47
|
}
|
|
45
48
|
|
|
46
49
|
// Default deserialization which uses Class.opcode and Class.wireFormat.
|
|
47
|
-
public static
|
|
50
|
+
public static fromBuffer(
|
|
48
51
|
this: InstructionConstructor & { wireFormat: OperandType[]; as: any },
|
|
49
52
|
buf: BufferCursor | Buffer,
|
|
50
53
|
): Instruction {
|
|
51
|
-
return this.as(this.wireFormat).
|
|
54
|
+
return this.as(this.wireFormat).fromBuffer(buf);
|
|
52
55
|
}
|
|
53
56
|
|
|
54
57
|
// Default serialization which uses Class.opcode and Class.wireFormat.
|
|
55
|
-
public
|
|
58
|
+
public toBuffer(): Buffer {
|
|
56
59
|
const klass = this.constructor as any;
|
|
57
60
|
assert(klass.opcode !== undefined && klass.opcode !== null);
|
|
58
61
|
assert(klass.wireFormat !== undefined && klass.wireFormat !== null);
|
|
59
|
-
return this.as(klass.opcode, klass.wireFormat).
|
|
62
|
+
return this.as(klass.opcode, klass.wireFormat).toBuffer();
|
|
60
63
|
}
|
|
61
64
|
|
|
62
65
|
/**
|
|
@@ -65,8 +68,8 @@ export abstract class Instruction {
|
|
|
65
68
|
* @param wireFormat The wire format of the instruction.
|
|
66
69
|
* @returns The new instruction instance.
|
|
67
70
|
*/
|
|
68
|
-
public as(opcode: Opcode, wireFormat: OperandType[]): Instruction &
|
|
69
|
-
return Object.defineProperty(this, '
|
|
71
|
+
public as(opcode: Opcode, wireFormat: OperandType[]): Instruction & Bufferable {
|
|
72
|
+
return Object.defineProperty(this, 'toBuffer', {
|
|
70
73
|
value: (): Buffer => {
|
|
71
74
|
return serializeAs(wireFormat, opcode, this);
|
|
72
75
|
},
|
|
@@ -82,7 +85,7 @@ export abstract class Instruction {
|
|
|
82
85
|
*/
|
|
83
86
|
public static as(this: InstructionConstructor, wireFormat: OperandType[]) {
|
|
84
87
|
return Object.assign(this, {
|
|
85
|
-
|
|
88
|
+
fromBuffer: (buf: BufferCursor | Buffer): Instruction => {
|
|
86
89
|
const res = deserialize(buf, wireFormat);
|
|
87
90
|
const args = res.slice(1); // Remove opcode.
|
|
88
91
|
return new this(...args);
|
|
@@ -91,13 +94,20 @@ export abstract class Instruction {
|
|
|
91
94
|
}
|
|
92
95
|
|
|
93
96
|
/**
|
|
94
|
-
*
|
|
95
|
-
* @returns
|
|
97
|
+
* Returns the base gas cost for the instruction.
|
|
98
|
+
* @returns The base gas cost.
|
|
96
99
|
*/
|
|
97
|
-
protected
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
100
|
+
protected baseGasCost(indirectOperandsCount: number, relativeOperandsCount: number): Gas {
|
|
101
|
+
return sumGas(getBaseGasCost(this.opcode), computeAddressingCost(indirectOperandsCount, relativeOperandsCount));
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* Computes the dynamic gas cost for the instruction
|
|
106
|
+
* @param dynMultiplier - The multiplier for the dynamic gas cost.
|
|
107
|
+
* @returns The dynamic gas cost.
|
|
108
|
+
*/
|
|
109
|
+
protected dynamicGasCost(dynMultiplier: number = 0): Gas {
|
|
110
|
+
return mulGas(getDynamicGasCost(this.opcode), dynMultiplier);
|
|
101
111
|
}
|
|
102
112
|
|
|
103
113
|
/**
|
|
@@ -106,9 +116,7 @@ export abstract class Instruction {
|
|
|
106
116
|
*/
|
|
107
117
|
public get type(): string {
|
|
108
118
|
const type = 'type' in this.constructor && (this.constructor.type as string);
|
|
109
|
-
|
|
110
|
-
throw new Error(`Instruction class ${this.constructor.name} does not have a static 'type' property defined.`);
|
|
111
|
-
}
|
|
119
|
+
assert(!!type, `Instruction class ${this.constructor.name} does not have a static 'type' property defined.`);
|
|
112
120
|
return type;
|
|
113
121
|
}
|
|
114
122
|
|
|
@@ -118,9 +126,11 @@ export abstract class Instruction {
|
|
|
118
126
|
*/
|
|
119
127
|
public get opcode(): Opcode {
|
|
120
128
|
const opcode = 'opcode' in this.constructor ? (this.constructor.opcode as Opcode) : undefined;
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
129
|
+
assert(
|
|
130
|
+
opcode !== undefined,
|
|
131
|
+
`Instruction class ${this.constructor.name} does not have a static 'opcode' property defined.`,
|
|
132
|
+
);
|
|
133
|
+
assert(Opcode[opcode] !== undefined, `Invalid opcode ${opcode} for instruction class ${this.constructor.name}.`);
|
|
124
134
|
return opcode;
|
|
125
135
|
}
|
|
126
136
|
}
|