diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-10-27 06:12:00 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-10-27 06:12:00 +0000 |
| commit | b3ecf9690089ec6f98d939cbec60e4f4f76a4093 (patch) | |
| tree | 3a5d6876550e7d96d35110916945190c58535050 /llvm/lib/Transforms | |
| parent | bb17180a23201580f89ec7a416a98299164d5ae8 (diff) | |
| download | bcm5719-llvm-b3ecf9690089ec6f98d939cbec60e4f4f76a4093.tar.gz bcm5719-llvm-b3ecf9690089ec6f98d939cbec60e4f4f76a4093.zip | |
Promote cases like cast (malloc sbyte, 100) to int* into
(malloc [25 x int]) directly without having to convert to
(malloc [100 x sbyte]) first.
llvm-svn: 24031
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index a5a2597a2f6..7ac1eccdf22 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -3826,7 +3826,28 @@ Instruction *InstCombiner::PromoteCastOfAllocation(CastInst &CI, Amt = InsertNewInstBefore(Tmp, AI); } } else { - return 0; + // See if we can satisfy the modulus by pulling a scale out of the array + // size argument. + unsigned ArraySizeScale = 1; + Value *NumElements = AI.getOperand(0); + + if (ConstantUInt *CI = dyn_cast<ConstantUInt>(NumElements)) { + ArraySizeScale = CI->getValue(); + NumElements = ConstantUInt::get(Type::UIntTy, 1); + } + + // If we can now satisfy the modulus, by using a non-1 scale, we really can + // do the xform. + if ((AllocElTySize*ArraySizeScale) % CastElTySize != 0) return 0; + + Amt = ConstantUInt::get(Type::UIntTy, + (AllocElTySize*ArraySizeScale)/CastElTySize); + if (ConstantUInt *CI = dyn_cast<ConstantUInt>(NumElements)) + Amt = ConstantExpr::getMul(CI, cast<ConstantUInt>(Amt)); + else { + Instruction *Tmp = BinaryOperator::createMul(Amt, NumElements, "tmp"); + Amt = InsertNewInstBefore(Tmp, AI); + } } std::string Name = AI.getName(); AI.setName(""); |

