diff options
author | Devang Patel <dpatel@apple.com> | 2010-03-28 21:23:37 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2010-03-28 21:23:37 +0000 |
commit | 1e8ccb5f8bd48cd057cf90f2bf8982d811b599b6 (patch) | |
tree | e582f65d835f60a5976f69076a15086c6bbbefe1 /llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | |
parent | d589593c930fee1f6c648ee735eca92417f82ba2 (diff) | |
download | bcm5719-llvm-1e8ccb5f8bd48cd057cf90f2bf8982d811b599b6.tar.gz bcm5719-llvm-1e8ccb5f8bd48cd057cf90f2bf8982d811b599b6.zip |
Revert 99772.
llvm-svn: 99778
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp')
-rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index 7601199488e..1d4f7f7ae68 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -62,7 +62,7 @@ AsmPrinter::AsmPrinter(formatted_raw_ostream &o, TargetMachine &tm, TM(tm), MAI(tm.getMCAsmInfo()), TRI(tm.getRegisterInfo()), OutContext(Streamer.getContext()), OutStreamer(Streamer), - LastMI(0), LastFn(0), Counter(~0U), SetCounter(0) { + LastMI(0), LastFn(0), Counter(~0U), SetCounter(0), PrevDLT(NULL) { DW = 0; MMI = 0; VerboseAsm = Streamer.isVerboseAsm(); } @@ -1337,12 +1337,25 @@ void AsmPrinter::processDebugLoc(const MachineInstr *MI, if (!MAI || !DW || !MAI->doesSupportDebugInformation() || !DW->ShouldEmitDwarfDebug()) return; + if (MI->getOpcode() == TargetOpcode::DBG_VALUE) + return; + DebugLoc DL = MI->getDebugLoc(); + if (DL.isUnknown()) + return; + DILocation CurDLT = MF->getDILocation(DL); + if (!CurDLT.getScope().Verify()) + return; - if (!BeforePrintingInsn) + if (!BeforePrintingInsn) { // After printing instruction DW->EndScope(MI); - else - DW->BeginScope(MI); + } else if (CurDLT.getNode() != PrevDLT) { + MCSymbol *L = DW->RecordSourceLine(CurDLT.getLineNumber(), + CurDLT.getColumnNumber(), + CurDLT.getScope().getNode()); + DW->BeginScope(MI, L); + PrevDLT = CurDLT.getNode(); + } } |