Summary:
This patch is an enhancement to propagate dbg.value information when Phis are created on behalf of LCSSA.
I noticed a case where a value carried across a loop was reported as <optimized out>.
Specifically this case:
```
int bar(int x, int y) {
return x + y;
}
int foo(int size) {
int val = 0;
for (int i = 0; i < size; ++i) {
val = bar(val, i); // Both val and i are correct
}
return val; // <optimized out>
}
```
In the above case, after all of the interesting computation completes our value
is reported as "optimized out." This change will add a dbg.value to correct this.
This patch also moves the dbg.value insertion routine from LoopRotation.cpp
into Local.cpp, so that we can share it in both places (LoopRotation and LCSSA).
Reviewers: mzolotukhin, aprantl, vsk, davide
Reviewed By: aprantl, vsk
Subscribers: dberlin, llvm-commits
Differential Revision: https://reviews.llvm.org/D42551
llvm-svn: 325926
28 lines
942 B
LLVM
28 lines
942 B
LLVM
; RUN: opt < %s -lcssa -S | FileCheck %s
|
|
; RUN: opt < %s -passes=lcssa -S | FileCheck %s
|
|
; RUN: opt < %s -debugify -lcssa -S | FileCheck -check-prefix=CHECK2 %s
|
|
|
|
define void @lcssa(i1 %S2) {
|
|
; CHECK-LABEL: @lcssa
|
|
entry:
|
|
br label %loop.interior
|
|
loop.interior: ; preds = %post.if, %entry
|
|
br i1 %S2, label %if.true, label %if.false
|
|
if.true: ; preds = %loop.interior
|
|
%X1 = add i32 0, 0 ; <i32> [#uses=1]
|
|
br label %post.if
|
|
if.false: ; preds = %loop.interior
|
|
%X2 = add i32 0, 1 ; <i32> [#uses=1]
|
|
br label %post.if
|
|
post.if: ; preds = %if.false, %if.true
|
|
%X3 = phi i32 [ %X1, %if.true ], [ %X2, %if.false ] ; <i32> [#uses=1]
|
|
br i1 %S2, label %loop.exit, label %loop.interior
|
|
loop.exit: ; preds = %post.if
|
|
; CHECK: %X3.lcssa = phi i32
|
|
; CHECK2: call void @llvm.dbg.value(metadata i32 %X3.lcssa, metadata !11, metadata !DIExpression()), !dbg !19
|
|
; CHECK: %X4 = add i32 3, %X3.lcssa
|
|
%X4 = add i32 3, %X3 ; <i32> [#uses=0]
|
|
ret void
|
|
}
|
|
|