summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2010-03-28 21:23:37 +0000
committerDevang Patel <dpatel@apple.com>2010-03-28 21:23:37 +0000
commit1e8ccb5f8bd48cd057cf90f2bf8982d811b599b6 (patch)
treee582f65d835f60a5976f69076a15086c6bbbefe1 /llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
parentd589593c930fee1f6c648ee735eca92417f82ba2 (diff)
downloadbcm5719-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.cpp21
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();
+ }
}
OpenPOWER on IntegriCloud