-
Notifications
You must be signed in to change notification settings - Fork 514
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
Migrate to Construct 2.10 take 2 #548
base: main
Are you sure you want to change the base?
Conversation
Move away from an internal copy of Construct to the latest version in order to support DWARF v5 required data types.
Thanks for working on this. I'm still pondering whether it's worth it, given the performance regression. The upside doesn't seem too large from the original description in #477 @sevaa what additional functionality does this enable that we couldn't achieve without upgrading? What are the latest performance numbers (I know you posted some in #477, but since this PR supersedes it, it's worth having here for completeness) |
Edited. There is no additional functionality that we could not achieve without upgrading :) I don't have a problem slapping together a constructs based parser for Int24, if needed. I don't know if SupremeMortal has a binary with those or it's just striving for perfection. I don't recall off the top of my head where in the DWARF standard is this datatype needed. The big promise of construct 2.10 is compile(). From what I've read, compile() mostly shines on pypy as opposed to the vanilla CPython. On CPython it's a mixed blessing - I've seen compiling slowing things down. There is no magic to compile, it merely eliminates the overhead of dispatching (function calls, object creation, dictionary lookups, etc.) - the parsing logic per se is the same. We might get more mileage out of leveraging the |
Thanks for the perspective. I remain unconvinced that this is worthwhile at this time. Performance is very important to some users of pyelftools, and while it's not exactly fast - making it even slower doesn't sound too appealing without a very good reason for the change. |
Okay then, kill both PRs, I won't cry :) This exercise did give me some ideas on possible performance enhancement though. |
Placing this on hold and closed the older PR. |
Found the spec and a use case for 3 byte ints: DWARFv5 contains form |
@eliben I was able to reduce the time of the DIE-only scroll-through by 28%, of the scroll-through with follow-up by 34%. I made the following enhancements, in the rough order of effect:
No breaking changes to the API. Could poke some more, or could send a PR. |
Sounds great -- looking forward to the PR. Please include the benchmarking harness too -- it's OK to split to multiple PRs if that makes sense |
Move away from an internal copy of Construct to the latest version in order to support DWARF v5 required data types.
Supersedes #477. Performance wise, we could do better, but I'm afraid for that we'd need to start monkeypatching or proper-patching constructs. Compilation is the biggest road to parsing speedup, but a ton of parser features that we use don't support compiling.
In the current iteration, on the performance test of firehose parsing of DWARF from memory, the decrease in performance compared to the main branch, is ~30%. That's not the best result that I've got as I was fiddling with settings (mostly compile vs. no compile); in the best test result, the performance decrease was 15%.
The original PR was mostly motivated by built-in support for 24 bit ints. To that I might add that construct 2.10 has built-in support for ULEB128 (but not SLEB128) and some miscellanea like
StreamOffset
. That said, I can see that there is still some slack for performance improvement - if one is willing to mess with construct internals.On the code style, with construct 2.10, the code becomes somewhat cleaner - e. g. there is no longer a notion that every parser object needs a name just in case it's included in a larger struct, and the premade parsers (the kind that is built in structs) are objects, not callables.