diff options
author | Jeffrey Wilcke <jeffrey@ethereum.org> | 2016-02-29 22:05:37 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2016-02-29 22:05:37 +0800 |
commit | 4044a8cea44cd4cee3a8ddaf51a76b71c9d22042 (patch) | |
tree | 1aa3776381e8e117b66e4a8ed1bf83e29d966ff1 /params | |
parent | c541b38fb36587d23c60f5e2f2b9b3c8700ec489 (diff) | |
parent | 61be63bb9b8527bb3e2357ad35a0f4ef29304da1 (diff) | |
download | go-tangerine-4044a8cea44cd4cee3a8ddaf51a76b71c9d22042.tar go-tangerine-4044a8cea44cd4cee3a8ddaf51a76b71c9d22042.tar.gz go-tangerine-4044a8cea44cd4cee3a8ddaf51a76b71c9d22042.tar.bz2 go-tangerine-4044a8cea44cd4cee3a8ddaf51a76b71c9d22042.tar.lz go-tangerine-4044a8cea44cd4cee3a8ddaf51a76b71c9d22042.tar.xz go-tangerine-4044a8cea44cd4cee3a8ddaf51a76b71c9d22042.tar.zst go-tangerine-4044a8cea44cd4cee3a8ddaf51a76b71c9d22042.zip |
Merge pull request #2258 from obscuren/release/1.3.4v1.3.4
Homestead Release Candidate
Diffstat (limited to 'params')
-rwxr-xr-x | params/protocol_params.go | 7 | ||||
-rw-r--r-- | params/util.go | 33 |
2 files changed, 37 insertions, 3 deletions
diff --git a/params/protocol_params.go b/params/protocol_params.go index dcc17e05d..45a9a2549 100755 --- a/params/protocol_params.go +++ b/params/protocol_params.go @@ -25,9 +25,10 @@ var ( MaximumExtraDataSize = big.NewInt(32) // Maximum size extra data may be after Genesis. ExpByteGas = big.NewInt(10) // Times ceil(log256(exponent)) for the EXP instruction. SloadGas = big.NewInt(50) // Multiplied by the number of 32-byte words that are copied (round up) for any *COPY operation and added. - CallValueTransferGas = big.NewInt(9000) // Paid for CALL when the value transfor is non-zero. + CallValueTransferGas = big.NewInt(9000) // Paid for CALL when the value transfer is non-zero. CallNewAccountGas = big.NewInt(25000) // Paid for CALL when the destination address didn't exist prior. - TxGas = big.NewInt(21000) // Per transaction. NOTE: Not payable on data of calls between transactions. + TxGas = big.NewInt(21000) // Per transaction not creating a contract. NOTE: Not payable on data of calls between transactions. + TxGasContractCreation = big.NewInt(53000) // Per transaction that creates a contract. NOTE: Not payable on data of calls between transactions. TxDataZeroGas = big.NewInt(4) // Per byte of data attached to a transaction that equals zero. NOTE: Not payable on data of calls between transactions. DifficultyBoundDivisor = big.NewInt(2048) // The bound divisor of the difficulty, used in the update calculations. QuadCoeffDiv = big.NewInt(512) // Divisor for the quadratic particle of the memory cost equation. @@ -40,7 +41,7 @@ var ( Sha256WordGas = big.NewInt(12) // MinGasLimit = big.NewInt(5000) // Minimum the gas limit may ever be. - GenesisGasLimit = big.NewInt(3141592) // Gas limit of the Genesis block. + GenesisGasLimit = big.NewInt(4712388) // Gas limit of the Genesis block. Sha3Gas = big.NewInt(30) // Once per SHA3 operation. Sha256Gas = big.NewInt(60) // diff --git a/params/util.go b/params/util.go new file mode 100644 index 000000000..6a49a2013 --- /dev/null +++ b/params/util.go @@ -0,0 +1,33 @@ +// Copyright 2015 The go-ethereum Authors +// This file is part of the go-ethereum library. +// +// The go-ethereum library is free software: you can redistribute it and/or modify +// it under the terms of the GNU Lesser General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// The go-ethereum library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public License +// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. + +package params + +import "math/big" + +var ( + TestNetHomesteadBlock = big.NewInt(494000) // testnet homestead block + MainNetHomesteadBlock = big.NewInt(1150000) // mainnet homestead block + HomesteadBlock = MainNetHomesteadBlock // homestead block used to check against +) + +func IsHomestead(blockNumber *big.Int) bool { + // for unit tests TODO: flip to true after homestead is live + if blockNumber == nil { + return false + } + return blockNumber.Cmp(HomesteadBlock) >= 0 +} |