11 int nPeriod =
Period(params);
15 int64_t nTimeTimeout =
EndTime(params);
28 if (pindexPrev !=
nullptr) {
33 std::vector<const CBlockIndex*> vToCompute;
34 while (cache.count(pindexPrev) == 0) {
35 if (pindexPrev ==
nullptr) {
45 vToCompute.push_back(pindexPrev);
50 assert(cache.count(pindexPrev));
54 while (!vToCompute.empty()) {
56 pindexPrev = vToCompute.back();
57 vToCompute.pop_back();
70 for (
int i = 0; i < nPeriod; i++) {
74 pindexCount = pindexCount->
pprev;
76 if (
count >= nThreshold) {
85 if (pindexPrev->
nHeight + 1 >= min_activation_height) {
96 cache[pindexPrev] = state = stateNext;
109 if (pindex ==
nullptr)
return stats;
115 if (signalling_blocks) {
116 signalling_blocks->assign(blocks_in_period,
false);
128 if (signalling_blocks) signalling_blocks->at(blocks_in_period) =
true;
130 currentIndex = currentIndex->
pprev;
131 }
while(blocks_in_period > 0);
154 const int nPeriod =
Period(params);
166 while (previousPeriodParent !=
nullptr &&
GetStateFor(previousPeriodParent, params, cache) == initialState) {
167 pindexPrev = previousPeriodParent;
172 return pindexPrev->
nHeight + 1;
206 return VersionBitsConditionChecker(pos).GetStateFor(pindexPrev, params, m_caches[pos]);
211 return VersionBitsConditionChecker(pos).GetStateStatisticsFor(pindex, params, signalling_blocks);
217 return VersionBitsConditionChecker(pos).GetStateSinceHeightFor(pindexPrev, params, m_caches[pos]);
222 return VersionBitsConditionChecker(pos).Mask(params);
232 ThresholdState state = VersionBitsConditionChecker(pos).GetStateFor(pindexPrev, params, m_caches[pos]);
234 nVersion |=
Mask(params, pos);
#define Assert(val)
Identity function.
Abstract class that implements BIP9-style threshold logic, and caches results.
virtual bool Condition(const CBlockIndex *pindex, const Consensus::Params ¶ms) const =0
virtual int Period(const Consensus::Params ¶ms) const =0
ThresholdState GetStateFor(const CBlockIndex *pindexPrev, const Consensus::Params ¶ms, ThresholdConditionCache &cache) const
Returns the state for pindex A based on parent pindexPrev B.
virtual int64_t EndTime(const Consensus::Params ¶ms) const =0
virtual int MinActivationHeight(const Consensus::Params ¶ms) const
int GetStateSinceHeightFor(const CBlockIndex *pindexPrev, const Consensus::Params ¶ms, ThresholdConditionCache &cache) const
Returns the height since when the ThresholdState has started for pindex A based on parent pindexPrev ...
virtual int64_t BeginTime(const Consensus::Params ¶ms) const =0
virtual int Threshold(const Consensus::Params ¶ms) const =0
BIP9Stats GetStateStatisticsFor(const CBlockIndex *pindex, const Consensus::Params ¶ms, std::vector< bool > *signalling_blocks=nullptr) const
Returns the numerical statistics of an in-progress BIP9 softfork in the period including pindex If pr...
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
int64_t GetMedianTimePast() const
int32_t nVersion
block header
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
int StateSinceHeight(const CBlockIndex *pindexPrev, const Consensus::Params ¶ms, Consensus::DeploymentPos pos) EXCLUSIVE_LOCKS_REQUIRED(!m_mutex)
Get the block height at which the BIP9 deployment switched into the state for the block after pindexP...
static BIP9Stats Statistics(const CBlockIndex *pindex, const Consensus::Params ¶ms, Consensus::DeploymentPos pos, std::vector< bool > *signalling_blocks=nullptr)
Get the numerical statistics for a given deployment for the signalling period that includes pindex.
int32_t ComputeBlockVersion(const CBlockIndex *pindexPrev, const Consensus::Params ¶ms) EXCLUSIVE_LOCKS_REQUIRED(!m_mutex)
Determine what nVersion a new block should use.
static uint32_t Mask(const Consensus::Params ¶ms, Consensus::DeploymentPos pos)
ThresholdState State(const CBlockIndex *pindexPrev, const Consensus::Params ¶ms, Consensus::DeploymentPos pos) EXCLUSIVE_LOCKS_REQUIRED(!m_mutex)
Get the BIP9 state for a given deployment for the block after pindexPrev.
void Clear() EXCLUSIVE_LOCKS_REQUIRED(!m_mutex)
constexpr I Mask()
Return a value of type I with its bits lowest bits set (bits must be > 0).
@ MAX_VERSION_BITS_DEPLOYMENTS
Display status of an in-progress BIP9 softfork.
int count
Number of blocks with the version bit set since the beginning of the current period.
int elapsed
Number of blocks elapsed since the beginning of the current period.
int threshold
Number of blocks with the version bit set required to activate the softfork.
bool possible
False if there are not enough blocks left in this period to pass activation threshold.
int period
Length of blocks of the BIP9 signalling period.
int min_activation_height
If lock in occurs, delay activation until at least this block height.
int bit
Bit position to select the particular bit in nVersion.
static constexpr int64_t ALWAYS_ACTIVE
Special value for nStartTime indicating that the deployment is always active.
static constexpr int64_t NEVER_ACTIVE
Special value for nStartTime indicating that the deployment is never active.
int64_t nTimeout
Timeout/expiry MedianTime for the deployment attempt.
int64_t nStartTime
Start MedianTime for version bits miner confirmation.
Parameters that influence chain consensus.
uint32_t nMinerConfirmationWindow
BIP9Deployment vDeployments[MAX_VERSION_BITS_DEPLOYMENTS]
uint32_t nRuleChangeActivationThreshold
Minimum blocks including miner confirmation of the total of 2016 blocks in a retargeting period,...
std::map< const CBlockIndex *, ThresholdState > ThresholdConditionCache
static const int32_t VERSIONBITS_TOP_BITS
What bits to set in version for versionbits blocks.
static const int32_t VERSIONBITS_TOP_MASK
What bitmask determines whether versionbits is in use.
ThresholdState
BIP 9 defines a finite-state-machine to deploy a softfork in multiple stages.