From 36b56886974eae4f9c5ebc96befd3e7bfe5de338 Mon Sep 17 00:00:00 2001 From: Stephen Hines Date: Wed, 23 Apr 2014 16:57:46 -0700 Subject: Update to LLVM 3.5a. Change-Id: Ifadecab779f128e62e430c2b4f6ddd84953ed617 --- lib/Target/XCore/MCTargetDesc/CMakeLists.txt | 5 -- lib/Target/XCore/MCTargetDesc/LLVMBuild.txt | 2 +- lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp | 3 +- .../XCore/MCTargetDesc/XCoreMCTargetDesc.cpp | 58 ++++++++++++++++++++++ 4 files changed, 60 insertions(+), 8 deletions(-) (limited to 'lib/Target/XCore/MCTargetDesc') diff --git a/lib/Target/XCore/MCTargetDesc/CMakeLists.txt b/lib/Target/XCore/MCTargetDesc/CMakeLists.txt index 3a3f5b4..a14cf5c 100644 --- a/lib/Target/XCore/MCTargetDesc/CMakeLists.txt +++ b/lib/Target/XCore/MCTargetDesc/CMakeLists.txt @@ -2,8 +2,3 @@ add_llvm_library(LLVMXCoreDesc XCoreMCTargetDesc.cpp XCoreMCAsmInfo.cpp ) - -add_dependencies(LLVMXCoreDesc XCoreCommonTableGen) - -# Hack: we need to include 'main' target directory to grab private headers -include_directories(${CMAKE_CURRENT_SOURCE_DIR}/.. ${CMAKE_CURRENT_BINARY_DIR}/..) diff --git a/lib/Target/XCore/MCTargetDesc/LLVMBuild.txt b/lib/Target/XCore/MCTargetDesc/LLVMBuild.txt index 8213f9e..6d390d2 100644 --- a/lib/Target/XCore/MCTargetDesc/LLVMBuild.txt +++ b/lib/Target/XCore/MCTargetDesc/LLVMBuild.txt @@ -19,5 +19,5 @@ type = Library name = XCoreDesc parent = XCore -required_libraries = MC XCoreAsmPrinter XCoreInfo +required_libraries = MC Support XCoreAsmPrinter XCoreInfo add_to_library_groups = XCore diff --git a/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp b/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp index 3d1c474..f788c59 100644 --- a/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp +++ b/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp @@ -20,8 +20,7 @@ XCoreMCAsmInfo::XCoreMCAsmInfo(StringRef TT) { Data64bitsDirective = 0; ZeroDirective = "\t.space\t"; CommentString = "#"; - - PrivateGlobalPrefix = ".L"; + AscizDirective = ".asciiz"; HiddenVisibilityAttr = MCSA_Invalid; diff --git a/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp b/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp index 10bb6df..439d0ab 100644 --- a/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp +++ b/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp @@ -14,11 +14,13 @@ #include "XCoreMCTargetDesc.h" #include "InstPrinter/XCoreInstPrinter.h" #include "XCoreMCAsmInfo.h" +#include "XCoreTargetStreamer.h" #include "llvm/MC/MCCodeGenInfo.h" #include "llvm/MC/MCInstrInfo.h" #include "llvm/MC/MCRegisterInfo.h" #include "llvm/MC/MCSubtargetInfo.h" #include "llvm/Support/ErrorHandling.h" +#include "llvm/Support/FormattedStream.h" #include "llvm/Support/TargetRegistry.h" #define GET_INSTRINFO_MC_DESC @@ -69,6 +71,12 @@ static MCCodeGenInfo *createXCoreMCCodeGenInfo(StringRef TT, Reloc::Model RM, if (RM == Reloc::Default) { RM = Reloc::Static; } + if (CM == CodeModel::Default) { + CM = CodeModel::Small; + } + if (CM != CodeModel::Small && CM != CodeModel::Large) + report_fatal_error("Target only supports CodeModel Small or Large"); + X->InitMCCodeGenInfo(RM, CM, OL); return X; } @@ -82,6 +90,54 @@ static MCInstPrinter *createXCoreMCInstPrinter(const Target &T, return new XCoreInstPrinter(MAI, MII, MRI); } +XCoreTargetStreamer::XCoreTargetStreamer(MCStreamer &S) : MCTargetStreamer(S) {} +XCoreTargetStreamer::~XCoreTargetStreamer() {} + +namespace { + +class XCoreTargetAsmStreamer : public XCoreTargetStreamer { + formatted_raw_ostream &OS; +public: + XCoreTargetAsmStreamer(MCStreamer &S, formatted_raw_ostream &OS); + virtual void emitCCTopData(StringRef Name) override; + virtual void emitCCTopFunction(StringRef Name) override; + virtual void emitCCBottomData(StringRef Name) override; + virtual void emitCCBottomFunction(StringRef Name) override; +}; + +XCoreTargetAsmStreamer::XCoreTargetAsmStreamer(MCStreamer &S, + formatted_raw_ostream &OS) + : XCoreTargetStreamer(S), OS(OS) {} + +void XCoreTargetAsmStreamer::emitCCTopData(StringRef Name) { + OS << "\t.cc_top " << Name << ".data," << Name << '\n'; +} + +void XCoreTargetAsmStreamer::emitCCTopFunction(StringRef Name) { + OS << "\t.cc_top " << Name << ".function," << Name << '\n'; +} + +void XCoreTargetAsmStreamer::emitCCBottomData(StringRef Name) { + OS << "\t.cc_bottom " << Name << ".data\n"; +} + +void XCoreTargetAsmStreamer::emitCCBottomFunction(StringRef Name) { + OS << "\t.cc_bottom " << Name << ".function\n"; +} +} + +static MCStreamer * +createXCoreMCAsmStreamer(MCContext &Ctx, formatted_raw_ostream &OS, + bool isVerboseAsm, bool useCFI, bool useDwarfDirectory, + MCInstPrinter *InstPrint, MCCodeEmitter *CE, + MCAsmBackend *TAB, bool ShowInst) { + MCStreamer *S = + llvm::createAsmStreamer(Ctx, OS, isVerboseAsm, useCFI, useDwarfDirectory, + InstPrint, CE, TAB, ShowInst); + new XCoreTargetAsmStreamer(*S, OS); + return S; +} + // Force static initialization. extern "C" void LLVMInitializeXCoreTargetMC() { // Register the MC asm info. @@ -104,4 +160,6 @@ extern "C" void LLVMInitializeXCoreTargetMC() { // Register the MCInstPrinter TargetRegistry::RegisterMCInstPrinter(TheXCoreTarget, createXCoreMCInstPrinter); + + TargetRegistry::RegisterAsmStreamer(TheXCoreTarget, createXCoreMCAsmStreamer); } -- cgit v1.1