<div dir="ltr"><div class="gmail_extra">Separate reply as the topics seem to have very little in common...</div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Oct 24, 2014 at 4:16 PM, Duncan P. N. Exon Smith <span dir="ltr"><<a href="mailto:dexonsmith@apple.com" target="_blank">dexonsmith@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 id=":1pq" class="a3s" style="overflow:hidden">Making debug info assembly readable and writable<br>
================================================<br>
<br>
Moreover, we're now in a place where it's trivial to express the<br>
"context" pointer structurally. Here's the same debug info as above,<br>
using syntactic sugar to fill the "context" pointers:<br></div></blockquote><div><br></div><div>FWIW, this doesn't make a huge difference to me in terms of readability other than avoiding ordering problems....</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div id=":1pq" class="a3s" style="overflow:hidden">Bike sheds to paint<br>
===================<br>
<br>
1. Should we trim some boilerplate? E.g., it would be trivial to<br>
change:<br>
<br>
!6 = metadata MDLocation(line: 43, column: 7, scope: !4)<br>
<br>
to:<br>
<br>
!6 = MDLocation(line: 43, column: 7, scope: !4)<br>
<br>
This would not complicate `LLParser`. Thoughts?<br></div></blockquote><div><br></div><div>If it is metadata, it should use 'metadata'. The boiler plate isn't the problem here IMO.</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div id=":1pq" class="a3s" style="overflow:hidden">
<br>
2. Which of the two "end goal" syntaxes is better: flat, or<br>
hierarchical? Better for what? Why?</div></blockquote></div><br>Some points that might simplify things:</div><div class="gmail_extra"><br></div><div class="gmail_extra">- The largest overhead left for humans (once the fields are named and semantically de-obfuscated) are IMO: lack of symbolic constants from DWARF and the lack of locality with the referencing instruction.</div><div class="gmail_extra"><br></div><div class="gmail_extra">- I think there is likely a better inflection point in the tradeoff space between normalization and duplication. For example, I would be happy to see line and column repeated for every instruction *on* the instruction. Every time you save the reader an indirection through some "!019243" (which is totally unremarkable and hard to track) you win unless the size of the input is greatly changed.</div><div class="gmail_extra"><br></div><div class="gmail_extra">- The conflict between humans and FileCheck is not as bad as I think you imagine. We have well established techniques for handling cases where what the IR contains isn't useful for FileCheck, and/or what would be useful for FileCheck is terribly cumbersome to write. We have the printer inject comments which can then be used in FileCheck. I think the same technique would tremendously help both human *readers* (but not writers) and FileCheck with location information. My suggestion: print out a comment line of the form "# location: ..." for all the indirected information every time that indirected information changes, and printed *before* the first instruction with the new indirected information. If both line or column are attached directly to the instruction, this gives just a comment at the start of each function and after each file change within the function body. Enough to form reasonably bracketed FileCheck but not overly verbose I suspect.</div><div class="gmail_extra"><br></div><div class="gmail_extra">- Once you've had an indirection from the actual IR structure to the debuginfo structure embedded down in the metadata, I agree that a structural form looks better.</div><div class="gmail_extra"><br></div><div class="gmail_extra">Hope these thoughts help formulate even better looking IR. Not specifically trying to change any part of this patch or any other single patch.</div></div>