2015-02-11 11:58:11 +01:00
|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
2015-12-13 14:51:43 +01:00
|
|
|
// Copyright (c) 2009-2015 The Bitcoin Core developers
|
2015-02-11 11:58:11 +01:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
2015-03-21 18:15:31 +01:00
|
|
|
#ifndef BITCOIN_CONSENSUS_PARAMS_H
|
|
|
|
#define BITCOIN_CONSENSUS_PARAMS_H
|
2015-02-11 11:58:11 +01:00
|
|
|
|
|
|
|
#include "uint256.h"
|
2016-02-15 05:13:27 +01:00
|
|
|
#include <map>
|
|
|
|
#include <string>
|
2015-02-11 11:58:11 +01:00
|
|
|
|
|
|
|
namespace Consensus {
|
2016-02-15 05:13:27 +01:00
|
|
|
|
|
|
|
enum DeploymentPos
|
|
|
|
{
|
2016-03-09 22:00:53 +01:00
|
|
|
DEPLOYMENT_TESTDUMMY,
|
2016-02-20 23:37:13 +01:00
|
|
|
DEPLOYMENT_CSV, // Deployment of BIP68, BIP112, and BIP113.
|
2017-09-11 16:13:30 +02:00
|
|
|
DEPLOYMENT_DIP0001, // Deployment of DIP0001 and lower transaction fees.
|
2018-01-30 20:18:51 +01:00
|
|
|
DEPLOYMENT_BIP147, // Deployment of BIP147 (NULLDUMMY)
|
2018-02-14 21:31:42 +01:00
|
|
|
DEPLOYMENT_DIP0003, // Deployment of DIP0002 and DIP0003 (txv3 and deterministic MN lists)
|
2017-04-11 12:53:54 +02:00
|
|
|
// NOTE: Also add new deployments to VersionBitsDeploymentInfo in versionbits.cpp
|
2016-03-09 22:00:53 +01:00
|
|
|
MAX_VERSION_BITS_DEPLOYMENTS
|
2016-02-15 05:13:27 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Struct for each individual consensus rule change using BIP9.
|
|
|
|
*/
|
|
|
|
struct BIP9Deployment {
|
|
|
|
/** Bit position to select the particular bit in nVersion. */
|
|
|
|
int bit;
|
|
|
|
/** Start MedianTime for version bits miner confirmation. Can be a date in the past */
|
|
|
|
int64_t nStartTime;
|
|
|
|
/** Timeout/expiry MedianTime for the deployment attempt. */
|
|
|
|
int64_t nTimeout;
|
2017-09-11 16:13:30 +02:00
|
|
|
/** The number of past blocks (including the block under consideration) to be taken into account for locking in a fork. */
|
|
|
|
int64_t nWindowSize;
|
|
|
|
/** A number of blocks, in the range of 1..nWindowSize, which must signal for a fork in order to lock it in. */
|
|
|
|
int64_t nThreshold;
|
2016-02-15 05:13:27 +01:00
|
|
|
};
|
|
|
|
|
2018-11-23 15:42:09 +01:00
|
|
|
enum LLMQType : uint8_t
|
|
|
|
{
|
|
|
|
LLMQ_NONE = 0xff,
|
|
|
|
|
|
|
|
LLMQ_50_60 = 1, // 50 members, 30 (60%) threshold, one per hour
|
|
|
|
LLMQ_400_60 = 2, // 400 members, 240 (60%) threshold, one every 12 hours
|
|
|
|
LLMQ_400_85 = 3, // 400 members, 340 (85%) threshold, one every 24 hours
|
|
|
|
|
|
|
|
// for testing only
|
|
|
|
LLMQ_10_60 = 100, // 10 members, 6 (60%) threshold, one per hour
|
|
|
|
};
|
|
|
|
|
|
|
|
// Configures a LLMQ and its DKG
|
|
|
|
// See https://github.com/dashpay/dips/blob/master/dip-0006.md for more details
|
|
|
|
struct LLMQParams {
|
|
|
|
LLMQType type;
|
|
|
|
|
|
|
|
// not consensus critical, only used in logging, RPC and UI
|
|
|
|
std::string name;
|
|
|
|
|
|
|
|
// the size of the quorum, e.g. 50 or 400
|
|
|
|
int size;
|
|
|
|
|
|
|
|
// The minimum number of valid members after the DKK. If less members are determined valid, no commitment can be
|
|
|
|
// created. Should be higher then the threshold to allow some room for failing nodes, otherwise quorum might end up
|
|
|
|
// not being able to ever created a recovered signature if more nodes fail after the DKG
|
|
|
|
int minSize;
|
|
|
|
|
|
|
|
// The threshold required to recover a final signature. Should be at least 50%+1 of the quorum size. This value
|
|
|
|
// also controls the size of the public key verification vector and has a large influence on the performance of
|
|
|
|
// recovery. It also influences the amount of minimum messages that need to be exchanged for a single signing session.
|
|
|
|
// This value has the most influence on the security of the quorum. The number of total malicious masternodes
|
|
|
|
// required to negatively influence signing sessions highly correlates to the threshold percentage.
|
|
|
|
int threshold;
|
|
|
|
|
|
|
|
// The interval in number blocks for DKGs and the creation of LLMQs. If set to 24 for example, a DKG will start
|
|
|
|
// every 24 blocks, which is approximately once every hour.
|
|
|
|
int dkgInterval;
|
|
|
|
|
|
|
|
// The number of blocks per phase in a DKG session. There are 6 phases plus the mining phase that need to be processed
|
|
|
|
// per DKG. Set this value to a number of blocks so that each phase has enough time to propagate all required
|
|
|
|
// messages to all members before the next phase starts. If blocks are produced too fast, whole DKG sessions will
|
|
|
|
// fail.
|
|
|
|
int dkgPhaseBlocks;
|
|
|
|
|
|
|
|
// The starting block inside the DKG interval for when mining of commitments starts. The value is inclusive.
|
|
|
|
// Starting from this block, the inclusion of (possibly null) commitments is enforced until the first non-null
|
|
|
|
// commitment is mined. The chosen value should be at least 5 * dkgPhaseBlocks so that it starts right after the
|
|
|
|
// finalization phase.
|
|
|
|
int dkgMiningWindowStart;
|
|
|
|
|
|
|
|
// The ending block inside the DKG interval for when mining of commitments ends. The value is inclusive.
|
|
|
|
// Choose a value so that miners have enough time to receive the commitment and mine it. Also take into consideration
|
|
|
|
// that miners might omit real commitments and revert to always including null commitments. The mining window should
|
|
|
|
// be large enough so that other miners have a chance to produce a block containing a non-null commitment. The window
|
|
|
|
// should at the same time not be too large so that not too much space is wasted with null commitments in case a DKG
|
|
|
|
// session failed.
|
|
|
|
int dkgMiningWindowEnd;
|
2018-05-24 16:14:55 +02:00
|
|
|
int dkgRndSleepTime;
|
|
|
|
int dkgBadVotesThreshold;
|
|
|
|
|
|
|
|
int neighborConnections;
|
|
|
|
int diagonalConnections;
|
|
|
|
int keepOldConnections;
|
2018-11-23 15:42:09 +01:00
|
|
|
};
|
|
|
|
|
2015-02-11 11:58:11 +01:00
|
|
|
/**
|
|
|
|
* Parameters that influence chain consensus.
|
|
|
|
*/
|
|
|
|
struct Params {
|
|
|
|
uint256 hashGenesisBlock;
|
2018-02-01 18:05:35 +01:00
|
|
|
uint256 hashDevnetGenesisBlock;
|
2015-02-11 11:58:11 +01:00
|
|
|
int nSubsidyHalvingInterval;
|
2016-02-17 17:29:36 +01:00
|
|
|
int nMasternodePaymentsStartBlock;
|
|
|
|
int nMasternodePaymentsIncreaseBlock;
|
|
|
|
int nMasternodePaymentsIncreasePeriod; // in blocks
|
2018-03-10 13:35:09 +01:00
|
|
|
int nInstantSendConfirmationsRequired; // in blocks
|
2016-06-29 20:20:18 +02:00
|
|
|
int nInstantSendKeepLock; // in blocks
|
2016-02-17 17:29:36 +01:00
|
|
|
int nBudgetPaymentsStartBlock;
|
|
|
|
int nBudgetPaymentsCycleBlocks;
|
|
|
|
int nBudgetPaymentsWindowBlocks;
|
2016-08-22 03:41:40 +02:00
|
|
|
int nSuperblockStartBlock;
|
2018-02-01 13:42:21 +01:00
|
|
|
uint256 nSuperblockStartHash;
|
2016-08-22 03:41:40 +02:00
|
|
|
int nSuperblockCycle; // in blocks
|
2017-02-02 09:50:44 +01:00
|
|
|
int nGovernanceMinQuorum; // Min absolute vote count to trigger an action
|
|
|
|
int nGovernanceFilterElements;
|
2016-05-19 21:03:17 +02:00
|
|
|
int nMasternodeMinimumConfirmations;
|
2015-11-02 22:41:55 +01:00
|
|
|
/** Block height and hash at which BIP34 becomes active */
|
|
|
|
int BIP34Height;
|
|
|
|
uint256 BIP34Hash;
|
2016-08-04 11:55:25 +02:00
|
|
|
/** Block height at which BIP65 becomes active */
|
|
|
|
int BIP65Height;
|
|
|
|
/** Block height at which BIP66 becomes active */
|
|
|
|
int BIP66Height;
|
2018-03-08 13:18:24 +01:00
|
|
|
/** Block height at which DIP0001 becomes active */
|
|
|
|
int DIP0001Height;
|
2018-12-28 17:13:44 +01:00
|
|
|
/** Block height at which DIP0003 becomes active */
|
|
|
|
int DIP0003Height;
|
|
|
|
uint256 DIP0003Hash;
|
2016-02-15 05:13:27 +01:00
|
|
|
/**
|
2018-01-22 08:05:44 +01:00
|
|
|
* Minimum blocks including miner confirmation of the total of nMinerConfirmationWindow blocks in a retargeting period,
|
2016-02-15 05:13:27 +01:00
|
|
|
* (nPowTargetTimespan / nPowTargetSpacing) which is also used for BIP9 deployments.
|
2017-09-11 16:13:30 +02:00
|
|
|
* Default BIP9Deployment::nThreshold value for deployments where it's not specified and for unknown deployments.
|
2016-02-15 05:13:27 +01:00
|
|
|
* Examples: 1916 for 95%, 1512 for testchains.
|
|
|
|
*/
|
|
|
|
uint32_t nRuleChangeActivationThreshold;
|
2017-09-11 16:13:30 +02:00
|
|
|
// Default BIP9Deployment::nWindowSize value for deployments where it's not specified and for unknown deployments.
|
2016-02-15 05:13:27 +01:00
|
|
|
uint32_t nMinerConfirmationWindow;
|
|
|
|
BIP9Deployment vDeployments[MAX_VERSION_BITS_DEPLOYMENTS];
|
2015-02-11 11:58:11 +01:00
|
|
|
/** Proof of work parameters */
|
2015-03-25 20:00:32 +01:00
|
|
|
uint256 powLimit;
|
2015-02-11 11:58:11 +01:00
|
|
|
bool fPowAllowMinDifficultyBlocks;
|
2015-10-19 14:25:29 +02:00
|
|
|
bool fPowNoRetargeting;
|
2015-02-11 11:58:11 +01:00
|
|
|
int64_t nPowTargetSpacing;
|
|
|
|
int64_t nPowTargetTimespan;
|
2017-12-01 06:15:11 +01:00
|
|
|
int nPowKGWHeight;
|
|
|
|
int nPowDGWHeight;
|
2015-02-11 11:58:11 +01:00
|
|
|
int64_t DifficultyAdjustmentInterval() const { return nPowTargetTimespan / nPowTargetSpacing; }
|
2017-08-23 16:21:08 +02:00
|
|
|
uint256 nMinimumChainWork;
|
|
|
|
uint256 defaultAssumeValid;
|
2018-10-25 09:16:38 +02:00
|
|
|
|
|
|
|
/** these parameters are only used on devnet and can be configured from the outside */
|
|
|
|
int nMinimumDifficultyBlocks{0};
|
|
|
|
int nHighSubsidyBlocks{0};
|
|
|
|
int nHighSubsidyFactor{1};
|
2018-11-23 10:40:46 +01:00
|
|
|
|
2018-11-23 15:42:09 +01:00
|
|
|
std::map<LLMQType, LLMQParams> llmqs;
|
2018-11-26 16:53:20 +01:00
|
|
|
bool fLLMQAllowDummyCommitments;
|
2015-02-11 11:58:11 +01:00
|
|
|
};
|
|
|
|
} // namespace Consensus
|
|
|
|
|
2015-03-21 18:15:31 +01:00
|
|
|
#endif // BITCOIN_CONSENSUS_PARAMS_H
|