
Debugify is extremely useful as a testing and debugging tool, and a good number of LLVM-IR transform tests use it. We need it to support "new" non-instruction debug-info to get test coverage, but it's not important enough to completely convert right now (and it'd be a large undertaking). Thus: convert to/from dbg.value/DPValue mode on entry and exit of the pass, which gives us the functionality without any further work. The cost is compile-time, but again this is only happening during tests. Tested by: the large set of debugify tests enabled here. Note the InstCombine test (cast-mul-select.ll) that hasn't been fully enabled: this is because there's a debug-info sinking piece of code there that hasn't been instrumented.
40 lines
1.3 KiB
LLVM
40 lines
1.3 KiB
LLVM
; RUN: opt %s -passes=debugify,simplifycfg -simplifycfg-require-and-preserve-domtree=1 -S | FileCheck %s
|
|
; RUN: opt %s -passes=debugify,simplifycfg -simplifycfg-require-and-preserve-domtree=1 -S --try-experimental-debuginfo-iterators | FileCheck %s
|
|
; Tests Bug 37966
|
|
|
|
define void @bar(i32 %aa) {
|
|
; CHECK-LABEL: @bar(
|
|
; CHECK: if.end.1.critedge:
|
|
; CHECK: br label %if.end.1, !dbg ![[DBG:[0-9]+]]
|
|
entry:
|
|
%aa.addr = alloca i32, align 4
|
|
%bb = alloca i32, align 4
|
|
store i32 %aa, ptr %aa.addr, align 4
|
|
store i32 0, ptr %bb, align 4
|
|
%tobool = icmp ne i32 %aa, 0
|
|
br i1 %tobool, label %if.then, label %if.end
|
|
|
|
if.then: ; preds = %entry
|
|
call void @foo()
|
|
br label %if.end
|
|
|
|
if.end: ; preds = %if.then, %entry
|
|
store i32 1, ptr %bb, align 4
|
|
br i1 %tobool, label %if.then.1, label %if.end.1 ; "line 10" to -debugify
|
|
|
|
if.then.1: ; preds = %if.end
|
|
call void @foo()
|
|
br label %if.end.1
|
|
|
|
if.end.1: ; preds = %if.then.1, %if.end
|
|
store i32 2, ptr %bb, align 4
|
|
br label %for.end
|
|
|
|
for.end: ; preds = %if.end.1
|
|
ret void
|
|
}
|
|
|
|
declare void @foo()
|
|
|
|
; CHECK: ![[DBG]] = !DILocation(line: 10,
|