[llvm] r348898 - Revert "debuginfo: Use symbol difference for CU length to simplify assembly reading/editing"

David Blaikie via llvm-commits llvm-commits at lists.llvm.org
Mon Dec 17 17:11:15 PST 2018


Recommitted in r349430, having validated against the internal failure.

On Mon, Dec 17, 2018 at 11:35 AM Artem Belevich <tra at google.com> wrote:

> Alexey or Eric are the people who have the best chance to answer your
> question.
>
> In general, emitting DWARF in PTX is a rather hairy process due to the
> limitations (and quirks) of PTX and your patch may have tripped on some of
> them.
>
>
> On Mon, Dec 17, 2018 at 11:20 AM David Blaikie <dblaikie at gmail.com> wrote:
>
>>
>>
>> On Tue, Dec 11, 2018 at 1:29 PM Jordan Rupprecht via llvm-commits <
>> llvm-commits at lists.llvm.org> wrote:
>>
>>> Author: rupprecht
>>> Date: Tue Dec 11 13:26:52 2018
>>> New Revision: 348898
>>>
>>> URL: http://llvm.org/viewvc/llvm-project?rev=348898&view=rev
>>> Log:
>>>  Revert "debuginfo: Use symbol difference for CU length to simplify
>>> assembly reading/editing"
>>>
>>> Temporarily reverts commit r348806 due to strange asm compilation issues
>>> in certain modes (combination of asan+cuda+other things). Will provide
>>> repro soon.
>>>
>>
>> Jordan - did you happen to get any more info on this?
>>
>> Art - given cuda+debug info is something you've some context on. Any idea
>> why the "if !nvptx" logic in this code wouldn't be sufficient & what would
>> be sufficient to workaround this issue?
>>
>>
>>>
>>> Modified:
>>>     llvm/trunk/lib/CodeGen/AsmPrinter/DwarfFile.cpp
>>>     llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp
>>>     llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h
>>>     llvm/trunk/test/DebugInfo/X86/sections_as_references.ll
>>>
>>> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfFile.cpp
>>> URL:
>>> http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfFile.cpp?rev=348898&r1=348897&r2=348898&view=diff
>>>
>>> ==============================================================================
>>> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfFile.cpp (original)
>>> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfFile.cpp Tue Dec 11 13:26:52
>>> 2018
>>> @@ -46,8 +46,6 @@ void DwarfFile::emitUnit(DwarfUnit *TheU
>>>    TheU->emitHeader(UseOffsets);
>>>
>>>    Asm->emitDwarfDIE(Die);
>>> -
>>> -  Asm->OutStreamer->EmitLabel(TheU->getEndLabel());
>>>  }
>>>
>>>  // Compute the size and offset for each DIE.
>>>
>>> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp
>>> URL:
>>> http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp?rev=348898&r1=348897&r2=348898&view=diff
>>>
>>> ==============================================================================
>>> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp (original)
>>> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.cpp Tue Dec 11 13:26:52
>>> 2018
>>> @@ -38,7 +38,6 @@
>>>  #include "llvm/Support/Casting.h"
>>>  #include "llvm/Support/CommandLine.h"
>>>  #include "llvm/Target/TargetLoweringObjectFile.h"
>>> -#include "llvm/Target/TargetMachine.h"
>>>  #include <cassert>
>>>  #include <cstdint>
>>>  #include <string>
>>> @@ -1554,17 +1553,7 @@ DIE *DwarfUnit::getOrCreateStaticMemberD
>>>  void DwarfUnit::emitCommonHeader(bool UseOffsets, dwarf::UnitType UT) {
>>>    // Emit size of content not including length itself
>>>    Asm->OutStreamer->AddComment("Length of Unit");
>>> -  StringRef Prefix = isDwoUnit() ? "debug_info_dwo_" : "debug_info_";
>>> -  MCSymbol *BeginLabel = Asm->createTempSymbol(Prefix + "start");
>>> -  EndLabel = Asm->createTempSymbol(Prefix + "end");
>>> -
>>> -  // Use a label difference for the convenience of legible/easily
>>> modified
>>> -  // assembly - except on NVPTX where label differences aren't
>>> supported.
>>> -  if (Asm->TM.getTargetTriple().isNVPTX())
>>> -    Asm->emitInt32(getHeaderSize() + getUnitDie().getSize());
>>> -  else
>>> -    Asm->EmitLabelDifference(EndLabel, BeginLabel, 4);
>>> -  Asm->OutStreamer->EmitLabel(BeginLabel);
>>> +  Asm->emitInt32(getHeaderSize() + getUnitDie().getSize());
>>>
>>>    Asm->OutStreamer->AddComment("DWARF version number");
>>>    unsigned Version = DD->getDwarfVersion();
>>>
>>> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h
>>> URL:
>>> http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h?rev=348898&r1=348897&r2=348898&view=diff
>>>
>>> ==============================================================================
>>> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h (original)
>>> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfUnit.h Tue Dec 11 13:26:52
>>> 2018
>>> @@ -48,7 +48,6 @@ protected:
>>>
>>>    /// Target of Dwarf emission.
>>>    AsmPrinter *Asm;
>>> -  MCSymbol *EndLabel;
>>>
>>>    // Holders for some common dwarf information.
>>>    DwarfDebug *DD;
>>> @@ -83,7 +82,6 @@ protected:
>>>  public:
>>>    // Accessors.
>>>    AsmPrinter* getAsmPrinter() const { return Asm; }
>>> -  MCSymbol *getEndLabel() const { return EndLabel; }
>>>    uint16_t getLanguage() const { return CUNode->getSourceLanguage(); }
>>>    const DICompileUnit *getCUNode() const { return CUNode; }
>>>
>>>
>>> Modified: llvm/trunk/test/DebugInfo/X86/sections_as_references.ll
>>> URL:
>>> http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/sections_as_references.ll?rev=348898&r1=348897&r2=348898&view=diff
>>>
>>> ==============================================================================
>>> --- llvm/trunk/test/DebugInfo/X86/sections_as_references.ll (original)
>>> +++ llvm/trunk/test/DebugInfo/X86/sections_as_references.ll Tue Dec 11
>>> 13:26:52 2018
>>> @@ -9,19 +9,13 @@
>>>  ; CHECK-NOT: .L
>>>
>>>  ; CHECK:      .section .debug_info
>>> -; CHECK-NEXT: .long .Ldebug_info_end0-.Ldebug_info_start0 # Length of
>>> Unit
>>> -; CHECK-NEXT: .Ldebug_info_start0:
>>> -; CHECK-NEXT: .short 2             # DWARF version number
>>> +; CHECK-NOT:  .L
>>> +; CHECK:      .short 2             # DWARF version number
>>>  ; CHECK-NOT:  .L
>>>  ; CHECK:      .long .debug_abbrev  # Offset Into Abbrev. Section
>>>  ; CHECK-NOT:  .L
>>>  ; CHECK:      .long .debug_line    # DW_AT_stmt_list
>>>  ; CHECK-NOT:  .L
>>> -; CHECK:      .Ldebug_info_end0:
>>> -; CHECK-NOT:  .L
>>> -; CHECK:      .long .Ldebug_info_end1-.Ldebug_info_start1 # Length of
>>> Unit
>>> -; CHECK-NEXT: .Ldebug_info_start1:
>>> -; CHECK-NOT:  .L
>>>  ; CHECK:      .long .debug_abbrev  # Offset Into Abbrev. Section
>>>  ; CHECK-NOT:  .L
>>>  ; CHECK:      .long .debug_line    # DW_AT_stmt_list
>>> @@ -29,7 +23,6 @@
>>>  ; CHECK:      .quad .debug_info+{{[0-9]+}} # DW_AT_type
>>>  ; CHECK-NOT:  .L
>>>  ; CHECK:      .byte 0              # End Of Children Mark
>>> -; CHECK-NEXT: .Ldebug_info_end1:
>>>  ; CHECK-NOT:  .L
>>>
>>>  source_filename = "test/DebugInfo/X86/sections_as_references.ll"
>>>
>>>
>>> _______________________________________________
>>> llvm-commits mailing list
>>> llvm-commits at lists.llvm.org
>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits
>>>
>>
>
> --
> --Artem Belevich
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20181217/bd388516/attachment.html>


More information about the llvm-commits mailing list