The LCSSA pass makes use of a function insertDebugValuesForPHIs() to propogate dbg.value() intrinsics to newly inserted PHI instructions. Faulty behaviour occurs when the parent PHI of a newly inserted PHI is not the most recent assignment to a source variable. insertDebugValuesForPHIs ends up propagating a value that isn't the most recent assignemnt. This change removes the call to insertDebugValuesForPHIs() from LCSSA, preventing incorrect dbg.value intrinsics from being propagated. Propagating variable locations between blocks will occur later, during LiveDebugValues. Differential Revision: https://reviews.llvm.org/D92576
30 lines
995 B
LLVM
30 lines
995 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=DEBUGIFY %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
|
|
; DEBUGIFY: %X3.lcssa = phi i32 {{.*}}, !dbg ![[DbgLoc:[0-9]+]]
|
|
; CHECK: %X4 = add i32 3, %X3.lcssa
|
|
%X4 = add i32 3, %X3 ; <i32> [#uses=0]
|
|
ret void
|
|
}
|
|
|
|
; Make sure the lcssa phi has %X3's debug location
|
|
; DEBUGIFY: ![[DbgLoc]] = !DILocation(line: 7
|