aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-09-13 21:59:15 +0000
committerChris Lattner <sabre@nondot.org>2005-09-13 21:59:15 +0000
commit6de8b53230a44b3e09801e8bf100a110d03a2b64 (patch)
tree72e4eb799b46db6a5379946daa03135cd62ac0a6
parent24eeeb8c3e80e22cb2fd311580ae22b5e3ae7b51 (diff)
continue xform function parsing
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23338 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--utils/TableGen/DAGISelEmitter.cpp8
-rw-r--r--utils/TableGen/DAGISelEmitter.h5
2 files changed, 12 insertions, 1 deletions
diff --git a/utils/TableGen/DAGISelEmitter.cpp b/utils/TableGen/DAGISelEmitter.cpp
index af9dc95e97..590e19420a 100644
--- a/utils/TableGen/DAGISelEmitter.cpp
+++ b/utils/TableGen/DAGISelEmitter.cpp
@@ -509,7 +509,7 @@ void DAGISelEmitter::ParseNodeTransforms(std::ostream &OS) {
SDNodeXForms.insert(std::make_pair(XFormNode,
std::make_pair(SDNode, Code)));
- if (!Code.empty()) {
+ if (0 && !Code.empty()) {
std::string ClassName = getSDNodeInfo(SDNode).getSDClassName();
const char *C2 = ClassName == "SDNode" ? "N" : "inN";
@@ -592,6 +592,12 @@ void DAGISelEmitter::ParseAndResolvePatternFragments(std::ostream &OS) {
OS << Code << "\n}\n";
P->getOnlyTree()->setPredicateFn("Predicate_"+Fragments[i]->getName());
}
+
+ // If there is a node transformation corresponding to this, keep track of
+ // it.
+ Record *Transform = Fragments[i]->getValueAsDef("OperandTransform");
+ if (!getSDNodeTransform(Transform).second.empty()) // not noop xform?
+ P->getOnlyTree()->setTransformFn("Transform_"+Transform->getName());
}
OS << "\n\n";
diff --git a/utils/TableGen/DAGISelEmitter.h b/utils/TableGen/DAGISelEmitter.h
index d160522867..d9668552db 100644
--- a/utils/TableGen/DAGISelEmitter.h
+++ b/utils/TableGen/DAGISelEmitter.h
@@ -302,6 +302,11 @@ public:
return PatternFragments.find(R)->second;
}
+ const std::pair<Record*, std::string> &getSDNodeTransform(Record *R) const {
+ assert(SDNodeXForms.count(R) && "Invalid transform!");
+ return SDNodeXForms.find(R)->second;
+ }
+
private:
void ParseNodeInfo();
void ParseNodeTransforms(std::ostream &OS);