<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 27, 2015 at 11:49 AM, Aboud, Amjad <span dir="ltr"><<a href="mailto:amjad.aboud@intel.com" target="_blank">amjad.aboud@intel.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div lang="EN-US" link="blue" vlink="purple">
<div>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">This would work just fine for function static variable.<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">In fact, this was my first thought when I tried to fix this specific problem.<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">But it will not solve the other two cases, the typedef and the record.<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Do you have any though on how to use same design to solve the type cases?</span></p></div></div></blockquote><div><br>It might be worth just saying that these types must be placed in the retained types list. Then we could do a walk over the retained types list, look for any type whose scope is a lexical block or function, and stuff those in the same map as the imported entities (or a separate map, or make the imported entities map have a struct value with separate lists of each kind of thing - I'm not too fussed) and generalize the scoped imported entities handling logic to cope with these toher things too.<br><br>This has the side effect of emitting unused local types, but that seems plausibly correct/useful. It's not like the type can be used from anywhere else (unlikely non-local types - which we can assume will be used from elsewhere if they're needed at all). I suppose the frontend could check if the type was unused and not emit it at all - actually it'll probably do that already... soo... fine.<br> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div lang="EN-US" link="blue" vlink="purple"><div><p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u><u></u></span></p>
<p class="MsoNormal"><span style="color:rgb(31,73,125);font-family:Calibri,sans-serif;font-size:11pt">For example:</span><br></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">int foo(bool b, int x) {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> if (b) {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> typedef short A;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> A a = x;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> return a;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> } else {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> typedef float A;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> A a = x;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> return a;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> }<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">}<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Regards,<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Amjad<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif"">From:</span></b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif""> David Blaikie [mailto:<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>]
<br>
<b>Sent:</b> Wednesday, May 27, 2015 21:42<br>
<b>To:</b> Aboud, Amjad<br>
<b>Cc:</b> <a href="mailto:reviews%2BD9960%2Bpublic%2B41c324f590718ccc@reviews.llvm.org" target="_blank">reviews+D9960+public+41c324f590718ccc@reviews.llvm.org</a>; Eric Christopher; Benjamin Kramer; <a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.edu</a>; Robinson, Paul</span></p><div><div class="h5"><br>
<b>Subject:</b> Re: [PATCH] Refactor debug info lexical block generation<u></u><u></u></div></div><p></p><div><div class="h5">
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<p class="MsoNormal">On Wed, May 27, 2015 at 11:32 AM, Aboud, Amjad <<a href="mailto:amjad.aboud@intel.com" target="_blank">amjad.aboud@intel.com</a>> wrote:<u></u><u></u></p>
<div>
<div>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">I am not sure what is imported entry is, and if it could be located inside a lexical block.</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">When you create an imported entry you call the “getOrCreateContextDIE”, this function will check
for, Compile-Unit, File, Namespace, Type, Subprogram context.</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">If none match, it calls “getDIE” function:</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal" style="text-autospace:none">
<span style="font-size:9.5pt;font-family:Consolas">DIE *DwarfUnit::getDIE(<span style="color:blue">const</span> DINode *D)
<span style="color:blue">const</span> {</span><u></u><u></u></p>
<p class="MsoNormal" style="text-autospace:none">
<span style="font-size:9.5pt;font-family:Consolas"> <span style="color:blue">if</span> (isShareableAcrossCUs(D))</span><u></u><u></u></p>
<p class="MsoNormal" style="text-autospace:none">
<span style="font-size:9.5pt;font-family:Consolas"> <span style="color:blue">return</span> DU->getDIE(D);</span><u></u><u></u></p>
<p class="MsoNormal" style="text-autospace:none">
<span style="font-size:9.5pt;font-family:Consolas"> <span style="color:blue">return</span> MDNodeToDieMap.lookup(D);</span><u></u><u></u></p>
<p class="MsoNormal" style="text-autospace:none">
<span style="font-size:9.5pt;font-family:Consolas">}</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Maybe imported entries fit with the first condition check of “</span><span style="font-size:9.5pt;font-family:Consolas">isShareableAcrossCUs</span><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">”,
but the function static variables will have a lexical block context and when we will look for this context in the “</span><span style="font-size:9.5pt;font-family:Consolas">MDNodeToDieMap</span><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">”
map it will not be there, because we do not map lexical block MDNode to lexical block DIE.</span><u></u><u></u></p>
</div>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><br>
Take a look in DwarfCompileUnit::cosntructScopeDIE, around half way through, you'll find this code:<u></u><u></u></p>
<div>
<p class="MsoNormal"> unsigned ChildScopeCount;<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"> // We create children here when we know the scope DIE is not going to be<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> // null and the children will be added to the scope DIE.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> createScopeChildrenDIE(Scope, Children, &ChildScopeCount);<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"> // Skip imported directives in gmlt-like data.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> if (!includeMinimalInlineScopes()) {<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> // There is no need to emit empty lexical block DIE.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> for (const auto &E : DD->findImportedEntitiesForScope(DS))<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> Children.push_back(<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> constructImportedEntityDIE(cast<DIImportedEntity>(E.second)));<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> }<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><br>
<<It seems to me like the code there that the logic for static variables should go here too - the same way imported entities are dealt with. Then, if we have any static variables, imported entities, we create this scope - otherwise we put it in the parent>> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> // If there are only other scopes as children, put them directly in the<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> // parent instead, as this scope would serve no purpose.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> if (Children.size() == ChildScopeCount) {<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> FinalChildren.insert(FinalChildren.end(),<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> std::make_move_iterator(Children.begin()),<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> std::make_move_iterator(Children.end()));<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> return;<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> }<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> ScopeDIE = constructLexicalScopeDIE(Scope);<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"> assert(ScopeDIE && "Scope DIE should not be null.");<br>
<br>
<u></u><u></u></p>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Also, right now, we decide if to create the lexical block DIE or not depends on the local variable
children only, as the function static variables DIE and the type DIEs were not attached yet to the lexical block DIE.</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">This, is why I also suggest to create all lexical blocks at first and once all its children are created,
we can revisit this lexical block FIE and decide if it worth collapsing with parent.</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Regards,</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Amjad</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif"">From:</span></b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif""> David Blaikie [mailto:<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>]
<br>
<b>Sent:</b> Wednesday, May 27, 2015 21:14<br>
<b>To:</b> <a href="mailto:reviews%2BD9960%2Bpublic%2B41c324f590718ccc@reviews.llvm.org" target="_blank">
reviews+D9960+public+41c324f590718ccc@reviews.llvm.org</a><br>
<b>Cc:</b> Aboud, Amjad; Eric Christopher; Benjamin Kramer; <a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">
llvm-commits@cs.uiuc.edu</a>; Robinson, Paul<br>
<b>Subject:</b> Re: [PATCH] Refactor debug info lexical block generation</span><u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
<div>
<p class="MsoNormal">Perhaps it'd be good to have a general design discussion here, rather than in the form of line-by-line code review. A few broad issues have been brought up by both Paul and Frederic
that sound reasonable to me, though I've not looked at the code in detail yet.<u></u><u></u></p>
<div>
<div>
<p class="MsoNormal"><br>
<br>
Is there any reason this wouldn't be implemented the same way as the imported entity work? Where we check for imported entities at scope construction time to decide whether to create that scope or not.<u></u><u></u></p>
</div>
</div>
</div>
<div>
<div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
<div>
<p class="MsoNormal">On Sun, May 24, 2015 at 9:00 AM, Amjad Aboud <<a href="mailto:amjad.aboud@intel.com" target="_blank">amjad.aboud@intel.com</a>> wrote:<u></u><u></u></p>
<p class="MsoNormal">Hi echristo, bkramer, dblaikie,<br>
<br>
This patch is needed for resolving Bug 19238.<br>
It is the first part which will be followed by D9758.<br>
<br>
The idea is to create all debug info lexical block DIEs and add them to the DIScope->DIE map.<br>
Latter, just before emitting the DIEs, we will search the DIE tree and collapse all redundant (useless) DIE lexical blocks.<br>
<br>
REPOSITORY<br>
rL LLVM<br>
<br>
<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__reviews.llvm.org_D9960&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=ZeyoBysEoLqCrU8KabH45F_3gt4IIjl-Ky5Lhbrqaps&s=9-LedayoW3J6PIv2Y6p2RPNJ8r1SmRZRO6I6FG6rsJw&e=" target="_blank">http://reviews.llvm.org/D9960</a><br>
<br>
Files:<br>
include/llvm/CodeGen/DIE.h<br>
lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp<br>
lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
lib/CodeGen/AsmPrinter/DwarfDebug.h<br>
test/DebugInfo/useless_lexical_scope.ll<br>
<br>
EMAIL PREFERENCES<br>
<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__reviews.llvm.org_settings_panel_emailpreferences_&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=ZeyoBysEoLqCrU8KabH45F_3gt4IIjl-Ky5Lhbrqaps&s=pKaZokqizIexuFeLtVK0C2Qm_QESvDVxTFIyjcK8ID4&e=" target="_blank">
http://reviews.llvm.org/settings/panel/emailpreferences/</a><u></u><u></u></p>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
</div>
</div>
</div>
<p>---------------------------------------------------------------------<br>
Intel Israel (74) Limited<u></u><u></u></p>
<p>This e-mail and any attachments may contain confidential material for<br>
the sole use of the intended recipient(s). Any review or distribution<br>
by others is strictly prohibited. If you are not the intended<br>
recipient, please contact the sender and delete all copies.<u></u><u></u></p>
</div>
</blockquote>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
</div>
</div></div></div><div><div class="h5">
<p>---------------------------------------------------------------------<br>
Intel Israel (74) Limited</p>
<p>This e-mail and any attachments may contain confidential material for<br>
the sole use of the intended recipient(s). Any review or distribution<br>
by others is strictly prohibited. If you are not the intended<br>
recipient, please contact the sender and delete all copies.</p></div></div></div>
</blockquote></div><br></div></div>