Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

perf(continuations): Improve initializations and reduce redundant computations #429

Merged
merged 158 commits into from
Aug 1, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
158 commits
Select commit Hold shift + click to select a range
a50e2db
[WIP] add account to linked list
4l0n50 May 3, 2024
52dc55d
Add account linked list and some unit tests
4l0n50 May 3, 2024
d242757
Modify tests for insetions and fix bugs
4l0n50 May 6, 2024
4558a38
Fix deletion test
4l0n50 May 6, 2024
c369aa5
[WIP] Getting trie data without leaves
4l0n50 May 7, 2024
ecf0e86
[WIP] changes during the flights
4l0n50 May 22, 2024
65773d8
Fix storage ll error
4l0n50 May 24, 2024
c9e3b4f
Add missing file
4l0n50 May 24, 2024
ba87c79
[WIP] checking consistency between linked list and state trie
4l0n50 May 24, 2024
6fc8c22
[WIP] addr 0x798c6047767c10f653ca157a7f66a592a1d6ca550cae352912be0b07…
4l0n50 May 27, 2024
31a850f
[WIP] add missing nibbles to key
4l0n50 May 27, 2024
d1df4c5
Fix accounts insertions
4l0n50 May 28, 2024
7689629
Check storage reads
4l0n50 May 28, 2024
29b79b1
Add segments to preinitialization
hratoanina May 29, 2024
edfc137
[WIP] Unreasonable offset
4l0n50 May 29, 2024
796087b
[WIP] Erc721 error
4l0n50 May 29, 2024
566ccb5
[WIP] uncomment ll reads
4l0n50 May 29, 2024
12e63ea
[WIP] Fixing iterator
4l0n50 May 30, 2024
c1f47dd
Fix unit tests
4l0n50 May 31, 2024
9a9323d
Fix erc721 error
4l0n50 May 31, 2024
6c93057
mend
4l0n50 May 31, 2024
48d1cfe
Remove debug info
May 31, 2024
c938cad
mend
May 31, 2024
dba0967
[WIP] hashing
4l0n50 Jun 3, 2024
8a386f9
Provide constants non-deterministically
hratoanina Jun 3, 2024
5deb97d
Update journaling
LindaGuiga Jun 4, 2024
fbb216b
Update search_account and read_accounts_linked_lists
LindaGuiga Jun 4, 2024
8c3ac79
Constraint state and storage leaves
Jun 4, 2024
1232b9a
Update slot and account search methods in linked_lists and update rev…
LindaGuiga Jun 4, 2024
5d43ff4
Fix asm
LindaGuiga Jun 5, 2024
bd1215d
Some fixes and debugging
LindaGuiga Jun 7, 2024
c4f410d
Fix hash mismatch
Jun 7, 2024
f650e8a
Fix bug while setting storage payloads
Jun 7, 2024
55255f6
Merge remote-tracking branch 'refs/remotes/origin/linked_lists' into …
Jun 7, 2024
128f614
Add functions for updating final trie
Jun 10, 2024
95e3001
[WIP] eliminating trie call
4l0n50 Jun 11, 2024
660a4f4
[WIP] Fix kexit_data issue
4l0n50 Jun 11, 2024
b9e2307
Merge with journaling branch
4l0n50 Jun 11, 2024
287cddd
Merge with journaling branch
4l0n50 Jun 11, 2024
9915fed
[WIP] set final tries
4l0n50 Jun 11, 2024
9a28eb5
Mutate storage payload on insertions
4l0n50 Jun 12, 2024
09a03b2
Fix deletions in final trie computation
4l0n50 Jun 12, 2024
7661bce
Remove double hashing of the initial state trie
4l0n50 Jun 12, 2024
2b666db
Merge branch 'develop' into linked_lists
Nashtare Jun 12, 2024
a144892
Misc
Nashtare Jun 12, 2024
dbc5a6a
trace_decoder/Cargo.toml
4l0n50 Jun 13, 2024
6bea276
Fix return from read_storage_linked_list_w_addr
Nashtare Jun 13, 2024
7660051
[WIP] debugging unit tests
4l0n50 Jun 13, 2024
67fd5cb
Merge remote-tracking branch 'refs/remotes/origin/linked_lists' into …
4l0n50 Jun 13, 2024
f0068aa
Fix set_payload_storage_extension and bring back final gas check
Nashtare Jun 13, 2024
885fe35
Merge remote-tracking branch 'refs/remotes/origin/linked_lists' into …
4l0n50 Jun 13, 2024
a4c3f91
Fix failing shanghai blocks
4l0n50 Jun 14, 2024
3922c06
Fix run_next_addresses_remove and some revertions
LindaGuiga Jun 21, 2024
24e6e6b
Some journaling fixes
LindaGuiga Jun 24, 2024
4355a51
FIx revert_storage_change and revert_account_created
LindaGuiga Jun 24, 2024
33235a9
Fix delete account
4l0n50 Jun 24, 2024
f54864a
[WIP] fixing LoopCallsDepthThenRevert3_d0g0v0_Shanghai.json
4l0n50 Jun 24, 2024
8945002
Add an overwrite version of account insertion and use it for mpt_inse…
LindaGuiga Jun 25, 2024
87b0c63
Fix final state trie hash mismatch
4l0n50 Jun 25, 2024
ef231c0
Fix insert_new_slot_with_value
LindaGuiga Jun 25, 2024
44e316e
Debugging variedContext_d10g0v0_Shanghai.json
4l0n50 Jun 26, 2024
29ca9df
Fix variedContext_d10g0v0_Shanghai
4l0n50 Jun 26, 2024
bf91f44
[WIP] Fixing vitalikTransactionTestParis_d0g0v0_Shanghai
4l0n50 Jun 26, 2024
c7ac311
Merge with develop
4l0n50 Jun 26, 2024
bc7341d
Merge remote-tracking branch 'origin/develop' into linked_lists
4l0n50 Jun 26, 2024
f34c4ed
Merge remote-tracking branch 'origin/develop' into linked_lists
Nashtare Jun 27, 2024
b83871d
Delete all associated slots when an account is deleted
LindaGuiga Jun 27, 2024
c6fed71
Fix run_next_remove_address_slots
LindaGuiga Jun 27, 2024
268604e
Copy initial accounts and slots
4l0n50 Jun 27, 2024
7e99b14
Fix find condition in run_next_remove_address_slots
LindaGuiga Jun 27, 2024
f769fa6
Fix erc721
4l0n50 Jul 1, 2024
cc71c4b
Deep copy of accounts and slots
4l0n50 Jul 1, 2024
5d4737d
Merge remote-tracking branch 'origin/linked_lists' into linked_lists_…
4l0n50 Jul 2, 2024
8111883
[WIP] Testing evm test suite
4l0n50 Jul 2, 2024
05d75ab
Fix most unit tests and fix revert_account_created
LindaGuiga Jul 2, 2024
f35c2c8
FIx linked list test and a bit of cleanup
LindaGuiga Jul 2, 2024
9bed611
Start merge
LindaGuiga Jul 2, 2024
244c9a8
[WIP] Debugging /stExample/basefeeExample_d0g0v0_Shanghai
4l0n50 Jul 3, 2024
54b360a
Fix merge and add batch sizes to the benchmark
LindaGuiga Jul 3, 2024
da7902b
Fix test_only in zero_bin
LindaGuiga Jul 3, 2024
1f8d853
Merge branch 'develop' into merge-continuations-develop
LindaGuiga Jul 3, 2024
ca490c1
Fix rlp pointers error
4l0n50 Jul 3, 2024
a9dc130
Minor
4l0n50 Jul 3, 2024
c07c4a4
Remove panic
Nashtare Jul 3, 2024
cb93551
Remove outdated counter update in insert_account_with_overwrite
4l0n50 Jul 3, 2024
53708dd
Merge remote-tracking branch 'refs/remotes/origin/linked_lists_late_h…
4l0n50 Jul 4, 2024
c1d8b4c
[WIP] Debugging InitCollisionParis_d2g0v0_Shanghai
4l0n50 Jul 4, 2024
eaddcc1
[WIP] Debugging stCallCodes/callcallcodecallcode_011_SuicideEnd_d0g0v…
4l0n50 Jul 4, 2024
29c23a9
Fix remove_all_slots
LindaGuiga Jul 4, 2024
9c2a58b
Merge Linda's callcallcodecallcode_011_SuicideEnd_d0g0v0_Shanghai
4l0n50 Jul 4, 2024
d1a647e
Merge remote-tracking branch 'refs/remotes/origin/linked_lists_late_h…
4l0n50 Jul 4, 2024
71e3eee
Clean code
4l0n50 Jul 4, 2024
352767f
Fix account code initialize mpts
4l0n50 Jul 4, 2024
a31692a
Apply comments and fix CI.
LindaGuiga Jul 4, 2024
2ce9465
Improve remove_all_slots_loop
LindaGuiga Jul 4, 2024
9d6072b
Fix stack comment
Nashtare Jul 5, 2024
899d471
Misc, faster get_valid_slot_ptr
Nashtare Jul 5, 2024
c9ad38e
[WIP] Debugging erc20
4l0n50 Jul 5, 2024
e4adcb0
Remove counter update and cold_access
Nashtare Jul 5, 2024
5717dbc
Merge branch 'merge-continuations-develop' into linked_lists_continua…
LindaGuiga Jul 5, 2024
bb4e2d2
Fix log_opcode circuit sizes
LindaGuiga Jul 5, 2024
99d0b8a
Fix stack comment and remove ctr update
Nashtare Jul 5, 2024
e59e282
Fix preinitialization
LindaGuiga Jul 8, 2024
ac6f85e
Fix unit tests
4l0n50 Jul 9, 2024
74c55a6
Debugging stShift/shr01_d0g0v0_Shanghai
4l0n50 Jul 10, 2024
6aeb8d3
Fixing shiftSignedCombinations_d0g0v0_Shanghai
4l0n50 Jul 10, 2024
6a10adc
Remove counter assertions from linked_lists tests
LindaGuiga Jul 11, 2024
af1c2c0
Merge branch 'linked_lists' into linked_lists_late_hash
LindaGuiga Jul 11, 2024
e395474
Merge branch 'linked_lists_continuations' into linked_lists_late_hash
LindaGuiga Jul 11, 2024
5074895
Fix preinitialization and start cleanup
LindaGuiga Jul 11, 2024
6e043f9
Fix test_process_receipt
LindaGuiga Jul 11, 2024
09a4967
Merge remote-tracking branch 'origin/feat/continuations' into late_ha…
Nashtare Jul 11, 2024
439b4a0
Fix MPT insert tests
Nashtare Jul 11, 2024
d3dd09a
Add check in mpt_insert tests
LindaGuiga Jul 12, 2024
b9b8c5c
Additional fixes
LindaGuiga Jul 12, 2024
9d994c1
Pass preinitialized_segments when necessary
LindaGuiga Jul 15, 2024
1756b03
Fix all unit tests
LindaGuiga Jul 15, 2024
19aa264
Cleanup
LindaGuiga Jul 16, 2024
e725678
More comments cleanup
LindaGuiga Jul 16, 2024
6436d12
Do not store memory content as vec
Nashtare Jul 13, 2024
dcf0575
Prevent needless conversion
Nashtare Jul 13, 2024
97b21af
Remove needless copy
Nashtare Jul 13, 2024
94a61e7
Remove needless checks
Nashtare Jul 13, 2024
3c915f3
Use tuple_windows instead
Nashtare Jul 13, 2024
526c456
Typo
Nashtare Jul 14, 2024
b992e9e
Remove leftover
Nashtare Jul 16, 2024
d9840d4
Remove unrelated changes
Nashtare Jul 16, 2024
b0c4248
Fix clone_slot
LindaGuiga Jul 16, 2024
80212ae
Remove assert 0 from clone_slot
LindaGuiga Jul 16, 2024
7445d53
Fix next_node_ok_with_value
LindaGuiga Jul 16, 2024
b46da0e
Apply comments and cleanup
LindaGuiga Jul 18, 2024
e01a37a
Start
Nashtare Jul 21, 2024
11febbb
Do not recompute LLs
Nashtare Jul 21, 2024
f828adc
Remove unused preinit
Nashtare Jul 21, 2024
892af9e
Remove useless function
Nashtare Jul 21, 2024
bc7dee6
Rename for consistency
Nashtare Jul 21, 2024
fc7ebb8
Cleanup
Nashtare Jul 21, 2024
c3d0ecf
More cleanup
Nashtare Jul 21, 2024
df1f8ff
Minor
Nashtare Jul 21, 2024
0784620
Lighten up initialization
Nashtare Jul 22, 2024
af334a1
Cleaner
Nashtare Jul 22, 2024
e6ed4e7
Remove is_dummy
Nashtare Jul 22, 2024
7f000a0
Remove dummy run
Nashtare Jul 22, 2024
04ab8f7
Fix next_node_ok_with_value and tiny cleanup
LindaGuiga Jul 22, 2024
8fda5ea
Simplify iterator
Nashtare Jul 22, 2024
5bad446
Tweak
Nashtare Jul 22, 2024
90cb9d1
Start addressing comments
LindaGuiga Jul 23, 2024
2414e6c
Tweak
Nashtare Jul 23, 2024
14467a8
Mighty clippy
Nashtare Jul 23, 2024
64d04fb
Revert num_procs
Nashtare Jul 23, 2024
f92c4eb
Remove unnecessary linked_lists methods and payload_ptr
LindaGuiga Jul 23, 2024
c14fe81
Update .env file
Nashtare Jul 25, 2024
89d77ea
Address comment, bring back txn hashes
Nashtare Jul 25, 2024
b9f9d13
Merge branch 'late_hash_continuations' into perf/ll/init
Nashtare Jul 26, 2024
ca6458d
Apply suggestion
Nashtare Jul 26, 2024
c84b723
Update sizes
Nashtare Jul 27, 2024
1cba6f4
Add explicit panic message
Nashtare Jul 27, 2024
eec56f6
Merge remote-tracking branch 'origin/feat/continuations' into perf/ll…
Nashtare Aug 1, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 9 additions & 9 deletions .env
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
AMQP_URI=amqp://localhost:5672
ARITHMETIC_CIRCUIT_SIZE=16..23
BYTE_PACKING_CIRCUIT_SIZE=9..21
CPU_CIRCUIT_SIZE=12..25
KECCAK_CIRCUIT_SIZE=14..20
KECCAK_SPONGE_CIRCUIT_SIZE=9..15
LOGIC_CIRCUIT_SIZE=12..18
MEMORY_CIRCUIT_SIZE=17..28
MEMORY_BEFORE_CIRCUIT_SIZE=7..23
MEMORY_AFTER_CIRCUIT_SIZE=7..27
ARITHMETIC_CIRCUIT_SIZE=16..21
BYTE_PACKING_CIRCUIT_SIZE=8..21
CPU_CIRCUIT_SIZE=8..21
KECCAK_CIRCUIT_SIZE=4..20
KECCAK_SPONGE_CIRCUIT_SIZE=8..17
LOGIC_CIRCUIT_SIZE=4..21
MEMORY_CIRCUIT_SIZE=17..24
MEMORY_BEFORE_CIRCUIT_SIZE=16..23
MEMORY_AFTER_CIRCUIT_SIZE=7..23
28 changes: 4 additions & 24 deletions evm_arithmetization/src/cpu/kernel/interpreter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,6 @@ pub(crate) struct Interpreter<F: Field> {
pub(crate) clock: usize,
/// Log of the maximal number of CPU cycles in one segment execution.
max_cpu_len_log: Option<usize>,
/// Indicates whethere this is a dummy run.
is_dummy: bool,
}

/// Simulates the CPU execution from `state` until the program counter reaches
Expand Down Expand Up @@ -168,22 +166,6 @@ impl<F: Field> Interpreter<F> {
result
}

/// Returns an instance of `Interpreter` given `GenerationInputs`, and
/// assuming we are initializing with the `KERNEL` code.
pub(crate) fn new_dummy_with_generation_inputs(
initial_offset: usize,
initial_stack: Vec<U256>,
inputs: &GenerationInputs,
) -> Self {
debug_inputs(inputs);

let max_cpu_len = Some(NUM_EXTRA_CYCLES_BEFORE + NUM_EXTRA_CYCLES_AFTER);
let mut result =
Self::new_with_generation_inputs(initial_offset, initial_stack, inputs, max_cpu_len);
result.is_dummy = true;
result
}

pub(crate) fn new(
initial_offset: usize,
initial_stack: Vec<U256>,
Expand All @@ -201,7 +183,6 @@ impl<F: Field> Interpreter<F> {
is_jumpdest_analysis: false,
clock: 0,
max_cpu_len_log,
is_dummy: false,
};
interpreter.generation_state.registers.program_counter = initial_offset;
let initial_stack_len = initial_stack.len();
Expand Down Expand Up @@ -233,7 +214,6 @@ impl<F: Field> Interpreter<F> {
is_jumpdest_analysis: true,
clock: 0,
max_cpu_len_log,
is_dummy: false,
}
}

Expand Down Expand Up @@ -641,10 +621,10 @@ impl<F: Field> State<F> for Interpreter<F> {
memory_state.contexts[ctx_idx] = ctx.clone();
}
}
if self.generation_state.set_preinit {
memory_state.preinitialized_segments =
self.generation_state.memory.preinitialized_segments.clone();
}

memory_state.preinitialized_segments =
self.generation_state.memory.preinitialized_segments.clone();

Some(memory_state)
}

Expand Down
22 changes: 8 additions & 14 deletions evm_arithmetization/src/fixed_recursive_verifier.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,18 +41,16 @@ use starky::stark::Stark;

use crate::all_stark::{all_cross_table_lookups, AllStark, Table, NUM_TABLES};
use crate::cpu::kernel::aggregator::KERNEL;
use crate::generation::GenerationInputs;
use crate::generation::{GenerationInputs, TrimmedGenerationInputs};
use crate::get_challenges::observe_public_values_target;
use crate::memory::segments::Segment;
use crate::proof::{
AllProof, BlockHashesTarget, BlockMetadataTarget, ExtraBlockData, ExtraBlockDataTarget,
FinalPublicValues, MemCapTarget, PublicValues, PublicValuesTarget, RegistersDataTarget,
TrieRoots, TrieRootsTarget, TARGET_HASH_SIZE,
};
use crate::prover::{
check_abort_signal, generate_all_data_segments, prove, GenerationSegmentData,
SegmentDataIterator,
};
use crate::prover::testing::prove_all_segments;
use crate::prover::{check_abort_signal, prove, GenerationSegmentData, SegmentDataIterator};
use crate::recursive_verifier::{
add_common_recursion_gates, add_virtual_public_values, get_memory_extra_looking_sum_circuit,
recursive_stark_circuit, set_public_value_targets, PlonkWrapperCircuit, PublicInputs,
Expand Down Expand Up @@ -1485,7 +1483,7 @@ where
&self,
all_stark: &AllStark<F, D>,
config: &StarkConfig,
generation_inputs: GenerationInputs,
generation_inputs: TrimmedGenerationInputs,
segment_data: &mut GenerationSegmentData,
timing: &mut TimingTree,
abort_signal: Option<Arc<AtomicBool>>,
Expand Down Expand Up @@ -1563,20 +1561,16 @@ where
timing: &mut TimingTree,
abort_signal: Option<Arc<AtomicBool>>,
) -> anyhow::Result<Vec<ProverOutputData<F, C, D>>> {
println!("Entering prove all segments");
let mut it_segment_data = SegmentDataIterator {
inputs: &generation_inputs,
partial_next_data: None,
max_cpu_len_log: Some(max_cpu_len_log),
};
let mut segment_iterator =
SegmentDataIterator::<F>::new(&generation_inputs, Some(max_cpu_len_log));

let mut proofs = vec![];

for mut next_data in it_segment_data {
for mut next_data in segment_iterator {
let proof = self.prove_segment(
all_stark,
config,
generation_inputs.clone(),
generation_inputs.trim(),
&mut next_data.1,
timing,
abort_signal.clone(),
Expand Down
85 changes: 43 additions & 42 deletions evm_arithmetization/src/generation/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ use std::collections::HashMap;

use anyhow::anyhow;
use ethereum_types::{Address, BigEndianHash, H256, U256};
use keccak_hash::keccak;
use log::log_enabled;
use mpt_trie::partial_trie::{HashedPartialTrie, PartialTrie};
use plonky2::field::extension::Extendable;
Expand Down Expand Up @@ -94,40 +95,43 @@ pub struct GenerationInputs {
/// A lighter version of [`GenerationInputs`], which have been trimmed
/// post pre-initialization processing.
#[derive(Clone, Debug, Deserialize, Serialize, Default)]
pub(crate) struct TrimmedGenerationInputs {
pub(crate) trimmed_tries: TrimmedTrieInputs,
/// The index of the transaction being proven within its block.
pub(crate) txn_number_before: U256,
pub struct TrimmedGenerationInputs {
pub trimmed_tries: TrimmedTrieInputs,
/// The index of the first transaction in this payload being proven within
/// its block.
pub txn_number_before: U256,
/// The cumulative gas used through the execution of all transactions prior
/// the current one.
pub(crate) gas_used_before: U256,
/// The cumulative gas used after the execution of the current transaction.
/// The exact gas used by the current transaction is `gas_used_after` -
/// `gas_used_before`.
pub(crate) gas_used_after: U256,
/// the current ones.
pub gas_used_before: U256,
/// The cumulative gas used after the execution of the current batch of
/// transactions. The exact gas used by the current batch of transactions
/// is `gas_used_after` - `gas_used_before`.
pub gas_used_after: U256,

/// Indicates whether there is an actual transaction or a dummy payload.
pub(crate) txns_len: usize,
/// The list of txn hashes contained in this batch.
pub txn_hashes: Vec<H256>,

/// Expected trie roots after the transactions are executed.
pub(crate) trie_roots_after: TrieRoots,
/// Expected trie roots before these transactions are executed.
pub trie_roots_before: TrieRoots,
/// Expected trie roots after these transactions are executed.
pub trie_roots_after: TrieRoots,

/// State trie root of the checkpoint block.
/// This could always be the genesis block of the chain, but it allows a
/// prover to continue proving blocks from certain checkpoint heights
/// without requiring proofs for blocks past this checkpoint.
pub(crate) checkpoint_state_trie_root: H256,
pub checkpoint_state_trie_root: H256,

/// Mapping between smart contract code hashes and the contract byte code.
/// All account smart contracts that are invoked will have an entry present.
pub(crate) contract_code: HashMap<H256, Vec<u8>>,
pub contract_code: HashMap<H256, Vec<u8>>,

/// Information contained in the block header.
pub(crate) block_metadata: BlockMetadata,
pub block_metadata: BlockMetadata,

/// The hash of the current block, and a list of the 256 previous block
/// hashes.
pub(crate) block_hashes: BlockHashes,
pub block_hashes: BlockHashes,
}

#[derive(Clone, Debug, Deserialize, Serialize, Default)]
Expand Down Expand Up @@ -178,12 +182,23 @@ impl GenerationInputs {
/// the fields that have already been processed during pre-initialization,
/// namely: the input tries, the signed transaction, and the withdrawals.
pub(crate) fn trim(&self) -> TrimmedGenerationInputs {
let txn_hashes = self
.signed_txns
.iter()
.map(|tx_bytes| keccak(&tx_bytes[..]))
.collect();

TrimmedGenerationInputs {
trimmed_tries: self.tries.trim(),
txn_number_before: self.txn_number_before,
gas_used_before: self.gas_used_before,
gas_used_after: self.gas_used_after,
txns_len: self.signed_txns.len(),
txn_hashes,
trie_roots_before: TrieRoots {
state_root: self.tries.state_trie.hash(),
transactions_root: self.tries.transactions_trie.hash(),
receipts_root: self.tries.receipts_trie.hash(),
},
trie_roots_after: self.trie_roots_after.clone(),
checkpoint_state_trie_root: self.checkpoint_state_trie_root,
contract_code: self.contract_code.clone(),
Expand All @@ -195,12 +210,11 @@ impl GenerationInputs {

fn apply_metadata_and_tries_memops<F: RichField + Extendable<D>, const D: usize>(
state: &mut GenerationState<F>,
inputs: &GenerationInputs,
inputs: &TrimmedGenerationInputs,
registers_before: &RegistersData,
registers_after: &RegistersData,
) {
let metadata = &inputs.block_metadata;
let tries = &inputs.tries;
let trie_roots_after = &inputs.trie_roots_after;
let fields = [
(
Expand All @@ -227,19 +241,19 @@ fn apply_metadata_and_tries_memops<F: RichField + Extendable<D>, const D: usize>
(GlobalMetadata::TxnNumberBefore, inputs.txn_number_before),
(
GlobalMetadata::TxnNumberAfter,
inputs.txn_number_before + inputs.signed_txns.len(),
inputs.txn_number_before + inputs.txn_hashes.len(),
),
(
GlobalMetadata::StateTrieRootDigestBefore,
h2u(tries.state_trie.hash()),
h2u(inputs.trie_roots_before.state_root),
),
(
GlobalMetadata::TransactionTrieRootDigestBefore,
h2u(tries.transactions_trie.hash()),
h2u(inputs.trie_roots_before.transactions_root),
),
(
GlobalMetadata::ReceiptTrieRootDigestBefore,
h2u(tries.receipts_trie.hash()),
h2u(inputs.trie_roots_before.receipts_root),
),
(
GlobalMetadata::StateTrieRootDigestAfter,
Expand Down Expand Up @@ -390,18 +404,14 @@ fn get_all_memory_address_and_values(memory_before: &MemoryState) -> Vec<(Memory
type TablesWithPVsAndFinalMem<F> = ([Vec<PolynomialValues<F>>; NUM_TABLES], PublicValues);
pub fn generate_traces<F: RichField + Extendable<D>, const D: usize>(
all_stark: &AllStark<F, D>,
inputs: &GenerationInputs,
inputs: &TrimmedGenerationInputs,
config: &StarkConfig,
segment_data: &mut GenerationSegmentData,
timing: &mut TimingTree,
) -> anyhow::Result<TablesWithPVsAndFinalMem<F>> {
debug_inputs(inputs);

let mut state = GenerationState::<F>::new(inputs, &KERNEL.code)
let mut state = GenerationState::<F>::new_with_segment_data(inputs, segment_data)
.map_err(|err| anyhow!("Failed to parse all the initial prover inputs: {:?}", err))?;

state.set_segment_data(segment_data);

initialize_kernel_code_and_shift_table(&mut segment_data.memory);

// Retrieve initial memory addresses and values.
Expand All @@ -410,20 +420,12 @@ pub fn generate_traces<F: RichField + Extendable<D>, const D: usize>(
// Initialize the state with the one at the end of the
// previous segment execution, if any.
let GenerationSegmentData {
is_dummy,
set_preinit,
segment_index,
max_cpu_len_log,
memory,
registers_before,
registers_after,
extra_data,
..
} = segment_data;

if segment_data.set_preinit {
state.memory.preinitialized_segments = segment_data.memory.preinitialized_segments.clone();
}

for &(address, val) in &actual_mem_before {
state.memory.set(address, val);
}
Expand All @@ -435,7 +437,7 @@ pub fn generate_traces<F: RichField + Extendable<D>, const D: usize>(
let cpu_res = timed!(
timing,
"simulate CPU",
simulate_cpu(&mut state, *max_cpu_len_log, *is_dummy)
simulate_cpu(&mut state, *max_cpu_len_log)
);
if cpu_res.is_err() {
output_debug_tries(&state)?;
Expand Down Expand Up @@ -500,7 +502,6 @@ pub fn generate_traces<F: RichField + Extendable<D>, const D: usize>(
fn simulate_cpu<F: Field>(
state: &mut GenerationState<F>,
max_cpu_len_log: Option<usize>,
is_dummy: bool,
) -> anyhow::Result<(RegistersState, Option<MemoryState>)> {
let (final_registers, mem_after) = state.run_cpu(max_cpu_len_log)?;

Expand Down
2 changes: 1 addition & 1 deletion evm_arithmetization/src/generation/prover_input.rs
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ impl<F: Field> GenerationState<F> {
fn run_end_of_txns(&mut self) -> Result<U256, ProgramError> {
// Reset the jumpdest table before the next transaction.
self.jumpdest_table = None;
let end = self.next_txn_index == self.inputs.txns_len;
let end = self.next_txn_index == self.inputs.txn_hashes.len();
if end {
Ok(U256::one())
} else {
Expand Down
20 changes: 18 additions & 2 deletions evm_arithmetization/src/generation/state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,8 @@ use crate::prover::GenerationSegmentData;
use crate::util::u256_to_usize;
use crate::witness::errors::ProgramError;
use crate::witness::memory::MemoryChannel::GeneralPurpose;
use crate::witness::memory::MemoryOpKind;
use crate::witness::memory::{MemoryAddress, MemoryOp, MemoryState};
use crate::witness::memory::{MemoryContextState, MemoryOpKind};
use crate::witness::operation::{generate_exception, Operation};
use crate::witness::state::RegistersState;
use crate::witness::traces::{TraceCheckpoint, Traces};
Expand Down Expand Up @@ -331,7 +331,7 @@ pub(crate) trait State<F: Field> {
}
}

#[derive(Debug)]
#[derive(Debug, Default)]
pub struct GenerationState<F: Field> {
pub(crate) inputs: TrimmedGenerationInputs,
pub(crate) registers: RegistersState,
Expand Down Expand Up @@ -435,6 +435,22 @@ impl<F: Field> GenerationState<F> {
Ok(state)
}

pub(crate) fn new_with_segment_data(
trimmed_inputs: &TrimmedGenerationInputs,
segment_data: &GenerationSegmentData,
) -> Result<Self, ProgramError> {
let mut state = Self {
inputs: trimmed_inputs.clone(),
..Default::default()
};

state.memory.preinitialized_segments = segment_data.memory.preinitialized_segments.clone();

state.set_segment_data(segment_data);

Ok(state)
}

/// Updates `program_counter`, and potentially adds some extra handling if
/// we're jumping to a special location.
pub(crate) fn jump_to(&mut self, dst: usize) -> Result<(), ProgramError> {
Expand Down
Loading
Loading