-
Notifications
You must be signed in to change notification settings - Fork 4
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
Migrating from Chibicc #1
Comments
For 1. 2.
For 3. I think I can simplify the layout a bit |
Lines 3039 to 3041 in 85ec382
The assignment node store evaluation result into the temporary lvar, then later place_stack_args() place_reg_args() copy the stored results into calling convention specified places.
You can drop the assign node and make dummy Obj*s that don't allocate lvar space if the backend have better solutions. |
Great, thank you very much for the information and the new commit. I try to refactor my code generators accordingly. |
Meanwhile I was able to integrate the mentioned commit and adapt my code (https://github.com/rochus-keller/EiGen/tree/widcc); I currently test with the nolib test cases and still get a few segfaults and code generator asserts which I have to investigate; so I assume that I haven't yet properly considered all of your design changes. May I ask whether and where you allocate an extra parameter in case of struct/union function returns? I also haven't understood why you need an extra list for param_promoted and how it relates to the param_next list. |
The segfaults seem to be associated with gotos and switch cases. As it seem, I would have to invest quite a lot of time in debugging, which is too much for me at the moment. I will therefore continue with Libfirm for the time being and come back to the widcc branch later. |
The pointer is saved on stack space without making an extra parameter Obj*: Lines 1628 to 1634 in a0bb010
Because return struct pointer being the first parameter is x86 sys-V specific, I believe this makes the frontend more platform-agnostic.
It's for old style functions, because their arguments are always default-promoted. The calling convention use default-promoted types; and callee cast received parameter from promoted type back to locally declared types.
I'd love to see it maintained up-to-date, at least not failing on python versions (bit funny for a c99 project). |
Thanks for the information. Meanwhile I was able to build my Awfy reference project with cparser and run benchmarks with different optimization levels. Here are the detailed results. The executable generated by cparser 1.22.1 -O2 is 8% slower than the one generated with gcc 4.8 -O2, but the build time with cparser is 4.3 times slower than with gcc. In the unoptimized case the executable generated with cparser is 36% faster (!) than the one generated with gcc, but the build time with cparser is still 3.7 times slower than with gcc. I already run a subset of Awfy with my chibicc version with Eigen backend (which does no optimization at all) and found that the generated executable is 3 to 4 times slower than the unoptimized gcc generated executable. I will try to build the Boem GC with my chibicc version and then run the full Awfy to enable fair comparison.
I was able to build it by using the last commit of libfirm before they switched to Python 3, just using Python 2 instead. I agree that it is pretty silly to add a Python dependency to the C compiler; there is actually also a Perl dependency to generate parts of the backend code. |
Just had a look at Open64 (https://en.wikipedia.org/wiki/Open64); apparently they used GCC as a frontend, so it's not interesting for me (GCC is a monster). |
Meanwhile I managed to integrate the Boem gc and run the full awfy. The detail results are in the referenced report. The chibicc/ecc generated code runs 3.5 times slower than the executable generated from the same code using GCC -O2. Maybe you want to run performance measurements yourself using widcc. Just in case, here is the source code. When you run the resulting executable, a report is printed to the console. |
It's... not unexpected, there are tons of dirty hacks in chibicc just to do correct things the simplest way, (I follow that direction in widcc, and only patched some out in slimcc), it's kind of a "so I'm doing this in one way, that one way must account for the worst-case, forgo the others" attitude, for example (num += 7) is strictly worse than (num = num + 7) because the former introduced an extra temporary just to account for the case that the operands may have side effect (transforming to (a = a + b) would evaluate "a" twice), introducing push-pop nodes in AST would help, but in that philosophy that's considered unnecessary complexity. And there's the volatile thing, chibicc omits the |
The Type, Obj and Node data structures seem to have a pretty different semantics in widcc than in chibicc.
What is the correct way to :
The text was updated successfully, but these errors were encountered: