Skip to content

Commit

Permalink
feat(tree): cache trie updates for nonfinalized canonical blocks
Browse files Browse the repository at this point in the history
  • Loading branch information
Rjected committed Aug 28, 2024
1 parent 05e85b7 commit 2f716c0
Showing 1 changed file with 15 additions and 4 deletions.
19 changes: 15 additions & 4 deletions crates/engine/tree/src/tree/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ use reth_rpc_types::{
ExecutionPayload,
};
use reth_stages_api::ControlFlow;
use reth_trie::HashedPostState;
use reth_trie::{updates::TrieUpdates, HashedPostState};
use std::{
collections::{btree_map, hash_map, BTreeMap, HashMap, HashSet},
ops::Bound,
Expand Down Expand Up @@ -81,6 +81,10 @@ pub struct TreeState {
blocks_by_number: BTreeMap<BlockNumber, Vec<ExecutedBlock>>,
/// Map of any parent block hash to its children.
parent_to_child: HashMap<B256, HashSet<B256>>,
/// Map of hash to trie updates for canonical blocks that are persisted but not finalized.
///
/// Contains the block number for easy removal.
persisted_trie_updates: HashMap<B256, (BlockNumber, Arc<TrieUpdates>)>,
/// Currently tracked canonical head of the chain.
current_canonical_head: BlockNumHash,
}
Expand All @@ -93,6 +97,7 @@ impl TreeState {
blocks_by_number: BTreeMap::new(),
current_canonical_head,
parent_to_child: HashMap::new(),
persisted_trie_updates: HashMap::new(),
}
}

Expand Down Expand Up @@ -236,14 +241,17 @@ impl TreeState {
// * fetch the number of the finalized hash, removing any sidechains that are __below__ the
// finalized block

// TODO: move trie updates here
// First, let's walk back the canonical chain and remove canonical blocks lower than the
// upper bound
let mut current_block = self.current_canonical_head.hash;
while let Some(executed) = self.blocks_by_hash.get(&current_block) {
current_block = executed.block.parent_hash;
if executed.block.number <= upper_bound {
self.remove_by_hash(executed.block.hash());
if let Some((removed, _)) = self.remove_by_hash(executed.block.hash()) {
// finally, move the trie updates
self.persisted_trie_updates
.insert(removed.block.hash(), (removed.block.number, removed.trie));
}
}
}

Expand All @@ -258,7 +266,6 @@ impl TreeState {

// We _exclude_ the finalized block because we will be dealing with the blocks __at__
// the finalized block later.
// TODO: remove trie updates whose root are below the finalized block
let blocks_to_remove = self
.blocks_by_number
.range((Bound::Unbounded, Bound::Excluded(finalized)))
Expand All @@ -268,6 +275,9 @@ impl TreeState {
self.remove_by_hash(hash);
}

// remove trie updates that are below the finalized block
self.persisted_trie_updates.retain(|_, (block_num, _)| *block_num <= finalized);

// The only blocks that exist at `finalized_num` now, are blocks in sidechains that
// should be removed.
//
Expand Down Expand Up @@ -2277,6 +2287,7 @@ mod tests {
blocks_by_number,
current_canonical_head: blocks.last().unwrap().block().num_hash(),
parent_to_child,
persisted_trie_updates: HashMap::default(),
};

let last_executed_block = blocks.last().unwrap().clone();
Expand Down

0 comments on commit 2f716c0

Please sign in to comment.