diff options
author | Chris Lattner <sabre@nondot.org> | 2012-01-25 02:06:10 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2012-01-25 02:06:10 +0000 |
commit | 9ddc6246b5f3dbb1a1e05d012361dc2c6d403381 (patch) | |
tree | db53b076e8e5bb9c5038df1b78b682b6c818bff7 /lib/CodeGen/CGExprScalar.cpp | |
parent | 443aac9bd22624c6abb1fe7e581ac30c4e654eea (diff) |
use the new ConstantVector::getSplat method where it makes sense.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@148902 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGExprScalar.cpp')
-rw-r--r-- | lib/CodeGen/CGExprScalar.cpp | 24 |
1 files changed, 6 insertions, 18 deletions
diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index e1342d3ce5..6893439343 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -612,10 +612,8 @@ Value *ScalarExprEmitter::EmitScalarConversion(Value *Src, QualType SrcType, // Splat the element across to all elements SmallVector<llvm::Constant*, 16> Args; unsigned NumElements = cast<llvm::VectorType>(DstTy)->getNumElements(); - for (unsigned i = 0; i != NumElements; ++i) - Args.push_back(Builder.getInt32(0)); - - llvm::Constant *Mask = llvm::ConstantVector::get(Args); + llvm::Constant *Mask = llvm::ConstantVector::getSplat(NumElements, + Builder.getInt32(0)); llvm::Value *Yay = Builder.CreateShuffleVector(UnV, UnV, Mask, "splat"); return Yay; } @@ -749,11 +747,8 @@ Value *ScalarExprEmitter::VisitShuffleVectorExpr(ShuffleVectorExpr *E) { (1 << llvm::Log2_32(LHSElts))-1); // Mask off the high bits of each shuffle index. - SmallVector<llvm::Constant *, 32> MaskV; - for (unsigned i = 0, e = MTy->getNumElements(); i != e; ++i) - MaskV.push_back(EltMask); - - Value* MaskBits = llvm::ConstantVector::get(MaskV); + Value *MaskBits = llvm::ConstantVector::getSplat(MTy->getNumElements(), + EltMask); Mask = Builder.CreateAnd(Mask, MaskBits, "mask"); // newv = undef @@ -1206,10 +1201,7 @@ Value *ScalarExprEmitter::VisitCastExpr(CastExpr *CE) { SmallVector<llvm::Constant*, 16> Args; unsigned NumElements = cast<llvm::VectorType>(DstTy)->getNumElements(); llvm::Constant *Zero = Builder.getInt32(0); - for (unsigned i = 0; i < NumElements; i++) - Args.push_back(Zero); - - llvm::Constant *Mask = llvm::ConstantVector::get(Args); + llvm::Constant *Mask = llvm::ConstantVector::getSplat(NumElements, Zero); llvm::Value *Yay = Builder.CreateShuffleVector(UnV, UnV, Mask, "splat"); return Yay; } @@ -2596,11 +2588,7 @@ VisitAbstractConditionalOperator(const AbstractConditionalOperator *E) { unsigned numElem = vecTy->getNumElements(); llvm::Type *elemType = vecTy->getElementType(); - std::vector<llvm::Constant*> Zvals; - for (unsigned i = 0; i < numElem; ++i) - Zvals.push_back(llvm::ConstantInt::get(elemType, 0)); - - llvm::Value *zeroVec = llvm::ConstantVector::get(Zvals); + llvm::Value *zeroVec = llvm::Constant::getNullValue(vecTy); llvm::Value *TestMSB = Builder.CreateICmpSLT(CondV, zeroVec); llvm::Value *tmp = Builder.CreateSExt(TestMSB, llvm::VectorType::get(elemType, |