diff options
| author | Craig Topper <craig.topper@intel.com> | 2017-11-22 07:11:01 +0000 |
|---|---|---|
| committer | Craig Topper <craig.topper@intel.com> | 2017-11-22 07:11:01 +0000 |
| commit | fb0d4cd48c0a9eada7273dd56a432eec342f6010 (patch) | |
| tree | 1be94f265e6ddf374bda188a8d487964e559515f /llvm/utils/TableGen | |
| parent | 23044fa63946909ec21dee0cca5f5a50d83f8262 (diff) | |
| download | bcm5719-llvm-fb0d4cd48c0a9eada7273dd56a432eec342f6010.tar.gz bcm5719-llvm-fb0d4cd48c0a9eada7273dd56a432eec342f6010.zip | |
[SelectionDAG] Add a isel matcher op to check the type of node results other than result 0.
I plan to use this to check the type of the mask result of masked gathers in the X86 backend.
llvm-svn: 318820
Diffstat (limited to 'llvm/utils/TableGen')
| -rw-r--r-- | llvm/utils/TableGen/DAGISelMatcherEmitter.cpp | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/llvm/utils/TableGen/DAGISelMatcherEmitter.cpp b/llvm/utils/TableGen/DAGISelMatcherEmitter.cpp index edfc5a19b82..e64943c1d02 100644 --- a/llvm/utils/TableGen/DAGISelMatcherEmitter.cpp +++ b/llvm/utils/TableGen/DAGISelMatcherEmitter.cpp @@ -497,11 +497,14 @@ EmitMatcher(const Matcher *N, unsigned Indent, unsigned CurrentIdx, } case Matcher::CheckType: - assert(cast<CheckTypeMatcher>(N)->getResNo() == 0 && - "FIXME: Add support for CheckType of resno != 0"); - OS << "OPC_CheckType, " - << getEnumName(cast<CheckTypeMatcher>(N)->getType()) << ",\n"; - return 2; + if (cast<CheckTypeMatcher>(N)->getResNo() == 0) { + OS << "OPC_CheckType, " + << getEnumName(cast<CheckTypeMatcher>(N)->getType()) << ",\n"; + return 2; + } + OS << "OPC_CheckTypeRes, " << cast<CheckTypeMatcher>(N)->getResNo() + << ", " << getEnumName(cast<CheckTypeMatcher>(N)->getType()) << ",\n"; + return 3; case Matcher::CheckChildType: OS << "OPC_CheckChild" |

