]> granicus.if.org Git - llvm/commitdiff
Revert "[DWARF] Incorrect prologue end line record."
authorRobert Lougher <rob.lougher@gmail.com>
Tue, 12 Sep 2017 18:23:15 +0000 (18:23 +0000)
committerRobert Lougher <rob.lougher@gmail.com>
Tue, 12 Sep 2017 18:23:15 +0000 (18:23 +0000)
This reverts commit r313047 as it is causing buildbot failure (lldb inline
stepping tests).

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@313057 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/AsmPrinter/DwarfDebug.cpp
test/DebugInfo/X86/invalid-prologue-end.ll [deleted file]

index 835ca1f2852fba54d7aa1cfd02cf33c20f16891d..e44ad4ea3026f5b1e1bc9a0b16161febcc83d24e 100644 (file)
@@ -1158,9 +1158,7 @@ void DwarfDebug::beginInstruction(const MachineInstr *MI) {
     return;
 
   // Check if source location changes, but ignore DBG_VALUE and CFI locations.
-  // If the instruction is part of the function frame setup code, do not emit
-  // any line record, as there is no correspondence with any user code.
-  if (MI->isMetaInstruction() || MI->getFlag(MachineInstr::FrameSetup))
+  if (MI->isMetaInstruction())
     return;
   const DebugLoc &DL = MI->getDebugLoc();
   // When we emit a line-0 record, we don't update PrevInstLoc; so look at
diff --git a/test/DebugInfo/X86/invalid-prologue-end.ll b/test/DebugInfo/X86/invalid-prologue-end.ll
deleted file mode 100644 (file)
index d386666..0000000
+++ /dev/null
@@ -1,91 +0,0 @@
-; RUN: llc -mtriple=x86_64-linux-gnu -filetype=asm %s -o - | FileCheck %s
-
-; The prologue-end line record must be emitted after the last instruction that
-; is part of the function frame setup code and before the instruction that marks
-; the beginning of the function body.
-;
-; For the given test, generated from:
-;
-; 1 extern int get_arg();
-; 2 extern void func(int x);
-; 3
-; 4 int main()
-; 5 {
-; 6   int a;
-; 7   func(get_arg());
-; 8 }
-; 9
-
-; The prologue-end line record is emitted with an incorrect associated address,
-; which causes a debugger to show the beginning of function body to be inside
-; the prologue.
-
-; This can be seen in the following trimmed assembler output:
-;
-; main:
-;   ...
-;      .loc    1 7 0 prologue_end
-;      pushq   %rax
-; .Lcfi0:
-;      .cfi_def_cfa_offset 16
-;      callq   _Z7get_argv
-;   ...
-;      retq
-
-; The instruction 'pushq %rax' is part of the frame setup code.
-
-; The correct location for the prologue-end line information is just before
-; the call to '_Z7get_argv', as illustrated in the following trimmed
-; assembler output:
-;
-; main:
-;   ...
-;      pushq   %rax
-; .Lcfi0:
-;      .cfi_def_cfa_offset 16
-;      .loc    1 7 0 prologue_end
-;      callq   _Z7get_argv
-;   ...
-;      retq
-
-; Check that the generated assembler matches the following sequence:
-
-; CHECK:        pushq  %rax
-; CHECK-NEXT: .Lcfi0:
-; CHECK-NEXT:   .cfi_def_cfa_offset 16
-; CHECK-NEXT:   .loc   1 7 0 prologue_end {{.*}}# invalid-prologue-end.cpp:7:0
-; CHECK-NEXT:   callq  _Z7get_argv
-
-define i32 @main() #0 !dbg !8 {
-  %1 = alloca i32, align 4
-  call void @llvm.dbg.declare(metadata i32* %1, metadata !12, metadata !DIExpression()), !dbg !13
-  %2 = call i32 @_Z7get_argv(), !dbg !14
-  call void @_Z4funci(i32 %2), !dbg !14
-  ret i32 0, !dbg !15
-}
-
-declare void @llvm.dbg.declare(metadata, metadata, metadata) #1
-
-declare void @_Z4funci(i32) #2
-declare i32 @_Z7get_argv() #2
-
-!llvm.dbg.cu = !{!0}
-!llvm.module.flags = !{!3, !4, !5, !6}
-!llvm.ident = !{!7}
-
-!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, file: !1, producer: "clang version 6.0.0 (trunk 312775)", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !2)
-!1 = !DIFile(filename: "invalid-prologue-end.cpp", directory: "D:\5C93830")
-!2 = !{}
-!3 = !{i32 2, !"Dwarf Version", i32 4}
-!4 = !{i32 2, !"Debug Info Version", i32 3}
-!5 = !{i32 1, !"wchar_size", i32 2}
-!6 = !{i32 7, !"PIC Level", i32 2}
-!7 = !{!"clang version 6.0.0 (trunk 312775)"}
-!8 = distinct !DISubprogram(name: "main", scope: !1, file: !1, line: 4, type: !9, isLocal: false, isDefinition: true, scopeLine: 5, flags: DIFlagPrototyped, isOptimized: false, unit: !0, variables: !2)
-!9 = !DISubroutineType(types: !10)
-!10 = !{!11}
-!11 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
-!12 = !DILocalVariable(name: "a", scope: !8, file: !1, line: 6, type: !11)
-!13 = !DILocation(line: 6, scope: !8)
-!14 = !DILocation(line: 7, scope: !8)
-!15 = !DILocation(line: 8, scope: !8)