Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Upgrade] Go-Ethereum release v1.9.13 #1123

Merged
merged 125 commits into from
Feb 12, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
125 commits
Select commit Hold shift + click to select a range
542df88
core: initial version of state snapshots
karalabe Aug 6, 2019
e146fbe
core/state: lazy sorting, snapshot invalidation
holiman Oct 4, 2019
d7d81d7
core/state/snapshot: extract and split cap method, cover corners
karalabe Oct 17, 2019
cdf3f01
snapshot: iteration and buffering optimizations
holiman Oct 23, 2019
d754091
core/state/snapshot: unlink snapshots from blocks, quad->linear cleanup
karalabe Nov 22, 2019
f300c0d
core/state/snapshot: replace bigcache with fastcache
holiman Nov 25, 2019
351a590
core/rawdb, core/state/snapshot: runtime snapshot generation
karalabe Nov 26, 2019
d5d7c0c
core/state/snapshot: fix difflayer origin-initalization after flatten
holiman Dec 1, 2019
fd39f72
core: journal the snapshot inside leveldb, not a flat file
karalabe Dec 2, 2019
3ad4335
core/state/snapshot: node behavioural difference on bloom content
holiman Dec 2, 2019
22c494d
core/state/snapshot: bloom, metrics and prefetcher fixes
karalabe Dec 3, 2019
7e38996
core/state/snapshot: implement snapshot layer iteration
holiman Nov 5, 2019
e567675
core/state/snapshot: move iterator out into its own files
karalabe Dec 5, 2019
e570835
core/state/snapshot: implement iterator priority for fast direct data…
holiman Dec 6, 2019
6ddb92a
core/state/snapshot: full featured account iteration
karalabe Dec 10, 2019
1909942
core/state/snapshot: faster account iteration, CLI integration
holiman Jan 19, 2020
06d4470
core: fix broken tests due to API changes + linter
karalabe Feb 24, 2020
92ec07d
core/state: fix an account resurrection issue
karalabe Feb 27, 2020
361a6f0
core/tests: test for destroy+recreate contract with storage
holiman Mar 2, 2020
fe8347e
squashme
holiman Mar 2, 2020
6e05ccd
core/state/snapshot, tests: sync snap gen + snaps in consensus tests
karalabe Mar 3, 2020
a4cf279
core/state: extend snapshotter to handle account resurrections
karalabe Mar 3, 2020
dcb22a9
core/state: fix account root hash update point
karalabe Mar 3, 2020
328de18
core/state: fix resurrection state clearing and access
karalabe Mar 4, 2020
eff7cfb
core/state/snapshot: handle deleted accounts in fast iterator
holiman Mar 4, 2020
bc5d742
core: more blockchain tests
holiman Mar 4, 2020
fab0ee3
core/state/snapshot: fix various iteration issues due to destruct set
karalabe Mar 4, 2020
8d7aa90
params: begin v1.9.13 release cycle
karalabe Mar 16, 2020
efd92d8
cmd/checkpoint-admin: add some documentation (#20697)
rjl493456442 Mar 18, 2020
5dd0cd1
go.mod: update duktape to fix sprintf warnings (#20777)
moreati Mar 18, 2020
20a092f
core/rawdb: fix freezer table test error check
meowsbits Mar 18, 2020
6283391
core/rawdb: improve table database (#20703)
rjl493456442 Mar 18, 2020
dc6e98d
eth: when triggering a sync, check the head header TD, not block
karalabe Mar 18, 2020
4655b60
Merge pull request #20780 from karalabe/fix-eth-mine-sync-race
karalabe Mar 18, 2020
e6ca195
internal/web3ext: fix clique console apis to work on missing arguments
karalabe Mar 18, 2020
36e93d2
Merge pull request #20779 from meowsbits/patch-3
karalabe Mar 18, 2020
0e6ea91
Merge pull request #20781 from karalabe/fix-clique-console-apis
karalabe Mar 19, 2020
e943f07
whisper/whisperv6: delete failing tests (#20788)
gballet Mar 20, 2020
93ffb85
rpc: dont log an error if user configures --rpcapi=rpc... (#20776)
meowsbits Mar 21, 2020
074efe6
core: fix two snapshot iterator flaws, decollide snap storage prefix
holiman Mar 6, 2020
613af7c
Merge pull request #20152 from karalabe/snapshot-5
karalabe Mar 23, 2020
a75c061
core/blockchain: simplify atomic store after writeBlockWithState (#20…
meowsbits Mar 23, 2020
0734c4b
node, cmd/clef: report actual port used for http rpc (#20789)
holiman Mar 23, 2020
39f5023
internal/ethapi: don't set sender-balance to maxuint, fixes #16999 (#…
holiman Mar 23, 2020
42e02ac
metrics: disable CPU stats (gosigar) on iOS
karalabe Mar 26, 2020
4690912
Merge pull request #20816 from karalabe/disable-gosigar-ios
karalabe Mar 26, 2020
1583e7d
cmd/devp2p: tweak DNS TTLs (#20801)
fjl Mar 26, 2020
87a411b
cmd/devp2p: lower route53 change limit again (#20819)
fjl Mar 26, 2020
d3c1e65
cmd/devp2p: be very correct about route53 change splitting (#20820)
fjl Mar 26, 2020
d7851e6
graphql, node, rpc: fix typos in comments (#20824)
renaynay Mar 27, 2020
d6c5f24
eth: improve shutdown synchronization (#20695)
fjl Mar 27, 2020
62cd943
les: fix dead lock (#20828)
rjl493456442 Mar 27, 2020
5d7e5b0
eth/filters: fix typo on unindexedLogs function's comment (#20827)
hadv Mar 27, 2020
55a73f5
core: bump txpool tx max size to 128KB
holiman Mar 30, 2020
84f4975
Merge pull request #20835 from holiman/bump
karalabe Mar 30, 2020
76eed9e
snapshotter/tests: verify snapdb post-state against trie (#20812)
holiman Mar 31, 2020
8f05cfa
cmd, consensus: add option to disable mmap for DAG caches/datasets (#…
de1acr0ix Mar 31, 2020
c56f4fa
cmd/clef: add newaccount command (#20782)
holiman Mar 31, 2020
03fe9de
eth: add debug_accountRange API (#19645)
jsvisa Mar 31, 2020
300c35b
travis: allow cocoapods deploy to fail (#20833)
adamschmideg Mar 31, 2020
3b69c14
whisper/whisperv6: decrease pow requirement in tests (#20815)
holiman Mar 31, 2020
32d31c3
metrics: improve TestTimerFunc (#20818)
holiman Mar 31, 2020
f78ffc0
les: create utilities as common package (#20509)
rjl493456442 Mar 31, 2020
f0be151
README: update private network genesis spec with istanbul (#20841)
shoenseiwaso Mar 31, 2020
a5a9fea
whisper: fix whisper go routine leak with sync wait group (#20844)
ucwong Apr 1, 2020
d56dc03
cmd/evm: Rework execution stats (#20792)
chfast Apr 1, 2020
1e2e1b4
cmd/devp2p, cmd/wnode, whisper: add missing calls to Timer.Stop (#20843)
ucwong Apr 1, 2020
bf35e27
p2p/server: add UDP port mapping goroutine to wait group (#20846)
ucwong Apr 1, 2020
f15849c
accounts/abi faster unpacking of int256 (#20850)
MariusVanDerWijden Apr 1, 2020
c87cdd3
p2p/discv5: add missing Timer.Stop calls (#20853)
ucwong Apr 2, 2020
ad4b60e
miner/worker: add missing timer.Stop call (#20857)
ucwong Apr 2, 2020
228a297
cmd/geth: fix bad genesis test (#20860)
holiman Apr 2, 2020
47f7c73
eth/filters: add missing Ticker.Stop call (#20862)
ucwong Apr 2, 2020
66ed58b
eth/fetcher: add missing timer.Stop calls (#20861)
ucwong Apr 2, 2020
4d891f2
les: add missing Ticker.Stop call (#20864)
ucwong Apr 2, 2020
0893ee6
event: add missing timer.Stop call in TestFeed (#20868)
ucwong Apr 2, 2020
53e034c
metrics: add missing calls to Ticker.Stop in tests (#20866)
ucwong Apr 2, 2020
37d6357
ethstats: add missing Ticker.Stop call (#20867)
ucwong Apr 2, 2020
0c359e4
p2p/discv5, p2p/testing: add missing Timer.Stop calls in tests (#20869)
ucwong Apr 2, 2020
f98caba
core: add missing Timer.Stop call in TestLogReorgs (#20870)
ucwong Apr 2, 2020
f7b29ec
rpc: add missing timer.Stop calls in websocket tests (#20863)
ucwong Apr 2, 2020
462ddce
crypto/ecies: improve concatKDF (#20836)
lukechampine Apr 3, 2020
be9172a
rpc: metrics for JSON-RPC method calls (#20847)
rjl493456442 Apr 3, 2020
98eab2d
mobile: use bind.NewKeyedTransactor instead of duplicating (#20888)
MariusVanDerWijden Apr 3, 2020
be6078a
all: fix a bunch of inconsequential goroutine leaks (#20667)
BurtonQin Apr 3, 2020
3cf7d2e
internal/ethapi: add CallArgs.ToMessage method (#20854)
wjmelements Apr 3, 2020
f0b5eb0
eth, les: fix flaky tests (#20897)
rjl493456442 Apr 7, 2020
0bec6a4
cmd/geth: enable metrics for geth import command (#20738)
holiman Apr 7, 2020
8dc8941
core/vm: use a callcontext struct (#20761)
holiman Apr 7, 2020
094996b
docs/audits: add discv5 protocol audits from LA and C53 (#20898)
holiman Apr 7, 2020
6a3daa2
.github: change gitter reference to discord link in issue template (#…
adamschmideg Apr 7, 2020
671f22b
couple of fixes to docs in clef (#20900)
renaynay Apr 7, 2020
b7394d7
p2p/discover: add initial discovery v5 implementation (#20750)
fjl Apr 8, 2020
c8e9a91
build: upgrade to golangci-lint 1.24.0 (#20901)
fjl Apr 8, 2020
6975172
whisper/mailserver : recover corrupt db files before opening (#20891)
ucwong Apr 8, 2020
5065cde
accounts/abi/bind: Refactored topics (#20851)
MariusVanDerWijden Apr 8, 2020
07d909f
node: allow websocket and HTTP on the same port (#20810)
renaynay Apr 8, 2020
fe9ffa5
crypto: improve error messages in LoadECDSA (#20718)
adamschmideg Apr 8, 2020
1bad861
changed date of rpcstack.go since new file (#20904)
renaynay Apr 8, 2020
023b87b
accounts/abi/bind: fixed erroneous filtering of negative ints (#20865)
MariusVanDerWijden Apr 9, 2020
15540ae
cmd: deprecate --testnet, use named networks instead (#20852)
q9f Apr 9, 2020
0851646
les, les/lespay/client: add service value statistics and API (#20837)
zsfelfoldi Apr 9, 2020
5a20cc0
README: update min go version to 1.13 (#20911)
ligi Apr 14, 2020
eb2fd82
travis, appveyor, build, Dockerfile: bump Go to 1.14.2 (#20913)
karalabe Apr 14, 2020
2a836bb
core/rawdb: fix data race between Retrieve and Close (#20919)
MariusVanDerWijden Apr 14, 2020
00064dd
accounts/abi: implement new fallback functions (#20764)
rjl493456442 Apr 15, 2020
6402c42
all: simplify and fix database iteration with prefix/start (#20808)
holiman Apr 15, 2020
d77d35a
params: update CHTs for the 1.9.13 release
karalabe Apr 15, 2020
359d9c3
Merge pull request #20925 from karalabe/cht-1.9.13
karalabe Apr 15, 2020
cbc4ac2
params: release Geth v1.9.13
karalabe Apr 16, 2020
ea9eda5
backup
ricardolyn Feb 9, 2021
0cdce11
Merge branch 'public_master' into upgrade/go-ethereum/v1.9.13-2021204…
ricardolyn Feb 9, 2021
e54fc49
fix: apply valid test cases for core/genesis_test.go, that should wor…
ricardolyn Feb 9, 2021
f95ea04
lint: fix lint issues
ricardolyn Feb 9, 2021
712bfcc
Merge branch 'master' into upgrade/go-ethereum/v1.9.13-2021204155332
ricardolyn Feb 9, 2021
29dd4ef
test: fix TestTransactionAllowedTxSize by using the custom transactio…
ricardolyn Feb 9, 2021
78f1334
lint: increase timeout
ricardolyn Feb 9, 2021
9cb6332
Merge branch 'master' of github.com:ConsenSys/quorum into upgrade/go-…
ricardolyn Feb 10, 2021
8420dd2
Merge branch 'master' into upgrade/go-ethereum/v1.9.13-2021204155332
ricardolyn Feb 10, 2021
15c2473
improvement: Created NewDual function to create pub and priv state at…
ricardolyn Feb 10, 2021
151602e
workflow: add 2 new AT
ricardolyn Feb 10, 2021
695ed71
workflow: remove extra ATs
ricardolyn Feb 11, 2021
1171737
fix: comments from review
ricardolyn Feb 12, 2021
1f871ab
Merge branch 'public_master' into upgrade/go-ethereum/v1.9.13-2021204…
ricardolyn Feb 12, 2021
e87075f
fix: tests and build issues
ricardolyn Feb 12, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 6 additions & 3 deletions core/state/statedb.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,9 @@ import (
"sort"
"time"

"github.com/ethereum/go-ethereum/core/rawdb"
"github.com/ethereum/go-ethereum/ethdb"

ricardolyn marked this conversation as resolved.
Show resolved Hide resolved
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/core/state/snapshot"
"github.com/ethereum/go-ethereum/core/types"
Expand Down Expand Up @@ -158,14 +161,14 @@ func New(root common.Hash, db Database, snaps *snapshot.Tree) (*StateDB, error)
return sdb, nil
}

// TODO ricardolyn: separate commit
// Quorum
// NewDual - Create a public and private state from a given public and private tree
func NewDual(root common.Hash, db Database, snaps *snapshot.Tree, privateRoot common.Hash, privateDb Database, privateSnaps *snapshot.Tree) (*StateDB, *StateDB, error) {
func NewDual(root common.Hash, db Database, snaps *snapshot.Tree, ethDb ethdb.Database, privateDb Database, privateSnaps *snapshot.Tree) (*StateDB, *StateDB, error) {
nmvalera marked this conversation as resolved.
Show resolved Hide resolved
publicState, err := New(root, db, snaps)
if err != nil {
return nil, nil, err
}
privateState, err := New(privateRoot, privateDb, privateSnaps)
privateState, err := New(rawdb.GetPrivateStateRoot(ethDb, root), privateDb, privateSnaps)
if err != nil {
return nil, nil, err
}
Expand Down
52 changes: 52 additions & 0 deletions core/state/statedb_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -733,6 +733,58 @@ func TestDeleteCreateRevert(t *testing.T) {
}
}

// Quorum - NewDual

func TestStorageRootNewDual(t *testing.T) {

var (
pubMem = rawdb.NewMemoryDatabase()
privMem = rawdb.NewMemoryDatabase()
pubDb = NewDatabase(pubMem)
privDb = NewDatabase(privMem)
pubState, privState, _ = NewDual(common.Hash{}, pubDb, nil, privMem, privDb, nil)
addr = common.Address{1}
key = common.Hash{1}
value = common.Hash{42}

empty = common.HexToHash("56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421")
)

args := []struct {
db Database
state *StateDB
}{
{
pubDb, pubState,
},
{
privDb, privState,
},
}

for _, arg := range args {
so := arg.state.GetOrNewStateObject(addr)

emptyRoot := so.storageRoot(arg.db)
if emptyRoot != empty {
t.Errorf("Invalid empty storage root, expected %x, got %x", empty, emptyRoot)
}

// add a bit of state
so.SetState(arg.db, key, value)
arg.state.Commit(false)

root := so.storageRoot(arg.db)
expected := common.HexToHash("63511abd258fa907afa30cb118b53744a4f49055bb3f531da512c6b866fc2ffb")

if expected != root {
t.Errorf("Invalid storage root, expected %x, got %x", expected, root)
}
}
}

// End Quorum - NewDual

// Quorum - Privacy Enhancements
func TestPrivacyMetadataIsSavedOnStateDbCommit(t *testing.T) {
ethDb := rawdb.NewMemoryDatabase()
Expand Down
22 changes: 13 additions & 9 deletions eth/api_tracer.go
Original file line number Diff line number Diff line change
Expand Up @@ -150,15 +150,17 @@ func (api *PrivateDebugAPI) traceChain(ctx context.Context, start, end *types.Bl
// Ensure we have a valid starting state before doing any work
origin := start.NumberU64()
database := state.NewDatabaseWithCache(api.eth.ChainDb(), 16) // Chain tracing will probably start at genesis
// Quorum
privateDatabase := state.NewDatabaseWithCache(api.eth.ChainDb(), 16)
// End Quorum

if number := start.NumberU64(); number > 0 {
start = api.eth.blockchain.GetBlock(start.ParentHash(), start.NumberU64()-1)
if start == nil {
return nil, fmt.Errorf("parent block #%d not found", number-1)
}
}
// TODO ricardolyn: original geth code pass snaps as nil. but at the same time it pass a custom database that we dont use here
statedb, privateStateDb, err := api.eth.blockchain.StateAt(start.Root())
statedb, privateStateDb, err := state.NewDual(start.Root(), database, nil, api.eth.chainDb, privateDatabase, nil)
if err != nil {
// If the starting state is missing, allow some number of blocks to be reexecuted
reexec := defaultTraceReexec
Expand All @@ -171,9 +173,9 @@ func (api *PrivateDebugAPI) traceChain(ctx context.Context, start, end *types.Bl
if start == nil {
break
}
// TODO ricardolyn: original geth code pass snaps as nil. but at the same time it pass a custom database that we dont use here
statedb, privateStateDb, err = api.eth.blockchain.StateAt(start.Root())
if err == nil {

// Quorum - use NewDual(...) to create private state too
if statedb, privateStateDb, err = state.NewDual(start.Root(), database, nil, api.eth.chainDb, privateDatabase, nil); err == nil {
break
}
}
Expand Down Expand Up @@ -668,23 +670,25 @@ func containsTx(block *types.Block, hash common.Hash) bool {
// attempted to be reexecuted to generate the desired state.
func (api *PrivateDebugAPI) computeStateDB(block *types.Block, reexec uint64) (*state.StateDB, *state.StateDB, error) {
// If we have the state fully available, use that
// TODO ricardolyn: original geth code pass snaps as nil. but at the same time it pass a custom database that we dont use here
statedb, privateStateDb, err := api.eth.blockchain.StateAt(block.Root())
if err == nil {
return statedb, privateStateDb, nil
}
// Otherwise try to reexec blocks until we find a state or reach our limit
origin := block.NumberU64()
database := state.NewDatabaseWithCache(api.eth.ChainDb(), 16)
// Quorum
privateDatabase := state.NewDatabaseWithCache(api.eth.ChainDb(), 16)
// End Quorum

for i := uint64(0); i < reexec; i++ {
block = api.eth.blockchain.GetBlock(block.ParentHash(), block.NumberU64()-1)
if block == nil {
break
}
// TODO ricardolyn: original geth code pass snaps as nil. but at the same time it pass a custom database that we dont use here
statedb, privateStateDb, err = api.eth.blockchain.StateAt(block.Root())
if err == nil {

// Quorum - use NewDual(...) to create private state too
if statedb, privateStateDb, err = state.NewDual(block.Root(), database, nil, api.eth.chainDb, privateDatabase, nil); err == nil {
break
}
}
Expand Down