Bitcoin Core 28.99.0
P2P Digital Currency
|
#include <arith_uint256.h>
#include <attributes.h>
#include <chain.h>
#include <checkqueue.h>
#include <consensus/amount.h>
#include <cuckoocache.h>
#include <deploymentstatus.h>
#include <kernel/chain.h>
#include <kernel/chainparams.h>
#include <kernel/chainstatemanager_opts.h>
#include <kernel/cs_main.h>
#include <node/blockstorage.h>
#include <policy/feerate.h>
#include <policy/packages.h>
#include <policy/policy.h>
#include <script/script_error.h>
#include <script/sigcache.h>
#include <sync.h>
#include <txdb.h>
#include <txmempool.h>
#include <uint256.h>
#include <util/check.h>
#include <util/fs.h>
#include <util/hasher.h>
#include <util/result.h>
#include <util/translation.h>
#include <versionbits.h>
#include <atomic>
#include <map>
#include <memory>
#include <optional>
#include <set>
#include <span>
#include <stdint.h>
#include <string>
#include <type_traits>
#include <utility>
#include <vector>
Go to the source code of this file.
Classes | |
struct | MempoolAcceptResult |
Validation result for a transaction evaluated by MemPoolAccept (single or package). More... | |
struct | PackageMempoolAcceptResult |
Validation result for package mempool acceptance. More... | |
class | CScriptCheck |
Closure representing one script verification Note that this stores references to the spending transaction. More... | |
class | ValidationCache |
Convenience class for initializing and passing the script execution cache and signature cache. More... | |
class | CVerifyDB |
RAII wrapper for VerifyDB: Verify consistency of the block and coin databases. More... | |
class | CoinsViews |
A convenience class for constructing the CCoinsView* hierarchy used to facilitate access to the UTXO set. More... | |
class | Chainstate |
Chainstate stores and provides an API to update our local knowledge of the current best chain. More... | |
class | ChainstateManager |
Provides an interface for creating and interacting with one or two chainstates: an IBD chainstate generated by downloading blocks, and an optional snapshot chainstate loaded from a UTXO snapshot. More... | |
Namespaces | |
namespace | node |
namespace | Consensus |
Transaction validation functions. | |
namespace | util |
Enumerations | |
enum class | SynchronizationState { INIT_REINDEX , INIT_DOWNLOAD , POST_INIT } |
Current sync state passed to tip changed callbacks. More... | |
enum class | VerifyDBResult { SUCCESS , CORRUPTED_BLOCK_DB , INTERRUPTED , SKIPPED_L3_CHECKS , SKIPPED_MISSING_BLOCKS } |
enum | DisconnectResult { DISCONNECT_OK , DISCONNECT_UNCLEAN , DISCONNECT_FAILED } |
enum class | FlushStateMode { NONE , IF_NEEDED , PERIODIC , ALWAYS } |
enum class | CoinsCacheSizeState { CRITICAL = 2 , LARGE = 1 , OK = 0 } |
enum class | SnapshotCompletionResult { SUCCESS , SKIPPED , MISSING_CHAINPARAMS , STATS_FAILED , HASH_MISMATCH , BASE_BLOCKHASH_MISMATCH } |
Functions | |
CAmount | GetBlockSubsidy (int nHeight, const Consensus::Params &consensusParams) |
bool | FatalError (kernel::Notifications ¬ifications, BlockValidationState &state, const bilingual_str &message) |
void | PruneBlockFilesManual (Chainstate &active_chainstate, int nManualPruneHeight) |
Prune block files up to a given height. More... | |
MempoolAcceptResult | AcceptToMemoryPool (Chainstate &active_chainstate, const CTransactionRef &tx, int64_t accept_time, bool bypass_limits, bool test_accept) EXCLUSIVE_LOCKS_REQUIRED(cs_main) |
Try to add a transaction to the mempool. More... | |
PackageMempoolAcceptResult | ProcessNewPackage (Chainstate &active_chainstate, CTxMemPool &pool, const Package &txns, bool test_accept, const std::optional< CFeeRate > &client_maxfeerate) EXCLUSIVE_LOCKS_REQUIRED(cs_main) |
Validate (and maybe submit) a package to the mempool. More... | |
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. More... | |
bool | CheckBlock (const CBlock &block, BlockValidationState &state, const Consensus::Params &consensusParams, bool fCheckPOW=true, bool fCheckMerkleRoot=true) |
Functions for validating blocks and updating the block tree. More... | |
bool | TestBlockValidity (BlockValidationState &state, const CChainParams &chainparams, Chainstate &chainstate, const CBlock &block, CBlockIndex *pindexPrev, bool fCheckPOW=true, bool fCheckMerkleRoot=true) EXCLUSIVE_LOCKS_REQUIRED(cs_main) |
Check a block is completely valid from start to finish (only works on top of our current best block) More... | |
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. More... | |
bool | IsBlockMutated (const CBlock &block, bool check_witness_root) |
Check if a block has been mutated (with respect to its merkle root and witness commitments). More... | |
arith_uint256 | CalculateClaimedHeadersWork (std::span< const CBlockHeader > headers) |
Return the sum of the claimed work on a given set of headers. More... | |
template<typename DEP > | |
bool | DeploymentActiveAfter (const CBlockIndex *pindexPrev, const ChainstateManager &chainman, DEP dep) |
Deployment* info via ChainstateManager. More... | |
template<typename DEP > | |
bool | DeploymentActiveAt (const CBlockIndex &index, const ChainstateManager &chainman, DEP dep) |
template<typename DEP > | |
bool | DeploymentEnabled (const ChainstateManager &chainman, DEP dep) |
bool | IsBIP30Repeat (const CBlockIndex &block_index) |
Identifies blocks that overwrote an existing coinbase output in the UTXO set (see BIP30) More... | |
bool | IsBIP30Unspendable (const CBlockIndex &block_index) |
Identifies blocks which coinbase output was subsequently overwritten in the UTXO set (see BIP30) More... | |
Variables | |
static const unsigned int | MIN_BLOCKS_TO_KEEP = 288 |
Block files containing a block-height within MIN_BLOCKS_TO_KEEP of ActiveChain().Tip() will not be pruned. More... | |
static const signed int | DEFAULT_CHECKBLOCKS = 6 |
static constexpr int | DEFAULT_CHECKLEVEL {3} |
static const uint64_t | MIN_DISK_SPACE_FOR_BLOCK_FILES = 550 * 1024 * 1024 |
static constexpr int | MAX_SCRIPTCHECK_THREADS {15} |
Maximum number of dedicated script-checking threads allowed. More... | |
const std::vector< std::string > | CHECKLEVEL_DOC |
Documentation for argument 'checklevel'. More... | |
bool CheckFinalTxAtTip(const CBlockIndex &active_chain_tip, const CTransaction &tx) EXCLUSIVE_LOCKS_REQUIRED(std::optional< LockPoints > | CalculateLockPointsAtTip (CBlockIndex *tip, const CCoinsView &coins_view, const CTransaction &tx) |
Check if transaction will be final in the next block to be created. More... | |
|
strong |
Enumerator | |
---|---|
CRITICAL | The coins cache is in immediate need of a flush. |
LARGE | The cache is at >= 90% capacity. |
OK |
Definition at line 481 of file validation.h.
enum DisconnectResult |
Enumerator | |
---|---|
DISCONNECT_OK | |
DISCONNECT_UNCLEAN | |
DISCONNECT_FAILED |
Definition at line 429 of file validation.h.
|
strong |
Enumerator | |
---|---|
NONE | |
IF_NEEDED | |
PERIODIC | |
ALWAYS |
Definition at line 439 of file validation.h.
|
strong |
Enumerator | |
---|---|
SUCCESS | |
SKIPPED | |
MISSING_CHAINPARAMS | |
STATS_FAILED | |
HASH_MISMATCH | |
BASE_BLOCKHASH_MISMATCH |
Definition at line 817 of file validation.h.
|
strong |
Current sync state passed to tip changed callbacks.
Enumerator | |
---|---|
INIT_REINDEX | |
INIT_DOWNLOAD | |
POST_INIT |
Definition at line 85 of file validation.h.
|
strong |
Enumerator | |
---|---|
SUCCESS | |
CORRUPTED_BLOCK_DB | |
INTERRUPTED | |
SKIPPED_L3_CHECKS | |
SKIPPED_MISSING_BLOCKS |
Definition at line 404 of file validation.h.
MempoolAcceptResult AcceptToMemoryPool | ( | Chainstate & | active_chainstate, |
const CTransactionRef & | tx, | ||
int64_t | accept_time, | ||
bool | bypass_limits, | ||
bool | test_accept | ||
) |
Try to add a transaction to the mempool.
This is an internal function and is exposed only for testing. Client code should use ChainstateManager::ProcessTransaction()
[in] | active_chainstate | Reference to the active chainstate. |
[in] | tx | The transaction to submit for mempool acceptance. |
[in] | accept_time | The timestamp for adding the transaction to the mempool. It is also used to determine when the entry expires. |
[in] | bypass_limits | When true, don't enforce mempool fee and capacity limits, and set entry_sequence to zero. |
[in] | test_accept | When true, run validation checks but don't submit to mempool. |
Definition at line 1878 of file validation.cpp.
arith_uint256 CalculateClaimedHeadersWork | ( | std::span< const CBlockHeader > | headers | ) |
Return the sum of the claimed work on a given set of headers.
No verification of PoW is done.
Definition at line 4187 of file validation.cpp.
bool CheckBlock | ( | const CBlock & | block, |
BlockValidationState & | state, | ||
const Consensus::Params & | consensusParams, | ||
bool | fCheckPOW = true , |
||
bool | fCheckMerkleRoot = true |
||
) |
Functions for validating blocks and updating the block tree.
Context-independent validity checks
Definition at line 4046 of file validation.cpp.
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.
[in] | tip | Chain tip to check tx sequence locks against. For example, the tip of the current active chain. |
[in] | lock_points | LockPoints containing the height and time at which this transaction is final. Simulates calling SequenceLocks() with data from the tip passed in. The LockPoints should not be considered valid if CheckSequenceLocksAtTip returns false. |
Definition at line 245 of file validation.cpp.
bool DeploymentActiveAfter | ( | const CBlockIndex * | pindexPrev, |
const ChainstateManager & | chainman, | ||
DEP | dep | ||
) |
Deployment* info via ChainstateManager.
Definition at line 1332 of file validation.h.
bool DeploymentActiveAt | ( | const CBlockIndex & | index, |
const ChainstateManager & | chainman, | ||
DEP | dep | ||
) |
Definition at line 1338 of file validation.h.
bool DeploymentEnabled | ( | const ChainstateManager & | chainman, |
DEP | dep | ||
) |
Definition at line 1344 of file validation.h.
bool FatalError | ( | kernel::Notifications & | notifications, |
BlockValidationState & | state, | ||
const bilingual_str & | message | ||
) |
Definition at line 2255 of file validation.cpp.
CAmount GetBlockSubsidy | ( | int | nHeight, |
const Consensus::Params & | consensusParams | ||
) |
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.
Definition at line 4150 of file validation.cpp.
bool IsBIP30Repeat | ( | const CBlockIndex & | block_index | ) |
Identifies blocks that overwrote an existing coinbase output in the UTXO set (see BIP30)
Definition at line 6361 of file validation.cpp.
bool IsBIP30Unspendable | ( | const CBlockIndex & | block_index | ) |
Identifies blocks which coinbase output was subsequently overwritten in the UTXO set (see BIP30)
Definition at line 6367 of file validation.cpp.
bool IsBlockMutated | ( | const CBlock & | block, |
bool | check_witness_root | ||
) |
Check if a block has been mutated (with respect to its merkle root and witness commitments).
Definition at line 4156 of file validation.cpp.
PackageMempoolAcceptResult ProcessNewPackage | ( | Chainstate & | active_chainstate, |
CTxMemPool & | pool, | ||
const Package & | txns, | ||
bool | test_accept, | ||
const std::optional< CFeeRate > & | client_maxfeerate | ||
) |
Validate (and maybe submit) a package to the mempool.
See doc/policy/packages.md for full details on package validation rules.
[in] | test_accept | When true, run validation checks but don't submit to mempool. |
[in] | client_maxfeerate | If exceeded by an individual transaction, rest of (sub)package evaluation is aborted. Only for sanity checks against local submission of transactions. |
Definition at line 1908 of file validation.cpp.
void PruneBlockFilesManual | ( | Chainstate & | active_chainstate, |
int | nManualPruneHeight | ||
) |
Prune block files up to a given height.
Definition at line 4695 of file validation.cpp.
bool TestBlockValidity | ( | BlockValidationState & | state, |
const CChainParams & | chainparams, | ||
Chainstate & | chainstate, | ||
const CBlock & | block, | ||
CBlockIndex * | pindexPrev, | ||
bool | fCheckPOW = true , |
||
bool | fCheckMerkleRoot = true |
||
) |
Check a block is completely valid from start to finish (only works on top of our current best block)
Definition at line 4656 of file validation.cpp.
bool CheckFinalTxAtTip(const CBlockIndex &active_chain_tip, const CTransaction &tx) EXCLUSIVE_LOCKS_REQUIRED(std::optional< LockPoints > CalculateLockPointsAtTip(CBlockIndex *tip, const CCoinsView &coins_view, const CTransaction &tx) | ( | CBlockIndex * | tip, |
const CCoinsView & | coins_view, | ||
const CTransaction & | tx | ||
) |
Check if transaction will be final in the next block to be created.
Calculate LockPoints required to check if transaction will be BIP68 final in the next block to be created on top of tip.
[in] | tip | Chain tip for which tx sequence locks are calculated. For example, the tip of the current active chain. |
[in] | coins_view | Any CCoinsView that provides access to the relevant coins for checking sequence locks. For example, it can be a CCoinsViewCache that isn't connected to anything but contains all the relevant coins, or a CCoinsViewMemPool that is connected to the mempool and chainstate UTXO set. In the latter case, the caller is responsible for holding the appropriate locks to ensure that calls to GetCoin() return correct coins. |
[in] | tx | The transaction being evaluated. |
Definition at line 309 of file validation.h.
|
extern |
Documentation for argument 'checklevel'.
Definition at line 99 of file validation.cpp.
|
static |
Definition at line 69 of file validation.h.
|
staticconstexpr |
Definition at line 70 of file validation.h.
|
staticconstexpr |
Maximum number of dedicated script-checking threads allowed.
Definition at line 82 of file validation.h.
|
static |
Block files containing a block-height within MIN_BLOCKS_TO_KEEP of ActiveChain().Tip() will not be pruned.
Definition at line 68 of file validation.h.
|
static |
Definition at line 79 of file validation.h.