mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-01 05:01:59 +01:00
SCEVExpander: Don't crash when trying to merge two constant phis.
Just constant fold them so they can't cause any trouble. Fixes PR12627. llvm-svn: 166286
This commit is contained in:
parent
947d01e1c5
commit
77d71ab3d7
@ -1618,6 +1618,17 @@ unsigned SCEVExpander::replaceCongruentIVs(Loop *L, const DominatorTree *DT,
|
||||
PEnd = Phis.end(); PIter != PEnd; ++PIter) {
|
||||
PHINode *Phi = *PIter;
|
||||
|
||||
// Fold constant phis. They may be congruent to other constant phis and
|
||||
// would confuse the logic below that expects proper IVs.
|
||||
if (Value *V = Phi->hasConstantValue()) {
|
||||
Phi->replaceAllUsesWith(V);
|
||||
DeadInsts.push_back(Phi);
|
||||
++NumElim;
|
||||
DEBUG_WITH_TYPE(DebugType, dbgs()
|
||||
<< "INDVARS: Eliminated constant iv: " << *Phi << '\n');
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!SE.isSCEVable(Phi->getType()))
|
||||
continue;
|
||||
|
||||
|
@ -0,0 +1,27 @@
|
||||
; RUN: opt -S -indvars < %s | FileCheck %s
|
||||
|
||||
; PR12627
|
||||
define void @test1(i32 %x) nounwind uwtable ssp {
|
||||
entry:
|
||||
br label %for.body
|
||||
|
||||
for.body: ; preds = %for.body, %entry
|
||||
%phi1 = phi i1 [ false, %entry ], [ %cmpa, %for.body ]
|
||||
%phi2 = phi i1 [ false, %entry ], [ %cmpb, %for.body ]
|
||||
%i.07 = phi i32 [ 0, %entry ], [ %inc, %for.body ]
|
||||
tail call void @aux(i1 %phi1, i1 %phi2) nounwind
|
||||
%cmpa = icmp sgt i32 %i.07, 200
|
||||
%cmpb = icmp sgt i32 %i.07, 100
|
||||
%inc = add nsw i32 %i.07, 1
|
||||
%exitcond = icmp eq i32 %inc, 100
|
||||
br i1 %exitcond, label %for.end, label %for.body
|
||||
|
||||
for.end: ; preds = %for.body
|
||||
ret void
|
||||
|
||||
; CHECK: @test1
|
||||
; CHECK-NOT: phi i1
|
||||
; CHECK: call void @aux(i1 false, i1 false)
|
||||
}
|
||||
|
||||
declare void @aux(i1, i1)
|
@ -199,7 +199,6 @@ entry:
|
||||
; back to the loop iv.
|
||||
;
|
||||
; CHECK: loop:
|
||||
; CHECK: phi i32
|
||||
; CHECK-NOT: phi
|
||||
; CHECK: exit:
|
||||
loop:
|
||||
|
Loading…
x
Reference in New Issue
Block a user