Teach SplitVectorOp how to split INSERT_VECTOR_ELT.

llvm-svn: 42457
This commit is contained in:
Dan Gohman 2007-09-28 23:53:40 +00:00
parent 8ef9b439d8
commit 02f80006f8
2 changed files with 30 additions and 0 deletions

View File

@ -5837,6 +5837,18 @@ void SelectionDAGLegalize::SplitVectorOp(SDOperand Op, SDOperand &Lo,
Lo = Node->getOperand(0);
Hi = Node->getOperand(1);
break;
case ISD::INSERT_VECTOR_ELT: {
SplitVectorOp(Node->getOperand(0), Lo, Hi);
unsigned Index = cast<ConstantSDNode>(Node->getOperand(2))->getValue();
SDOperand ScalarOp = Node->getOperand(1);
if (Index < NewNumElts)
Lo = DAG.getNode(ISD::INSERT_VECTOR_ELT, NewVT, Lo, ScalarOp,
DAG.getConstant(Index, TLI.getPointerTy()));
else
Hi = DAG.getNode(ISD::INSERT_VECTOR_ELT, NewVT, Hi, ScalarOp,
DAG.getConstant(Index - NewNumElts, TLI.getPointerTy()));
break;
}
case ISD::BUILD_VECTOR: {
SmallVector<SDOperand, 8> LoOps(Node->op_begin(),
Node->op_begin()+NewNumElts);

View File

@ -0,0 +1,18 @@
; RUN: llvm-as %s -o - | llc -march=x86-64
define <4 x double> @foo0(<4 x double> %t) {
%r = insertelement <4 x double> %t, double 2.3, i32 0
ret <4 x double> %r
}
define <4 x double> @foo1(<4 x double> %t) {
%r = insertelement <4 x double> %t, double 2.3, i32 1
ret <4 x double> %r
}
define <4 x double> @foo2(<4 x double> %t) {
%r = insertelement <4 x double> %t, double 2.3, i32 2
ret <4 x double> %r
}
define <4 x double> @foo3(<4 x double> %t) {
%r = insertelement <4 x double> %t, double 2.3, i32 3
ret <4 x double> %r
}