2019-08-26 18:23:11 +00:00
|
|
|
package build
|
|
|
|
|
2019-10-16 07:07:16 +00:00
|
|
|
import (
|
|
|
|
"math/big"
|
2020-03-31 23:13:37 +00:00
|
|
|
|
|
|
|
"github.com/libp2p/go-libp2p-core/protocol"
|
|
|
|
|
|
|
|
"github.com/filecoin-project/lotus/node/modules/dtypes"
|
2019-10-16 07:07:16 +00:00
|
|
|
)
|
2019-09-27 21:42:12 +00:00
|
|
|
|
2019-08-26 18:23:11 +00:00
|
|
|
// Core network constants
|
|
|
|
|
2020-03-31 23:13:37 +00:00
|
|
|
func BlocksTopic(netName dtypes.NetworkName) string { return "/fil/blocks/" + string(netName) }
|
|
|
|
func MessagesTopic(netName dtypes.NetworkName) string { return "/fil/msgs/" + string(netName) }
|
|
|
|
func DhtProtocolName(netName dtypes.NetworkName) protocol.ID {
|
|
|
|
return protocol.ID("/fil/kad/" + string(netName))
|
|
|
|
}
|
2020-03-03 23:44:08 +00:00
|
|
|
|
2019-09-24 11:16:05 +00:00
|
|
|
// /////
|
|
|
|
// Storage
|
|
|
|
|
2019-08-26 18:23:11 +00:00
|
|
|
const UnixfsChunkSize uint64 = 1 << 20
|
2019-08-27 22:10:23 +00:00
|
|
|
const UnixfsLinksPerLevel = 1024
|
|
|
|
|
2020-02-12 17:41:35 +00:00
|
|
|
const SectorChallengeRatioDiv = 25
|
|
|
|
|
2019-09-24 11:16:05 +00:00
|
|
|
// /////
|
|
|
|
// Payments
|
|
|
|
|
2019-11-28 12:46:56 +00:00
|
|
|
// Epochs
|
2019-12-10 10:52:24 +00:00
|
|
|
const PaymentChannelClosingDelay = 6 * 60 * 60 / BlockDelay // six hours
|
2019-09-09 13:55:06 +00:00
|
|
|
|
2019-09-24 11:16:05 +00:00
|
|
|
// /////
|
|
|
|
// Consensus / Network
|
|
|
|
|
|
|
|
// Seconds
|
2019-12-16 00:43:32 +00:00
|
|
|
const AllowableClockDrift = 1
|
2019-09-24 11:16:05 +00:00
|
|
|
|
2019-11-28 12:46:56 +00:00
|
|
|
// Epochs
|
2019-11-15 00:20:39 +00:00
|
|
|
const ForkLengthThreshold = Finality
|
2019-09-19 16:17:49 +00:00
|
|
|
|
2019-10-13 01:18:59 +00:00
|
|
|
// Blocks (e)
|
2019-11-09 00:18:15 +00:00
|
|
|
const BlocksPerEpoch = 5
|
2019-10-13 01:18:59 +00:00
|
|
|
|
2019-11-28 12:46:56 +00:00
|
|
|
// Epochs
|
2019-10-28 17:14:24 +00:00
|
|
|
const Finality = 500
|
|
|
|
|
2019-11-09 00:18:15 +00:00
|
|
|
// constants for Weight calculation
|
|
|
|
// The ratio of weight contributed by short-term vs long-term factors in a given round
|
|
|
|
const WRatioNum = int64(1)
|
|
|
|
const WRatioDen = 2
|
|
|
|
|
2019-09-24 11:16:05 +00:00
|
|
|
// /////
|
2019-10-28 08:15:08 +00:00
|
|
|
// Proofs
|
2019-09-24 11:16:05 +00:00
|
|
|
|
2020-03-09 06:54:29 +00:00
|
|
|
// Epochs
|
|
|
|
const FallbackPoStConfidence = 6
|
|
|
|
|
2019-11-28 12:46:56 +00:00
|
|
|
// Epochs
|
2019-10-28 17:14:24 +00:00
|
|
|
const SealRandomnessLookback = Finality
|
|
|
|
|
2019-11-28 12:46:56 +00:00
|
|
|
// Epochs
|
2020-04-03 17:45:48 +00:00
|
|
|
const SealRandomnessLookbackLimit = SealRandomnessLookback + 2000 // TODO: Get from spec specs-actors
|
2019-11-05 16:15:52 +00:00
|
|
|
|
2020-01-08 21:40:51 +00:00
|
|
|
// Maximum lookback that randomness can be sourced from for a seal proof submission
|
2020-04-03 17:45:48 +00:00
|
|
|
const MaxSealLookback = SealRandomnessLookbackLimit + 2000 // TODO: Get from specs-actors
|
2020-01-08 21:40:51 +00:00
|
|
|
|
2019-10-28 08:15:08 +00:00
|
|
|
// /////
|
|
|
|
// Mining
|
2019-09-24 11:16:05 +00:00
|
|
|
|
2019-11-28 12:46:56 +00:00
|
|
|
// Epochs
|
2020-04-06 12:47:14 +00:00
|
|
|
const EcRandomnessLookback = Finality
|
2019-09-19 13:32:00 +00:00
|
|
|
|
2019-09-24 11:16:05 +00:00
|
|
|
// /////
|
|
|
|
// Devnet settings
|
|
|
|
|
2019-11-08 08:40:02 +00:00
|
|
|
const TotalFilecoin = 2_000_000_000
|
|
|
|
const MiningRewardTotal = 1_400_000_000
|
2019-09-26 22:33:38 +00:00
|
|
|
|
2019-11-08 08:40:02 +00:00
|
|
|
const FilecoinPrecision = 1_000_000_000_000_000_000
|
2019-09-12 04:12:35 +00:00
|
|
|
|
2020-03-07 01:33:24 +00:00
|
|
|
var InitialRewardBalance *big.Int
|
|
|
|
|
2019-08-26 18:23:11 +00:00
|
|
|
// TODO: Move other important consts here
|
2019-09-27 21:42:12 +00:00
|
|
|
|
|
|
|
func init() {
|
2020-03-07 01:33:24 +00:00
|
|
|
InitialRewardBalance = big.NewInt(MiningRewardTotal)
|
|
|
|
InitialRewardBalance = InitialRewardBalance.Mul(InitialRewardBalance, big.NewInt(FilecoinPrecision))
|
2019-09-27 21:42:12 +00:00
|
|
|
}
|
2019-10-09 12:55:27 +00:00
|
|
|
|
|
|
|
// Sync
|
2019-11-11 22:37:34 +00:00
|
|
|
const BadBlockCacheSize = 1 << 15
|
2019-11-12 07:16:42 +00:00
|
|
|
|
2019-11-28 12:46:56 +00:00
|
|
|
// assuming 4000 messages per round, this lets us not lose any messages across a
|
2019-11-11 22:37:34 +00:00
|
|
|
// 10 block reorg.
|
2019-11-12 07:16:42 +00:00
|
|
|
const BlsSignatureCacheSize = 40000
|
2020-01-07 20:41:26 +00:00
|
|
|
|
|
|
|
// ///////
|
|
|
|
// Limits
|
|
|
|
|
|
|
|
const BlockMessageLimit = 512
|