@aztec/simulator 0.0.1-commit.d431d1c → 0.0.1-commit.d6f2b3f94

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. package/dest/private/acvm/acvm.d.ts +4 -2
  2. package/dest/private/acvm/acvm.d.ts.map +1 -1
  3. package/dest/private/acvm/acvm.js +4 -3
  4. package/dest/private/acvm_native.d.ts +5 -3
  5. package/dest/private/acvm_native.d.ts.map +1 -1
  6. package/dest/private/acvm_native.js +8 -6
  7. package/dest/private/acvm_wasm.d.ts +4 -3
  8. package/dest/private/acvm_wasm.d.ts.map +1 -1
  9. package/dest/private/acvm_wasm.js +4 -4
  10. package/dest/private/circuit_recording/circuit_recorder.d.ts +4 -3
  11. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
  12. package/dest/private/circuit_recording/circuit_recorder.js +5 -3
  13. package/dest/private/circuit_recording/file_circuit_recorder.d.ts +3 -2
  14. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -1
  15. package/dest/private/circuit_recording/file_circuit_recorder.js +2 -2
  16. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +7 -2
  17. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -1
  18. package/dest/private/circuit_recording/memory_circuit_recorder.js +4 -4
  19. package/dest/private/factory.d.ts +3 -3
  20. package/dest/private/factory.d.ts.map +1 -1
  21. package/dest/private/factory.js +7 -4
  22. package/dest/public/avm/avm_context.d.ts +3 -3
  23. package/dest/public/avm/avm_context.d.ts.map +1 -1
  24. package/dest/public/avm/avm_contract_call_result.d.ts +6 -6
  25. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  26. package/dest/public/avm/avm_contract_call_result.js +3 -3
  27. package/dest/public/avm/avm_execution_environment.d.ts +6 -5
  28. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  29. package/dest/public/avm/avm_machine_state.d.ts +6 -5
  30. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  31. package/dest/public/avm/avm_machine_state.js +3 -2
  32. package/dest/public/avm/avm_memory_types.d.ts +1 -1
  33. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  34. package/dest/public/avm/avm_memory_types.js +3 -0
  35. package/dest/public/avm/avm_simulator.d.ts +3 -2
  36. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  37. package/dest/public/avm/avm_simulator.js +5 -4
  38. package/dest/public/avm/calldata.d.ts +51 -0
  39. package/dest/public/avm/calldata.d.ts.map +1 -0
  40. package/dest/public/avm/calldata.js +63 -0
  41. package/dest/public/avm/fixtures/account_proof_fetcher.d.ts +2 -0
  42. package/dest/public/avm/fixtures/account_proof_fetcher.d.ts.map +1 -0
  43. package/dest/public/avm/fixtures/account_proof_fetcher.js +152 -0
  44. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
  45. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  46. package/dest/public/avm/fixtures/avm_simulation_tester.js +3 -2
  47. package/dest/public/avm/fixtures/initializers.d.ts +1 -1
  48. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
  49. package/dest/public/avm/fixtures/initializers.js +2 -1
  50. package/dest/public/avm/opcodes/accrued_substate.d.ts +3 -4
  51. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  52. package/dest/public/avm/opcodes/accrued_substate.js +12 -12
  53. package/dest/public/avm/opcodes/contract.d.ts +1 -1
  54. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  55. package/dest/public/avm/opcodes/contract.js +4 -4
  56. package/dest/public/avm/opcodes/external_calls.d.ts +1 -1
  57. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  58. package/dest/public/avm/opcodes/external_calls.js +7 -7
  59. package/dest/public/avm/opcodes/memory.js +1 -1
  60. package/dest/public/avm/opcodes/storage.d.ts +13 -12
  61. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  62. package/dest/public/avm/opcodes/storage.js +30 -20
  63. package/dest/public/debug_fn_name.d.ts +4 -4
  64. package/dest/public/debug_fn_name.d.ts.map +1 -1
  65. package/dest/public/debug_fn_name.js +7 -5
  66. package/dest/public/executor_metrics.d.ts +1 -1
  67. package/dest/public/executor_metrics.d.ts.map +1 -1
  68. package/dest/public/executor_metrics.js +7 -2
  69. package/dest/public/fixtures/opcode_spammer.d.ts +3 -4
  70. package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -1
  71. package/dest/public/fixtures/opcode_spammer.js +30 -58
  72. package/dest/public/fuzzing/avm_simulator_bin.js +7 -4
  73. package/dest/public/public_db_sources.d.ts +4 -3
  74. package/dest/public/public_db_sources.d.ts.map +1 -1
  75. package/dest/public/public_db_sources.js +4 -4
  76. package/dest/public/public_processor/public_processor.d.ts +5 -3
  77. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  78. package/dest/public/public_processor/public_processor.js +8 -5
  79. package/dest/public/public_processor/public_processor_metrics.d.ts +2 -2
  80. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  81. package/dest/public/public_processor/public_processor_metrics.js +20 -4
  82. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +3 -2
  83. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -1
  84. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +2 -2
  85. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +5 -5
  86. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
  87. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +8 -8
  88. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +4 -4
  89. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -1
  90. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +5 -5
  91. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +4 -4
  92. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -1
  93. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +6 -6
  94. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +3 -2
  95. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -1
  96. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +2 -2
  97. package/dest/public/public_tx_simulator/factories.d.ts +3 -2
  98. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -1
  99. package/dest/public/public_tx_simulator/factories.js +3 -3
  100. package/dest/public/public_tx_simulator/public_tx_context.d.ts +4 -3
  101. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  102. package/dest/public/public_tx_simulator/public_tx_context.js +8 -8
  103. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +4 -3
  104. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  105. package/dest/public/public_tx_simulator/public_tx_simulator.js +9 -6
  106. package/dest/public/side_effect_trace.d.ts +4 -4
  107. package/dest/public/side_effect_trace.d.ts.map +1 -1
  108. package/dest/public/side_effect_trace.js +3 -3
  109. package/dest/public/state_manager/state_manager.d.ts +10 -4
  110. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  111. package/dest/public/state_manager/state_manager.js +12 -5
  112. package/dest/public/test_executor_metrics.d.ts +3 -2
  113. package/dest/public/test_executor_metrics.d.ts.map +1 -1
  114. package/dest/public/test_executor_metrics.js +2 -2
  115. package/package.json +16 -16
  116. package/src/private/acvm/acvm.ts +4 -3
  117. package/src/private/acvm_native.ts +11 -5
  118. package/src/private/acvm_wasm.ts +7 -3
  119. package/src/private/circuit_recording/circuit_recorder.ts +5 -3
  120. package/src/private/circuit_recording/file_circuit_recorder.ts +7 -2
  121. package/src/private/circuit_recording/memory_circuit_recorder.ts +6 -4
  122. package/src/private/factory.ts +7 -4
  123. package/src/public/avm/avm_context.ts +2 -2
  124. package/src/public/avm/avm_contract_call_result.ts +8 -6
  125. package/src/public/avm/avm_execution_environment.ts +9 -4
  126. package/src/public/avm/avm_machine_state.ts +6 -5
  127. package/src/public/avm/avm_memory_types.ts +4 -0
  128. package/src/public/avm/avm_simulator.ts +8 -5
  129. package/src/public/avm/calldata.ts +100 -0
  130. package/src/public/avm/fixtures/account_proof.json +553 -0
  131. package/src/public/avm/fixtures/account_proof_fetcher.ts +166 -0
  132. package/src/public/avm/fixtures/avm_simulation_tester.ts +8 -2
  133. package/src/public/avm/fixtures/initializers.ts +2 -1
  134. package/src/public/avm/opcodes/accrued_substate.ts +13 -15
  135. package/src/public/avm/opcodes/contract.ts +1 -4
  136. package/src/public/avm/opcodes/external_calls.ts +8 -7
  137. package/src/public/avm/opcodes/memory.ts +1 -1
  138. package/src/public/avm/opcodes/storage.ts +28 -20
  139. package/src/public/debug_fn_name.ts +10 -8
  140. package/src/public/executor_metrics.ts +4 -1
  141. package/src/public/fixtures/opcode_spammer.ts +49 -53
  142. package/src/public/fuzzing/avm_simulator_bin.ts +11 -1
  143. package/src/public/public_db_sources.ts +15 -5
  144. package/src/public/public_processor/public_processor.ts +18 -5
  145. package/src/public/public_processor/public_processor_metrics.ts +10 -4
  146. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +6 -3
  147. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +9 -6
  148. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +6 -4
  149. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +7 -5
  150. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +3 -1
  151. package/src/public/public_tx_simulator/factories.ts +4 -2
  152. package/src/public/public_tx_simulator/public_tx_context.ts +13 -6
  153. package/src/public/public_tx_simulator/public_tx_simulator.ts +14 -5
  154. package/src/public/side_effect_trace.ts +5 -2
  155. package/src/public/state_manager/state_manager.ts +27 -4
  156. package/src/public/test_executor_metrics.ts +3 -3
@@ -1,6 +1,6 @@
1
1
  import { AVM_MAX_PROCESSABLE_L2_GAS } from '@aztec/constants';
2
2
  import { Fr } from '@aztec/foundation/curves/bn254';
3
- import { type Logger, createLogger } from '@aztec/foundation/log';
3
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
4
4
  import { ProtocolContractAddress, ProtocolContractsList } from '@aztec/protocol-contracts';
5
5
  import { computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
6
6
  import { AvmExecutionHints, AvmTxHint, PublicSimulatorConfig, PublicTxEffect, PublicTxResult } from '@aztec/stdlib/avm';
@@ -19,6 +19,7 @@ import {
19
19
  import { strict as assert } from 'assert';
20
20
 
21
21
  import type { AvmFinalizedCallResult } from '../avm/avm_contract_call_result.js';
22
+ import { CallDataArray } from '../avm/calldata.js';
22
23
  import { AvmSimulator } from '../avm/index.js';
23
24
  import { getPublicFunctionDebugName } from '../debug_fn_name.js';
24
25
  import { HintingMerkleWriteOperations, HintingPublicContractsDB } from '../hinting_db_sources.js';
@@ -80,6 +81,7 @@ type ProcessedPhase = {
80
81
  export class PublicTxSimulator implements PublicTxSimulatorInterface {
81
82
  protected log: Logger;
82
83
  protected readonly config: PublicSimulatorConfig;
84
+ protected readonly bindings?: LoggerBindings;
83
85
 
84
86
  constructor(
85
87
  protected merkleTree: MerkleTreeWriteOperations,
@@ -87,9 +89,11 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
87
89
  protected globalVariables: GlobalVariables,
88
90
  config?: Partial<PublicSimulatorConfig>,
89
91
  protected protocolContracts: ProtocolContracts = ProtocolContractsList,
92
+ bindings?: LoggerBindings,
90
93
  ) {
91
94
  this.config = PublicSimulatorConfig.from(config ?? {});
92
- this.log = createLogger(`simulator:public_tx_simulator`);
95
+ this.bindings = bindings;
96
+ this.log = createLogger(`simulator:public_tx_simulator`, bindings);
93
97
  }
94
98
 
95
99
  /**
@@ -118,6 +122,7 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
118
122
  this.globalVariables,
119
123
  this.protocolContracts,
120
124
  this.config.proverId,
125
+ this.bindings,
121
126
  );
122
127
 
123
128
  // This will throw if there is a nullifier collision.
@@ -267,7 +272,7 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
267
272
 
268
273
  const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest);
269
274
 
270
- returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output));
275
+ returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output.bestEffortReadAll()));
271
276
 
272
277
  if (enqueuedCallResult.reverted) {
273
278
  reverted = true;
@@ -297,7 +302,11 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
297
302
  ): Promise<AvmFinalizedCallResult> {
298
303
  const stateManager = context.state.getActiveStateManager();
299
304
  const contractAddress = callRequest.request.contractAddress;
300
- const fnName = await getPublicFunctionDebugName(this.contractsDB, contractAddress, callRequest.calldata);
305
+ const fnName = await getPublicFunctionDebugName(
306
+ this.contractsDB,
307
+ contractAddress,
308
+ new CallDataArray(callRequest.calldata),
309
+ );
301
310
 
302
311
  const allocatedGas = context.getGasLeftAtPhase(phase);
303
312
 
@@ -357,7 +366,7 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
357
366
  transactionFee,
358
367
  this.globalVariables,
359
368
  request.isStaticCall,
360
- calldata,
369
+ new CallDataArray(calldata),
361
370
  allocatedGas,
362
371
  this.config,
363
372
  );
@@ -9,7 +9,7 @@ import {
9
9
  } from '@aztec/constants';
10
10
  import { Fr } from '@aztec/foundation/curves/bn254';
11
11
  import { EthAddress } from '@aztec/foundation/eth-address';
12
- import { type LogLevel, createLogger } from '@aztec/foundation/log';
12
+ import { type LogLevel, type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
13
13
  import { PublicDataUpdateRequest } from '@aztec/stdlib/avm';
14
14
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
15
15
  import { computePublicDataTreeLeafSlot } from '@aztec/stdlib/hash';
@@ -61,7 +61,7 @@ export class SideEffectArrayLengths {
61
61
  * Trace side effects for an enqueued public call's execution.
62
62
  */
63
63
  export class SideEffectTrace implements PublicSideEffectTraceInterface {
64
- public log = createLogger('simulator:side_effect_trace');
64
+ public log: Logger;
65
65
 
66
66
  /** The side effect counter increments with every call to the trace. */
67
67
  private sideEffectCounter: number;
@@ -79,6 +79,7 @@ export class SideEffectTrace implements PublicSideEffectTraceInterface {
79
79
  constructor(
80
80
  /** The counter of this trace's first side effect. */
81
81
  public readonly startSideEffectCounter: number = 0,
82
+ bindings?: LoggerBindings,
82
83
  /** Track parent's (or previous kernel's) lengths so the AVM can properly enforce TX-wide limits,
83
84
  * otherwise the public kernel can fail to prove because TX limits are breached.
84
85
  */
@@ -90,11 +91,13 @@ export class SideEffectTrace implements PublicSideEffectTraceInterface {
90
91
  private debugLogMemoryReads: number = 0,
91
92
  ) {
92
93
  this.sideEffectCounter = startSideEffectCounter;
94
+ this.log = createLogger('simulator:side_effect_trace', bindings);
93
95
  }
94
96
 
95
97
  public fork() {
96
98
  return new SideEffectTrace(
97
99
  this.sideEffectCounter,
100
+ this.log.getBindings(),
98
101
  new SideEffectArrayLengths(
99
102
  this.previousSideEffectArrayLengths.publicDataWrites + this.userPublicDataWritesLength,
100
103
  this.previousSideEffectArrayLengths.protocolPublicDataWrites + this.protocolPublicDataWritesLength,
@@ -2,7 +2,7 @@ import { CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS, MAX_PROTOCOL_CONTRACTS } f
2
2
  import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
3
3
  import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { jsonStringify } from '@aztec/foundation/json-rpc';
5
- import { type LogLevel, createLogger } from '@aztec/foundation/log';
5
+ import { type LogLevel, type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
6
6
  import { ProtocolContractAddress } from '@aztec/protocol-contracts';
7
7
  import { FunctionSelector } from '@aztec/stdlib/abi';
8
8
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
@@ -42,7 +42,7 @@ import { PublicStorage } from './public_storage.js';
42
42
  * Manages merging of successful/reverted child state into current state.
43
43
  */
44
44
  export class PublicPersistableStateManager {
45
- private readonly log = createLogger('simulator:state_manager');
45
+ private readonly log: Logger;
46
46
 
47
47
  /** Make sure a forked state is never merged twice. */
48
48
  private alreadyMergedIntoParent = false;
@@ -56,7 +56,10 @@ export class PublicPersistableStateManager {
56
56
  private readonly doMerkleOperations: boolean = true,
57
57
  private readonly publicStorage: PublicStorage = new PublicStorage(treesDB),
58
58
  private readonly nullifiers: NullifierManager = new NullifierManager(treesDB),
59
- ) {}
59
+ bindings?: LoggerBindings,
60
+ ) {
61
+ this.log = createLogger('simulator:state_manager', bindings);
62
+ }
60
63
 
61
64
  /**
62
65
  * Create a new state manager
@@ -67,8 +70,19 @@ export class PublicPersistableStateManager {
67
70
  trace: PublicSideEffectTraceInterface,
68
71
  firstNullifier: Fr,
69
72
  timestamp: UInt64,
73
+ bindings?: LoggerBindings,
70
74
  ): PublicPersistableStateManager {
71
- return new PublicPersistableStateManager(treesDB, contractsDB, trace, firstNullifier, timestamp);
75
+ return new PublicPersistableStateManager(
76
+ treesDB,
77
+ contractsDB,
78
+ trace,
79
+ firstNullifier,
80
+ timestamp,
81
+ undefined,
82
+ undefined,
83
+ undefined,
84
+ bindings,
85
+ );
72
86
  }
73
87
 
74
88
  /**
@@ -85,6 +99,7 @@ export class PublicPersistableStateManager {
85
99
  this.doMerkleOperations,
86
100
  this.publicStorage.fork(),
87
101
  this.nullifiers.fork(),
102
+ this.log.getBindings(),
88
103
  );
89
104
  }
90
105
 
@@ -233,7 +248,15 @@ export class PublicPersistableStateManager {
233
248
  public async checkNullifierExists(contractAddress: AztecAddress, nullifier: Fr): Promise<boolean> {
234
249
  this.log.trace(`Checking existence of nullifier (address=${contractAddress}, nullifier=${nullifier})`);
235
250
  const siloedNullifier = await siloNullifier(contractAddress, nullifier);
251
+ return this.checkSiloedNullifierExists(siloedNullifier);
252
+ }
236
253
 
254
+ /**
255
+ * Check if a siloed nullifier exists.
256
+ * @param siloedNullifier - the siloed nullifier to check
257
+ * @returns exists - whether the nullifier exists in the nullifier set
258
+ */
259
+ public async checkSiloedNullifierExists(siloedNullifier: Fr): Promise<boolean> {
237
260
  if (this.doMerkleOperations) {
238
261
  const exists = await this.treesDB.checkNullifierExists(siloedNullifier);
239
262
  this.log.trace(`Checked siloed nullifier ${siloedNullifier} (exists=${exists})`);
@@ -1,5 +1,5 @@
1
1
  import { sum } from '@aztec/foundation/collection';
2
- import { type Logger, createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import { Timer } from '@aztec/foundation/timer';
4
4
  import type { RevertCode } from '@aztec/stdlib/avm';
5
5
  import type { GasUsed } from '@aztec/stdlib/gas';
@@ -88,8 +88,8 @@ export class TestExecutorMetrics implements ExecutorMetricsInterface {
88
88
  private currentTxLabel: string | undefined;
89
89
  private txTimer: Timer | undefined;
90
90
 
91
- constructor() {
92
- this.logger = createLogger(`simulator:test_executor_metrics`);
91
+ constructor(bindings?: LoggerBindings) {
92
+ this.logger = createLogger(`simulator:test_executor_metrics`, bindings);
93
93
  }
94
94
 
95
95
  startRecordingTxSimulation(txLabel: string) {