mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 02:33:24 -03:00
Merge bitcoin/bitcoin#29569: Rename CalculateHeadersWork to CalculateClaimedHeadersWork
eb7cc9fd21
Rename CalculateHeadersWork to CalculateClaimedHeadersWork (Greg Sanders) Pull request description: And clean up some comments. Confusion about what this is doing seems to be a running theme: https://github.com/bitcoin/bitcoin/pull/29549#discussion_r1511113344 https://github.com/bitcoin/bitcoin/pull/27278#discussion_r1141510303 ACKs for top commit: achow101: ACKeb7cc9fd21
pablomartin4btc: ACKeb7cc9fd21
0xB10C: ACKeb7cc9fd21
dergoegge: ACKeb7cc9fd21
BrandonOdiwuor: ACKeb7cc9fd21
Tree-SHA512: 6ccbc5e417155516487bb220753d189b5341dec05366db88a3fa5b1932eace21fbfaf23408c639bb54b36169a8d0a7536a1ee5e63b4ce5a3b70f2ff8407b6e07
This commit is contained in:
commit
4cc99df44a
4 changed files with 9 additions and 9 deletions
|
@ -2690,8 +2690,8 @@ bool PeerManagerImpl::IsContinuationOfLowWorkHeadersSync(Peer& peer, CNode& pfro
|
||||||
|
|
||||||
bool PeerManagerImpl::TryLowWorkHeadersSync(Peer& peer, CNode& pfrom, const CBlockIndex* chain_start_header, std::vector<CBlockHeader>& headers)
|
bool PeerManagerImpl::TryLowWorkHeadersSync(Peer& peer, CNode& pfrom, const CBlockIndex* chain_start_header, std::vector<CBlockHeader>& headers)
|
||||||
{
|
{
|
||||||
// Calculate the total work on this chain.
|
// Calculate the claimed total work on this chain.
|
||||||
arith_uint256 total_work = chain_start_header->nChainWork + CalculateHeadersWork(headers);
|
arith_uint256 total_work = chain_start_header->nChainWork + CalculateClaimedHeadersWork(headers);
|
||||||
|
|
||||||
// Our dynamic anti-DoS threshold (minimum work required on a headers chain
|
// Our dynamic anti-DoS threshold (minimum work required on a headers chain
|
||||||
// before we'll store it)
|
// before we'll store it)
|
||||||
|
@ -4424,7 +4424,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
MaybeSendGetHeaders(pfrom, GetLocator(m_chainman.m_best_header), *peer);
|
MaybeSendGetHeaders(pfrom, GetLocator(m_chainman.m_best_header), *peer);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
} else if (prev_block->nChainWork + CalculateHeadersWork({cmpctblock.header}) < GetAntiDoSWorkThreshold()) {
|
} else if (prev_block->nChainWork + CalculateClaimedHeadersWork({cmpctblock.header}) < GetAntiDoSWorkThreshold()) {
|
||||||
// If we get a low-work header in a compact block, we can ignore it.
|
// If we get a low-work header in a compact block, we can ignore it.
|
||||||
LogPrint(BCLog::NET, "Ignoring low-work compact block from peer %d\n", pfrom.GetId());
|
LogPrint(BCLog::NET, "Ignoring low-work compact block from peer %d\n", pfrom.GetId());
|
||||||
return;
|
return;
|
||||||
|
@ -4744,8 +4744,8 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
// cs_main in ProcessNewBlock is fine.
|
// cs_main in ProcessNewBlock is fine.
|
||||||
mapBlockSource.emplace(hash, std::make_pair(pfrom.GetId(), true));
|
mapBlockSource.emplace(hash, std::make_pair(pfrom.GetId(), true));
|
||||||
|
|
||||||
// Check work on this block against our anti-dos thresholds.
|
// Check claimed work on this block against our anti-dos thresholds.
|
||||||
if (prev_block && prev_block->nChainWork + CalculateHeadersWork({pblock->GetBlockHeader()}) >= GetAntiDoSWorkThreshold()) {
|
if (prev_block && prev_block->nChainWork + CalculateClaimedHeadersWork({pblock->GetBlockHeader()}) >= GetAntiDoSWorkThreshold()) {
|
||||||
min_pow_checked = true;
|
min_pow_checked = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -108,7 +108,7 @@ FUZZ_TARGET(headers_sync_state, .init = initialize_headers_sync_state_fuzz)
|
||||||
|
|
||||||
// If we get to redownloading, the presynced headers need
|
// If we get to redownloading, the presynced headers need
|
||||||
// to have the min amount of work on them.
|
// to have the min amount of work on them.
|
||||||
assert(CalculateHeadersWork(all_headers) >= min_work);
|
assert(CalculateClaimedHeadersWork(all_headers) >= min_work);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3895,7 +3895,7 @@ bool IsBlockMutated(const CBlock& block, bool check_witness_root)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
arith_uint256 CalculateHeadersWork(const std::vector<CBlockHeader>& headers)
|
arith_uint256 CalculateClaimedHeadersWork(const std::vector<CBlockHeader>& headers)
|
||||||
{
|
{
|
||||||
arith_uint256 total_work{0};
|
arith_uint256 total_work{0};
|
||||||
for (const CBlockHeader& header : headers) {
|
for (const CBlockHeader& header : headers) {
|
||||||
|
|
|
@ -382,8 +382,8 @@ bool HasValidProofOfWork(const std::vector<CBlockHeader>& headers, const Consens
|
||||||
/** Check if a block has been mutated (with respect to its merkle root and witness commitments). */
|
/** Check if a block has been mutated (with respect to its merkle root and witness commitments). */
|
||||||
bool IsBlockMutated(const CBlock& block, bool check_witness_root);
|
bool IsBlockMutated(const CBlock& block, bool check_witness_root);
|
||||||
|
|
||||||
/** Return the sum of the work on a given set of headers */
|
/** Return the sum of the claimed work on a given set of headers. No verification of PoW is done. */
|
||||||
arith_uint256 CalculateHeadersWork(const std::vector<CBlockHeader>& headers);
|
arith_uint256 CalculateClaimedHeadersWork(const std::vector<CBlockHeader>& headers);
|
||||||
|
|
||||||
enum class VerifyDBResult {
|
enum class VerifyDBResult {
|
||||||
SUCCESS,
|
SUCCESS,
|
||||||
|
|
Loading…
Add table
Reference in a new issue