diff options
author | Chris Lattner <sabre@nondot.org> | 2003-08-15 04:28:04 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2003-08-15 04:28:04 +0000 |
commit | 673537e5c000f37963a41b15079162984f9208c9 (patch) | |
tree | 23e73cdc468eb84645a073e81bb8f0cbc113f831 /support/tools | |
parent | af06a08584aeae7b68a1b13c775d939de61c94d3 (diff) | |
download | llvm-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.cpp | 5 |
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)) |