<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 6, 2015 at 2:25 PM, Adrian Prantl <span dir="ltr"><<a href="mailto:aprantl@apple.com" target="_blank">aprantl@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"><br><div><span class=""><blockquote type="cite"><div>On May 5, 2015, at 1:23 PM, David Blaikie <<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>> wrote:</div><br><div><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, May 5, 2015 at 11:52 AM, Adrian Prantl <span dir="ltr"><<a href="mailto:aprantl@apple.com" target="_blank">aprantl@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"><br><div><span><blockquote type="cite"><div>On May 5, 2015, at 9:42 AM, David Blaikie <<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>> wrote:</div><br><div><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, May 5, 2015 at 8:35 AM, Adrian Prantl <span dir="ltr"><<a href="mailto:aprantl@apple.com" target="_blank">aprantl@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">David, I’m not entirely sure if you are ok with the naming of the field as is.. is this good to commit from your side?<br></blockquote><div><br>It's a bit generic/misleading given that for the common case of plain Fission the DWO ID is generated based on the DWARF in the backend, so it doesn't make sense to carry it as part of the metadata because it cannot be known then.<br><br>What's the particular part of the module debug info this will be used for? Your comment says it's specifically for the skeleton side (so we'll take the module ID in the frontend and emit a skeleton CU into the metadata)? What about the concrete side for the module's debug info? (it'll need the same dwo ID)<br></div></div></div></div></div></blockquote><div><br></div></span><div>I casually mentioned that in one of the emails in the other thread; the idea is that when emitting a clang module the backend computes the regular DWARF DWOId for it. When emitting an external type reference, the frontend is using libDebugInfo to extract the DWOId from the module and emits a skeleton CU with pcm filename and DWOId.</div></div></div></blockquote><div><br>That seems a bit heavy... I thought we discussed with Richard Smith that the module has an actual identifier we could use here?</div></div></div></div></div></blockquote><div><br></div></span><div>I realize now that I haven't communicated this problem back to the list after discovering it, and I apologize for that: It is true that each type has a unique TypeId in the module,</div></div></div></blockquote><div><br>I don't think I was suggesting using a module based type id - I figured we'd use the type IDs that type units already use (a hash of the fully qualified name - same as the type uniquing in debug info metadata that was implemented years ago (well the type uniquing uses the mangled name itself - I just hashed that to create the type identifier for the comdat section and type signature for type units))<br><br>In any case, I wasn't asking about the type identifier, I was asking about the module identifier (the DWO ID).<br><br> </div><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><div> but this is just a integer counter that is not necessarily stable across rebuilds. With modules becoming more deterministic, an id should survive a rebuild of the module, but if the header file the module is built with is altered in any way, the ids could be shuffled. It is more resilient (but still fast enough) to look up a type by decl context + name.</div><span class="HOEnZb"><font color="#888888"><div><br></div><div>-- adrian</div></font></span><div><div class="h5"><br><blockquote type="cite"><div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><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><span><blockquote type="cite"><div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div>While I'm all for incremental development, a little context of the path you've got in mind may be helpful.<br></div></div></div></div></div></blockquote><div><br></div></span>Right, the examples in cfe-dev were always DWARF and never showed the IR:</div><div>A skeleton CU emitted by the frontend would be represented as a</div><div>  !0 = DICompileUnit(file: MDFile(“/path/to”, “module.pcm”), dwoId: ABCD1234)</div><div>and is emitted as a compile_unit with an AT_dwo_name and an AT_dwo_id by the backend.</div></div></blockquote><div><br>OK.<br> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><span><font color="#888888"><div><br></div></font></span><div><span><font color="#888888">-- adrian</font></span><div><div><br><blockquote type="cite"><div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div><br>- David<br> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<span><font color="#888888"><br>
-- adrian<br>
</font></span><div><div><br>
> On May 4, 2015, at 9:04 PM, Duncan P. N. Exon Smith <<a href="mailto:dexonsmith@apple.com" target="_blank">dexonsmith@apple.com</a>> wrote:<br>
><br>
><br>
>> On 2015 May 4, at 20:17, Adrian Prantl <<a href="mailto:aprantl@apple.com" target="_blank">aprantl@apple.com</a>> wrote:<br>
>><br>
>> Now with autoupgrade testcase.<br>
>><br>
>><br>
>> <a href="http://reviews.llvm.org/D9488" target="_blank">http://reviews.llvm.org/D9488</a><br>
>><br>
>> Files:<br>
>> include/llvm/IR/DIBuilder.h<br>
>> include/llvm/IR/DebugInfoMetadata.h<br>
>> lib/AsmParser/LLParser.cpp<br>
>> lib/Bitcode/Reader/BitcodeReader.cpp<br>
>> lib/Bitcode/Writer/BitcodeWriter.cpp<br>
>> lib/IR/AsmWriter.cpp<br>
>> lib/IR/DIBuilder.cpp<br>
>> lib/IR/DebugInfoMetadata.cpp<br>
>> lib/IR/LLVMContextImpl.h<br>
>> test/Assembler/mdcompileunit.ll<br>
>> test/Bitcode/DICompileUnit-upgrade.test<br>
>> test/Bitcode/Inputs/DICompileUnit-no-DWOId.bc<br>
>> unittests/IR/MetadataTest.cpp<br>
>><br>
>> EMAIL PREFERENCES<br>
>> <a href="http://reviews.llvm.org/settings/panel/emailpreferences/" target="_blank">http://reviews.llvm.org/settings/panel/emailpreferences/</a><br>
>> <D9488.24927.patch><br>
><br>
> LGTM with some changes to the autoupgrade test.<br>
><br>
>> Index: test/Bitcode/DICompileUnit-upgrade.test<br>
>> ===================================================================<br>
>> --- /dev/null<br>
>> +++ test/Bitcode/DICompileUnit-upgrade.test<br>
><br>
> Can you be more descriptive?  Perhaps dicompileunit-no-dwoid.ll.<br>
> (Feel free to use the camel-case filename; I personally avoid<br>
> capitals but clearly there's no harm.)<br>
><br>
>> @@ -0,0 +1,6 @@<br>
>> +RUN: llvm-dis %p/Inputs/DICompileUnit-no-DWOId.bc -o - | FileCheck %s<br>
><br>
> %p was undocumented last I checked.  I recommend the documented %S<br>
> when this sort of functionality is necessary.<br>
><br>
> But I wouldn't even use the `Inputs` folder here.  The usual bitcode<br>
> upgrade tests say:<br>
><br>
>    ; RUN: llvm-dis < %s.bc | FileCheck %s<br>
>    ; RUN: verify-uselistorder < %s.bc<br>
><br>
> and just drop a .ll.bc file next to a .ll test in `test/Bitcode`.<br>
><br>
> Moreover, the test file should be the `.ll` file that was used to<br>
> generate the bitcode.  Please add a comment that says what revision of<br>
> LLVM was used to generate the bitcode, something like:<br>
><br>
>    ; Bitcode generated from llvm-as @ r123456.<br>
><br>
>> +The input uses the older form without a dwoId field.<br>
>> +This should default to 0,<br>
>> +which is not displayed at all in the textual representation.<br>
>> +CHECK: !DICompileUnit<br>
>> +CHECK-NOT: dwoId:<br>
><br>
<br>
</div></div></blockquote></div><br></div></div>
</div></blockquote></div></div></div><br></div></blockquote></div><br></div></div>
</div></blockquote></div></div></div><br></div></blockquote></div><br></div></div>