-
Notifications
You must be signed in to change notification settings - Fork 958
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
Rewrite recursive cfg traversal to non-recursive #495
Conversation
d0e7aee
to
09c7bbe
Compare
(the initial version had a bad rebase) |
Thank you for the PR! 👍 I will review it and will let you know. |
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 have included several comments concerning the code. Most importantly, we will need to figure out why some of the regression tests started failing.
Hey Petr, i'll fix the compile failure on 4.9. As for the regtests, how do i run those? If there is a way i can run the failing tests, i'm happy to debug it. If there's no way to run it, i'll start the simple way by printing out the CFG traversal nodes on large testcases and seeing if they differ. |
Forget it, found the other regression test repo. |
Great 👍 Yes, all instructions are here. Let me know if you have any issues with the setup or execution of the tests. You can then run one of the failing tests via
The outputs from the test will then be in
|
I know what's wrong. I mixed too much logic into the iterator version. |
09c7bbe
to
1484963
Compare
I've updated it to the latest version of the patch, which just moves the logic into a (local) depth first iterator to make it easier to debug. I have not finished making all requested changes, but wanted to put a working version here. It passes the regression test the other one failed. I've tested this version by instrumenting pre/post versions of the compiler to print traversals and ensuring the same traversals occur in the same order (using https://gist.github.com/39013640d89f08ec285a04e68d7197bf for the pre). There are a few spurious differences in traversals i am tracking down , but they don't affect generated code AFAICT. Some of them are caused by the fact that functions in callinfo/et al are sorted in pointer order so the overall processing order of some things is not deterministic. I know y'all do SCC finding, but you store the results in sets with only a pointer sort order. So you are losing the topo ordering of SCCs and the ordering of functions in the SCC. Even with disabling ASLR, this means, for example, computeFuncInfoDefinition is not running on functions in the same order from run to run. This is easy to see by printing the function names as they are processed. IMHO, the SCC sets should be vectors so they maintain order. Tarjan will never try to add duplicates anyway. |
Hi Daniel. We are planning to release a new version of RetDec. It would be cool if this PR could be part of that release. Can you please summarize the current status of this PR? |
Sure. I tested the updated version before I had to run away and it seems to
work fine for regression tests/etc. It is, AFAICT, functionally correct at
this point. I haven't had a chance to see if there are comment/other
requested changes. and unfortunately i don't think i'll get back to it for
a while :(
(I had a bunch of free time and now i suddenly don't)
…On Tue, Mar 5, 2019 at 10:46 PM Petr Zemek ***@***.***> wrote:
Hi Daniel. We are planning to release a new version of RetDec. It would be
cool if this PR could be part of that release. Can you please summarize the
current status of this PR?
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#495 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAT0a4ZygJ33PiiqkUwQmi4vuQLc_Hfuks5vT2QzgaJpZM4aqB6R>
.
|
That's alright. All our tests pass. Is it OK if I merge the branch into |
It is perfectly fine by me!
…On Wed, Mar 6, 2019 at 10:21 PM Petr Zemek ***@***.***> wrote:
That's alright. All our tests pass. Is it OK if I merge the branch into master?
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub, or mute the thread.
|
Great. Thank you for the valuable contribution! 👍 |
This removes the rest of the stack usage in the forward CFG traversal.
On very large BB testcases i have (millions of BBs), this reduces stack usage to essentially nothing.
This implementation is also somewhat faster for other reasons:
The recursive implementation will touch a lot more nodes due to how it recurses - it will touch each node, start processing the successors, and then recurse on itself (which then processes successors). Depending on CFG structure, when it pops back up, it will now touch a whole bunch of successors that it already processed (it then later discovers it already checked them).
This is fairly bad cache behavior, etc.
This implementation will not, they are cut off before any other processing is done.
It is a minor thing for most CFGs, of course.
I have not updated the reverse traversal. In practice, the next step really should be to turn this into a generic depth first iterator rather than duplicate the code.
The code is based on code i wrote for LLVM's depth first iterator (http://llvm.org/doxygen/DepthFirstIterator_8h_source.html), and meant to be able to be turned into one fairly easily.
I just don't have time at the moment to do it :)