-
Notifications
You must be signed in to change notification settings - Fork 115
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
Merge v1.11.2 #205
Merge v1.11.2 #205
Changes from 21 commits
c539bda
ea65eda
8334b5f
e34e540
8c5ce11
f58ebd9
9afc681
ae42148
bc90a88
b4ea2bf
add337e
64067fb
c3b4268
12df456
722bb21
97c563e
c2e0abc
6975f09
64dccf7
ec2ec2d
193f350
8846c07
e76813e
c5dc61c
add1bff
6a4e05c
8c6e74e
53d1ae0
1325fef
0dc9b01
eb01927
63ffda3
0e06735
743e404
1b8a392
c1aa1db
e24d600
10347c6
06632da
1f35988
41306b0
01953b3
b44abf5
f20eba4
4221280
6891288
a9dfac0
890e2ef
711afbc
3315bad
3775e19
262bd38
250a80a
cda051e
fa97788
502fa82
f51f6ed
f53ff0f
d3411b9
79a478b
b818e73
0180842
577db2e
9921ca0
c87f321
db82ea2
9d38466
dad9250
c6a2f77
efc9409
a4e19c5
0848102
d021157
9e6a1c3
a251bca
41fe9d6
6c149fd
f426805
fcf3d00
b56c796
2189773
686f743
71f7988
43692c8
ccacb99
faff980
b8bc8c2
4ada314
7a48962
2c6dda5
452a12a
793f0f9
c125e6e
6f858fa
b748709
d379e3f
a21e963
e04d63e
0e486a5
450d771
0b53b29
554c8d7
55c3b6f
d345a4a
c858da5
8d4c81d
f2758a8
297ec06
97401b6
4a3fb58
a35b654
690338f
2d2c069
24c7023
8748972
3f544ce
50e6539
4f4a25d
2b44ef5
d36e6fc
e4fa2cf
163e996
59a48e0
2b57a27
2a2b041
55f41d1
245cff0
2fecac6
34115c8
abe4159
a63875b
90f15a0
df52967
fd4230f
3ff3d07
17017b2
78d089b
efbd508
bd6a05e
8ded6a9
5c8cc10
5d8bff1
a8cf439
d0a4989
d9699c8
3a79a99
877d217
9826cd6
bd726f8
8e92881
918aed4
10c1484
8860b39
3a5acee
37e3208
91cb6f8
cefc0fa
31d401e
2f73f4f
00a9b80
8c18b48
9842301
0c9eb8c
095e365
ed51b8c
6a148dd
bf1798e
da3c974
3086c25
22c3ad1
77380b9
b0cd8c4
0ea65d4
241cf62
2def62b
7d29fff
03585ed
1c5fa40
f44ebc4
ff38c9e
101587b
dbd6c13
5967a22
7fb42e6
18b641b
194b5c9
5ccc99b
08bf8a6
645e3e8
13d7de7
e9d4249
4d35256
7696106
b40c109
6428663
15e5e61
7c749c9
1db978c
2166c86
e1e2781
4ec4235
a43efce
1652684
c02334b
4519054
41dee26
ba4267f
13ef21d
7d4db69
90d2551
6d2d126
2f20fd3
fe01a2f
4034c67
f86f048
73b01f4
200f18a
5b323d5
c863fd8
2c6866f
619f528
3e96f97
5061259
11ec7fe
7d84c94
7d93587
8cf1b94
5c973ad
3b2bb0a
d6fffd9
252be1d
3800745
1a3622e
1e33eb0
f2975a0
3f45f11
6484970
1193877
94f91bc
d62d1b4
24d6a56
06b5ef6
d6ee418
b8f10c7
a1cc048
503ffe6
ac74403
e272e4e
c2794dd
558c5fe
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -1409,7 +1409,7 @@ func (bc *BlockChain) writeBlockWithState(block *types.Block, receipts []*types. | |
} | ||
|
||
// Full but not archive node, do proper garbage collection | ||
triedb.Reference(root, common.Hash{}) // metadata reference to keep trie alive | ||
bc.triedb.Reference(root, common.Hash{}) // metadata reference to keep trie alive | ||
bc.triegc.Push(trieGcEntry{root, block.Header().Time}, -int64(block.NumberU64())) | ||
|
||
blockLimit := int64(block.NumberU64()) - int64(bc.cacheConfig.TriesInMemory) // only cleared if below that | ||
|
@@ -1418,28 +1418,28 @@ func (bc *BlockChain) writeBlockWithState(block *types.Block, receipts []*types. | |
if blockLimit > 0 && timeLimit > 0 { | ||
// If we exceeded our memory allowance, flush matured singleton nodes to disk | ||
var ( | ||
nodes, imgs = triedb.Size() | ||
nodes, imgs = bc.triedb.Size() | ||
limit = common.StorageSize(bc.cacheConfig.TrieDirtyLimit) * 1024 * 1024 | ||
) | ||
if nodes > limit || imgs > 4*1024*1024 { | ||
triedb.Cap(limit - ethdb.IdealBatchSize) | ||
bc.triedb.Cap(limit - ethdb.IdealBatchSize) | ||
} | ||
var prevEntry *trieGcEntry | ||
var prevNum uint64 | ||
// Garbage collect anything below our required write retention | ||
for !bc.triegc.Empty() { | ||
tmp, number := bc.triegc.Pop() | ||
triegcEntry := tmp.(trieGcEntry) | ||
if uint64(-number) > uint64(blockLimit) || triegcEntry.Timestamp > uint64(timeLimit) { | ||
bc.triegc.Push(triegcEntry, number) | ||
root, number := bc.triegc.Pop() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. our variable (unlike mainline) is not a root, but a triegc entry that has both root and timestamp.. rename "root" to triegcEntry, or something similar.. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Done |
||
if uint64(-number) > uint64(blockLimit) || root.Timestamp > uint64(timeLimit) { | ||
bc.triegc.Push(root, number) | ||
break | ||
} | ||
if prevEntry != nil { | ||
triedb.Dereference(prevEntry.Root) | ||
bc.triedb.Dereference(prevEntry.Root) | ||
} | ||
prevEntry = &triegcEntry | ||
prevEntry = &root | ||
prevNum = uint64(-number) | ||
} | ||
flushInterval := time.Duration(atomic.LoadInt64(&bc.flushInterval)) | ||
// If we exceeded out time allowance, flush an entire trie to disk | ||
if bc.gcproc > bc.cacheConfig.TrieTimeLimit && prevEntry != nil { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this should be if gcproc > flushInterval There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Alright, changed it. I think they should be the same value anyway because |
||
// If the header is missing (canonical chain behind), we're reorging a low | ||
|
@@ -1450,17 +1450,17 @@ func (bc *BlockChain) writeBlockWithState(block *types.Block, receipts []*types. | |
} else { | ||
// If we're exceeding limits but haven't reached a large enough memory gap, | ||
// warn the user that the system is becoming unstable. | ||
if chosen < bc.lastWrite+bc.cacheConfig.TriesInMemory && bc.gcproc >= 2*flushInterval { | ||
log.Info("State in memory for too long, committing", "time", bc.gcproc, "allowance", flushInterval, "optimum", float64(prevNum-bc.lastWrite)/bc.cacheConfig.TriesInMemory) | ||
if blockLimit < int64(bc.lastWrite+bc.cacheConfig.TriesInMemory) && bc.gcproc >= 2*flushInterval { | ||
log.Info("State in memory for too long, committing", "time", bc.gcproc, "allowance", flushInterval, "optimum", float64(prevNum-bc.lastWrite)/float64(bc.cacheConfig.TriesInMemory)) | ||
} | ||
// Flush an entire trie and restart the counters | ||
triedb.Commit(header.Root, true, nil) | ||
bc.triedb.Commit(header.Root, true) | ||
bc.lastWrite = prevNum | ||
bc.gcproc = 0 | ||
} | ||
} | ||
if prevEntry != nil { | ||
triedb.Dereference(prevEntry.Root) | ||
bc.triedb.Dereference(prevEntry.Root) | ||
} | ||
} | ||
return nil | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
instead of all of those - maybe we could just add omitempty to receipt's Un/MarshalJson?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@PlasmaPower ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm.. people might be expecting this from our RPC even for L1->L2 txs unfortunately
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, will leave it as-is