diff options
| author | Dan Gohman <gohman@apple.com> | 2010-04-23 01:51:29 +0000 |
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2010-04-23 01:51:29 +0000 |
| commit | ff3174e97f40670db05daf8077347a372b9581c3 (patch) | |
| tree | 4e22f1a776381fc200018bbdfffd9357f296e747 /llvm/lib/Analysis | |
| parent | e9135cb3fb927f130b4f27e34e9b35cc95d76b19 (diff) | |
| download | bcm5719-llvm-ff3174e97f40670db05daf8077347a372b9581c3.tar.gz bcm5719-llvm-ff3174e97f40670db05daf8077347a372b9581c3.zip | |
When it doesn't matter whether zero or sign extension is used,
use ScalarEvolutions "any" extend function.
llvm-svn: 102156
Diffstat (limited to 'llvm/lib/Analysis')
| -rw-r--r-- | llvm/lib/Analysis/ScalarEvolution.cpp | 8 |
1 files changed, 2 insertions, 6 deletions
diff --git a/llvm/lib/Analysis/ScalarEvolution.cpp b/llvm/lib/Analysis/ScalarEvolution.cpp index f540bcbdcd1..0daf39383ee 100644 --- a/llvm/lib/Analysis/ScalarEvolution.cpp +++ b/llvm/lib/Analysis/ScalarEvolution.cpp @@ -1355,9 +1355,7 @@ const SCEV *ScalarEvolution::getAddExpr(SmallVectorImpl<const SCEV *> &Ops, } LargeOps.push_back(T->getOperand()); } else if (const SCEVConstant *C = dyn_cast<SCEVConstant>(Ops[i])) { - // This could be either sign or zero extension, but sign extension - // is much more likely to be foldable here. - LargeOps.push_back(getSignExtendExpr(C, SrcType)); + LargeOps.push_back(getAnyExtendExpr(C, SrcType)); } else if (const SCEVMulExpr *M = dyn_cast<SCEVMulExpr>(Ops[i])) { SmallVector<const SCEV *, 8> LargeMulOps; for (unsigned j = 0, f = M->getNumOperands(); j != f && Ok; ++j) { @@ -1370,9 +1368,7 @@ const SCEV *ScalarEvolution::getAddExpr(SmallVectorImpl<const SCEV *> &Ops, LargeMulOps.push_back(T->getOperand()); } else if (const SCEVConstant *C = dyn_cast<SCEVConstant>(M->getOperand(j))) { - // This could be either sign or zero extension, but sign extension - // is much more likely to be foldable here. - LargeMulOps.push_back(getSignExtendExpr(C, SrcType)); + LargeMulOps.push_back(getAnyExtendExpr(C, SrcType)); } else { Ok = false; break; |

