|
@@ -34,7 +34,7 @@ var (
|
|
|
|
|
|
|
|
BSCGenesisHash = common.HexToHash("0x0d21840abff46b96c84b2ac9e10e4f5cdaeb5693cb665db62a2f3b02d2d57b5b")
|
|
BSCGenesisHash = common.HexToHash("0x0d21840abff46b96c84b2ac9e10e4f5cdaeb5693cb665db62a2f3b02d2d57b5b")
|
|
|
ChapelGenesisHash = common.HexToHash("0x6d3c66c5357ec91d5c43af47e234a939b22557cbb552dc45bebbceeed90fbe34")
|
|
ChapelGenesisHash = common.HexToHash("0x6d3c66c5357ec91d5c43af47e234a939b22557cbb552dc45bebbceeed90fbe34")
|
|
|
- RialtoGenesisHash = common.HexToHash("0x005dc005bddd1967de6187c1c23be801eb7abdd80cebcc24f341b727b70311d6")
|
|
|
|
|
|
|
+ RialtoGenesisHash = common.HexToHash("0xaabe549bfa85c84f7aee9da7010b97453ad686f2c2d8ce00503d1a00c72cad54")
|
|
|
YoloV3GenesisHash = common.HexToHash("0xf1f2876e8500c77afcc03228757b39477eceffccf645b734967fe3c7e16967b7")
|
|
YoloV3GenesisHash = common.HexToHash("0xf1f2876e8500c77afcc03228757b39477eceffccf645b734967fe3c7e16967b7")
|
|
|
)
|
|
)
|
|
|
|
|
|
|
@@ -75,6 +75,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(0),
|
|
RamanujanBlock: big.NewInt(0),
|
|
|
NielsBlock: big.NewInt(0),
|
|
NielsBlock: big.NewInt(0),
|
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
|
|
|
+ BrunoBlock: big.NewInt(0),
|
|
|
BerlinBlock: big.NewInt(12_244_000),
|
|
BerlinBlock: big.NewInt(12_244_000),
|
|
|
Ethash: new(EthashConfig),
|
|
Ethash: new(EthashConfig),
|
|
|
}
|
|
}
|
|
@@ -118,6 +119,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(0),
|
|
RamanujanBlock: big.NewInt(0),
|
|
|
NielsBlock: big.NewInt(0),
|
|
NielsBlock: big.NewInt(0),
|
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
|
|
|
+ BrunoBlock: big.NewInt(0),
|
|
|
BerlinBlock: big.NewInt(9_812_189),
|
|
BerlinBlock: big.NewInt(9_812_189),
|
|
|
Ethash: new(EthashConfig),
|
|
Ethash: new(EthashConfig),
|
|
|
}
|
|
}
|
|
@@ -161,6 +163,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(0),
|
|
RamanujanBlock: big.NewInt(0),
|
|
|
NielsBlock: big.NewInt(0),
|
|
NielsBlock: big.NewInt(0),
|
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
|
|
|
+ BrunoBlock: big.NewInt(0),
|
|
|
BerlinBlock: big.NewInt(8_290_928),
|
|
BerlinBlock: big.NewInt(8_290_928),
|
|
|
Clique: &CliqueConfig{
|
|
Clique: &CliqueConfig{
|
|
|
Period: 15,
|
|
Period: 15,
|
|
@@ -203,6 +206,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(0),
|
|
RamanujanBlock: big.NewInt(0),
|
|
|
NielsBlock: big.NewInt(0),
|
|
NielsBlock: big.NewInt(0),
|
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
|
|
|
+ BrunoBlock: big.NewInt(0),
|
|
|
IstanbulBlock: big.NewInt(1_561_651),
|
|
IstanbulBlock: big.NewInt(1_561_651),
|
|
|
MuirGlacierBlock: nil,
|
|
MuirGlacierBlock: nil,
|
|
|
BerlinBlock: big.NewInt(4_460_644),
|
|
BerlinBlock: big.NewInt(4_460_644),
|
|
@@ -246,6 +250,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(0),
|
|
RamanujanBlock: big.NewInt(0),
|
|
|
NielsBlock: big.NewInt(0),
|
|
NielsBlock: big.NewInt(0),
|
|
|
MirrorSyncBlock: big.NewInt(5184000),
|
|
MirrorSyncBlock: big.NewInt(5184000),
|
|
|
|
|
+ BrunoBlock: nil,
|
|
|
Parlia: &ParliaConfig{
|
|
Parlia: &ParliaConfig{
|
|
|
Period: 3,
|
|
Period: 3,
|
|
|
Epoch: 200,
|
|
Epoch: 200,
|
|
@@ -266,6 +271,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(1010000),
|
|
RamanujanBlock: big.NewInt(1010000),
|
|
|
NielsBlock: big.NewInt(1014369),
|
|
NielsBlock: big.NewInt(1014369),
|
|
|
MirrorSyncBlock: big.NewInt(5582500),
|
|
MirrorSyncBlock: big.NewInt(5582500),
|
|
|
|
|
+ BrunoBlock: big.NewInt(13837000),
|
|
|
Parlia: &ParliaConfig{
|
|
Parlia: &ParliaConfig{
|
|
|
Period: 3,
|
|
Period: 3,
|
|
|
Epoch: 200,
|
|
Epoch: 200,
|
|
@@ -286,6 +292,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(400),
|
|
RamanujanBlock: big.NewInt(400),
|
|
|
NielsBlock: big.NewInt(0),
|
|
NielsBlock: big.NewInt(0),
|
|
|
MirrorSyncBlock: big.NewInt(400),
|
|
MirrorSyncBlock: big.NewInt(400),
|
|
|
|
|
+ BrunoBlock: big.NewInt(400),
|
|
|
Parlia: &ParliaConfig{
|
|
Parlia: &ParliaConfig{
|
|
|
Period: 3,
|
|
Period: 3,
|
|
|
Epoch: 200,
|
|
Epoch: 200,
|
|
@@ -308,6 +315,7 @@ var (
|
|
|
RamanujanBlock: big.NewInt(0),
|
|
RamanujanBlock: big.NewInt(0),
|
|
|
NielsBlock: big.NewInt(0),
|
|
NielsBlock: big.NewInt(0),
|
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
MirrorSyncBlock: big.NewInt(0),
|
|
|
|
|
+ BrunoBlock: big.NewInt(0),
|
|
|
MuirGlacierBlock: nil,
|
|
MuirGlacierBlock: nil,
|
|
|
BerlinBlock: nil, // Don't enable Berlin directly, we're YOLOing it
|
|
BerlinBlock: nil, // Don't enable Berlin directly, we're YOLOing it
|
|
|
YoloV3Block: big.NewInt(0),
|
|
YoloV3Block: big.NewInt(0),
|
|
@@ -322,16 +330,16 @@ var (
|
|
|
//
|
|
//
|
|
|
// This configuration is intentionally not using keyed fields to force anyone
|
|
// This configuration is intentionally not using keyed fields to force anyone
|
|
|
// adding flags to the config to also have to set these fields.
|
|
// adding flags to the config to also have to set these fields.
|
|
|
- AllEthashProtocolChanges = &ChainConfig{big.NewInt(1337), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, big.NewInt(0), big.NewInt(0), big.NewInt(0), new(EthashConfig), nil, nil}
|
|
|
|
|
|
|
+ AllEthashProtocolChanges = &ChainConfig{big.NewInt(1337), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), new(EthashConfig), nil, nil}
|
|
|
|
|
|
|
|
// AllCliqueProtocolChanges contains every protocol change (EIPs) introduced
|
|
// AllCliqueProtocolChanges contains every protocol change (EIPs) introduced
|
|
|
// and accepted by the Ethereum core developers into the Clique consensus.
|
|
// and accepted by the Ethereum core developers into the Clique consensus.
|
|
|
//
|
|
//
|
|
|
// This configuration is intentionally not using keyed fields to force anyone
|
|
// This configuration is intentionally not using keyed fields to force anyone
|
|
|
// adding flags to the config to also have to set these fields.
|
|
// adding flags to the config to also have to set these fields.
|
|
|
- AllCliqueProtocolChanges = &ChainConfig{big.NewInt(1337), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, &CliqueConfig{Period: 0, Epoch: 30000}, nil}
|
|
|
|
|
|
|
+ AllCliqueProtocolChanges = &ChainConfig{big.NewInt(1337), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, &CliqueConfig{Period: 0, Epoch: 30000}, nil}
|
|
|
|
|
|
|
|
- TestChainConfig = &ChainConfig{big.NewInt(1), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, big.NewInt(0), big.NewInt(0), big.NewInt(0), new(EthashConfig), nil, nil}
|
|
|
|
|
|
|
+ TestChainConfig = &ChainConfig{big.NewInt(1), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), new(EthashConfig), nil, nil}
|
|
|
|
|
|
|
|
TestRules = TestChainConfig.Rules(new(big.Int))
|
|
TestRules = TestChainConfig.Rules(new(big.Int))
|
|
|
)
|
|
)
|
|
@@ -418,6 +426,7 @@ type ChainConfig struct {
|
|
|
RamanujanBlock *big.Int `json:"ramanujanBlock,omitempty" toml:",omitempty"` // ramanujanBlock switch block (nil = no fork, 0 = already activated)
|
|
RamanujanBlock *big.Int `json:"ramanujanBlock,omitempty" toml:",omitempty"` // ramanujanBlock switch block (nil = no fork, 0 = already activated)
|
|
|
NielsBlock *big.Int `json:"nielsBlock,omitempty" toml:",omitempty"` // nielsBlock switch block (nil = no fork, 0 = already activated)
|
|
NielsBlock *big.Int `json:"nielsBlock,omitempty" toml:",omitempty"` // nielsBlock switch block (nil = no fork, 0 = already activated)
|
|
|
MirrorSyncBlock *big.Int `json:"mirrorSyncBlock,omitempty" toml:",omitempty"` // mirrorSyncBlock switch block (nil = no fork, 0 = already activated)
|
|
MirrorSyncBlock *big.Int `json:"mirrorSyncBlock,omitempty" toml:",omitempty"` // mirrorSyncBlock switch block (nil = no fork, 0 = already activated)
|
|
|
|
|
+ BrunoBlock *big.Int `json:"brunoBlock,omitempty" toml:",omitempty"` // brunoBlock switch block (nil = no fork, 0 = already activated)
|
|
|
|
|
|
|
|
// Various consensus engines
|
|
// Various consensus engines
|
|
|
Ethash *EthashConfig `json:"ethash,omitempty" toml:",omitempty"`
|
|
Ethash *EthashConfig `json:"ethash,omitempty" toml:",omitempty"`
|
|
@@ -468,7 +477,7 @@ func (c *ChainConfig) String() string {
|
|
|
default:
|
|
default:
|
|
|
engine = "unknown"
|
|
engine = "unknown"
|
|
|
}
|
|
}
|
|
|
- return fmt.Sprintf("{ChainID: %v Homestead: %v DAO: %v DAOSupport: %v EIP150: %v EIP155: %v EIP158: %v Byzantium: %v Constantinople: %v Petersburg: %v Istanbul: %v, Muir Glacier: %v, Ramanujan: %v, Niels: %v, MirrorSync: %v, Berlin: %v, YOLO v3: %v, Engine: %v}",
|
|
|
|
|
|
|
+ return fmt.Sprintf("{ChainID: %v Homestead: %v DAO: %v DAOSupport: %v EIP150: %v EIP155: %v EIP158: %v Byzantium: %v Constantinople: %v Petersburg: %v Istanbul: %v, Muir Glacier: %v, Ramanujan: %v, Niels: %v, MirrorSync: %v, Bruno: %v, Berlin: %v, YOLO v3: %v, Engine: %v}",
|
|
|
c.ChainID,
|
|
c.ChainID,
|
|
|
c.HomesteadBlock,
|
|
c.HomesteadBlock,
|
|
|
c.DAOForkBlock,
|
|
c.DAOForkBlock,
|
|
@@ -484,6 +493,7 @@ func (c *ChainConfig) String() string {
|
|
|
c.RamanujanBlock,
|
|
c.RamanujanBlock,
|
|
|
c.NielsBlock,
|
|
c.NielsBlock,
|
|
|
c.MirrorSyncBlock,
|
|
c.MirrorSyncBlock,
|
|
|
|
|
+ c.BrunoBlock,
|
|
|
c.BerlinBlock,
|
|
c.BerlinBlock,
|
|
|
c.YoloV3Block,
|
|
c.YoloV3Block,
|
|
|
engine,
|
|
engine,
|
|
@@ -555,6 +565,16 @@ func (c *ChainConfig) IsOnMirrorSync(num *big.Int) bool {
|
|
|
return configNumEqual(c.MirrorSyncBlock, num)
|
|
return configNumEqual(c.MirrorSyncBlock, num)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+// IsBruno returns whether num is either equal to the Burn fork block or greater.
|
|
|
|
|
+func (c *ChainConfig) IsBruno(num *big.Int) bool {
|
|
|
|
|
+ return isForked(c.BrunoBlock, num)
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+// IsOnBruno returns whether num is equal to the Burn fork block
|
|
|
|
|
+func (c *ChainConfig) IsOnBruno(num *big.Int) bool {
|
|
|
|
|
+ return configNumEqual(c.BrunoBlock, num)
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
// IsMuirGlacier returns whether num is either equal to the Muir Glacier (EIP-2384) fork block or greater.
|
|
// IsMuirGlacier returns whether num is either equal to the Muir Glacier (EIP-2384) fork block or greater.
|
|
|
func (c *ChainConfig) IsMuirGlacier(num *big.Int) bool {
|
|
func (c *ChainConfig) IsMuirGlacier(num *big.Int) bool {
|
|
|
return isForked(c.MuirGlacierBlock, num)
|
|
return isForked(c.MuirGlacierBlock, num)
|
|
@@ -616,6 +636,7 @@ func (c *ChainConfig) CheckConfigForkOrder() error {
|
|
|
var lastFork fork
|
|
var lastFork fork
|
|
|
for _, cur := range []fork{
|
|
for _, cur := range []fork{
|
|
|
{name: "mirrorSyncBlock", block: c.MirrorSyncBlock},
|
|
{name: "mirrorSyncBlock", block: c.MirrorSyncBlock},
|
|
|
|
|
+ {name: "brunoBlock", block: c.BrunoBlock},
|
|
|
{name: "berlinBlock", block: c.BerlinBlock},
|
|
{name: "berlinBlock", block: c.BerlinBlock},
|
|
|
} {
|
|
} {
|
|
|
if lastFork.name != "" {
|
|
if lastFork.name != "" {
|
|
@@ -695,6 +716,9 @@ func (c *ChainConfig) checkCompatible(newcfg *ChainConfig, head *big.Int) *Confi
|
|
|
if isForkIncompatible(c.MirrorSyncBlock, newcfg.MirrorSyncBlock, head) {
|
|
if isForkIncompatible(c.MirrorSyncBlock, newcfg.MirrorSyncBlock, head) {
|
|
|
return newCompatError("mirrorSync fork block", c.MirrorSyncBlock, newcfg.MirrorSyncBlock)
|
|
return newCompatError("mirrorSync fork block", c.MirrorSyncBlock, newcfg.MirrorSyncBlock)
|
|
|
}
|
|
}
|
|
|
|
|
+ if isForkIncompatible(c.BrunoBlock, newcfg.BrunoBlock, head) {
|
|
|
|
|
+ return newCompatError("bruno fork block", c.BrunoBlock, newcfg.BrunoBlock)
|
|
|
|
|
+ }
|
|
|
return nil
|
|
return nil
|
|
|
}
|
|
}
|
|
|
|
|
|