diff options
Diffstat (limited to 'contrib/llvm/lib/CodeGen/AsmPrinter/WinCodeViewLineTables.cpp')
| -rw-r--r-- | contrib/llvm/lib/CodeGen/AsmPrinter/WinCodeViewLineTables.cpp | 123 | 
1 files changed, 60 insertions, 63 deletions
| diff --git a/contrib/llvm/lib/CodeGen/AsmPrinter/WinCodeViewLineTables.cpp b/contrib/llvm/lib/CodeGen/AsmPrinter/WinCodeViewLineTables.cpp index b5e0929efd91..371e20a3e5a0 100644 --- a/contrib/llvm/lib/CodeGen/AsmPrinter/WinCodeViewLineTables.cpp +++ b/contrib/llvm/lib/CodeGen/AsmPrinter/WinCodeViewLineTables.cpp @@ -20,14 +20,13 @@ namespace llvm {  StringRef WinCodeViewLineTables::getFullFilepath(const MDNode *S) {    assert(S); -  DIDescriptor D(S); -  assert((D.isCompileUnit() || D.isFile() || D.isSubprogram() || -          D.isLexicalBlockFile() || D.isLexicalBlock()) && +  assert((isa<DICompileUnit>(S) || isa<DIFile>(S) || isa<DISubprogram>(S) || +          isa<DILexicalBlockBase>(S)) &&           "Unexpected scope info"); -  DIScope Scope(S); -  StringRef Dir = Scope.getDirectory(), -            Filename = Scope.getFilename(); +  auto *Scope = cast<DIScope>(S); +  StringRef Dir = Scope->getDirectory(), +            Filename = Scope->getFilename();    char *&Result = DirAndFilenameToFilepathMap[std::make_pair(Dir, Filename)];    if (Result)      return Result; @@ -40,7 +39,7 @@ StringRef WinCodeViewLineTables::getFullFilepath(const MDNode *S) {    if (Filename.find(':') == 1)      Filepath = Filename;    else -    Filepath = (Dir + Twine("\\") + Filename).str(); +    Filepath = (Dir + "\\" + Filename).str();    // Canonicalize the path.  We have to do it textually because we may no longer    // have access the file in the filesystem. @@ -81,7 +80,7 @@ StringRef WinCodeViewLineTables::getFullFilepath(const MDNode *S) {  void WinCodeViewLineTables::maybeRecordLocation(DebugLoc DL,                                                  const MachineFunction *MF) { -  const MDNode *Scope = DL.getScope(MF->getFunction()->getContext()); +  const MDNode *Scope = DL.getScope();    if (!Scope)      return;    StringRef Filename = getFullFilepath(Scope); @@ -95,8 +94,8 @@ void WinCodeViewLineTables::maybeRecordLocation(DebugLoc DL,    }    FileNameRegistry.add(Filename); -  MCSymbol *MCL = Asm->MMI->getContext().CreateTempSymbol(); -  Asm->OutStreamer.EmitLabel(MCL); +  MCSymbol *MCL = Asm->MMI->getContext().createTempSymbol(); +  Asm->OutStreamer->EmitLabel(MCL);    CurFn->Instrs.push_back(MCL);    InstrInfo[MCL] = InstrInfoTy(Filename, DL.getLine());  } @@ -121,7 +120,7 @@ void WinCodeViewLineTables::endModule() {      return;    assert(Asm != nullptr); -  Asm->OutStreamer.SwitchSection( +  Asm->OutStreamer->SwitchSection(        Asm->getObjFileLowering().getCOFFDebugSymbolsSection());    Asm->EmitInt32(COFF::DEBUG_SECTION_MAGIC); @@ -136,7 +135,7 @@ void WinCodeViewLineTables::endModule() {      emitDebugInfoForFunction(VisitedFunctions[I]);    // This subsection holds a file index to offset in string table table. -  Asm->OutStreamer.AddComment("File index to string table offset subsection"); +  Asm->OutStreamer->AddComment("File index to string table offset subsection");    Asm->EmitInt32(COFF::DEBUG_INDEX_SUBSECTION);    size_t NumFilenames = FileNameRegistry.Infos.size();    Asm->EmitInt32(8 * NumFilenames); @@ -149,7 +148,7 @@ void WinCodeViewLineTables::endModule() {    }    // This subsection holds the string table. -  Asm->OutStreamer.AddComment("String table"); +  Asm->OutStreamer->AddComment("String table");    Asm->EmitInt32(COFF::DEBUG_STRING_TABLE_SUBSECTION);    Asm->EmitInt32(FileNameRegistry.LastOffset);    // The payload starts with a null character. @@ -157,12 +156,12 @@ void WinCodeViewLineTables::endModule() {    for (size_t I = 0, E = FileNameRegistry.Filenames.size(); I != E; ++I) {      // Just emit unique filenames one by one, separated by a null character. -    Asm->OutStreamer.EmitBytes(FileNameRegistry.Filenames[I]); +    Asm->OutStreamer->EmitBytes(FileNameRegistry.Filenames[I]);      Asm->EmitInt8(0);    }    // No more subsections. Fill with zeros to align the end of the section by 4. -  Asm->OutStreamer.EmitFill((-FileNameRegistry.LastOffset) % 4, 0); +  Asm->OutStreamer->EmitFill((-FileNameRegistry.LastOffset) % 4, 0);    clear();  } @@ -190,8 +189,11 @@ void WinCodeViewLineTables::emitDebugInfoForFunction(const Function *GV) {      return;    assert(FI.End && "Don't know where the function ends?"); -  StringRef FuncName = getDISubprogram(GV).getDisplayName(), -            GVName = GV->getName(); +  StringRef GVName = GV->getName(); +  StringRef FuncName; +  if (auto *SP = getDISubprogram(GV)) +    FuncName = SP->getDisplayName(); +    // FIXME Clang currently sets DisplayName to "bar" for a C++    // "namespace_foo::bar" function, see PR21528.  Luckily, dbghelp.dll is trying    // to demangle display names anyways, so let's just put a mangled name into @@ -199,41 +201,41 @@ void WinCodeViewLineTables::emitDebugInfoForFunction(const Function *GV) {    if (GVName.startswith("\01?"))      FuncName = GVName.substr(1);    // Emit a symbol subsection, required by VS2012+ to find function boundaries. -  MCSymbol *SymbolsBegin = Asm->MMI->getContext().CreateTempSymbol(), -           *SymbolsEnd = Asm->MMI->getContext().CreateTempSymbol(); -  Asm->OutStreamer.AddComment("Symbol subsection for " + Twine(FuncName)); +  MCSymbol *SymbolsBegin = Asm->MMI->getContext().createTempSymbol(), +           *SymbolsEnd = Asm->MMI->getContext().createTempSymbol(); +  Asm->OutStreamer->AddComment("Symbol subsection for " + Twine(FuncName));    Asm->EmitInt32(COFF::DEBUG_SYMBOL_SUBSECTION); -  EmitLabelDiff(Asm->OutStreamer, SymbolsBegin, SymbolsEnd); -  Asm->OutStreamer.EmitLabel(SymbolsBegin); +  EmitLabelDiff(*Asm->OutStreamer, SymbolsBegin, SymbolsEnd); +  Asm->OutStreamer->EmitLabel(SymbolsBegin);    { -    MCSymbol *ProcSegmentBegin = Asm->MMI->getContext().CreateTempSymbol(), -             *ProcSegmentEnd = Asm->MMI->getContext().CreateTempSymbol(); -    EmitLabelDiff(Asm->OutStreamer, ProcSegmentBegin, ProcSegmentEnd, 2); -    Asm->OutStreamer.EmitLabel(ProcSegmentBegin); +    MCSymbol *ProcSegmentBegin = Asm->MMI->getContext().createTempSymbol(), +             *ProcSegmentEnd = Asm->MMI->getContext().createTempSymbol(); +    EmitLabelDiff(*Asm->OutStreamer, ProcSegmentBegin, ProcSegmentEnd, 2); +    Asm->OutStreamer->EmitLabel(ProcSegmentBegin);      Asm->EmitInt16(COFF::DEBUG_SYMBOL_TYPE_PROC_START);      // Some bytes of this segment don't seem to be required for basic debugging,      // so just fill them with zeroes. -    Asm->OutStreamer.EmitFill(12, 0); +    Asm->OutStreamer->EmitFill(12, 0);      // This is the important bit that tells the debugger where the function      // code is located and what's its size: -    EmitLabelDiff(Asm->OutStreamer, Fn, FI.End); -    Asm->OutStreamer.EmitFill(12, 0); -    Asm->OutStreamer.EmitCOFFSecRel32(Fn); -    Asm->OutStreamer.EmitCOFFSectionIndex(Fn); +    EmitLabelDiff(*Asm->OutStreamer, Fn, FI.End); +    Asm->OutStreamer->EmitFill(12, 0); +    Asm->OutStreamer->EmitCOFFSecRel32(Fn); +    Asm->OutStreamer->EmitCOFFSectionIndex(Fn);      Asm->EmitInt8(0);      // Emit the function display name as a null-terminated string. -    Asm->OutStreamer.EmitBytes(FuncName); +    Asm->OutStreamer->EmitBytes(FuncName);      Asm->EmitInt8(0); -    Asm->OutStreamer.EmitLabel(ProcSegmentEnd); +    Asm->OutStreamer->EmitLabel(ProcSegmentEnd);      // We're done with this function.      Asm->EmitInt16(0x0002);      Asm->EmitInt16(COFF::DEBUG_SYMBOL_TYPE_PROC_END);    } -  Asm->OutStreamer.EmitLabel(SymbolsEnd); +  Asm->OutStreamer->EmitLabel(SymbolsEnd);    // Every subsection must be aligned to a 4-byte boundary. -  Asm->OutStreamer.EmitFill((-FuncName.size()) % 4, 0); +  Asm->OutStreamer->EmitFill((-FuncName.size()) % 4, 0);    // PCs/Instructions are grouped into segments sharing the same filename.    // Pre-calculate the lengths (in instructions) of these segments and store @@ -252,21 +254,21 @@ void WinCodeViewLineTables::emitDebugInfoForFunction(const Function *GV) {    FilenameSegmentLengths[LastSegmentEnd] = FI.Instrs.size() - LastSegmentEnd;    // Emit a line table subsection, requred to do PC-to-file:line lookup. -  Asm->OutStreamer.AddComment("Line table subsection for " + Twine(FuncName)); +  Asm->OutStreamer->AddComment("Line table subsection for " + Twine(FuncName));    Asm->EmitInt32(COFF::DEBUG_LINE_TABLE_SUBSECTION); -  MCSymbol *LineTableBegin = Asm->MMI->getContext().CreateTempSymbol(), -           *LineTableEnd = Asm->MMI->getContext().CreateTempSymbol(); -  EmitLabelDiff(Asm->OutStreamer, LineTableBegin, LineTableEnd); -  Asm->OutStreamer.EmitLabel(LineTableBegin); +  MCSymbol *LineTableBegin = Asm->MMI->getContext().createTempSymbol(), +           *LineTableEnd = Asm->MMI->getContext().createTempSymbol(); +  EmitLabelDiff(*Asm->OutStreamer, LineTableBegin, LineTableEnd); +  Asm->OutStreamer->EmitLabel(LineTableBegin);    // Identify the function this subsection is for. -  Asm->OutStreamer.EmitCOFFSecRel32(Fn); -  Asm->OutStreamer.EmitCOFFSectionIndex(Fn); +  Asm->OutStreamer->EmitCOFFSecRel32(Fn); +  Asm->OutStreamer->EmitCOFFSectionIndex(Fn);    // Insert padding after a 16-bit section index.    Asm->EmitInt16(0);    // Length of the function's code, in bytes. -  EmitLabelDiff(Asm->OutStreamer, Fn, FI.End); +  EmitLabelDiff(*Asm->OutStreamer, Fn, FI.End);    // PC-to-linenumber lookup table:    MCSymbol *FileSegmentEnd = nullptr; @@ -277,17 +279,17 @@ void WinCodeViewLineTables::emitDebugInfoForFunction(const Function *GV) {      if (FilenameSegmentLengths.count(J)) {        // We came to a beginning of a new filename segment.        if (FileSegmentEnd) -        Asm->OutStreamer.EmitLabel(FileSegmentEnd); +        Asm->OutStreamer->EmitLabel(FileSegmentEnd);        StringRef CurFilename = InstrInfo[FI.Instrs[J]].Filename;        assert(FileNameRegistry.Infos.count(CurFilename));        size_t IndexInStringTable =            FileNameRegistry.Infos[CurFilename].FilenameID;        // Each segment starts with the offset of the filename        // in the string table. -      Asm->OutStreamer.AddComment( +      Asm->OutStreamer->AddComment(            "Segment for file '" + Twine(CurFilename) + "' begins"); -      MCSymbol *FileSegmentBegin = Asm->MMI->getContext().CreateTempSymbol(); -      Asm->OutStreamer.EmitLabel(FileSegmentBegin); +      MCSymbol *FileSegmentBegin = Asm->MMI->getContext().createTempSymbol(); +      Asm->OutStreamer->EmitLabel(FileSegmentBegin);        Asm->EmitInt32(8 * IndexInStringTable);        // Number of PC records in the lookup table. @@ -296,18 +298,18 @@ void WinCodeViewLineTables::emitDebugInfoForFunction(const Function *GV) {        // Full size of the segment for this filename, including the prev two        // records. -      FileSegmentEnd = Asm->MMI->getContext().CreateTempSymbol(); -      EmitLabelDiff(Asm->OutStreamer, FileSegmentBegin, FileSegmentEnd); +      FileSegmentEnd = Asm->MMI->getContext().createTempSymbol(); +      EmitLabelDiff(*Asm->OutStreamer, FileSegmentBegin, FileSegmentEnd);      }      // The first PC with the given linenumber and the linenumber itself. -    EmitLabelDiff(Asm->OutStreamer, Fn, Instr); +    EmitLabelDiff(*Asm->OutStreamer, Fn, Instr);      Asm->EmitInt32(InstrInfo[Instr].LineNumber);    }    if (FileSegmentEnd) -    Asm->OutStreamer.EmitLabel(FileSegmentEnd); -  Asm->OutStreamer.EmitLabel(LineTableEnd); +    Asm->OutStreamer->EmitLabel(FileSegmentEnd); +  Asm->OutStreamer->EmitLabel(LineTableEnd);  }  void WinCodeViewLineTables::beginFunction(const MachineFunction *MF) { @@ -327,7 +329,7 @@ void WinCodeViewLineTables::beginFunction(const MachineFunction *MF) {    DebugLoc PrologEndLoc;    bool EmptyPrologue = true;    for (const auto &MBB : *MF) { -    if (!PrologEndLoc.isUnknown()) +    if (PrologEndLoc)        break;      for (const auto &MI : MBB) {        if (MI.isDebugValue()) @@ -336,8 +338,7 @@ void WinCodeViewLineTables::beginFunction(const MachineFunction *MF) {        // First known non-DBG_VALUE and non-frame setup location marks        // the beginning of the function body.        // FIXME: do we need the first subcondition? -      if (!MI.getFlag(MachineInstr::FrameSetup) && -          (!MI.getDebugLoc().isUnknown())) { +      if (!MI.getFlag(MachineInstr::FrameSetup) && MI.getDebugLoc()) {          PrologEndLoc = MI.getDebugLoc();          break;        } @@ -345,9 +346,8 @@ void WinCodeViewLineTables::beginFunction(const MachineFunction *MF) {      }    }    // Record beginning of function if we have a non-empty prologue. -  if (!PrologEndLoc.isUnknown() && !EmptyPrologue) { -    DebugLoc FnStartDL = -        PrologEndLoc.getFnDebugLoc(MF->getFunction()->getContext()); +  if (PrologEndLoc && !EmptyPrologue) { +    DebugLoc FnStartDL = PrologEndLoc.getFnDebugLoc();      maybeRecordLocation(FnStartDL, MF);    }  } @@ -364,10 +364,7 @@ void WinCodeViewLineTables::endFunction(const MachineFunction *MF) {      FnDebugInfo.erase(GV);      VisitedFunctions.pop_back();    } else { -    // Define end label for subprogram. -    MCSymbol *FunctionEndSym = Asm->OutStreamer.getContext().CreateTempSymbol(); -    Asm->OutStreamer.EmitLabel(FunctionEndSym); -    CurFn->End = FunctionEndSym; +    CurFn->End = Asm->getFunctionEnd();    }    CurFn = nullptr;  } @@ -377,7 +374,7 @@ void WinCodeViewLineTables::beginInstruction(const MachineInstr *MI) {    if (!Asm || MI->isDebugValue() || MI->getFlag(MachineInstr::FrameSetup))      return;    DebugLoc DL = MI->getDebugLoc(); -  if (DL == PrevInstLoc || DL.isUnknown()) +  if (DL == PrevInstLoc || !DL)      return;    maybeRecordLocation(DL, Asm->MF);  } | 
