summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-07-26 05:03:33 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-07-26 05:03:33 +0000
commitee01b242e8600e97dea3f0c0bd9895c8dc71bf94 (patch)
tree44f8a26930ac47b87e7594d575cd46ea14c6c158 /llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp
parentbd481a119c5c69b4f8ede1db221327a415d010af (diff)
downloadbcm5719-llvm-ee01b242e8600e97dea3f0c0bd9895c8dc71bf94.tar.gz
bcm5719-llvm-ee01b242e8600e97dea3f0c0bd9895c8dc71bf94.zip
Factor commonality in triple match routines into helper template for registering
classes, and migrate existing targets over. llvm-svn: 77126
Diffstat (limited to 'llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp')
-rw-r--r--llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp39
1 files changed, 3 insertions, 36 deletions
diff --git a/llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp b/llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp
index 4f075456032..cc3d61e4e71 100644
--- a/llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp
+++ b/llvm/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp
@@ -12,43 +12,10 @@
#include "llvm/Target/TargetRegistry.h"
using namespace llvm;
-Target llvm::TheMipsTarget;
-
-static unsigned Mips_TripleMatchQuality(const std::string &TT) {
- // We strongly match "mips*-*".
- if (TT.size() >= 5 && std::string(TT.begin(), TT.begin()+5) == "mips-")
- return 20;
-
- if (TT.size() >= 13 && std::string(TT.begin(),
- TT.begin()+13) == "mipsallegrex-")
- return 20;
-
- return 0;
-}
-
-Target llvm::TheMipselTarget;
-
-static unsigned Mipsel_TripleMatchQuality(const std::string &TT) {
- // We strongly match "mips*el-*".
- if (TT.size() >= 7 && std::string(TT.begin(), TT.begin()+7) == "mipsel-")
- return 20;
-
- if (TT.size() >= 15 && std::string(TT.begin(),
- TT.begin()+15) == "mipsallegrexel-")
- return 20;
-
- if (TT.size() == 3 && std::string(TT.begin(), TT.begin()+3) == "psp")
- return 20;
-
- return 0;
-}
+Target llvm::TheMipsTarget, llvm::TheMipselTarget;
extern "C" void LLVMInitializeMipsTargetInfo() {
- TargetRegistry::RegisterTarget(TheMipsTarget, "mips",
- "Mips",
- &Mips_TripleMatchQuality);
+ RegisterTarget<Triple::mips> X(TheMipsTarget, "mips", "Mips");
- TargetRegistry::RegisterTarget(TheMipselTarget, "mipsel",
- "Mipsel",
- &Mipsel_TripleMatchQuality);
+ RegisterTarget<Triple::mipsel> Y(TheMipselTarget, "mipsel", "Mipsel");
}
OpenPOWER on IntegriCloud