diff options
| author | Nick Lewycky <nicholas@mxc.ca> | 2008-05-23 03:26:47 +0000 | 
|---|---|---|
| committer | Nick Lewycky <nicholas@mxc.ca> | 2008-05-23 03:26:47 +0000 | 
| commit | 2ec9a011737cec6bc1fab68cecfe7aba1116d21e (patch) | |
| tree | 9921e45e16d0a4713a7adec78e0c27aa269d6bcb /llvm/lib | |
| parent | d6795749a6d6b78ca761166d359555d1f4a09184 (diff) | |
| download | bcm5719-llvm-2ec9a011737cec6bc1fab68cecfe7aba1116d21e.tar.gz bcm5719-llvm-2ec9a011737cec6bc1fab68cecfe7aba1116d21e.zip | |
Fix a recently added optimization to not crash on vectors.
llvm-svn: 51471
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 12 | 
1 files changed, 10 insertions, 2 deletions
| diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 13dbc115261..a398884e592 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -3276,8 +3276,16 @@ Instruction *InstCombiner::commonIDivTransforms(BinaryOperator &I) {    Value *Op0 = I.getOperand(0), *Op1 = I.getOperand(1);    // (sdiv X, X) --> 1     (udiv X, X) --> 1 -  if (Op0 == Op1) -    return ReplaceInstUsesWith(I, ConstantInt::get(I.getType(), 1)); +  if (Op0 == Op1) { +    if (const VectorType *Ty = dyn_cast<VectorType>(I.getType())) { +      ConstantInt *CI = ConstantInt::get(Ty->getElementType(), 1); +      std::vector<Constant*> Elts(Ty->getNumElements(), CI); +      return ReplaceInstUsesWith(I, ConstantVector::get(Elts)); +    } + +    ConstantInt *CI = ConstantInt::get(I.getType(), 1); +    return ReplaceInstUsesWith(I, CI); +  }    if (Instruction *Common = commonDivTransforms(I))      return Common; | 

