For instructions which produce no result, e.g. store, chain's Resno == 0.

llvm-svn: 24652
This commit is contained in:
Evan Cheng 2005-12-10 00:09:17 +00:00
parent 5c6a84b5fc
commit 8300ae66d1

View File

@ -1779,10 +1779,11 @@ public:
if (NodeHasChain(N, ISE)) {
OpNo = 1;
if (!isRoot) {
const SDNodeInfo &CInfo = ISE.getSDNodeInfo(N->getOperator());
OS << " if (!" << RootName << ".hasOneUse()) goto P"
<< PatternNo << "Fail; // Multiple uses of actual result?\n";
OS << " if (CodeGenMap.count(" << RootName
<< ".getValue(1))) goto P"
<< ".getValue(" << CInfo.getNumResults() << "))) goto P"
<< PatternNo << "Fail; // Already selected for a chain use?\n";
}
if (InnerChain.empty()) {
@ -2024,10 +2025,11 @@ public:
}
OS << " Chain ";
if (NodeHasChain(LHS, ISE))
OS << "= CodeGenMap[N.getValue(1)] ";
OS << "= CodeGenMap[N.getValue(" << NumResults << ")] ";
for (unsigned j = 0, e = FoldedChains.size(); j < e; j++)
OS << "= CodeGenMap[" << FoldedChains[j] << ".getValue(1)] ";
OS << "= Result.getValue(1);\n";
OS << "= CodeGenMap[" << FoldedChains[j] << ".getValue("
<< NumResults << ")] ";
OS << "= Result.getValue(" << NumResults << ");\n";
if (NumResults == 0)
OS << " return Chain;\n";
else