[llvm] r290012 - Allow "line 0" to be the first explicit debug location in a function.
Adrian Prantl via llvm-commits
llvm-commits at lists.llvm.org
Sat Dec 17 13:23:40 PST 2016
Thanks for the quick turnaround! This works.
-- adrian
> On Dec 16, 2016, at 3:54 PM, Paul Robinson via llvm-commits <llvm-commits at lists.llvm.org> wrote:
>
> Author: probinson
> Date: Fri Dec 16 17:54:33 2016
> New Revision: 290012
>
> URL: http://llvm.org/viewvc/llvm-project?rev=290012&view=rev
> Log:
> Allow "line 0" to be the first explicit debug location in a function.
>
> Feedback on r289468 from Adrian Prantl.
>
> Modified:
> llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp
> llvm/trunk/test/DebugInfo/X86/dbg-prolog-end.ll
>
> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=290012&r1=290011&r2=290012&view=diff
> ==============================================================================
> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp (original)
> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp Fri Dec 16 17:54:33 2016
> @@ -1063,7 +1063,7 @@ void DwarfDebug::beginInstruction(const
> // We have an explicit location, different from the previous location.
> // Don't repeat a line-0 record, but otherwise emit the new location.
> // (The new location might be an explicit line 0, which we do emit.)
> - if (DL.getLine() == 0 && LastAsmLine == 0)
> + if (PrevInstLoc && DL.getLine() == 0 && LastAsmLine == 0)
> return;
> unsigned Flags = 0;
> if (DL == PrologEndLoc) {
>
> Modified: llvm/trunk/test/DebugInfo/X86/dbg-prolog-end.ll
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/X86/dbg-prolog-end.ll?rev=290012&r1=290011&r2=290012&view=diff
> ==============================================================================
> --- llvm/trunk/test/DebugInfo/X86/dbg-prolog-end.ll (original)
> +++ llvm/trunk/test/DebugInfo/X86/dbg-prolog-end.ll Fri Dec 16 17:54:33 2016
> @@ -2,6 +2,7 @@
> target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
> target triple = "x86_64-apple-macosx10.6.7"
>
> +;CHECK-LABEL: foo:
> ;CHECK: .loc 1 2 11 prologue_end
> define i32 @foo(i32 %i) nounwind ssp !dbg !1 {
> entry:
> @@ -24,10 +25,13 @@ entry:
>
> declare void @llvm.dbg.declare(metadata, metadata, metadata) nounwind readnone
>
> +;CHECK-LABEL: main:
> +;CHECK: .loc 1 0 0 prologue_end
> +
> define i32 @main() nounwind ssp !dbg !6 {
> entry:
> %retval = alloca i32, align 4
> - store i32 0, i32* %retval
> + store i32 0, i32* %retval, !dbg !22
> %call = call i32 @foo(i32 21), !dbg !16
> ret i32 %call, !dbg !16
> }
> @@ -57,3 +61,4 @@ entry:
> !19 = !DIFile(filename: "/tmp/a.c", directory: "/private/tmp")
> !20 = !{}
> !21 = !{i32 1, !"Debug Info Version", i32 3}
> +!22 = !DILocation(line: 0, column: 0, scope: !17)
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits
More information about the llvm-commits
mailing list