summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/X86/X86ISelLowering.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib/Target/X86/X86ISelLowering.cpp')
-rw-r--r--llvm/lib/Target/X86/X86ISelLowering.cpp23
1 files changed, 3 insertions, 20 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp
index 9a553d61bfb..eca63f80ae0 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.cpp
+++ b/llvm/lib/Target/X86/X86ISelLowering.cpp
@@ -14661,29 +14661,12 @@ static SDValue PerformShuffleCombine(SDNode *N, SelectionDAG &DAG,
return EltsFromConsecutiveLoads(VT, Elts, dl, DAG);
}
-/// PerformTruncateCombine - In some cases a sequence with "truncate"
-/// operation may be simplified.
+/// PerformTruncateCombine - Converts truncate operation to
+/// a sequence of vector shuffle operations.
+/// It is possible when we truncate 256-bit vector to 128-bit vector
static SDValue PerformTruncateCombine(SDNode *N, SelectionDAG &DAG,
TargetLowering::DAGCombinerInfo &DCI,
const X86Subtarget *Subtarget) {
- EVT VT = N->getValueType(0);
- if (DCI.isBeforeLegalize() || !VT.isVector())
- return SDValue();
-
- SDValue In = N->getOperand(0);
- // Optimize the sequence setcc -> truncate
- if (In.getOpcode() == ISD::SETCC) {
- DebugLoc DL = N->getDebugLoc();
- EVT InVT = In.getValueType();
-
- // The vector element is all ones or all zero. Just take a half of it.
- EVT HalfVT = EVT::getVectorVT(*DAG.getContext(), InVT.getScalarType(),
- InVT.getVectorNumElements()/2);
- SDValue HalfVec = DAG.getNode(ISD::EXTRACT_SUBVECTOR, DL, HalfVT, In,
- DAG.getIntPtrConstant(0));
- assert(HalfVT.getSizeInBits() == VT.getSizeInBits());
- return DAG.getNode(ISD::BITCAST, DL, VT, HalfVec);
- }
return SDValue();
}
OpenPOWER on IntegriCloud