Tweak enum serialization to generate better LLVM IR and more compact code #77
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Hello!
I'm looking at reducing the size of some programs that use borsh, and I've noticed that deriving
BorshSerialize
on enums can sometimes trigger some pretty bad inlining from rustc/LLVM.This PR changes enum serialization from:
To:
The latter generates better LLVM IR, and avoids
writer.write_all(&variant_idx.to_le_bytes())?
from being inlined into each match branch.Here's a test case that shows the issue: https://gist.github.com/alessandrod/f192c59f6b75159733d2cb6c60a78f1b
Cargo bloat before:
Cargo bloat after: