<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 14 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:Tahoma;
panose-1:2 11 6 4 3 5 4 4 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
margin-bottom:.0001pt;
font-size:12.0pt;
font-family:"Times New Roman","serif";}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:purple;
text-decoration:underline;}
span.EmailStyle17
{mso-style-type:personal-reply;
font-family:"Calibri","sans-serif";
color:#1F497D;}
.MsoChpDefault
{mso-style-type:export-only;
font-family:"Calibri","sans-serif";}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">An emit-now-or-defer-until-later flag would save memory, at the cost of some coding complexity.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">Let me know if you really need the label-before-dot-file situation to work.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">--paulr<o:p></o:p></span></p>
<p class="MsoNormal"><a name="_MailEndCompose"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D"><o:p> </o:p></span></a></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<div>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<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:dblaikie@gmail.com]
<br>
<b>Sent:</b> Wednesday, April 18, 2018 1:55 PM<br>
<b>To:</b> Robinson, Paul<br>
<b>Cc:</b> llvm-commits@lists.llvm.org<br>
<b>Subject:</b> Re: [llvm] r328805 - Reapply "[DWARFv5] Emit file 0 to the line table."<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">Following up internally for this particular use case (some weird code generation situation)<br>
<br>
But alternatively, it wouldn't necessarily require caching all the labels & making them at the end - but potentially only deferring them until an instruction is found (until the label becomes necessary/relevant).<o:p></o:p></p>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div>
<p class="MsoNormal">On Wed, Apr 18, 2018 at 7:59 AM <<a href="mailto:paul.robinson@sony.com">paul.robinson@sony.com</a>> wrote:<o:p></o:p></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" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">I believe that can happen only when there is a label prior to the first .file directive. We generate
a label DIE for the label and therefore need a source location and therefore assume that if we haven't seen any .file directives, we should implicitly use the assembly source file as file #1.</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">If you want to consider this to be a bug, we'd have to defer generating label DIEs until we've parsed
the entire assembly file. I think it's feasible but is it really worth the trouble?</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D">--paulr</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><a name="m_6636145094563707788__MailEndCompose"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D"> </span></a><o:p></o:p></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<div>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><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> Tuesday, April 17, 2018 3:07 PM<br>
<b>To:</b> Robinson, Paul<br>
<b>Cc:</b> <a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a><br>
<b>Subject:</b> Re: [llvm] r328805 - Reapply "[DWARFv5] Emit file 0 to the line table."</span><o:p></o:p></p>
</div>
</div>
</div>
</div>
</div>
<div>
<div>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt">This looks like it still breaks clang -g for assembly files with .file directives in it:<o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New"">$ cat test.s</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New"">label:</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New""> .file "bar.c"</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New""> .file 1 "/foo" "bar.c"</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New"">$ clang-tot test.s -c </span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New"">$ clang-tot test.s -c -gmlt</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New"">test.s:3:2: error: file number already allocated</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New""> .file 1 "/foo" "bar.c"</span><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:"Courier New""> ^</span><o:p></o:p></p>
</div>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">On Thu, Mar 29, 2018 at 10:19 AM Paul Robinson via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>> wrote:<o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Author: probinson<br>
Date: Thu Mar 29 10:16:41 2018<br>
New Revision: 328805<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=328805&view=rev" target="_blank">
http://llvm.org/viewvc/llvm-project?rev=328805&view=rev</a><br>
Log:<br>
Reapply "[DWARFv5] Emit file 0 to the line table."<br>
<br>
DWARF v5 specifies that the root file (also given in the DW_AT_name<br>
attribute of the compilation unit DIE) should be emitted explicitly to<br>
the line table's list of files. This makes the line table more<br>
independent of the .debug_info section.<br>
We emit the new syntax only for DWARF v5 and later.<br>
<br>
Fixes the bug found by asan. Also XFAIL the new test for Darwin, which<br>
is stuck on DWARF v2, and fix up other tests so they stop failing on<br>
Windows. Last but not least, don't break "clang -g" of an assembler<br>
file that has .file directives in it.<br>
<br>
Differential Revision: <a href="https://reviews.llvm.org/D44054" target="_blank">
https://reviews.llvm.org/D44054</a><br>
<br>
Added:<br>
llvm/trunk/test/MC/ELF/dwarf-file0.s<br>
Modified:<br>
llvm/trunk/include/llvm/MC/MCContext.h<br>
llvm/trunk/include/llvm/MC/MCDwarf.h<br>
llvm/trunk/include/llvm/MC/MCStreamer.h<br>
llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp<br>
llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h<br>
llvm/trunk/lib/MC/MCAsmStreamer.cpp<br>
llvm/trunk/lib/MC/MCDwarf.cpp<br>
llvm/trunk/lib/MC/MCParser/AsmParser.cpp<br>
llvm/trunk/lib/MC/MCStreamer.cpp<br>
llvm/trunk/test/CodeGen/Generic/dwarf-md5.ll<br>
llvm/trunk/test/CodeGen/Generic/dwarf-source.ll<br>
llvm/trunk/test/DebugInfo/X86/dbg-file-name.ll<br>
llvm/trunk/test/DebugInfo/X86/inline-asm-locs.ll<br>
llvm/trunk/test/MC/ARM/dwarf-asm-multiple-sections.s<br>
llvm/trunk/test/MC/ELF/debug-file-options.s<br>
llvm/trunk/test/MC/ELF/debug-md5.s<br>
llvm/trunk/test/MC/ELF/debug-source.s<br>
llvm/trunk/tools/llvm-mc/llvm-mc.cpp<br>
<br>
Modified: llvm/trunk/include/llvm/MC/MCContext.h<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/MC/MCContext.h?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/MC/MCContext.h?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/include/llvm/MC/MCContext.h (original)<br>
+++ llvm/trunk/include/llvm/MC/MCContext.h Thu Mar 29 10:16:41 2018<br>
@@ -537,8 +537,13 @@ namespace llvm {<br>
DwarfCompileUnitID = CUIndex;<br>
}<br>
<br>
- void setMCLineTableCompilationDir(unsigned CUID, StringRef CompilationDir) {<br>
- getMCDwarfLineTable(CUID).setCompilationDir(CompilationDir);<br>
+ /// Specifies the "root" file and directory of the compilation unit.<br>
+ /// These are "file 0" and "directory 0" in DWARF v5.<br>
+ void setMCLineTableRootFile(unsigned CUID, StringRef CompilationDir,<br>
+ StringRef Filename, MD5::MD5Result *Checksum,<br>
+ Optional<StringRef> Source) {<br>
+ getMCDwarfLineTable(CUID).setRootFile(CompilationDir, Filename, Checksum,<br>
+ Source);<br>
}<br>
<br>
/// Saves the information from the currently parsed dwarf .loc directive<br>
<br>
Modified: llvm/trunk/include/llvm/MC/MCDwarf.h<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/MC/MCDwarf.h?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/MC/MCDwarf.h?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/include/llvm/MC/MCDwarf.h (original)<br>
+++ llvm/trunk/include/llvm/MC/MCDwarf.h Thu Mar 29 10:16:41 2018<br>
@@ -214,6 +214,7 @@ struct MCDwarfLineTableHeader {<br>
SmallVector<MCDwarfFile, 3> MCDwarfFiles;<br>
StringMap<unsigned> SourceIdMap;<br>
StringRef CompilationDir;<br>
+ MCDwarfFile RootFile;<br>
bool HasMD5 = false;<br>
bool HasSource = false;<br>
<br>
@@ -241,8 +242,17 @@ class MCDwarfDwoLineTable {<br>
MCDwarfLineTableHeader Header;<br>
<br>
public:<br>
- void setCompilationDir(StringRef CompilationDir) {<br>
- Header.CompilationDir = CompilationDir;<br>
+ void maybeSetRootFile(StringRef Directory, StringRef FileName,<br>
+ MD5::MD5Result *Checksum, Optional<StringRef> Source) {<br>
+ if (!Header.RootFile.Name.empty())<br>
+ return;<br>
+ Header.CompilationDir = Directory;<br>
+ <a href="http://Header.RootFile.Name" target="_blank">Header.RootFile.Name</a> = FileName;<br>
+ Header.RootFile.DirIndex = 0;<br>
+ Header.RootFile.Checksum = Checksum;<br>
+ Header.RootFile.Source = Source;<br>
+ Header.HasMD5 = (Checksum != nullptr);<br>
+ Header.HasSource = Source.hasValue();<br>
}<br>
<br>
unsigned getFile(StringRef Directory, StringRef FileName,<br>
@@ -277,6 +287,17 @@ public:<br>
FileNumber));<br>
}<br>
<br>
+ void setRootFile(StringRef Directory, StringRef FileName,<br>
+ MD5::MD5Result *Checksum, Optional<StringRef> Source) {<br>
+ Header.CompilationDir = Directory;<br>
+ <a href="http://Header.RootFile.Name" target="_blank">Header.RootFile.Name</a> = FileName;<br>
+ Header.RootFile.DirIndex = 0;<br>
+ Header.RootFile.Checksum = Checksum;<br>
+ Header.RootFile.Source = Source;<br>
+ Header.HasMD5 = (Checksum != nullptr);<br>
+ Header.HasSource = Source.hasValue();<br>
+ }<br>
+<br>
MCSymbol *getLabel() const {<br>
return Header.Label;<br>
}<br>
@@ -285,10 +306,6 @@ public:<br>
Header.Label = Label;<br>
}<br>
<br>
- void setCompilationDir(StringRef CompilationDir) {<br>
- Header.CompilationDir = CompilationDir;<br>
- }<br>
-<br>
const SmallVectorImpl<std::string> &getMCDwarfDirs() const {<br>
return Header.MCDwarfDirs;<br>
}<br>
<br>
Modified: llvm/trunk/include/llvm/MC/MCStreamer.h<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/MC/MCStreamer.h?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/MC/MCStreamer.h?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/include/llvm/MC/MCStreamer.h (original)<br>
+++ llvm/trunk/include/llvm/MC/MCStreamer.h Thu Mar 29 10:16:41 2018<br>
@@ -775,6 +775,12 @@ public:<br>
MD5::MD5Result *Checksum = nullptr, Optional<StringRef> Source = None,<br>
unsigned CUID = 0);<br>
<br>
+ /// Specify the "root" file of the compilation, using the ".file 0" extension.<br>
+ virtual void emitDwarfFile0Directive(StringRef Directory, StringRef Filename,<br>
+ MD5::MD5Result *Checksum,<br>
+ Optional<StringRef> Source,<br>
+ unsigned CUID = 0);<br>
+<br>
/// \brief This implements the DWARF2 '.loc fileno lineno ...' assembler<br>
/// directive.<br>
virtual void EmitDwarfLocDirective(unsigned FileNo, unsigned Line,<br>
<br>
Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp (original)<br>
+++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp Thu Mar 29 10:16:41 2018<br>
@@ -499,8 +499,9 @@ DwarfDebug::getOrCreateDwarfCompileUnit(<br>
// explicitly describe the directory of all files, never relying on the<br>
// compilation directory.<br>
if (!Asm->OutStreamer->hasRawTextSupport() || SingleCU)<br>
- Asm->OutStreamer->getContext().setMCLineTableCompilationDir(<br>
- NewCU.getUniqueID(), CompilationDir);<br>
+ Asm->OutStreamer->emitDwarfFile0Directive(<br>
+ CompilationDir, FN, NewCU.getMD5AsBytes(DIUnit->getFile()),<br>
+ DIUnit->getSource(), NewCU.getUniqueID());<br>
<br>
StringRef Producer = DIUnit->getProducer();<br>
StringRef Flags = DIUnit->getFlags();<br>
@@ -2148,8 +2149,10 @@ void DwarfDebug::emitDebugStrDWO() {<br>
MCDwarfDwoLineTable *DwarfDebug::getDwoLineTable(const DwarfCompileUnit &CU) {<br>
if (!useSplitDwarf())<br>
return nullptr;<br>
- if (SingleCU)<br>
- SplitTypeUnitFileTable.setCompilationDir(CU.getCUNode()->getDirectory());<br>
+ const DICompileUnit *DIUnit = CU.getCUNode();<br>
+ SplitTypeUnitFileTable.maybeSetRootFile(<br>
+ DIUnit->getDirectory(), DIUnit->getFilename(),<br>
+ CU.getMD5AsBytes(DIUnit->getFile()), DIUnit->getSource());<br>
return &SplitTypeUnitFileTable;<br>
}<br>
<br>
<br>
Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp (original)<br>
+++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp Thu Mar 29 10:16:41 2018<br>
@@ -282,8 +282,10 @@ void DwarfUnit::addSectionOffset(DIE &Di<br>
addUInt(Die, Attribute, dwarf::DW_FORM_data4, Integer);<br>
}<br>
<br>
-MD5::MD5Result *DwarfUnit::getMD5AsBytes(const DIFile *File) {<br>
+MD5::MD5Result *DwarfUnit::getMD5AsBytes(const DIFile *File) const {<br>
assert(File);<br>
+ if (DD->getDwarfVersion() < 5)<br>
+ return nullptr;<br>
Optional<DIFile::ChecksumInfo<StringRef>> Checksum = File->getChecksum();<br>
if (!Checksum || Checksum->Kind != DIFile::CSK_MD5)<br>
return nullptr;<br>
<br>
Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h (original)<br>
+++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h Thu Mar 29 10:16:41 2018<br>
@@ -306,6 +306,10 @@ public:<br>
const MCSymbol *Label,<br>
const MCSymbol *Sec);<br>
<br>
+ /// If the \p File has an MD5 checksum, return it as an MD5Result<br>
+ /// allocated in the MCContext.<br>
+ MD5::MD5Result *getMD5AsBytes(const DIFile *File) const;<br>
+<br>
protected:<br>
~DwarfUnit();<br>
<br>
@@ -316,10 +320,6 @@ protected:<br>
/// create a new ID and insert it in the line table.<br>
virtual unsigned getOrCreateSourceID(const DIFile *File) = 0;<br>
<br>
- /// If the \p File has an MD5 checksum, return it as an MD5Result<br>
- /// allocated in the MCContext.<br>
- MD5::MD5Result *getMD5AsBytes(const DIFile *File);<br>
-<br>
/// Look in the DwarfDebug map for the MDNode that corresponds to the<br>
/// reference.<br>
template <typename T> T *resolve(TypedDINodeRef<T> Ref) const {<br>
<br>
Modified: llvm/trunk/lib/MC/MCAsmStreamer.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCAsmStreamer.cpp?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCAsmStreamer.cpp?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/MC/MCAsmStreamer.cpp (original)<br>
+++ llvm/trunk/lib/MC/MCAsmStreamer.cpp Thu Mar 29 10:16:41 2018<br>
@@ -219,6 +219,10 @@ public:<br>
MD5::MD5Result *Checksum = 0,<br>
Optional<StringRef> Source = None,<br>
unsigned CUID = 0) override;<br>
+ void emitDwarfFile0Directive(StringRef Directory, StringRef Filename,<br>
+ MD5::MD5Result *Checksum,<br>
+ Optional<StringRef> Source,<br>
+ unsigned CUID = 0) override;<br>
void EmitDwarfLocDirective(unsigned FileNo, unsigned Line,<br>
unsigned Column, unsigned Flags,<br>
unsigned Isa, unsigned Discriminator,<br>
@@ -1077,21 +1081,12 @@ void MCAsmStreamer::EmitFileDirective(St<br>
EmitEOL();<br>
}<br>
<br>
-Expected<unsigned> MCAsmStreamer::tryEmitDwarfFileDirective(<br>
- unsigned FileNo, StringRef Directory, StringRef Filename,<br>
- MD5::MD5Result *Checksum, Optional<StringRef> Source, unsigned CUID) {<br>
- assert(CUID == 0);<br>
-<br>
- MCDwarfLineTable &Table = getContext().getMCDwarfLineTable(CUID);<br>
- unsigned NumFiles = Table.getMCDwarfFiles().size();<br>
- Expected<unsigned> FileNoOrErr =<br>
- Table.tryGetFile(Directory, Filename, Checksum, Source, FileNo);<br>
- if (!FileNoOrErr)<br>
- return FileNoOrErr.takeError();<br>
- FileNo = FileNoOrErr.get();<br>
- if (NumFiles == Table.getMCDwarfFiles().size())<br>
- return FileNo;<br>
-<br>
+static void printDwarfFileDirective(unsigned FileNo, StringRef Directory,<br>
+ StringRef Filename,<br>
+ MD5::MD5Result *Checksum,<br>
+ Optional<StringRef> Source,<br>
+ bool UseDwarfDirectory,<br>
+ raw_svector_ostream &OS) {<br>
SmallString<128> FullPathName;<br>
<br>
if (!UseDwarfDirectory && !Directory.empty()) {<br>
@@ -1105,31 +1100,71 @@ Expected<unsigned> MCAsmStreamer::tryEmi<br>
}<br>
}<br>
<br>
- SmallString<128> Str;<br>
- raw_svector_ostream OS1(Str);<br>
- OS1 << "\t.file\t" << FileNo << ' ';<br>
+ OS << "\t.file\t" << FileNo << ' ';<br>
if (!Directory.empty()) {<br>
- PrintQuotedString(Directory, OS1);<br>
- OS1 << ' ';<br>
+ PrintQuotedString(Directory, OS);<br>
+ OS << ' ';<br>
}<br>
- PrintQuotedString(Filename, OS1);<br>
+ PrintQuotedString(Filename, OS);<br>
if (Checksum) {<br>
- OS1 << " md5 ";<br>
- PrintQuotedString(Checksum->digest(), OS1);<br>
+ OS << " md5 ";<br>
+ PrintQuotedString(Checksum->digest(), OS);<br>
}<br>
if (Source) {<br>
- OS1 << " source ";<br>
- PrintQuotedString(*Source, OS1);<br>
+ OS << " source ";<br>
+ PrintQuotedString(*Source, OS);<br>
}<br>
- if (MCTargetStreamer *TS = getTargetStreamer()) {<br>
+}<br>
+<br>
+Expected<unsigned> MCAsmStreamer::tryEmitDwarfFileDirective(<br>
+ unsigned FileNo, StringRef Directory, StringRef Filename,<br>
+ MD5::MD5Result *Checksum, Optional<StringRef> Source, unsigned CUID) {<br>
+ assert(CUID == 0 && "multiple CUs not supported by MCAsmStreamer");<br>
+<br>
+ MCDwarfLineTable &Table = getContext().getMCDwarfLineTable(CUID);<br>
+ unsigned NumFiles = Table.getMCDwarfFiles().size();<br>
+ Expected<unsigned> FileNoOrErr =<br>
+ Table.tryGetFile(Directory, Filename, Checksum, Source, FileNo);<br>
+ if (!FileNoOrErr)<br>
+ return FileNoOrErr.takeError();<br>
+ FileNo = FileNoOrErr.get();<br>
+ if (NumFiles == Table.getMCDwarfFiles().size())<br>
+ return FileNo;<br>
+<br>
+ SmallString<128> Str;<br>
+ raw_svector_ostream OS1(Str);<br>
+ printDwarfFileDirective(FileNo, Directory, Filename, Checksum, Source,<br>
+ UseDwarfDirectory, OS1);<br>
+<br>
+ if (MCTargetStreamer *TS = getTargetStreamer())<br>
TS->emitDwarfFileDirective(OS1.str());<br>
- } else {<br>
+ else<br>
EmitRawText(OS1.str());<br>
- }<br>
<br>
return FileNo;<br>
}<br>
<br>
+void MCAsmStreamer::emitDwarfFile0Directive(StringRef Directory,<br>
+ StringRef Filename,<br>
+ MD5::MD5Result *Checksum,<br>
+ Optional<StringRef> Source,<br>
+ unsigned CUID) {<br>
+ assert(CUID == 0);<br>
+ // .file 0 is new for DWARF v5.<br>
+ if (getContext().getDwarfVersion() < 5)<br>
+ return;<br>
+<br>
+ SmallString<128> Str;<br>
+ raw_svector_ostream OS1(Str);<br>
+ printDwarfFileDirective(0, Directory, Filename, Checksum, Source,<br>
+ UseDwarfDirectory, OS1);<br>
+<br>
+ if (MCTargetStreamer *TS = getTargetStreamer())<br>
+ TS->emitDwarfFileDirective(OS1.str());<br>
+ else<br>
+ EmitRawText(OS1.str());<br>
+}<br>
+<br>
void MCAsmStreamer::EmitDwarfLocDirective(unsigned FileNo, unsigned Line,<br>
unsigned Column, unsigned Flags,<br>
unsigned Isa,<br>
<br>
Modified: llvm/trunk/lib/MC/MCDwarf.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCDwarf.cpp?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCDwarf.cpp?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/MC/MCDwarf.cpp (original)<br>
+++ llvm/trunk/lib/MC/MCDwarf.cpp Thu Mar 29 10:16:41 2018<br>
@@ -349,6 +349,34 @@ void MCDwarfLineTableHeader::emitV2FileD<br>
MCOS->EmitIntValue(0, 1); // Terminate the file list.<br>
}<br>
<br>
+static void emitOneV5FileEntry(MCStreamer *MCOS, const MCDwarfFile &DwarfFile,<br>
+ bool HasMD5, bool HasSource,<br>
+ Optional<MCDwarfLineStr> &LineStr) {<br>
+ assert(!DwarfFile.Name.empty());<br>
+ if (LineStr)<br>
+ LineStr->emitRef(MCOS, DwarfFile.Name);<br>
+ else {<br>
+ MCOS->EmitBytes(DwarfFile.Name); // FileName and...<br>
+ MCOS->EmitBytes(StringRef("\0", 1)); // its null terminator.<br>
+ }<br>
+ MCOS->EmitULEB128IntValue(DwarfFile.DirIndex); // Directory number.<br>
+ if (HasMD5) {<br>
+ MD5::MD5Result *Cksum = DwarfFile.Checksum;<br>
+ MCOS->EmitBinaryData(<br>
+ StringRef(reinterpret_cast<const char *>(Cksum->Bytes.data()),<br>
+ Cksum->Bytes.size()));<br>
+ }<br>
+ if (HasSource) {<br>
+ if (LineStr)<br>
+ LineStr->emitRef(MCOS, DwarfFile.Source.getValueOr(StringRef()));<br>
+ else {<br>
+ MCOS->EmitBytes(<br>
+ DwarfFile.Source.getValueOr(StringRef())); // Source and...<br>
+ MCOS->EmitBytes(StringRef("\0", 1)); // its null terminator.<br>
+ }<br>
+ }<br>
+}<br>
+<br>
void MCDwarfLineTableHeader::emitV5FileDirTables(<br>
MCStreamer *MCOS, Optional<MCDwarfLineStr> &LineStr) const {<br>
// The directory format, which is just a list of the directory paths. In a<br>
@@ -397,33 +425,12 @@ void MCDwarfLineTableHeader::emitV5FileD<br>
MCOS->EmitULEB128IntValue(LineStr ? dwarf::DW_FORM_line_strp<br>
: dwarf::DW_FORM_string);<br>
}<br>
- // Then the list of file names. These start at 1.<br>
- MCOS->EmitULEB128IntValue(MCDwarfFiles.size() - 1);<br>
- for (unsigned i = 1; i < MCDwarfFiles.size(); ++i) {<br>
- assert(!MCDwarfFiles[i].Name.empty());<br>
- if (LineStr)<br>
- LineStr->emitRef(MCOS, MCDwarfFiles[i].Name);<br>
- else {<br>
- MCOS->EmitBytes(MCDwarfFiles[i].Name); // FileName and...<br>
- MCOS->EmitBytes(StringRef("\0", 1)); // its null terminator.<br>
- }<br>
- MCOS->EmitULEB128IntValue(MCDwarfFiles[i].DirIndex); // Directory number.<br>
- if (HasMD5) {<br>
- MD5::MD5Result *Cksum = MCDwarfFiles[i].Checksum;<br>
- MCOS->EmitBinaryData(<br>
- StringRef(reinterpret_cast<const char *>(Cksum->Bytes.data()),<br>
- Cksum->Bytes.size()));<br>
- }<br>
- if (HasSource) {<br>
- if (LineStr)<br>
- LineStr->emitRef(MCOS, MCDwarfFiles[i].Source.getValueOr(StringRef()));<br>
- else {<br>
- MCOS->EmitBytes(<br>
- MCDwarfFiles[i].Source.getValueOr(StringRef())); // Source and...<br>
- MCOS->EmitBytes(StringRef("\0", 1)); // its null terminator.<br>
- }<br>
- }<br>
- }<br>
+ // Then the counted list of files. The root file is file #0, then emit the<br>
+ // files as provide by .file directives.<br>
+ MCOS->EmitULEB128IntValue(MCDwarfFiles.size());<br>
+ emitOneV5FileEntry(MCOS, RootFile, HasMD5, HasSource, LineStr);<br>
+ for (unsigned i = 1; i < MCDwarfFiles.size(); ++i)<br>
+ emitOneV5FileEntry(MCOS, MCDwarfFiles[i], HasMD5, HasSource, LineStr);<br>
}<br>
<br>
std::pair<MCSymbol *, MCSymbol *><br>
<br>
Modified: llvm/trunk/lib/MC/MCParser/AsmParser.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCParser/AsmParser.cpp?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCParser/AsmParser.cpp?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/MC/MCParser/AsmParser.cpp (original)<br>
+++ llvm/trunk/lib/MC/MCParser/AsmParser.cpp Thu Mar 29 10:16:41 2018<br>
@@ -3276,8 +3276,8 @@ bool AsmParser::parseDirectiveFile(SMLoc<br>
FileNumber = getTok().getIntVal();<br>
Lex();<br>
<br>
- if (FileNumber < 1)<br>
- return TokError("file number less than one");<br>
+ if (FileNumber < 0)<br>
+ return TokError("negative file number");<br>
}<br>
<br>
std::string Path = getTok().getString();<br>
@@ -3356,11 +3356,15 @@ bool AsmParser::parseDirectiveFile(SMLoc<br>
memcpy(SourceBuf, SourceString.data(), SourceString.size());<br>
Source = StringRef(SourceBuf, SourceString.size());<br>
}<br>
- Expected<unsigned> FileNumOrErr = getStreamer().tryEmitDwarfFileDirective(<br>
- FileNumber, Directory, Filename, CKMem, Source);<br>
- if (!FileNumOrErr)<br>
- return Error(DirectiveLoc, toString(FileNumOrErr.takeError()));<br>
- FileNumber = FileNumOrErr.get();<br>
+ if (FileNumber == 0)<br>
+ getStreamer().emitDwarfFile0Directive(Directory, Filename, CKMem, Source);<br>
+ else {<br>
+ Expected<unsigned> FileNumOrErr = getStreamer().tryEmitDwarfFileDirective(<br>
+ FileNumber, Directory, Filename, CKMem, Source);<br>
+ if (!FileNumOrErr)<br>
+ return Error(DirectiveLoc, toString(FileNumOrErr.takeError()));<br>
+ FileNumber = FileNumOrErr.get();<br>
+ }<br>
}<br>
<br>
return false;<br>
<br>
Modified: llvm/trunk/lib/MC/MCStreamer.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCStreamer.cpp?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCStreamer.cpp?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/MC/MCStreamer.cpp (original)<br>
+++ llvm/trunk/lib/MC/MCStreamer.cpp Thu Mar 29 10:16:41 2018<br>
@@ -199,6 +199,15 @@ MCStreamer::tryEmitDwarfFileDirective(un<br>
Source, CUID);<br>
}<br>
<br>
+void MCStreamer::emitDwarfFile0Directive(StringRef Directory,<br>
+ StringRef Filename,<br>
+ MD5::MD5Result *Checksum,<br>
+ Optional<StringRef> Source,<br>
+ unsigned CUID) {<br>
+ getContext().setMCLineTableRootFile(CUID, Directory, Filename, Checksum,<br>
+ Source);<br>
+}<br>
+<br>
void MCStreamer::EmitDwarfLocDirective(unsigned FileNo, unsigned Line,<br>
unsigned Column, unsigned Flags,<br>
unsigned Isa,<br>
<br>
Modified: llvm/trunk/test/CodeGen/Generic/dwarf-md5.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/Generic/dwarf-md5.ll?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/Generic/dwarf-md5.ll?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/CodeGen/Generic/dwarf-md5.ll (original)<br>
+++ llvm/trunk/test/CodeGen/Generic/dwarf-md5.ll Thu Mar 29 10:16:41 2018<br>
@@ -5,31 +5,33 @@<br>
; XFAIL: darwin<br>
<br>
; REQUIRES: object-emission<br>
-; RUN: %llc_dwarf -dwarf-version 4 -filetype=asm -o - %s | FileCheck %s --check-prefix=ASM<br>
-; RUN: %llc_dwarf -dwarf-version 5 -filetype=asm -o - %s | FileCheck %s --check-prefix=ASM<br>
+; RUN: %llc_dwarf -dwarf-version 4 -filetype=asm -o - %s | FileCheck %s --check-prefixes=ASM,ASM-4<br>
+; RUN: %llc_dwarf -dwarf-version 5 -filetype=asm -o - %s | FileCheck %s --check-prefixes=ASM,ASM-5<br>
; RUN: %llc_dwarf -dwarf-version 4 -filetype=obj -o %t4.o %s<br>
-; RUN: llvm-dwarfdump -debug-line %t4.o | FileCheck %s --check-prefix=OBJ-4<br>
+; RUN: llvm-dwarfdump -debug-line %t4.o | FileCheck %s --check-prefix=OBJ<br>
; RUN: %llc_dwarf -dwarf-version 5 -filetype=obj -o %t5.o %s<br>
-; RUN: llvm-dwarfdump -debug-line %t5.o | FileCheck %s --check-prefix=OBJ-5<br>
+; RUN: llvm-dwarfdump -debug-line %t5.o | FileCheck %s --check-prefixes=OBJ,OBJ-5<br>
<br>
-; FIXME: Need to convey the MD5 for the primary source file.<br>
-; ASM: .file 1 ".{{/|\\\\}}t1.h" md5 "11111111111111111111111111111111"<br>
-; ASM: .file 2 ".{{/|\\\\}}t2.h" md5 "22222222222222222222222222222222"<br>
-<br>
-; OBJ-4: file_names[ 1]:<br>
-; OBJ-4-NEXT: name: "t1.h"<br>
-; OBJ-4-NEXT: dir_index: 1<br>
-; OBJ-4: file_names[ 2]:<br>
-; OBJ-4-NEXT: name: "t2.h"<br>
-; OBJ-4-NEXT: dir_index: 1<br>
+; ASM-4-NOT: .file 0<br>
+; ASM-5: .file 0 "/scratch{{[/\\]}}t.c" md5 "00000000000000000000000000000000"<br>
+; ASM: .file 1 "/scratch{{[/\\]}}t1.h"<br>
+; ASM-4-NOT: md5<br>
+; ASM-5-SAME: md5 "11111111111111111111111111111111"<br>
+; ASM: .file 2 "/scratch{{[/\\]}}t2.h"<br>
+; ASM-4-NOT: md5<br>
+; ASM-5-SAME: md5 "22222222222222222222222222222222"<br>
<br>
; OBJ-5: file_names[ 0]:<br>
-; OBJ-5-NEXT: name: "t1.h"<br>
-; OBJ-5-NEXT: dir_index: 1<br>
+; OBJ-5-NEXT: name: "t.c"<br>
+; OBJ-5-NEXT: dir_index: 0<br>
+; OBJ-5-NEXT: md5_checksum: 00000000000000000000000000000000<br>
+; OBJ: file_names[ 1]:<br>
+; OBJ-NEXT: name: "t1.h"<br>
+; OBJ-NEXT: dir_index: 0<br>
; OBJ-5-NEXT: md5_checksum: 11111111111111111111111111111111<br>
-; OBJ-5: file_names[ 1]:<br>
-; OBJ-5-NEXT: name: "t2.h"<br>
-; OBJ-5-NEXT: dir_index: 1<br>
+; OBJ: file_names[ 2]:<br>
+; OBJ-NEXT: name: "t2.h"<br>
+; OBJ-NEXT: dir_index: 0<br>
; OBJ-5-NEXT: md5_checksum: 22222222222222222222222222222222<br>
<br>
; ModuleID = 't.c'<br>
@@ -45,14 +47,14 @@ source_filename = "t.c"<br>
!0 = !DIGlobalVariableExpression(var: !1, expr: !DIExpression())<br>
!1 = distinct !DIGlobalVariable(name: "t1", scope: !2, file: !10, line: 1, type: !9, isLocal: false, isDefinition: true)<br>
!2 = distinct !DICompileUnit(language: DW_LANG_C99, file: !3, producer: "clang version 7.0.0 (trunk 322159)", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !4, globals: !5)<br>
-!3 = !DIFile(filename: "t.c", directory: "/home/probinson/projects/scratch", checksumkind: CSK_MD5, checksum: "00000000000000000000000000000000")<br>
+!3 = !DIFile(filename: "t.c", directory: "/scratch", checksumkind: CSK_MD5, checksum: "00000000000000000000000000000000")<br>
!4 = !{}<br>
!5 = !{!0, !6}<br>
!6 = !DIGlobalVariableExpression(var: !7, expr: !DIExpression())<br>
!7 = distinct !DIGlobalVariable(name: "t2", scope: !2, file: !8, line: 1, type: !9, isLocal: false, isDefinition: true)<br>
-!8 = !DIFile(filename: "./t2.h", directory: "/home/probinson/projects/scratch", checksumkind: CSK_MD5, checksum: "22222222222222222222222222222222")<br>
+!8 = !DIFile(filename: "t2.h", directory: "/scratch", checksumkind: CSK_MD5, checksum: "22222222222222222222222222222222")<br>
!9 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)<br>
-!10 = !DIFile(filename: "./t1.h", directory: "/home/probinson/projects/scratch", checksumkind: CSK_MD5, checksum: "11111111111111111111111111111111")<br>
+!10 = !DIFile(filename: "t1.h", directory: "/scratch", checksumkind: CSK_MD5, checksum: "11111111111111111111111111111111")<br>
!11 = !{i32 2, !"Dwarf Version", i32 4}<br>
!12 = !{i32 2, !"Debug Info Version", i32 3}<br>
!13 = !{i32 1, !"wchar_size", i32 4}<br>
<br>
Modified: llvm/trunk/test/CodeGen/Generic/dwarf-source.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/Generic/dwarf-source.ll?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/Generic/dwarf-source.ll?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/CodeGen/Generic/dwarf-source.ll (original)<br>
+++ llvm/trunk/test/CodeGen/Generic/dwarf-source.ll Thu Mar 29 10:16:41 2018<br>
@@ -6,32 +6,29 @@<br>
<br>
; REQUIRES: object-emission<br>
; RUN: %llc_dwarf -dwarf-version 4 -filetype=asm -o - %s | FileCheck %s --check-prefix=ASM<br>
-; RUN: %llc_dwarf -dwarf-version 5 -filetype=asm -o - %s | FileCheck %s --check-prefix=ASM<br>
+; RUN: %llc_dwarf -dwarf-version 5 -filetype=asm -o - %s | FileCheck %s --check-prefixes=ASM,ASM-5<br>
; RUN: %llc_dwarf -dwarf-version 4 -filetype=obj -o %t4.o %s<br>
-; RUN: llvm-dwarfdump -debug-line %t4.o | FileCheck %s --check-prefix=OBJ-4<br>
+; RUN: llvm-dwarfdump -debug-line %t4.o | FileCheck %s --check-prefixes=OBJ,OBJ-4<br>
; RUN: %llc_dwarf -dwarf-version 5 -filetype=obj -o %t5.o %s<br>
-; RUN: llvm-dwarfdump -debug-line %t5.o | FileCheck %s --check-prefix=OBJ-5<br>
+; RUN: llvm-dwarfdump -debug-line %t5.o | FileCheck %s --check-prefixes=OBJ,OBJ-5<br>
<br>
-; FIXME: Need to convey the source for the primary source file.<br>
-; ASM: .file 1 ".{{/|\\\\}}t1.h" source "11111111111111111111111111111111"<br>
-; ASM: .file 2 ".{{/|\\\\}}t2.h" source "22222222222222222222222222222222"<br>
-<br>
-; OBJ-4: file_names[ 1]:<br>
-; OBJ-4-NEXT: name: "t1.h"<br>
-; OBJ-4-NEXT: dir_index: 1<br>
-; OBJ-4-NOT: 11111111111111111111111111111111<br>
-; OBJ-4: file_names[ 2]:<br>
-; OBJ-4-NEXT: name: "t2.h"<br>
-; OBJ-4-NEXT: dir_index: 1<br>
-; OBJ-4-NOT: 22222222222222222222222222222222<br>
+; ASM-5: .file 0 "/test{{[/\\]}}t.c" source "00000000000000000000000000000000"<br>
+; ASM: .file 1 "/test{{[/\\]}}t1.h" source "11111111111111111111111111111111"<br>
+; ASM: .file 2 "/test{{[/\\]}}t2.h" source "22222222222222222222222222222222"<br>
<br>
; OBJ-5: file_names[ 0]:<br>
-; OBJ-5-NEXT: name: "t1.h"<br>
-; OBJ-5-NEXT: dir_index: 1<br>
+; OBJ-5-NEXT: name: "t.c"<br>
+; OBJ-5-NEXT: dir_index: 0<br>
+; OBJ-5-NEXT: source: "00000000000000000000000000000000"<br>
+; OBJ: file_names[ 1]:<br>
+; OBJ-NEXT: name: "t1.h"<br>
+; OBJ-NEXT: dir_index: 0<br>
+; OBJ-4-NOT: 11111111111111111111111111111111<br>
; OBJ-5-NEXT: source: "11111111111111111111111111111111"<br>
-; OBJ-5: file_names[ 1]:<br>
-; OBJ-5-NEXT: name: "t2.h"<br>
-; OBJ-5-NEXT: dir_index: 1<br>
+; OBJ: file_names[ 2]:<br>
+; OBJ-NEXT: name: "t2.h"<br>
+; OBJ-NEXT: dir_index: 0<br>
+; OBJ-4-NOT: 22222222222222222222222222222222<br>
; OBJ-5-NEXT: source: "22222222222222222222222222222222"<br>
<br>
; ModuleID = 't.c'<br>
@@ -52,9 +49,9 @@ source_filename = "t.c"<br>
!5 = !{!0, !6}<br>
!6 = !DIGlobalVariableExpression(var: !7, expr: !DIExpression())<br>
!7 = distinct !DIGlobalVariable(name: "t2", scope: !2, file: !8, line: 1, type: !9, isLocal: false, isDefinition: true)<br>
-!8 = !DIFile(filename: "./t2.h", directory: "/test", source: "22222222222222222222222222222222")<br>
+!8 = !DIFile(filename: "t2.h", directory: "/test", source: "22222222222222222222222222222222")<br>
!9 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)<br>
-!10 = !DIFile(filename: "./t1.h", directory: "/test", source: "11111111111111111111111111111111")<br>
+!10 = !DIFile(filename: "t1.h", directory: "/test", source: "11111111111111111111111111111111")<br>
!11 = !{i32 2, !"Dwarf Version", i32 4}<br>
!12 = !{i32 2, !"Debug Info Version", i32 3}<br>
!13 = !{i32 1, !"wchar_size", i32 4}<br>
<br>
Modified: llvm/trunk/test/DebugInfo/X86/dbg-file-name.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/dbg-file-name.ll?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/dbg-file-name.ll?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/DebugInfo/X86/dbg-file-name.ll (original)<br>
+++ llvm/trunk/test/DebugInfo/X86/dbg-file-name.ll Thu Mar 29 10:16:41 2018<br>
@@ -2,7 +2,7 @@<br>
<br>
; Verify that the file name is relative to the directory.<br>
; rdar://problem/8884898<br>
-; CHECK: file 1 "simple.c"<br>
+; CHECK: file 1 "/Users/manav/one/two" "simple.c"<br>
<br>
declare i32 @printf(i8*, ...) nounwind<br>
<br>
<br>
Modified: llvm/trunk/test/DebugInfo/X86/inline-asm-locs.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/inline-asm-locs.ll?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/inline-asm-locs.ll?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/DebugInfo/X86/inline-asm-locs.ll (original)<br>
+++ llvm/trunk/test/DebugInfo/X86/inline-asm-locs.ll Thu Mar 29 10:16:41 2018<br>
@@ -22,7 +22,7 @@<br>
; CHECK: .file 2 "B.asm"<br>
; CHECK: .loc 1 111<br>
; CHECK: .loc 2 222<br>
-; CHECK: .file 3 "test.c"<br>
+; CHECK: .file 3 "{{.*[/\\]}}test.c"<br>
; CHECK: .loc 3 14 0 <br>
<br>
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"<br>
<br>
Modified: llvm/trunk/test/MC/ARM/dwarf-asm-multiple-sections.s<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ARM/dwarf-asm-multiple-sections.s?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ARM/dwarf-asm-multiple-sections.s?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/MC/ARM/dwarf-asm-multiple-sections.s (original)<br>
+++ llvm/trunk/test/MC/ARM/dwarf-asm-multiple-sections.s Thu Mar 29 10:16:41 2018<br>
@@ -54,9 +54,9 @@ b:<br>
// DWARF-DL: .debug_line contents:<br>
// DWARF-DL: version: [[DWVER]]<br>
// DWARF-DL-5: address_size: 4<br>
-// DWARF-DL-5: include_directories[ 0] = ""<br>
+// DWARF-DL-5: include_directories[ 0] = "/tmp"<br>
// DWARF-DL: file_names[ [[DWFILE]]]:<br>
-// DWARF-DL: name: "<stdin>"<br>
+// DWARF-DL: name: "{{(<stdin>|-)}}"<br>
// DWARF-DL: 0x0000000000000000 17 0 1 0 0 is_stmt<br>
// DWARF-DL-NEXT: 0x0000000000000004 17 0 1 0 0 is_stmt end_sequence<br>
// DWARF-DL-NEXT: 0x0000000000000000 21 0 1 0 0 is_stmt<br>
<br>
Modified: llvm/trunk/test/MC/ELF/debug-file-options.s<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/debug-file-options.s?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/debug-file-options.s?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/MC/ELF/debug-file-options.s (original)<br>
+++ llvm/trunk/test/MC/ELF/debug-file-options.s Thu Mar 29 10:16:41 2018<br>
@@ -11,25 +11,32 @@<br>
<br>
# CHECK: debug_line[0x00000000]<br>
# CHECK: version: 5<br>
-# CHECK: include_directories[ 0] = .debug_line_str[0x[[DIR0:[0-9a-f]+]]] = ""<br>
+# CHECK: include_directories[ 0] = .debug_line_str[0x[[DIR0:[0-9a-f]+]]] = "{{.+}}"<br>
# CHECK: include_directories[ 1] = .debug_line_str[0x[[DIR1:[0-9a-f]+]]] = "dir1"<br>
# CHECK: include_directories[ 2] = .debug_line_str[0x[[DIR2:[0-9a-f]+]]] = "dir2"<br>
# CHECK-NOT: include_directories<br>
# CHECK: file_names[ 0]:<br>
+# CHECK-NEXT: name: .debug_line_str[0x[[FILE0:[0-9a-f]+]]] = "{{.+}}"<br>
+# CHECK-NEXT: dir_index: 0<br>
+# CHECK-NEXT: md5_checksum:<br>
+# CHECK-NEXT: source: .debug_line_str[0x[[FILE0SRC:[0-9a-f]+]]] = ""<br>
+# CHECK: file_names[ 1]:<br>
# CHECK-NEXT: name: .debug_line_str[0x[[FILE1:[0-9a-f]+]]] = "foo"<br>
# CHECK-NEXT: dir_index: 1<br>
# CHECK-NEXT: md5_checksum: ee87e05688663173cd6043a3a15bba6e<br>
# CHECK-NEXT: source: .debug_line_str[0x[[FILE1SRC:[0-9a-f]+]]] = "void foo() {}"<br>
-# CHECK: file_names[ 1]:<br>
+# CHECK: file_names[ 2]:<br>
# CHECK-NEXT: name: .debug_line_str[0x[[FILE2:[0-9a-f]+]]] = "bar"<br>
# CHECK-NEXT: dir_index: 2<br>
# CHECK-NEXT: md5_checksum: 816225a0c90ca8948b70eb58be4d522f<br>
# CHECK-NEXT: source: .debug_line_str[0x[[FILE2SRC:[0-9a-f]+]]] = "void bar() {}"<br>
<br>
# CHECK: .debug_line_str contents:<br>
-# CHECK-NEXT: 0x[[DIR0]]: ""<br>
+# CHECK-NEXT: 0x[[DIR0]]: "{{.+}}"<br>
# CHECK-NEXT: 0x[[DIR1]]: "dir1"<br>
# CHECK-NEXT: 0x[[DIR2]]: "dir2"<br>
+# CHECK-NEXT: 0x[[FILE0]]: "{{.+}}"<br>
+# CHECK-NEXT: 0x[[FILE0SRC]]: ""<br>
# CHECK-NEXT: 0x[[FILE1]]: "foo"<br>
# CHECK-NEXT: 0x[[FILE1SRC]]: "void foo() {}"<br>
# CHECK-NEXT: 0x[[FILE2]]: "bar"<br>
<br>
Modified: llvm/trunk/test/MC/ELF/debug-md5.s<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/debug-md5.s?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/debug-md5.s?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/MC/ELF/debug-md5.s (original)<br>
+++ llvm/trunk/test/MC/ELF/debug-md5.s Thu Mar 29 10:16:41 2018<br>
@@ -1,4 +1,4 @@<br>
-// RUN: llvm-mc -triple x86_64-unknown-unknown -dwarf-version 5 -filetype=obj %s -o - | llvm-dwarfdump --debug-line --debug-line-str -v - | FileCheck %s<br>
+// RUN: llvm-mc -triple x86_64-unknown-unknown -dwarf-version 5 -fdebug-compilation-dir=/tmp -filetype=obj %s -o - | llvm-dwarfdump --debug-line --debug-line-str -v - | FileCheck %s<br>
<br>
.file 1 "dir1/foo" md5 "00112233445566778899aabbccddeeff"<br>
.file 2 "dir2" "bar" md5 "ffeeddccbbaa99887766554433221100"<br>
@@ -9,22 +9,26 @@<br>
<br>
# CHECK: debug_line[0x00000000]<br>
# CHECK: version: 5<br>
-# CHECK: include_directories[ 0] = .debug_line_str[0x[[DIR0:[0-9a-f]+]]] = ""<br>
+# CHECK: include_directories[ 0] = .debug_line_str[0x[[DIR0:[0-9a-f]+]]] = "/tmp"<br>
# CHECK: include_directories[ 1] = .debug_line_str[0x[[DIR1:[0-9a-f]+]]] = "dir1"<br>
# CHECK: include_directories[ 2] = .debug_line_str[0x[[DIR2:[0-9a-f]+]]] = "dir2"<br>
# CHECK-NOT: include_directories<br>
# CHECK: file_names[ 0]:<br>
+# CHECK-NEXT: name: .debug_line_str[0x[[FILE0:[0-9a-f]+]]] = "{{.+}}"<br>
+# CHECK-NEXT: dir_index: 0<br>
+# CHECK: file_names[ 1]:<br>
# CHECK-NEXT: name: .debug_line_str[0x[[FILE1:[0-9a-f]+]]] = "foo"<br>
# CHECK-NEXT: dir_index: 1<br>
# CHECK-NEXT: md5_checksum: 00112233445566778899aabbccddeeff<br>
-# CHECK: file_names[ 1]:<br>
+# CHECK: file_names[ 2]:<br>
# CHECK-NEXT: name: .debug_line_str[0x[[FILE2:[0-9a-f]+]]] = "bar"<br>
# CHECK-NEXT: dir_index: 2<br>
# CHECK-NEXT: md5_checksum: ffeeddccbbaa99887766554433221100<br>
<br>
# CHECK: .debug_line_str contents:<br>
-# CHECK-NEXT: 0x[[DIR0]]: ""<br>
+# CHECK-NEXT: 0x[[DIR0]]: "/tmp"<br>
# CHECK-NEXT: 0x[[DIR1]]: "dir1"<br>
# CHECK-NEXT: 0x[[DIR2]]: "dir2"<br>
+# CHECK-NEXT: 0x[[FILE0]]: "{{.+}}"<br>
# CHECK-NEXT: 0x[[FILE1]]: "foo"<br>
# CHECK-NEXT: 0x[[FILE2]]: "bar"<br>
<br>
Modified: llvm/trunk/test/MC/ELF/debug-source.s<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/debug-source.s?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/debug-source.s?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/MC/ELF/debug-source.s (original)<br>
+++ llvm/trunk/test/MC/ELF/debug-source.s Thu Mar 29 10:16:41 2018<br>
@@ -9,23 +9,29 @@<br>
<br>
# CHECK: debug_line[0x00000000]<br>
# CHECK: version: 5<br>
-# CHECK: include_directories[ 0] = .debug_line_str[0x[[DIR0:[0-9a-f]+]]] = ""<br>
+# CHECK: include_directories[ 0] = .debug_line_str[0x[[DIR0:[0-9a-f]+]]] = "{{.+}}"<br>
# CHECK: include_directories[ 1] = .debug_line_str[0x[[DIR1:[0-9a-f]+]]] = "dir1"<br>
# CHECK: include_directories[ 2] = .debug_line_str[0x[[DIR2:[0-9a-f]+]]] = "dir2"<br>
# CHECK-NOT: include_directories<br>
# CHECK: file_names[ 0]:<br>
+# CHECK-NEXT: name: .debug_line_str[0x[[FILE0:[0-9a-f]+]]] = "{{.+}}"<br>
+# CHECK-NEXT: dir_index: 0<br>
+# CHECK-NEXT: source: .debug_line_str[0x[[FILE0SRC:[0-9a-f]+]]] = ""<br>
+# CHECK: file_names[ 1]:<br>
# CHECK-NEXT: name: .debug_line_str[0x[[FILE1:[0-9a-f]+]]] = "foo"<br>
# CHECK-NEXT: dir_index: 1<br>
# CHECK-NEXT: source: .debug_line_str[0x[[FILE1SRC:[0-9a-f]+]]] = "void foo() {}"<br>
-# CHECK: file_names[ 1]:<br>
+# CHECK: file_names[ 2]:<br>
# CHECK-NEXT: name: .debug_line_str[0x[[FILE2:[0-9a-f]+]]] = "bar"<br>
# CHECK-NEXT: dir_index: 2<br>
# CHECK-NEXT: source: .debug_line_str[0x[[FILE2SRC:[0-9a-f]+]]] = "void bar()\n{\n}"<br>
<br>
# CHECK: .debug_line_str contents:<br>
-# CHECK-NEXT: 0x[[DIR0]]: ""<br>
+# CHECK-NEXT: 0x[[DIR0]]: "{{.+}}"<br>
# CHECK-NEXT: 0x[[DIR1]]: "dir1"<br>
# CHECK-NEXT: 0x[[DIR2]]: "dir2"<br>
+# CHECK-NEXT: 0x[[FILE0]]: "{{.+}}"<br>
+# CHECK-NEXT: 0x[[FILE0SRC]]: ""<br>
# CHECK-NEXT: 0x[[FILE1]]: "foo"<br>
# CHECK-NEXT: 0x[[FILE1SRC]]: "void foo() {}"<br>
# CHECK-NEXT: 0x[[FILE2]]: "bar"<br>
<br>
Added: llvm/trunk/test/MC/ELF/dwarf-file0.s<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/dwarf-file0.s?rev=328805&view=auto" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/dwarf-file0.s?rev=328805&view=auto</a><br>
==============================================================================<br>
--- llvm/trunk/test/MC/ELF/dwarf-file0.s (added)<br>
+++ llvm/trunk/test/MC/ELF/dwarf-file0.s Thu Mar 29 10:16:41 2018<br>
@@ -0,0 +1,19 @@<br>
+# RUN: llvm-mc -dwarf-version 4 %s -filetype=obj -o - | llvm-dwarfdump -debug-line - | FileCheck %s --check-prefixes=CHECK,CHECK-4<br>
+# RUN: llvm-mc -dwarf-version 5 %s -filetype=obj -o - | llvm-dwarfdump -debug-line - | FileCheck %s --check-prefixes=CHECK,CHECK-5<br>
+# Darwin is stuck on DWARF v2.<br>
+# XFAIL: darwin<br>
+ .file 0 "root.cpp"<br>
+ .file 1 "header.h"<br>
+ .file 2 "root.cpp"<br>
+# CHECK-5: include_directories[ 0] = ""<br>
+# CHECK-4-NOT: include_directories<br>
+# CHECK-4-NOT: file_names[ 0]<br>
+# CHECK-5: file_names[ 0]:<br>
+# CHECK-5-NEXT: name: "root.cpp"<br>
+# CHECK-5-NEXT: dir_index: 0<br>
+# CHECK: file_names[ 1]:<br>
+# CHECK-NEXT: name: "header.h"<br>
+# CHECK-NEXT: dir_index: 0<br>
+# CHECK: file_names[ 2]:<br>
+# CHECK-NEXT: name: "root.cpp"<br>
+# CHECK-NEXT: dir_index: 0<br>
<br>
Modified: llvm/trunk/tools/llvm-mc/llvm-mc.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/tools/llvm-mc/llvm-mc.cpp?rev=328805&r1=328804&r2=328805&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/llvm/trunk/tools/llvm-mc/llvm-mc.cpp?rev=328805&r1=328804&r2=328805&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/tools/llvm-mc/llvm-mc.cpp (original)<br>
+++ llvm/trunk/tools/llvm-mc/llvm-mc.cpp Thu Mar 29 10:16:41 2018<br>
@@ -390,6 +390,18 @@ int main(int argc, char **argv) {<br>
}<br>
if (!MainFileName.empty())<br>
Ctx.setMainFileName(MainFileName);<br>
+ if (DwarfVersion >= 5) {<br>
+ // DWARF v5 needs the root file as well as the compilation directory.<br>
+ // If we find a '.file 0' directive that will supersede these values.<br>
+ MD5 Hash;<br>
+ MD5::MD5Result *Cksum =<br>
+ (MD5::MD5Result *)Ctx.allocate(sizeof(MD5::MD5Result), 1);<br>
+ Hash.update(Buffer->getBuffer());<br>
+ Hash.final(*Cksum);<br>
+ Ctx.setMCLineTableRootFile(<br>
+ /*CUID=*/0, Ctx.getCompilationDir(),<br>
+ !MainFileName.empty() ? MainFileName : InputFilename, Cksum, None);<br>
+ }<br>
<br>
// Package up features to be passed to target/subtarget<br>
std::string FeaturesStr;<br>
<br>
<br>
_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><o:p></o:p></p>
</blockquote>
</div>
</div>
</div>
</div>
</blockquote>
</div>
</div>
</div>
</body>
</html>