forked from OSchip/llvm-project
Fix an infinite loop I caused by making sure to legalize the flag operand
of CALLSEQ_* nodes llvm-svn: 25582
This commit is contained in:
parent
78c38a7bc7
commit
f9a1e3aadc
|
@ -823,6 +823,13 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||
Tmp2 = Node->getOperand(0);
|
||||
if (Tmp1 != Tmp2)
|
||||
Node->setAdjCallChain(Tmp1);
|
||||
|
||||
// If this has a flag input, do legalize it.
|
||||
if (Node->getOperand(Node->getNumOperands()-1).getValueType() == MVT::Flag){
|
||||
Tmp1 = LegalizeOp(Node->getOperand(Node->getNumOperands()-1));
|
||||
if (Tmp1 != Node->getOperand(Node->getNumOperands()-1))
|
||||
Node->setAdjCallFlag(Tmp1);
|
||||
}
|
||||
|
||||
// Note that we do not create new CALLSEQ_DOWN/UP nodes here. These
|
||||
// nodes are treated specially and are mutated in place. This makes the dag
|
||||
|
@ -1365,7 +1372,8 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||
Tmp2,
|
||||
Node->getOperand(3));
|
||||
}
|
||||
Node = Result.Val;
|
||||
Result = LegalizeOp(Result);
|
||||
break;
|
||||
}
|
||||
|
||||
switch (getTypeAction(Node->getOperand(1).getValueType())) {
|
||||
|
|
|
@ -1276,6 +1276,19 @@ void SDNode::setAdjCallChain(SDOperand N) {
|
|||
OperandList[0].Val->Uses.push_back(this);
|
||||
}
|
||||
|
||||
// setAdjCallFlag - This method changes the flag input of an
|
||||
// CALLSEQ_START/END node to be the specified operand.
|
||||
void SDNode::setAdjCallFlag(SDOperand N) {
|
||||
assert(N.getValueType() == MVT::Flag);
|
||||
assert((getOpcode() == ISD::CALLSEQ_START ||
|
||||
getOpcode() == ISD::CALLSEQ_END) && "Cannot adjust this node!");
|
||||
|
||||
SDOperand &FlagOp = OperandList[getNumOperands()-1];
|
||||
assert(FlagOp.getValueType() == MVT::Flag);
|
||||
FlagOp.Val->removeUser(this);
|
||||
FlagOp = N;
|
||||
FlagOp.Val->Uses.push_back(this);
|
||||
}
|
||||
|
||||
|
||||
SDOperand SelectionDAG::getLoad(MVT::ValueType VT,
|
||||
|
|
Loading…
Reference in New Issue