Skip to content

Commit de4242f

Browse files
refactor: Use reference for chain_start in HeadersSyncState
chain_start can never be null, so it's better to pass it as a reference rather than a raw pointer Also slightly reformat HeaderSyncState constructor to make clang-format happy Lastly, remove `const` from `chain_start` declaration in headers_sync_chainwork_tests, to work aroud a false-positive dangling-reference warning in gcc 13.0 Co-Authored-By: maflcko <[email protected]>
1 parent e37555e commit de4242f

File tree

5 files changed

+34
-31
lines changed

5 files changed

+34
-31
lines changed

src/headerssync.cpp

Lines changed: 22 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -14,18 +14,21 @@
1414
// CompressedHeader (we should re-calculate parameters if we compress further).
1515
static_assert(sizeof(CompressedHeader) == 48);
1616

17-
HeadersSyncState::HeadersSyncState(NodeId id, const Consensus::Params& consensus_params,
18-
const HeadersSyncParams& params, const CBlockIndex* chain_start,
19-
const arith_uint256& minimum_required_work) :
20-
m_commit_offset((assert(params.commitment_period > 0), // HeadersSyncParams field must be initialized to non-zero.
21-
FastRandomContext().randrange(params.commitment_period))),
22-
m_id(id), m_consensus_params(consensus_params),
23-
m_params(params),
24-
m_chain_start(chain_start),
25-
m_minimum_required_work(minimum_required_work),
26-
m_current_chain_work(chain_start->nChainWork),
27-
m_last_header_received(m_chain_start->GetBlockHeader()),
28-
m_current_height(chain_start->nHeight)
17+
HeadersSyncState::HeadersSyncState(NodeId id,
18+
const Consensus::Params& consensus_params,
19+
const HeadersSyncParams& params,
20+
const CBlockIndex& chain_start,
21+
const arith_uint256& minimum_required_work)
22+
: m_commit_offset((assert(params.commitment_period > 0), // HeadersSyncParams field must be initialized to non-zero.
23+
FastRandomContext().randrange(params.commitment_period))),
24+
m_id(id),
25+
m_consensus_params(consensus_params),
26+
m_params(params),
27+
m_chain_start(chain_start),
28+
m_minimum_required_work(minimum_required_work),
29+
m_current_chain_work(chain_start.nChainWork),
30+
m_last_header_received(m_chain_start.GetBlockHeader()),
31+
m_current_height(chain_start.nHeight)
2932
{
3033
// Estimate the number of blocks that could possibly exist on the peer's
3134
// chain *right now* using 6 blocks/second (fastest blockrate given the MTP
@@ -35,7 +38,7 @@ HeadersSyncState::HeadersSyncState(NodeId id, const Consensus::Params& consensus
3538
// exceeds this bound, because it's not possible for a consensus-valid
3639
// chain to be longer than this (at the current time -- in the future we
3740
// could try again, if necessary, to sync a longer chain).
38-
const auto max_seconds_since_start{(Ticks<std::chrono::seconds>(NodeClock::now() - NodeSeconds{std::chrono::seconds{chain_start->GetMedianTimePast()}}))
41+
const auto max_seconds_since_start{(Ticks<std::chrono::seconds>(NodeClock::now() - NodeSeconds{std::chrono::seconds{chain_start.GetMedianTimePast()}}))
3942
+ MAX_FUTURE_BLOCK_TIME};
4043
m_max_commitments = 6 * max_seconds_since_start / m_params.commitment_period;
4144

@@ -161,10 +164,10 @@ bool HeadersSyncState::ValidateAndStoreHeadersCommitments(std::span<const CBlock
161164

162165
if (m_current_chain_work >= m_minimum_required_work) {
163166
m_redownloaded_headers.clear();
164-
m_redownload_buffer_last_height = m_chain_start->nHeight;
165-
m_redownload_buffer_first_prev_hash = m_chain_start->GetBlockHash();
166-
m_redownload_buffer_last_hash = m_chain_start->GetBlockHash();
167-
m_redownload_chain_work = m_chain_start->nChainWork;
167+
m_redownload_buffer_last_height = m_chain_start.nHeight;
168+
m_redownload_buffer_first_prev_hash = m_chain_start.GetBlockHash();
169+
m_redownload_buffer_last_hash = m_chain_start.GetBlockHash();
170+
m_redownload_chain_work = m_chain_start.nChainWork;
168171
m_download_state = State::REDOWNLOAD;
169172
LogDebug(BCLog::NET, "Initial headers sync transition with peer=%d: reached sufficient work at height=%i, redownloading from height=%i\n", m_id, m_current_height, m_redownload_buffer_last_height);
170173
}
@@ -228,7 +231,7 @@ bool HeadersSyncState::ValidateAndStoreRedownloadedHeader(const CBlockHeader& he
228231
if (!m_redownloaded_headers.empty()) {
229232
previous_nBits = m_redownloaded_headers.back().nBits;
230233
} else {
231-
previous_nBits = m_chain_start->nBits;
234+
previous_nBits = m_chain_start.nBits;
232235
}
233236

234237
if (!PermittedDifficultyTransition(m_consensus_params, next_height,
@@ -295,7 +298,7 @@ CBlockLocator HeadersSyncState::NextHeadersRequestLocator() const
295298
Assume(m_download_state != State::FINAL);
296299
if (m_download_state == State::FINAL) return {};
297300

298-
auto chain_start_locator = LocatorEntries(m_chain_start);
301+
auto chain_start_locator = LocatorEntries(&m_chain_start);
299302
std::vector<uint256> locator;
300303

301304
if (m_download_state == State::PRESYNC) {

src/headerssync.h

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -137,8 +137,8 @@ class HeadersSyncState {
137137
* minimum_required_work: amount of chain work required to accept the chain
138138
*/
139139
HeadersSyncState(NodeId id, const Consensus::Params& consensus_params,
140-
const HeadersSyncParams& params, const CBlockIndex* chain_start,
141-
const arith_uint256& minimum_required_work);
140+
const HeadersSyncParams& params, const CBlockIndex& chain_start,
141+
const arith_uint256& minimum_required_work);
142142

143143
/** Result data structure for ProcessNextHeaders. */
144144
struct ProcessingResult {
@@ -220,7 +220,7 @@ class HeadersSyncState {
220220
const HeadersSyncParams m_params;
221221

222222
/** Store the last block in our block index that the peer's chain builds from */
223-
const CBlockIndex* m_chain_start{nullptr};
223+
const CBlockIndex& m_chain_start;
224224

225225
/** Minimum work that we're looking for on this chain. */
226226
const arith_uint256 m_minimum_required_work;

src/net_processing.cpp

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -686,8 +686,8 @@ class PeerManagerImpl final : public PeerManager
686686
* calling); false otherwise.
687687
*/
688688
bool TryLowWorkHeadersSync(Peer& peer, CNode& pfrom,
689-
const CBlockIndex* chain_start_header,
690-
std::vector<CBlockHeader>& headers)
689+
const CBlockIndex& chain_start_header,
690+
std::vector<CBlockHeader>& headers)
691691
EXCLUSIVE_LOCKS_REQUIRED(!peer.m_headers_sync_mutex, !m_peer_mutex, !m_headers_presync_mutex, g_msgproc_mutex);
692692

693693
/** Return true if the given header is an ancestor of
@@ -2633,10 +2633,10 @@ bool PeerManagerImpl::IsContinuationOfLowWorkHeadersSync(Peer& peer, CNode& pfro
26332633
return false;
26342634
}
26352635

2636-
bool PeerManagerImpl::TryLowWorkHeadersSync(Peer& peer, CNode& pfrom, const CBlockIndex* chain_start_header, std::vector<CBlockHeader>& headers)
2636+
bool PeerManagerImpl::TryLowWorkHeadersSync(Peer& peer, CNode& pfrom, const CBlockIndex& chain_start_header, std::vector<CBlockHeader>& headers)
26372637
{
26382638
// Calculate the claimed total work on this chain.
2639-
arith_uint256 total_work = chain_start_header->nChainWork + CalculateClaimedHeadersWork(headers);
2639+
arith_uint256 total_work = chain_start_header.nChainWork + CalculateClaimedHeadersWork(headers);
26402640

26412641
// Our dynamic anti-DoS threshold (minimum work required on a headers chain
26422642
// before we'll store it)
@@ -2667,7 +2667,7 @@ bool PeerManagerImpl::TryLowWorkHeadersSync(Peer& peer, CNode& pfrom, const CBlo
26672667
// handled inside of IsContinuationOfLowWorkHeadersSync.
26682668
(void)IsContinuationOfLowWorkHeadersSync(peer, pfrom, headers);
26692669
} else {
2670-
LogDebug(BCLog::NET, "Ignoring low-work chain (height=%u) from peer=%d\n", chain_start_header->nHeight + headers.size(), pfrom.GetId());
2670+
LogDebug(BCLog::NET, "Ignoring low-work chain (height=%u) from peer=%d\n", chain_start_header.nHeight + headers.size(), pfrom.GetId());
26712671
}
26722672

26732673
// The peer has not yet given us a chain that meets our work threshold,
@@ -2933,7 +2933,7 @@ void PeerManagerImpl::ProcessHeadersMessage(CNode& pfrom, Peer& peer,
29332933
// Do anti-DoS checks to determine if we should process or store for later
29342934
// processing.
29352935
if (!already_validated_work && TryLowWorkHeadersSync(peer, pfrom,
2936-
chain_start_header, headers)) {
2936+
*chain_start_header, headers)) {
29372937
// If we successfully started a low-work headers sync, then there
29382938
// should be no headers to process any further.
29392939
Assume(headers.empty());

src/test/fuzz/headerssync.cpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ class FuzzedHeadersSyncState : public HeadersSyncState
4444
{
4545
public:
4646
FuzzedHeadersSyncState(const HeadersSyncParams& sync_params, const size_t commit_offset,
47-
const CBlockIndex* chain_start, const arith_uint256& minimum_required_work)
47+
const CBlockIndex& chain_start, const arith_uint256& minimum_required_work)
4848
: HeadersSyncState(/*id=*/0, Params().GetConsensus(), sync_params, chain_start, minimum_required_work)
4949
{
5050
const_cast<size_t&>(m_commit_offset) = commit_offset;
@@ -74,7 +74,7 @@ FUZZ_TARGET(headers_sync_state, .init = initialize_headers_sync_state_fuzz)
7474
FuzzedHeadersSyncState headers_sync(
7575
params,
7676
/*commit_offset=*/fuzzed_data_provider.ConsumeIntegralInRange<size_t>(0, params.commitment_period - 1),
77-
/*chain_start=*/&start_index,
77+
/*chain_start=*/start_index,
7878
/*minimum_required_work=*/min_work);
7979

8080
// Store headers for potential redownload phase.

src/test/headers_sync_chainwork_tests.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -52,7 +52,7 @@ constexpr size_t COMMITMENT_PERIOD{600}; // Somewhat close to mainnet.
5252

5353
struct HeadersGeneratorSetup : public RegTestingSetup {
5454
const CBlock& genesis{Params().GenesisBlock()};
55-
const CBlockIndex* chain_start{WITH_LOCK(::cs_main, return m_node.chainman->m_blockman.LookupBlockIndex(genesis.GetHash()))};
55+
CBlockIndex& chain_start{WITH_LOCK(::cs_main, return *Assert(m_node.chainman->m_blockman.LookupBlockIndex(genesis.GetHash())))};
5656

5757
// Generate headers for two different chains (using differing merkle roots
5858
// to ensure the headers are different).

0 commit comments

Comments
 (0)