mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-07 11:33:44 +00:00
R600/SI: Handle nodes with glue results correctly SITargetLowering::foldOperands()
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@183133 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8a72c73032
commit
051a28e0e8
@ -700,6 +700,22 @@ SDNode *SITargetLowering::foldOperands(MachineSDNode *Node,
|
|||||||
for (unsigned i = NumOps - NumDefs, e = Node->getNumOperands(); i < e; ++i)
|
for (unsigned i = NumOps - NumDefs, e = Node->getNumOperands(); i < e; ++i)
|
||||||
Ops.push_back(Node->getOperand(i));
|
Ops.push_back(Node->getOperand(i));
|
||||||
|
|
||||||
|
// Nodes that have a glue result are not CSE'd by getMachineNode(), so in
|
||||||
|
// this case a brand new node is always be created, even if the operands
|
||||||
|
// are the same as before. So, manually check if anything has been changed.
|
||||||
|
if (Desc->Opcode == Opcode) {
|
||||||
|
bool Changed = false;
|
||||||
|
for (unsigned i = 0, e = Node->getNumOperands(); i < e; ++i) {
|
||||||
|
if (Ops[i].getNode() != Node->getOperand(i).getNode()) {
|
||||||
|
Changed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!Changed) {
|
||||||
|
return Node;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Create a complete new instruction
|
// Create a complete new instruction
|
||||||
return DAG.getMachineNode(Desc->Opcode, SDLoc(Node), Node->getVTList(), Ops);
|
return DAG.getMachineNode(Desc->Opcode, SDLoc(Node), Node->getVTList(), Ops);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user