summaryrefslogtreecommitdiff
path: root/support/tools
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-08-15 04:28:04 +0000
committerChris Lattner <sabre@nondot.org>2003-08-15 04:28:04 +0000
commit673537e5c000f37963a41b15079162984f9208c9 (patch)
tree23e73cdc468eb84645a073e81bb8f0cbc113f831 /support/tools
parentaf06a08584aeae7b68a1b13c775d939de61c94d3 (diff)
downloadllvm-673537e5c000f37963a41b15079162984f9208c9.tar.gz
llvm-673537e5c000f37963a41b15079162984f9208c9.tar.bz2
llvm-673537e5c000f37963a41b15079162984f9208c9.tar.xz
Add support for nodes with void arguments, like chain nodes
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7869 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'support/tools')
-rw-r--r--support/tools/TableGen/InstrSelectorEmitter.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/support/tools/TableGen/InstrSelectorEmitter.cpp b/support/tools/TableGen/InstrSelectorEmitter.cpp
index 28c7de1140..2db6da4bd2 100644
--- a/support/tools/TableGen/InstrSelectorEmitter.cpp
+++ b/support/tools/TableGen/InstrSelectorEmitter.cpp
@@ -299,6 +299,9 @@ bool Pattern::InferTypes(TreePatternNode *N, bool &MadeChange) {
MadeChange |= Child->updateNodeType(ISE.getTarget().getPointerType(),
TheRecord->getName());
break;
+ case NodeType::Void:
+ MadeChange |= Child->updateNodeType(MVT::isVoid, TheRecord->getName());
+ break;
default: assert(0 && "Invalid argument ArgType!");
}
}
@@ -449,8 +452,6 @@ void InstrSelectorEmitter::ReadNodeTypes() {
throw "In node " + Node->getName() + ", arg 0 cannot have type 'arg0'!";
if (a == 1 && ArgTypes.back() == NodeType::Arg1)
throw "In node " + Node->getName() + ", arg 1 cannot have type 'arg1'!";
- if (ArgTypes.back() == NodeType::Void)
- throw "In node " + Node->getName() + ", args cannot be void type!";
}
if ((RetTy == NodeType::Arg0 && Args->getSize() == 0) ||
(RetTy == NodeType::Arg1 && Args->getSize() < 2))