<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Apr 24, 2015 at 6:58 AM, Sergey Dmitrouk <span dir="ltr"><<a href="mailto:sdmitrouk@accesssoftek.com" target="_blank">sdmitrouk@accesssoftek.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi,<br>
<br>
NOTE: there is an attached patch, but it's to show how it can be achieved not<br>
NOTE: for review, that's why the message is not in llvm-commits.  I'd like to<br>
NOTE: get general opinion on the change.<br>
<br>
I've been trying to fix PR13269 (<a href="https://llvm.org/bugs/show_bug.cgi?id=13269" target="_blank">https://llvm.org/bugs/show_bug.cgi?id=13269</a>)<br>
in <a href="http://reviews.llvm.org/D9084" target="_blank">http://reviews.llvm.org/D9084</a> as that issue stood in the way of getting<br>
correct debug locations.  With those changes applied it is better in general,<br>
but for -O0 flag debug locations are still a mess as FastISel is used for<br>
generating most of code and it doesn't make use of additional information from<br>
SDNodes.<br>
<br>
FastISel resets debug locations on materializing constants (see<br>
<a href="http://reviews.llvm.org/rL108302" target="_blank">http://reviews.llvm.org/rL108302</a>), which is a workaround for issue created by<br>
FastISel by eliminating redundancy for constant emission as it implies<br>
instruction reordering and basically shuffled order of debug locations.<br>
<br>
Workaround from r108302 mentioned above fails in the way that some instructions<br>
are assigned debug locations of completely unrelated code lines (see attached<br>
"bad" files right after prologue).<br>
<br>
Not resetting debug locations of instructions for constants partially fixes it<br>
although leads to worse debugging experience, but still some auxiliary code like<br>
that for register spilling will be marked with almost random debug locations.<br>
<br>
The best (in the sense of "most readable" and "easy to debug") assembly is<br>
produced with disabled local value optimization and intact debug locations (see<br>
"good" files in the attachment).<br>
<br>
I'd like to propose adding a way to produce this "debuggable" assembly on<br>
request via additional option in Clang.  It could be enabled on -g3 or maybe we<br>
could introduce -g4, although -g2 and -g3 currently seem to be equivalent to<br>
-g (-g1).  Or some other way if anyone has better idea.<br></blockquote><div><br>Having a debug mode that changes the object code is a pretty hard line we haven't crossed yet. There's been some mention of -Og which would optimize for debuggability, which would be totally fine to affect codegen, but I don't know if this change would fit there either.<br><br>It'd be best to try to find a solution that doesn't adversely affect code generation. Paul's suggestion (or something that produces the equivalent behavior - essentially attribute the constant manifesting instructions to whatever the first debug-located instruction is in the basic block) is one option. Another would be to change the way these constants are emitted, sinking them down at least to their first use, and attributing them to that use. I haven't looked at the code enough to know how this would work/be implemented.<br><br> - David<br> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
As attached patch for LLVM demonstrates, this is quite easy to achieve.<br>
<br>
Best regards,<br>
Sergey<br>
<br>_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
<br></blockquote></div><br></div></div>