|
|
@ -66,6 +66,7 @@ var ( |
|
|
|
ConstantinopleBlock: big.NewInt(7280000), |
|
|
|
ConstantinopleBlock: big.NewInt(7280000), |
|
|
|
PetersburgBlock: big.NewInt(7280000), |
|
|
|
PetersburgBlock: big.NewInt(7280000), |
|
|
|
IstanbulBlock: big.NewInt(9069000), |
|
|
|
IstanbulBlock: big.NewInt(9069000), |
|
|
|
|
|
|
|
MuirGlacierBlock: big.NewInt(9200000), |
|
|
|
Ethash: new(EthashConfig), |
|
|
|
Ethash: new(EthashConfig), |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -104,6 +105,7 @@ var ( |
|
|
|
ConstantinopleBlock: big.NewInt(4230000), |
|
|
|
ConstantinopleBlock: big.NewInt(4230000), |
|
|
|
PetersburgBlock: big.NewInt(4939394), |
|
|
|
PetersburgBlock: big.NewInt(4939394), |
|
|
|
IstanbulBlock: big.NewInt(6485846), |
|
|
|
IstanbulBlock: big.NewInt(6485846), |
|
|
|
|
|
|
|
MuirGlacierBlock: big.NewInt(7117117), |
|
|
|
Ethash: new(EthashConfig), |
|
|
|
Ethash: new(EthashConfig), |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -213,16 +215,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), nil, new(EthashConfig), 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), nil, nil, new(EthashConfig), 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), nil, nil, &CliqueConfig{Period: 0, Epoch: 30000}} |
|
|
|
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), nil, nil, nil, &CliqueConfig{Period: 0, Epoch: 30000}} |
|
|
|
|
|
|
|
|
|
|
|
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), nil, new(EthashConfig), 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), nil, nil, new(EthashConfig), nil} |
|
|
|
TestRules = TestChainConfig.Rules(new(big.Int)) |
|
|
|
TestRules = TestChainConfig.Rules(new(big.Int)) |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
@ -292,6 +294,7 @@ type ChainConfig struct { |
|
|
|
ConstantinopleBlock *big.Int `json:"constantinopleBlock,omitempty"` // Constantinople switch block (nil = no fork, 0 = already activated)
|
|
|
|
ConstantinopleBlock *big.Int `json:"constantinopleBlock,omitempty"` // Constantinople switch block (nil = no fork, 0 = already activated)
|
|
|
|
PetersburgBlock *big.Int `json:"petersburgBlock,omitempty"` // Petersburg switch block (nil = same as Constantinople)
|
|
|
|
PetersburgBlock *big.Int `json:"petersburgBlock,omitempty"` // Petersburg switch block (nil = same as Constantinople)
|
|
|
|
IstanbulBlock *big.Int `json:"istanbulBlock,omitempty"` // Istanbul switch block (nil = no fork, 0 = already on istanbul)
|
|
|
|
IstanbulBlock *big.Int `json:"istanbulBlock,omitempty"` // Istanbul switch block (nil = no fork, 0 = already on istanbul)
|
|
|
|
|
|
|
|
MuirGlacierBlock *big.Int `json:"muirGlacierBlock,omitempty"` // Eip-2384 (bomb delay) switch block (nil = no fork, 0 = already activated)
|
|
|
|
EWASMBlock *big.Int `json:"ewasmBlock,omitempty"` // EWASM switch block (nil = no fork, 0 = already activated)
|
|
|
|
EWASMBlock *big.Int `json:"ewasmBlock,omitempty"` // EWASM switch block (nil = no fork, 0 = already activated)
|
|
|
|
|
|
|
|
|
|
|
|
// Various consensus engines
|
|
|
|
// Various consensus engines
|
|
|
@ -329,7 +332,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 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, Engine: %v}", |
|
|
|
c.ChainID, |
|
|
|
c.ChainID, |
|
|
|
c.HomesteadBlock, |
|
|
|
c.HomesteadBlock, |
|
|
|
c.DAOForkBlock, |
|
|
|
c.DAOForkBlock, |
|
|
@ -341,6 +344,7 @@ func (c *ChainConfig) String() string { |
|
|
|
c.ConstantinopleBlock, |
|
|
|
c.ConstantinopleBlock, |
|
|
|
c.PetersburgBlock, |
|
|
|
c.PetersburgBlock, |
|
|
|
c.IstanbulBlock, |
|
|
|
c.IstanbulBlock, |
|
|
|
|
|
|
|
c.MuirGlacierBlock, |
|
|
|
engine, |
|
|
|
engine, |
|
|
|
) |
|
|
|
) |
|
|
|
} |
|
|
|
} |
|
|
@ -380,6 +384,11 @@ func (c *ChainConfig) IsConstantinople(num *big.Int) bool { |
|
|
|
return isForked(c.ConstantinopleBlock, num) |
|
|
|
return isForked(c.ConstantinopleBlock, num) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 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 { |
|
|
|
|
|
|
|
return isForked(c.MuirGlacierBlock, num) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// IsPetersburg returns whether num is either
|
|
|
|
// IsPetersburg returns whether num is either
|
|
|
|
// - equal to or greater than the PetersburgBlock fork block,
|
|
|
|
// - equal to or greater than the PetersburgBlock fork block,
|
|
|
|
// - OR is nil, and Constantinople is active
|
|
|
|
// - OR is nil, and Constantinople is active
|
|
|
@ -432,6 +441,7 @@ func (c *ChainConfig) CheckConfigForkOrder() error { |
|
|
|
{"constantinopleBlock", c.ConstantinopleBlock}, |
|
|
|
{"constantinopleBlock", c.ConstantinopleBlock}, |
|
|
|
{"petersburgBlock", c.PetersburgBlock}, |
|
|
|
{"petersburgBlock", c.PetersburgBlock}, |
|
|
|
{"istanbulBlock", c.IstanbulBlock}, |
|
|
|
{"istanbulBlock", c.IstanbulBlock}, |
|
|
|
|
|
|
|
{"muirGlacierBlock", c.MuirGlacierBlock}, |
|
|
|
} { |
|
|
|
} { |
|
|
|
if lastFork.name != "" { |
|
|
|
if lastFork.name != "" { |
|
|
|
// Next one must be higher number
|
|
|
|
// Next one must be higher number
|
|
|
@ -485,6 +495,9 @@ func (c *ChainConfig) checkCompatible(newcfg *ChainConfig, head *big.Int) *Confi |
|
|
|
if isForkIncompatible(c.IstanbulBlock, newcfg.IstanbulBlock, head) { |
|
|
|
if isForkIncompatible(c.IstanbulBlock, newcfg.IstanbulBlock, head) { |
|
|
|
return newCompatError("Istanbul fork block", c.IstanbulBlock, newcfg.IstanbulBlock) |
|
|
|
return newCompatError("Istanbul fork block", c.IstanbulBlock, newcfg.IstanbulBlock) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if isForkIncompatible(c.MuirGlacierBlock, newcfg.MuirGlacierBlock, head) { |
|
|
|
|
|
|
|
return newCompatError("Muir Glacier fork block", c.MuirGlacierBlock, newcfg.MuirGlacierBlock) |
|
|
|
|
|
|
|
} |
|
|
|
if isForkIncompatible(c.EWASMBlock, newcfg.EWASMBlock, head) { |
|
|
|
if isForkIncompatible(c.EWASMBlock, newcfg.EWASMBlock, head) { |
|
|
|
return newCompatError("ewasm fork block", c.EWASMBlock, newcfg.EWASMBlock) |
|
|
|
return newCompatError("ewasm fork block", c.EWASMBlock, newcfg.EWASMBlock) |
|
|
|
} |
|
|
|
} |
|
|
|