-
Notifications
You must be signed in to change notification settings - Fork 66
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
VKT state migration optimized methods & lower LeafNode memory pressure #338
base: master
Are you sure you want to change the base?
Conversation
if i >= NodeWidth-1 { | ||
if i >= NodeWidth { |
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.
I forgot to mention: I found this bug the hard way while doing the helpers and running stuff converting trees...
I think we got lucky to not see this bug happening before.
a32ba28
to
5126adb
Compare
ret[i] = LeafNode{ | ||
values: nv.Values, | ||
stem: nv.Stem, | ||
c1: Generator(), | ||
c2: Generator(), | ||
} | ||
|
||
var c1poly, c2poly [NodeWidth]Fr | ||
|
||
valsslice := make([][]byte, NodeWidth) | ||
for idx := range nv.Values { | ||
valsslice[idx] = nv.Values[idx] | ||
} | ||
|
||
fillSuffixTreePoly(c1poly[:], valsslice[:NodeWidth/2]) | ||
ret[i].c1 = cfg.CommitToPoly(c1poly[:], 0) | ||
fillSuffixTreePoly(c2poly[:], valsslice[NodeWidth/2:]) | ||
ret[i].c2 = cfg.CommitToPoly(c2poly[:], 0) |
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.
Now that we merged the other emptyCode cached PR, we can exploit the same here. Maybe I can extract this code section to be shared between both.
For now, it won't make a big difference in the conversion since we're bottleneck by compactions.
I prefer to merge this PR as is with our correctness guarantees, and I'll do a PR right after with only that refactor.
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.
Looks good overall, but isn't using a map slowing things down, especially the serialization part?
This change was optimized for the tree conversion. In that case, we have a lot of memory pressure by having 256-slices where, most of the nodes, only use a few slots. The more efficient the RAM use, the more batching we can do. For replay benchmark or "usual" run of block execution, that memory waste isn't that big since we don't have that many nodes in memory. In that case, using a map is paying some CPU cost for the cryptographic hash function maybe unnecessarily. I'd say is I change I'd ideally want to keep for the conversion code runs, and maybe not for master. To mention some numbers, the |
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
… tree building Signed-off-by: Ignacio Hagopian <[email protected]>
Signed-off-by: Ignacio Hagopian <[email protected]>
0ebfd85
to
1604357
Compare
Marking this PR This PR is complete and works for a full tree conversion, but now we're also exploring the overlay tree conversion in parallel. |
This PR contains the following:
conversion.go
file with specifically crafted methods to supportgeth
VKT state migration subcommand.LeafNodes
optimized for the conversion case where spare 256 slices create a lot of memory pressure for the VKT conversion. This might be beneficial too for "daily" usage, but I doubt it might be entirely useful for that case.I preferred to do some heavy commenting in the code for future readers, but it will also serve as PR comments.
For context, see gballet/go-ethereum#196.
This PR is reviewable and mergable, but let's hold it open for a bit until we fully understand implications/results.