mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 11:57:28 -03:00
refactor: De-globalize last notified header index
In future, users of the kernel library might run multiple chainstates in parallel, or create and destroy multiple chainstates over the lifetime of a process. Having static, mutable variables could lead to state inconsistencies in these scenarios.
This commit is contained in:
parent
3443943f86
commit
39f9b80fba
2 changed files with 5 additions and 3 deletions
|
@ -3409,16 +3409,15 @@ static bool NotifyHeaderTip(ChainstateManager& chainman) LOCKS_EXCLUDED(cs_main)
|
||||||
{
|
{
|
||||||
bool fNotify = false;
|
bool fNotify = false;
|
||||||
bool fInitialBlockDownload = false;
|
bool fInitialBlockDownload = false;
|
||||||
static CBlockIndex* pindexHeaderOld = nullptr;
|
|
||||||
CBlockIndex* pindexHeader = nullptr;
|
CBlockIndex* pindexHeader = nullptr;
|
||||||
{
|
{
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
pindexHeader = chainman.m_best_header;
|
pindexHeader = chainman.m_best_header;
|
||||||
|
|
||||||
if (pindexHeader != pindexHeaderOld) {
|
if (pindexHeader != chainman.m_last_notified_header) {
|
||||||
fNotify = true;
|
fNotify = true;
|
||||||
fInitialBlockDownload = chainman.IsInitialBlockDownload();
|
fInitialBlockDownload = chainman.IsInitialBlockDownload();
|
||||||
pindexHeaderOld = pindexHeader;
|
chainman.m_last_notified_header = pindexHeader;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Send block tip changed notifications without cs_main
|
// Send block tip changed notifications without cs_main
|
||||||
|
|
|
@ -1063,6 +1063,9 @@ public:
|
||||||
/** Best header we've seen so far (used for getheaders queries' starting points). */
|
/** Best header we've seen so far (used for getheaders queries' starting points). */
|
||||||
CBlockIndex* m_best_header GUARDED_BY(::cs_main){nullptr};
|
CBlockIndex* m_best_header GUARDED_BY(::cs_main){nullptr};
|
||||||
|
|
||||||
|
/** The last header for which a headerTip notification was issued. */
|
||||||
|
CBlockIndex* m_last_notified_header GUARDED_BY(::cs_main){nullptr};
|
||||||
|
|
||||||
//! 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…
Reference in a new issue