@ -3115,7 +3115,7 @@ static bool AcceptBlock(const std::shared_ptr<const CBlock>& pblock, CValidation
// process an unrequested block if it's new and has enough work to
// process an unrequested block if it's new and has enough work to
// advance our tip, and isn't too many blocks ahead.
// advance our tip, and isn't too many blocks ahead.
bool fAlreadyHave = pindex - > nStatus & BLOCK_HAVE_DATA ;
bool fAlreadyHave = pindex - > nStatus & BLOCK_HAVE_DATA ;
bool fHasMore Work = ( chainActive . Tip ( ) ? pindex - > nChainWork > chainActive . Tip ( ) - > nChainWork : true ) ;
bool fHasMore OrSame Work = ( chainActive . Tip ( ) ? pindex - > nChainWork > = chainActive . Tip ( ) - > nChainWork : true ) ;
// Blocks that are too out-of-order needlessly limit the effectiveness of
// Blocks that are too out-of-order needlessly limit the effectiveness of
// pruning, because pruning will not delete block files that contain any
// pruning, because pruning will not delete block files that contain any
// blocks which are too close in height to the tip. Apply this test
// blocks which are too close in height to the tip. Apply this test
@ -3132,9 +3132,9 @@ static bool AcceptBlock(const std::shared_ptr<const CBlock>& pblock, CValidation
// and unrequested blocks.
// and unrequested blocks.
if ( fAlreadyHave ) return true ;
if ( fAlreadyHave ) return true ;
if ( ! fRequested ) { // If we didn't ask for it:
if ( ! fRequested ) { // If we didn't ask for it:
if ( pindex - > nTx ! = 0 ) return true ; // This is a previously-processed block that was pruned
if ( pindex - > nTx ! = 0 ) return true ; // This is a previously-processed block that was pruned
if ( ! fHasMore Work) return true ; // Don't process less-work chains
if ( ! fHasMore OrSame Work) return true ; // Don't process less-work chains
if ( fTooFarAhead ) return true ; // Block height is too high
if ( fTooFarAhead ) return true ; // Block height is too high
// Protect against DoS attacks from low-work chains.
// Protect against DoS attacks from low-work chains.
// If our tip is behind, a peer could try to send us
// If our tip is behind, a peer could try to send us