mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-04 07:32:13 +00:00
MC/Mach-O: Stub out explicit MCMachObjectTargetWriter interface.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@121973 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
297ed28bf9
commit
ae5abd595f
@ -14,7 +14,23 @@
|
|||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
MCObjectWriter *createMachObjectWriter(raw_ostream &OS, bool is64Bit,
|
class MCMachObjectTargetWriter {
|
||||||
|
protected:
|
||||||
|
MCMachObjectTargetWriter();
|
||||||
|
|
||||||
|
public:
|
||||||
|
virtual ~MCMachObjectTargetWriter();
|
||||||
|
};
|
||||||
|
|
||||||
|
/// \brief Construct a new Mach-O writer instance.
|
||||||
|
///
|
||||||
|
/// This routine takes ownership of the target writer subclass.
|
||||||
|
///
|
||||||
|
/// \param MOTW - The target specific Mach-O writer subclass.
|
||||||
|
/// \param OS - The stream to write to.
|
||||||
|
/// \returns The constructed object writer.
|
||||||
|
MCObjectWriter *createMachObjectWriter(MCMachObjectTargetWriter *MOTW,
|
||||||
|
raw_ostream &OS, bool is64Bit,
|
||||||
uint32_t CPUType, uint32_t CPUSubtype,
|
uint32_t CPUType, uint32_t CPUSubtype,
|
||||||
bool IsLittleEndian);
|
bool IsLittleEndian);
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ add_llvm_library(LLVMMC
|
|||||||
MCDwarf.cpp
|
MCDwarf.cpp
|
||||||
MCLoggingStreamer.cpp
|
MCLoggingStreamer.cpp
|
||||||
MCMachOStreamer.cpp
|
MCMachOStreamer.cpp
|
||||||
|
MCMachObjectTargetWriter.cpp
|
||||||
MCNullStreamer.cpp
|
MCNullStreamer.cpp
|
||||||
MCObjectStreamer.cpp
|
MCObjectStreamer.cpp
|
||||||
MCObjectFormat.cpp
|
MCObjectFormat.cpp
|
||||||
|
18
lib/MC/MCMachObjectTargetWriter.cpp
Normal file
18
lib/MC/MCMachObjectTargetWriter.cpp
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
//===-- MCMachObjectTargetWriter.cpp - Mach-O Target Writer Subclass ------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "llvm/MC/MCMachObjectWriter.h"
|
||||||
|
|
||||||
|
using namespace llvm;
|
||||||
|
|
||||||
|
MCMachObjectTargetWriter::MCMachObjectTargetWriter() {
|
||||||
|
}
|
||||||
|
|
||||||
|
MCMachObjectTargetWriter::~MCMachObjectTargetWriter() {
|
||||||
|
}
|
@ -7,12 +7,13 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "llvm/MC/MCMachObjectWriter.h"
|
||||||
|
#include "llvm/ADT/OwningPtr.h"
|
||||||
#include "llvm/ADT/StringMap.h"
|
#include "llvm/ADT/StringMap.h"
|
||||||
#include "llvm/ADT/Twine.h"
|
#include "llvm/ADT/Twine.h"
|
||||||
#include "llvm/MC/MCAssembler.h"
|
#include "llvm/MC/MCAssembler.h"
|
||||||
#include "llvm/MC/MCAsmLayout.h"
|
#include "llvm/MC/MCAsmLayout.h"
|
||||||
#include "llvm/MC/MCExpr.h"
|
#include "llvm/MC/MCExpr.h"
|
||||||
#include "llvm/MC/MCMachObjectWriter.h"
|
|
||||||
#include "llvm/MC/MCObjectWriter.h"
|
#include "llvm/MC/MCObjectWriter.h"
|
||||||
#include "llvm/MC/MCSectionMachO.h"
|
#include "llvm/MC/MCSectionMachO.h"
|
||||||
#include "llvm/MC/MCSymbol.h"
|
#include "llvm/MC/MCSymbol.h"
|
||||||
@ -162,17 +163,8 @@ class MachObjectWriter : public MCObjectWriter {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/// @name Utility Methods
|
/// The target specific Mach-O writer instance.
|
||||||
/// @{
|
llvm::OwningPtr<MCMachObjectTargetWriter> TargetObjectWriter;
|
||||||
|
|
||||||
bool isFixupKindPCRel(const MCAssembler &Asm, unsigned Kind) {
|
|
||||||
const MCFixupKindInfo &FKI = Asm.getBackend().getFixupKindInfo(
|
|
||||||
(MCFixupKind) Kind);
|
|
||||||
|
|
||||||
return FKI.Flags & MCFixupKindInfo::FKF_IsPCRel;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @}
|
|
||||||
|
|
||||||
/// @name Relocation Data
|
/// @name Relocation Data
|
||||||
/// @{
|
/// @{
|
||||||
@ -192,6 +184,19 @@ class MachObjectWriter : public MCObjectWriter {
|
|||||||
|
|
||||||
/// @}
|
/// @}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/// @name Utility Methods
|
||||||
|
/// @{
|
||||||
|
|
||||||
|
bool isFixupKindPCRel(const MCAssembler &Asm, unsigned Kind) {
|
||||||
|
const MCFixupKindInfo &FKI = Asm.getBackend().getFixupKindInfo(
|
||||||
|
(MCFixupKind) Kind);
|
||||||
|
|
||||||
|
return FKI.Flags & MCFixupKindInfo::FKF_IsPCRel;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// @}
|
||||||
|
|
||||||
SectionAddrMap SectionAddress;
|
SectionAddrMap SectionAddress;
|
||||||
uint64_t getSectionAddress(const MCSectionData* SD) const {
|
uint64_t getSectionAddress(const MCSectionData* SD) const {
|
||||||
return SectionAddress.lookup(SD);
|
return SectionAddress.lookup(SD);
|
||||||
@ -226,10 +231,10 @@ class MachObjectWriter : public MCObjectWriter {
|
|||||||
uint32_t CPUSubtype;
|
uint32_t CPUSubtype;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MachObjectWriter(raw_ostream &_OS,
|
MachObjectWriter(MCMachObjectTargetWriter *MOTW, raw_ostream &_OS,
|
||||||
bool _Is64Bit, uint32_t _CPUType, uint32_t _CPUSubtype,
|
bool _Is64Bit, uint32_t _CPUType, uint32_t _CPUSubtype,
|
||||||
bool _IsLittleEndian)
|
bool _IsLittleEndian)
|
||||||
: MCObjectWriter(_OS, _IsLittleEndian),
|
: MCObjectWriter(_OS, _IsLittleEndian), TargetObjectWriter(MOTW),
|
||||||
Is64Bit(_Is64Bit), CPUType(_CPUType), CPUSubtype(_CPUSubtype) {
|
Is64Bit(_Is64Bit), CPUType(_CPUType), CPUSubtype(_CPUSubtype) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1321,9 +1326,11 @@ public:
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MCObjectWriter *llvm::createMachObjectWriter(raw_ostream &OS, bool is64Bit,
|
MCObjectWriter *llvm::createMachObjectWriter(MCMachObjectTargetWriter *MOTW,
|
||||||
|
raw_ostream &OS, bool is64Bit,
|
||||||
uint32_t CPUType,
|
uint32_t CPUType,
|
||||||
uint32_t CPUSubtype,
|
uint32_t CPUSubtype,
|
||||||
bool IsLittleEndian) {
|
bool IsLittleEndian) {
|
||||||
return new MachObjectWriter(OS, is64Bit, CPUType, CPUSubtype, IsLittleEndian);
|
return new MachObjectWriter(MOTW, OS, is64Bit, CPUType, CPUSubtype,
|
||||||
|
IsLittleEndian);
|
||||||
}
|
}
|
||||||
|
@ -28,6 +28,9 @@
|
|||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
class ARMMachObjectWriter : public MCMachObjectTargetWriter {
|
||||||
|
};
|
||||||
|
|
||||||
class ARMAsmBackend : public TargetAsmBackend {
|
class ARMAsmBackend : public TargetAsmBackend {
|
||||||
bool isThumbMode; // Currently emitting Thumb code.
|
bool isThumbMode; // Currently emitting Thumb code.
|
||||||
public:
|
public:
|
||||||
@ -382,7 +385,8 @@ public:
|
|||||||
|
|
||||||
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
||||||
// FIXME: Subtarget info should be derived. Force v7 for now.
|
// FIXME: Subtarget info should be derived. Force v7 for now.
|
||||||
return createMachObjectWriter(OS, /*Is64Bit=*/false,
|
return createMachObjectWriter(new ARMMachObjectWriter,
|
||||||
|
OS, /*Is64Bit=*/false,
|
||||||
object::mach::CTM_ARM,
|
object::mach::CTM_ARM,
|
||||||
object::mach::CSARM_V7,
|
object::mach::CSARM_V7,
|
||||||
/*IsLittleEndian=*/true);
|
/*IsLittleEndian=*/true);
|
||||||
|
@ -19,6 +19,9 @@
|
|||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
class PPCMachObjectWriter : public MCMachObjectTargetWriter {
|
||||||
|
};
|
||||||
|
|
||||||
class PPCAsmBackend : public TargetAsmBackend {
|
class PPCAsmBackend : public TargetAsmBackend {
|
||||||
const Target &TheTarget;
|
const Target &TheTarget;
|
||||||
public:
|
public:
|
||||||
@ -92,7 +95,8 @@ namespace {
|
|||||||
|
|
||||||
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
||||||
bool is64 = getPointerSize() == 8;
|
bool is64 = getPointerSize() == 8;
|
||||||
return createMachObjectWriter(OS, /*Is64Bit=*/is64,
|
return createMachObjectWriter(new PPCMachObjectWriter,
|
||||||
|
OS, /*Is64Bit=*/is64,
|
||||||
(is64 ? object::mach::CTM_PowerPC64 :
|
(is64 ? object::mach::CTM_PowerPC64 :
|
||||||
object::mach::CTM_PowerPC),
|
object::mach::CTM_PowerPC),
|
||||||
object::mach::CSPPC_ALL,
|
object::mach::CSPPC_ALL,
|
||||||
|
@ -46,6 +46,9 @@ static unsigned getFixupKindLog2Size(unsigned Kind) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
class X86MachObjectWriter : public MCMachObjectTargetWriter {
|
||||||
|
};
|
||||||
|
|
||||||
class X86AsmBackend : public TargetAsmBackend {
|
class X86AsmBackend : public TargetAsmBackend {
|
||||||
public:
|
public:
|
||||||
X86AsmBackend(const Target &T)
|
X86AsmBackend(const Target &T)
|
||||||
@ -362,7 +365,8 @@ public:
|
|||||||
: DarwinX86AsmBackend(T) {}
|
: DarwinX86AsmBackend(T) {}
|
||||||
|
|
||||||
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
||||||
return createMachObjectWriter(OS, /*Is64Bit=*/false,
|
return createMachObjectWriter(new X86MachObjectWriter,
|
||||||
|
OS, /*Is64Bit=*/false,
|
||||||
object::mach::CTM_i386,
|
object::mach::CTM_i386,
|
||||||
object::mach::CSX86_ALL,
|
object::mach::CSX86_ALL,
|
||||||
/*IsLittleEndian=*/true);
|
/*IsLittleEndian=*/true);
|
||||||
@ -377,7 +381,8 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
||||||
return createMachObjectWriter(OS, /*Is64Bit=*/true,
|
return createMachObjectWriter(new X86MachObjectWriter,
|
||||||
|
OS, /*Is64Bit=*/true,
|
||||||
object::mach::CTM_x86_64,
|
object::mach::CTM_x86_64,
|
||||||
object::mach::CSX86_ALL,
|
object::mach::CSX86_ALL,
|
||||||
/*IsLittleEndian=*/true);
|
/*IsLittleEndian=*/true);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user