From e31678f3557e8d035c1e4a8209e08e025f08ab8c Mon Sep 17 00:00:00 2001 From: Andrew Ashikhmin <34320705+yperbasis@users.noreply.github.com> Date: Fri, 17 Feb 2023 15:05:49 +0100 Subject: [PATCH] Body downloader: fix empty withdrawals in empty bodies (#6893) Potentially fixes Issue #6817. --- turbo/stages/bodydownload/body_algos.go | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/turbo/stages/bodydownload/body_algos.go b/turbo/stages/bodydownload/body_algos.go index d31fcab10..449ba01d2 100644 --- a/turbo/stages/bodydownload/body_algos.go +++ b/turbo/stages/bodydownload/body_algos.go @@ -136,17 +136,23 @@ func (bd *BodyDownload) RequestMoreBodies(tx kv.RwTx, blockReader services.FullB } } if request { - if header.UncleHash != types.EmptyUncleHash || header.TxHash != types.EmptyRootHash || - (header.WithdrawalsHash != nil && *header.WithdrawalsHash != types.EmptyRootHash) { + if header.UncleHash == types.EmptyUncleHash && header.TxHash == types.EmptyRootHash && + (header.WithdrawalsHash == nil || *header.WithdrawalsHash == types.EmptyRootHash) { + // Empty block body + body := &types.RawBody{} + if header.WithdrawalsHash != nil { + // implies *header.WithdrawalsHash == types.EmptyRootHash + body.Withdrawals = make([]*types.Withdrawal, 0) + } + bd.addBodyToCache(blockNum, body) + request = false + } else { // Perhaps we already have this block block := rawdb.ReadBlock(tx, hash, blockNum) if block != nil { bd.addBodyToCache(blockNum, block.RawBody()) request = false } - } else { - bd.addBodyToCache(blockNum, &types.RawBody{}) - request = false } } if request {