feat(engine): prefetch withdrawal addresses in pre-warming#21966
Merged
feat(engine): prefetch withdrawal addresses in pre-warming#21966
Conversation
Contributor
|
mattsse
requested changes
Feb 9, 2026
Withdrawals happen at the end of block execution as balance increments. Previously, the pre-warming system did not prefetch any data for these withdrawal addresses, meaning the multiproof computation for withdrawals had to wait for I/O during post-execution. This change generates account-level multiproof prefetch targets for withdrawal addresses and sends them immediately when spawning the payload processor, before transaction prewarming begins. This gives the multiproof task a head start on fetching trie proofs for withdrawal accounts. - Add `withdrawals` field to `ExecutionEnv` - Add `multiproof_targets_from_withdrawals()` helper (supports both legacy and V2 proof targets) - Send `PrefetchProofs` for withdrawals at spawn time in non-BAL path - Filter zero-amount withdrawals and deduplicate addresses - BAL path excluded since BAL should already cover withdrawal touches Co-authored-by: mattsse <matt@paradigm.xyz> Amp-Thread-ID: https://ampcode.com/threads/T-019c3de1-3f1a-75ce-89f6-cc1ff085a42c Co-authored-by: Amp <amp@ampcode.com>
Amp-Thread-ID: https://ampcode.com/threads/T-019c3de1-3f1a-75ce-89f6-cc1ff085a42c Co-authored-by: Amp <amp@ampcode.com>
This reverts commit a812d80.
Amp-Thread-ID: https://ampcode.com/threads/T-019c42d4-887b-7004-b11d-48bea8f3a51b Co-authored-by: Amp <amp@ampcode.com>
750c61e to
d809536
Compare
DaniPopes
reviewed
Feb 9, 2026
DaniPopes
reviewed
Feb 9, 2026
mattsse
requested changes
Feb 9, 2026
- Remove amount > 0 filters (withdrawal amounts are never 0) - Check withdrawals is non-empty instead of filtering by amount - Return &[Withdrawal] from BlockOrPayload::withdrawals() to avoid cloning - Keep dedup filter in V2 targets Amp-Thread-ID: https://ampcode.com/threads/T-019c43f3-4165-7637-bea2-707b4d96b71d Co-authored-by: Amp <amp@ampcode.com>
…tions Amp-Thread-ID: https://ampcode.com/threads/T-019c43fa-95b8-76d7-9a28-d8fc40812735 Co-authored-by: Amp <amp@ampcode.com>
Amp-Thread-ID: https://ampcode.com/threads/T-019c43fa-95b8-76d7-9a28-d8fc40812735 Co-authored-by: Amp <amp@ampcode.com>
Amp-Thread-ID: https://ampcode.com/threads/T-019c43fa-95b8-76d7-9a28-d8fc40812735 Co-authored-by: Amp <amp@ampcode.com>
mattsse
approved these changes
Feb 9, 2026
gakonst
commented
Feb 9, 2026
shekhirin
approved these changes
Feb 9, 2026
CarlBeek
added a commit
to CarlBeek/reth
that referenced
this pull request
Feb 10, 2026
* paradigmxyz/main: (144 commits) feat(engine): add getPayloadBodiesV2 endpoints for EIP-7928 BAL support (paradigmxyz#21774) ci: skip scheduled workflows on forks (paradigmxyz#22022) chore: rm random log file (paradigmxyz#22023) chore: remove base.reth.rs public endpoint references (paradigmxyz#22019) feat(rpc): add `subscribeFinalizedChainNotifications` endpoint (paradigmxyz#22011) feat(trie): remove `SerialSparseTrie` (paradigmxyz#21808) fix(rocksdb): set max_open_files to prevent fd exhaustion (paradigmxyz#22005) refactor(txpool): rename and document validation methods (paradigmxyz#22008) feat(engine): prefetch withdrawal addresses in pre-warming (paradigmxyz#21966) refactor(pool): add IntoIter: Send bounds to avoid unnecessary Vec collect (paradigmxyz#22001) fix(rpc): enforce blockHash constraint in append_matching_block_logs (paradigmxyz#22007) chore: move Kurtosis failures to the hive slack channel (paradigmxyz#21983) feat(rpc): propagate TransactionOrigin through send_transaction and batcher (paradigmxyz#21969) feat(engine): reorg depth commitment metric (paradigmxyz#21992) feat(storage): add use_hashed_state storage setting (paradigmxyz#21997) perf: better scheduling for storage roots computation (paradigmxyz#21987) chore(deps): bump alloy 1.6.2 -> 1.6.3 (paradigmxyz#21986) fix(stages): skip sender unwind when fully pruned (paradigmxyz#21988) chore(net): remove OP stack bootnodes (paradigmxyz#21984) ci: use depot for hive and kurtosis image builds, run daily (paradigmxyz#21976) ... # Conflicts: # .github/workflows/compact.yml # .github/workflows/dependencies.yml # .github/workflows/docker-tag-latest.yml # .github/workflows/docker.yml # .github/workflows/e2e.yml # .github/workflows/hive.yml # .github/workflows/integration.yml # .github/workflows/kurtosis.yml # .github/workflows/lint.yml # .github/workflows/release.yml # .github/workflows/reproducible-build.yml # .github/workflows/stale.yml # .github/workflows/sync-era.yml # .github/workflows/sync.yml # .github/workflows/unit.yml # bin/reth/Cargo.toml # crates/cli/commands/src/node.rs # crates/node/core/src/node_config.rs
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
Prefetch trie proofs for withdrawal addresses during pre-warming, before block execution reaches the post-block balance increment phase.
Motivation
Withdrawals happen at the end of block execution as balance increments. The multiproof computation for these accounts currently has to wait for I/O during post-execution. Since withdrawal addresses are known from the payload upfront, we can prefetch their trie proofs early.
Changes
withdrawalsfield toExecutionEnv(mod.rs)multiproof_targets_from_withdrawals()helper inprewarm.rs(supports both legacy and V2 proof targets)PrefetchProofsfor withdrawals at spawn time inPayloadProcessor::spawn(), non-BAL path onlywithdrawals()accessor toBlockOrPayloadTesting
a70a6a1a-3221-496e-b67d-7327ec34d57bSlack thread: https://tempoxyz.slack.com/archives/C0A87C21805/p1770564694402899