config.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. // Copyright 2016 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package params
  17. import (
  18. "fmt"
  19. "math/big"
  20. "github.com/ethereum/go-ethereum/common"
  21. )
  22. // MainnetChainConfig is the chain parameters to run a node on the main network.
  23. var MainnetChainConfig = &ChainConfig{
  24. ChainId: MainNetChainID,
  25. HomesteadBlock: MainNetHomesteadBlock,
  26. DAOForkBlock: MainNetDAOForkBlock,
  27. DAOForkSupport: true,
  28. EIP150Block: MainNetHomesteadGasRepriceBlock,
  29. EIP150Hash: MainNetHomesteadGasRepriceHash,
  30. EIP155Block: MainNetSpuriousDragon,
  31. EIP158Block: MainNetSpuriousDragon,
  32. }
  33. // TestnetChainConfig is the chain parameters to run a node on the test network.
  34. var TestnetChainConfig = &ChainConfig{
  35. ChainId: big.NewInt(3),
  36. HomesteadBlock: big.NewInt(0),
  37. DAOForkBlock: nil,
  38. DAOForkSupport: true,
  39. EIP150Block: big.NewInt(0),
  40. EIP150Hash: common.HexToHash("0x41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d"),
  41. EIP155Block: big.NewInt(10),
  42. EIP158Block: big.NewInt(10),
  43. }
  44. // ChainConfig is the core config which determines the blockchain settings.
  45. //
  46. // ChainConfig is stored in the database on a per block basis. This means
  47. // that any network, identified by its genesis block, can have its own
  48. // set of configuration options.
  49. type ChainConfig struct {
  50. ChainId *big.Int `json:"chainId"` // Chain id identifies the current chain and is used for replay protection
  51. HomesteadBlock *big.Int `json:"homesteadBlock"` // Homestead switch block (nil = no fork, 0 = already homestead)
  52. DAOForkBlock *big.Int `json:"daoForkBlock"` // TheDAO hard-fork switch block (nil = no fork)
  53. DAOForkSupport bool `json:"daoForkSupport"` // Whether the nodes supports or opposes the DAO hard-fork
  54. // EIP150 implements the Gas price changes (https://github.com/ethereum/EIPs/issues/150)
  55. EIP150Block *big.Int `json:"eip150Block"` // EIP150 HF block (nil = no fork)
  56. EIP150Hash common.Hash `json:"eip150Hash"` // EIP150 HF hash (fast sync aid)
  57. EIP155Block *big.Int `json:"eip155Block"` // EIP155 HF block
  58. EIP158Block *big.Int `json:"eip158Block"` // EIP158 HF block
  59. }
  60. // String implements the Stringer interface.
  61. func (c *ChainConfig) String() string {
  62. return fmt.Sprintf("{ChainID: %v Homestead: %v DAO: %v DAOSupport: %v EIP150: %v EIP155: %v EIP158: %v}",
  63. c.ChainId,
  64. c.HomesteadBlock,
  65. c.DAOForkBlock,
  66. c.DAOForkSupport,
  67. c.EIP150Block,
  68. c.EIP155Block,
  69. c.EIP158Block,
  70. )
  71. }
  72. var (
  73. TestChainConfig = &ChainConfig{big.NewInt(1), new(big.Int), new(big.Int), true, new(big.Int), common.Hash{}, new(big.Int), new(big.Int)}
  74. TestRules = TestChainConfig.Rules(new(big.Int))
  75. )
  76. // IsHomestead returns whether num is either equal to the homestead block or greater.
  77. func (c *ChainConfig) IsHomestead(num *big.Int) bool {
  78. if c.HomesteadBlock == nil || num == nil {
  79. return false
  80. }
  81. return num.Cmp(c.HomesteadBlock) >= 0
  82. }
  83. // GasTable returns the gas table corresponding to the current phase (homestead or homestead reprice).
  84. //
  85. // The returned GasTable's fields shouldn't, under any circumstances, be changed.
  86. func (c *ChainConfig) GasTable(num *big.Int) GasTable {
  87. if num == nil {
  88. return GasTableHomestead
  89. }
  90. switch {
  91. case c.EIP158Block != nil && num.Cmp(c.EIP158Block) >= 0:
  92. return GasTableEIP158
  93. case c.EIP150Block != nil && num.Cmp(c.EIP150Block) >= 0:
  94. return GasTableHomesteadGasRepriceFork
  95. default:
  96. return GasTableHomestead
  97. }
  98. }
  99. func (c *ChainConfig) IsEIP150(num *big.Int) bool {
  100. if c.EIP150Block == nil || num == nil {
  101. return false
  102. }
  103. return num.Cmp(c.EIP150Block) >= 0
  104. }
  105. func (c *ChainConfig) IsEIP155(num *big.Int) bool {
  106. if c.EIP155Block == nil || num == nil {
  107. return false
  108. }
  109. return num.Cmp(c.EIP155Block) >= 0
  110. }
  111. func (c *ChainConfig) IsEIP158(num *big.Int) bool {
  112. if c.EIP158Block == nil || num == nil {
  113. return false
  114. }
  115. return num.Cmp(c.EIP158Block) >= 0
  116. }
  117. // Rules wraps ChainConfig and is merely syntatic sugar or can be used for functions
  118. // that do not have or require information about the block.
  119. //
  120. // Rules is a one time interface meaning that it shouldn't be used in between transition
  121. // phases.
  122. type Rules struct {
  123. ChainId *big.Int
  124. IsHomestead, IsEIP150, IsEIP155, IsEIP158 bool
  125. }
  126. func (c *ChainConfig) Rules(num *big.Int) Rules {
  127. return Rules{ChainId: new(big.Int).Set(c.ChainId), IsHomestead: c.IsHomestead(num), IsEIP150: c.IsEIP150(num), IsEIP155: c.IsEIP155(num), IsEIP158: c.IsEIP158(num)}
  128. }