diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2007-03-04 01:25:35 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2007-03-04 01:25:35 +0000 |
commit | 69904f939a0b81863b8e5668059d02fc230e5f80 (patch) | |
tree | 5705a953f311b9c9c62c0c4457849d395de8a465 /llvm/lib/Analysis | |
parent | 1f7648efbae53df771d8de1c2429f65a0ddae2a9 (diff) | |
download | bcm5719-llvm-69904f939a0b81863b8e5668059d02fc230e5f80.tar.gz bcm5719-llvm-69904f939a0b81863b8e5668059d02fc230e5f80.zip |
Guard further against APInt operations with operands of unequal bit width.
llvm-svn: 34897
Diffstat (limited to 'llvm/lib/Analysis')
-rw-r--r-- | llvm/lib/Analysis/ScalarEvolution.cpp | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/llvm/lib/Analysis/ScalarEvolution.cpp b/llvm/lib/Analysis/ScalarEvolution.cpp index d2eca4adeb4..051631e80d1 100644 --- a/llvm/lib/Analysis/ScalarEvolution.cpp +++ b/llvm/lib/Analysis/ScalarEvolution.cpp @@ -1354,16 +1354,22 @@ static APInt GetConstantFactor(SCEVHandle S) { // The result is the min of all operands. APInt Res = GetConstantFactor(A->getOperand(0)); for (unsigned i = 1, e = A->getNumOperands(); - i != e && Res.ugt(APInt(Res.getBitWidth(),1)); ++i) - Res = APIntOps::umin(Res, GetConstantFactor(A->getOperand(i))); + i != e && Res.ugt(APInt(Res.getBitWidth(),1)); ++i) { + APInt Tmp(GetConstantFactor(A->getOperand(i))); + Tmp.zextOrTrunc(Res.getBitWidth()); + Res = APIntOps::umin(Res, Tmp); + } return Res; } if (SCEVMulExpr *M = dyn_cast<SCEVMulExpr>(S)) { // The result is the product of all the operands. APInt Res = GetConstantFactor(M->getOperand(0)); - for (unsigned i = 1, e = M->getNumOperands(); i != e; ++i) - Res *= GetConstantFactor(M->getOperand(i)); + for (unsigned i = 1, e = M->getNumOperands(); i != e; ++i) { + APInt Tmp(GetConstantFactor(M->getOperand(i))); + Tmp.zextOrTrunc(Res.getBitWidth()); + Res *= Tmp; + } return Res; } @@ -1375,6 +1381,7 @@ static APInt GetConstantFactor(SCEVHandle S) { if (Start == 1) return APInt(A->getBitWidth(),1); APInt Stride = GetConstantFactor(A->getOperand(1)); + Start.zextOrTrunc(Stride.getBitWidth()); return APIntOps::GreatestCommonDivisor(Start, Stride); } } |