Add VPERMQ/VPERMPD to the list of target specific shuffles that can be looked through...
authorCraig Topper <craig.topper@gmail.com>
Sun, 6 May 2012 18:54:26 +0000 (18:54 +0000)
committerCraig Topper <craig.topper@gmail.com>
Sun, 6 May 2012 18:54:26 +0000 (18:54 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@156266 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/X86ISelLowering.cpp

index 24d95a9977f3ea40aa24de615bdf84513f439a62..e282617e3e03979c03c56866dd633060e9d87c7b 100644 (file)
@@ -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,