summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-01-13 20:40:58 +0000
committerChris Lattner <sabre@nondot.org>2005-01-13 20:40:58 +0000
commit4cb9fa373b8874f641975ab48d38d7fe4310e6c2 (patch)
treea9d34ee293d28a147f1708aa12e30e6f7a13fb24 /llvm/lib
parent0798af33a581c319bc3ef2ee5bdd1d6a7dd9b918 (diff)
downloadbcm5719-llvm-4cb9fa373b8874f641975ab48d38d7fe4310e6c2.tar.gz
bcm5719-llvm-4cb9fa373b8874f641975ab48d38d7fe4310e6c2.zip
Fix some bugs in code I didn't mean to check in.
llvm-svn: 19534
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Transforms/Scalar/InstructionCombining.cpp17
1 files changed, 12 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp
index d21ec762152..9f6e712e254 100644
--- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp
+++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp
@@ -2112,6 +2112,7 @@ static Value *EmitGEPOffset(User *GEP, Instruction &I, InstCombiner &IC) {
SIntPtrTy);
if (Constant *OpC = dyn_cast<Constant>(Op)) {
if (!OpC->isNullValue()) {
+ OpC = ConstantExpr::getCast(OpC, SIntPtrTy);
Scale = ConstantExpr::getMul(OpC, Scale);
if (Constant *RC = dyn_cast<Constant>(Result))
Result = ConstantExpr::getAdd(RC, Scale);
@@ -2123,13 +2124,19 @@ static Value *EmitGEPOffset(User *GEP, Instruction &I, InstCombiner &IC) {
}
}
} else {
- // We'll let instcombine(mul) convert this to a shl if possible.
- Value *Offs =
- IC.InsertNewInstBefore(BinaryOperator::createMul(Op, Scale,
- GEP->getName()+".idx"), I);
+ //if (Op->getType() != Scale->getType())
+ if (Size != 1) {
+ // Convert to correct type.
+ Op = IC.InsertNewInstBefore(new CastInst(Op, SIntPtrTy,
+ Op->getName()+".c"), I);
+
+ // We'll let instcombine(mul) convert this to a shl if possible.
+ Op = IC.InsertNewInstBefore(BinaryOperator::createMul(Op, Scale,
+ GEP->getName()+".idx"), I);
+ }
// Emit an add instruction.
- Result = IC.InsertNewInstBefore(BinaryOperator::createAdd(Offs, Result,
+ Result = IC.InsertNewInstBefore(BinaryOperator::createAdd(Op, Result,
GEP->getName()+".offs"), I);
}
}
OpenPOWER on IntegriCloud