Improve unwind information chunking and optimise unwind info #4
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.
Before we were splitting only on function boundaries, but this is not necessary, we can split anywhere as long as the end of function markers are in place for every single function that has a gap with the next function (sorted by PC), as well as the last function.
By doing this, we not only use the unwind shard space more efficiently, but also we support huge functions better, and have to do less work, while making the code more readable.
The cases that we have to handle (just showing PCs and generated chunk ranges):
[10, 20, 30]
[10, 20, 30]
Additionally, this commit also does some basic optimisations w.r.t. the unwind information, we remove redundant end of function markers as well as unwind rows that are repeated.
Test Plan
Tested for hours on my box and simulated worst case scenarios with very small unwind shards (few hundreds of items) without issues. Also wrote some exhaustive checker for these conditions, but the code isn't ready to be added yet, will submit a separate PR where all this logic is abstracted and the tests are added.