From 776f09215cbc824d7e102d07ee1dbe8de25755a8 Mon Sep 17 00:00:00 2001 From: tersec Date: Tue, 6 Sep 2022 11:43:19 +0000 Subject: [PATCH] only mark post-finalized blocks invalid (#4072) --- beacon_chain/consensus_object_pools/blockchain_dag.nim | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/beacon_chain/consensus_object_pools/blockchain_dag.nim b/beacon_chain/consensus_object_pools/blockchain_dag.nim index 3eac8dc1e4..8983006643 100644 --- a/beacon_chain/consensus_object_pools/blockchain_dag.nim +++ b/beacon_chain/consensus_object_pools/blockchain_dag.nim @@ -1515,14 +1515,14 @@ proc markBlockInvalid*(dag: ChainDAGRef, root: Eth2Digest) = doAssert strictVerification notin dag.updateFlags return - if root == dag.finalizedHead.blck.root: + if blck.slot <= dag.finalizedHead.slot: # https://github.com/ethereum/consensus-specs/blob/v1.2.0-rc.3/sync/optimistic.md#re-orgs # "If the justified checkpoint transitions from `NOT_VALIDATED` -> # `INVALIDATED`, a consensus engine MAY choose to alert the user and force # the application to exit." # # But be slightly less aggressive, and only check finalized. - warn "markBlockInvalid: finalized block invalidated" + warn "markBlockInvalid: attempted to mark finalized block invalidated" doAssert strictVerification notin dag.updateFlags return