Bitcoin ABC 0.33.6
P2P Digital Currency
validation.h
Go to the documentation of this file.
1// Copyright (c) 2009-2010 Satoshi Nakamoto
2// Copyright (c) 2009-2019 The Bitcoin Core developers
3// Copyright (c) 2017-2020 The Bitcoin developers
4// Distributed under the MIT software license, see the accompanying
5// file COPYING or http://www.opensource.org/licenses/mit-license.php.
6
7#ifndef BITCOIN_VALIDATION_H
8#define BITCOIN_VALIDATION_H
9
10#if defined(HAVE_CONFIG_H)
11#include <config/bitcoin-config.h>
12#endif
13
14#include <arith_uint256.h>
15#include <attributes.h>
16#include <blockfileinfo.h>
18#include <chain.h>
19#include <common/bloom.h>
20#include <config.h>
21#include <consensus/amount.h>
22#include <consensus/consensus.h>
23#include <deploymentstatus.h>
24#include <disconnectresult.h>
25#include <flatfile.h>
26#include <kernel/chain.h>
27#include <kernel/chainparams.h>
29#include <kernel/cs_main.h>
30#include <node/blockstorage.h>
31#include <policy/packages.h>
32#include <script/script_error.h>
34#include <script/scriptcache.h>
35#include <script/sigcache.h>
36#include <shutdown.h>
37#include <sync.h>
38#include <txdb.h>
39#include <txmempool.h> // For CTxMemPool::cs
40#include <uint256.h>
41#include <util/check.h>
42#include <util/fs.h>
43#include <util/result.h>
44#include <util/time.h>
45#include <util/translation.h>
46
47#include <atomic>
48#include <cstdint>
49#include <map>
50#include <memory>
51#include <optional>
52#include <set>
53#include <string>
54#include <thread>
55#include <type_traits>
56#include <utility>
57#include <vector>
58
60class CChainParams;
61class Chainstate;
63class CScriptCheck;
64class CTxMemPool;
65class CTxUndo;
67
68struct ChainTxData;
69struct FlatFilePos;
71struct LockPoints;
72struct AssumeutxoData;
73namespace node {
74class SnapshotMetadata;
75} // namespace node
76namespace Consensus {
77struct Params;
78} // namespace Consensus
79namespace avalanche {
80class Processor;
81} // namespace avalanche
82namespace util {
83class SignalInterrupt;
84} // namespace util
85
86#define MIN_TRANSACTION_SIZE (::GetSerializeSize(CTransaction{}))
87
89static const int MAX_SCRIPTCHECK_THREADS = 15;
91static const int DEFAULT_SCRIPTCHECK_THREADS = 0;
92
93static const bool DEFAULT_PEERBLOOMFILTERS = true;
94
99static const unsigned int MIN_BLOCKS_TO_KEEP = 288;
100static const signed int DEFAULT_CHECKBLOCKS = 6;
101static constexpr int DEFAULT_CHECKLEVEL{3};
115static const uint64_t MIN_DISK_SPACE_FOR_BLOCK_FILES = 550 * 1024 * 1024;
116
119
121extern std::condition_variable g_best_block_cv;
123extern const CBlockIndex *g_best_block;
124
126extern const std::vector<std::string> CHECKLEVEL_DOC;
127
129private:
131 bool checkPoW : 1;
133
134public:
135 // Do full validation by default
136 explicit BlockValidationOptions(const Config &config);
137 explicit BlockValidationOptions(uint64_t _excessiveBlockSize,
138 bool _checkPow = true,
139 bool _checkMerkleRoot = true)
140 : excessiveBlockSize(_excessiveBlockSize), checkPoW(_checkPow),
141 checkMerkleRoot(_checkMerkleRoot) {}
142
143 BlockValidationOptions withCheckPoW(bool _checkPoW = true) const {
144 BlockValidationOptions ret = *this;
145 ret.checkPoW = _checkPoW;
146 return ret;
147 }
148
150 withCheckMerkleRoot(bool _checkMerkleRoot = true) const {
151 BlockValidationOptions ret = *this;
152 ret.checkMerkleRoot = _checkMerkleRoot;
153 return ret;
154 }
155
156 bool shouldValidatePoW() const { return checkPoW; }
158 uint64_t getExcessiveBlockSize() const { return excessiveBlockSize; }
159};
160
164void StartScriptCheckWorkerThreads(int threads_num);
165
170
171Amount GetBlockSubsidy(int nHeight, const Consensus::Params &consensusParams);
172
173bool FatalError(kernel::Notifications &notifications,
174 BlockValidationState &state, const std::string &strMessage,
175 const bilingual_str &userMessage = {});
176
181double GuessVerificationProgress(const ChainTxData &data,
182 const CBlockIndex *pindex);
183
185void PruneBlockFilesManual(Chainstate &active_chainstate,
186 int nManualPruneHeight);
187
188// clang-format off
211// clang-format on
214 enum class ResultType {
216 VALID,
218 INVALID,
220 MEMPOOL_ENTRY,
221 };
224
227
232 const std::optional<int64_t> m_vsize;
234 const std::optional<Amount> m_base_fees;
242 const std::optional<CFeeRate> m_effective_feerate;
249 const std::optional<std::vector<TxId>> m_txids_fee_calculations;
250
252 return MempoolAcceptResult(state);
253 }
254
256 FeeFailure(TxValidationState state, CFeeRate effective_feerate,
257 const std::vector<TxId> &txids_fee_calculations) {
258 return MempoolAcceptResult(state, effective_feerate,
259 txids_fee_calculations);
260 }
261
264 Success(int64_t vsize, Amount fees, CFeeRate effective_feerate,
265 const std::vector<TxId> &txids_fee_calculations) {
266 return MempoolAcceptResult(ResultType::VALID, vsize, fees,
267 effective_feerate, txids_fee_calculations);
268 }
269
274 static MempoolAcceptResult MempoolTx(int64_t vsize, Amount fees) {
275 return MempoolAcceptResult(vsize, fees);
276 }
277
278 // Private constructors. Use static methods MempoolAcceptResult::Success,
279 // etc. to construct.
280private:
283 : m_result_type(ResultType::INVALID), m_state(state),
284 m_base_fees(std::nullopt) {
285 // Can be invalid or error
286 Assume(!state.IsValid());
287 }
288
291 ResultType result_type, int64_t vsize, Amount fees,
292 CFeeRate effective_feerate,
293 const std::vector<TxId> &txids_fee_calculations)
294 : m_result_type(result_type), m_vsize{vsize}, m_base_fees(fees),
295 m_effective_feerate(effective_feerate),
296 m_txids_fee_calculations(txids_fee_calculations) {}
297
300 TxValidationState state, CFeeRate effective_feerate,
301 const std::vector<TxId> &txids_fee_calculations)
302 : m_result_type(ResultType::INVALID), m_state(state),
303 m_effective_feerate(effective_feerate),
304 m_txids_fee_calculations(txids_fee_calculations) {}
305
307 explicit MempoolAcceptResult(int64_t vsize, Amount fees)
308 : m_result_type(ResultType::MEMPOOL_ENTRY), m_vsize{vsize},
309 m_base_fees(fees) {}
310};
311
324 std::map<TxId, MempoolAcceptResult> m_tx_results;
325
328 std::map<TxId, MempoolAcceptResult> &&results)
329 : m_state{state}, m_tx_results(std::move(results)) {}
330
335 explicit PackageMempoolAcceptResult(const TxId &txid,
336 const MempoolAcceptResult &result)
337 : m_tx_results{{txid, result}} {}
338};
339
363AcceptToMemoryPool(Chainstate &active_chainstate, const CTransactionRef &tx,
364 int64_t accept_time, bool bypass_limits,
365 bool test_accept = false, unsigned int heightOverride = 0)
367
380ProcessNewPackage(Chainstate &active_chainstate, CTxMemPool &pool,
381 const Package &txns, bool test_accept)
383
389protected:
390 std::atomic<int64_t> remaining;
391
392public:
393 explicit CheckInputsLimiter(int64_t limit) : remaining(limit) {}
394
395 bool consume_and_check(int consumed) {
396 auto newvalue = (remaining -= consumed);
397 return newvalue >= 0;
398 }
399
400 bool check() { return remaining >= 0; }
401};
402
404public:
406
407 // Let's make this bad boy copiable.
409 : CheckInputsLimiter(rhs.remaining.load()) {}
410
412 remaining = rhs.remaining.load();
413 return *this;
414 }
415
417 TxSigCheckLimiter txLimiter;
418 // Historically, there has not been a transaction with more than 20k sig
419 // checks on testnet or mainnet, so this effectively disable sigchecks.
420 txLimiter.remaining = 20000;
421 return txLimiter;
422 }
423};
424
430private:
434
435public:
439
440 ValidationCache(size_t script_execution_cache_bytes,
441 size_t signature_cache_bytes);
442
445
449 }
450};
451
481bool CheckInputScripts(const CTransaction &tx, TxValidationState &state,
482 const CCoinsViewCache &view, const uint32_t flags,
483 bool sigCacheStore, bool scriptCacheStore,
484 const PrecomputedTransactionData &txdata,
485 ValidationCache &validation_cache, int &nSigChecksOut,
486 TxSigCheckLimiter &txLimitSigChecks,
487 CheckInputsLimiter *pBlockLimitSigChecks,
488 std::vector<CScriptCheck> *pvChecks)
490
494static inline bool
495CheckInputScripts(const CTransaction &tx, TxValidationState &state,
496 const CCoinsViewCache &view, const uint32_t flags,
497 bool sigCacheStore, bool scriptCacheStore,
498 const PrecomputedTransactionData &txdata,
499 ValidationCache &validation_cache, int &nSigChecksOut)
501 TxSigCheckLimiter nSigChecksTxLimiter;
502 return CheckInputScripts(
503 tx, state, view, flags, sigCacheStore, scriptCacheStore, txdata,
504 validation_cache, nSigChecksOut, nSigChecksTxLimiter, nullptr, nullptr);
505}
506
510void SpendCoins(CCoinsViewCache &view, const CTransaction &tx, CTxUndo &txundo,
511 int nHeight);
512
516void UpdateCoins(CCoinsViewCache &view, const CTransaction &tx, CTxUndo &txundo,
517 int nHeight);
518
523std::optional<std::vector<Coin>>
524GetSpentCoins(const CTransactionRef &ptx, const CCoinsViewCache &coins_view);
525
544std::optional<LockPoints> CalculateLockPointsAtTip(CBlockIndex *tip,
545 const CCoinsView &coins_view,
546 const CTransaction &tx);
547
557bool CheckSequenceLocksAtTip(CBlockIndex *tip, const LockPoints &lock_points);
558
567private:
569 const CTransaction *ptxTo;
570 unsigned int nIn;
571 uint32_t nFlags;
578
579public:
580 CScriptCheck(const CTxOut &outIn, const CTransaction &txToIn,
581 SignatureCache &signature_cache, unsigned int nInIn,
582 uint32_t nFlagsIn, bool cacheIn,
583 const PrecomputedTransactionData &txdataIn,
584 TxSigCheckLimiter *pTxLimitSigChecksIn = nullptr,
585 CheckInputsLimiter *pBlockLimitSigChecksIn = nullptr)
586 : m_tx_out(outIn), ptxTo(&txToIn), nIn(nInIn), nFlags(nFlagsIn),
587 cacheStore(cacheIn), txdata(txdataIn),
588 m_signature_cache(&signature_cache),
589 pTxLimitSigChecks(pTxLimitSigChecksIn),
590 pBlockLimitSigChecks(pBlockLimitSigChecksIn) {}
591
592 CScriptCheck(const CScriptCheck &) = delete;
596
597 std::optional<std::pair<ScriptError, std::string>> operator()();
598
600};
601
602// CScriptCheck is used a lot in std::vector, make sure that's efficient
603static_assert(std::is_nothrow_move_assignable_v<CScriptCheck>);
604static_assert(std::is_nothrow_move_constructible_v<CScriptCheck>);
605static_assert(std::is_nothrow_destructible_v<CScriptCheck>);
606
615bool CheckBlock(const CBlock &block, BlockValidationState &state,
616 const Consensus::Params &params,
617 BlockValidationOptions validationOptions);
618
624 BlockValidationState &state, const CChainParams &params,
625 Chainstate &chainstate, const CBlock &block, CBlockIndex *pindexPrev,
626 const std::function<NodeClock::time_point()> &adjusted_time_callback,
628
632bool HasValidProofOfWork(const std::vector<CBlockHeader> &headers,
633 const Consensus::Params &consensusParams);
634
638bool IsBlockMutated(const CBlock &block);
639
641arith_uint256 CalculateHeadersWork(const std::vector<CBlockHeader> &headers);
642
643enum class VerifyDBResult {
644 SUCCESS,
646 INTERRUPTED,
649};
650
656private:
658
659public:
661
662public:
663 explicit CVerifyDB(kernel::Notifications &notifications);
664 ~CVerifyDB();
665
666 [[nodiscard]] VerifyDBResult VerifyDB(Chainstate &chainstate,
667 CCoinsView &coinsview,
668 int nCheckLevel, int nCheckDepth)
670};
671
673enum class FlushStateMode { NONE, IF_NEEDED, PERIODIC, ALWAYS };
674
685public:
689
693
696 std::unique_ptr<CCoinsViewCache> m_cacheview GUARDED_BY(cs_main);
697
701 std::unique_ptr<CCoinsViewCache> m_connect_block_view GUARDED_BY(cs_main);
702
711 CoinsViews(DBParams db_params, CoinsViewOptions options);
712
714 void InitCache() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
715};
716
719 CRITICAL = 2,
721 LARGE = 1,
722 OK = 0
723};
724
740protected:
746
750
753 std::unique_ptr<CoinsViews> m_coins_views;
754
767 bool m_disabled GUARDED_BY(::cs_main){false};
768
770
775 const CBlockIndex *m_avalancheFinalizedBlockIndex
776 GUARDED_BY(cs_avalancheFinalizedBlockIndex) = nullptr;
777
784 CRollingBloomFilter m_filterParkingPoliciesApplied =
785 CRollingBloomFilter{1000, 0.000001};
786
787 CBlockIndex const *m_best_fork_tip = nullptr;
788 CBlockIndex const *m_best_fork_base = nullptr;
789
791 const CBlockIndex *m_cached_snapshot_base GUARDED_BY(::cs_main){nullptr};
792
793public:
797
802
803 explicit Chainstate(
804 CTxMemPool *mempool, node::BlockManager &blockman,
805 ChainstateManager &chainman,
806 std::optional<BlockHash> from_snapshot_blockhash = std::nullopt);
807
813
820 void InitCoinsDB(size_t cache_size_bytes, bool in_memory, bool should_wipe,
821 std::string leveldb_name = "chainstate");
822
825 void InitCoinsCache(size_t cache_size_bytes)
827
831 bool CanFlushToDisk() const EXCLUSIVE_LOCKS_REQUIRED(::cs_main) {
833 return m_coins_views && m_coins_views->m_cacheview;
834 }
835
839
846 const std::optional<BlockHash> m_from_snapshot_blockhash{};
847
853 const CBlockIndex *SnapshotBase() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
854
862 std::set<CBlockIndex *, CBlockIndexWorkComparator> setBlockIndexCandidates;
863
867 Assert(m_coins_views);
868 return *Assert(m_coins_views->m_cacheview);
869 }
870
874 return Assert(m_coins_views)->m_dbview;
875 }
876
878 CTxMemPool *GetMempool() { return m_mempool; }
879
885 return Assert(m_coins_views)->m_catcherview;
886 }
887
889 void ResetCoinsViews() { m_coins_views.reset(); }
890
892 bool HasCoinsViews() const { return (bool)m_coins_views; }
893
895 size_t m_coinsdb_cache_size_bytes{0};
896
898 size_t m_coinstip_cache_size_bytes{0};
899
902 bool ResizeCoinsCaches(size_t coinstip_size, size_t coinsdb_size)
904
916 bool FlushStateToDisk(BlockValidationState &state, FlushStateMode mode,
917 int nManualPruneHeight = 0);
918
920 void ForceFlushStateToDisk();
921
924 void PruneAndFlush();
925
946 bool ActivateBestChain(BlockValidationState &state,
947 std::shared_ptr<const CBlock> pblock = nullptr,
948 avalanche::Processor *const avalanche = nullptr)
949 EXCLUSIVE_LOCKS_REQUIRED(!m_chainstate_mutex,
950 !cs_avalancheFinalizedBlockIndex)
952
953 // Block (dis)connection on a given view:
954 DisconnectResult DisconnectBlock(const CBlock &block,
955 const CBlockIndex *pindex,
956 CCoinsViewCache &view)
958 bool ConnectBlock(const CBlock &block, BlockValidationState &state,
959 CBlockIndex *pindex, CCoinsViewCache &view,
961 Amount *blockFees = nullptr, bool fJustCheck = false)
963
964 // Apply the effects of a block disconnection on the UTXO set.
965 bool DisconnectTip(BlockValidationState &state,
966 DisconnectedBlockTransactions *disconnectpool)
968
969 // Manual block validity manipulation:
975 bool PreciousBlock(BlockValidationState &state, CBlockIndex *pindex,
976 avalanche::Processor *const avalanche = nullptr)
977 EXCLUSIVE_LOCKS_REQUIRED(!m_chainstate_mutex,
978 !cs_avalancheFinalizedBlockIndex)
983 EXCLUSIVE_LOCKS_REQUIRED(!m_chainstate_mutex,
984 !cs_avalancheFinalizedBlockIndex);
986 bool ParkBlock(BlockValidationState &state, CBlockIndex *pindex)
988 EXCLUSIVE_LOCKS_REQUIRED(!m_chainstate_mutex,
989 !cs_avalancheFinalizedBlockIndex);
990
994 bool AvalancheFinalizeBlock(CBlockIndex *pindex,
995 avalanche::Processor &avalanche)
996 EXCLUSIVE_LOCKS_REQUIRED(::cs_main, !cs_avalancheFinalizedBlockIndex);
997
1001 void ClearAvalancheFinalizedBlock()
1002 EXCLUSIVE_LOCKS_REQUIRED(!cs_avalancheFinalizedBlockIndex);
1003
1007 bool IsBlockAvalancheFinalized(const CBlockIndex *pindex) const
1008 EXCLUSIVE_LOCKS_REQUIRED(!cs_avalancheFinalizedBlockIndex);
1009
1011 void SetBlockFailureFlags(CBlockIndex *pindex)
1013
1015 void ResetBlockFailureFlags(CBlockIndex *pindex)
1017 template <typename F>
1018 bool UpdateFlagsForBlock(CBlockIndex *pindexBase, CBlockIndex *pindex, F f)
1020 template <typename F, typename C, typename AC>
1021 void UpdateFlags(CBlockIndex *pindex, CBlockIndex *&pindexReset, F f,
1022 C fChild, AC fAncestorWasChanged)
1024
1026 void UnparkBlockAndChildren(CBlockIndex *pindex)
1028
1030 void UnparkBlock(CBlockIndex *pindex) EXCLUSIVE_LOCKS_REQUIRED(cs_main);
1031
1033 bool ReplayBlocks();
1034
1039 bool LoadGenesisBlock();
1040
1041 void TryAddBlockIndexCandidate(CBlockIndex *pindex)
1043
1044 void PruneBlockIndexCandidates();
1045
1046 void ClearBlockIndexCandidates() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
1047
1049 const CBlockIndex *FindForkInGlobalIndex(const CBlockLocator &locator) const
1051
1053 void
1054 LoadMempool(const fs::path &load_path,
1055 fsbridge::FopenFn mockable_fopen_function = fsbridge::fopen);
1056
1059 bool LoadChainTip() EXCLUSIVE_LOCKS_REQUIRED(cs_main);
1060
1064 CoinsCacheSizeState GetCoinsCacheSizeState()
1066
1068 GetCoinsCacheSizeState(size_t max_coins_cache_size_bytes,
1069 size_t max_mempool_size_bytes)
1071
1073
1076 RecursiveMutex *MempoolMutex() const LOCK_RETURNED(m_mempool->cs) {
1077 return m_mempool ? &m_mempool->cs : nullptr;
1078 }
1079
1080private:
1081 bool ActivateBestChainStep(
1082 BlockValidationState &state, CBlockIndex *pindexMostWork,
1083 const std::shared_ptr<const CBlock> &pblock, bool &fInvalidFound,
1084 const avalanche::Processor *const avalanche = nullptr,
1087 !cs_avalancheFinalizedBlockIndex);
1088 bool ConnectTip(BlockValidationState &state,
1089 BlockPolicyValidationState &blockPolicyState,
1090 CBlockIndex *pindexNew,
1091 const std::shared_ptr<const CBlock> &pblock,
1092 DisconnectedBlockTransactions &disconnectpool,
1093 const avalanche::Processor *const avalanche = nullptr,
1094 ChainstateRole chainstate_role = ChainstateRole::NORMAL)
1096 !cs_avalancheFinalizedBlockIndex);
1097 void InvalidBlockFound(CBlockIndex *pindex,
1098 const BlockValidationState &state)
1099 EXCLUSIVE_LOCKS_REQUIRED(cs_main, !cs_avalancheFinalizedBlockIndex);
1100 CBlockIndex *
1101 FindMostWorkChain(std::vector<const CBlockIndex *> &blocksToReconcile,
1102 bool fAutoUnpark)
1103 EXCLUSIVE_LOCKS_REQUIRED(cs_main, !cs_avalancheFinalizedBlockIndex);
1104
1105 bool RollforwardBlock(const CBlockIndex *pindex, CCoinsViewCache &inputs)
1107
1108 void UnparkBlockImpl(CBlockIndex *pindex, bool fClearChildren)
1110
1111 bool UnwindBlock(BlockValidationState &state, CBlockIndex *pindex,
1112 bool invalidate)
1113 EXCLUSIVE_LOCKS_REQUIRED(m_chainstate_mutex,
1114 !cs_avalancheFinalizedBlockIndex);
1115
1116 void CheckForkWarningConditions() EXCLUSIVE_LOCKS_REQUIRED(cs_main);
1117 void CheckForkWarningConditionsOnNewFork(CBlockIndex *pindexNewForkTip)
1119 void InvalidChainFound(CBlockIndex *pindexNew)
1120 EXCLUSIVE_LOCKS_REQUIRED(cs_main, !cs_avalancheFinalizedBlockIndex);
1121
1122 const CBlockIndex *FindBlockToFinalize(CBlockIndex *pindexNew)
1124
1128 void UpdateTip(const CBlockIndex *pindexNew)
1130
1131 NodeClock::time_point m_next_write{NodeClock::time_point::max()};
1132
1137 [[nodiscard]] util::Result<void> InvalidateCoinsDBOnDisk()
1139
1141};
1142
1144 SUCCESS,
1145 SKIPPED,
1146
1147 // Expected assumeutxo configuration data is not found for the height of the
1148 // base block.
1150
1151 // Failed to generate UTXO statistics (to check UTXO set hash) for the
1152 // background chainstate.
1154
1155 // The UTXO set hash of the background validation chainstate does not match
1156 // the one expected by assumeutxo chainparams.
1158
1159 // The blockhash of the current tip of the background validation chainstate
1160 // does not match the one expected by the snapshot chainstate.
1162};
1163
1192private:
1208 std::unique_ptr<Chainstate> m_ibd_chainstate GUARDED_BY(::cs_main);
1209
1219 std::unique_ptr<Chainstate> m_snapshot_chainstate GUARDED_BY(::cs_main);
1220
1227 Chainstate *m_active_chainstate GUARDED_BY(::cs_main){nullptr};
1228
1229 CBlockIndex *m_best_invalid GUARDED_BY(::cs_main){nullptr};
1230 CBlockIndex *m_best_parked GUARDED_BY(::cs_main){nullptr};
1231
1239 [[nodiscard]] bool
1240 PopulateAndValidateSnapshot(Chainstate &snapshot_chainstate,
1241 AutoFile &coins_file,
1242 const node::SnapshotMetadata &metadata);
1251 bool AcceptBlockHeader(
1252 const CBlockHeader &block, BlockValidationState &state,
1253 CBlockIndex **ppindex, bool min_pow_checked,
1254 const std::optional<CCheckpointData> &test_checkpoints = std::nullopt)
1257
1263 bool IsUsable(const Chainstate *const pchainstate) const
1265 return pchainstate && !pchainstate->m_disabled;
1266 }
1267
1269 SteadyMilliseconds m_last_presync_update GUARDED_BY(::cs_main){};
1270
1271public:
1273
1274 explicit ChainstateManager(const util::SignalInterrupt &interrupt,
1275 Options options,
1276 node::BlockManager::Options blockman_options);
1277
1280 std::function<void()> snapshot_download_completed = std::function<void()>();
1281
1282 const Config &GetConfig() const { return m_options.config; }
1283
1284 const CChainParams &GetParams() const {
1285 return m_options.config.GetChainParams();
1286 }
1288 return m_options.config.GetChainParams().GetConsensus();
1289 }
1291 return *Assert(m_options.check_block_index);
1292 }
1294 return *Assert(m_options.minimum_chain_work);
1295 }
1297 return *Assert(m_options.assumed_valid_block);
1298 }
1300 return m_options.notifications;
1301 }
1302 int StopAtHeight() const { return m_options.stop_at_height; }
1303
1310 void CheckBlockIndex();
1311
1325 }
1326
1329 std::thread m_thread_load;
1333
1335
1343 mutable std::atomic<bool> m_cached_finished_ibd{false};
1344
1350 std::atomic<int32_t> nBlockSequenceId{1};
1351
1353 int32_t nBlockReverseSequenceId = -1;
1355 arith_uint256 nLastPreciousChainwork = 0;
1356
1357 // Reset the memory-only sequence counters we use to track block arrival
1358 // (used by tests to reset state)
1361 nBlockSequenceId = 1;
1362 nBlockReverseSequenceId = -1;
1363 }
1364
1384 std::set<CBlockIndex *> m_failed_blocks;
1385
1390 CBlockIndex *m_best_header GUARDED_BY(::cs_main){nullptr};
1391
1394 size_t m_total_coinstip_cache{0};
1395 //
1398 size_t m_total_coinsdb_cache{0};
1399
1403 // constructor
1404 Chainstate &InitializeChainstate(CTxMemPool *mempool)
1406
1408 std::vector<Chainstate *> GetAll();
1409
1423 [[nodiscard]] util::Result<CBlockIndex *>
1424 ActivateSnapshot(AutoFile &coins_file,
1425 const node::SnapshotMetadata &metadata, bool in_memory);
1426
1434 SnapshotCompletionResult MaybeCompleteSnapshotValidation()
1436
1438 const CBlockIndex *GetSnapshotBaseBlock() const
1440
1442 Chainstate &ActiveChainstate() const;
1443 CChain &ActiveChain() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex()) {
1444 return ActiveChainstate().m_chain;
1445 }
1446 int ActiveHeight() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex()) {
1447 return ActiveChain().Height();
1448 }
1450 return ActiveChain().Tip();
1451 }
1452
1453 const CBlockIndex *GetAvalancheFinalizedTip() const;
1454
1457 return IsUsable(m_snapshot_chainstate.get()) &&
1458 IsUsable(m_ibd_chainstate.get());
1459 }
1460
1463 EXCLUSIVE_LOCKS_REQUIRED(GetMutex()) {
1464 return BackgroundSyncInProgress() ? m_ibd_chainstate->m_chain.Tip()
1465 : nullptr;
1466 }
1467
1470 return m_blockman.m_block_index;
1471 }
1472
1475 bool IsSnapshotActive() const;
1476
1477 std::optional<BlockHash> SnapshotBlockhash() const;
1478
1481 return m_snapshot_chainstate && m_ibd_chainstate &&
1482 m_ibd_chainstate->m_disabled;
1483 }
1484
1489 bool IsInitialBlockDownload() const;
1490
1522 void LoadExternalBlockFile(AutoFile &file_in, FlatFilePos *dbp = nullptr,
1523 std::multimap<BlockHash, FlatFilePos>
1524 *blocks_with_unknown_parent = nullptr,
1525 avalanche::Processor *const avalanche = nullptr);
1526
1554 bool ProcessNewBlock(const std::shared_ptr<const CBlock> &block,
1555 bool force_processing, bool min_pow_checked,
1556 bool *new_block,
1557 avalanche::Processor *const avalanche = nullptr)
1559
1575 bool ProcessNewBlockHeaders(
1576 const std::vector<CBlockHeader> &block, bool min_pow_checked,
1577 BlockValidationState &state, const CBlockIndex **ppindex = nullptr,
1578 const std::optional<CCheckpointData> &test_checkpoints = std::nullopt)
1580
1599 bool AcceptBlock(const std::shared_ptr<const CBlock> &pblock,
1600 BlockValidationState &state, bool fRequested,
1601 const FlatFilePos *dbp, bool *fNewBlock,
1602 bool min_pow_checked) EXCLUSIVE_LOCKS_REQUIRED(cs_main);
1603
1604 void ReceivedBlockTransactions(const CBlock &block, CBlockIndex *pindexNew,
1605 const FlatFilePos &pos)
1607
1616 [[nodiscard]] MempoolAcceptResult
1617 ProcessTransaction(const CTransactionRef &tx, bool test_accept = false)
1619
1622 bool LoadBlockIndex() EXCLUSIVE_LOCKS_REQUIRED(cs_main);
1623
1626 void MaybeRebalanceCaches() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
1627
1634 void ReportHeadersPresync(const arith_uint256 &work, int64_t height,
1635 int64_t timestamp);
1636
1639 bool DetectSnapshotChainstate(CTxMemPool *mempool)
1641
1642 void ResetChainstates() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
1643
1646 [[nodiscard]] bool DeleteSnapshotChainstate()
1648
1651 Chainstate &ActivateExistingSnapshot(BlockHash base_blockhash)
1653
1663 bool ValidatedSnapshotCleanup() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
1664
1673 Chainstate &GetChainstateForIndexing() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
1674
1678 std::pair<int, int> GetPruneRange(const Chainstate &chainstate,
1679 int last_height_can_prune)
1681
1684 std::optional<int> GetSnapshotBaseHeight() const
1686
1690 void RecalculateBestHeader() EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
1691
1693 bool DumpRecentHeadersTime(const fs::path &filePath) const
1694 EXCLUSIVE_LOCKS_REQUIRED(GetMutex());
1696 bool LoadRecentHeadersTime(const fs::path &filePath)
1697 EXCLUSIVE_LOCKS_REQUIRED(GetMutex());
1698};
1699
1701template <typename DEP>
1702bool DeploymentActiveAfter(const CBlockIndex *pindexPrev,
1703 const ChainstateManager &chainman, DEP dep) {
1704 return DeploymentActiveAfter(pindexPrev, chainman.GetConsensus(), dep);
1705}
1706
1707template <typename DEP>
1709 const ChainstateManager &chainman, DEP dep) {
1710 return DeploymentActiveAt(index, chainman.GetConsensus(), dep);
1711}
1712
1713#endif // BITCOIN_VALIDATION_H
int flags
Definition: bitcoin-tx.cpp:546
static void InvalidateBlock(ChainstateManager &chainman, avalanche::Processor *const avalanche, const BlockHash &block_hash)
const CChainParams & Params()
Return the currently selected parameters.
Definition: chainparams.cpp:21
#define Assert(val)
Identity function.
Definition: check.h:84
#define Assume(val)
Assume is the identity function.
Definition: check.h:97
Non-refcounted RAII wrapper for FILE*.
Definition: streams.h:430
uint64_t getExcessiveBlockSize() const
Definition: validation.h:158
BlockValidationOptions withCheckPoW(bool _checkPoW=true) const
Definition: validation.h:143
BlockValidationOptions(uint64_t _excessiveBlockSize, bool _checkPow=true, bool _checkMerkleRoot=true)
Definition: validation.h:137
BlockValidationOptions withCheckMerkleRoot(bool _checkMerkleRoot=true) const
Definition: validation.h:150
BlockValidationOptions(const Config &config)
Definition: validation.cpp:121
bool shouldValidatePoW() const
Definition: validation.h:156
uint64_t excessiveBlockSize
Definition: validation.h:130
bool shouldValidateMerkleRoot() const
Definition: validation.h:157
Nodes collect new transactions into a block, hash them into a hash tree, and scan through nonce value...
Definition: block.h:23
Definition: block.h:60
The block chain is a tree shaped structure starting with the genesis block at the root,...
Definition: blockindex.h:25
An in-memory indexed chain of blocks.
Definition: chain.h:138
CChainParams defines various tweakable parameters of a given instance of the Bitcoin system.
Definition: chainparams.h:86
CCoinsView that adds a memory cache for transactions to another CCoinsView.
Definition: coins.h:358
CCoinsView backed by the coin database (chainstate/)
Definition: txdb.h:49
This is a minimally invasive approach to shutdown on LevelDB read errors from the chainstate,...
Definition: coins.h:551
Abstract view on the open txout dataset.
Definition: coins.h:304
Fee rate in satoshis per kilobyte: Amount / kB.
Definition: feerate.h:21
RollingBloomFilter is a probabilistic "keep track of most recently inserted" set.
Definition: bloom.h:115
A hasher class for SHA-256.
Definition: sha256.h:13
Closure representing one script verification.
Definition: validation.h:566
CScriptCheck & operator=(CScriptCheck &&)=default
SignatureCache * m_signature_cache
Definition: validation.h:575
ScriptExecutionMetrics GetScriptExecutionMetrics() const
Definition: validation.h:599
CScriptCheck(const CScriptCheck &)=delete
uint32_t nFlags
Definition: validation.h:571
TxSigCheckLimiter * pTxLimitSigChecks
Definition: validation.h:576
ScriptExecutionMetrics metrics
Definition: validation.h:573
CTxOut m_tx_out
Definition: validation.h:568
CScriptCheck(CScriptCheck &&)=default
CScriptCheck(const CTxOut &outIn, const CTransaction &txToIn, SignatureCache &signature_cache, unsigned int nInIn, uint32_t nFlagsIn, bool cacheIn, const PrecomputedTransactionData &txdataIn, TxSigCheckLimiter *pTxLimitSigChecksIn=nullptr, CheckInputsLimiter *pBlockLimitSigChecksIn=nullptr)
Definition: validation.h:580
bool cacheStore
Definition: validation.h:572
std::optional< std::pair< ScriptError, std::string > > operator()()
PrecomputedTransactionData txdata
Definition: validation.h:574
const CTransaction * ptxTo
Definition: validation.h:569
unsigned int nIn
Definition: validation.h:570
CheckInputsLimiter * pBlockLimitSigChecks
Definition: validation.h:577
CScriptCheck & operator=(const CScriptCheck &)=delete
CTxMemPool stores valid-according-to-the-current-best-chain transactions that may be included in the ...
Definition: txmempool.h:221
RecursiveMutex cs
This mutex needs to be locked when accessing mapTx or other members that are guarded by it.
Definition: txmempool.h:317
An output of a transaction.
Definition: transaction.h:128
Restore the UTXO in a Coin at a given COutPoint.
Definition: undo.h:61
RAII wrapper for VerifyDB: Verify consistency of the block and coin databases.
Definition: validation.h:655
VerifyDBResult VerifyDB(Chainstate &chainstate, CCoinsView &coinsview, int nCheckLevel, int nCheckDepth) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
kernel::Notifications & m_notifications
Definition: validation.h:657
Chainstate stores and provides an API to update our local knowledge of the current best chain.
Definition: validation.h:739
Mutex m_chainstate_mutex
The ChainState Mutex.
Definition: validation.h:745
CChain m_chain
The current chain of blockheaders we consult and build on.
Definition: validation.h:838
bool HasCoinsViews() const
Does this chainstate have a UTXO set attached?
Definition: validation.h:892
CTxMemPool * GetMempool()
Definition: validation.h:878
CCoinsViewErrorCatcher & CoinsErrorCatcher() EXCLUSIVE_LOCKS_REQUIRED(cs_main)
Definition: validation.h:882
Mutex cs_avalancheFinalizedBlockIndex
Definition: validation.h:769
CTxMemPool * m_mempool
Optional mempool that is kept in sync with the chain.
Definition: validation.h:749
bool m_disabled GUARDED_BY(::cs_main)
This toggle exists for use when doing background validation for UTXO snapshots.
Definition: validation.h:767
CCoinsViewDB & CoinsDB() EXCLUSIVE_LOCKS_REQUIRED(
Definition: validation.h:872
ChainstateManager & m_chainman
The chainstate manager that owns this chainstate.
Definition: validation.h:801
std::unique_ptr< CoinsViews > m_coins_views
Manages the UTXO set, which is a reflection of the contents of m_chain.
Definition: validation.h:753
void ResetCoinsViews()
Destructs all objects related to accessing the UTXO set.
Definition: validation.h:889
const CBlockIndex *m_avalancheFinalizedBlockIndex GUARDED_BY(cs_avalancheFinalizedBlockIndex)
The best block via avalanche voting.
node::BlockManager & m_blockman
Reference to a BlockManager instance which itself is shared across all Chainstate instances.
Definition: validation.h:796
const CBlockIndex *m_cached_snapshot_base GUARDED_BY(::cs_main)
Cached result of LookupBlockIndex(*m_from_snapshot_blockhash)
Definition: validation.h:791
Provides an interface for creating and interacting with one or two chainstates: an IBD chainstate gen...
Definition: validation.h:1191
std::unique_ptr< Chainstate > m_ibd_chainstate GUARDED_BY(::cs_main)
The chainstate used under normal operation (i.e.
node::BlockMap & BlockIndex() EXCLUSIVE_LOCKS_REQUIRED(
Definition: validation.h:1468
CBlockIndex *m_best_header GUARDED_BY(::cs_main)
Best header we've seen so far (used for getheaders queries' starting points).
Definition: validation.h:1390
ValidationCache m_validation_cache
Definition: validation.h:1334
const Config & GetConfig() const
Definition: validation.h:1282
const CBlockIndex * GetBackgroundSyncTip() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex())
The tip of the background sync chain.
Definition: validation.h:1462
std::thread m_thread_load
Definition: validation.h:1329
kernel::Notifications & GetNotifications() const
Definition: validation.h:1299
SteadyMilliseconds m_last_presync_update GUARDED_BY(::cs_main)
Most recent headers presync progress update, for rate-limiting.
Definition: validation.h:1269
bool ShouldCheckBlockIndex() const
Definition: validation.h:1290
RecursiveMutex & GetMutex() const LOCK_RETURNED(
Alias for cs_main.
Definition: validation.h:1323
bool IsSnapshotValidated() const EXCLUSIVE_LOCKS_REQUIRED(
Is there a snapshot in use and has it been fully validated?
Definition: validation.h:1480
bool IsUsable(const Chainstate *const pchainstate) const EXCLUSIVE_LOCKS_REQUIRED(
Return true if a chainstate is considered usable.
Definition: validation.h:1263
CBlockIndex * ActiveTip() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex())
Definition: validation.h:1449
CBlockIndex *m_best_invalid GUARDED_BY(::cs_main)
Definition: validation.h:1229
bool BackgroundSyncInProgress() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex())
The state of a background sync (for net processing)
Definition: validation.h:1456
const util::SignalInterrupt & m_interrupt
Definition: validation.h:1327
int ActiveHeight() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex())
Definition: validation.h:1446
int StopAtHeight() const
Definition: validation.h:1302
const CChainParams & GetParams() const
Definition: validation.h:1284
const Consensus::Params & GetConsensus() const
Definition: validation.h:1287
CBlockIndex *m_best_parked GUARDED_BY(::cs_main)
Definition: validation.h:1230
const arith_uint256 & MinimumChainWork() const
Definition: validation.h:1293
const Options m_options
Definition: validation.h:1328
Chainstate *m_active_chainstate GUARDED_BY(::cs_main)
Points to either the ibd or snapshot chainstate; indicates our most-work chain.
Definition: validation.h:1227
const BlockHash & AssumedValidBlock() const
Definition: validation.h:1296
Chainstate &InitializeChainstate(CTxMemPool *mempool) EXCLUSIVE_LOCKS_REQUIRED(std::vector< Chainstate * GetAll)()
Instantiate a new chainstate.
Definition: validation.h:1408
std::set< CBlockIndex * > m_failed_blocks
In order to efficiently track invalidity of headers, we keep the set of blocks which we tried to conn...
Definition: validation.h:1384
std::unique_ptr< Chainstate > m_snapshot_chainstate GUARDED_BY(::cs_main)
A chainstate initialized on the basis of a UTXO snapshot.
void ResetBlockSequenceCounters() EXCLUSIVE_LOCKS_REQUIRED(
Definition: validation.h:1359
node::BlockManager m_blockman
A single BlockManager instance is shared across each constructed chainstate to avoid duplicating bloc...
Definition: validation.h:1332
Simple class for regulating resource usage during CheckInputScripts (and CScriptCheck),...
Definition: validation.h:388
bool consume_and_check(int consumed)
Definition: validation.h:395
std::atomic< int64_t > remaining
Definition: validation.h:390
CheckInputsLimiter(int64_t limit)
Definition: validation.h:393
A convenience class for constructing the CCoinsView* hierarchy used to facilitate access to the UTXO ...
Definition: validation.h:684
std::unique_ptr< CCoinsViewCache > m_cacheview GUARDED_BY(cs_main)
This is the top layer of the cache hierarchy - it keeps as many coins in memory as can fit per the db...
CCoinsViewErrorCatcher m_catcherview GUARDED_BY(cs_main)
This view wraps access to the leveldb instance and handles read errors gracefully.
std::unique_ptr< CCoinsViewCache > m_connect_block_view GUARDED_BY(cs_main)
Temporary CCoinsViewCache layered on top of m_cacheview and passed to ConnectBlock().
CCoinsViewDB m_dbview GUARDED_BY(cs_main)
The lowest level of the CoinsViews cache hierarchy sits in a leveldb database on disk.
CoinsViews(DBParams db_params, CoinsViewOptions options)
This constructor initializes CCoinsViewDB and CCoinsViewErrorCatcher instances, but it does not creat...
Definition: config.h:19
Different type to mark Mutex at global scope.
Definition: sync.h:144
Valid signature cache, to avoid doing expensive ECDSA signature checking twice for every transaction ...
Definition: sigcache.h:33
static TxSigCheckLimiter getDisabled()
Definition: validation.h:416
TxSigCheckLimiter & operator=(const TxSigCheckLimiter &rhs)
Definition: validation.h:411
TxSigCheckLimiter(const TxSigCheckLimiter &rhs)
Definition: validation.h:408
Convenience class for initializing and passing the script execution cache and signature cache.
Definition: validation.h:429
CuckooCache::cache< ScriptCacheElement, ScriptCacheHasher > m_script_execution_cache
Definition: validation.h:437
ValidationCache(size_t script_execution_cache_bytes, size_t signature_cache_bytes)
ValidationCache & operator=(const ValidationCache &)=delete
ValidationCache(const ValidationCache &)=delete
CSHA256 ScriptExecutionCacheHasher() const
Return a copy of the pre-initialized hasher.
Definition: validation.h:447
CSHA256 m_script_execution_cache_hasher
Pre-initialized hasher to avoid having to recreate it for every hash calculation.
Definition: validation.h:433
SignatureCache m_signature_cache
Definition: validation.h:438
bool IsValid() const
Definition: validation.h:119
256-bit unsigned big integer.
A base class defining functions for notifying about certain kernel events.
Maintains a tree of blocks (stored in m_block_index) which is consulted to determine where the most-w...
Definition: blockstorage.h:116
Metadata describing a serialized version of a UTXO set from which an assumeutxo Chainstate can be con...
Definition: utxo_snapshot.h:30
Helper class that manages an interrupt flag, and allows a thread or signal to interrupt another threa...
static const uint64_t MAX_TX_SIGCHECKS
Allowed number of signature check operations per transaction.
Definition: consensus.h:22
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition: cs_main.cpp:7
DisconnectResult
ChainstateRole
This enum describes the various roles a specific Chainstate instance can take.
Definition: chain.h:14
static void LoadExternalBlockFile(benchmark::Bench &bench)
The LoadExternalBlockFile() function is used during -reindex and -loadblock.
unsigned int nHeight
static void pool cs
Filesystem operations and types.
Definition: fs.h:20
Bridge operations to C stdio.
Definition: fs.cpp:28
FILE * fopen(const fs::path &p, const char *mode)
Definition: fs.cpp:30
std::function< FILE *(const fs::path &, const char *)> FopenFn
Definition: fs.h:204
bool LoadMempool(CTxMemPool &pool, const fs::path &load_path, Chainstate &active_chainstate, FopenFn mockable_fopen_function)
Definition: messages.h:12
std::unordered_map< BlockHash, CBlockIndex, BlockHasher > BlockMap
Definition: blockstorage.h:74
Implement std::hash so RCUPtr can be used as a key for maps or sets.
Definition: rcu.h:259
std::vector< CTransactionRef > Package
A package is an ordered list of transactions.
Definition: packages.h:40
std::shared_ptr< const CTransaction > CTransactionRef
Definition: transaction.h:315
static std::string ToString(const CService &ip)
Definition: db.h:36
@ OK
The message verification was successful.
Definition: amount.h:21
Holds configuration for use during UTXO snapshot load and validation.
Definition: chainparams.h:48
A BlockHash is a unqiue identifier for a block.
Definition: blockhash.h:13
Describes a place in the block chain to another node such that if the other node doesn't have the sam...
Definition: block.h:108
Holds various statistics on transactions within a chain.
Definition: chainparams.h:73
User-controlled performance and debug options.
Definition: txdb.h:40
Parameters that influence chain consensus.
Definition: params.h:34
Application-specific storage settings.
Definition: dbwrapper.h:31
Validation result for a transaction evaluated by MemPoolAccept (single or package).
Definition: validation.h:212
const std::optional< int64_t > m_vsize
Virtual size as used by the mempool, calculated using serialized size and sigchecks.
Definition: validation.h:232
MempoolAcceptResult(ResultType result_type, int64_t vsize, Amount fees, CFeeRate effective_feerate, const std::vector< TxId > &txids_fee_calculations)
Generic constructor for success cases.
Definition: validation.h:290
const ResultType m_result_type
Result type.
Definition: validation.h:223
const std::optional< std::vector< TxId > > m_txids_fee_calculations
Contains the txids of the transactions used for fee-related checks.
Definition: validation.h:249
MempoolAcceptResult(TxValidationState state)
Constructor for failure case.
Definition: validation.h:282
const TxValidationState m_state
Contains information about why the transaction failed.
Definition: validation.h:226
MempoolAcceptResult(TxValidationState state, CFeeRate effective_feerate, const std::vector< TxId > &txids_fee_calculations)
Constructor for fee-related failure case.
Definition: validation.h:299
ResultType
Used to indicate the results of mempool validation.
Definition: validation.h:214
@ VALID
Fully validated, valid.
static MempoolAcceptResult Failure(TxValidationState state)
Definition: validation.h:251
const std::optional< CFeeRate > m_effective_feerate
The feerate at which this transaction was considered.
Definition: validation.h:242
static MempoolAcceptResult FeeFailure(TxValidationState state, CFeeRate effective_feerate, const std::vector< TxId > &txids_fee_calculations)
Definition: validation.h:256
static MempoolAcceptResult Success(int64_t vsize, Amount fees, CFeeRate effective_feerate, const std::vector< TxId > &txids_fee_calculations)
Constructor for success case.
Definition: validation.h:264
static MempoolAcceptResult MempoolTx(int64_t vsize, Amount fees)
Constructor for already-in-mempool case.
Definition: validation.h:274
MempoolAcceptResult(int64_t vsize, Amount fees)
Constructor for already-in-mempool case.
Definition: validation.h:307
const std::optional< Amount > m_base_fees
Raw base fees in satoshis.
Definition: validation.h:234
Mockable clock in the context of tests, otherwise the system clock.
Definition: time.h:20
std::chrono::time_point< NodeClock > time_point
Definition: time.h:21
Validation result for package mempool acceptance.
Definition: validation.h:315
PackageMempoolAcceptResult(const TxId &txid, const MempoolAcceptResult &result)
Constructor to create a PackageMempoolAcceptResult from a MempoolAcceptResult.
Definition: validation.h:335
PackageMempoolAcceptResult(PackageValidationState state, std::map< TxId, MempoolAcceptResult > &&results)
Definition: validation.h:326
PackageValidationState m_state
Definition: validation.h:316
std::map< TxId, MempoolAcceptResult > m_tx_results
Map from txid to finished MempoolAcceptResults.
Definition: validation.h:324
Precompute sighash midstate to avoid quadratic hashing.
Definition: transaction.h:325
Struct for holding cumulative results from executing a script or a sequence of scripts.
A TxId is the identifier of a transaction.
Definition: txid.h:14
Bilingual messages:
Definition: translation.h:17
An options struct for BlockManager, more ergonomically referred to as BlockManager::Options due to th...
An options struct for ChainstateManager, more ergonomically referred to as ChainstateManager::Options...
#define EXCLUSIVE_LOCKS_REQUIRED(...)
Definition: threadsafety.h:56
#define LOCKS_EXCLUDED(...)
Definition: threadsafety.h:55
#define LOCK_RETURNED(x)
Definition: threadsafety.h:54
std::chrono::time_point< std::chrono::steady_clock, std::chrono::milliseconds > SteadyMilliseconds
Definition: time.h:33
AssertLockHeld(pool.cs)
void StartScriptCheckWorkerThreads(int threads_num)
Run instances of script checking worker threads.
GlobalMutex g_best_block_mutex
Definition: validation.cpp:117
bool TestBlockValidity(BlockValidationState &state, const CChainParams &params, Chainstate &chainstate, const CBlock &block, CBlockIndex *pindexPrev, const std::function< NodeClock::time_point()> &adjusted_time_callback, BlockValidationOptions validationOptions) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
Check a block is completely valid from start to finish (only works on top of our current best block)
Amount GetBlockSubsidy(int nHeight, const Consensus::Params &consensusParams)
std::condition_variable g_best_block_cv
Definition: validation.cpp:118
std::optional< LockPoints > CalculateLockPointsAtTip(CBlockIndex *tip, const CCoinsView &coins_view, const CTransaction &tx)
Calculate LockPoints required to check if transaction will be BIP68 final in the next block to be cre...
Definition: validation.cpp:181
static constexpr int DEFAULT_CHECKLEVEL
Definition: validation.h:101
PackageMempoolAcceptResult ProcessNewPackage(Chainstate &active_chainstate, CTxMemPool &pool, const Package &txns, bool test_accept) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
Validate (and maybe submit) a package to the mempool.
arith_uint256 CalculateHeadersWork(const std::vector< CBlockHeader > &headers)
Return the sum of the work on a given set of headers.
double GuessVerificationProgress(const ChainTxData &data, const CBlockIndex *pindex)
Guess verification progress (as a fraction between 0.0=genesis and 1.0=current tip).
static const uint64_t MIN_DISK_SPACE_FOR_BLOCK_FILES
Require that user allocate at least 550 MiB for block & undo files (blk???.dat and rev?...
Definition: validation.h:115
bool CheckSequenceLocksAtTip(CBlockIndex *tip, const LockPoints &lock_points)
Check if transaction will be BIP68 final in the next block to be created on top of tip.
Definition: validation.cpp:205
static const unsigned int MIN_BLOCKS_TO_KEEP
Block files containing a block-height within MIN_BLOCKS_TO_KEEP of ActiveChain().Tip() will not be pr...
Definition: validation.h:99
const CBlockIndex * g_best_block
Used to notify getblocktemplate RPC of new tips.
Definition: validation.cpp:119
bool HasValidProofOfWork(const std::vector< CBlockHeader > &headers, const Consensus::Params &consensusParams)
Check with the proof of work on each blockheader matches the value in nBits.
bool DeploymentActiveAfter(const CBlockIndex *pindexPrev, const ChainstateManager &chainman, DEP dep)
Deployment* info via ChainstateManager.
Definition: validation.h:1702
SnapshotCompletionResult
Definition: validation.h:1143
static const int MAX_SCRIPTCHECK_THREADS
Maximum number of dedicated script-checking threads allowed.
Definition: validation.h:89
SynchronizationState
Current sync state passed to tip changed callbacks.
Definition: validation.h:118
static const int DEFAULT_SCRIPTCHECK_THREADS
-par default (number of script-checking threads, 0 = auto)
Definition: validation.h:91
MempoolAcceptResult AcceptToMemoryPool(Chainstate &active_chainstate, const CTransactionRef &tx, int64_t accept_time, bool bypass_limits, bool test_accept=false, unsigned int heightOverride=0) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
Try to add a transaction to the mempool.
void StopScriptCheckWorkerThreads()
Stop all of the script checking worker threads.
VerifyDBResult
Definition: validation.h:643
void SpendCoins(CCoinsViewCache &view, const CTransaction &tx, CTxUndo &txundo, int nHeight)
Mark all the coins corresponding to a given transaction inputs as spent.
bool CheckBlock(const CBlock &block, BlockValidationState &state, const Consensus::Params &params, BlockValidationOptions validationOptions)
Functions for validating blocks and updating the block tree.
const std::vector< std::string > CHECKLEVEL_DOC
Documentation for argument 'checklevel'.
Definition: validation.cpp:99
void PruneBlockFilesManual(Chainstate &active_chainstate, int nManualPruneHeight)
Prune block files up to a given height.
bool IsBlockMutated(const CBlock &block)
Check if a block has been mutated (with respect to its merkle root).
CoinsCacheSizeState
Definition: validation.h:717
@ LARGE
The cache is at >= 90% capacity.
@ CRITICAL
The coins cache is in immediate need of a flush.
bool CheckInputScripts(const CTransaction &tx, TxValidationState &state, const CCoinsViewCache &view, const uint32_t flags, bool sigCacheStore, bool scriptCacheStore, const PrecomputedTransactionData &txdata, ValidationCache &validation_cache, int &nSigChecksOut, TxSigCheckLimiter &txLimitSigChecks, CheckInputsLimiter *pBlockLimitSigChecks, std::vector< CScriptCheck > *pvChecks) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
Check whether all of this transaction's input scripts succeed.
std::optional< std::vector< Coin > > GetSpentCoins(const CTransactionRef &ptx, const CCoinsViewCache &coins_view)
Get the coins spent by ptx from the coins_view.
bool DeploymentActiveAt(const CBlockIndex &index, const ChainstateManager &chainman, DEP dep)
Definition: validation.h:1708
void UpdateCoins(CCoinsViewCache &view, const CTransaction &tx, CTxUndo &txundo, int nHeight)
Apply the effects of this transaction on the UTXO set represented by view.
static const signed int DEFAULT_CHECKBLOCKS
Definition: validation.h:100
FlushStateMode
Definition: validation.h:673
static const bool DEFAULT_PEERBLOOMFILTERS
Definition: validation.h:93
bool FatalError(kernel::Notifications &notifications, BlockValidationState &state, const std::string &strMessage, const bilingual_str &userMessage={})