From: Eli Friedman Date: Thu, 29 May 2008 11:08:17 +0000 (+0000) Subject: A couple minor fixes to make debug info usable for arbitrary code: don't X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=32ea35fee916ed73fe343bad2de9a609eb2cca38;p=clang A couple minor fixes to make debug info usable for arbitrary code: don't emit incomplete types, because they crash llc, and always use the logical location as the current location so we don't crash doing invalid queries on CurLoc. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@51675 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGDebugInfo.cpp b/lib/CodeGen/CGDebugInfo.cpp index e703396979..1827fc980c 100644 --- a/lib/CodeGen/CGDebugInfo.cpp +++ b/lib/CodeGen/CGDebugInfo.cpp @@ -77,6 +77,11 @@ CGDebugInfo::~CGDebugInfo() delete SubprogramAnchor; } +void CGDebugInfo::setLocation(SourceLocation loc) +{ + SourceManager &SM = M->getContext().getSourceManager(); + CurLoc = SM.getLogicalLoc(loc); +} /// getCastValueFor - Return a llvm representation for a given debug information /// descriptor cast to an empty struct pointer. @@ -339,6 +344,8 @@ CGDebugInfo::getOrCreateFunctionType(QualType type, llvm::CompileUnitDesc *Unit) llvm::TypeDesc * CGDebugInfo::getOrCreateType(QualType type, llvm::CompileUnitDesc *Unit) { + // TODO: Re-enable once we can generate all types + return 0; if (type.isNull()) return NULL; diff --git a/lib/CodeGen/CGDebugInfo.h b/lib/CodeGen/CGDebugInfo.h index 9ac77a4b0d..4e6626fc4d 100644 --- a/lib/CodeGen/CGDebugInfo.h +++ b/lib/CodeGen/CGDebugInfo.h @@ -80,7 +80,7 @@ public: CGDebugInfo(CodeGenModule *m); ~CGDebugInfo(); - void setLocation(SourceLocation loc) { CurLoc = loc; } + void setLocation(SourceLocation loc); /// EmitStopPoint - Emit a call to llvm.dbg.stoppoint to indicate a change of /// source line.