<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, Dec 16, 2013 at 5:18 PM, Greg Clayton <span dir="ltr"><<a href="mailto:gclayton@apple.com" target="_blank">gclayton@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 class="im"><br>
On Dec 16, 2013, at 5:10 PM, David Blaikie <<a href="mailto:dblaikie@gmail.com">dblaikie@gmail.com</a>> wrote:<br>
<br>
><br>
><br>
><br>
> On Mon, Dec 16, 2013 at 4:42 PM, Adrian Prantl <<a href="mailto:aprantl@apple.com">aprantl@apple.com</a>> wrote:<br>
><br>
> On Dec 16, 2013, at 14:55, David Blaikie <<a href="mailto:dblaikie@gmail.com">dblaikie@gmail.com</a>> wrote:<br>
><br>
> ><br>
> ><br>
> ><br>
> > On Mon, Dec 16, 2013 at 2:44 PM, Adrian Prantl <<a href="mailto:aprantl@apple.com">aprantl@apple.com</a>> wrote:<br>
> > Hi Chandler and David,<br>
> ><br>
> > unfortunately it looks more like case 1. This optimization breaks several assumptions that tools in our software stack depend on.<br>
> ><br>
> > It's a fairly substantial debug info size savings that seems worth investigating whether you can keep it enabled at least in<br>
><br>
> this sentence is cut off in the middle :-)<br>
> But extrapolating from that: For (LTO) builds we still have type uniquing which gets us the same kind of improvement and more.<br>
><br>
> Sure - in the final linked debug info, but you'll still suffer a disk/build-time penalty for all that & that only applies to LTO.<br>
><br>
> I was trying to say "keep it enabled at least in some cases" - ie: look at the cases where you're having trouble with this optimization and see if a more targetted approach to addressing those particular use cases can be employed.<br>
><br>
> > - For example, it breaks dtrace, which on Darwin relies on being able to pull the (complete) CTF info (compact C type format) out of the DWARF in the .dSYM for a given module.<br>
> ><br>
> > I take it you're already using -fno-limit-debug-info for these scenarios, then? (are you using -flimit-debug-info at all?)<br>
><br>
> Currently I believe that -flimit-debug-info is the default on Darwin. I don’t know what you mean by “these scenarios”; “we" can’t anticipate what programs users may want to probe using dtrace.<br>
><br>
> Can dtrace be improved to read the rest of the debug info/can you ship debug info for the libraries in question?<br>
<br>
</div>No, dtrace uses CTF, which is an archived version of the struct/class layouts generated from the DWARF. It is the CTF tool that would be required to be updated.<br></blockquote><div><br></div><div>OK - I'm unfamiliar with these tools.</div>
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Again, how would you go about find a random type "foo" that is a declaration only? Where would you look? What executable file should one look in?<br>
</blockquote><div><br></div><div>Fair question - though I do wonder why this question isn't already an issue. If the user's code only declares a pointer to one of these types Clang (under -flimit-debug-info) only emits the declaration of that type. Or if the user forward declares the type and never includes the header with the definition, we can only emit a declaration of the type. <br>
<br>So how does this issue not already come up for you?</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im"><br>
><br>
> ><br>
> > - Kernel extensions tend to inherit from base classes that are defined in a system framework (I/O Kit works this way for example).<br>
> ><br>
> > And the library where the base class is defined isn't built with debug info as a matter of course? Is that solvable at all?<br>
><br>
> Of course — by not performing this optimization, the type info for the base class ends up in the user’s .o file, as it always used to. This is just one example to make the "user code that inherits from base classes defined in 3rd-party C++ library” scenario I mentioned yesterday more real.<br>
><br>
> I meant is it possible to solve the problem of "this library is built without debug info" - in my experience libraries generally offer a dbg variant of the library for this purpose. Is this a possible solution to your problem? Or are you unable to ship the libraries in question with appropriate debug info & must rely on the user's builds to contain sufficient info?<br>
<br>
</div>We don't ship any system libraries to external folks here at Apple, so that isn't a solution we can deal with. The kernel is "special" in that it uses all sorts of interesting approaches and special tools for its build and it isn't going to change soon and/or quickly. We can work on it, but it will take time.<br>
</blockquote><div><br></div><div>OK - so are you suggesting making a special case change so that kernel modules would build without this debug info space optimization on? It would seem a pity (but hey, it's your platform) to suffer 20% debug info size increase (yes, in non-LTO, non-linked debug info cases) for other scenarios just because this particularly esoteric one has an issue.</div>
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im"><br>
><br>
> (notice that I first discovered this GCC optimization looking at basic_ifstream - the stream base is polymorphic and has an out-of-line vtable - this optimization allows code using C++ streams to avoid emitting /tons/ of stream related debug info and rely on it being present in the debug build of the standard library)<br>
<br>
</div>I can believe that there are some serious savings with this enabled.<br>
<br>
Given that we have no good solution for finding the one true definition for a type besides "find all debug info files for all shared libraries and parse all that debug info until you can find a definition", it is hard to justify this extra cost.</blockquote>
<div><br>I don't really understand why you don't already have this problem, though... especially if you're defaulting to -flimit-debug-info. Maybe not for this particular type that you're encountering a problem with today/with my optimization, but for many other types I imagine you would've seen declaration-only debug info quite a bit.<br>
<br>- David </div></div></div></div>