Fix PR1975: dag isel emitter produces patterns that isel wrong flag result.

llvm-svn: 46776
This commit is contained in:
Evan Cheng 2008-02-05 22:50:29 +00:00
parent e509232483
commit 851d353eb8
3 changed files with 33 additions and 8 deletions
lib/CodeGen/SelectionDAG
test/CodeGen/X86
utils/TableGen

View File

@ -3183,10 +3183,6 @@ SDNode *SelectionDAG::getTargetNode(unsigned Opcode,
void SelectionDAG::ReplaceAllUsesWith(SDOperand FromN, SDOperand To,
DAGUpdateListener *UpdateListener) {
SDNode *From = FromN.Val;
// FIXME: This works around a dag isel emitter bug.
if (From->getNumValues() == 1 && FromN.ResNo != 0)
return; // FIXME: THIS IS BOGUS
assert(From->getNumValues() == 1 && FromN.ResNo == 0 &&
"Cannot replace with this method!");
assert(From != To.Val && "Cannot replace uses of with self");

View File

@ -0,0 +1,12 @@
; RUN: llvm-as < %s | llc -march=x86
; PR1975
@nodes = external global i64 ; <i64*> [#uses=2]
define fastcc i32 @ab(i32 %alpha, i32 %beta) nounwind {
entry:
%tmp1 = load i64* @nodes, align 8 ; <i64> [#uses=1]
%tmp2 = add i64 %tmp1, 1 ; <i64> [#uses=1]
store i64 %tmp2, i64* @nodes, align 8
ret i32 0
}

View File

@ -305,6 +305,8 @@ private:
std::map<std::string, std::string> VariableMap;
// Node to operator mapping
std::map<std::string, Record*> OperatorMap;
// Name of the folded node which produces a flag.
std::pair<std::string, unsigned> FoldedFlag;
// Names of all the folded nodes which produce chains.
std::vector<std::pair<std::string, unsigned> > FoldedChains;
// Original input chain(s).
@ -587,8 +589,17 @@ public:
emitCheck(RootName + ".getOpcode() == " +
CInfo.getEnumName());
EmitMatchCode(Child, Parent, RootName, ChainSuffix, FoundChain);
if (NodeHasProperty(Child, SDNPHasChain, CGP))
bool HasChain = false;
if (NodeHasProperty(Child, SDNPHasChain, CGP)) {
HasChain = true;
FoldedChains.push_back(std::make_pair(RootName, CInfo.getNumResults()));
}
if (NodeHasProperty(Child, SDNPOutFlag, CGP)) {
assert(FoldedFlag.first == "" && FoldedFlag.second == 0 &&
"Pattern folded multiple nodes which produce flags?");
FoldedFlag = std::make_pair(RootName,
CInfo.getNumResults() + (unsigned)HasChain);
}
} else {
// If this child has a name associated with it, capture it in VarMap. If
// we already saw this in the pattern, emit code to verify dagness.
@ -1105,9 +1116,15 @@ public:
}
if (NodeHasOutFlag) {
emitCode("ReplaceUses(SDOperand(N.Val, " +
utostr(NumPatResults + (unsigned)InputHasChain)
+"), InFlag);");
if (FoldedFlag.first != "") {
emitCode("ReplaceUses(SDOperand(" + FoldedFlag.first + ".Val, " +
utostr(FoldedFlag.second) + "), InFlag);");
} else {
assert(NodeHasProperty(Pattern, SDNPOutFlag, CGP));
emitCode("ReplaceUses(SDOperand(N.Val, " +
utostr(NumPatResults + (unsigned)InputHasChain)
+"), InFlag);");
}
NeedReplace = true;
}