aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/CodeGen/AsmPrinter/AsmPrinter.cpp2
-rw-r--r--lib/Target/PIC16/PIC16DebugInfo.cpp16
2 files changed, 12 insertions, 6 deletions
diff --git a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
index 7c5c23b268..6d660a60c3 100644
--- a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
+++ b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
@@ -138,7 +138,7 @@ bool AsmPrinter::doInitialization(Module &M) {
if (MMI)
MMI->AnalyzeModule(M);
DW = getAnalysisIfAvailable<DwarfWriter>();
- if (DW)
+ if (DW && MAI->doesSupportDebugInformation())
DW->BeginModule(&M, MMI, O, this, MAI);
return false;
diff --git a/lib/Target/PIC16/PIC16DebugInfo.cpp b/lib/Target/PIC16/PIC16DebugInfo.cpp
index 0ed44d21fc..49df457af7 100644
--- a/lib/Target/PIC16/PIC16DebugInfo.cpp
+++ b/lib/Target/PIC16/PIC16DebugInfo.cpp
@@ -467,12 +467,18 @@ void PIC16DbgInfo::EmitVarDebugInfo(Module &M) {
void PIC16DbgInfo::SwitchToCU(MDNode *CU) {
// Get the file path from CU.
DICompileUnit cu(CU);
- std::string DirName = cu.getDirectory();
- std::string FileName = cu.getFilename();
- std::string FilePath = DirName + "/" + FileName;
+ std::string FilePath = "";
+ if (cu.getDirectory()) {
+ std::string DirName = cu.getDirectory();
+ FilePath = FilePath + DirName + "/";
+ }
+ if (cu.getFilename()) {
+ std::string FileName = cu.getFilename();
+ FilePath = FilePath + FileName;
+ }
- // Nothing to do if source file is still same.
- if ( FilePath == CurFile ) return;
+ // Nothing to do if source file is still same or it is empty.
+ if ( FilePath == CurFile || FilePath == "") return;
// Else, close the current one and start a new.
if (CurFile != "") O << "\n\t.eof";