mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-02 22:04:55 +00:00
X86/MC/Mach-O: Split out createX86MachObjectWriter().
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122246 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ee9a2e322a
commit
9b2f25e313
@ -29,6 +29,7 @@ set(sources
|
|||||||
X86ISelLowering.cpp
|
X86ISelLowering.cpp
|
||||||
X86InstrInfo.cpp
|
X86InstrInfo.cpp
|
||||||
X86JITInfo.cpp
|
X86JITInfo.cpp
|
||||||
|
X86MachObjectWriter.cpp
|
||||||
X86MCAsmInfo.cpp
|
X86MCAsmInfo.cpp
|
||||||
X86MCCodeEmitter.cpp
|
X86MCCodeEmitter.cpp
|
||||||
X86MCInstLower.cpp
|
X86MCInstLower.cpp
|
||||||
|
@ -23,11 +23,13 @@ class FunctionPass;
|
|||||||
class JITCodeEmitter;
|
class JITCodeEmitter;
|
||||||
class MCCodeEmitter;
|
class MCCodeEmitter;
|
||||||
class MCContext;
|
class MCContext;
|
||||||
|
class MCObjectWriter;
|
||||||
class MachineCodeEmitter;
|
class MachineCodeEmitter;
|
||||||
class Target;
|
class Target;
|
||||||
class TargetAsmBackend;
|
class TargetAsmBackend;
|
||||||
class X86TargetMachine;
|
class X86TargetMachine;
|
||||||
class formatted_raw_ostream;
|
class formatted_raw_ostream;
|
||||||
|
class raw_ostream;
|
||||||
|
|
||||||
/// createX86ISelDag - This pass converts a legalized DAG into a
|
/// createX86ISelDag - This pass converts a legalized DAG into a
|
||||||
/// X86-specific DAG, ready for instruction scheduling.
|
/// X86-specific DAG, ready for instruction scheduling.
|
||||||
@ -74,6 +76,13 @@ FunctionPass *createEmitX86CodeToMemory();
|
|||||||
///
|
///
|
||||||
FunctionPass *createX86MaxStackAlignmentHeuristicPass();
|
FunctionPass *createX86MaxStackAlignmentHeuristicPass();
|
||||||
|
|
||||||
|
|
||||||
|
/// createX86MachObjectWriter - Construct an X86 Mach-O object writer.
|
||||||
|
MCObjectWriter *createX86MachObjectWriter(raw_ostream &OS,
|
||||||
|
bool Is64Bit,
|
||||||
|
uint32_t CPUType,
|
||||||
|
uint32_t CPUSubtype);
|
||||||
|
|
||||||
extern Target TheX86_32Target, TheX86_64Target;
|
extern Target TheX86_32Target, TheX86_64Target;
|
||||||
|
|
||||||
} // End llvm namespace
|
} // End llvm namespace
|
||||||
|
@ -46,13 +46,6 @@ static unsigned getFixupKindLog2Size(unsigned Kind) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
class X86MachObjectWriter : public MCMachObjectTargetWriter {
|
|
||||||
public:
|
|
||||||
X86MachObjectWriter(bool Is64Bit, uint32_t CPUType,
|
|
||||||
uint32_t CPUSubtype)
|
|
||||||
: MCMachObjectTargetWriter(Is64Bit, CPUType, CPUSubtype,
|
|
||||||
/*UseAggressiveSymbolFolding=*/Is64Bit) {}
|
|
||||||
};
|
|
||||||
|
|
||||||
class X86ELFObjectWriter : public MCELFObjectTargetWriter {
|
class X86ELFObjectWriter : public MCELFObjectTargetWriter {
|
||||||
public:
|
public:
|
||||||
@ -357,11 +350,9 @@ public:
|
|||||||
: DarwinX86AsmBackend(T) {}
|
: DarwinX86AsmBackend(T) {}
|
||||||
|
|
||||||
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
||||||
return createMachObjectWriter(new X86MachObjectWriter(
|
return createX86MachObjectWriter(OS, /*Is64Bit=*/false,
|
||||||
/*Is64Bit=*/false,
|
object::mach::CTM_i386,
|
||||||
object::mach::CTM_i386,
|
object::mach::CSX86_ALL);
|
||||||
object::mach::CSX86_ALL),
|
|
||||||
OS, /*IsLittleEndian=*/true);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -373,11 +364,9 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
|
||||||
return createMachObjectWriter(new X86MachObjectWriter(
|
return createX86MachObjectWriter(OS, /*Is64Bit=*/true,
|
||||||
/*Is64Bit=*/true,
|
object::mach::CTM_x86_64,
|
||||||
object::mach::CTM_x86_64,
|
object::mach::CSX86_ALL);
|
||||||
object::mach::CSX86_ALL),
|
|
||||||
OS, /*IsLittleEndian=*/true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool doesSectionRequireSymbols(const MCSection &Section) const {
|
virtual bool doesSectionRequireSymbols(const MCSection &Section) const {
|
||||||
|
32
lib/Target/X86/X86MachObjectWriter.cpp
Normal file
32
lib/Target/X86/X86MachObjectWriter.cpp
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
//===-- X86MachObjectWriter.cpp - X86 Mach-O Writer -----------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "X86.h"
|
||||||
|
#include "llvm/MC/MCMachObjectWriter.h"
|
||||||
|
using namespace llvm;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
class X86MachObjectWriter : public MCMachObjectTargetWriter {
|
||||||
|
public:
|
||||||
|
X86MachObjectWriter(bool Is64Bit, uint32_t CPUType,
|
||||||
|
uint32_t CPUSubtype)
|
||||||
|
: MCMachObjectTargetWriter(Is64Bit, CPUType, CPUSubtype,
|
||||||
|
/*UseAggressiveSymbolFolding=*/Is64Bit) {}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
MCObjectWriter *llvm::createX86MachObjectWriter(raw_ostream &OS,
|
||||||
|
bool Is64Bit,
|
||||||
|
uint32_t CPUType,
|
||||||
|
uint32_t CPUSubtype) {
|
||||||
|
return createMachObjectWriter(new X86MachObjectWriter(Is64Bit,
|
||||||
|
CPUType,
|
||||||
|
CPUSubtype),
|
||||||
|
OS, /*IsLittleEndian=*/true);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user