summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@gmail.com>2012-05-06 18:54:26 +0000
committerCraig Topper <craig.topper@gmail.com>2012-05-06 18:54:26 +0000
commit804be3b546222c629beb6a01e14e7cb32f23a186 (patch)
tree726fc692b26807537cce842bab387523ec96bb2b
parent54bdb350e27a130c54a15b6340d31eda07cddef1 (diff)
downloadbcm5719-llvm-804be3b546222c629beb6a01e14e7cb32f23a186.tar.gz
bcm5719-llvm-804be3b546222c629beb6a01e14e7cb32f23a186.zip
Add VPERMQ/VPERMPD to the list of target specific shuffles that can be looked through for DAG combine purposes.
llvm-svn: 156266
-rw-r--r--llvm/lib/Target/X86/X86ISelLowering.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp
index 24d95a9977f..e282617e3e0 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.cpp
+++ b/llvm/lib/Target/X86/X86ISelLowering.cpp
@@ -2914,6 +2914,7 @@ static bool isTargetShuffle(unsigned Opcode) {
case X86ISD::UNPCKH:
case X86ISD::VPERMILP:
case X86ISD::VPERM2X128:
+ case X86ISD::VPERMI:
return true;
}
}
@@ -4455,6 +4456,11 @@ static bool getTargetShuffleMask(SDNode *N, EVT VT,
DecodePSHUFLWMask(VT, cast<ConstantSDNode>(ImmN)->getZExtValue(), Mask);
IsUnary = true;
break;
+ case X86ISD::VPERMI:
+ ImmN = N->getOperand(N->getNumOperands()-1);
+ DecodeVPERMMask(cast<ConstantSDNode>(ImmN)->getZExtValue(), Mask);
+ IsUnary = true;
+ break;
case X86ISD::MOVSS:
case X86ISD::MOVSD: {
// The index 0 always comes from the first element of the second source,
OpenPOWER on IntegriCloud