From 2b169efa236fae47a851782ee8690e81524d2e85 Mon Sep 17 00:00:00 2001 From: Etan Kissling Date: Tue, 26 Mar 2024 05:13:35 +0100 Subject: [PATCH] keep proposal state around in clearance to reapply block lagfree --- beacon_chain/consensus_object_pools/blockchain_dag.nim | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/beacon_chain/consensus_object_pools/blockchain_dag.nim b/beacon_chain/consensus_object_pools/blockchain_dag.nim index fbd6fa236..484c65d09 100644 --- a/beacon_chain/consensus_object_pools/blockchain_dag.nim +++ b/beacon_chain/consensus_object_pools/blockchain_dag.nim @@ -2657,9 +2657,12 @@ proc getProposalState*( # and thus has a hot hash tree cache let state = if dag.incrementalState != nil: + # The block's pre-state will be needed soon to validate our own block + dag.clearanceState.assign(dag.incrementalState[]) dag.incrementalState else: assignClone(dag.clearanceState) + dag.resetChainProgressWatchdog() var info = ForkedEpochInfo() @@ -2681,8 +2684,6 @@ proc getProposalState*( dag.cfg, state[], slot, cache, info, {skipLastStateRootCalculation}).expect("advancing 1 slot should not fail") - # Ensure async operations don't interfere with `incrementalState` - dag.resetChainProgressWatchdog() ok state func aggregateAll*(