BTW, the reason I stopped responding to this thread is not because I solved the problem, but because I simply gave up and decided to work on other things for a while since I was making no progress. Having finished those other things (the stack crawler, for one), I'm hoping that time and a fresh start will yield better results. Unfortunately after about a day spent reviewing old llvm-dev threads and trying different permutations of calls to DIFactory, I have not discovered anything that I didn't already know.<div>
<br></div><div>With respect to the suggestion of building my own copy of dwarfdump (so that I could run it under gdb and see where it breaks), I never did get it to compile and run on OS X, since it requires ELF headers and libs. I thought about doing the same thing under Linux, however dwarfdump doesn't segfault on Linux when I feed it my LLVM-generated binary. (It does report errors, however: "dwarf_srclines: DW_DLE_ATTR_FORM_BAD". The weird part is that it does this even when I completely disable the code that calls IRBuilder.SetCurrentDebugLocation()).</div>
<div><br></div><div>As per usual, this is with a recent LLVM head (like about a week old).<br><div><br><div class="gmail_quote">On Tue, Sep 7, 2010 at 9:21 AM, Devang Patel <span dir="ltr"><<a href="mailto:dpatel@apple.com">dpatel@apple.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;"><div style="word-wrap:break-word"><div class="im"><br><div><div>On Sep 7, 2010, at 9:11 AM, Renato Golin wrote:</div>
<br>
<blockquote type="cite"><div>On 7 September 2010 16:49, Devang Patel <<a href="mailto:dpatel@apple.com" target="_blank">dpatel@apple.com</a>> wrote:<br><blockquote type="cite">Your recent changes mentioned below would change correctness of debug info,<br>
</blockquote><blockquote type="cite">but it would unlikely to impact structure of DWARF generated. And somehow,<br></blockquote><blockquote type="cite">this structure is invalid in your case.<br></blockquote><br>I was hoping for a quick-fix on the assumptions of DwarfDebug about<br>
Subprograms' MDNodes, but it might be anywhere.<br><br>Reducing the test case is the best solution, but it might not be easy.<br><br>Validating the MDNodes in DIFactory (or anywhere before DwarfDebug)<br>would be a good step to ensure IR consistency and isolate problems.<br>
Unfortunately, it is the kind of thing that is not fundamental to get<br>things working, so it always gets left behind... ;)<br><font color="#000000"><font color="#144FAE"><br></font></font></div></blockquote><br></div></div>
<div>I understand your point and certainly acknowledge need for better documentation.</div><div><br></div><div>There are couple of wrinkles to note here</div><div>- While constructing IR using DIFactory you are not seeing entire picture. When you see a declaration you're not sure whether you'll see matching def. or not. When you build a inlined subprogram, you don't know whether you'll see a out of line definition of this function or not. etc...</div>
<div>- DwarfDebug must be able to handle malformed debug info gracefully and make best out of whatever is fed. This is because, optimizer may have chewed on IR mercilessly and optimizer must not be influenced by presence of encoded debug info in IR.</div>
<div><br></div><div>-</div><div>Devang</div></div></blockquote></div><br><br clear="all"><br>-- <br>-- Talin<br>
</div></div>