aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/Alpha/TargetInfo
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Target/Alpha/TargetInfo')
-rw-r--r--lib/Target/Alpha/TargetInfo/AlphaTargetInfo.cpp57
-rw-r--r--lib/Target/Alpha/TargetInfo/CMakeLists.txt6
-rw-r--r--lib/Target/Alpha/TargetInfo/Makefile15
3 files changed, 78 insertions, 0 deletions
diff --git a/lib/Target/Alpha/TargetInfo/AlphaTargetInfo.cpp b/lib/Target/Alpha/TargetInfo/AlphaTargetInfo.cpp
new file mode 100644
index 0000000..df560b8
--- /dev/null
+++ b/lib/Target/Alpha/TargetInfo/AlphaTargetInfo.cpp
@@ -0,0 +1,57 @@
+//===-- AlphaTargetInfo.cpp - Alpha Target Implementation -----------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/Module.h"
+#include "llvm/Target/TargetRegistry.h"
+using namespace llvm;
+
+Target TheAlphaTarget;
+
+static unsigned Alpha_JITMatchQuality() {
+#ifdef __alpha
+ return 10;
+#else
+ return 0;
+#endif
+}
+
+static unsigned Alpha_TripleMatchQuality(const std::string &TT) {
+ // We strongly match "alpha*".
+ if (TT.size() >= 5 && TT[0] == 'a' && TT[1] == 'l' && TT[2] == 'p' &&
+ TT[3] == 'h' && TT[4] == 'a')
+ return 20;
+
+ return 0;
+}
+
+static unsigned Alpha_ModuleMatchQuality(const Module &M) {
+ // Check for a triple match.
+ if (unsigned Q = Alpha_TripleMatchQuality(M.getTargetTriple()))
+ return Q;
+
+ // Otherwise if the target triple is non-empty, we don't match.
+ if (!M.getTargetTriple().empty()) return 0;
+
+ if (M.getEndianness() == Module::LittleEndian &&
+ M.getPointerSize() == Module::Pointer64)
+ return 10; // Weak match
+ else if (M.getEndianness() != Module::AnyEndianness ||
+ M.getPointerSize() != Module::AnyPointerSize)
+ return 0; // Match for some other target
+
+ return Alpha_JITMatchQuality()/2;
+}
+
+extern "C" void LLVMInitializeAlphaTargetInfo() {
+ TargetRegistry::RegisterTarget(TheAlphaTarget, "alpha",
+ "Alpha [experimental]",
+ &Alpha_TripleMatchQuality,
+ &Alpha_ModuleMatchQuality,
+ &Alpha_JITMatchQuality);
+}
diff --git a/lib/Target/Alpha/TargetInfo/CMakeLists.txt b/lib/Target/Alpha/TargetInfo/CMakeLists.txt
new file mode 100644
index 0000000..4478ef8
--- /dev/null
+++ b/lib/Target/Alpha/TargetInfo/CMakeLists.txt
@@ -0,0 +1,6 @@
+include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/.. )
+
+add_llvm_library(LLVMAlphaInfo
+ AlphaTargetInfo.cpp
+ )
+
diff --git a/lib/Target/Alpha/TargetInfo/Makefile b/lib/Target/Alpha/TargetInfo/Makefile
new file mode 100644
index 0000000..7250358
--- /dev/null
+++ b/lib/Target/Alpha/TargetInfo/Makefile
@@ -0,0 +1,15 @@
+#===- lib/Target/Alpha/TargetInfo/Makefile -----------------*- Makefile -*-===##
+#
+# The LLVM Compiler Infrastructure
+#
+# This file is distributed under the University of Illinois Open Source
+# License. See LICENSE.TXT for details.
+#
+##===----------------------------------------------------------------------===##
+LEVEL = ../../../..
+LIBRARYNAME = LLVMAlphaInfo
+
+# Hack: we need to include 'main' target directory to grab private headers
+CPPFLAGS = -I$(PROJ_OBJ_DIR)/.. -I$(PROJ_SRC_DIR)/..
+
+include $(LEVEL)/Makefile.common