From 806e1ca0a337f4ad8590d9859ea1b5c1942389bb Mon Sep 17 00:00:00 2001 From: SChernykh Date: Fri, 29 Oct 2021 11:39:15 +0200 Subject: [PATCH] SideChain: faster check for low-diff spam blocks --- src/side_chain.cpp | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/src/side_chain.cpp b/src/side_chain.cpp index 03794cc..ed95d87 100644 --- a/src/side_chain.cpp +++ b/src/side_chain.cpp @@ -370,7 +370,7 @@ bool SideChain::add_external_block(PoolBlock& block, std::vector& missing_ return false; } - difficulty_type min_accepted_diff; + bool too_low_diff = (block.m_difficulty < m_curDifficulty); { MutexLock lock(m_sidechainLock); if (m_blocksById.find(block.m_sidechainId) != m_blocksById.end()) { @@ -378,23 +378,25 @@ bool SideChain::add_external_block(PoolBlock& block, std::vector& missing_ return true; } - // Find the minimum difficulty in the current PPLNS window - min_accepted_diff = m_curDifficulty; - for (PoolBlock* tmp = m_chainTip; tmp && (tmp->m_sidechainHeight + m_chainWindowSize > m_chainTip->m_sidechainHeight); tmp = get_parent(tmp)) { - if (tmp->m_difficulty < min_accepted_diff) { - min_accepted_diff = tmp->m_difficulty; + // This is mainly an anti-spam measure, not an actual verification step + if (too_low_diff) { + // Reduce required diff by 50% (by doubling this block's diff) to account for alternative chains + difficulty_type diff2 = block.m_difficulty; + diff2 += block.m_difficulty; + + for (PoolBlock* tmp = m_chainTip; tmp && (tmp->m_sidechainHeight + m_chainWindowSize > m_chainTip->m_sidechainHeight); tmp = get_parent(tmp)) { + if (diff2 >= tmp->m_difficulty) { + too_low_diff = false; + break; + } } } } LOGINFO(4, "add_external_block: height = " << block.m_sidechainHeight << ", id = " << block.m_sidechainId << ", mainchain height = " << block.m_txinGenHeight); - // Reduce it by 50% to account for alternative chains. This is mainly an anti-spam measure, not an actual verification step - min_accepted_diff.lo = (min_accepted_diff.lo >> 1) | (min_accepted_diff.hi << 63); - min_accepted_diff.hi >>= 1; - - if (block.m_difficulty < min_accepted_diff) { - LOGWARN(4, "add_external_block: block has too low difficulty " << block.m_difficulty << ", expected >= " << min_accepted_diff << ". Ignoring it."); + if (too_low_diff) { + LOGWARN(4, "add_external_block: block has too low difficulty " << block.m_difficulty << ", expected >= ~" << m_curDifficulty << ". Ignoring it."); return true; }