diff options
| author | Duncan Sands <baldrick@free.fr> | 2012-11-13 13:01:58 +0000 | 
|---|---|---|
| committer | Duncan Sands <baldrick@free.fr> | 2012-11-13 13:01:58 +0000 | 
| commit | b2df01ab2a311688c9c4ca4eb8a93ae1bf40d468 (patch) | |
| tree | 6885071d6d0eada6ebfeed0631b0fddf36637162 | |
| parent | 707276d415002fb37ac3fbc50c66905a4ffe1f75 (diff) | |
| download | external_llvm-b2df01ab2a311688c9c4ca4eb8a93ae1bf40d468.zip external_llvm-b2df01ab2a311688c9c4ca4eb8a93ae1bf40d468.tar.gz external_llvm-b2df01ab2a311688c9c4ca4eb8a93ae1bf40d468.tar.bz2 | |
Codegen support for arbitrary vector getelementptrs.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@167830 91177308-0d34-0410-b5e6-96231b3b80d8
| -rw-r--r-- | lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | 6 | ||||
| -rw-r--r-- | test/CodeGen/Generic/vector.ll | 5 | 
2 files changed, 8 insertions, 3 deletions
| diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp index 3fbf7c2..0af7b9a 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp @@ -3137,12 +3137,12 @@ void SelectionDAGBuilder::visitGetElementPtr(const User &I) {         OI != E; ++OI) {      const Value *Idx = *OI;      if (StructType *StTy = dyn_cast<StructType>(Ty)) { -      unsigned Field = cast<ConstantInt>(Idx)->getZExtValue(); +      unsigned Field = cast<Constant>(Idx)->getUniqueInteger().getZExtValue();        if (Field) {          // N = N + Offset          uint64_t Offset = TD->getStructLayout(StTy)->getElementOffset(Field);          N = DAG.getNode(ISD::ADD, getCurDebugLoc(), N.getValueType(), N, -                        DAG.getIntPtrConstant(Offset)); +                        DAG.getConstant(Offset, N.getValueType()));        }        Ty = StTy->getElementType(Field); @@ -3187,7 +3187,7 @@ void SelectionDAGBuilder::visitGetElementPtr(const User &I) {                               N.getValueType(), IdxN,                               DAG.getConstant(Amt, IdxN.getValueType()));          } else { -          SDValue Scale = DAG.getConstant(ElementSize, TLI.getPointerTy()); +          SDValue Scale = DAG.getConstant(ElementSize, IdxN.getValueType());            IdxN = DAG.getNode(ISD::MUL, getCurDebugLoc(),                               N.getValueType(), IdxN, Scale);          } diff --git a/test/CodeGen/Generic/vector.ll b/test/CodeGen/Generic/vector.ll index a0f9a02..84814a1 100644 --- a/test/CodeGen/Generic/vector.ll +++ b/test/CodeGen/Generic/vector.ll @@ -152,3 +152,8 @@ define void @splat_i4(%i4* %P, %i4* %Q, i32 %X) {  	store %i4 %R, %i4* %P  	ret void  } + +define <2 x i32*> @vector_gep(<2 x [3 x {i32, i32}]*> %a) { +    %w = getelementptr <2 x [3 x {i32, i32}]*> %a, <2 x i32> <i32 1, i32 2>, <2 x i32> <i32 2, i32 3>, <2 x i32> <i32 1, i32 1> +      ret <2 x i32*> %w +} | 
