@@ -286,8 +286,10 @@ bool CheckSequenceLocks(CBlockIndex* tip,
286
286
static unsigned int GetBlockScriptFlags (const CBlockIndex* pindex, const Consensus::Params& chainparams);
287
287
288
288
static void LimitMempoolSize (CTxMemPool& pool, CCoinsViewCache& coins_cache, size_t limit, std::chrono::seconds age)
289
- EXCLUSIVE_LOCKS_REQUIRED(pool.cs, ::cs_main)
289
+ EXCLUSIVE_LOCKS_REQUIRED(::cs_main, pool.cs )
290
290
{
291
+ AssertLockHeld (::cs_main);
292
+ AssertLockHeld (pool.cs );
291
293
int expired = pool.Expire (GetTime<std::chrono::seconds>() - age);
292
294
if (expired != 0 ) {
293
295
LogPrint (BCLog::MEMPOOL, " Expired %i transactions from the memory pool\n " , expired);
@@ -628,8 +630,10 @@ class MemPoolAccept
628
630
EXCLUSIVE_LOCKS_REQUIRED(cs_main, m_pool.cs);
629
631
630
632
// Compare a package's feerate against minimum allowed.
631
- bool CheckFeeRate (size_t package_size, CAmount package_fee, TxValidationState& state) EXCLUSIVE_LOCKS_REQUIRED(cs_main, m_pool.cs)
633
+ bool CheckFeeRate (size_t package_size, CAmount package_fee, TxValidationState& state) EXCLUSIVE_LOCKS_REQUIRED(:: cs_main, m_pool.cs)
632
634
{
635
+ AssertLockHeld (::cs_main);
636
+ AssertLockHeld (m_pool.cs );
633
637
CAmount mempoolRejectFee = m_pool.GetMinFee (gArgs .GetIntArg (" -maxmempool" , DEFAULT_MAX_MEMPOOL_SIZE) * 1000000 ).GetFee (package_size);
634
638
if (mempoolRejectFee > 0 && package_fee < mempoolRejectFee) {
635
639
return state.Invalid (TxValidationResult::TX_MEMPOOL_POLICY, " mempool min fee not met" , strprintf (" %d < %d" , package_fee, mempoolRejectFee));
@@ -663,6 +667,8 @@ class MemPoolAccept
663
667
664
668
bool MemPoolAccept::PreChecks (ATMPArgs& args, Workspace& ws)
665
669
{
670
+ AssertLockHeld (cs_main);
671
+ AssertLockHeld (m_pool.cs );
666
672
const CTransactionRef& ptx = ws.m_ptx ;
667
673
const CTransaction& tx = *ws.m_ptx ;
668
674
const uint256& hash = ws.m_hash ;
@@ -963,6 +969,8 @@ bool MemPoolAccept::PackageMempoolChecks(const std::vector<CTransactionRef>& txn
963
969
964
970
bool MemPoolAccept::PolicyScriptChecks (const ATMPArgs& args, Workspace& ws)
965
971
{
972
+ AssertLockHeld (cs_main);
973
+ AssertLockHeld (m_pool.cs );
966
974
const CTransaction& tx = *ws.m_ptx ;
967
975
TxValidationState& state = ws.m_state ;
968
976
@@ -989,6 +997,8 @@ bool MemPoolAccept::PolicyScriptChecks(const ATMPArgs& args, Workspace& ws)
989
997
990
998
bool MemPoolAccept::ConsensusScriptChecks (const ATMPArgs& args, Workspace& ws)
991
999
{
1000
+ AssertLockHeld (cs_main);
1001
+ AssertLockHeld (m_pool.cs );
992
1002
const CTransaction& tx = *ws.m_ptx ;
993
1003
const uint256& hash = ws.m_hash ;
994
1004
TxValidationState& state = ws.m_state ;
@@ -1021,6 +1031,8 @@ bool MemPoolAccept::ConsensusScriptChecks(const ATMPArgs& args, Workspace& ws)
1021
1031
1022
1032
bool MemPoolAccept::Finalize (const ATMPArgs& args, Workspace& ws)
1023
1033
{
1034
+ AssertLockHeld (cs_main);
1035
+ AssertLockHeld (m_pool.cs );
1024
1036
const CTransaction& tx = *ws.m_ptx ;
1025
1037
const uint256& hash = ws.m_hash ;
1026
1038
TxValidationState& state = ws.m_state ;
@@ -1342,8 +1354,9 @@ PackageMempoolAcceptResult MemPoolAccept::AcceptPackage(const Package& package,
1342
1354
1343
1355
MempoolAcceptResult AcceptToMemoryPool (CChainState& active_chainstate, const CTransactionRef& tx,
1344
1356
int64_t accept_time, bool bypass_limits, bool test_accept)
1345
- EXCLUSIVE_LOCKS_REQUIRED(cs_main)
1357
+ EXCLUSIVE_LOCKS_REQUIRED(:: cs_main)
1346
1358
{
1359
+ AssertLockHeld (::cs_main);
1347
1360
const CChainParams& chainparams{active_chainstate.m_params };
1348
1361
assert (active_chainstate.GetMempool () != nullptr );
1349
1362
CTxMemPool& pool{*active_chainstate.GetMempool ()};
@@ -1421,6 +1434,7 @@ CoinsViews::CoinsViews(
1421
1434
1422
1435
void CoinsViews::InitCache ()
1423
1436
{
1437
+ AssertLockHeld (::cs_main);
1424
1438
m_cacheview = std::make_unique<CCoinsViewCache>(&m_catcherview);
1425
1439
}
1426
1440
@@ -1451,6 +1465,7 @@ void CChainState::InitCoinsDB(
1451
1465
1452
1466
void CChainState::InitCoinsCache (size_t cache_size_bytes)
1453
1467
{
1468
+ AssertLockHeld (::cs_main);
1454
1469
assert (m_coins_views != nullptr );
1455
1470
m_coinstip_cache_size_bytes = cache_size_bytes;
1456
1471
m_coins_views->InitCache ();
@@ -1524,6 +1539,7 @@ void CChainState::CheckForkWarningConditions()
1524
1539
// Called both upon regular invalid block discovery *and* InvalidateBlock
1525
1540
void CChainState::InvalidChainFound (CBlockIndex* pindexNew)
1526
1541
{
1542
+ AssertLockHeld (cs_main);
1527
1543
if (!m_chainman.m_best_invalid || pindexNew->nChainWork > m_chainman.m_best_invalid ->nChainWork ) {
1528
1544
m_chainman.m_best_invalid = pindexNew;
1529
1545
}
@@ -1546,6 +1562,7 @@ void CChainState::InvalidChainFound(CBlockIndex* pindexNew)
1546
1562
// which does its own setBlockIndexCandidates management.
1547
1563
void CChainState::InvalidBlockFound (CBlockIndex* pindex, const BlockValidationState& state)
1548
1564
{
1565
+ AssertLockHeld (cs_main);
1549
1566
if (state.GetResult () != BlockValidationResult::BLOCK_MUTATED) {
1550
1567
pindex->nStatus |= BLOCK_FAILED_VALID;
1551
1568
m_chainman.m_failed_blocks .insert (pindex);
@@ -2210,6 +2227,7 @@ bool CChainState::ConnectBlock(const CBlock& block, BlockValidationState& state,
2210
2227
2211
2228
CoinsCacheSizeState CChainState::GetCoinsCacheSizeState ()
2212
2229
{
2230
+ AssertLockHeld (::cs_main);
2213
2231
return this ->GetCoinsCacheSizeState (
2214
2232
m_coinstip_cache_size_bytes,
2215
2233
gArgs .GetIntArg (" -maxmempool" , DEFAULT_MAX_MEMPOOL_SIZE) * 1000000 );
@@ -2219,6 +2237,7 @@ CoinsCacheSizeState CChainState::GetCoinsCacheSizeState(
2219
2237
size_t max_coins_cache_size_bytes,
2220
2238
size_t max_mempool_size_bytes)
2221
2239
{
2240
+ AssertLockHeld (::cs_main);
2222
2241
const int64_t nMempoolUsage = m_mempool ? m_mempool->DynamicMemoryUsage () : 0 ;
2223
2242
int64_t cacheSize = CoinsTip ().DynamicMemoryUsage ();
2224
2243
int64_t nTotalSpace =
@@ -2427,6 +2446,7 @@ static void UpdateTipLog(
2427
2446
2428
2447
void CChainState::UpdateTip (const CBlockIndex* pindexNew)
2429
2448
{
2449
+ AssertLockHeld (::cs_main);
2430
2450
const auto & coins_tip = this ->CoinsTip ();
2431
2451
2432
2452
// The remainder of the function isn't relevant if we are not acting on
@@ -2650,7 +2670,9 @@ bool CChainState::ConnectTip(BlockValidationState& state, CBlockIndex* pindexNew
2650
2670
* Return the tip of the chain with the most work in it, that isn't
2651
2671
* known to be invalid (it's however far from certain to be valid).
2652
2672
*/
2653
- CBlockIndex* CChainState::FindMostWorkChain () {
2673
+ CBlockIndex* CChainState::FindMostWorkChain ()
2674
+ {
2675
+ AssertLockHeld (::cs_main);
2654
2676
do {
2655
2677
CBlockIndex *pindexNew = nullptr ;
2656
2678
@@ -2854,7 +2876,7 @@ bool CChainState::ActivateBestChain(BlockValidationState& state, std::shared_ptr
2854
2876
// far from a guarantee. Things in the P2P/RPC will often end up calling
2855
2877
// us in the middle of ProcessNewBlock - do not assume pblock is set
2856
2878
// sanely for performance or correctness!
2857
- AssertLockNotHeld (cs_main);
2879
+ AssertLockNotHeld (:: cs_main);
2858
2880
2859
2881
// ABC maintains a fair degree of expensive-to-calculate internal state
2860
2882
// because this function periodically releases cs_main so that it does not lock up other threads for too long
@@ -2950,6 +2972,8 @@ bool CChainState::ActivateBestChain(BlockValidationState& state, std::shared_ptr
2950
2972
2951
2973
bool CChainState::PreciousBlock (BlockValidationState& state, CBlockIndex* pindex)
2952
2974
{
2975
+ AssertLockNotHeld (m_chainstate_mutex);
2976
+ AssertLockNotHeld (::cs_main);
2953
2977
{
2954
2978
LOCK (cs_main);
2955
2979
if (pindex->nChainWork < m_chain.Tip ()->nChainWork ) {
@@ -2980,6 +3004,7 @@ bool CChainState::PreciousBlock(BlockValidationState& state, CBlockIndex* pindex
2980
3004
bool CChainState::InvalidateBlock (BlockValidationState& state, CBlockIndex* pindex)
2981
3005
{
2982
3006
AssertLockNotHeld (m_chainstate_mutex);
3007
+ AssertLockNotHeld (::cs_main);
2983
3008
2984
3009
// Genesis block can't be invalidated
2985
3010
assert (pindex);
@@ -3158,6 +3183,7 @@ void CChainState::ResetBlockFailureFlags(CBlockIndex *pindex) {
3158
3183
/* * Mark a block as having its data received and checked (up to BLOCK_VALID_TRANSACTIONS). */
3159
3184
void CChainState::ReceivedBlockTransactions (const CBlock& block, CBlockIndex* pindexNew, const FlatFilePos& pos)
3160
3185
{
3186
+ AssertLockHeld (cs_main);
3161
3187
pindexNew->nTx = block.vtx .size ();
3162
3188
pindexNew->nChainTx = 0 ;
3163
3189
pindexNew->nFile = pos.nFile ;
@@ -3330,8 +3356,9 @@ std::vector<unsigned char> GenerateCoinbaseCommitment(CBlock& block, const CBloc
3330
3356
* in ConnectBlock().
3331
3357
* Note that -reindex-chainstate skips the validation that happens here!
3332
3358
*/
3333
- static bool ContextualCheckBlockHeader (const CBlockHeader& block, BlockValidationState& state, BlockManager& blockman, const CChainParams& params, const CBlockIndex* pindexPrev, int64_t nAdjustedTime) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
3359
+ static bool ContextualCheckBlockHeader (const CBlockHeader& block, BlockValidationState& state, BlockManager& blockman, const CChainParams& params, const CBlockIndex* pindexPrev, int64_t nAdjustedTime) EXCLUSIVE_LOCKS_REQUIRED(:: cs_main)
3334
3360
{
3361
+ AssertLockHeld (::cs_main);
3335
3362
assert (pindexPrev != nullptr );
3336
3363
const int nHeight = pindexPrev->nHeight + 1 ;
3337
3364
@@ -3702,6 +3729,7 @@ bool ChainstateManager::ProcessNewBlock(const CChainParams& chainparams, const s
3702
3729
3703
3730
MempoolAcceptResult ChainstateManager::ProcessTransaction (const CTransactionRef& tx, bool test_accept)
3704
3731
{
3732
+ AssertLockHeld (cs_main);
3705
3733
CChainState& active_chainstate = ActiveChainstate ();
3706
3734
if (!active_chainstate.GetMempool ()) {
3707
3735
TxValidationState state;
@@ -3915,6 +3943,7 @@ bool CVerifyDB::VerifyDB(
3915
3943
/* * Apply the effects of a block on the utxo cache, ignoring that it may already have been applied. */
3916
3944
bool CChainState::RollforwardBlock (const CBlockIndex* pindex, CCoinsViewCache& inputs)
3917
3945
{
3946
+ AssertLockHeld (cs_main);
3918
3947
// TODO: merge with ConnectBlock
3919
3948
CBlock block;
3920
3949
if (!ReadBlockFromDisk (block, pindex, m_params.GetConsensus ())) {
@@ -4018,7 +4047,9 @@ bool CChainState::NeedsRedownload() const
4018
4047
return false ;
4019
4048
}
4020
4049
4021
- void CChainState::UnloadBlockIndex () {
4050
+ void CChainState::UnloadBlockIndex ()
4051
+ {
4052
+ AssertLockHeld (::cs_main);
4022
4053
nBlockSequenceId = 1 ;
4023
4054
setBlockIndexCandidates.clear ();
4024
4055
}
@@ -4090,6 +4121,7 @@ bool CChainState::LoadGenesisBlock()
4090
4121
4091
4122
void CChainState::LoadExternalBlockFile (FILE* fileIn, FlatFilePos* dbp)
4092
4123
{
4124
+ AssertLockNotHeld (m_chainstate_mutex);
4093
4125
// Map of disk positions for blocks with unknown parent (only used for reindex)
4094
4126
static std::multimap<uint256, FlatFilePos> mapBlocksUnknownParent;
4095
4127
int64_t nStart = GetTimeMillis ();
@@ -4430,6 +4462,7 @@ void CChainState::CheckBlockIndex()
4430
4462
4431
4463
std::string CChainState::ToString ()
4432
4464
{
4465
+ AssertLockHeld (::cs_main);
4433
4466
CBlockIndex* tip = m_chain.Tip ();
4434
4467
return strprintf (" Chainstate [%s] @ height %d (%s)" ,
4435
4468
m_from_snapshot_blockhash ? " snapshot" : " ibd" ,
@@ -4438,6 +4471,7 @@ std::string CChainState::ToString()
4438
4471
4439
4472
bool CChainState::ResizeCoinsCaches (size_t coinstip_size, size_t coinsdb_size)
4440
4473
{
4474
+ AssertLockHeld (::cs_main);
4441
4475
if (coinstip_size == m_coinstip_cache_size_bytes &&
4442
4476
coinsdb_size == m_coinsdb_cache_size_bytes) {
4443
4477
// Cache sizes are unchanged, no need to continue.
@@ -4662,6 +4696,7 @@ std::vector<CChainState*> ChainstateManager::GetAll()
4662
4696
CChainState& ChainstateManager::InitializeChainstate (
4663
4697
CTxMemPool* mempool, const std::optional<uint256>& snapshot_blockhash)
4664
4698
{
4699
+ AssertLockHeld (::cs_main);
4665
4700
bool is_snapshot = snapshot_blockhash.has_value ();
4666
4701
std::unique_ptr<CChainState>& to_modify =
4667
4702
is_snapshot ? m_snapshot_chainstate : m_ibd_chainstate;
@@ -4999,6 +5034,7 @@ bool ChainstateManager::IsSnapshotActive() const
4999
5034
5000
5035
void ChainstateManager::Unload ()
5001
5036
{
5037
+ AssertLockHeld (::cs_main);
5002
5038
for (CChainState* chainstate : this ->GetAll ()) {
5003
5039
chainstate->m_chain .SetTip (nullptr );
5004
5040
chainstate->UnloadBlockIndex ();
@@ -5020,6 +5056,7 @@ void ChainstateManager::Reset()
5020
5056
5021
5057
void ChainstateManager::MaybeRebalanceCaches ()
5022
5058
{
5059
+ AssertLockHeld (::cs_main);
5023
5060
if (m_ibd_chainstate && !m_snapshot_chainstate) {
5024
5061
LogPrintf (" [snapshot] allocating all cache to the IBD chainstate\n " );
5025
5062
// Allocate everything to the IBD chainstate.
0 commit comments