Updates for consensus engine injection
This commit is contained in:
parent
c6e1ed0c2b
commit
2c24710d5d
@ -113,6 +113,10 @@ type StateDB interface {
|
|||||||
SlotInAccessList(addr Address, slot Hash) (addressOk bool, slotOk bool)
|
SlotInAccessList(addr Address, slot Hash) (addressOk bool, slotOk bool)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type RWStateDB interface {
|
||||||
|
StateDB
|
||||||
|
}
|
||||||
|
|
||||||
type ScopeContext interface {
|
type ScopeContext interface {
|
||||||
Memory() Memory
|
Memory() Memory
|
||||||
Stack() Stack
|
Stack() Stack
|
||||||
|
@ -34,231 +34,6 @@ var (
|
|||||||
CalaverasGenesisHash = core.HexToHash("0xeb9233d066c275efcdfed8037f4fc082770176aefdbcb7691c71da412a5670f2")
|
CalaverasGenesisHash = core.HexToHash("0xeb9233d066c275efcdfed8037f4fc082770176aefdbcb7691c71da412a5670f2")
|
||||||
)
|
)
|
||||||
|
|
||||||
// TrustedCheckpoints associates each known checkpoint with the genesis hash of
|
|
||||||
// the chain it belongs to.
|
|
||||||
var TrustedCheckpoints = map[core.Hash]*TrustedCheckpoint{
|
|
||||||
MainnetGenesisHash: MainnetTrustedCheckpoint,
|
|
||||||
RopstenGenesisHash: RopstenTrustedCheckpoint,
|
|
||||||
RinkebyGenesisHash: RinkebyTrustedCheckpoint,
|
|
||||||
GoerliGenesisHash: GoerliTrustedCheckpoint,
|
|
||||||
}
|
|
||||||
|
|
||||||
// CheckpointOracles associates each known checkpoint oracles with the genesis hash of
|
|
||||||
// the chain it belongs to.
|
|
||||||
var CheckpointOracles = map[core.Hash]*CheckpointOracleConfig{
|
|
||||||
MainnetGenesisHash: MainnetCheckpointOracle,
|
|
||||||
RopstenGenesisHash: RopstenCheckpointOracle,
|
|
||||||
RinkebyGenesisHash: RinkebyCheckpointOracle,
|
|
||||||
GoerliGenesisHash: GoerliCheckpointOracle,
|
|
||||||
}
|
|
||||||
|
|
||||||
var (
|
|
||||||
// MainnetChainConfig is the chain parameters to run a node on the main network.
|
|
||||||
MainnetChainConfig = &ChainConfig{
|
|
||||||
ChainID: big.NewInt(1),
|
|
||||||
HomesteadBlock: big.NewInt(1_150_000),
|
|
||||||
DAOForkBlock: big.NewInt(1_920_000),
|
|
||||||
DAOForkSupport: true,
|
|
||||||
EIP150Block: big.NewInt(2_463_000),
|
|
||||||
EIP150Hash: core.HexToHash("0x2086799aeebeae135c246c65021c82b4e15a2c451340993aacfd2751886514f0"),
|
|
||||||
EIP155Block: big.NewInt(2_675_000),
|
|
||||||
EIP158Block: big.NewInt(2_675_000),
|
|
||||||
ByzantiumBlock: big.NewInt(4_370_000),
|
|
||||||
ConstantinopleBlock: big.NewInt(7_280_000),
|
|
||||||
PetersburgBlock: big.NewInt(7_280_000),
|
|
||||||
IstanbulBlock: big.NewInt(9_069_000),
|
|
||||||
MuirGlacierBlock: big.NewInt(9_200_000),
|
|
||||||
BerlinBlock: big.NewInt(12_244_000),
|
|
||||||
LondonBlock: big.NewInt(12_965_000),
|
|
||||||
Ethash: new(EthashConfig),
|
|
||||||
}
|
|
||||||
|
|
||||||
// MainnetTrustedCheckpoint contains the light client trusted checkpoint for the main network.
|
|
||||||
MainnetTrustedCheckpoint = &TrustedCheckpoint{
|
|
||||||
SectionIndex: 389,
|
|
||||||
SectionHead: core.HexToHash("0x8f96e510cf64abf34095c5aa3937acdf5316de5540945b9688f4a2e083cddc73"),
|
|
||||||
CHTRoot: core.HexToHash("0xa2362493848d6dbc50dcbbf74c017ea808b8938bfb129217d507bd276950d7ac"),
|
|
||||||
BloomRoot: core.HexToHash("0x72fc78a841bde7e08e1fb7c187b622c49dc8271db12db748ff5d0f27bdb41413"),
|
|
||||||
}
|
|
||||||
|
|
||||||
// MainnetCheckpointOracle contains a set of configs for the main network oracle.
|
|
||||||
MainnetCheckpointOracle = &CheckpointOracleConfig{
|
|
||||||
Address: core.HexToAddress("0x9a9070028361F7AAbeB3f2F2Dc07F82C4a98A02a"),
|
|
||||||
Signers: []core.Address{
|
|
||||||
core.HexToAddress("0x1b2C260efc720BE89101890E4Db589b44E950527"), // Peter
|
|
||||||
core.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin
|
|
||||||
core.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt
|
|
||||||
core.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary
|
|
||||||
core.HexToAddress("0x0DF8fa387C602AE62559cC4aFa4972A7045d6707"), // Guillaume
|
|
||||||
},
|
|
||||||
Threshold: 2,
|
|
||||||
}
|
|
||||||
|
|
||||||
// RopstenChainConfig contains the chain parameters to run a node on the Ropsten test network.
|
|
||||||
RopstenChainConfig = &ChainConfig{
|
|
||||||
ChainID: big.NewInt(3),
|
|
||||||
HomesteadBlock: big.NewInt(0),
|
|
||||||
DAOForkBlock: nil,
|
|
||||||
DAOForkSupport: true,
|
|
||||||
EIP150Block: big.NewInt(0),
|
|
||||||
EIP150Hash: core.HexToHash("0x41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d"),
|
|
||||||
EIP155Block: big.NewInt(10),
|
|
||||||
EIP158Block: big.NewInt(10),
|
|
||||||
ByzantiumBlock: big.NewInt(1_700_000),
|
|
||||||
ConstantinopleBlock: big.NewInt(4_230_000),
|
|
||||||
PetersburgBlock: big.NewInt(4_939_394),
|
|
||||||
IstanbulBlock: big.NewInt(6_485_846),
|
|
||||||
MuirGlacierBlock: big.NewInt(7_117_117),
|
|
||||||
BerlinBlock: big.NewInt(9_812_189),
|
|
||||||
LondonBlock: big.NewInt(10_499_401),
|
|
||||||
Ethash: new(EthashConfig),
|
|
||||||
}
|
|
||||||
|
|
||||||
// RopstenTrustedCheckpoint contains the light client trusted checkpoint for the Ropsten test network.
|
|
||||||
RopstenTrustedCheckpoint = &TrustedCheckpoint{
|
|
||||||
SectionIndex: 322,
|
|
||||||
SectionHead: core.HexToHash("0xe3f2fb70acd752bbcac06b67688db8430815c788a31213011ed51b966108a5f4"),
|
|
||||||
CHTRoot: core.HexToHash("0xb2993a6bc28b23b84159cb477c38c0ec5607434faae6b3657ad44cbcf116f288"),
|
|
||||||
BloomRoot: core.HexToHash("0x871841e5c2ada9dab2011a550d38e9fe0a30047cfc81f1ffc7ebc09f4f230732"),
|
|
||||||
}
|
|
||||||
|
|
||||||
// RopstenCheckpointOracle contains a set of configs for the Ropsten test network oracle.
|
|
||||||
RopstenCheckpointOracle = &CheckpointOracleConfig{
|
|
||||||
Address: core.HexToAddress("0xEF79475013f154E6A65b54cB2742867791bf0B84"),
|
|
||||||
Signers: []core.Address{
|
|
||||||
core.HexToAddress("0x32162F3581E88a5f62e8A61892B42C46E2c18f7b"), // Peter
|
|
||||||
core.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin
|
|
||||||
core.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt
|
|
||||||
core.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary
|
|
||||||
core.HexToAddress("0x0DF8fa387C602AE62559cC4aFa4972A7045d6707"), // Guillaume
|
|
||||||
},
|
|
||||||
Threshold: 2,
|
|
||||||
}
|
|
||||||
|
|
||||||
// RinkebyChainConfig contains the chain parameters to run a node on the Rinkeby test network.
|
|
||||||
RinkebyChainConfig = &ChainConfig{
|
|
||||||
ChainID: big.NewInt(4),
|
|
||||||
HomesteadBlock: big.NewInt(1),
|
|
||||||
DAOForkBlock: nil,
|
|
||||||
DAOForkSupport: true,
|
|
||||||
EIP150Block: big.NewInt(2),
|
|
||||||
EIP150Hash: core.HexToHash("0x9b095b36c15eaf13044373aef8ee0bd3a382a5abb92e402afa44b8249c3a90e9"),
|
|
||||||
EIP155Block: big.NewInt(3),
|
|
||||||
EIP158Block: big.NewInt(3),
|
|
||||||
ByzantiumBlock: big.NewInt(1_035_301),
|
|
||||||
ConstantinopleBlock: big.NewInt(3_660_663),
|
|
||||||
PetersburgBlock: big.NewInt(4_321_234),
|
|
||||||
IstanbulBlock: big.NewInt(5_435_345),
|
|
||||||
MuirGlacierBlock: nil,
|
|
||||||
BerlinBlock: big.NewInt(8_290_928),
|
|
||||||
LondonBlock: big.NewInt(8_897_988),
|
|
||||||
Clique: &CliqueConfig{
|
|
||||||
Period: 15,
|
|
||||||
Epoch: 30000,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
// RinkebyTrustedCheckpoint contains the light client trusted checkpoint for the Rinkeby test network.
|
|
||||||
RinkebyTrustedCheckpoint = &TrustedCheckpoint{
|
|
||||||
SectionIndex: 270,
|
|
||||||
SectionHead: core.HexToHash("0x03ef8982c93bbf18c859bc1b20ae05b439f04cf1ff592656e941d2c3fcff5d68"),
|
|
||||||
CHTRoot: core.HexToHash("0x9eb80685e8ece479e105b170439779bc0f89997ab7f4dee425f85c4234e8a6b5"),
|
|
||||||
BloomRoot: core.HexToHash("0xc3673721c5697efe5fe4cb825d178f4a335dbfeda6a197fb75c9256a767379dc"),
|
|
||||||
}
|
|
||||||
|
|
||||||
// RinkebyCheckpointOracle contains a set of configs for the Rinkeby test network oracle.
|
|
||||||
RinkebyCheckpointOracle = &CheckpointOracleConfig{
|
|
||||||
Address: core.HexToAddress("0xebe8eFA441B9302A0d7eaECc277c09d20D684540"),
|
|
||||||
Signers: []core.Address{
|
|
||||||
core.HexToAddress("0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3"), // Peter
|
|
||||||
core.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin
|
|
||||||
core.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt
|
|
||||||
core.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary
|
|
||||||
},
|
|
||||||
Threshold: 2,
|
|
||||||
}
|
|
||||||
|
|
||||||
// GoerliChainConfig contains the chain parameters to run a node on the Görli test network.
|
|
||||||
GoerliChainConfig = &ChainConfig{
|
|
||||||
ChainID: big.NewInt(5),
|
|
||||||
HomesteadBlock: big.NewInt(0),
|
|
||||||
DAOForkBlock: nil,
|
|
||||||
DAOForkSupport: true,
|
|
||||||
EIP150Block: big.NewInt(0),
|
|
||||||
EIP155Block: big.NewInt(0),
|
|
||||||
EIP158Block: big.NewInt(0),
|
|
||||||
ByzantiumBlock: big.NewInt(0),
|
|
||||||
ConstantinopleBlock: big.NewInt(0),
|
|
||||||
PetersburgBlock: big.NewInt(0),
|
|
||||||
IstanbulBlock: big.NewInt(1_561_651),
|
|
||||||
MuirGlacierBlock: nil,
|
|
||||||
BerlinBlock: big.NewInt(4_460_644),
|
|
||||||
LondonBlock: big.NewInt(5_062_605),
|
|
||||||
Clique: &CliqueConfig{
|
|
||||||
Period: 15,
|
|
||||||
Epoch: 30000,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
// GoerliTrustedCheckpoint contains the light client trusted checkpoint for the Görli test network.
|
|
||||||
GoerliTrustedCheckpoint = &TrustedCheckpoint{
|
|
||||||
SectionIndex: 154,
|
|
||||||
SectionHead: core.HexToHash("0xf4cb74cc0e3683589f4992902184241fb892d7c3859d0044c16ec864605ff80d"),
|
|
||||||
CHTRoot: core.HexToHash("0xead95f9f2504b2c7c6d82c51d30e50b40631c3ea2f590cddcc9721cfc0ae79de"),
|
|
||||||
BloomRoot: core.HexToHash("0xc6dd6cfe88ac9c4a6d19c9a8651944fa9d941a2340a8f5ddaf673d4d39779d81"),
|
|
||||||
}
|
|
||||||
|
|
||||||
// GoerliCheckpointOracle contains a set of configs for the Goerli test network oracle.
|
|
||||||
GoerliCheckpointOracle = &CheckpointOracleConfig{
|
|
||||||
Address: core.HexToAddress("0x18CA0E045F0D772a851BC7e48357Bcaab0a0795D"),
|
|
||||||
Signers: []core.Address{
|
|
||||||
core.HexToAddress("0x4769bcaD07e3b938B7f43EB7D278Bc7Cb9efFb38"), // Peter
|
|
||||||
core.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin
|
|
||||||
core.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt
|
|
||||||
core.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary
|
|
||||||
core.HexToAddress("0x0DF8fa387C602AE62559cC4aFa4972A7045d6707"), // Guillaume
|
|
||||||
},
|
|
||||||
Threshold: 2,
|
|
||||||
}
|
|
||||||
|
|
||||||
CalaverasChainConfig = &ChainConfig{
|
|
||||||
ChainID: big.NewInt(123),
|
|
||||||
HomesteadBlock: big.NewInt(0),
|
|
||||||
DAOForkBlock: nil,
|
|
||||||
DAOForkSupport: true,
|
|
||||||
EIP150Block: big.NewInt(0),
|
|
||||||
EIP155Block: big.NewInt(0),
|
|
||||||
EIP158Block: big.NewInt(0),
|
|
||||||
ByzantiumBlock: big.NewInt(0),
|
|
||||||
ConstantinopleBlock: big.NewInt(0),
|
|
||||||
PetersburgBlock: big.NewInt(0),
|
|
||||||
IstanbulBlock: big.NewInt(0),
|
|
||||||
MuirGlacierBlock: nil,
|
|
||||||
BerlinBlock: big.NewInt(0),
|
|
||||||
LondonBlock: big.NewInt(500),
|
|
||||||
Clique: &CliqueConfig{
|
|
||||||
Period: 30,
|
|
||||||
Epoch: 30000,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
// AllEthashProtocolChanges contains every protocol change (EIPs) introduced
|
|
||||||
// and accepted by the Ethereum core developers into the Ethash consensus.
|
|
||||||
//
|
|
||||||
// This configuration is intentionally not using keyed fields to force anyone
|
|
||||||
// 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), core.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), big.NewInt(0), nil, new(EthashConfig), nil}
|
|
||||||
|
|
||||||
// AllCliqueProtocolChanges contains every protocol change (EIPs) introduced
|
|
||||||
// and accepted by the Ethereum core developers into the Clique consensus.
|
|
||||||
//
|
|
||||||
// This configuration is intentionally not using keyed fields to force anyone
|
|
||||||
// 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), core.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), big.NewInt(0), nil, nil, &CliqueConfig{Period: 0, Epoch: 30000}}
|
|
||||||
|
|
||||||
TestChainConfig = &ChainConfig{big.NewInt(1), big.NewInt(0), nil, false, big.NewInt(0), core.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), big.NewInt(0), nil, new(EthashConfig), nil}
|
|
||||||
TestRules = TestChainConfig.Rules(new(big.Int))
|
|
||||||
)
|
|
||||||
|
|
||||||
// TrustedCheckpoint represents a set of post-processed trie roots (CHT and
|
// TrustedCheckpoint represents a set of post-processed trie roots (CHT and
|
||||||
// BloomTrie) associated with the appropriate section index and head hash. It is
|
// BloomTrie) associated with the appropriate section index and head hash. It is
|
||||||
@ -336,7 +111,24 @@ type ChainConfig struct {
|
|||||||
BerlinBlock *big.Int `json:"berlinBlock,omitempty"` // Berlin switch block (nil = no fork, 0 = already on berlin)
|
BerlinBlock *big.Int `json:"berlinBlock,omitempty"` // Berlin switch block (nil = no fork, 0 = already on berlin)
|
||||||
LondonBlock *big.Int `json:"londonBlock,omitempty"` // London switch block (nil = no fork, 0 = already on london)
|
LondonBlock *big.Int `json:"londonBlock,omitempty"` // London switch block (nil = no fork, 0 = already on london)
|
||||||
|
|
||||||
CatalystBlock *big.Int `json:"catalystBlock,omitempty"` // Catalyst switch block (nil = no fork, 0 = already on catalyst)
|
ArrowGlacierBlock *big.Int `json:"arrowGlacierBlock,omitempty"` // Eip-4345 (bomb delay) switch block (nil = no fork, 0 = already activated)
|
||||||
|
GrayGlacierBlock *big.Int `json:"grayGlacierBlock,omitempty"` // Eip-5133 (bomb delay) switch block (nil = no fork, 0 = already activated)
|
||||||
|
MergeNetsplitBlock *big.Int `json:"mergeNetsplitBlock,omitempty"` // Virtual fork after The Merge to use as a network splitter
|
||||||
|
|
||||||
|
// Fork scheduling was switched from blocks to timestamps here
|
||||||
|
|
||||||
|
ShanghaiTime *uint64 `json:"shanghaiTime,omitempty"` // Shanghai switch time (nil = no fork, 0 = already on shanghai)
|
||||||
|
CancunTime *uint64 `json:"cancunTime,omitempty"` // Cancun switch time (nil = no fork, 0 = already on cancun)
|
||||||
|
PragueTime *uint64 `json:"pragueTime,omitempty"` // Prague switch time (nil = no fork, 0 = already on prague)
|
||||||
|
|
||||||
|
// TerminalTotalDifficulty is the amount of total difficulty reached by
|
||||||
|
// the network that triggers the consensus upgrade.
|
||||||
|
TerminalTotalDifficulty *big.Int `json:"terminalTotalDifficulty,omitempty"`
|
||||||
|
|
||||||
|
// TerminalTotalDifficultyPassed is a flag specifying that the network already
|
||||||
|
// passed the terminal total difficulty. Its purpose is to disable legacy sync
|
||||||
|
// even without having seen the TTD locally (safer long term).
|
||||||
|
TerminalTotalDifficultyPassed bool `json:"terminalTotalDifficultyPassed,omitempty"`
|
||||||
|
|
||||||
// Various consensus engines
|
// Various consensus engines
|
||||||
Ethash *EthashConfig `json:"ethash,omitempty"`
|
Ethash *EthashConfig `json:"ethash,omitempty"`
|
||||||
@ -454,11 +246,6 @@ func (c *ChainConfig) IsLondon(num *big.Int) bool {
|
|||||||
return isForked(c.LondonBlock, num)
|
return isForked(c.LondonBlock, num)
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsCatalyst returns whether num is either equal to the Merge fork block or greater.
|
|
||||||
func (c *ChainConfig) IsCatalyst(num *big.Int) bool {
|
|
||||||
return isForked(c.CatalystBlock, num)
|
|
||||||
}
|
|
||||||
|
|
||||||
// CheckCompatible checks whether scheduled fork transitions have been imported
|
// CheckCompatible checks whether scheduled fork transitions have been imported
|
||||||
// with a mismatching chain configuration.
|
// with a mismatching chain configuration.
|
||||||
func (c *ChainConfig) CheckCompatible(newcfg *ChainConfig, height uint64) *ConfigCompatError {
|
func (c *ChainConfig) CheckCompatible(newcfg *ChainConfig, height uint64) *ConfigCompatError {
|
||||||
@ -656,6 +443,5 @@ func (c *ChainConfig) Rules(num *big.Int) Rules {
|
|||||||
IsIstanbul: c.IsIstanbul(num),
|
IsIstanbul: c.IsIstanbul(num),
|
||||||
IsBerlin: c.IsBerlin(num),
|
IsBerlin: c.IsBerlin(num),
|
||||||
IsLondon: c.IsLondon(num),
|
IsLondon: c.IsLondon(num),
|
||||||
IsCatalyst: c.IsCatalyst(num),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user