[PATCH] D50621: [DebugInfo] Fix bug in LiveDebugVariables.
Bjorn Pettersson via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Aug 23 10:04:36 PDT 2018
bjope added inline comments.
================
Comment at: llvm/trunk/test/DebugInfo/Generic/debug-var-slot.ll:8
+;
+; RUN: llc < %s -stop-after=livedebugvars -debug 2>&1 | FileCheck %s
+;
----------------
chandlerc wrote:
> You cannot use `-debug` in test cases reliably.
>
> Adrian actually specifically suggested a way of testing this, please follow up there before submitting (and for the reviewer, please make sure that other commenters on a patch are OK with proceeding).
>
> I'm going to revert for now as it is breaking bots and any user not building with asserts.
Sorry @chandlerc . I actually read Adrians comments, but must have missed that last part about doing the CHECKs on the MIR-output (the other requests from Adrian had been fixed and the comment was marked as "Done").
@HsiangKai , if I write a test case like this it asserts without your patch, so maybe this is a more narrow test case (I haven't tried it with your patch so please look at the CHECK lines to see if this matches your problem):
```
# RUN: llc -run-pass=livedebugvars -o - %s | FileCheck %s
--- |
define i32 @foo(i32 %a, i32 %b) !dbg !4 {
entry:
ret i32 0, !dbg !12
}
!llvm.dbg.cu = !{!0}
!llvm.module.flags = !{!3}
!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2)
!1 = !DIFile(filename: "debug-var-slot.c", directory: "./")
!2 = !{}
!3 = !{i32 2, !"Debug Info Version", i32 3}
!4 = distinct !DISubprogram(name: "foo", scope: !1, file: !1, line: 1, type: !5, isLocal: false, isDefinition: true, scopeLine: 2, isOptimized: true, unit: !0, retainedNodes: !2)
!5 = !DISubroutineType(types: !6)
!6 = !{!7, !7, !7}
!7 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
!8 = !DILabel(scope: !4, name: "top", file: !1, line: 4)
!9 = !DILocation(line: 4, column: 1, scope: !4)
!10 = !DILocalVariable(name: "local_var", scope: !4, file: !1, line: 7, type: !7)
!11 = !DILocation(line: 7, column: 1, scope: !4)
!12 = !DILocation(line: 8, column: 3, scope: !4)
!13 = !DILocalVariable(name: "local_var2", scope: !4, file: !1, line: 7, type: !7)
...
---
name: foo
tracksRegLiveness: true
body: |
bb.0:
DBG_VALUE debug-use $esi, debug-use $noreg, !13, !DIExpression(), debug-location !11
DBG_LABEL !8, debug-location !9
DBG_VALUE debug-use $edi, debug-use $noreg, !10, !DIExpression(), debug-location !11
RET 0, undef $eax, debug-location !12
...
# CHECK-LABEL: name: foo
# CHECK: bb.0:
# CHECK-DAG: DBG_LABEL
# CHECK-DAG: DBG_VALUE debug-use $esi
# CHECK-DAG: DBG_VALUE debug-use $edi
```
Repository:
rL LLVM
https://reviews.llvm.org/D50621
More information about the llvm-commits
mailing list