mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
Add basic support for legalizing returns of vectors
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@27578 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
06c24350a9
commit
f87324e44d
@ -1397,20 +1397,47 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||||||
Tmp1 = DAG.getNode(ISD::TokenFactor, MVT::Other, Tmp1, LastCALLSEQ_END);
|
Tmp1 = DAG.getNode(ISD::TokenFactor, MVT::Other, Tmp1, LastCALLSEQ_END);
|
||||||
Tmp1 = LegalizeOp(Tmp1);
|
Tmp1 = LegalizeOp(Tmp1);
|
||||||
LastCALLSEQ_END = DAG.getEntryNode();
|
LastCALLSEQ_END = DAG.getEntryNode();
|
||||||
|
Tmp2 = Node->getOperand(1);
|
||||||
|
|
||||||
switch (Node->getNumOperands()) {
|
switch (Node->getNumOperands()) {
|
||||||
case 2: // ret val
|
case 2: // ret val
|
||||||
switch (getTypeAction(Node->getOperand(1).getValueType())) {
|
switch (getTypeAction(Tmp2.getValueType())) {
|
||||||
case Legal:
|
case Legal:
|
||||||
Tmp2 = LegalizeOp(Node->getOperand(1));
|
Result = DAG.UpdateNodeOperands(Result, Tmp1, LegalizeOp(Tmp2));
|
||||||
Result = DAG.UpdateNodeOperands(Result, Tmp1, Tmp2);
|
|
||||||
break;
|
break;
|
||||||
case Expand: {
|
case Expand:
|
||||||
SDOperand Lo, Hi;
|
if (Tmp2.getValueType() != MVT::Vector) {
|
||||||
ExpandOp(Node->getOperand(1), Lo, Hi);
|
SDOperand Lo, Hi;
|
||||||
Result = DAG.getNode(ISD::RET, MVT::Other, Tmp1, Lo, Hi);
|
ExpandOp(Tmp2, Lo, Hi);
|
||||||
|
Result = DAG.getNode(ISD::RET, MVT::Other, Tmp1, Lo, Hi);
|
||||||
|
} else {
|
||||||
|
SDNode *InVal = Tmp2.Val;
|
||||||
|
unsigned NumElems =
|
||||||
|
cast<ConstantSDNode>(*(InVal->op_end()-2))->getValue();
|
||||||
|
MVT::ValueType EVT = cast<VTSDNode>(*(InVal->op_end()-1))->getVT();
|
||||||
|
|
||||||
|
// Figure out if there is a Packed type corresponding to this Vector
|
||||||
|
// type. If so, convert to the packed type.
|
||||||
|
MVT::ValueType TVT = MVT::getVectorType(EVT, NumElems);
|
||||||
|
if (TVT != MVT::Other && TLI.isTypeLegal(TVT)) {
|
||||||
|
// Turn this into a return of the packed type.
|
||||||
|
Tmp2 = PackVectorOp(Tmp2, TVT);
|
||||||
|
Result = DAG.UpdateNodeOperands(Result, Tmp1, Tmp2);
|
||||||
|
} else if (NumElems == 1) {
|
||||||
|
// Turn this into a return of the scalar type.
|
||||||
|
Tmp2 = PackVectorOp(Tmp2, EVT);
|
||||||
|
Result = DAG.UpdateNodeOperands(Result, Tmp1, Tmp2);
|
||||||
|
// The scalarized value type may not be legal, e.g. it might require
|
||||||
|
// promotion or expansion. Relegalize the return.
|
||||||
|
Result = LegalizeOp(Result);
|
||||||
|
} else {
|
||||||
|
SDOperand Lo, Hi;
|
||||||
|
SplitVectorOp(Tmp2, Lo, Hi);
|
||||||
|
Result = DAG.getNode(ISD::RET, MVT::Other, Tmp1, Lo, Hi);
|
||||||
|
Result = LegalizeOp(Result);
|
||||||
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
case Promote:
|
case Promote:
|
||||||
Tmp2 = PromoteOp(Node->getOperand(1));
|
Tmp2 = PromoteOp(Node->getOperand(1));
|
||||||
Result = DAG.UpdateNodeOperands(Result, Tmp1, Tmp2);
|
Result = DAG.UpdateNodeOperands(Result, Tmp1, Tmp2);
|
||||||
|
Loading…
Reference in New Issue
Block a user