2018-11-18 16:39:35 +00:00
|
|
|
// Package params defines important constants that are essential to the
|
|
|
|
// Ethereum 2.0 services.
|
2018-07-14 02:15:37 +00:00
|
|
|
package params
|
2018-07-11 22:29:31 +00:00
|
|
|
|
2018-09-22 20:15:39 +00:00
|
|
|
import (
|
2018-09-27 02:34:35 +00:00
|
|
|
"time"
|
2018-09-22 20:15:39 +00:00
|
|
|
)
|
|
|
|
|
2018-12-25 06:47:07 +00:00
|
|
|
func makeEmptySignature() [][]byte {
|
|
|
|
signature := make([][]byte, 2)
|
|
|
|
signature[0] = make([]byte, 48)
|
|
|
|
signature[1] = make([]byte, 48)
|
|
|
|
return signature
|
|
|
|
}
|
|
|
|
|
2019-01-06 04:36:05 +00:00
|
|
|
// BeaconChainConfig contains constant configs for node to participate in beacon chain.
|
2018-11-21 01:41:20 +00:00
|
|
|
type BeaconChainConfig struct {
|
2019-01-06 04:36:05 +00:00
|
|
|
// Misc constants.
|
|
|
|
ShardCount uint64 // ShardCount is the number of shard chains in Ethereum 2.0.
|
|
|
|
TargetCommitteeSize uint64 // TargetCommitteeSize is the number of validators in a committee when the chain is healthy.
|
|
|
|
EjectionBalance uint64 // EjectionBalance is the minimal ETH a validator needs to have before ejected.
|
|
|
|
EjectionBalanceInGwei uint64 // EjectionBalance is the minimal GWei a validator needs to have before ejected.
|
|
|
|
MaxBalanceChurnQuotient uint64 // MaxBalanceChurnQuotient is used to determine how many validators can rotate per epoch.
|
|
|
|
Gwei uint64 // Gwei is the denomination of Gwei in Ether.
|
|
|
|
BeaconChainShardNumber uint64 // BeaconChainShardNumber is the shard number of the beacon chain.
|
|
|
|
MaxCasperVotes uint64 // MaxCasperVotes is used to verify slashable Casper vote data.
|
|
|
|
LatestBlockRootsLength uint64 // LatestBlockRootsLength is the number of block roots kept in the beacon state.
|
|
|
|
LatestRandaoMixesLength uint64 // LatestRandaoMixesLength is the number of randao mixes kept in the beacon state.
|
|
|
|
LatestPenalizedExitLength uint64 // LatestPenalizedExitLength is used to track penalized exit balances per time interval.
|
2019-01-16 05:52:57 +00:00
|
|
|
MaxWithdrawalsPerEpoch uint64 // MaxWithdrawalsPerEpoch is the max withdrawals can happen for a single epoch.
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Deposit contract constants.
|
|
|
|
DepositContractAddress []byte // DepositContractAddress is the address of the deposit contract in PoW chain.
|
|
|
|
DepositContractTreeDepth uint64 // Depth of the Merkle trie of deposits in the validator deposit contract on the PoW chain.
|
|
|
|
MaxDepositInGwei uint64 // MaxDepositInGwei is the maximal amount of Gwei a validator can send to the deposit contract at once.
|
2019-01-24 23:29:04 +00:00
|
|
|
MinDepositInGwei uint64 // MinDepositInGwei is the maximal amount of Gwei a validator can send to the deposit contract at once.
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Initial value constants.
|
|
|
|
GenesisForkVersion uint64 // GenesisForkVersion is used to track fork version between state transitions.
|
2019-01-20 18:26:33 +00:00
|
|
|
GenesisSlot uint64 // GenesisSlot is used to initialize the genesis state fields.
|
|
|
|
GenesisStartShard uint64 // GenesisStartShard is the first shard to assign validators.
|
2019-01-06 04:36:05 +00:00
|
|
|
ZeroHash [32]byte // ZeroHash is used to represent a zeroed out 32 byte array.
|
|
|
|
EmptySignature [][]byte // EmptySignature is used to represent a zeroed out BLS Signature.
|
|
|
|
BLSWithdrawalPrefixByte byte // BLSWithdrawalPrefixByte is used for BLS withdrawal and it's the first byte.
|
|
|
|
|
|
|
|
// Time parameters constants.
|
|
|
|
SlotDuration uint64 // SlotDuration is how many seconds are in a single slot.
|
|
|
|
MinAttestationInclusionDelay uint64 // MinAttestationInclusionDelay defines how long validator has to wait to include attestation for beacon block.
|
|
|
|
EpochLength uint64 // EpochLength is the number of slots in an epoch.
|
|
|
|
SeedLookahead uint64 // SeedLookahead is the duration of randao look ahead seed.
|
|
|
|
EntryExitDelay uint64 // EntryExitDelay is the duration a validator has to wait for entry and exit.
|
2019-01-09 04:42:42 +00:00
|
|
|
DepositRootVotingPeriod uint64 // DepositRootVotingPeriod defines how often the merkle root of deposit receipts get updated in beacon node.
|
2019-01-06 04:36:05 +00:00
|
|
|
MinValidatorWithdrawalTime uint64 // MinValidatorWithdrawalTime is the shortest amount of time a validator can get the deposit out.
|
2019-01-12 02:11:43 +00:00
|
|
|
FarFutureSlot uint64 // FarFutureSlot represents a slot extremely far away in the future used as the default penalization slot for validators.
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Reward and penalty quotients constants.
|
|
|
|
BaseRewardQuotient uint64 // BaseRewardQuotient is used to calculate validator per-slot interest rate.
|
|
|
|
WhistlerBlowerRewardQuotient uint64 // WhistlerBlowerRewardQuotient is used to calculate whistler blower reward.
|
|
|
|
IncluderRewardQuotient uint64 // IncluderRewardQuotient defines the reward quotient of proposer for including attestations..
|
|
|
|
InactivityPenaltyQuotient uint64 // InactivityPenaltyQuotient defines how much validator leaks out balances for offline.
|
|
|
|
|
|
|
|
// Max operations per block constants.
|
|
|
|
MaxExits uint64 // MaxExits determines the maximum number of validator exits in a block.
|
|
|
|
MaxDeposits uint64 // MaxExits determines the maximum number of validator deposits in a block.
|
|
|
|
MaxAttestations uint64 // MaxAttestations defines the maximum allowed attestations in a beacon block.
|
|
|
|
MaxProposerSlashings uint64 // MaxProposerSlashings defines the maximum number of slashings of proposers possible in a block.
|
|
|
|
MaxCasperSlashings uint64 // MaxCasperSlashings defines the maximum number of casper FFG slashings possible in a block.
|
|
|
|
|
|
|
|
// Prysm constants.
|
2019-01-11 08:29:30 +00:00
|
|
|
DepositsForChainStart uint64 // DepositsForChainStart defines how many validator deposits needed to kick off beacon chain.
|
|
|
|
SimulatedBlockRandao [32]byte // SimulatedBlockRandao is a RANDAO seed stubbed in simulated block for advancing local beacon chain.
|
|
|
|
RandBytes uint64 // RandBytes is the number of bytes used as entropy to shuffle validators.
|
|
|
|
SyncPollingInterval int64 // SyncPollingInterval queries network nodes for sync status.
|
|
|
|
GenesisTime time.Time // GenesisTime used by the protocol.
|
|
|
|
MaxNumLog2Validators uint64 // MaxNumLog2Validators is the Max number of validators in Log2 exists given total ETH supply.
|
2018-09-28 06:48:39 +00:00
|
|
|
}
|
|
|
|
|
2018-11-21 01:41:20 +00:00
|
|
|
// ShardChainConfig contains configs for node to participate in shard chains.
|
|
|
|
type ShardChainConfig struct {
|
|
|
|
ChunkSize uint64 // ChunkSize defines the size of each chunk in bytes.
|
|
|
|
MaxShardBlockSize uint64 // MaxShardBlockSize defines the max size of each shard block in bytes.
|
|
|
|
}
|
|
|
|
|
|
|
|
var defaultBeaconConfig = &BeaconChainConfig{
|
2019-01-06 04:36:05 +00:00
|
|
|
// Misc constant.
|
|
|
|
ShardCount: 1024,
|
2019-01-20 18:26:33 +00:00
|
|
|
TargetCommitteeSize: 128,
|
2019-01-06 04:36:05 +00:00
|
|
|
EjectionBalance: 16,
|
|
|
|
EjectionBalanceInGwei: 16 * 1e9,
|
2019-01-13 20:52:31 +00:00
|
|
|
MaxBalanceChurnQuotient: 32,
|
2019-01-06 04:36:05 +00:00
|
|
|
Gwei: 1e9,
|
|
|
|
BeaconChainShardNumber: 1<<64 - 1,
|
|
|
|
MaxCasperVotes: 1024,
|
|
|
|
LatestBlockRootsLength: 8192,
|
|
|
|
LatestRandaoMixesLength: 8192,
|
|
|
|
LatestPenalizedExitLength: 8192,
|
2019-01-16 05:52:57 +00:00
|
|
|
MaxWithdrawalsPerEpoch: 4,
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Deposit contract constants.
|
|
|
|
DepositContractTreeDepth: 32,
|
|
|
|
MaxDepositInGwei: 32 * 1e9,
|
2019-01-24 23:29:04 +00:00
|
|
|
MinDepositInGwei: 1 * 1e9,
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Initial value constants.
|
|
|
|
GenesisForkVersion: 0,
|
|
|
|
GenesisSlot: 0,
|
2019-01-20 18:26:33 +00:00
|
|
|
GenesisStartShard: 0,
|
2019-01-06 04:36:05 +00:00
|
|
|
FarFutureSlot: 1<<64 - 1,
|
|
|
|
ZeroHash: [32]byte{},
|
|
|
|
EmptySignature: makeEmptySignature(),
|
|
|
|
|
|
|
|
// Time parameter constants.
|
|
|
|
SlotDuration: 16,
|
|
|
|
MinAttestationInclusionDelay: 4,
|
|
|
|
EpochLength: 64,
|
|
|
|
SeedLookahead: 64,
|
|
|
|
EntryExitDelay: 256,
|
2019-01-09 04:42:42 +00:00
|
|
|
DepositRootVotingPeriod: 1024,
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Reward and penalty quotients constants.
|
|
|
|
BaseRewardQuotient: 1024,
|
|
|
|
WhistlerBlowerRewardQuotient: 512,
|
|
|
|
IncluderRewardQuotient: 8,
|
|
|
|
InactivityPenaltyQuotient: 1 << 24,
|
|
|
|
|
|
|
|
// Max operations per block constants.
|
|
|
|
MaxExits: 16,
|
|
|
|
MaxDeposits: 16,
|
|
|
|
MaxAttestations: 128,
|
|
|
|
MaxProposerSlashings: 16,
|
|
|
|
MaxCasperSlashings: 16,
|
|
|
|
|
|
|
|
// Prysm constants.
|
|
|
|
DepositsForChainStart: 16384,
|
|
|
|
RandBytes: 3,
|
|
|
|
SyncPollingInterval: 16 * 4, // Query nodes over the network every 4 slots for sync status.
|
|
|
|
GenesisTime: time.Date(2018, 9, 0, 0, 0, 0, 0, time.UTC),
|
|
|
|
MaxNumLog2Validators: 24,
|
2018-09-28 06:48:39 +00:00
|
|
|
}
|
|
|
|
|
2018-11-21 01:41:20 +00:00
|
|
|
var demoBeaconConfig = &BeaconChainConfig{
|
2019-01-06 04:36:05 +00:00
|
|
|
// Misc constant.
|
|
|
|
ShardCount: 5,
|
|
|
|
TargetCommitteeSize: 3,
|
|
|
|
EjectionBalance: defaultBeaconConfig.EjectionBalance,
|
|
|
|
EjectionBalanceInGwei: defaultBeaconConfig.EjectionBalanceInGwei,
|
2019-01-13 20:52:31 +00:00
|
|
|
MaxBalanceChurnQuotient: defaultBeaconConfig.MaxBalanceChurnQuotient,
|
2019-01-06 04:36:05 +00:00
|
|
|
Gwei: defaultBeaconConfig.Gwei,
|
|
|
|
BeaconChainShardNumber: defaultBeaconConfig.BeaconChainShardNumber,
|
|
|
|
MaxCasperVotes: defaultBeaconConfig.MaxCasperVotes,
|
|
|
|
LatestBlockRootsLength: defaultBeaconConfig.LatestBlockRootsLength,
|
|
|
|
LatestRandaoMixesLength: defaultBeaconConfig.LatestRandaoMixesLength,
|
|
|
|
LatestPenalizedExitLength: defaultBeaconConfig.LatestPenalizedExitLength,
|
2019-01-16 05:52:57 +00:00
|
|
|
MaxWithdrawalsPerEpoch: defaultBeaconConfig.MaxWithdrawalsPerEpoch,
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Deposit contract constants.
|
|
|
|
DepositContractTreeDepth: defaultBeaconConfig.DepositContractTreeDepth,
|
|
|
|
MaxDepositInGwei: defaultBeaconConfig.MaxDepositInGwei,
|
2019-01-24 23:29:04 +00:00
|
|
|
MinDepositInGwei: defaultBeaconConfig.MinDepositInGwei,
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Initial value constants.
|
|
|
|
GenesisForkVersion: defaultBeaconConfig.GenesisForkVersion,
|
|
|
|
GenesisSlot: defaultBeaconConfig.GenesisSlot,
|
2019-01-20 18:26:33 +00:00
|
|
|
GenesisStartShard: defaultBeaconConfig.GenesisStartShard,
|
2019-01-06 04:36:05 +00:00
|
|
|
FarFutureSlot: defaultBeaconConfig.FarFutureSlot,
|
|
|
|
ZeroHash: defaultBeaconConfig.ZeroHash,
|
|
|
|
EmptySignature: defaultBeaconConfig.EmptySignature,
|
|
|
|
|
|
|
|
// Time parameter constants.
|
|
|
|
SlotDuration: 2,
|
|
|
|
MinAttestationInclusionDelay: defaultBeaconConfig.MinAttestationInclusionDelay,
|
|
|
|
EpochLength: defaultBeaconConfig.EpochLength,
|
|
|
|
SeedLookahead: defaultBeaconConfig.SeedLookahead,
|
|
|
|
EntryExitDelay: defaultBeaconConfig.EntryExitDelay,
|
2019-01-09 04:42:42 +00:00
|
|
|
DepositRootVotingPeriod: defaultBeaconConfig.DepositRootVotingPeriod,
|
2019-01-06 04:36:05 +00:00
|
|
|
|
|
|
|
// Reward and penalty quotients constants.
|
|
|
|
BaseRewardQuotient: defaultBeaconConfig.BaseRewardQuotient,
|
|
|
|
WhistlerBlowerRewardQuotient: defaultBeaconConfig.WhistlerBlowerRewardQuotient,
|
|
|
|
IncluderRewardQuotient: defaultBeaconConfig.IncluderRewardQuotient,
|
|
|
|
InactivityPenaltyQuotient: defaultBeaconConfig.InactivityPenaltyQuotient,
|
|
|
|
|
|
|
|
// Max operations per block constants.
|
|
|
|
MaxExits: defaultBeaconConfig.MaxExits,
|
2019-01-24 23:29:04 +00:00
|
|
|
MaxDeposits: defaultBeaconConfig.MaxDeposits,
|
2019-01-06 04:36:05 +00:00
|
|
|
MaxAttestations: defaultBeaconConfig.MaxAttestations,
|
|
|
|
MaxProposerSlashings: defaultBeaconConfig.MaxProposerSlashings,
|
|
|
|
MaxCasperSlashings: defaultBeaconConfig.MaxCasperSlashings,
|
|
|
|
|
|
|
|
// Prysm constants.
|
|
|
|
DepositsForChainStart: defaultBeaconConfig.DepositsForChainStart,
|
|
|
|
RandBytes: defaultBeaconConfig.RandBytes,
|
|
|
|
SyncPollingInterval: 2 * 4, // Query nodes over the network every 4 slots for sync status.
|
|
|
|
GenesisTime: time.Now(),
|
|
|
|
MaxNumLog2Validators: defaultBeaconConfig.MaxNumLog2Validators,
|
2019-01-11 10:55:01 +00:00
|
|
|
SimulatedBlockRandao: [32]byte{'S', 'I', 'M', 'U', 'L', 'A', 'T', 'O', 'R'},
|
2018-09-28 06:48:39 +00:00
|
|
|
}
|
|
|
|
|
2018-11-21 01:41:20 +00:00
|
|
|
var defaultShardConfig = &ShardChainConfig{
|
|
|
|
ChunkSize: uint64(256),
|
|
|
|
MaxShardBlockSize: uint64(32768),
|
|
|
|
}
|
|
|
|
|
2018-11-18 16:39:35 +00:00
|
|
|
var beaconConfig = defaultBeaconConfig
|
2018-11-21 01:41:20 +00:00
|
|
|
var shardConfig = defaultShardConfig
|
2018-11-18 16:39:35 +00:00
|
|
|
|
2018-11-21 01:41:20 +00:00
|
|
|
// BeaconConfig retrieves beacon chain config.
|
|
|
|
func BeaconConfig() *BeaconChainConfig {
|
2018-11-18 16:39:35 +00:00
|
|
|
return beaconConfig
|
|
|
|
}
|
|
|
|
|
2018-11-21 01:41:20 +00:00
|
|
|
// ShardConfig retrieves shard chain config.
|
|
|
|
func ShardConfig() *ShardChainConfig {
|
|
|
|
return shardConfig
|
|
|
|
}
|
|
|
|
|
2018-11-18 16:39:35 +00:00
|
|
|
// UseDemoBeaconConfig for beacon chain services.
|
|
|
|
func UseDemoBeaconConfig() {
|
|
|
|
beaconConfig = demoBeaconConfig
|
|
|
|
}
|
|
|
|
|
|
|
|
// OverrideBeaconConfig by replacing the config. The preferred pattern is to
|
|
|
|
// call BeaconConfig(), change the specific parameters, and then call
|
|
|
|
// OverrideBeaconConfig(c). Any subsequent calls to params.BeaconConfig() will
|
|
|
|
// return this new configuration.
|
2018-11-21 01:41:20 +00:00
|
|
|
func OverrideBeaconConfig(c *BeaconChainConfig) {
|
2018-11-18 16:39:35 +00:00
|
|
|
beaconConfig = c
|
|
|
|
}
|