All v2f64 shuffle cases can be handled.

llvm-svn: 27044
This commit is contained in:
Evan Cheng 2006-03-24 06:40:32 +00:00
parent 3fb8f32540
commit 8507228441
2 changed files with 8 additions and 1 deletions

View File

@ -655,3 +655,7 @@ call _foo
Obviously it would have been better for the first mov (or any op) to store
directly %esp[0] if there are no other uses.
//===---------------------------------------------------------------------===//
Add more vector shuffle special cases using unpckhps and unpcklps.

View File

@ -2329,7 +2329,10 @@ SDOperand X86TargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
return DAG.getNode(ISD::VECTOR_SHUFFLE, VT, V1,
DAG.getNode(ISD::UNDEF, V1.getValueType()),
PermMask);
} else if (NumElems == 2 || X86::isSHUFPMask(PermMask.Val)) {
} else if (NumElems == 2) {
// All v2f64 cases are handled.
return SDOperand();
} else if (X86::isSHUFPMask(PermMask.Val)) {
SDOperand Elt = PermMask.getOperand(0);
if (cast<ConstantSDNode>(Elt)->getValue() >= NumElems) {
// Swap the operands and change mask.