summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/ARM/TargetInfo/ARMTargetInfo.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/ARM/TargetInfo/ARMTargetInfo.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/ARM/TargetInfo/ARMTargetInfo.cpp')
-rw-r--r--llvm/lib/Target/ARM/TargetInfo/ARMTargetInfo.cpp34
1 files changed, 5 insertions, 29 deletions
diff --git a/llvm/lib/Target/ARM/TargetInfo/ARMTargetInfo.cpp b/llvm/lib/Target/ARM/TargetInfo/ARMTargetInfo.cpp
index a975a1c6e90..163a0a98758 100644
--- a/llvm/lib/Target/ARM/TargetInfo/ARMTargetInfo.cpp
+++ b/llvm/lib/Target/ARM/TargetInfo/ARMTargetInfo.cpp
@@ -12,36 +12,12 @@
#include "llvm/Target/TargetRegistry.h"
using namespace llvm;
-Target llvm::TheARMTarget;
-
-static unsigned ARM_TripleMatchQuality(const std::string &TT) {
- // Match arm-foo-bar, as well as things like armv5blah-*
- if (TT.size() >= 4 &&
- (TT.substr(0, 4) == "arm-" || TT.substr(0, 4) == "armv"))
- return 20;
-
- return 0;
-}
-
-Target llvm::TheThumbTarget;
-
-static unsigned Thumb_TripleMatchQuality(const std::string &TT) {
- // Match thumb-foo-bar, as well as things like thumbv5blah-*
- if (TT.size() >= 6 &&
- (TT.substr(0, 6) == "thumb-" || TT.substr(0, 6) == "thumbv"))
- return 20;
-
- return 0;
-}
+Target llvm::TheARMTarget, llvm::TheThumbTarget;
extern "C" void LLVMInitializeARMTargetInfo() {
- TargetRegistry::RegisterTarget(TheARMTarget, "arm",
- "ARM",
- &ARM_TripleMatchQuality,
- /*HasJIT=*/true);
+ RegisterTarget<Triple::arm, /*HasJIT=*/true>
+ X(TheARMTarget, "arm", "ARM");
- TargetRegistry::RegisterTarget(TheThumbTarget, "thumb",
- "Thumb",
- &Thumb_TripleMatchQuality,
- /*HasJIT=*/true);
+ RegisterTarget<Triple::thumb, /*HasJIT=*/true>
+ Y(TheThumbTarget, "thumb", "Thumb");
}
OpenPOWER on IntegriCloud