mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
GVN: If a branch has two identical successors, we cannot declare either dead.
This previously caused miscompilations as a result of phi nodes receiving undef incoming values from blocks dominated by such successors. Differential Revision: http://reviews.llvm.org/D10726 llvm-svn: 240670
This commit is contained in:
parent
393725d952
commit
3b0fac198c
@ -2804,6 +2804,10 @@ bool GVN::processFoldableCondBr(BranchInst *BI) {
|
|||||||
if (!BI || BI->isUnconditional())
|
if (!BI || BI->isUnconditional())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
// If a branch has two identical successors, we cannot declare either dead.
|
||||||
|
if (BI->getSuccessor(0) == BI->getSuccessor(1))
|
||||||
|
return false;
|
||||||
|
|
||||||
ConstantInt *Cond = dyn_cast<ConstantInt>(BI->getCondition());
|
ConstantInt *Cond = dyn_cast<ConstantInt>(BI->getCondition());
|
||||||
if (!Cond)
|
if (!Cond)
|
||||||
return false;
|
return false;
|
||||||
|
38
test/Transforms/GVN/br-identical.ll
Normal file
38
test/Transforms/GVN/br-identical.ll
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
; RUN: opt -gvn -S -o - %s | FileCheck %s
|
||||||
|
|
||||||
|
; If a branch has two identical successors, we cannot declare either dead.
|
||||||
|
|
||||||
|
define void @widget(i1 %p) {
|
||||||
|
entry:
|
||||||
|
br label %bb2
|
||||||
|
|
||||||
|
bb2:
|
||||||
|
%t1 = phi i64 [ 0, %entry ], [ %t5, %bb7 ]
|
||||||
|
%t2 = add i64 %t1, 1
|
||||||
|
%t3 = icmp ult i64 0, %t2
|
||||||
|
br i1 %t3, label %bb3, label %bb4
|
||||||
|
|
||||||
|
bb3:
|
||||||
|
%t4 = call i64 @f()
|
||||||
|
br label %bb4
|
||||||
|
|
||||||
|
bb4:
|
||||||
|
; CHECK-NOT: phi {{.*}} undef
|
||||||
|
%foo = phi i64 [ %t4, %bb3 ], [ 0, %bb2 ]
|
||||||
|
br i1 %p, label %bb5, label %bb6
|
||||||
|
|
||||||
|
bb5:
|
||||||
|
br i1 true, label %bb7, label %bb7
|
||||||
|
|
||||||
|
bb6:
|
||||||
|
br i1 true, label %bb7, label %bb7
|
||||||
|
|
||||||
|
bb7:
|
||||||
|
%t5 = add i64 %t1, 1
|
||||||
|
br i1 %p, label %bb2, label %bb8
|
||||||
|
|
||||||
|
bb8:
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
|
declare i64 @f()
|
Loading…
Reference in New Issue
Block a user