2015-07-07 02:54:22 +02:00
// Copyright 2014 The go-ethereum Authors
2015-07-22 18:48:40 +02:00
// This file is part of the go-ethereum library.
2015-07-07 02:54:22 +02:00
//
2015-07-23 18:35:11 +02:00
// The go-ethereum library is free software: you can redistribute it and/or modify
2015-07-07 02:54:22 +02:00
// 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.
//
2015-07-22 18:48:40 +02:00
// The go-ethereum library is distributed in the hope that it will be useful,
2015-07-07 02:54:22 +02:00
// but WITHOUT ANY WARRANTY; without even the implied warranty of
2015-07-22 18:48:40 +02:00
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2015-07-07 02:54:22 +02:00
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
2015-07-22 18:48:40 +02:00
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
2015-07-07 02:54:22 +02:00
2015-07-07 05:08:16 +02:00
// Package eth implements the Ethereum protocol.
2014-12-14 18:03:24 +00:00
package eth
import (
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
"context"
2017-04-12 16:27:23 +02:00
"errors"
2015-01-04 14:20:16 +01:00
"fmt"
2017-05-16 22:07:27 +03:00
"math/big"
2017-04-12 16:27:23 +02:00
"runtime"
2016-05-12 19:32:04 +02:00
"sync"
2017-04-10 11:43:01 +03:00
"sync/atomic"
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
"time"
2014-12-14 18:03:24 +00:00
2015-02-26 13:22:09 +01:00
"github.com/ethereum/go-ethereum/accounts"
2015-03-18 13:00:01 +01:00
"github.com/ethereum/go-ethereum/common"
2017-04-12 16:27:23 +02:00
"github.com/ethereum/go-ethereum/common/hexutil"
2017-04-05 01:16:29 +03:00
"github.com/ethereum/go-ethereum/consensus"
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
"github.com/ethereum/go-ethereum/consensus/beacon"
2017-04-10 13:24:12 +03:00
"github.com/ethereum/go-ethereum/consensus/clique"
2014-12-14 18:03:24 +00:00
"github.com/ethereum/go-ethereum/core"
2017-08-29 14:13:11 +03:00
"github.com/ethereum/go-ethereum/core/bloombits"
2018-05-07 14:35:06 +03:00
"github.com/ethereum/go-ethereum/core/rawdb"
all: bloom-filter based pruning mechanism (#21724)
* cmd, core, tests: initial state pruner
core: fix db inspector
cmd/geth: add verify-state
cmd/geth: add verification tool
core/rawdb: implement flatdb
cmd, core: fix rebase
core/state: use new contract code layout
core/state/pruner: avoid deleting genesis state
cmd/geth: add helper function
core, cmd: fix extract genesis
core: minor fixes
contracts: remove useless
core/state/snapshot: plugin stacktrie
core: polish
core/state/snapshot: iterate storage concurrently
core/state/snapshot: fix iteration
core: add comments
core/state/snapshot: polish code
core/state: polish
core/state/snapshot: rebase
core/rawdb: add comments
core/rawdb: fix tests
core/rawdb: improve tests
core/state/snapshot: fix concurrent iteration
core/state: run pruning during the recovery
core, trie: implement martin's idea
core, eth: delete flatdb and polish pruner
trie: fix import
core/state/pruner: add log
core/state/pruner: fix issues
core/state/pruner: don't read back
core/state/pruner: fix contract code write
core/state/pruner: check root node presence
cmd, core: polish log
core/state: use HEAD-127 as the target
core/state/snapshot: improve tests
cmd/geth: fix verification tool
cmd/geth: use HEAD as the verification default target
all: replace the bloomfilter with martin's fork
cmd, core: polish code
core, cmd: forcibly delete state root
core/state/pruner: add hash64
core/state/pruner: fix blacklist
core/state: remove blacklist
cmd, core: delete trie clean cache before pruning
cmd, core: fix lint
cmd, core: fix rebase
core/state: fix the special case for clique networks
core/state/snapshot: remove useless code
core/state/pruner: capping the snapshot after pruning
cmd, core, eth: fixes
core/rawdb: update db inspector
cmd/geth: polish code
core/state/pruner: fsync bloom filter
cmd, core: print warning log
core/state/pruner: adjust the parameters for bloom filter
cmd, core: create the bloom filter by size
core: polish
core/state/pruner: sanitize invalid bloomfilter size
cmd: address comments
cmd/geth: address comments
cmd/geth: address comment
core/state/pruner: address comments
core/state/pruner: rename homedir to datadir
cmd, core: address comments
core/state/pruner: address comment
core/state: address comments
core, cmd, tests: address comments
core: address comments
core/state/pruner: release the iterator after each commit
core/state/pruner: improve pruner
cmd, core: adjust bloom paramters
core/state/pruner: fix lint
core/state/pruner: fix tests
core: fix rebase
core/state/pruner: remove atomic rename
core/state/pruner: address comments
all: run go mod tidy
core/state/pruner: avoid false-positive for the middle state roots
core/state/pruner: add checks for middle roots
cmd/geth: replace crit with error
* core/state/pruner: fix lint
* core: drop legacy bloom filter
* core/state/snapshot: improve pruner
* core/state/snapshot: polish concurrent logs to report ETA vs. hashes
* core/state/pruner: add progress report for pruning and compaction too
* core: fix snapshot test API
* core/state: fix some pruning logs
* core/state/pruner: support recovering from bloom flush fail
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-02-08 19:16:30 +08:00
"github.com/ethereum/go-ethereum/core/state/pruner"
2022-10-24 16:13:55 +03:00
"github.com/ethereum/go-ethereum/core/txpool"
2015-03-13 18:34:43 +01:00
"github.com/ethereum/go-ethereum/core/types"
2017-01-17 11:19:50 +00:00
"github.com/ethereum/go-ethereum/core/vm"
2015-04-13 17:22:32 +02:00
"github.com/ethereum/go-ethereum/eth/downloader"
2021-02-05 20:51:15 +08:00
"github.com/ethereum/go-ethereum/eth/ethconfig"
2015-12-16 04:26:23 +01:00
"github.com/ethereum/go-ethereum/eth/gasprice"
2020-12-14 11:27:15 +02:00
"github.com/ethereum/go-ethereum/eth/protocols/eth"
"github.com/ethereum/go-ethereum/eth/protocols/snap"
2015-01-04 14:20:16 +01:00
"github.com/ethereum/go-ethereum/ethdb"
2014-12-14 18:03:24 +00:00
"github.com/ethereum/go-ethereum/event"
2015-12-16 04:26:23 +01:00
"github.com/ethereum/go-ethereum/internal/ethapi"
2021-12-17 17:48:51 +03:30
"github.com/ethereum/go-ethereum/internal/shutdowncheck"
2017-02-22 14:10:07 +02:00
"github.com/ethereum/go-ethereum/log"
2015-02-17 12:24:51 +01:00
"github.com/ethereum/go-ethereum/miner"
2015-11-17 18:33:25 +02:00
"github.com/ethereum/go-ethereum/node"
2014-12-14 18:03:24 +00:00
"github.com/ethereum/go-ethereum/p2p"
2021-05-04 11:29:32 +02:00
"github.com/ethereum/go-ethereum/p2p/dnsdisc"
2020-02-13 14:38:30 +01:00
"github.com/ethereum/go-ethereum/p2p/enode"
2016-10-20 13:36:29 +02:00
"github.com/ethereum/go-ethereum/params"
2017-04-12 16:27:23 +02:00
"github.com/ethereum/go-ethereum/rlp"
2015-12-16 10:58:01 +01:00
"github.com/ethereum/go-ethereum/rpc"
2014-12-14 18:03:24 +00:00
)
2021-02-05 20:51:15 +08:00
// Config contains the configuration options of the ETH protocol.
// Deprecated: use ethconfig.Config instead.
type Config = ethconfig . Config
2016-06-30 13:03:26 +03:00
// Ethereum implements the Ethereum full node service.
type Ethereum struct {
2021-02-05 20:51:15 +08:00
config * ethconfig . Config
2017-09-05 19:18:28 +03:00
2015-10-19 16:08:17 +02:00
// Handlers
2022-10-24 16:13:55 +03:00
txPool * txpool . TxPool
2020-12-14 11:27:15 +02:00
blockchain * core . BlockChain
handler * handler
ethDialCandidates enode . Iterator
snapDialCandidates enode . Iterator
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
merger * consensus . Merger
2017-09-05 19:18:28 +03:00
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
seqRPCService * rpc . Client
historicalRPCService * rpc . Client
2015-12-16 04:26:23 +01:00
// DB interfaces
chainDb ethdb . Database // Block chain database
2014-12-14 18:03:24 +00:00
2015-12-16 04:26:23 +01:00
eventMux * event . TypeMux
2017-04-05 01:16:29 +03:00
engine consensus . Engine
2015-12-16 04:26:23 +01:00
accountManager * accounts . Manager
2015-05-26 14:17:43 +02:00
2020-03-27 14:03:20 +01:00
bloomRequests chan chan * bloombits . Retrieval // Channel receiving bloom data retrieval requests
bloomIndexer * core . ChainIndexer // Bloom indexer operating during block imports
closeBloomHandler chan struct { }
2017-08-18 21:52:20 +02:00
2018-05-09 00:59:00 -07:00
APIBackend * EthAPIBackend
2015-10-26 22:24:09 +01:00
2017-05-29 10:21:34 +03:00
miner * miner . Miner
gasPrice * big . Int
etherbase common . Address
2014-12-14 18:03:24 +00:00
2018-06-14 03:14:52 -07:00
networkID uint64
2022-06-21 11:05:43 +02:00
netRPCService * ethapi . NetAPI
2017-05-29 10:21:34 +03:00
2020-08-03 19:40:46 +02:00
p2pServer * p2p . Server
2014-12-14 18:03:24 +00:00
2020-08-03 19:40:46 +02:00
lock sync . RWMutex // Protects the variadic fields (e.g. gas price and etherbase)
2021-12-17 17:48:51 +03:30
shutdownTracker * shutdowncheck . ShutdownTracker // Tracks if and when the node has shutdown ungracefully
all: on-chain oracle checkpoint syncing (#19543)
* all: implement simple checkpoint syncing
cmd, les, node: remove callback mechanism
cmd, node: remove callback definition
les: simplify the registrar
les: expose checkpoint rpc services in the light client
les, light: don't store untrusted receipt
cmd, contracts, les: discard stale checkpoint
cmd, contracts/registrar: loose restriction of registeration
cmd, contracts: add replay-protection
all: off-chain multi-signature contract
params: deploy checkpoint contract for rinkeby
cmd/registrar: add raw signing mode for registrar
cmd/registrar, contracts/registrar, les: fixed messages
* cmd/registrar, contracts/registrar: fix lints
* accounts/abi/bind, les: address comments
* cmd, contracts, les, light, params: minor checkpoint sync cleanups
* cmd, eth, les, light: move checkpoint config to config file
* cmd, eth, les, params: address comments
* eth, les, params: address comments
* cmd: polish up the checkpoint admin CLI
* cmd, contracts, params: deploy new version contract
* cmd/checkpoint-admin: add another flag for clef mode signing
* cmd, contracts, les: rename and regen checkpoint oracle with abigen
2019-06-28 15:34:02 +08:00
}
2016-06-30 13:03:26 +03:00
// New creates a new Ethereum object (including the
2015-12-16 04:26:23 +01:00
// initialisation of the common Ethereum object)
2021-02-05 20:51:15 +08:00
func New ( stack * node . Node , config * ethconfig . Config ) ( * Ethereum , error ) {
2018-08-23 13:02:36 +03:00
// Ensure configuration values are compatible and sane
2017-04-12 16:27:23 +02:00
if config . SyncMode == downloader . LightSync {
return nil , errors . New ( "can't run eth.Ethereum in light sync mode, use les.LightEthereum" )
}
if ! config . SyncMode . IsValid ( ) {
return nil , fmt . Errorf ( "invalid sync mode %d" , config . SyncMode )
}
2019-04-23 15:08:51 +08:00
if config . Miner . GasPrice == nil || config . Miner . GasPrice . Cmp ( common . Big0 ) <= 0 {
2021-02-05 20:51:15 +08:00
log . Warn ( "Sanitizing invalid miner gas price" , "provided" , config . Miner . GasPrice , "updated" , ethconfig . Defaults . Miner . GasPrice )
config . Miner . GasPrice = new ( big . Int ) . Set ( ethconfig . Defaults . Miner . GasPrice )
2018-08-23 13:02:36 +03:00
}
2019-02-05 12:49:59 +02:00
if config . NoPruning && config . TrieDirtyCache > 0 {
2020-05-06 06:01:01 -04:00
if config . SnapshotCache > 0 {
config . TrieCleanCache += config . TrieDirtyCache * 3 / 5
config . SnapshotCache += config . TrieDirtyCache * 2 / 5
} else {
config . TrieCleanCache += config . TrieDirtyCache
}
2019-02-05 12:49:59 +02:00
config . TrieDirtyCache = 0
}
log . Info ( "Allocated trie memory caches" , "clean" , common . StorageSize ( config . TrieCleanCache ) * 1024 * 1024 , "dirty" , common . StorageSize ( config . TrieDirtyCache ) * 1024 * 1024 )
2018-08-23 13:02:36 +03:00
// Assemble the Ethereum object
2021-03-23 02:06:30 +08:00
chainDb , err := stack . OpenDatabaseWithFreezer ( "chaindata" , config . DatabaseCache , config . DatabaseHandles , config . DatabaseFreezer , "eth/db/chaindata/" , false )
2015-01-04 14:20:16 +01:00
if err != nil {
2015-11-17 18:33:25 +02:00
return nil , err
2015-01-04 14:20:16 +01:00
}
all: bloom-filter based pruning mechanism (#21724)
* cmd, core, tests: initial state pruner
core: fix db inspector
cmd/geth: add verify-state
cmd/geth: add verification tool
core/rawdb: implement flatdb
cmd, core: fix rebase
core/state: use new contract code layout
core/state/pruner: avoid deleting genesis state
cmd/geth: add helper function
core, cmd: fix extract genesis
core: minor fixes
contracts: remove useless
core/state/snapshot: plugin stacktrie
core: polish
core/state/snapshot: iterate storage concurrently
core/state/snapshot: fix iteration
core: add comments
core/state/snapshot: polish code
core/state: polish
core/state/snapshot: rebase
core/rawdb: add comments
core/rawdb: fix tests
core/rawdb: improve tests
core/state/snapshot: fix concurrent iteration
core/state: run pruning during the recovery
core, trie: implement martin's idea
core, eth: delete flatdb and polish pruner
trie: fix import
core/state/pruner: add log
core/state/pruner: fix issues
core/state/pruner: don't read back
core/state/pruner: fix contract code write
core/state/pruner: check root node presence
cmd, core: polish log
core/state: use HEAD-127 as the target
core/state/snapshot: improve tests
cmd/geth: fix verification tool
cmd/geth: use HEAD as the verification default target
all: replace the bloomfilter with martin's fork
cmd, core: polish code
core, cmd: forcibly delete state root
core/state/pruner: add hash64
core/state/pruner: fix blacklist
core/state: remove blacklist
cmd, core: delete trie clean cache before pruning
cmd, core: fix lint
cmd, core: fix rebase
core/state: fix the special case for clique networks
core/state/snapshot: remove useless code
core/state/pruner: capping the snapshot after pruning
cmd, core, eth: fixes
core/rawdb: update db inspector
cmd/geth: polish code
core/state/pruner: fsync bloom filter
cmd, core: print warning log
core/state/pruner: adjust the parameters for bloom filter
cmd, core: create the bloom filter by size
core: polish
core/state/pruner: sanitize invalid bloomfilter size
cmd: address comments
cmd/geth: address comments
cmd/geth: address comment
core/state/pruner: address comments
core/state/pruner: rename homedir to datadir
cmd, core: address comments
core/state/pruner: address comment
core/state: address comments
core, cmd, tests: address comments
core: address comments
core/state/pruner: release the iterator after each commit
core/state/pruner: improve pruner
cmd, core: adjust bloom paramters
core/state/pruner: fix lint
core/state/pruner: fix tests
core: fix rebase
core/state/pruner: remove atomic rename
core/state/pruner: address comments
all: run go mod tidy
core/state/pruner: avoid false-positive for the middle state roots
core/state/pruner: add checks for middle roots
cmd/geth: replace crit with error
* core/state/pruner: fix lint
* core: drop legacy bloom filter
* core/state/snapshot: improve pruner
* core/state/snapshot: polish concurrent logs to report ETA vs. hashes
* core/state/pruner: add progress report for pruning and compaction too
* core: fix snapshot test API
* core/state: fix some pruning logs
* core/state/pruner: support recovering from bloom flush fail
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-02-08 19:16:30 +08:00
if err := pruner . RecoverPruning ( stack . ResolvePath ( "" ) , chainDb , stack . ResolvePath ( config . TrieCleanCacheJournal ) ) ; err != nil {
log . Error ( "Failed to recover state" , "error" , err )
}
2022-08-31 00:22:28 +08:00
// Transfer mining-related config to the ethash config.
ethashConfig := config . Ethash
ethashConfig . NotifyFull = config . Miner . NotifyFull
cliqueConfig , err := core . LoadCliqueConfig ( chainDb , config . Genesis )
if err != nil {
return nil , err
}
engine := ethconfig . CreateConsensusEngine ( stack , & ethashConfig , cliqueConfig , config . Miner . Notify , config . Miner . Noverify , chainDb )
2016-06-30 13:03:26 +03:00
eth := & Ethereum {
2020-03-27 14:03:20 +01:00
config : config ,
2022-08-31 00:22:28 +08:00
merger : consensus . NewMerger ( chainDb ) ,
2020-03-27 14:03:20 +01:00
chainDb : chainDb ,
2020-08-03 19:40:46 +02:00
eventMux : stack . EventMux ( ) ,
accountManager : stack . AccountManager ( ) ,
2022-08-31 00:22:28 +08:00
engine : engine ,
2020-03-27 14:03:20 +01:00
closeBloomHandler : make ( chan struct { } ) ,
networkID : config . NetworkId ,
gasPrice : config . Miner . GasPrice ,
etherbase : config . Miner . Etherbase ,
bloomRequests : make ( chan chan * bloombits . Retrieval ) ,
2021-02-05 20:51:15 +08:00
bloomIndexer : core . NewBloomIndexer ( chainDb , params . BloomBitsBlocks , params . BloomConfirms ) ,
2020-08-03 19:40:46 +02:00
p2pServer : stack . Server ( ) ,
2021-12-17 17:48:51 +03:30
shutdownTracker : shutdowncheck . NewShutdownTracker ( chainDb ) ,
2015-07-10 14:29:40 +02:00
}
2016-03-01 23:32:43 +01:00
2019-02-21 21:14:35 +08:00
bcVersion := rawdb . ReadDatabaseVersion ( chainDb )
var dbVer = "<nil>"
if bcVersion != nil {
dbVer = fmt . Sprintf ( "%d" , * bcVersion )
}
2015-12-16 04:26:23 +01:00
2015-04-13 10:13:52 +02:00
if ! config . SkipBcVersionCheck {
2019-01-11 19:49:12 +08:00
if bcVersion != nil && * bcVersion > core . BlockChainVersion {
return nil , fmt . Errorf ( "database version is v%d, Geth %s only supports v%d" , * bcVersion , params . VersionWithMeta , core . BlockChainVersion )
2019-02-21 21:14:35 +08:00
} else if bcVersion == nil || * bcVersion < core . BlockChainVersion {
2021-05-03 15:42:43 +03:00
if bcVersion != nil { // only print warning on upgrade, not on init
log . Warn ( "Upgrade blockchain database version" , "from" , dbVer , "to" , core . BlockChainVersion )
}
2019-02-21 21:14:35 +08:00
rawdb . WriteDatabaseVersion ( chainDb , core . BlockChainVersion )
2015-04-13 10:13:52 +02:00
}
}
2018-02-05 18:40:32 +02:00
var (
2018-09-20 09:44:35 +02:00
vmConfig = vm . Config {
EnablePreimageRecording : config . EnablePreimageRecording ,
}
2019-04-01 11:52:11 +03:00
cacheConfig = & core . CacheConfig {
TrieCleanLimit : config . TrieCleanCache ,
2020-08-03 19:40:46 +02:00
TrieCleanJournal : stack . ResolvePath ( config . TrieCleanCacheJournal ) ,
2020-07-28 21:30:31 +08:00
TrieCleanRejournal : config . TrieCleanCacheRejournal ,
2019-04-01 11:52:11 +03:00
TrieCleanNoPrefetch : config . NoPrefetch ,
TrieDirtyLimit : config . TrieDirtyCache ,
TrieDirtyDisabled : config . NoPruning ,
TrieTimeLimit : config . TrieTimeout ,
2019-11-26 09:48:29 +02:00
SnapshotLimit : config . SnapshotCache ,
2020-11-18 17:51:33 +08:00
Preimages : config . Preimages ,
2019-04-01 11:52:11 +03:00
}
2018-02-05 18:40:32 +02:00
)
2022-08-31 00:22:28 +08:00
// Override the chain config with provided settings.
var overrides core . ChainOverrides
2023-01-06 15:07:38 +02:00
if config . OverrideShanghai != nil {
overrides . OverrideShanghai = config . OverrideShanghai
2022-08-31 00:22:28 +08:00
}
2022-12-05 10:52:29 -08:00
if config . OverrideOptimismBedrock != nil {
overrides . OverrideOptimismBedrock = config . OverrideOptimismBedrock
}
2023-02-23 13:47:55 +10:00
if config . OverrideOptimismRegolith != nil {
overrides . OverrideOptimismRegolith = config . OverrideOptimismRegolith
}
2022-12-05 10:52:29 -08:00
if config . OverrideOptimism != nil {
overrides . OverrideOptimism = config . OverrideOptimism
}
2022-08-31 00:22:28 +08:00
eth . blockchain , err = core . NewBlockChain ( chainDb , cacheConfig , config . Genesis , & overrides , eth . engine , vmConfig , eth . shouldPreserve , & config . TxLookupLimit )
2015-06-08 12:12:13 +02:00
if err != nil {
return nil , err
}
2023-01-17 18:00:55 +01:00
if chainConfig := eth . blockchain . Config ( ) ; chainConfig . Optimism != nil { // config.Genesis.Config.ChainID cannot be used because it's based on CLI flags only, thus default to mainnet L1
config . NetworkId = chainConfig . ChainID . Uint64 ( ) // optimism defaults eth network ID to chain ID
eth . networkID = config . NetworkId
}
log . Info ( "Initialising Ethereum protocol" , "network" , config . NetworkId , "dbversion" , dbVer )
2017-10-24 15:19:09 +02:00
eth . bloomIndexer . Start ( eth . blockchain )
2017-03-02 14:03:33 +01:00
2017-07-28 15:09:39 +02:00
if config . TxPool . Journal != "" {
2020-08-03 19:40:46 +02:00
config . TxPool . Journal = stack . ResolvePath ( config . TxPool . Journal )
2017-07-28 15:09:39 +02:00
}
2022-10-24 16:13:55 +03:00
eth . txPool = txpool . NewTxPool ( config . TxPool , eth . blockchain . Config ( ) , eth . blockchain )
2015-06-15 11:33:08 +02:00
2019-05-13 15:28:01 +03:00
// Permit the downloader to use the trie cache allowance during fast sync
2019-11-26 09:48:29 +02:00
cacheLimit := cacheConfig . TrieCleanLimit + cacheConfig . TrieDirtyLimit + cacheConfig . SnapshotLimit
all: on-chain oracle checkpoint syncing (#19543)
* all: implement simple checkpoint syncing
cmd, les, node: remove callback mechanism
cmd, node: remove callback definition
les: simplify the registrar
les: expose checkpoint rpc services in the light client
les, light: don't store untrusted receipt
cmd, contracts, les: discard stale checkpoint
cmd, contracts/registrar: loose restriction of registeration
cmd, contracts: add replay-protection
all: off-chain multi-signature contract
params: deploy checkpoint contract for rinkeby
cmd/registrar: add raw signing mode for registrar
cmd/registrar, contracts/registrar, les: fixed messages
* cmd/registrar, contracts/registrar: fix lints
* accounts/abi/bind, les: address comments
* cmd, contracts, les, light, params: minor checkpoint sync cleanups
* cmd, eth, les, light: move checkpoint config to config file
* cmd, eth, les, params: address comments
* eth, les, params: address comments
* cmd: polish up the checkpoint admin CLI
* cmd, contracts, params: deploy new version contract
* cmd/checkpoint-admin: add another flag for clef mode signing
* cmd, contracts, les: rename and regen checkpoint oracle with abigen
2019-06-28 15:34:02 +08:00
checkpoint := config . Checkpoint
if checkpoint == nil {
2022-08-31 00:22:28 +08:00
checkpoint = params . TrustedCheckpoints [ eth . blockchain . Genesis ( ) . Hash ( ) ]
all: on-chain oracle checkpoint syncing (#19543)
* all: implement simple checkpoint syncing
cmd, les, node: remove callback mechanism
cmd, node: remove callback definition
les: simplify the registrar
les: expose checkpoint rpc services in the light client
les, light: don't store untrusted receipt
cmd, contracts, les: discard stale checkpoint
cmd, contracts/registrar: loose restriction of registeration
cmd, contracts: add replay-protection
all: off-chain multi-signature contract
params: deploy checkpoint contract for rinkeby
cmd/registrar: add raw signing mode for registrar
cmd/registrar, contracts/registrar, les: fixed messages
* cmd/registrar, contracts/registrar: fix lints
* accounts/abi/bind, les: address comments
* cmd, contracts, les, light, params: minor checkpoint sync cleanups
* cmd, eth, les, light: move checkpoint config to config file
* cmd, eth, les, params: address comments
* eth, les, params: address comments
* cmd: polish up the checkpoint admin CLI
* cmd, contracts, params: deploy new version contract
* cmd/checkpoint-admin: add another flag for clef mode signing
* cmd, contracts, les: rename and regen checkpoint oracle with abigen
2019-06-28 15:34:02 +08:00
}
2020-12-14 11:27:15 +02:00
if eth . handler , err = newHandler ( & handlerConfig {
2022-05-04 19:55:17 +03:00
Database : chainDb ,
Chain : eth . blockchain ,
TxPool : eth . txPool ,
2022-08-31 00:22:28 +08:00
Merger : eth . merger ,
2022-05-04 19:55:17 +03:00
Network : config . NetworkId ,
Sync : config . SyncMode ,
BloomCache : uint64 ( cacheLimit ) ,
EventMux : eth . eventMux ,
Checkpoint : checkpoint ,
RequiredBlocks : config . RequiredBlocks ,
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
NoTxGossip : config . RollupDisableTxPoolGossip ,
2020-12-14 11:27:15 +02:00
} ) ; err != nil {
2015-09-01 17:35:14 +03:00
return nil , err
}
2021-04-16 21:29:22 +02:00
2022-08-31 00:22:28 +08:00
eth . miner = miner . New ( eth , & config . Miner , eth . blockchain . Config ( ) , eth . EventMux ( ) , eth . engine , eth . isLocalBlock )
2019-04-23 15:08:51 +08:00
eth . miner . SetExtra ( makeExtraData ( config . Miner . ExtraData ) )
2015-07-25 17:33:56 +02:00
2021-02-23 13:09:19 +01:00
eth . APIBackend = & EthAPIBackend { stack . Config ( ) . ExtRPCEnabled ( ) , stack . Config ( ) . AllowUnprotectedTxs , eth , nil }
if eth . APIBackend . allowUnprotectedTxs {
log . Info ( "Unprotected transactions allowed" )
}
2017-04-12 16:27:23 +02:00
gpoParams := config . GPO
if gpoParams . Default == nil {
2019-04-23 15:08:51 +08:00
gpoParams . Default = config . Miner . GasPrice
2015-12-16 04:26:23 +01:00
}
2020-01-09 13:26:37 +02:00
eth . APIBackend . gpo = gasprice . NewOracle ( eth . APIBackend , gpoParams )
2015-12-16 04:26:23 +01:00
2021-05-04 11:29:32 +02:00
// Setup DNS discovery iterators.
dnsclient := dnsdisc . NewClient ( dnsdisc . Config { } )
eth . ethDialCandidates , err = dnsclient . NewIterator ( eth . config . EthDiscoveryURLs ... )
2020-12-14 11:27:15 +02:00
if err != nil {
return nil , err
}
2021-05-04 11:29:32 +02:00
eth . snapDialCandidates , err = dnsclient . NewIterator ( eth . config . SnapDiscoveryURLs ... )
2020-02-13 14:38:30 +01:00
if err != nil {
return nil , err
}
2021-05-04 11:29:32 +02:00
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
if config . RollupSequencerHTTP != "" {
ctx , cancel := context . WithTimeout ( context . Background ( ) , 5 * time . Second )
client , err := rpc . DialContext ( ctx , config . RollupSequencerHTTP )
cancel ( )
if err != nil {
return nil , err
}
eth . seqRPCService = client
}
if config . RollupHistoricalRPC != "" {
2023-01-31 06:35:04 -05:00
ctx , cancel := context . WithTimeout ( context . Background ( ) , config . RollupHistoricalRPCTimeout )
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
client , err := rpc . DialContext ( ctx , config . RollupHistoricalRPC )
cancel ( )
if err != nil {
return nil , err
}
eth . historicalRPCService = client
}
2020-08-03 19:40:46 +02:00
// Start the RPC service
2022-06-21 11:05:43 +02:00
eth . netRPCService = ethapi . NewNetAPI ( eth . p2pServer , config . NetworkId )
2020-08-03 19:40:46 +02:00
// Register the backend on the node
stack . RegisterAPIs ( eth . APIs ( ) )
stack . RegisterProtocols ( eth . Protocols ( ) )
stack . RegisterLifecycle ( eth )
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
2021-12-17 17:48:51 +03:30
// Successful startup; push a marker and check previous unclean shutdowns.
eth . shutdownTracker . MarkStartup ( )
2014-12-14 18:03:24 +00:00
return eth , nil
}
2017-04-12 16:27:23 +02:00
func makeExtraData ( extra [ ] byte ) [ ] byte {
if len ( extra ) == 0 {
// create default extradata
extra , _ = rlp . EncodeToBytes ( [ ] interface { } {
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
uint ( params . OPVersionMajor << 16 | params . OPVersionMinor << 8 | params . OPVersionPatch ) ,
2017-04-12 16:27:23 +02:00
"geth" ,
runtime . Version ( ) ,
runtime . GOOS ,
} )
}
if uint64 ( len ( extra ) ) > params . MaximumExtraDataSize {
log . Warn ( "Miner extra data exceed limit" , "extra" , hexutil . Bytes ( extra ) , "limit" , params . MaximumExtraDataSize )
extra = nil
}
return extra
}
2018-05-24 20:55:20 +08:00
// APIs return the collection of RPC services the ethereum package offers.
2015-10-15 16:07:19 +02:00
// NOTE, some of these services probably need to be moved to somewhere else.
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) APIs ( ) [ ] rpc . API {
2018-05-09 00:59:00 -07:00
apis := ethapi . GetAPIs ( s . APIBackend )
2017-04-05 01:16:29 +03:00
// Append any APIs exposed explicitly by the consensus engine
apis = append ( apis , s . engine . APIs ( s . BlockChain ( ) ) ... )
// Append all the local APIs and return
return append ( apis , [ ] rpc . API {
2015-10-15 16:07:19 +02:00
{
Namespace : "eth" ,
2022-06-21 11:05:43 +02:00
Service : NewEthereumAPI ( s ) ,
2015-10-15 16:07:19 +02:00
} , {
2022-06-21 11:05:43 +02:00
Namespace : "miner" ,
Service : NewMinerAPI ( s ) ,
2015-10-15 16:07:19 +02:00
} , {
Namespace : "eth" ,
2022-06-21 11:05:43 +02:00
Service : downloader . NewDownloaderAPI ( s . handler . downloader , s . eventMux ) ,
2015-12-04 20:56:11 +02:00
} , {
Namespace : "admin" ,
2022-06-21 11:05:43 +02:00
Service : NewAdminAPI ( s ) ,
2015-12-04 20:56:11 +02:00
} , {
Namespace : "debug" ,
2022-06-21 11:05:43 +02:00
Service : NewDebugAPI ( s ) ,
2015-12-16 10:58:01 +01:00
} , {
Namespace : "net" ,
Service : s . netRPCService ,
2015-10-15 16:07:19 +02:00
} ,
2015-12-16 04:26:23 +01:00
} ... )
2015-10-15 16:07:19 +02:00
}
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) ResetWithGenesisBlock ( gb * types . Block ) {
2015-08-31 17:09:50 +02:00
s . blockchain . ResetWithGenesisBlock ( gb )
2015-03-13 18:34:43 +01:00
}
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) Etherbase ( ) ( eb common . Address , err error ) {
2017-05-29 10:21:34 +03:00
s . lock . RLock ( )
etherbase := s . etherbase
s . lock . RUnlock ( )
if etherbase != ( common . Address { } ) {
return etherbase , nil
2017-01-24 11:49:20 +02:00
}
2017-12-10 00:42:23 +02:00
return common . Address { } , fmt . Errorf ( "etherbase must be explicitly specified" )
2015-03-26 21:49:22 +00:00
}
2018-09-21 01:02:15 +08:00
// isLocalBlock checks whether the specified block is mined
// by local miner accounts.
2018-09-20 20:09:30 +08:00
//
2018-09-21 01:02:15 +08:00
// We regard two types of accounts as local miner account: etherbase
// and accounts specified via `txpool.locals` flag.
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
func ( s * Ethereum ) isLocalBlock ( header * types . Header ) bool {
author , err := s . engine . Author ( header )
2018-09-21 01:02:15 +08:00
if err != nil {
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
log . Warn ( "Failed to retrieve block author" , "number" , header . Number . Uint64 ( ) , "hash" , header . Hash ( ) , "err" , err )
2018-09-21 01:02:15 +08:00
return false
}
2018-09-20 20:09:30 +08:00
// Check whether the given address is etherbase.
s . lock . RLock ( )
etherbase := s . etherbase
s . lock . RUnlock ( )
2018-09-21 01:02:15 +08:00
if author == etherbase {
2018-09-20 20:09:30 +08:00
return true
}
// Check whether the given address is specified by `txpool.local`
// CLI flag.
for _ , account := range s . config . TxPool . Locals {
2018-09-21 01:02:15 +08:00
if account == author {
2018-09-20 20:09:30 +08:00
return true
}
}
return false
}
2018-09-21 01:02:15 +08:00
// shouldPreserve checks whether we should preserve the given block
// during the chain reorg depending on whether the author of block
// is a local account.
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
func ( s * Ethereum ) shouldPreserve ( header * types . Header ) bool {
2018-09-21 01:02:15 +08:00
// The reason we need to disable the self-reorg preserving for clique
// is it can be probable to introduce a deadlock.
//
// e.g. If there are 7 available signers
//
// r1 A
// r2 B
// r3 C
// r4 D
// r5 A [X] F G
// r6 [X]
//
// In the round5, the inturn signer E is offline, so the worst case
// is A, F and G sign the block of round5 and reject the block of opponents
// and in the round6, the last available signer B is offline, the whole
// network is stuck.
if _ , ok := s . engine . ( * clique . Clique ) ; ok {
return false
}
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
return s . isLocalBlock ( header )
2018-09-21 01:02:15 +08:00
}
2018-05-03 05:15:33 -07:00
// SetEtherbase sets the mining reward address.
func ( s * Ethereum ) SetEtherbase ( etherbase common . Address ) {
s . lock . Lock ( )
s . etherbase = etherbase
s . lock . Unlock ( )
2017-05-29 10:21:34 +03:00
2018-05-03 05:15:33 -07:00
s . miner . SetEtherbase ( etherbase )
2015-07-07 10:32:05 +02:00
}
2018-08-23 13:02:36 +03:00
// StartMining starts the miner with the given number of CPU threads. If mining
// is already running, this method adjust the number of threads allowed to use
// and updates the minimum price required by the transaction pool.
func ( s * Ethereum ) StartMining ( threads int ) error {
// Update the thread count within the consensus engine
type threaded interface {
SetThreads ( threads int )
2016-10-28 20:05:01 +03:00
}
2018-08-23 13:02:36 +03:00
if th , ok := s . engine . ( threaded ) ; ok {
log . Info ( "Updated mining threads" , "threads" , threads )
if threads == 0 {
threads = - 1 // Disable the miner from within
2017-04-10 13:24:12 +03:00
}
2018-08-23 13:02:36 +03:00
th . SetThreads ( threads )
2017-04-10 13:24:12 +03:00
}
2018-08-23 13:02:36 +03:00
// If the miner was not running, initialize it
if ! s . IsMining ( ) {
// Propagate the initial price point to the transaction pool
s . lock . RLock ( )
price := s . gasPrice
s . lock . RUnlock ( )
s . txPool . SetGasPrice ( price )
2018-09-20 20:09:30 +08:00
// Configure the local mining address
2018-08-23 13:02:36 +03:00
eb , err := s . Etherbase ( )
if err != nil {
log . Error ( "Cannot start mining without etherbase" , "err" , err )
return fmt . Errorf ( "etherbase missing: %v" , err )
}
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
var cli * clique . Clique
if c , ok := s . engine . ( * clique . Clique ) ; ok {
cli = c
} else if cl , ok := s . engine . ( * beacon . Beacon ) ; ok {
if c , ok := cl . InnerEngine ( ) . ( * clique . Clique ) ; ok {
cli = c
}
}
if cli != nil {
2018-08-23 13:02:36 +03:00
wallet , err := s . accountManager . Find ( accounts . Account { Address : eb } )
if wallet == nil || err != nil {
log . Error ( "Etherbase account unavailable locally" , "err" , err )
return fmt . Errorf ( "signer missing: %v" , err )
}
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
cli . Authorize ( eb , wallet . SignData )
2018-08-23 13:02:36 +03:00
}
// If mining is started, we can disable the transaction rejection mechanism
// introduced to speed sync times.
2020-12-14 11:27:15 +02:00
atomic . StoreUint32 ( & s . handler . acceptTxs , 1 )
2018-08-23 13:02:36 +03:00
2023-01-21 00:26:01 +08:00
go s . miner . Start ( )
2017-04-10 11:43:01 +03:00
}
2016-10-28 20:05:01 +03:00
return nil
}
2018-08-23 13:02:36 +03:00
// StopMining terminates the miner, both at the consensus engine level as well as
// at the block creation level.
func ( s * Ethereum ) StopMining ( ) {
// Update the thread count within the consensus engine
type threaded interface {
SetThreads ( threads int )
}
if th , ok := s . engine . ( threaded ) ; ok {
th . SetThreads ( - 1 )
}
// Stop the block creating itself
s . miner . Stop ( )
}
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) IsMining ( ) bool { return s . miner . Mining ( ) }
func ( s * Ethereum ) Miner ( ) * miner . Miner { return s . miner }
func ( s * Ethereum ) AccountManager ( ) * accounts . Manager { return s . accountManager }
func ( s * Ethereum ) BlockChain ( ) * core . BlockChain { return s . blockchain }
2022-10-24 16:13:55 +03:00
func ( s * Ethereum ) TxPool ( ) * txpool . TxPool { return s . txPool }
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) EventMux ( ) * event . TypeMux { return s . eventMux }
2017-04-05 01:16:29 +03:00
func ( s * Ethereum ) Engine ( ) consensus . Engine { return s . engine }
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) ChainDb ( ) ethdb . Database { return s . chainDb }
func ( s * Ethereum ) IsListening ( ) bool { return true } // Always listening
2020-12-14 11:27:15 +02:00
func ( s * Ethereum ) Downloader ( ) * downloader . Downloader { return s . handler . downloader }
func ( s * Ethereum ) Synced ( ) bool { return atomic . LoadUint32 ( & s . handler . acceptTxs ) == 1 }
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
func ( s * Ethereum ) SetSynced ( ) { atomic . StoreUint32 ( & s . handler . acceptTxs , 1 ) }
2019-06-11 15:40:32 +08:00
func ( s * Ethereum ) ArchiveMode ( ) bool { return s . config . NoPruning }
2020-08-03 19:40:46 +02:00
func ( s * Ethereum ) BloomIndexer ( ) * core . ChainIndexer { return s . bloomIndexer }
all: core rework for the merge transition (#23761)
* all: work for eth1/2 transtition
* consensus/beacon, eth: change beacon difficulty to 0
* eth: updates
* all: add terminalBlockDifficulty config, fix rebasing issues
* eth: implemented merge interop spec
* internal/ethapi: update to v1.0.0.alpha.2
This commit updates the code to the new spec, moving payloadId into
it's own object. It also fixes an issue with finalizing an empty blockhash.
It also properly sets the basefee
* all: sync polishes, other fixes + refactors
* core, eth: correct semantics for LeavePoW, EnterPoS
* core: fixed rebasing artifacts
* core: light: performance improvements
* core: use keyed field (f)
* core: eth: fix compilation issues + tests
* eth/catalyst: dbetter error codes
* all: move Merger to consensus/, remove reliance on it in bc
* all: renamed EnterPoS and LeavePoW to ReachTDD and FinalizePoS
* core: make mergelogs a function
* core: use InsertChain instead of InsertBlock
* les: drop merger from lightchain object
* consensus: add merger
* core: recoverAncestors in catalyst mode
* core: fix nitpick
* all: removed merger from beacon, use TTD, nitpicks
* consensus: eth: add docstring, removed unnecessary code duplication
* consensus/beacon: better comment
* all: easy to fix nitpicks by karalabe
* consensus/beacon: verify known headers to be sure
* core: comments
* core: eth: don't drop peers who advertise blocks, nitpicks
* core: never add beacon blocks to the future queue
* core: fixed nitpicks
* consensus/beacon: simplify IsTTDReached check
* consensus/beacon: correct IsTTDReached check
Co-authored-by: rjl493456442 <garyrong0905@gmail.com>
Co-authored-by: Péter Szilágyi <peterke@gmail.com>
2021-11-26 12:23:02 +01:00
func ( s * Ethereum ) Merger ( ) * consensus . Merger { return s . merger }
func ( s * Ethereum ) SyncMode ( ) downloader . SyncMode {
mode , _ := s . handler . chainSync . modeAndLocalHead ( )
return mode
}
2015-01-28 18:14:28 +01:00
2020-08-03 19:40:46 +02:00
// Protocols returns all the currently configured
2015-11-17 18:33:25 +02:00
// network protocols to start.
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) Protocols ( ) [ ] p2p . Protocol {
2020-12-14 11:27:15 +02:00
protos := eth . MakeProtocols ( ( * ethHandler ) ( s . handler ) , s . networkID , s . ethDialCandidates )
if s . config . SnapshotCache > 0 {
protos = append ( protos , snap . MakeProtocols ( ( * snapHandler ) ( s . handler ) , s . snapDialCandidates ) ... )
2019-07-08 18:53:47 +03:00
}
return protos
2015-11-17 18:33:25 +02:00
}
2015-04-22 12:46:41 +02:00
2020-08-03 19:40:46 +02:00
// Start implements node.Lifecycle, starting all internal goroutines needed by the
2016-06-30 13:03:26 +03:00
// Ethereum protocol implementation.
2020-08-03 19:40:46 +02:00
func ( s * Ethereum ) Start ( ) error {
2020-12-14 11:27:15 +02:00
eth . StartENRUpdater ( s . blockchain , s . p2pServer . LocalNode ( ) )
2019-07-08 18:53:47 +03:00
2017-08-29 14:13:11 +03:00
// Start the bloom bits servicing goroutines
2018-08-28 15:08:16 +08:00
s . startBloomHandlers ( params . BloomBitsBlocks )
2017-08-29 14:13:11 +03:00
2021-12-17 17:48:51 +03:30
// Regularly update shutdown marker
s . shutdownTracker . Start ( )
2017-09-05 19:18:28 +03:00
// Figure out a max peers count based on the server limits
2020-08-03 19:40:46 +02:00
maxPeers := s . p2pServer . MaxPeers
2017-09-05 19:18:28 +03:00
if s . config . LightServ > 0 {
2020-08-03 19:40:46 +02:00
if s . config . LightPeers >= s . p2pServer . MaxPeers {
return fmt . Errorf ( "invalid peer config: light peer count (%d) >= total peer count (%d)" , s . config . LightPeers , s . p2pServer . MaxPeers )
2017-09-05 19:18:28 +03:00
}
2018-02-05 14:41:53 +01:00
maxPeers -= s . config . LightPeers
2017-09-05 19:18:28 +03:00
}
2017-08-29 14:13:11 +03:00
// Start the networking layer and the light server if requested
2020-12-14 11:27:15 +02:00
s . handler . Start ( maxPeers )
2014-12-14 18:03:24 +00:00
return nil
}
2020-08-03 19:40:46 +02:00
// Stop implements node.Lifecycle, terminating all internal goroutines used by the
2015-11-17 18:33:25 +02:00
// Ethereum protocol.
2016-06-30 13:03:26 +03:00
func ( s * Ethereum ) Stop ( ) error {
2020-03-27 14:03:20 +01:00
// Stop all the peer-related stuff first.
2021-05-04 11:29:32 +02:00
s . ethDialCandidates . Close ( )
s . snapDialCandidates . Close ( )
2020-12-14 11:27:15 +02:00
s . handler . Stop ( )
2020-03-27 14:03:20 +01:00
// Then stop everything else.
s . bloomIndexer . Close ( )
close ( s . closeBloomHandler )
2014-12-14 18:03:24 +00:00
s . txPool . Stop ( )
2021-10-08 18:36:58 +02:00
s . miner . Close ( )
2020-03-27 14:03:20 +01:00
s . blockchain . Stop ( )
s . engine . Close ( )
optimism: historical Bedrock geth rollup changes
This commit squashes the op-geth fork history into a more maintainable
diff for rebasing upon upstream geth.
reference-optimistic-geth changes (origins of op-geth in early Bedrock
development stage):
- Deposit TX Type
- Enable deposit tx in EVM/tx pool
- Change deposit nonce to not be the max nonce
- Extend PayloadAttributesV1 with a Transactions field
- Force deposits at the start of each L2 block
- Fix height check
- noTxPool flag, reproduce block in verifier mode without tx pool interference
- Fix RPC json marshalling (ref op-geth PR 4)
- Deposit txs block height check in block body validation (ref op-geth PR 5)
- core: do not try to reinject deposit txs into tx-pool (ref-op-geth PR 6)
- deposit source hash field instead of L2 block height and tx index combination
- Include invalid deposits, rewind state, but always persist mint (#10)
- Provide gas to Call/Create in deposit transactions (#12)
- Add docker builds (ref-op-geth PR 16, 17)
- Don't panic on deposit transaction signature values or chain ID (ref-op-geth PR 18)
- core: Add version to DepositTx (ref-op-geth PR 19)
- Enable Geth build/lint/test in CircleCI (ref-op-geth PR 23)
- core: Include guaranteed gas in the gas pool (ref-op-geth PR 21)
- core: handle base fee, l1 availability fee, tx fee (ref-op-geth PR 27)
- fix: deposit tx hash
- fix l1 fee cache, rpc, tracing and tx pool
- core: remove deposit-tx sub-type (a.k.a. deposit version byte)
- eth/catalyst: allow engine user to reorg own chain
- miner: restore ability to reorg deep as block builder
- params: print Optimism consensus type in banner
- core/types: remove unused protected() method, see upstream PR 23376
- core: do not mutate original balance value in tx pool l1 cost adjustment
- core: subtract deposit gas from pool, so other txs do not use the same gas. And fail tx processing if deposits reach gas limit
- core/types: deposits do not tip, avoid basefee subtraction
- Unmeter the L1 Attributes Transaction
- miner: handle force tx errors as critical, clean up diff
- ci: Switch branch
- eth,miner: return STATUS_INVALID when failing to process forced transactions in request (ref-op-geth PR 40)
- verifier: forward tx to sequencer based on flag
- txpool: add flag to disable tx gossip (ref-op-geth PR 42)
- Add op-geth version in addition to geth version (ref-op-geth PR 43)
- ci: CircleCI improvements (ref-op-geth PR 44)
- Rename to op-geth
- Build latest tag on optimism branch
op-geth changes:
- Expose cache config in simulated backend (#2)
- Add EIP-1559 parameters
- eth/catalyst: update payload id computation (#1)
- make eip1559 configurable (#4)
- post-merge network should not log warnings about missing transition information (#5)
- Make the simulator more configurable (#6)
- fix OPB-6 - IsDepositTx check instead of artificial nonce value check (#7)
- Simulated backend - enable proof of stake consensus type and fix performance issue (#8)
- accounts: simulated backend consensus engine option and immediate tx indexing
- consensus/beacon: recognize all blocks as reached TTD with 0 TTD in chain config
- Add --rollup.historicalhttp CLI flag and fix backend iface
- Flags and interfaces for historical RPC requests (#12)
- Redirect historical RPC requests (#13)
- Use the pre-existing ethereum.NotFound error (#18)
- Add historical endpoint to TraceBlockByNumber and TraceBlockByHash (#19)
- Add historical endpoint to TraceTransaction (#20)
- Add historical endpoint to TraceCall (#21)
- optimism: fee params from info txi, update l1 cost func GPO params read (#15)
- add hardcoded addresses for fee payouts (#23)
- dynamic gas limit via engine API (#22)
Co-authored-by: Matthew Slipper <me@matthewslipper.com>
Co-authored-by: Joshua Gutow <jgutow@oplabs.co>
Co-authored-by: protolambda <proto@protolambda.com>
Co-authored-by: Mark Tyneway <mark.tyneway@gmail.com>
Co-authored-by: Maurelian <maurelian@protonmail.ch>
2022-03-10 12:13:11 -08:00
if s . seqRPCService != nil {
s . seqRPCService . Close ( )
}
if s . historicalRPCService != nil {
s . historicalRPCService . Close ( )
}
2021-12-17 17:48:51 +03:30
// Clean shutdown marker as the last thing before closing db
s . shutdownTracker . Stop ( )
2015-09-14 09:45:40 +02:00
s . chainDb . Close ( )
2020-03-27 14:03:20 +01:00
s . eventMux . Stop ( )
2020-12-14 11:27:15 +02:00
2015-11-17 18:33:25 +02:00
return nil
2014-12-14 18:03:24 +00:00
}