mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-05 13:26:55 +00:00
Unbreak
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@76064 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
6
lib/Target/SystemZ/TargetInfo/CMakeLists.txt
Normal file
6
lib/Target/SystemZ/TargetInfo/CMakeLists.txt
Normal file
@@ -0,0 +1,6 @@
|
||||
include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/.. )
|
||||
|
||||
add_llvm_library(LLVMSystemZInfo
|
||||
SystemZTargetInfo.cpp
|
||||
)
|
||||
|
15
lib/Target/SystemZ/TargetInfo/Makefile
Normal file
15
lib/Target/SystemZ/TargetInfo/Makefile
Normal file
@@ -0,0 +1,15 @@
|
||||
##===- lib/Target/SystemZ/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 = LLVMSystemZInfo
|
||||
|
||||
# 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
|
44
lib/Target/SystemZ/TargetInfo/SystemZTargetInfo.cpp
Normal file
44
lib/Target/SystemZ/TargetInfo/SystemZTargetInfo.cpp
Normal file
@@ -0,0 +1,44 @@
|
||||
//===-- SystemZTargetInfo.cpp - SystemZ 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 TheSystemZTarget;
|
||||
|
||||
static unsigned SystemZ_JITMatchQuality() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned SystemZ_TripleMatchQuality(const std::string &TT) {
|
||||
// We strongly match s390x
|
||||
if (TT.size() >= 5 && TT[0] == 's' && TT[1] == '3' && TT[2] == '9' &&
|
||||
TT[3] == '0' && TT[4] == 'x')
|
||||
return 20;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned SystemZ_ModuleMatchQuality(const Module &M) {
|
||||
// Check for a triple match.
|
||||
if (unsigned Q = SystemZ_TripleMatchQuality(M.getTargetTriple()))
|
||||
return Q;
|
||||
|
||||
// Otherwise we don't match.
|
||||
return 0;
|
||||
}
|
||||
|
||||
extern "C" void LLVMInitializeSystemZTargetInfo() {
|
||||
TargetRegistry::RegisterTarget(TheSystemZTarget, "systemz",
|
||||
"SystemZ",
|
||||
&SystemZ_TripleMatchQuality,
|
||||
&SystemZ_ModuleMatchQuality,
|
||||
&SystemZ_JITMatchQuality);
|
||||
}
|
Reference in New Issue
Block a user