Skip to content

Commit

Permalink
Boxes removed from StateRootTask
Browse files Browse the repository at this point in the history
Signed-off-by: nadtech-hub <[email protected]>
  • Loading branch information
nadtech-hub committed Jan 17, 2025
1 parent e6d9907 commit 2f9fa43
Showing 1 changed file with 13 additions and 14 deletions.
27 changes: 13 additions & 14 deletions crates/engine/tree/src/tree/root.rs
Original file line number Diff line number Diff line change
Expand Up @@ -105,13 +105,13 @@ pub enum StateRootMessage<BPF: BlindedProviderFactory> {
/// New state update from transaction execution
StateUpdate(EvmState),
/// Proof calculation completed for a specific state update
ProofCalculated(Box<ProofCalculated>),
ProofCalculated(ProofCalculated),
/// Error during proof calculation
ProofCalculationError(ProviderError),
/// State root calculation completed
RootCalculated {
/// The updated sparse trie
trie: Box<SparseStateTrie<BPF>>,
trie: SparseStateTrie<BPF>,
/// Time taken to calculate the root
elapsed: Duration,
},
Expand Down Expand Up @@ -273,7 +273,7 @@ pub struct StateRootTask<Factory, BPF: BlindedProviderFactory> {
proof_sequencer: ProofSequencer,
/// The sparse trie used for the state root calculation. If [`None`], then update is in
/// progress.
sparse_trie: Option<Box<SparseStateTrie<BPF>>>,
sparse_trie: Option<SparseStateTrie<BPF>>,
/// Reference to the shared thread pool for parallel proof generation
thread_pool: Arc<rayon::ThreadPool>,
}
Expand Down Expand Up @@ -304,7 +304,7 @@ where
tx,
fetched_proof_targets: Default::default(),
proof_sequencer: ProofSequencer::new(),
sparse_trie: Some(Box::new(SparseStateTrie::new(blinded_provider).with_updates(true))),
sparse_trie: Some(SparseStateTrie::new(blinded_provider).with_updates(true)),
thread_pool,
}
}
Expand Down Expand Up @@ -416,12 +416,12 @@ where
match result {
Ok(proof) => {
let _ = state_root_message_sender.send(StateRootMessage::ProofCalculated(
Box::new(ProofCalculated {
ProofCalculated {
state_update: hashed_state_update,
targets: proof_targets,
proof,
sequence_number: proof_sequence_number,
}),
},
));
}
Err(error) => {
Expand Down Expand Up @@ -754,17 +754,16 @@ where

/// Updates the sparse trie with the given proofs and state, and returns the updated trie and the
/// time it took.
fn update_sparse_trie<BPF>(
mut trie: Box<SparseStateTrie<BPF>>,
fn update_sparse_trie<
ABP: BlindedProvider<Error = SparseTrieError> + Send + Sync,
SBP: BlindedProvider<Error = SparseTrieError> + Send + Sync,
BPF: BlindedProviderFactory<AccountNodeProvider = ABP, StorageNodeProvider = SBP> + Send + Sync,
>(
mut trie: SparseStateTrie<BPF>,
multiproof: MultiProof,
targets: MultiProofTargets,
state: HashedPostState,
) -> SparseStateTrieResult<(Box<SparseStateTrie<BPF>>, Duration)>
where
BPF: BlindedProviderFactory + Send + Sync,
BPF::AccountNodeProvider: BlindedProvider + Send + Sync,
BPF::StorageNodeProvider: BlindedProvider + Send + Sync,
{
) -> SparseStateTrieResult<(SparseStateTrie<BPF>, Duration)> {
trace!(target: "engine::root::sparse", "Updating sparse trie");
let started_at = Instant::now();

Expand Down

0 comments on commit 2f9fa43

Please sign in to comment.