@aztec/simulator 0.46.7 → 0.47.1
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/dest/acvm/acvm.d.ts +1 -1
- package/dest/acvm/acvm.d.ts.map +1 -1
- package/dest/acvm/oracle/oracle.d.ts +4 -4
- package/dest/acvm/oracle/oracle.d.ts.map +1 -1
- package/dest/acvm/oracle/oracle.js +10 -12
- package/dest/acvm/oracle/typed_oracle.d.ts +9 -6
- package/dest/acvm/oracle/typed_oracle.d.ts.map +1 -1
- package/dest/acvm/oracle/typed_oracle.js +3 -3
- package/dest/acvm/serialize.d.ts +0 -11
- package/dest/acvm/serialize.d.ts.map +1 -1
- package/dest/acvm/serialize.js +1 -26
- package/dest/avm/avm_gas.d.ts.map +1 -1
- package/dest/avm/avm_gas.js +5 -1
- package/dest/avm/fixtures/index.d.ts +2 -1
- package/dest/avm/fixtures/index.d.ts.map +1 -1
- package/dest/avm/fixtures/index.js +5 -2
- package/dest/avm/opcodes/commitment.d.ts +16 -0
- package/dest/avm/opcodes/commitment.d.ts.map +1 -0
- package/dest/avm/opcodes/commitment.js +50 -0
- package/dest/avm/opcodes/hashing.d.ts +11 -0
- package/dest/avm/opcodes/hashing.d.ts.map +1 -1
- package/dest/avm/opcodes/hashing.js +42 -3
- package/dest/avm/serialization/bytecode_serialization.d.ts.map +1 -1
- package/dest/avm/serialization/bytecode_serialization.js +7 -2
- package/dest/avm/serialization/instruction_serialization.d.ts +4 -1
- package/dest/avm/serialization/instruction_serialization.d.ts.map +1 -1
- package/dest/avm/serialization/instruction_serialization.js +6 -2
- package/dest/client/client_execution_context.d.ts +17 -12
- package/dest/client/client_execution_context.d.ts.map +1 -1
- package/dest/client/client_execution_context.js +25 -31
- package/dest/client/execution_result.d.ts +12 -6
- package/dest/client/execution_result.d.ts.map +1 -1
- package/dest/client/execution_result.js +21 -8
- package/dest/mocks/fixtures.d.ts +5 -5
- package/dest/mocks/fixtures.d.ts.map +1 -1
- package/dest/mocks/fixtures.js +6 -9
- package/dest/providers/factory.d.ts +12 -0
- package/dest/providers/factory.d.ts.map +1 -0
- package/dest/providers/factory.js +27 -0
- package/dest/providers/index.d.ts +1 -0
- package/dest/providers/index.d.ts.map +1 -1
- package/dest/providers/index.js +2 -1
- package/dest/public/abstract_phase_manager.d.ts +4 -5
- package/dest/public/abstract_phase_manager.d.ts.map +1 -1
- package/dest/public/abstract_phase_manager.js +16 -83
- package/dest/public/execution.d.ts +8 -10
- package/dest/public/execution.d.ts.map +1 -1
- package/dest/public/execution.js +10 -1
- package/dest/public/executor.d.ts +2 -1
- package/dest/public/executor.d.ts.map +1 -1
- package/dest/public/executor.js +3 -3
- package/dest/public/index.d.ts +1 -1
- package/dest/public/index.d.ts.map +1 -1
- package/dest/public/index.js +1 -1
- package/dest/public/public_processor.d.ts +1 -1
- package/dest/public/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor.js +9 -3
- package/dest/public/side_effect_trace.d.ts +1 -0
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +9 -9
- package/package.json +9 -9
- package/src/acvm/acvm.ts +1 -1
- package/src/acvm/oracle/oracle.ts +9 -7
- package/src/acvm/oracle/typed_oracle.ts +6 -10
- package/src/acvm/serialize.ts +0 -29
- package/src/avm/avm_gas.ts +4 -0
- package/src/avm/fixtures/index.ts +5 -1
- package/src/avm/opcodes/commitment.ts +66 -0
- package/src/avm/opcodes/hashing.ts +53 -2
- package/src/avm/serialization/bytecode_serialization.ts +6 -1
- package/src/avm/serialization/instruction_serialization.ts +4 -0
- package/src/client/client_execution_context.ts +34 -38
- package/src/client/execution_result.ts +25 -10
- package/src/mocks/fixtures.ts +13 -11
- package/src/providers/factory.ts +38 -0
- package/src/providers/index.ts +1 -0
- package/src/public/abstract_phase_manager.ts +22 -102
- package/src/public/execution.ts +30 -14
- package/src/public/executor.ts +4 -3
- package/src/public/index.ts +1 -1
- package/src/public/public_processor.ts +8 -5
- package/src/public/side_effect_trace.ts +13 -7
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { UnencryptedFunctionL2Logs, UnencryptedL2Log } from '@aztec/circuit-types';
|
|
1
|
+
import { PublicExecutionRequest, UnencryptedFunctionL2Logs, UnencryptedL2Log } from '@aztec/circuit-types';
|
|
2
2
|
import { AvmContractInstanceHint, AvmExecutionHints, AvmExternalCallHint, AvmKeyValueHint, AztecAddress, CallContext, ContractStorageRead, ContractStorageUpdateRequest, EthAddress, Gas, L2ToL1Message, LogHash, NoteHash, Nullifier, ReadRequest, } from '@aztec/circuits.js';
|
|
3
3
|
import { Fr } from '@aztec/foundation/fields';
|
|
4
4
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
5
5
|
import { createSimulationError } from '../common/errors.js';
|
|
6
|
+
import { resultToPublicCallRequest } from './execution.js';
|
|
6
7
|
export class PublicSideEffectTrace {
|
|
7
8
|
constructor(
|
|
8
9
|
/** The counter of this trace's first side effect. */
|
|
@@ -21,6 +22,7 @@ export class PublicSideEffectTrace {
|
|
|
21
22
|
this.unencryptedLogs = [];
|
|
22
23
|
this.allUnencryptedLogs = [];
|
|
23
24
|
this.unencryptedLogsHashes = [];
|
|
25
|
+
this.publicCallRequests = [];
|
|
24
26
|
this.gotContractInstances = [];
|
|
25
27
|
this.nestedExecutions = [];
|
|
26
28
|
this.sideEffectCounter = startSideEffectCounter;
|
|
@@ -159,6 +161,7 @@ export class PublicSideEffectTrace {
|
|
|
159
161
|
// this function will accept all of the nested's side effects into this instance
|
|
160
162
|
this.nestedExecutions.push(result);
|
|
161
163
|
const gasUsed = new Gas(result.startGasLeft.daGas - result.endGasLeft.daGas, result.startGasLeft.l2Gas - result.endGasLeft.l2Gas);
|
|
164
|
+
this.publicCallRequests.push(resultToPublicCallRequest(result));
|
|
162
165
|
this.avmCircuitHints.externalCalls.items.push(new AvmExternalCallHint(
|
|
163
166
|
/*success=*/ new Fr(result.reverted ? 0 : 1), result.returnValues, gasUsed, result.endSideEffectCounter));
|
|
164
167
|
}
|
|
@@ -205,6 +208,7 @@ export class PublicSideEffectTrace {
|
|
|
205
208
|
unencryptedLogsHashes: this.unencryptedLogsHashes,
|
|
206
209
|
// TODO(dbanks12): process contract instance read requests in public kernel
|
|
207
210
|
//gotContractInstances: this.gotContractInstances,
|
|
211
|
+
publicCallRequests: this.publicCallRequests,
|
|
208
212
|
nestedExecutions: this.nestedExecutions,
|
|
209
213
|
avmCircuitHints: this.avmCircuitHints,
|
|
210
214
|
functionName,
|
|
@@ -222,12 +226,8 @@ function createPublicExecutionRequest(avmEnvironment) {
|
|
|
222
226
|
isDelegateCall: avmEnvironment.isDelegateCall,
|
|
223
227
|
isStaticCall: avmEnvironment.isStaticCall,
|
|
224
228
|
});
|
|
225
|
-
return
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
callContext,
|
|
229
|
-
// execution request does not contain AvmContextInputs prefix
|
|
230
|
-
args: avmEnvironment.getCalldataWithoutPrefix(),
|
|
231
|
-
};
|
|
229
|
+
return new PublicExecutionRequest(avmEnvironment.address, callContext,
|
|
230
|
+
// execution request does not contain AvmContextInputs prefix
|
|
231
|
+
avmEnvironment.getCalldataWithoutPrefix());
|
|
232
232
|
}
|
|
233
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side_effect_trace.js","sourceRoot":"","sources":["../../src/public/side_effect_trace.ts"],"names":[],"mappings":"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"}
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side_effect_trace.js","sourceRoot":"","sources":["../../src/public/side_effect_trace.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/simulator",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.47.1",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
6
|
".": "./dest/index.js",
|
|
@@ -56,14 +56,14 @@
|
|
|
56
56
|
]
|
|
57
57
|
},
|
|
58
58
|
"dependencies": {
|
|
59
|
-
"@aztec/circuit-types": "0.
|
|
60
|
-
"@aztec/circuits.js": "0.
|
|
61
|
-
"@aztec/foundation": "0.
|
|
62
|
-
"@aztec/noir-protocol-circuits-types": "0.
|
|
63
|
-
"@aztec/protocol-contracts": "0.
|
|
64
|
-
"@aztec/telemetry-client": "0.
|
|
65
|
-
"@aztec/types": "0.
|
|
66
|
-
"@aztec/world-state": "0.
|
|
59
|
+
"@aztec/circuit-types": "0.47.1",
|
|
60
|
+
"@aztec/circuits.js": "0.47.1",
|
|
61
|
+
"@aztec/foundation": "0.47.1",
|
|
62
|
+
"@aztec/noir-protocol-circuits-types": "0.47.1",
|
|
63
|
+
"@aztec/protocol-contracts": "0.47.1",
|
|
64
|
+
"@aztec/telemetry-client": "0.47.1",
|
|
65
|
+
"@aztec/types": "0.47.1",
|
|
66
|
+
"@aztec/world-state": "0.47.1",
|
|
67
67
|
"@noir-lang/acvm_js": "portal:../../noir/packages/acvm_js",
|
|
68
68
|
"@noir-lang/types": "portal:../../noir/packages/types",
|
|
69
69
|
"levelup": "^5.1.1",
|
package/src/acvm/acvm.ts
CHANGED
|
@@ -18,7 +18,7 @@ import { type ORACLE_NAMES } from './oracle/index.js';
|
|
|
18
18
|
*/
|
|
19
19
|
type ACIRCallback = Record<
|
|
20
20
|
ORACLE_NAMES,
|
|
21
|
-
(...args: ForeignCallInput[]) => void | ForeignCallOutput | Promise<ForeignCallOutput>
|
|
21
|
+
(...args: ForeignCallInput[]) => void | Promise<void> | ForeignCallOutput | Promise<ForeignCallOutput>
|
|
22
22
|
>;
|
|
23
23
|
|
|
24
24
|
/**
|
|
@@ -6,7 +6,7 @@ import { Fr, Point } from '@aztec/foundation/fields';
|
|
|
6
6
|
|
|
7
7
|
import { type ACVMField } from '../acvm_types.js';
|
|
8
8
|
import { frToBoolean, frToNumber, fromACVMField } from '../deserialize.js';
|
|
9
|
-
import { toACVMField
|
|
9
|
+
import { toACVMField } from '../serialize.js';
|
|
10
10
|
import { type TypedOracle } from './typed_oracle.js';
|
|
11
11
|
|
|
12
12
|
/**
|
|
@@ -340,6 +340,7 @@ export class Oracle {
|
|
|
340
340
|
[ivpkMX]: ACVMField[],
|
|
341
341
|
[ivpkMY]: ACVMField[],
|
|
342
342
|
[ivpkMIsInfinite]: ACVMField[],
|
|
343
|
+
[recipient]: ACVMField[],
|
|
343
344
|
preimage: ACVMField[],
|
|
344
345
|
): ACVMField[] {
|
|
345
346
|
const ovpkM = new Point(fromACVMField(ovpkMX), fromACVMField(ovpkMY), !fromACVMField(ovpkMIsInfinite).isZero());
|
|
@@ -351,6 +352,7 @@ export class Oracle {
|
|
|
351
352
|
Fr.fromString(eventTypeId),
|
|
352
353
|
ovKeys,
|
|
353
354
|
ivpkM,
|
|
355
|
+
AztecAddress.fromString(recipient),
|
|
354
356
|
preimage.map(fromACVMField),
|
|
355
357
|
);
|
|
356
358
|
const bytes: ACVMField[] = [];
|
|
@@ -371,6 +373,7 @@ export class Oracle {
|
|
|
371
373
|
[ivpkMX]: ACVMField[],
|
|
372
374
|
[ivpkMY]: ACVMField[],
|
|
373
375
|
[ivpkMIsInfinite]: ACVMField[],
|
|
376
|
+
[recipient]: ACVMField[],
|
|
374
377
|
preimage: ACVMField[],
|
|
375
378
|
): ACVMField[] {
|
|
376
379
|
const ovpkM = new Point(fromACVMField(ovpkMX), fromACVMField(ovpkMY), !fromACVMField(ovpkMIsInfinite).isZero());
|
|
@@ -382,6 +385,7 @@ export class Oracle {
|
|
|
382
385
|
NoteSelector.fromField(Fr.fromString(noteTypeId)),
|
|
383
386
|
ovKeys,
|
|
384
387
|
ivpkM,
|
|
388
|
+
AztecAddress.fromString(recipient),
|
|
385
389
|
preimage.map(fromACVMField),
|
|
386
390
|
);
|
|
387
391
|
const bytes: ACVMField[] = [];
|
|
@@ -425,7 +429,7 @@ export class Oracle {
|
|
|
425
429
|
[isStaticCall]: ACVMField[],
|
|
426
430
|
[isDelegateCall]: ACVMField[],
|
|
427
431
|
): Promise<ACVMField[]> {
|
|
428
|
-
const
|
|
432
|
+
const { endSideEffectCounter, returnsHash } = await this.typedOracle.callPrivateFunction(
|
|
429
433
|
AztecAddress.fromField(fromACVMField(contractAddress)),
|
|
430
434
|
FunctionSelector.fromField(fromACVMField(functionSelector)),
|
|
431
435
|
fromACVMField(argsHash),
|
|
@@ -433,7 +437,7 @@ export class Oracle {
|
|
|
433
437
|
frToBoolean(fromACVMField(isStaticCall)),
|
|
434
438
|
frToBoolean(fromACVMField(isDelegateCall)),
|
|
435
439
|
);
|
|
436
|
-
return
|
|
440
|
+
return [endSideEffectCounter, returnsHash].map(toACVMField);
|
|
437
441
|
}
|
|
438
442
|
|
|
439
443
|
async callPublicFunction(
|
|
@@ -463,7 +467,7 @@ export class Oracle {
|
|
|
463
467
|
[isStaticCall]: ACVMField[],
|
|
464
468
|
[isDelegateCall]: ACVMField[],
|
|
465
469
|
) {
|
|
466
|
-
|
|
470
|
+
await this.typedOracle.enqueuePublicFunctionCall(
|
|
467
471
|
AztecAddress.fromString(contractAddress),
|
|
468
472
|
FunctionSelector.fromField(fromACVMField(functionSelector)),
|
|
469
473
|
fromACVMField(argsHash),
|
|
@@ -471,7 +475,6 @@ export class Oracle {
|
|
|
471
475
|
frToBoolean(fromACVMField(isStaticCall)),
|
|
472
476
|
frToBoolean(fromACVMField(isDelegateCall)),
|
|
473
477
|
);
|
|
474
|
-
return toAcvmEnqueuePublicFunctionResult(enqueuedRequest);
|
|
475
478
|
}
|
|
476
479
|
|
|
477
480
|
async setPublicTeardownFunctionCall(
|
|
@@ -482,7 +485,7 @@ export class Oracle {
|
|
|
482
485
|
[isStaticCall]: ACVMField[],
|
|
483
486
|
[isDelegateCall]: ACVMField[],
|
|
484
487
|
) {
|
|
485
|
-
|
|
488
|
+
await this.typedOracle.setPublicTeardownFunctionCall(
|
|
486
489
|
AztecAddress.fromString(contractAddress),
|
|
487
490
|
FunctionSelector.fromField(fromACVMField(functionSelector)),
|
|
488
491
|
fromACVMField(argsHash),
|
|
@@ -490,7 +493,6 @@ export class Oracle {
|
|
|
490
493
|
frToBoolean(fromACVMField(isStaticCall)),
|
|
491
494
|
frToBoolean(fromACVMField(isDelegateCall)),
|
|
492
495
|
);
|
|
493
|
-
return toAcvmEnqueuePublicFunctionResult(teardownRequest);
|
|
494
496
|
}
|
|
495
497
|
|
|
496
498
|
aes128Encrypt(input: ACVMField[], initializationVector: ACVMField[], key: ACVMField[]): ACVMField[] {
|
|
@@ -9,13 +9,7 @@ import {
|
|
|
9
9
|
type SiblingPath,
|
|
10
10
|
type UnencryptedL2Log,
|
|
11
11
|
} from '@aztec/circuit-types';
|
|
12
|
-
import {
|
|
13
|
-
type Header,
|
|
14
|
-
type KeyValidationRequest,
|
|
15
|
-
type L1_TO_L2_MSG_TREE_HEIGHT,
|
|
16
|
-
type PrivateCallStackItem,
|
|
17
|
-
type PublicCallRequest,
|
|
18
|
-
} from '@aztec/circuits.js';
|
|
12
|
+
import { type Header, type KeyValidationRequest, type L1_TO_L2_MSG_TREE_HEIGHT } from '@aztec/circuits.js';
|
|
19
13
|
import { type FunctionSelector, type NoteSelector } from '@aztec/foundation/abi';
|
|
20
14
|
import { type AztecAddress } from '@aztec/foundation/aztec-address';
|
|
21
15
|
import { Fr } from '@aztec/foundation/fields';
|
|
@@ -222,6 +216,7 @@ export abstract class TypedOracle {
|
|
|
222
216
|
_eventTypeId: Fr,
|
|
223
217
|
_ovKeys: KeyValidationRequest,
|
|
224
218
|
_ivpkM: PublicKey,
|
|
219
|
+
_recipient: AztecAddress,
|
|
225
220
|
_preimage: Fr[],
|
|
226
221
|
): Buffer {
|
|
227
222
|
throw new OracleMethodNotAvailableError('computeEncryptedEventLog');
|
|
@@ -233,6 +228,7 @@ export abstract class TypedOracle {
|
|
|
233
228
|
_noteTypeId: NoteSelector,
|
|
234
229
|
_ovKeys: KeyValidationRequest,
|
|
235
230
|
_ivpkM: PublicKey,
|
|
231
|
+
_recipient: AztecAddress,
|
|
236
232
|
_preimage: Fr[],
|
|
237
233
|
): Buffer {
|
|
238
234
|
throw new OracleMethodNotAvailableError('computeEncryptedNoteLog');
|
|
@@ -253,7 +249,7 @@ export abstract class TypedOracle {
|
|
|
253
249
|
_sideEffectCounter: number,
|
|
254
250
|
_isStaticCall: boolean,
|
|
255
251
|
_isDelegateCall: boolean,
|
|
256
|
-
): Promise<
|
|
252
|
+
): Promise<{ endSideEffectCounter: Fr; returnsHash: Fr }> {
|
|
257
253
|
throw new OracleMethodNotAvailableError('callPrivateFunction');
|
|
258
254
|
}
|
|
259
255
|
|
|
@@ -275,7 +271,7 @@ export abstract class TypedOracle {
|
|
|
275
271
|
_sideEffectCounter: number,
|
|
276
272
|
_isStaticCall: boolean,
|
|
277
273
|
_isDelegateCall: boolean,
|
|
278
|
-
): Promise<
|
|
274
|
+
): Promise<void> {
|
|
279
275
|
throw new OracleMethodNotAvailableError('enqueuePublicFunctionCall');
|
|
280
276
|
}
|
|
281
277
|
|
|
@@ -286,7 +282,7 @@ export abstract class TypedOracle {
|
|
|
286
282
|
_sideEffectCounter: number,
|
|
287
283
|
_isStaticCall: boolean,
|
|
288
284
|
_isDelegateCall: boolean,
|
|
289
|
-
): Promise<
|
|
285
|
+
): Promise<void> {
|
|
290
286
|
throw new OracleMethodNotAvailableError('setPublicTeardownFunctionCall');
|
|
291
287
|
}
|
|
292
288
|
|
package/src/acvm/serialize.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { ENQUEUE_PUBLIC_FUNCTION_CALL_RETURN_LENGTH, type PublicCallRequest } from '@aztec/circuits.js';
|
|
2
1
|
import { type AztecAddress } from '@aztec/foundation/aztec-address';
|
|
3
2
|
import { type EthAddress } from '@aztec/foundation/eth-address';
|
|
4
3
|
import { Fr } from '@aztec/foundation/fields';
|
|
@@ -40,34 +39,6 @@ export function toACVMField(
|
|
|
40
39
|
return `0x${adaptBufferSize(buffer).toString('hex')}`;
|
|
41
40
|
}
|
|
42
41
|
|
|
43
|
-
// Utilities to write TS classes to ACVM Field arrays
|
|
44
|
-
// In the order that the ACVM expects them
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* Converts a public call stack item with the request for executing a public function to
|
|
48
|
-
* a set of ACVM fields accepted by the enqueue_public_function_call_oracle Aztec.nr function.
|
|
49
|
-
* Note that only the fields related to the request are serialized: those related to the result
|
|
50
|
-
* are empty since this is just an execution request, so we don't send them to the circuit.
|
|
51
|
-
* @param item - The public call stack item to serialize to be passed onto Noir.
|
|
52
|
-
* @returns The fields expected by the enqueue_public_function_call_oracle Aztec.nr function.
|
|
53
|
-
* TODO(#4380): Nuke this and replace it with PublicCallRequest.toFields()
|
|
54
|
-
*/
|
|
55
|
-
export function toAcvmEnqueuePublicFunctionResult(item: PublicCallRequest): ACVMField[] {
|
|
56
|
-
const fields = [
|
|
57
|
-
item.contractAddress.toField(),
|
|
58
|
-
item.functionSelector.toField(),
|
|
59
|
-
...item.callContext.toFields(),
|
|
60
|
-
item.sideEffectCounter,
|
|
61
|
-
item.getArgsHash(),
|
|
62
|
-
];
|
|
63
|
-
if (fields.length !== ENQUEUE_PUBLIC_FUNCTION_CALL_RETURN_LENGTH) {
|
|
64
|
-
throw new Error(
|
|
65
|
-
`Invalid length for EnqueuePublicFunctionResult (got ${fields.length} expected ${ENQUEUE_PUBLIC_FUNCTION_CALL_RETURN_LENGTH})`,
|
|
66
|
-
);
|
|
67
|
-
}
|
|
68
|
-
return fields.map(toACVMField);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
42
|
/**
|
|
72
43
|
* Inserts a list of ACVM fields to a witness.
|
|
73
44
|
* @param witnessStartIndex - The index where to start inserting the fields.
|
package/src/avm/avm_gas.ts
CHANGED
|
@@ -124,8 +124,12 @@ const BaseGasCosts: Record<Opcode, Gas> = {
|
|
|
124
124
|
[Opcode.PEDERSEN]: DefaultBaseGasCost,
|
|
125
125
|
[Opcode.ECADD]: DefaultBaseGasCost,
|
|
126
126
|
[Opcode.MSM]: DefaultBaseGasCost,
|
|
127
|
+
[Opcode.PEDERSENCOMMITMENT]: DefaultBaseGasCost,
|
|
127
128
|
// Conversions
|
|
128
129
|
[Opcode.TORADIXLE]: DefaultBaseGasCost,
|
|
130
|
+
// Other
|
|
131
|
+
[Opcode.SHA256COMPRESSION]: DefaultBaseGasCost,
|
|
132
|
+
[Opcode.KECCAKF1600]: DefaultBaseGasCost,
|
|
129
133
|
};
|
|
130
134
|
|
|
131
135
|
/** Returns the fixed base gas cost for a given opcode. */
|
|
@@ -14,7 +14,7 @@ import { type PublicSideEffectTraceInterface } from '../../public/side_effect_tr
|
|
|
14
14
|
import { AvmContext } from '../avm_context.js';
|
|
15
15
|
import { AvmContextInputs, AvmExecutionEnvironment } from '../avm_execution_environment.js';
|
|
16
16
|
import { AvmMachineState } from '../avm_machine_state.js';
|
|
17
|
-
import { Field, Uint8 } from '../avm_memory_types.js';
|
|
17
|
+
import { Field, Uint8, Uint64 } from '../avm_memory_types.js';
|
|
18
18
|
import { HostStorage } from '../journal/host_storage.js';
|
|
19
19
|
import { AvmPersistableStateManager } from '../journal/journal.js';
|
|
20
20
|
import { NullifierManager } from '../journal/nullifiers.js';
|
|
@@ -135,6 +135,10 @@ export function randomMemoryBytes(length: number): Uint8[] {
|
|
|
135
135
|
return [...Array(length)].map(_ => new Uint8(Math.floor(Math.random() * 255)));
|
|
136
136
|
}
|
|
137
137
|
|
|
138
|
+
export function randomMemoryUint64s(length: number): Uint64[] {
|
|
139
|
+
return [...Array(length)].map(_ => new Uint64(Math.floor(Math.random() * 255)));
|
|
140
|
+
}
|
|
141
|
+
|
|
138
142
|
export function randomMemoryFields(length: number): Field[] {
|
|
139
143
|
return [...Array(length)].map(_ => new Field(Fr.random()));
|
|
140
144
|
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { pedersenCommit } from '@aztec/foundation/crypto';
|
|
2
|
+
|
|
3
|
+
import { type AvmContext } from '../avm_context.js';
|
|
4
|
+
import { Field, TypeTag, Uint8 } from '../avm_memory_types.js';
|
|
5
|
+
import { Opcode, OperandType } from '../serialization/instruction_serialization.js';
|
|
6
|
+
import { Addressing } from './addressing_mode.js';
|
|
7
|
+
import { Instruction } from './instruction.js';
|
|
8
|
+
|
|
9
|
+
export class PedersenCommitment extends Instruction {
|
|
10
|
+
static type: string = 'PEDERSENCOMMITMENT';
|
|
11
|
+
static readonly opcode: Opcode = Opcode.PEDERSENCOMMITMENT;
|
|
12
|
+
|
|
13
|
+
// Informs (de)serialization. See Instruction.deserialize.
|
|
14
|
+
static readonly wireFormat: OperandType[] = [
|
|
15
|
+
OperandType.UINT8 /* Opcode */,
|
|
16
|
+
OperandType.UINT8 /* Indirect */,
|
|
17
|
+
OperandType.UINT32 /* Input Offset*/,
|
|
18
|
+
OperandType.UINT32 /* Dst Offset */,
|
|
19
|
+
OperandType.UINT32 /* Input Size Offset */,
|
|
20
|
+
OperandType.UINT32 /* Generator Index Offset */,
|
|
21
|
+
];
|
|
22
|
+
|
|
23
|
+
constructor(
|
|
24
|
+
private indirect: number,
|
|
25
|
+
private inputOffset: number,
|
|
26
|
+
private outputOffset: number,
|
|
27
|
+
private inputSizeOffset: number,
|
|
28
|
+
private genIndexOffset: number,
|
|
29
|
+
) {
|
|
30
|
+
super();
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
public async execute(context: AvmContext): Promise<void> {
|
|
34
|
+
const memory = context.machineState.memory.track(this.type);
|
|
35
|
+
const [inputOffset, outputOffset, inputSizeOffset, genIndexOffset] = Addressing.fromWire(this.indirect).resolve(
|
|
36
|
+
[this.inputOffset, this.outputOffset, this.inputSizeOffset, this.genIndexOffset],
|
|
37
|
+
memory,
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
const inputSize = memory.get(inputSizeOffset).toNumber();
|
|
41
|
+
memory.checkTag(TypeTag.UINT32, inputSizeOffset);
|
|
42
|
+
|
|
43
|
+
const inputs = memory.getSlice(inputOffset, inputSize);
|
|
44
|
+
memory.checkTagsRange(TypeTag.FIELD, inputOffset, inputSize);
|
|
45
|
+
|
|
46
|
+
// Generator index not used for now since we dont utilise it in the pedersenCommit function
|
|
47
|
+
memory.checkTag(TypeTag.UINT32, genIndexOffset);
|
|
48
|
+
|
|
49
|
+
const memoryOperations = { reads: inputSize + 1, writes: 3, indirect: this.indirect };
|
|
50
|
+
context.machineState.consumeGas(this.gasCost(memoryOperations));
|
|
51
|
+
|
|
52
|
+
const inputBuffer: Buffer[] = inputs.map(input => input.toBuffer());
|
|
53
|
+
// TODO: Add the generate index to the pedersenCommit function
|
|
54
|
+
const commitment = pedersenCommit(inputBuffer).map(f => new Field(f));
|
|
55
|
+
// The function doesnt include a flag if the output point is infinity, come back to this
|
|
56
|
+
// for now we just check if theyre zero - until we know how bb encodes them
|
|
57
|
+
const isInfinity = commitment[0].equals(new Field(0)) && commitment[1].equals(new Field(0));
|
|
58
|
+
|
|
59
|
+
memory.set(outputOffset, commitment[0]); // Field typed
|
|
60
|
+
memory.set(outputOffset + 1, commitment[1]); // Field typed
|
|
61
|
+
memory.set(outputOffset + 2, new Uint8(isInfinity ? 1 : 0)); // U8 typed
|
|
62
|
+
|
|
63
|
+
memory.assert(memoryOperations);
|
|
64
|
+
context.machineState.incrementPc();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import { keccak256, pedersenHash, poseidon2Permutation, sha256 } from '@aztec/foundation/crypto';
|
|
1
|
+
import { keccak256, keccakf1600, pedersenHash, poseidon2Permutation, sha256 } from '@aztec/foundation/crypto';
|
|
2
|
+
|
|
3
|
+
import { strict as assert } from 'assert';
|
|
2
4
|
|
|
3
5
|
import { type AvmContext } from '../avm_context.js';
|
|
4
|
-
import { Field, TypeTag, Uint8 } from '../avm_memory_types.js';
|
|
6
|
+
import { Field, TypeTag, Uint8, Uint64 } from '../avm_memory_types.js';
|
|
5
7
|
import { Opcode, OperandType } from '../serialization/instruction_serialization.js';
|
|
6
8
|
import { Addressing } from './addressing_mode.js';
|
|
7
9
|
import { Instruction } from './instruction.js';
|
|
@@ -94,6 +96,55 @@ export class Keccak extends Instruction {
|
|
|
94
96
|
}
|
|
95
97
|
}
|
|
96
98
|
|
|
99
|
+
export class KeccakF1600 extends Instruction {
|
|
100
|
+
static type: string = 'KECCAKF1600';
|
|
101
|
+
static readonly opcode: Opcode = Opcode.KECCAKF1600;
|
|
102
|
+
|
|
103
|
+
// Informs (de)serialization. See Instruction.deserialize.
|
|
104
|
+
static readonly wireFormat: OperandType[] = [
|
|
105
|
+
OperandType.UINT8,
|
|
106
|
+
OperandType.UINT8,
|
|
107
|
+
OperandType.UINT32,
|
|
108
|
+
OperandType.UINT32,
|
|
109
|
+
OperandType.UINT32,
|
|
110
|
+
];
|
|
111
|
+
|
|
112
|
+
constructor(
|
|
113
|
+
private indirect: number,
|
|
114
|
+
private dstOffset: number,
|
|
115
|
+
private stateOffset: number,
|
|
116
|
+
// This is here for compatibility with the CPP side. Should be removed in both.
|
|
117
|
+
private stateSizeOffset: number,
|
|
118
|
+
) {
|
|
119
|
+
super();
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
// pub fn keccakf1600(input: [u64; 25]) -> [u64; 25]
|
|
123
|
+
public async execute(context: AvmContext): Promise<void> {
|
|
124
|
+
const memory = context.machineState.memory.track(this.type);
|
|
125
|
+
const [dstOffset, stateOffset, stateSizeOffset] = Addressing.fromWire(this.indirect).resolve(
|
|
126
|
+
[this.dstOffset, this.stateOffset, this.stateSizeOffset],
|
|
127
|
+
memory,
|
|
128
|
+
);
|
|
129
|
+
memory.checkTag(TypeTag.UINT32, stateSizeOffset);
|
|
130
|
+
const stateSize = memory.get(stateSizeOffset).toNumber();
|
|
131
|
+
assert(stateSize === 25, 'Invalid state size for keccakf1600');
|
|
132
|
+
const memoryOperations = { reads: stateSize + 1, writes: 25, indirect: this.indirect };
|
|
133
|
+
context.machineState.consumeGas(this.gasCost(memoryOperations));
|
|
134
|
+
|
|
135
|
+
memory.checkTagsRange(TypeTag.UINT64, stateOffset, stateSize);
|
|
136
|
+
|
|
137
|
+
const stateData = memory.getSlice(stateOffset, stateSize).map(word => word.toBigInt());
|
|
138
|
+
const updatedState = keccakf1600(stateData);
|
|
139
|
+
|
|
140
|
+
const res = updatedState.map(word => new Uint64(word));
|
|
141
|
+
memory.setSlice(dstOffset, res);
|
|
142
|
+
|
|
143
|
+
memory.assert(memoryOperations);
|
|
144
|
+
context.machineState.incrementPc();
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
|
|
97
148
|
export class Sha256 extends Instruction {
|
|
98
149
|
static type: string = 'SHA256';
|
|
99
150
|
static readonly opcode: Opcode = Opcode.SHA256;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
+
import { PedersenCommitment } from '../opcodes/commitment.js';
|
|
1
2
|
import { DAGasLeft, L2GasLeft } from '../opcodes/context_getters.js';
|
|
2
3
|
import { EcAdd } from '../opcodes/ec_add.js';
|
|
3
|
-
import { Keccak, Pedersen, Poseidon2, Sha256 } from '../opcodes/hashing.js';
|
|
4
|
+
import { Keccak, KeccakF1600, Pedersen, Poseidon2, Sha256 } from '../opcodes/hashing.js';
|
|
4
5
|
import type { Instruction } from '../opcodes/index.js';
|
|
5
6
|
import {
|
|
6
7
|
Add,
|
|
@@ -146,8 +147,12 @@ const INSTRUCTION_SET = () =>
|
|
|
146
147
|
[Sha256.opcode, Sha256],
|
|
147
148
|
[Pedersen.opcode, Pedersen],
|
|
148
149
|
[MultiScalarMul.opcode, MultiScalarMul],
|
|
150
|
+
[PedersenCommitment.opcode, PedersenCommitment],
|
|
149
151
|
// Conversions
|
|
150
152
|
[ToRadixLE.opcode, ToRadixLE],
|
|
153
|
+
// Future Gadgets -- pending changes in noir
|
|
154
|
+
// SHA256COMPRESSION,
|
|
155
|
+
[KeccakF1600.opcode, KeccakF1600],
|
|
151
156
|
]);
|
|
152
157
|
|
|
153
158
|
interface Serializable {
|
|
@@ -78,8 +78,12 @@ export enum Opcode {
|
|
|
78
78
|
PEDERSEN, // temp - may be removed, but alot of contracts rely on it
|
|
79
79
|
ECADD,
|
|
80
80
|
MSM,
|
|
81
|
+
PEDERSENCOMMITMENT,
|
|
81
82
|
// Conversion
|
|
82
83
|
TORADIXLE,
|
|
84
|
+
// Future Gadgets -- pending changes in noir
|
|
85
|
+
SHA256COMPRESSION,
|
|
86
|
+
KECCAKF1600, // Here for when we eventually support this
|
|
83
87
|
}
|
|
84
88
|
|
|
85
89
|
// Possible types for an instruction's operand in its wire format. (Keep in sync with CPP code.
|