mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-26 11:13:23 -03:00
Move m_failed_blocks to ChainstateManager
The member is unrelated to block storage (BlockManager). It is related to validation. Fix the confusion by moving it. Can be reviewed with --color-moved=dimmed-zebra --color-moved-ws=ignore-all-space
This commit is contained in:
parent
fa47b5c100
commit
facd2137ec
2 changed files with 27 additions and 26 deletions
|
@ -1291,7 +1291,7 @@ void CChainState::InvalidBlockFound(CBlockIndex* pindex, const BlockValidationSt
|
||||||
{
|
{
|
||||||
if (state.GetResult() != BlockValidationResult::BLOCK_MUTATED) {
|
if (state.GetResult() != BlockValidationResult::BLOCK_MUTATED) {
|
||||||
pindex->nStatus |= BLOCK_FAILED_VALID;
|
pindex->nStatus |= BLOCK_FAILED_VALID;
|
||||||
m_blockman.m_failed_blocks.insert(pindex);
|
m_chainman.m_failed_blocks.insert(pindex);
|
||||||
setDirtyBlockIndex.insert(pindex);
|
setDirtyBlockIndex.insert(pindex);
|
||||||
setBlockIndexCandidates.erase(pindex);
|
setBlockIndexCandidates.erase(pindex);
|
||||||
InvalidChainFound(pindex);
|
InvalidChainFound(pindex);
|
||||||
|
@ -2844,7 +2844,7 @@ bool CChainState::InvalidateBlock(BlockValidationState& state, CBlockIndex* pind
|
||||||
to_mark_failed->nStatus |= BLOCK_FAILED_VALID;
|
to_mark_failed->nStatus |= BLOCK_FAILED_VALID;
|
||||||
setDirtyBlockIndex.insert(to_mark_failed);
|
setDirtyBlockIndex.insert(to_mark_failed);
|
||||||
setBlockIndexCandidates.erase(to_mark_failed);
|
setBlockIndexCandidates.erase(to_mark_failed);
|
||||||
m_blockman.m_failed_blocks.insert(to_mark_failed);
|
m_chainman.m_failed_blocks.insert(to_mark_failed);
|
||||||
|
|
||||||
// If any new blocks somehow arrived while we were disconnecting
|
// If any new blocks somehow arrived while we were disconnecting
|
||||||
// (above), then the pre-calculation of what should go into
|
// (above), then the pre-calculation of what should go into
|
||||||
|
@ -2889,7 +2889,7 @@ void CChainState::ResetBlockFailureFlags(CBlockIndex *pindex) {
|
||||||
// Reset invalid block marker if it was pointing to one of those.
|
// Reset invalid block marker if it was pointing to one of those.
|
||||||
pindexBestInvalid = nullptr;
|
pindexBestInvalid = nullptr;
|
||||||
}
|
}
|
||||||
m_blockman.m_failed_blocks.erase(it->second);
|
m_chainman.m_failed_blocks.erase(it->second);
|
||||||
}
|
}
|
||||||
it++;
|
it++;
|
||||||
}
|
}
|
||||||
|
@ -2899,7 +2899,7 @@ void CChainState::ResetBlockFailureFlags(CBlockIndex *pindex) {
|
||||||
if (pindex->nStatus & BLOCK_FAILED_MASK) {
|
if (pindex->nStatus & BLOCK_FAILED_MASK) {
|
||||||
pindex->nStatus &= ~BLOCK_FAILED_MASK;
|
pindex->nStatus &= ~BLOCK_FAILED_MASK;
|
||||||
setDirtyBlockIndex.insert(pindex);
|
setDirtyBlockIndex.insert(pindex);
|
||||||
m_blockman.m_failed_blocks.erase(pindex);
|
m_chainman.m_failed_blocks.erase(pindex);
|
||||||
}
|
}
|
||||||
pindex = pindex->pprev;
|
pindex = pindex->pprev;
|
||||||
}
|
}
|
||||||
|
@ -3325,7 +3325,7 @@ bool ChainstateManager::AcceptBlockHeader(const CBlockHeader& block, BlockValida
|
||||||
// hasn't been validated up to BLOCK_VALID_SCRIPTS. This is a performance
|
// hasn't been validated up to BLOCK_VALID_SCRIPTS. This is a performance
|
||||||
// optimization, in the common case of adding a new block to the tip,
|
// optimization, in the common case of adding a new block to the tip,
|
||||||
// we don't need to iterate over the failed blocks list.
|
// we don't need to iterate over the failed blocks list.
|
||||||
for (const CBlockIndex* failedit : m_blockman.m_failed_blocks) {
|
for (const CBlockIndex* failedit : m_failed_blocks) {
|
||||||
if (pindexPrev->GetAncestor(failedit->nHeight) == failedit) {
|
if (pindexPrev->GetAncestor(failedit->nHeight) == failedit) {
|
||||||
assert(failedit->nStatus & BLOCK_FAILED_VALID);
|
assert(failedit->nStatus & BLOCK_FAILED_VALID);
|
||||||
CBlockIndex* invalid_walk = pindexPrev;
|
CBlockIndex* invalid_walk = pindexPrev;
|
||||||
|
@ -3804,7 +3804,6 @@ bool BlockManager::LoadBlockIndex(
|
||||||
}
|
}
|
||||||
|
|
||||||
void BlockManager::Unload() {
|
void BlockManager::Unload() {
|
||||||
m_failed_blocks.clear();
|
|
||||||
m_blocks_unlinked.clear();
|
m_blocks_unlinked.clear();
|
||||||
|
|
||||||
for (const BlockMap::value_type& entry : m_block_index) {
|
for (const BlockMap::value_type& entry : m_block_index) {
|
||||||
|
@ -5119,6 +5118,7 @@ void ChainstateManager::Unload()
|
||||||
chainstate->UnloadBlockIndex();
|
chainstate->UnloadBlockIndex();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_failed_blocks.clear();
|
||||||
m_blockman.Unload();
|
m_blockman.Unload();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -405,26 +405,6 @@ private:
|
||||||
public:
|
public:
|
||||||
BlockMap m_block_index GUARDED_BY(cs_main);
|
BlockMap m_block_index GUARDED_BY(cs_main);
|
||||||
|
|
||||||
/** In order to efficiently track invalidity of headers, we keep the set of
|
|
||||||
* blocks which we tried to connect and found to be invalid here (ie which
|
|
||||||
* were set to BLOCK_FAILED_VALID since the last restart). We can then
|
|
||||||
* walk this set and check if a new header is a descendant of something in
|
|
||||||
* this set, preventing us from having to walk m_block_index when we try
|
|
||||||
* to connect a bad block and fail.
|
|
||||||
*
|
|
||||||
* While this is more complicated than marking everything which descends
|
|
||||||
* from an invalid block as invalid at the time we discover it to be
|
|
||||||
* invalid, doing so would require walking all of m_block_index to find all
|
|
||||||
* descendants. Since this case should be very rare, keeping track of all
|
|
||||||
* BLOCK_FAILED_VALID blocks in a set should be just fine and work just as
|
|
||||||
* well.
|
|
||||||
*
|
|
||||||
* Because we already walk m_block_index in height-order at startup, we go
|
|
||||||
* ahead and mark descendants of invalid blocks as FAILED_CHILD at that time,
|
|
||||||
* instead of putting things in this set.
|
|
||||||
*/
|
|
||||||
std::set<CBlockIndex*> m_failed_blocks;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* All pairs A->B, where A (or one of its ancestors) misses transactions, but B has transactions.
|
* All pairs A->B, where A (or one of its ancestors) misses transactions, but B has transactions.
|
||||||
* Pruned nodes may have entries where B is missing data.
|
* Pruned nodes may have entries where B is missing data.
|
||||||
|
@ -909,6 +889,27 @@ public:
|
||||||
//! chainstate to avoid duplicating block metadata.
|
//! chainstate to avoid duplicating block metadata.
|
||||||
BlockManager m_blockman GUARDED_BY(::cs_main);
|
BlockManager m_blockman GUARDED_BY(::cs_main);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* In order to efficiently track invalidity of headers, we keep the set of
|
||||||
|
* blocks which we tried to connect and found to be invalid here (ie which
|
||||||
|
* were set to BLOCK_FAILED_VALID since the last restart). We can then
|
||||||
|
* walk this set and check if a new header is a descendant of something in
|
||||||
|
* this set, preventing us from having to walk m_block_index when we try
|
||||||
|
* to connect a bad block and fail.
|
||||||
|
*
|
||||||
|
* While this is more complicated than marking everything which descends
|
||||||
|
* from an invalid block as invalid at the time we discover it to be
|
||||||
|
* invalid, doing so would require walking all of m_block_index to find all
|
||||||
|
* descendants. Since this case should be very rare, keeping track of all
|
||||||
|
* BLOCK_FAILED_VALID blocks in a set should be just fine and work just as
|
||||||
|
* well.
|
||||||
|
*
|
||||||
|
* Because we already walk m_block_index in height-order at startup, we go
|
||||||
|
* ahead and mark descendants of invalid blocks as FAILED_CHILD at that time,
|
||||||
|
* instead of putting things in this set.
|
||||||
|
*/
|
||||||
|
std::set<CBlockIndex*> m_failed_blocks;
|
||||||
|
|
||||||
//! The total number of bytes available for us to use across all in-memory
|
//! The total number of bytes available for us to use across all in-memory
|
||||||
//! coins caches. This will be split somehow across chainstates.
|
//! coins caches. This will be split somehow across chainstates.
|
||||||
int64_t m_total_coinstip_cache{0};
|
int64_t m_total_coinstip_cache{0};
|
||||||
|
|
Loading…
Add table
Reference in a new issue