mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
Stay rational; don't assert trying to take the square root of a negative value.
If it's negative, the loop is already proven to be infinite. Fixes PR13489! llvm-svn: 161107
This commit is contained in:
parent
892c043c64
commit
e84df7229f
@ -5370,6 +5370,12 @@ SolveQuadraticEquation(const SCEVAddRecExpr *AddRec, ScalarEvolution &SE) {
|
||||
SqrtTerm *= B;
|
||||
SqrtTerm -= Four * (A * C);
|
||||
|
||||
if (SqrtTerm.isNegative()) {
|
||||
// The loop is provably infinite.
|
||||
const SCEV *CNC = SE.getCouldNotCompute();
|
||||
return std::make_pair(CNC, CNC);
|
||||
}
|
||||
|
||||
// Compute sqrt(B^2-4ac). This is guaranteed to be the nearest
|
||||
// integer value or else APInt::sqrt() will assert.
|
||||
APInt SqrtVal(SqrtTerm.sqrt());
|
||||
|
@ -80,3 +80,24 @@ for.cond539.preheader:
|
||||
unreachable
|
||||
}
|
||||
; CHECK: Determining loop execution counts for: @test3
|
||||
|
||||
; PR13489
|
||||
; We used to crash on this too.
|
||||
|
||||
define void @test4() {
|
||||
entry:
|
||||
br label %for.body
|
||||
|
||||
for.body: ; preds = %for.body, %entry
|
||||
%v2.02 = phi i64 [ 2, %entry ], [ %phitmp, %for.body ]
|
||||
%v1.01 = phi i64 [ -2, %entry ], [ %sub1, %for.body ]
|
||||
%sub1 = sub i64 %v1.01, %v2.02
|
||||
%phitmp = add i64 %v2.02, 2
|
||||
%tobool = icmp eq i64 %sub1, %phitmp
|
||||
br i1 %tobool, label %for.end, label %for.body
|
||||
|
||||
for.end: ; preds = %for.body
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK: Determining loop execution counts for: @test4
|
||||
|
Loading…
Reference in New Issue
Block a user