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