From 0ad57fb93ae53ac94ebcd247201f60d87600188f Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 23 Dec 2009 21:33:41 +0000 Subject: simplify my previous patch. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@92057 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGExpr.cpp | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) (limited to 'lib/CodeGen/CGExpr.cpp') diff --git a/lib/CodeGen/CGExpr.cpp b/lib/CodeGen/CGExpr.cpp index 6b54d969f8..66831c293d 100644 --- a/lib/CodeGen/CGExpr.cpp +++ b/lib/CodeGen/CGExpr.cpp @@ -1215,17 +1215,10 @@ EmitExtVectorElementExpr(const ExtVectorElementExpr *E) { assert(VT && "Result must be a vector"); llvm::Value *Vec = EmitScalarExpr(E->getBase()); - // Store the vector to memory (because LValue wants an address) and use an - // index list of 0,1,2,3 which is the full vector. + // Store the vector to memory (because LValue wants an address). llvm::Value *VecMem =CreateTempAlloca(ConvertType(E->getBase()->getType())); Builder.CreateStore(Vec, VecMem); - - llvm::SmallVector CElts; - for (unsigned i = 0, e = VT->getNumElements(); i != e; ++i) - CElts.push_back(llvm::ConstantInt::get(Int32Ty, i)); - - llvm::Constant *Elts = llvm::ConstantVector::get(&CElts[0], CElts.size()); - Base = LValue::MakeExtVectorElt(VecMem, Elts, 0); + Base = LValue::MakeAddr(VecMem, Qualifiers()); } // Encode the element access list into a vector of unsigned indices. -- cgit v1.2.3-70-g09d2