diff options
| author | Jim Laskey <jlaskey@mac.com> | 2006-10-23 14:56:37 +0000 | 
|---|---|---|
| committer | Jim Laskey <jlaskey@mac.com> | 2006-10-23 14:56:37 +0000 | 
| commit | 66ebf0973d717b4b2cdef731847aef3904fd04b2 (patch) | |
| tree | 7c98ec2d36c9eb7c2c4deb9960a29f3819ce9eda /lib | |
| parent | 978b35e5027208e707f642247643fb17de4af5f7 (diff) | |
| download | external_llvm-66ebf0973d717b4b2cdef731847aef3904fd04b2.zip external_llvm-66ebf0973d717b4b2cdef731847aef3904fd04b2.tar.gz external_llvm-66ebf0973d717b4b2cdef731847aef3904fd04b2.tar.bz2  | |
More complete solution to deleting blocks and debug info.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31129 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/CodeGen/BranchFolding.cpp | 2 | ||||
| -rw-r--r-- | lib/CodeGen/DwarfWriter.cpp | 21 | ||||
| -rw-r--r-- | lib/CodeGen/MachineDebugInfo.cpp | 19 | 
3 files changed, 28 insertions, 14 deletions
diff --git a/lib/CodeGen/BranchFolding.cpp b/lib/CodeGen/BranchFolding.cpp index 0752e3c..4643c74 100644 --- a/lib/CodeGen/BranchFolding.cpp +++ b/lib/CodeGen/BranchFolding.cpp @@ -75,7 +75,7 @@ void BranchFolder::RemoveDeadBlock(MachineBasicBlock *MBB) {           I != E; ++I) {        if ((unsigned)I->getOpcode() == DWARF_LABELOpc) {          // The label ID # is always operand #0, an immediate. -        MDI->RemoveLabelInfo(I->getOperand(0).getImm()); +        MDI->InvalidateLabel(I->getOperand(0).getImm());        }      }    } diff --git a/lib/CodeGen/DwarfWriter.cpp b/lib/CodeGen/DwarfWriter.cpp index dc59b81..c600edb 100644 --- a/lib/CodeGen/DwarfWriter.cpp +++ b/lib/CodeGen/DwarfWriter.cpp @@ -1755,17 +1755,24 @@ void DwarfWriter::ConstructScope(DebugScope *ParentScope,      // FIXME - Ignore inlined functions for the time being.      if (!Scope->getParent()) continue; +    unsigned StartID = Scope->getStartLabelID(); +    unsigned EndID = Scope->getEndLabelID(); +     +    // Throw out scope if block is discarded. +    if (StartID && !DebugInfo->isLabelValid(StartID)) continue; +    if (EndID && !DebugInfo->isLabelValid(EndID)) continue; +          DIE *ScopeDie = new DIE(DW_TAG_lexical_block);      // Add the scope bounds. -    if (unsigned StartID = Scope->getStartLabelID()) { +    if (StartID) {        ScopeDie->AddLabel(DW_AT_low_pc, DW_FORM_addr,                           DWLabel("loc", StartID));      } else {        ScopeDie->AddLabel(DW_AT_low_pc, DW_FORM_addr,                           DWLabel("func_begin", SubprogramCount));      } -    if (unsigned EndID = Scope->getEndLabelID()) { +    if (EndID) {        ScopeDie->AddLabel(DW_AT_high_pc, DW_FORM_addr,                           DWLabel("loc", EndID));      } else { @@ -1975,6 +1982,10 @@ void DwarfWriter::EmitFrameMoves(const char *BaseLabel, unsigned BaseLabelID,    for (unsigned i = 0, N = Moves.size(); i < N; ++i) {      MachineMove *Move = Moves[i];      unsigned LabelID = Move->getLabelID(); +     +    // Throw out move if the label is invalid. +    if (LabelID && !DebugInfo->isLabelValid(LabelID)) continue; +          const MachineLocation &Dst = Move->getDestination();      const MachineLocation &Src = Move->getSource(); @@ -2194,6 +2205,10 @@ void DwarfWriter::EmitDebugLines() const {      // Construct rows of the address, source, line, column matrix.      for (unsigned i = 0, N = LineInfos.size(); i < N; ++i) {        const SourceLineInfo &LineInfo = LineInfos[i]; +      unsigned LabelID = LineInfo.getLabelID(); +       +      // Throw out line info if label is invalid. +      if (!DebugInfo->isLabelValid(LabelID)) continue;        if (DwarfVerbose) {          unsigned SourceID = LineInfo.getSourceID(); @@ -2210,7 +2225,7 @@ void DwarfWriter::EmitDebugLines() const {        EmitInt8(0); EOL("Extended Op");        EmitInt8(4 + 1); EOL("Op size");        EmitInt8(DW_LNE_set_address); EOL("DW_LNE_set_address"); -      EmitReference("loc",  LineInfo.getLabelID()); EOL("Location label"); +      EmitReference("loc",  LabelID); EOL("Location label");        // If change of source, then switch to the new source.        if (Source != LineInfo.getSourceID()) { diff --git a/lib/CodeGen/MachineDebugInfo.cpp b/lib/CodeGen/MachineDebugInfo.cpp index a1f4f13..380b8a9 100644 --- a/lib/CodeGen/MachineDebugInfo.cpp +++ b/lib/CodeGen/MachineDebugInfo.cpp @@ -1451,6 +1451,7 @@ MachineDebugInfo::MachineDebugInfo()  , LabelID(0)  , ScopeMap()  , RootScope(NULL) +, DeletedLabelIDs()  , FrameMoves()  {}  MachineDebugInfo::~MachineDebugInfo() { @@ -1543,20 +1544,18 @@ unsigned MachineDebugInfo::RecordLabel(unsigned Line, unsigned Column,    return ID;  } -static bool LabelUIDComparison(const SourceLineInfo &LI, unsigned UID) { -  return LI.getLabelID() < UID; +/// InvalidateLabel - Inhibit use of the specified label # from +/// MachineDebugInfo, for example because the code was deleted. +void MachineDebugInfo::InvalidateLabel(unsigned LabelID) { +  DeletedLabelIDs.insert(LabelID);  } -/// RemoveLabelInfo - Remove the specified label # from MachineDebugInfo, for -/// example because the code was deleted. -void MachineDebugInfo::RemoveLabelInfo(unsigned LabelUID) { -  std::vector<SourceLineInfo>::iterator I = -    std::lower_bound(Lines.begin(), Lines.end(), LabelUID, LabelUIDComparison); -  assert(I != Lines.end() && "Didn't find label UID in MachineDebugInfo!"); -  Lines.erase(I); +/// isLabelValid - Check to make sure the label is still valid before +/// attempting to use. +bool MachineDebugInfo::isLabelValid(unsigned LabelID) { +  return DeletedLabelIDs.find(LabelID) == DeletedLabelIDs.end();  } -  /// RecordSource - Register a source file with debug info. Returns an source  /// ID.  unsigned MachineDebugInfo::RecordSource(const std::string &Directory,  | 
