forked from OSchip/llvm-project
parent
8f115c6b45
commit
b1baaf5ab9
|
@ -617,6 +617,7 @@ private:
|
||||||
SDValue WidenVecOp_BIT_CONVERT(SDNode *N);
|
SDValue WidenVecOp_BIT_CONVERT(SDNode *N);
|
||||||
SDValue WidenVecOp_CONCAT_VECTORS(SDNode *N);
|
SDValue WidenVecOp_CONCAT_VECTORS(SDNode *N);
|
||||||
SDValue WidenVecOp_EXTRACT_VECTOR_ELT(SDNode *N);
|
SDValue WidenVecOp_EXTRACT_VECTOR_ELT(SDNode *N);
|
||||||
|
SDValue WidenVecOp_EXTRACT_SUBVECTOR(SDNode *N);
|
||||||
SDValue WidenVecOp_STORE(SDNode* N);
|
SDValue WidenVecOp_STORE(SDNode* N);
|
||||||
|
|
||||||
SDValue WidenVecOp_Convert(SDNode *N);
|
SDValue WidenVecOp_Convert(SDNode *N);
|
||||||
|
|
|
@ -1789,6 +1789,7 @@ bool DAGTypeLegalizer::WidenVectorOperand(SDNode *N, unsigned ResNo) {
|
||||||
|
|
||||||
case ISD::BIT_CONVERT: Res = WidenVecOp_BIT_CONVERT(N); break;
|
case ISD::BIT_CONVERT: Res = WidenVecOp_BIT_CONVERT(N); break;
|
||||||
case ISD::CONCAT_VECTORS: Res = WidenVecOp_CONCAT_VECTORS(N); break;
|
case ISD::CONCAT_VECTORS: Res = WidenVecOp_CONCAT_VECTORS(N); break;
|
||||||
|
case ISD::EXTRACT_SUBVECTOR: Res = WidenVecOp_EXTRACT_SUBVECTOR(N); break;
|
||||||
case ISD::EXTRACT_VECTOR_ELT: Res = WidenVecOp_EXTRACT_VECTOR_ELT(N); break;
|
case ISD::EXTRACT_VECTOR_ELT: Res = WidenVecOp_EXTRACT_VECTOR_ELT(N); break;
|
||||||
case ISD::STORE: Res = WidenVecOp_STORE(N); break;
|
case ISD::STORE: Res = WidenVecOp_STORE(N); break;
|
||||||
|
|
||||||
|
@ -1893,6 +1894,12 @@ SDValue DAGTypeLegalizer::WidenVecOp_CONCAT_VECTORS(SDNode *N) {
|
||||||
return DAG.getNode(ISD::BUILD_VECTOR, dl, VT, &Ops[0], NumElts);
|
return DAG.getNode(ISD::BUILD_VECTOR, dl, VT, &Ops[0], NumElts);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SDValue DAGTypeLegalizer::WidenVecOp_EXTRACT_SUBVECTOR(SDNode *N) {
|
||||||
|
SDValue InOp = GetWidenedVector(N->getOperand(0));
|
||||||
|
return DAG.getNode(ISD::EXTRACT_SUBVECTOR, N->getDebugLoc(),
|
||||||
|
N->getValueType(0), InOp, N->getOperand(1));
|
||||||
|
}
|
||||||
|
|
||||||
SDValue DAGTypeLegalizer::WidenVecOp_EXTRACT_VECTOR_ELT(SDNode *N) {
|
SDValue DAGTypeLegalizer::WidenVecOp_EXTRACT_VECTOR_ELT(SDNode *N) {
|
||||||
SDValue InOp = GetWidenedVector(N->getOperand(0));
|
SDValue InOp = GetWidenedVector(N->getOperand(0));
|
||||||
return DAG.getNode(ISD::EXTRACT_VECTOR_ELT, N->getDebugLoc(),
|
return DAG.getNode(ISD::EXTRACT_VECTOR_ELT, N->getDebugLoc(),
|
||||||
|
|
Loading…
Reference in New Issue