mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 04:30:23 +00:00
Move ARMMachObjectWriter to its own file.
Just tidy up a bit. No functional change. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133638 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a098bf1239
commit
2fc6898886
@ -27,6 +27,7 @@ class FunctionPass;
|
|||||||
class JITCodeEmitter;
|
class JITCodeEmitter;
|
||||||
class formatted_raw_ostream;
|
class formatted_raw_ostream;
|
||||||
class MCCodeEmitter;
|
class MCCodeEmitter;
|
||||||
|
class MCObjectWriter;
|
||||||
class TargetAsmBackend;
|
class TargetAsmBackend;
|
||||||
class MachineInstr;
|
class MachineInstr;
|
||||||
class ARMAsmPrinter;
|
class ARMAsmPrinter;
|
||||||
@ -58,6 +59,12 @@ extern Target TheARMTarget, TheThumbTarget;
|
|||||||
void LowerARMMachineInstrToMCInst(const MachineInstr *MI, MCInst &OutMI,
|
void LowerARMMachineInstrToMCInst(const MachineInstr *MI, MCInst &OutMI,
|
||||||
ARMAsmPrinter &AP);
|
ARMAsmPrinter &AP);
|
||||||
|
|
||||||
|
/// createARMMachObjectWriter - Construct an ARM Mach-O object writer.
|
||||||
|
MCObjectWriter *createARMMachObjectWriter(raw_ostream &OS,
|
||||||
|
bool Is64Bit,
|
||||||
|
uint32_t CPUType,
|
||||||
|
uint32_t CPUSubtype);
|
||||||
|
|
||||||
} // end namespace llvm;
|
} // end namespace llvm;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -28,14 +28,6 @@
|
|||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
class ARMMachObjectWriter : public MCMachObjectTargetWriter {
|
|
||||||
public:
|
|
||||||
ARMMachObjectWriter(bool Is64Bit, uint32_t CPUType,
|
|
||||||
uint32_t CPUSubtype)
|
|
||||||
: MCMachObjectTargetWriter(Is64Bit, CPUType, CPUSubtype,
|
|
||||||
/*UseAggressiveSymbolFolding=*/true) {}
|
|
||||||
};
|
|
||||||
|
|
||||||
class ARMELFObjectWriter : public MCELFObjectTargetWriter {
|
class ARMELFObjectWriter : public MCELFObjectTargetWriter {
|
||||||
public:
|
public:
|
||||||
ARMELFObjectWriter(Triple::OSType OSType)
|
ARMELFObjectWriter(Triple::OSType OSType)
|
||||||
@ -423,12 +415,9 @@ public:
|
|||||||
: ARMAsmBackend(T), Subtype(st) { }
|
: ARMAsmBackend(T), Subtype(st) { }
|
||||||
|
|
||||||
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
||||||
return createMachObjectWriter(new ARMMachObjectWriter(
|
return createARMMachObjectWriter(OS, /*Is64Bit=*/false,
|
||||||
/*Is64Bit=*/false,
|
object::mach::CTM_ARM,
|
||||||
object::mach::CTM_ARM,
|
Subtype);
|
||||||
Subtype),
|
|
||||||
OS,
|
|
||||||
/*IsLittleEndian=*/true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ApplyFixup(const MCFixup &Fixup, char *Data, unsigned DataSize,
|
void ApplyFixup(const MCFixup &Fixup, char *Data, unsigned DataSize,
|
||||||
|
32
lib/Target/ARM/ARMMachObjectWriter.cpp
Normal file
32
lib/Target/ARM/ARMMachObjectWriter.cpp
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
//===-- ARMMachObjectWriter.cpp - ARM Mach Object Writer ------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "ARM.h"
|
||||||
|
#include "llvm/MC/MCMachObjectWriter.h"
|
||||||
|
using namespace llvm;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
class ARMMachObjectWriter : public MCMachObjectTargetWriter {
|
||||||
|
public:
|
||||||
|
ARMMachObjectWriter(bool Is64Bit, uint32_t CPUType,
|
||||||
|
uint32_t CPUSubtype)
|
||||||
|
: MCMachObjectTargetWriter(Is64Bit, CPUType, CPUSubtype,
|
||||||
|
/*UseAggressiveSymbolFolding=*/true) {}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
MCObjectWriter *llvm::createARMMachObjectWriter(raw_ostream &OS,
|
||||||
|
bool Is64Bit,
|
||||||
|
uint32_t CPUType,
|
||||||
|
uint32_t CPUSubtype) {
|
||||||
|
return createMachObjectWriter(new ARMMachObjectWriter(Is64Bit,
|
||||||
|
CPUType,
|
||||||
|
CPUSubtype),
|
||||||
|
OS, /*IsLittleEndian=*/true);
|
||||||
|
}
|
@ -34,6 +34,7 @@ add_llvm_target(ARMCodeGen
|
|||||||
ARMISelLowering.cpp
|
ARMISelLowering.cpp
|
||||||
ARMInstrInfo.cpp
|
ARMInstrInfo.cpp
|
||||||
ARMJITInfo.cpp
|
ARMJITInfo.cpp
|
||||||
|
ARMMachObjectWriter.cpp
|
||||||
ARMMCCodeEmitter.cpp
|
ARMMCCodeEmitter.cpp
|
||||||
ARMMCExpr.cpp
|
ARMMCExpr.cpp
|
||||||
ARMLoadStoreOptimizer.cpp
|
ARMLoadStoreOptimizer.cpp
|
||||||
|
Loading…
Reference in New Issue
Block a user