12 #include <validation.h>
20 template <
typename... Args>
21 static void FatalError(
const char* fmt,
const Args&... args)
26 AbortError(
_(
"A fatal internal error occurred, see debug.log for details"));
30 BaseIndex::DB::DB(
const fs::path& path,
size_t n_cache_size,
bool f_memory,
bool f_wipe,
bool f_obfuscate) :
31 CDBWrapper(path, n_cache_size, f_memory, f_wipe, f_obfuscate)
57 if (!
GetDB().ReadBestBlock(locator)) {
93 int64_t last_log_time = 0;
94 int64_t last_locator_write_time = 0;
116 FatalError(
"%s: Failed to rewind index %s to a previous chain tip",
120 pindex = pindex_next;
123 int64_t current_time =
GetTime();
125 LogPrintf(
"Syncing %s with block chain from height %d\n",
127 last_log_time = current_time;
132 last_locator_write_time = current_time;
139 FatalError(
"%s: Failed to read block %s from disk",
144 FatalError(
"%s: Failed to write block %s to index database",
162 return error(
"%s: Failed to commit latest %s state", __func__,
GetName());
197 if (!best_block_index) {
199 FatalError(
"%s: First block connected is not the genesis block (height=%d)",
210 LogPrintf(
"%s: WARNING: Block %s does not connect to an ancestor of "
211 "known best chain (tip=%s); not updating index\n",
216 if (best_block_index != pindex->
pprev && !
Rewind(best_block_index, pindex->
pprev)) {
217 FatalError(
"%s: Failed to rewind index %s to a previous chain tip",
226 FatalError(
"%s: Failed to write block %s to index",
238 const uint256& locator_tip_hash = locator.
vHave.front();
245 if (!locator_tip_index) {
246 FatalError(
"%s: First block (hash=%s) in locator was not found",
247 __func__, locator_tip_hash.
ToString());
258 LogPrintf(
"%s: WARNING: Locator contains block (hash=%s) not on known best "
259 "chain (tip=%s); not writing index locator\n",
260 __func__, locator_tip_hash.
ToString(),
290 LogPrintf(
"%s: %s is catching up on block notifications\n", __func__,
GetName());
static const CBlockIndex * NextSyncBlock(const CBlockIndex *pindex_prev) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
constexpr int64_t SYNC_LOG_INTERVAL
static void FatalError(const char *fmt, const Args &... args)
constexpr int64_t SYNC_LOCATOR_WRITE_INTERVAL
constexpr char DB_BEST_BLOCK
const CChainParams & Params()
Return the currently selected parameters.
void WriteBestBlock(CDBBatch &batch, const CBlockLocator &locator)
Write block locator of the chain that the txindex is in sync with.
DB(const fs::path &path, size_t n_cache_size, bool f_memory=false, bool f_wipe=false, bool f_obfuscate=false)
bool ReadBestBlock(CBlockLocator &locator) const
Read block locator of the chain that the txindex is in sync with.
void Stop()
Stops the instance from staying in sync with blockchain updates.
virtual bool Init()
Initialize internal state from the database and block index.
void BlockConnected(const std::shared_ptr< const CBlock > &block, const CBlockIndex *pindex) override
Notifies listeners of a block being connected.
bool BlockUntilSyncedToCurrentChain() const
Blocks the current thread until the index is caught up to the current state of the block chain.
void Start()
Start initializes the sync state and registers the instance as a ValidationInterface so that it stays...
virtual ~BaseIndex()
Destructor interrupts sync thread if running and blocks until it exits.
virtual bool CommitInternal(CDBBatch &batch)
Virtual method called internally by Commit that can be overridden to atomically commit more index sta...
std::atomic< bool > m_synced
Whether the index is in sync with the main chain.
CThreadInterrupt m_interrupt
IndexSummary GetSummary() const
Get a summary of the index and its state.
void ChainStateFlushed(const CBlockLocator &locator) override
Notifies listeners of the new active block chain on-disk.
std::thread m_thread_sync
bool Commit()
Write the current index state (eg.
virtual bool WriteBlock(const CBlock &block, const CBlockIndex *pindex)
Write update index entries for a newly connected block.
void ThreadSync()
Sync the index with the block index starting from the current best block.
virtual DB & GetDB() const =0
virtual bool Rewind(const CBlockIndex *current_tip, const CBlockIndex *new_tip)
Rewind index to an earlier chain tip during a chain reorg.
std::atomic< const CBlockIndex * > m_best_block_index
The last block in the chain that the index is in sync with.
virtual const char * GetName() const =0
Get the name of the index for display in logs.
The block chain is a tree shaped structure starting with the genesis block at the root,...
CBlockIndex * pprev
pointer to the index of the predecessor of this block
uint256 GetBlockHash() const
CBlockIndex * GetAncestor(int height)
Efficiently find an ancestor of this block.
int nHeight
height of the entry in the chain. The genesis block has height 0
CBlockIndex * Genesis() const
Returns the index entry for the genesis block of this chain, or nullptr if none.
CBlockIndex * Next(const CBlockIndex *pindex) const
Find the successor of a block in this chain, or nullptr if the given index is not found or is the tip...
CBlockIndex * Tip() const
Returns the index entry for the tip of this chain, or nullptr if none.
const Consensus::Params & GetConsensus() const
Batch of changes queued to be written to a CDBWrapper.
void Write(const K &key, const V &value)
std::string ToString() const
static void LogPrintf(const char *fmt, const Args &... args)
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Describes a place in the block chain to another node such that if the other node doesn't have the sam...
std::vector< uint256 > vHave
#define AssertLockNotHeld(cs)
bool error(const char *fmt, const Args &... args)
void TraceThread(const char *name, Callable func)
#define EXCLUSIVE_LOCKS_REQUIRED(...)
int64_t GetTime()
DEPRECATED Use either GetSystemTimeInSeconds (not mockable) or GetTime<T> (mockable)
bilingual_str _(const char *psz)
Translation function.
bilingual_str Untranslated(std::string original)
Mark a bilingual_str as untranslated.
constexpr auto AbortError
CChain & ChainActive()
Please prefer the identical ChainstateManager::ActiveChain.
bool ReadBlockFromDisk(CBlock &block, const FlatFilePos &pos, const Consensus::Params &consensusParams)
Functions for disk access for blocks.
AssertLockHeld(mempool.cs)
CBlockIndex * LookupBlockIndex(const uint256 &hash)
CBlockIndex * FindForkInGlobalIndex(const CChain &chain, const CBlockLocator &locator)
Find the last common block between the parameter chain and a locator.
void UnregisterValidationInterface(CValidationInterface *callbacks)
Unregister subscriber.
void RegisterValidationInterface(CValidationInterface *callbacks)
Register subscriber.
void SyncWithValidationInterfaceQueue()
This is a synonym for the following, which asserts certain locks are not held: std::promise<void> pro...
void SetMiscWarning(const bilingual_str &warning)