<p dir="ltr">Do you have a test case by chance?</p>
<div class="gmail_quote">On Jul 2, 2014 10:52 PM, "Bob Wilson" <<a href="mailto:bob.wilson@apple.com">bob.wilson@apple.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
This seems to be breaking a Release+Asserts build of clang with LTO on Darwin:<br>
<br>
Assertion failed: (FnScope->getScopeNode() == DI->second), function beginFunction, file /Users/buildslave/zorg/buildbot/smooshlab/slave-0.8/build.apple-clang-RA_master/clang/src/lib/CodeGen/AsmPrinter/DwarfDebug.cpp, line 1508.<br>
<br>
<br>
> On Jul 2, 2014, at 11:31 AM, David Blaikie <<a href="mailto:dblaikie@gmail.com">dblaikie@gmail.com</a>> wrote:<br>
><br>
> Author: dblaikie<br>
> Date: Wed Jul 2 13:31:35 2014<br>
> New Revision: 212203<br>
><br>
> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=212203&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=212203&view=rev</a><br>
> Log:<br>
> Don't try to construct debug LexicalScopes hierarchy for functions that do not have top level debug information.<br>
><br>
> If a function isn't actually in a CU's subprogram list in the debug info<br>
> metadata, ignore all the DebugLocs and don't try to build scopes, track<br>
> variables, etc.<br>
><br>
> While this is possibly a minor optimization, it's also a correctness fix<br>
> for an incoming patch that will add assertions to LexicalScopes and the<br>
> debug info verifier to ensure that all scope chains lead to debug info<br>
> for the current function.<br>
><br>
> Fix up a few test cases that had broken/incomplete debug info that could<br>
> violate this constraint.<br>
><br>
> Add a test case where this occurs by design (inlining a<br>
> debug-info-having function in an attribute nodebug function - we want<br>
> this to work because /if/ the nodebug function is then inlined into a<br>
> debug-info-having function, it should be fine (and will work fine - we<br>
> just stitch the scopes up as usual), but should the inlining not happen<br>
> we need to not assert fail either).<br>
><br>
> Added:<br>
> llvm/trunk/test/DebugInfo/nodebug.ll<br>
> Modified:<br>
> llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
> llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h<br>
> llvm/trunk/lib/CodeGen/LiveDebugVariables.cpp<br>
> llvm/trunk/lib/CodeGen/LiveDebugVariables.h<br>
> llvm/trunk/test/CodeGen/X86/2010-06-01-DeadArg-DbgInfo.ll<br>
> llvm/trunk/test/CodeGen/X86/dbg-changes-codegen-branch-folding.ll<br>
> llvm/trunk/test/DebugInfo/X86/concrete_out_of_line.ll<br>
><br>
> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=212203&r1=212202&r2=212203&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=212203&r1=212202&r2=212203&view=diff</a><br>
> ==============================================================================<br>
> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp (original)<br>
> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp Wed Jul 2 13:31:35 2014<br>
> @@ -730,6 +730,8 @@ void DwarfDebug::beginModule() {<br>
><br>
> const Module *M = MMI->getModule();<br>
><br>
> + FunctionDIs = makeSubprogramMap(*M);<br>
> +<br>
> // If module has named metadata anchors then use them, otherwise scan the<br>
> // module using debug info finder to collect debug info.<br>
> NamedMDNode *CU_Nodes = M->getNamedMetadata("<a href="http://llvm.dbg.cu" target="_blank">llvm.dbg.cu</a>");<br>
> @@ -1415,6 +1417,10 @@ void DwarfDebug::beginFunction(const Mac<br>
> if (!MMI->hasDebugInfo())<br>
> return;<br>
><br>
> + auto DI = FunctionDIs.find(MF->getFunction());<br>
> + if (DI == FunctionDIs.end())<br>
> + return;<br>
> +<br>
> // Grab the lexical scopes for the function, if we don't have any of those<br>
> // then we're not going to be able to do anything.<br>
> LScopes.initialize(*MF);<br>
> @@ -1430,6 +1436,7 @@ void DwarfDebug::beginFunction(const Mac<br>
> // belongs to so that we add to the correct per-cu line table in the<br>
> // non-asm case.<br>
> LexicalScope *FnScope = LScopes.getCurrentFunctionScope();<br>
> + assert(FnScope->getScopeNode() == DI->second);<br>
> DwarfCompileUnit *TheCU = SPMap.lookup(FnScope->getScopeNode());<br>
> assert(TheCU && "Unable to find compile unit!");<br>
> if (Asm->OutStreamer.hasRawTextSupport())<br>
> @@ -1527,7 +1534,8 @@ void DwarfDebug::endFunction(const Machi<br>
> assert(CurFn == MF);<br>
> assert(CurFn != nullptr);<br>
><br>
> - if (!MMI->hasDebugInfo() || LScopes.empty()) {<br>
> + if (!MMI->hasDebugInfo() || LScopes.empty() ||<br>
> + !FunctionDIs.count(MF->getFunction())) {<br>
> // If we don't have a lexical scope for this function then there will<br>
> // be a hole in the range information. Keep note of this by setting the<br>
> // previously used section to nullptr.<br>
><br>
> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h?rev=212203&r1=212202&r2=212203&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h?rev=212203&r1=212202&r2=212203&view=diff</a><br>
> ==============================================================================<br>
> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h (original)<br>
> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h Wed Jul 2 13:31:35 2014<br>
> @@ -330,6 +330,8 @@ class DwarfDebug : public AsmPrinterHand<br>
> DwarfAccelTable AccelNamespace;<br>
> DwarfAccelTable AccelTypes;<br>
><br>
> + DenseMap<const Function *, DISubprogram> FunctionDIs;<br>
> +<br>
> MCDwarfDwoLineTable *getDwoLineTable(const DwarfCompileUnit &);<br>
><br>
> void addScopeVariable(LexicalScope *LS, DbgVariable *Var);<br>
><br>
> Modified: llvm/trunk/lib/CodeGen/LiveDebugVariables.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/LiveDebugVariables.cpp?rev=212203&r1=212202&r2=212203&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/LiveDebugVariables.cpp?rev=212203&r1=212202&r2=212203&view=diff</a><br>
> ==============================================================================<br>
> --- llvm/trunk/lib/CodeGen/LiveDebugVariables.cpp (original)<br>
> +++ llvm/trunk/lib/CodeGen/LiveDebugVariables.cpp Wed Jul 2 13:31:35 2014<br>
> @@ -329,12 +329,13 @@ class LDVImpl {<br>
> void computeIntervals();<br>
><br>
> public:<br>
> - LDVImpl(LiveDebugVariables *ps) : pass(*ps), EmitDone(false),<br>
> - ModifiedMF(false) {}<br>
> + LDVImpl(LiveDebugVariables *ps)<br>
> + : pass(*ps), MF(nullptr), EmitDone(false), ModifiedMF(false) {}<br>
> bool runOnMachineFunction(MachineFunction &mf);<br>
><br>
> /// clear - Release all memory.<br>
> void clear() {<br>
> + MF = nullptr;<br>
> userValues.clear();<br>
> virtRegToEqClass.clear();<br>
> userVarMap.clear();<br>
> @@ -693,11 +694,11 @@ void LDVImpl::computeIntervals() {<br>
> }<br>
><br>
> bool LDVImpl::runOnMachineFunction(MachineFunction &mf) {<br>
> + clear();<br>
> MF = &mf;<br>
> LIS = &pass.getAnalysis<LiveIntervals>();<br>
> MDT = &pass.getAnalysis<MachineDominatorTree>();<br>
> TRI = mf.getTarget().getRegisterInfo();<br>
> - clear();<br>
> LS.initialize(mf);<br>
> DEBUG(dbgs() << "********** COMPUTING LIVE DEBUG VARIABLES: "<br>
> << mf.getName() << " **********\n");<br>
> @@ -712,6 +713,8 @@ bool LDVImpl::runOnMachineFunction(Machi<br>
> bool LiveDebugVariables::runOnMachineFunction(MachineFunction &mf) {<br>
> if (!EnableLDV)<br>
> return false;<br>
> + if (!FunctionDIs.count(mf.getFunction()))<br>
> + return false;<br>
> if (!pImpl)<br>
> pImpl = new LDVImpl(this);<br>
> return static_cast<LDVImpl*>(pImpl)->runOnMachineFunction(mf);<br>
> @@ -974,6 +977,8 @@ void UserValue::emitDebugValues(VirtRegM<br>
><br>
> void LDVImpl::emitDebugValues(VirtRegMap *VRM) {<br>
> DEBUG(dbgs() << "********** EMITTING LIVE DEBUG VARIABLES **********\n");<br>
> + if (!MF)<br>
> + return;<br>
> const TargetInstrInfo *TII = MF->getTarget().getInstrInfo();<br>
> for (unsigned i = 0, e = userValues.size(); i != e; ++i) {<br>
> DEBUG(userValues[i]->print(dbgs(), &MF->getTarget()));<br>
> @@ -988,6 +993,10 @@ void LiveDebugVariables::emitDebugValues<br>
> static_cast<LDVImpl*>(pImpl)->emitDebugValues(VRM);<br>
> }<br>
><br>
> +bool LiveDebugVariables::doInitialization(Module &M) {<br>
> + FunctionDIs = makeSubprogramMap(M);<br>
> + return Pass::doInitialization(M);<br>
> +}<br>
><br>
> #ifndef NDEBUG<br>
> void LiveDebugVariables::dump() {<br>
><br>
> Modified: llvm/trunk/lib/CodeGen/LiveDebugVariables.h<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/LiveDebugVariables.h?rev=212203&r1=212202&r2=212203&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/LiveDebugVariables.h?rev=212203&r1=212202&r2=212203&view=diff</a><br>
> ==============================================================================<br>
> --- llvm/trunk/lib/CodeGen/LiveDebugVariables.h (original)<br>
> +++ llvm/trunk/lib/CodeGen/LiveDebugVariables.h Wed Jul 2 13:31:35 2014<br>
> @@ -22,6 +22,7 @@<br>
> #define LLVM_CODEGEN_LIVEDEBUGVARIABLES_H<br>
><br>
> #include "llvm/ADT/ArrayRef.h"<br>
> +#include "llvm/IR/DebugInfo.h"<br>
> #include "llvm/CodeGen/MachineFunctionPass.h"<br>
><br>
> namespace llvm {<br>
> @@ -32,6 +33,7 @@ class VirtRegMap;<br>
><br>
> class LiveDebugVariables : public MachineFunctionPass {<br>
> void *pImpl;<br>
> + DenseMap<const Function*, DISubprogram> FunctionDIs;<br>
> public:<br>
> static char ID; // Pass identification, replacement for typeid<br>
><br>
> @@ -64,6 +66,7 @@ private:<br>
> bool runOnMachineFunction(MachineFunction &) override;<br>
> void releaseMemory() override;<br>
> void getAnalysisUsage(AnalysisUsage &) const override;<br>
> + bool doInitialization(Module &) override;<br>
><br>
> };<br>
><br>
><br>
> Modified: llvm/trunk/test/CodeGen/X86/2010-06-01-DeadArg-DbgInfo.ll<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/2010-06-01-DeadArg-DbgInfo.ll?rev=212203&r1=212202&r2=212203&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/2010-06-01-DeadArg-DbgInfo.ll?rev=212203&r1=212202&r2=212203&view=diff</a><br>
> ==============================================================================<br>
> --- llvm/trunk/test/CodeGen/X86/2010-06-01-DeadArg-DbgInfo.ll (original)<br>
> +++ llvm/trunk/test/CodeGen/X86/2010-06-01-DeadArg-DbgInfo.ll Wed Jul 2 13:31:35 2014<br>
> @@ -24,7 +24,7 @@ declare void @llvm.dbg.value(metadata, i<br>
> !<a href="http://llvm.dbg.lv" target="_blank">llvm.dbg.lv</a> = !{!0, !14, !15, !16, !17, !24, !25, !28}<br>
><br>
> !0 = metadata !{i32 786689, metadata !1, metadata !"this", metadata !3, i32 11, metadata !12, i32 0, null} ; [ DW_TAG_arg_variable ]<br>
> -!1 = metadata !{i32 786478, metadata !31, metadata !2, metadata !"bar", metadata !"bar", metadata !"_ZN3foo3barEi", i32 11, metadata !9, i1 false, i1 true, i32 0, i32 0, null, i32 0, i1 true, i32 (%struct.foo*, i32)* @_ZN3foo3bazEi, null, null, null, i32 11} ; [ DW_TAG_subprogram ]<br>
> +!1 = metadata !{i32 786478, metadata !31, metadata !2, metadata !"bar", metadata !"bar", metadata !"_ZN3foo3barEi", i32 11, metadata !9, i1 false, i1 true, i32 0, i32 0, null, i32 0, i1 true, i32 (%struct.foo*, i32)* null, null, null, null, i32 11} ; [ DW_TAG_subprogram ]<br>
> !2 = metadata !{i32 786451, metadata !31, metadata !3, metadata !"foo", i32 3, i64 32, i64 32, i64 0, i32 0, null, metadata !5, i32 0, null, null, null} ; [ DW_TAG_structure_type ] [foo] [line 3, size 32, align 32, offset 0] [def] [from ]<br>
> !3 = metadata !{i32 786473, metadata !31} ; [ DW_TAG_file_type ]<br>
> !4 = metadata !{i32 786449, metadata !31, i32 4, metadata !"4.2.1 LLVM build", i1 true, metadata !"", i32 0, metadata !32, metadata !32, metadata !33, null, null, metadata !""} ; [ DW_TAG_compile_unit ]<br>
><br>
> Modified: llvm/trunk/test/CodeGen/X86/dbg-changes-codegen-branch-folding.ll<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/dbg-changes-codegen-branch-folding.ll?rev=212203&r1=212202&r2=212203&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/dbg-changes-codegen-branch-folding.ll?rev=212203&r1=212202&r2=212203&view=diff</a><br>
> ==============================================================================<br>
> --- llvm/trunk/test/CodeGen/X86/dbg-changes-codegen-branch-folding.ll (original)<br>
> +++ llvm/trunk/test/CodeGen/X86/dbg-changes-codegen-branch-folding.ll Wed Jul 2 13:31:35 2014<br>
> @@ -52,58 +52,153 @@ define void @_Z3barii(i32 %param1, i32 %<br>
> entry:<br>
> %var1 = alloca %struct.AAA3, align 1<br>
> %var2 = alloca %struct.AAA3, align 1<br>
> - %tobool = icmp eq i32 %param2, 0<br>
> - br i1 %tobool, label %if.end, label %if.then<br>
> + tail call void @llvm.dbg.value(metadata !{i32 %param1}, i64 0, metadata !30), !dbg !47<br>
> + tail call void @llvm.dbg.value(metadata !{i32 %param2}, i64 0, metadata !31), !dbg !47<br>
> + tail call void @llvm.dbg.value(metadata !48, i64 0, metadata !32), !dbg !49<br>
> + %tobool = icmp eq i32 %param2, 0, !dbg !50<br>
> + br i1 %tobool, label %if.end, label %if.then, !dbg !50<br>
><br>
> if.then: ; preds = %entry<br>
> - %call = call i8* @_Z5i2stri(i32 %param2)<br>
> - br label %if.end<br>
> + %call = tail call i8* @_Z5i2stri(i32 %param2), !dbg !52<br>
> + tail call void @llvm.dbg.value(metadata !{i8* %call}, i64 0, metadata !32), !dbg !49<br>
> + br label %if.end, !dbg !54<br>
><br>
> if.end: ; preds = %entry, %if.then<br>
> - call void @llvm.dbg.value(metadata !{%struct.AAA3* %var1}, i64 0, metadata !60)<br>
> - call void @llvm.dbg.value(metadata !62, i64 0, metadata !63)<br>
> - %arraydecay.i = getelementptr inbounds %struct.AAA3* %var1, i64 0, i32 0, i64 0<br>
> - call void @_Z3fooPcjPKc(i8* %arraydecay.i, i32 4, i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0))<br>
> - call void @llvm.dbg.declare(metadata !{%struct.AAA3* %var2}, metadata !38)<br>
> - %arraydecay.i5 = getelementptr inbounds %struct.AAA3* %var2, i64 0, i32 0, i64 0<br>
> - call void @_Z3fooPcjPKc(i8* %arraydecay.i5, i32 4, i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0))<br>
> - %tobool1 = icmp eq i32 %param1, 0<br>
> - br i1 %tobool1, label %if.else, label %if.then2<br>
> + tail call void @llvm.dbg.value(metadata !{%struct.AAA3* %var1}, i64 0, metadata !33), !dbg !55<br>
> + tail call void @llvm.dbg.value(metadata !{%struct.AAA3* %var1}, i64 0, metadata !56), !dbg !57<br>
> + tail call void @llvm.dbg.value(metadata !58, i64 0, metadata !59), !dbg !60<br>
> + %arraydecay.i = getelementptr inbounds %struct.AAA3* %var1, i64 0, i32 0, i64 0, !dbg !61<br>
> + call void @_Z3fooPcjPKc(i8* %arraydecay.i, i32 4, i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0)), !dbg !61<br>
> + call void @llvm.dbg.value(metadata !{%struct.AAA3* %var2}, i64 0, metadata !34), !dbg !63<br>
> + call void @llvm.dbg.value(metadata !{%struct.AAA3* %var2}, i64 0, metadata !64), !dbg !65<br>
> + call void @llvm.dbg.value(metadata !58, i64 0, metadata !66), !dbg !67<br>
> + %arraydecay.i5 = getelementptr inbounds %struct.AAA3* %var2, i64 0, i32 0, i64 0, !dbg !68<br>
> + call void @_Z3fooPcjPKc(i8* %arraydecay.i5, i32 4, i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0)), !dbg !68<br>
> + %tobool1 = icmp eq i32 %param1, 0, !dbg !69<br>
> + call void @llvm.dbg.value(metadata !{%struct.AAA3* %var2}, i64 0, metadata !34), !dbg !63<br>
> + br i1 %tobool1, label %if.else, label %if.then2, !dbg !69<br>
><br>
> if.then2: ; preds = %if.end<br>
> - call void @_Z3fooPcjPKc(i8* %arraydecay.i5, i32 4, i8* getelementptr inbounds ([2 x i8]* @.str1, i64 0, i64 0))<br>
> - br label %if.end3<br>
> + call void @llvm.dbg.value(metadata !{%struct.AAA3* %var2}, i64 0, metadata !71), !dbg !73<br>
> + call void @llvm.dbg.value(metadata !74, i64 0, metadata !75), !dbg !76<br>
> + call void @_Z3fooPcjPKc(i8* %arraydecay.i5, i32 4, i8* getelementptr inbounds ([2 x i8]* @.str1, i64 0, i64 0)), !dbg !76<br>
> + br label %if.end3, !dbg !72<br>
><br>
> if.else: ; preds = %if.end<br>
> - call void @_Z3fooPcjPKc(i8* %arraydecay.i5, i32 4, i8* getelementptr inbounds ([2 x i8]* @.str2, i64 0, i64 0))<br>
> + call void @llvm.dbg.value(metadata !{%struct.AAA3* %var2}, i64 0, metadata !77), !dbg !79<br>
> + call void @llvm.dbg.value(metadata !80, i64 0, metadata !81), !dbg !82<br>
> + call void @_Z3fooPcjPKc(i8* %arraydecay.i5, i32 4, i8* getelementptr inbounds ([2 x i8]* @.str2, i64 0, i64 0)), !dbg !82<br>
> br label %if.end3<br>
><br>
> if.end3: ; preds = %if.else, %if.then2<br>
> - call void @_Z3fooPcjPKc(i8* %arraydecay.i, i32 4, i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0))<br>
> - ret void<br>
> + call void @llvm.dbg.value(metadata !{%struct.AAA3* %var1}, i64 0, metadata !33), !dbg !55<br>
> + call void @llvm.dbg.value(metadata !{%struct.AAA3* %var1}, i64 0, metadata !83), !dbg !85<br>
> + call void @llvm.dbg.value(metadata !58, i64 0, metadata !86), !dbg !87<br>
> + call void @_Z3fooPcjPKc(i8* %arraydecay.i, i32 4, i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0)), !dbg !87<br>
> + ret void, !dbg !88<br>
> }<br>
><br>
> -; Function Attrs: nounwind readnone<br>
> -declare void @llvm.dbg.declare(metadata, metadata) #1<br>
> -<br>
> -declare i8* @_Z5i2stri(i32) #2<br>
> +declare i8* @_Z5i2stri(i32) #1<br>
><br>
> -declare void @_Z3fooPcjPKc(i8*, i32, i8*) #2<br>
> +declare void @_Z3fooPcjPKc(i8*, i32, i8*) #1<br>
><br>
> ; Function Attrs: nounwind readnone<br>
> -declare void @llvm.dbg.value(metadata, i64, metadata) #1<br>
> +declare void @llvm.dbg.value(metadata, i64, metadata) #2<br>
><br>
> attributes #0 = { uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }<br>
> -attributes #1 = { nounwind readnone }<br>
> -attributes #2 = { "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }<br>
> -<br>
> -!llvm.module.flags = !{!48, !49}<br>
> -!llvm.ident = !{!50}<br>
> +attributes #1 = { "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }<br>
> +attributes #2 = { nounwind readnone }<br>
><br>
> -!38 = metadata !{i32 786688, null, metadata !"var2", null, i32 20, null, i32 0, i32 0} ; [ DW_TAG_auto_variable ] [var2] [line 20]<br>
> -!48 = metadata !{i32 2, metadata !"Dwarf Version", i32 4}<br>
> -!49 = metadata !{i32 1, metadata !"Debug Info Version", i32 1}<br>
> -!50 = metadata !{metadata !"clang version 3.5 (202418)"}<br>
> -!60 = metadata !{i32 786689, null, metadata !"this", null, i32 16777216, null, i32 1088, null} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> -!62 = metadata !{i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0)}<br>
> -!63 = metadata !{i32 786689, null, metadata !"value", null, i32 33554439, null, i32 0, null} ; [ DW_TAG_arg_variable ] [value] [line 7]<br>
> +!<a href="http://llvm.dbg.cu" target="_blank">llvm.dbg.cu</a> = !{!0}<br>
> +!llvm.module.flags = !{!44, !45}<br>
> +!llvm.ident = !{!46}<br>
> +<br>
> +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.5.0 ", i1 true, metadata !"", i32 0, metadata !2, metadata !3, metadata !23, metadata !2, metadata !2, metadata !"", i32 1} ; [ DW_TAG_compile_unit ] [/tmp/dbginfo/dbg-changes-codegen-branch-folding.cpp] [DW_LANG_C_plus_plus]<br>
> +!1 = metadata !{metadata !"dbg-changes-codegen-branch-folding.cpp", metadata !"/tmp/dbginfo"}<br>
> +!2 = metadata !{}<br>
> +!3 = metadata !{metadata !4}<br>
> +!4 = metadata !{i32 786451, metadata !1, null, metadata !"AAA3", i32 4, i64 32, i64 8, i32 0, i32 0, null, metadata !5, i32 0, null, null, metadata !"_ZTS4AAA3"} ; [ DW_TAG_structure_type ] [AAA3] [line 4, size 32, align 8, offset 0] [def] [from ]<br>
> +!5 = metadata !{metadata !6, metadata !11, metadata !17, metadata !18}<br>
> +!6 = metadata !{i32 786445, metadata !1, metadata !"_ZTS4AAA3", metadata !"text", i32 8, i64 32, i64 8, i64 0, i32 0, metadata !7} ; [ DW_TAG_member ] [text] [line 8, size 32, align 8, offset 0] [from ]<br>
> +!7 = metadata !{i32 786433, null, null, metadata !"", i32 0, i64 32, i64 8, i32 0, i32 0, metadata !8, metadata !9, i32 0, null, null, null} ; [ DW_TAG_array_type ] [line 0, size 32, align 8, offset 0] [from char]<br>
> +!8 = metadata !{i32 786468, null, null, metadata !"char", i32 0, i64 8, i64 8, i64 0, i32 0, i32 6} ; [ DW_TAG_base_type ] [char] [line 0, size 8, align 8, offset 0, enc DW_ATE_signed_char]<br>
> +!9 = metadata !{metadata !10}<br>
> +!10 = metadata !{i32 786465, i64 0, i64 4} ; [ DW_TAG_subrange_type ] [0, 3]<br>
> +!11 = metadata !{i32 786478, metadata !1, metadata !"_ZTS4AAA3", metadata !"AAA3", metadata !"AAA3", metadata !"", i32 5, metadata !12, i1 false, i1 false, i32 0, i32 0, null, i32 256, i1 true, null, null, i32 0, null, i32 5} ; [ DW_TAG_subprogram ] [line 5] [AAA3]<br>
> +!12 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !13, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> +!13 = metadata !{null, metadata !14, metadata !15}<br>
> +!14 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !"_ZTS4AAA3"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from _ZTS4AAA3]<br>
> +!15 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 0, metadata !16} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [from ]<br>
> +!16 = metadata !{i32 786470, null, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, metadata !8} ; [ DW_TAG_const_type ] [line 0, size 0, align 0, offset 0] [from char]<br>
> +!17 = metadata !{i32 786478, metadata !1, metadata !"_ZTS4AAA3", metadata !"operator=", metadata !"operator=", metadata !"_ZN4AAA3aSEPKc", i32 6, metadata !12, i1 false, i1 false, i32 0, i32 0, null, i32 256, i1 true, null, null, i32 0, null, i32 6} ; [ DW_TAG_subprogram ] [line 6] [operator=]<br>
> +!18 = metadata !{i32 786478, metadata !1, metadata !"_ZTS4AAA3", metadata !"operator const char *", metadata !"operator const char *", metadata !"_ZNK4AAA3cvPKcEv", i32 7, metadata !19, i1 false, i1 false, i32 0, i32 0, null, i32 256, i1 true, null, null, i32 0, null, i32 7} ; [ DW_TAG_subprogram ] [line 7] [operator const char *]<br>
> +!19 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !20, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> +!20 = metadata !{metadata !15, metadata !21}<br>
> +!21 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !22} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from ]<br>
> +!22 = metadata !{i32 786470, null, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, metadata !"_ZTS4AAA3"} ; [ DW_TAG_const_type ] [line 0, size 0, align 0, offset 0] [from _ZTS4AAA3]<br>
> +!23 = metadata !{metadata !24, metadata !35, metadata !40}<br>
> +!24 = metadata !{i32 786478, metadata !1, metadata !25, metadata !"bar", metadata !"bar", metadata !"_Z3barii", i32 11, metadata !26, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, void (i32, i32)* @_Z3barii, null, null, metadata !29, i32 11} ; [ DW_TAG_subprogram ] [line 11] [def] [bar]<br>
> +!25 = metadata !{i32 786473, metadata !1} ; [ DW_TAG_file_type ] [/tmp/dbginfo/dbg-changes-codegen-branch-folding.cpp]<br>
> +!26 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !27, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> +!27 = metadata !{null, metadata !28, metadata !28}<br>
> +!28 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed]<br>
> +!29 = metadata !{metadata !30, metadata !31, metadata !32, metadata !33, metadata !34}<br>
> +!30 = metadata !{i32 786689, metadata !24, metadata !"param1", metadata !25, i32 16777227, metadata !28, i32 0, i32 0} ; [ DW_TAG_arg_variable ] [param1] [line 11]<br>
> +!31 = metadata !{i32 786689, metadata !24, metadata !"param2", metadata !25, i32 33554443, metadata !28, i32 0, i32 0} ; [ DW_TAG_arg_variable ] [param2] [line 11]<br>
> +!32 = metadata !{i32 786688, metadata !24, metadata !"temp", metadata !25, i32 12, metadata !15, i32 0, i32 0} ; [ DW_TAG_auto_variable ] [temp] [line 12]<br>
> +!33 = metadata !{i32 786688, metadata !24, metadata !"var1", metadata !25, i32 17, metadata !"_ZTS4AAA3", i32 0, i32 0} ; [ DW_TAG_auto_variable ] [var1] [line 17]<br>
> +!34 = metadata !{i32 786688, metadata !24, metadata !"var2", metadata !25, i32 18, metadata !"_ZTS4AAA3", i32 0, i32 0} ; [ DW_TAG_auto_variable ] [var2] [line 18]<br>
> +!35 = metadata !{i32 786478, metadata !1, metadata !"_ZTS4AAA3", metadata !"operator=", metadata !"operator=", metadata !"_ZN4AAA3aSEPKc", i32 6, metadata !12, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, null, null, metadata !17, metadata !36, i32 6} ; [ DW_TAG_subprogram ] [line 6] [def] [operator=]<br>
> +!36 = metadata !{metadata !37, metadata !39}<br>
> +!37 = metadata !{i32 786689, metadata !35, metadata !"this", null, i32 16777216, metadata !38, i32 1088, i32 0} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> +!38 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 0, metadata !"_ZTS4AAA3"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [from _ZTS4AAA3]<br>
> +!39 = metadata !{i32 786689, metadata !35, metadata !"value", metadata !25, i32 33554438, metadata !15, i32 0, i32 0} ; [ DW_TAG_arg_variable ] [value] [line 6]<br>
> +!40 = metadata !{i32 786478, metadata !1, metadata !"_ZTS4AAA3", metadata !"AAA3", metadata !"AAA3", metadata !"_ZN4AAA3C2EPKc", i32 5, metadata !12, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, null, null, metadata !11, metadata !41, i32 5} ; [ DW_TAG_subprogram ] [line 5] [def] [AAA3]<br>
> +!41 = metadata !{metadata !42, metadata !43}<br>
> +!42 = metadata !{i32 786689, metadata !40, metadata !"this", null, i32 16777216, metadata !38, i32 1088, i32 0} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> +!43 = metadata !{i32 786689, metadata !40, metadata !"value", metadata !25, i32 33554437, metadata !15, i32 0, i32 0} ; [ DW_TAG_arg_variable ] [value] [line 5]<br>
> +!44 = metadata !{i32 2, metadata !"Dwarf Version", i32 4}<br>
> +!45 = metadata !{i32 2, metadata !"Debug Info Version", i32 1}<br>
> +!46 = metadata !{metadata !"clang version 3.5.0 "}<br>
> +!47 = metadata !{i32 11, i32 0, metadata !24, null}<br>
> +!48 = metadata !{i8* null}<br>
> +!49 = metadata !{i32 12, i32 0, metadata !24, null}<br>
> +!50 = metadata !{i32 14, i32 0, metadata !51, null}<br>
> +!51 = metadata !{i32 786443, metadata !1, metadata !24, i32 14, i32 0, i32 0, i32 0} ; [ DW_TAG_lexical_block ] [/tmp/dbginfo/dbg-changes-codegen-branch-folding.cpp]<br>
> +!52 = metadata !{i32 15, i32 0, metadata !53, null}<br>
> +!53 = metadata !{i32 786443, metadata !1, metadata !51, i32 14, i32 0, i32 0, i32 1} ; [ DW_TAG_lexical_block ] [/tmp/dbginfo/dbg-changes-codegen-branch-folding.cpp]<br>
> +!54 = metadata !{i32 16, i32 0, metadata !53, null}<br>
> +!55 = metadata !{i32 17, i32 0, metadata !24, null}<br>
> +!56 = metadata !{i32 786689, metadata !40, metadata !"this", null, i32 16777216, metadata !38, i32 1088, metadata !55} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> +!57 = metadata !{i32 0, i32 0, metadata !40, metadata !55}<br>
> +!58 = metadata !{i8* getelementptr inbounds ([1 x i8]* @.str, i64 0, i64 0)}<br>
> +!59 = metadata !{i32 786689, metadata !40, metadata !"value", metadata !25, i32 33554437, metadata !15, i32 0, metadata !55} ; [ DW_TAG_arg_variable ] [value] [line 5]<br>
> +!60 = metadata !{i32 5, i32 0, metadata !40, metadata !55}<br>
> +!61 = metadata !{i32 5, i32 0, metadata !62, metadata !55}<br>
> +!62 = metadata !{i32 786443, metadata !1, metadata !40, i32 5, i32 0, i32 0, i32 3} ; [ DW_TAG_lexical_block ] [/tmp/dbginfo/dbg-changes-codegen-branch-folding.cpp]<br>
> +!63 = metadata !{i32 18, i32 0, metadata !24, null}<br>
> +!64 = metadata !{i32 786689, metadata !40, metadata !"this", null, i32 16777216, metadata !38, i32 1088, metadata !63} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> +!65 = metadata !{i32 0, i32 0, metadata !40, metadata !63}<br>
> +!66 = metadata !{i32 786689, metadata !40, metadata !"value", metadata !25, i32 33554437, metadata !15, i32 0, metadata !63} ; [ DW_TAG_arg_variable ] [value] [line 5]<br>
> +!67 = metadata !{i32 5, i32 0, metadata !40, metadata !63}<br>
> +!68 = metadata !{i32 5, i32 0, metadata !62, metadata !63}<br>
> +!69 = metadata !{i32 20, i32 0, metadata !70, null}<br>
> +!70 = metadata !{i32 786443, metadata !1, metadata !24, i32 20, i32 0, i32 0, i32 2} ; [ DW_TAG_lexical_block ] [/tmp/dbginfo/dbg-changes-codegen-branch-folding.cpp]<br>
> +!71 = metadata !{i32 786689, metadata !35, metadata !"this", null, i32 16777216, metadata !38, i32 1088, metadata !72} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> +!72 = metadata !{i32 21, i32 0, metadata !70, null}<br>
> +!73 = metadata !{i32 0, i32 0, metadata !35, metadata !72}<br>
> +!74 = metadata !{i8* getelementptr inbounds ([2 x i8]* @.str1, i64 0, i64 0)}<br>
> +!75 = metadata !{i32 786689, metadata !35, metadata !"value", metadata !25, i32 33554438, metadata !15, i32 0, metadata !72} ; [ DW_TAG_arg_variable ] [value] [line 6]<br>
> +!76 = metadata !{i32 6, i32 0, metadata !35, metadata !72}<br>
> +!77 = metadata !{i32 786689, metadata !35, metadata !"this", null, i32 16777216, metadata !38, i32 1088, metadata !78} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> +!78 = metadata !{i32 23, i32 0, metadata !70, null}<br>
> +!79 = metadata !{i32 0, i32 0, metadata !35, metadata !78}<br>
> +!80 = metadata !{i8* getelementptr inbounds ([2 x i8]* @.str2, i64 0, i64 0)}<br>
> +!81 = metadata !{i32 786689, metadata !35, metadata !"value", metadata !25, i32 33554438, metadata !15, i32 0, metadata !78} ; [ DW_TAG_arg_variable ] [value] [line 6]<br>
> +!82 = metadata !{i32 6, i32 0, metadata !35, metadata !78}<br>
> +!83 = metadata !{i32 786689, metadata !35, metadata !"this", null, i32 16777216, metadata !38, i32 1088, metadata !84} ; [ DW_TAG_arg_variable ] [this] [line 0]<br>
> +!84 = metadata !{i32 24, i32 0, metadata !24, null}<br>
> +!85 = metadata !{i32 0, i32 0, metadata !35, metadata !84}<br>
> +!86 = metadata !{i32 786689, metadata !35, metadata !"value", metadata !25, i32 33554438, metadata !15, i32 0, metadata !84} ; [ DW_TAG_arg_variable ] [value] [line 6]<br>
> +!87 = metadata !{i32 6, i32 0, metadata !35, metadata !84}<br>
> +!88 = metadata !{i32 25, i32 0, metadata !24, null}<br>
><br>
> Modified: llvm/trunk/test/DebugInfo/X86/concrete_out_of_line.ll<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/concrete_out_of_line.ll?rev=212203&r1=212202&r2=212203&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/concrete_out_of_line.ll?rev=212203&r1=212202&r2=212203&view=diff</a><br>
> ==============================================================================<br>
> --- llvm/trunk/test/DebugInfo/X86/concrete_out_of_line.ll (original)<br>
> +++ llvm/trunk/test/DebugInfo/X86/concrete_out_of_line.ll Wed Jul 2 13:31:35 2014<br>
> @@ -79,7 +79,7 @@ declare void @_Z8moz_freePv(i8*)<br>
> !0 = metadata !{i32 786449, metadata !59, i32 4, metadata !"clang version 3.1 ()", i1 true, metadata !"", i32 0, metadata !1, metadata !1, metadata !3, metadata !47, metadata !1, metadata !""} ; [ DW_TAG_compile_unit ]<br>
> !1 = metadata !{}<br>
> !3 = metadata !{metadata !5, metadata !23, metadata !27, metadata !31}<br>
> -!5 = metadata !{i32 720942, metadata !6, null, metadata !"Release", metadata !"Release", metadata !"_ZN17nsAutoRefCnt7ReleaseEv", i32 14, metadata !7, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, i32* null, null, metadata !12, metadata !20, i32 14} ; [ DW_TAG_subprogram ] [line 14] [def] [Release]<br>
> +!5 = metadata !{i32 720942, metadata !6, null, metadata !"Release", metadata !"Release", metadata !"_ZN17nsAutoRefCnt7ReleaseEv", i32 14, metadata !7, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, i32 ()* @_ZN17nsAutoRefCnt7ReleaseEv , null, metadata !12, metadata !20, i32 14} ; [ DW_TAG_subprogram ] [line 14] [def] [Release]<br>
> !6 = metadata !{i32 720937, metadata !59} ; [ DW_TAG_file_type ]<br>
> !7 = metadata !{i32 720917, i32 0, null, i32 0, i32 0, i64 0, i64 0, i32 0, i32 0, null, metadata !8, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> !8 = metadata !{metadata !9, metadata !10}<br>
> @@ -95,7 +95,7 @@ declare void @_Z8moz_freePv(i8*)<br>
> !18 = metadata !{}<br>
> !20 = metadata !{metadata !22}<br>
> !22 = metadata !{i32 786689, metadata !5, metadata !"this", metadata !6, i32 16777230, metadata !10, i32 64, i32 0} ; [ DW_TAG_arg_variable ]<br>
> -!23 = metadata !{i32 720942, metadata !6, null, metadata !"~nsAutoRefCnt", metadata !"~nsAutoRefCnt", metadata !"_ZN17nsAutoRefCntD1Ev", i32 18, metadata !16, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, i32* null, null, metadata !15, metadata !24, i32 18} ; [ DW_TAG_subprogram ] [line 18] [def] [~nsAutoRefCnt]<br>
> +!23 = metadata !{i32 720942, metadata !6, null, metadata !"~nsAutoRefCnt", metadata !"~nsAutoRefCnt", metadata !"_ZN17nsAutoRefCntD1Ev", i32 18, metadata !16, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, void ()* @_ZN17nsAutoRefCntD1Ev, null, metadata !15, metadata !24, i32 18} ; [ DW_TAG_subprogram ] [line 18] [def] [~nsAutoRefCnt]<br>
> !24 = metadata !{metadata !26}<br>
> !26 = metadata !{i32 786689, metadata !23, metadata !"this", metadata !6, i32 16777234, metadata !10, i32 64, i32 0} ; [ DW_TAG_arg_variable ]<br>
> !27 = metadata !{i32 720942, metadata !6, null, metadata !"~nsAutoRefCnt", metadata !"~nsAutoRefCnt", metadata !"_ZN17nsAutoRefCntD2Ev", i32 18, metadata !16, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, i32* null, null, metadata !15, metadata !28, i32 18} ; [ DW_TAG_subprogram ] [line 18] [def] [~nsAutoRefCnt]<br>
><br>
> Added: llvm/trunk/test/DebugInfo/nodebug.ll<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/nodebug.ll?rev=212203&view=auto" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/nodebug.ll?rev=212203&view=auto</a><br>
> ==============================================================================<br>
> --- llvm/trunk/test/DebugInfo/nodebug.ll (added)<br>
> +++ llvm/trunk/test/DebugInfo/nodebug.ll Wed Jul 2 13:31:35 2014<br>
> @@ -0,0 +1,51 @@<br>
> +; REQUIRES: object-emission<br>
> +<br>
> +; RUN: %llc_dwarf < %s -filetype=obj | llvm-dwarfdump -debug-dump=info - | FileCheck %s<br>
> +<br>
> +; Test that a nodebug function (a function not appearing in the debug info IR<br>
> +; metadata subprogram list) with DebugLocs on its IR doesn't cause crashes/does<br>
> +; the right thing.<br>
> +<br>
> +; Build with clang from the following:<br>
> +; extern int i;<br>
> +; inline __attribute__((always_inline)) void f1() {<br>
> +; i = 3;<br>
> +; }<br>
> +;<br>
> +; __attribute__((nodebug)) void f2() {<br>
> +; f1();<br>
> +; }<br>
> +<br>
> +; Check that there's only one DW_TAG_subprogram, nothing for the 'f2' function.<br>
> +; CHECK: DW_TAG_subprogram<br>
> +; CHECK-NOT: DW_TAG<br>
> +; CHECK: DW_AT_name {{.*}} "f1"<br>
> +; CHECK-NOT: DW_TAG_subprogram<br>
> +<br>
> +@i = external global i32<br>
> +<br>
> +; Function Attrs: uwtable<br>
> +define void @_Z2f2v() #0 {<br>
> +entry:<br>
> + store i32 3, i32* @i, align 4, !dbg !11<br>
> + ret void<br>
> +}<br>
> +<br>
> +attributes #0 = { uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }<br>
> +<br>
> +!<a href="http://llvm.dbg.cu" target="_blank">llvm.dbg.cu</a> = !{!0}<br>
> +!llvm.module.flags = !{!8, !9}<br>
> +!llvm.ident = !{!10}<br>
> +<br>
> +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.5.0 ", i1 false, metadata !"", i32 0, metadata !2, metadata !2, metadata !3, metadata !2, metadata !2, metadata !"", i32 1} ; [ DW_TAG_compile_unit ] [/tmp/dbginfo/nodebug.cpp] [DW_LANG_C_plus_plus]<br>
> +!1 = metadata !{metadata !"nodebug.cpp", metadata !"/tmp/dbginfo"}<br>
> +!2 = metadata !{}<br>
> +!3 = metadata !{metadata !4}<br>
> +!4 = metadata !{i32 786478, metadata !1, metadata !5, metadata !"f1", metadata !"f1", metadata !"_Z2f1v", i32 2, metadata !6, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, null, null, null, metadata !2, i32 2} ; [ DW_TAG_subprogram ] [line 2] [def] [f1]<br>
> +!5 = metadata !{i32 786473, metadata !1} ; [ DW_TAG_file_type ] [/tmp/dbginfo/nodebug.cpp]<br>
> +!6 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !7, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>
> +!7 = metadata !{null}<br>
> +!8 = metadata !{i32 2, metadata !"Dwarf Version", i32 4}<br>
> +!9 = metadata !{i32 2, metadata !"Debug Info Version", i32 1}<br>
> +!10 = metadata !{metadata !"clang version 3.5.0 "}<br>
> +!11 = metadata !{i32 3, i32 0, metadata !4, null}<br>
><br>
><br>
> _______________________________________________<br>
> llvm-commits mailing list<br>
> <a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
<br>
</blockquote></div>