summaryrefslogtreecommitdiffstats
path: root/llvm/utils/TableGen/DAGISelEmitter.cpp
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2009-05-12 22:32:29 +0000
committerDale Johannesen <dalej@apple.com>2009-05-12 22:32:29 +0000
commit69ee5e4cfeff5aac77842a4aa8b18965a5c89b51 (patch)
treed79b4a91e5c7aaef95f6d9bfeeafaf18b0b3c11f /llvm/utils/TableGen/DAGISelEmitter.cpp
parent46632d89bb8e15aa97ef6d1b769e0dc265fbbd53 (diff)
downloadbcm5719-llvm-69ee5e4cfeff5aac77842a4aa8b18965a5c89b51.tar.gz
bcm5719-llvm-69ee5e4cfeff5aac77842a4aa8b18965a5c89b51.zip
Slightly improve generated code in a degenerate case.
Should remove a warning from MSVC. llvm-svn: 71603
Diffstat (limited to 'llvm/utils/TableGen/DAGISelEmitter.cpp')
-rw-r--r--llvm/utils/TableGen/DAGISelEmitter.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/llvm/utils/TableGen/DAGISelEmitter.cpp b/llvm/utils/TableGen/DAGISelEmitter.cpp
index 39791e2cba5..0e2e61596f6 100644
--- a/llvm/utils/TableGen/DAGISelEmitter.cpp
+++ b/llvm/utils/TableGen/DAGISelEmitter.cpp
@@ -2025,6 +2025,14 @@ void DAGISelEmitter::EmitInstructionSelector(std::ostream &OS) {
OpcodeVTMap.find(OpName);
std::vector<std::string> &OpVTs = OpVTI->second;
OS << " case " << OpName << ": {\n";
+ // If we have only one variant and it's the default, elide the
+ // switch. Marginally faster, and makes MSVC happier.
+ if (OpVTs.size()==1 && OpVTs[0].empty()) {
+ OS << " return Select_" << getLegalCName(OpName) << "(N);\n";
+ OS << " break;\n";
+ OS << " }\n";
+ continue;
+ }
// Keep track of whether we see a pattern that has an iPtr result.
bool HasPtrPattern = false;
bool HasDefaultPattern = false;
OpenPOWER on IntegriCloud