diff options
| author | Michael J. Spencer <bigcheesegs@gmail.com> | 2010-07-27 06:46:15 +0000 |
|---|---|---|
| committer | Michael J. Spencer <bigcheesegs@gmail.com> | 2010-07-27 06:46:15 +0000 |
| commit | f8270bdb2d0465dd9ac4f33357d369eddd572a73 (patch) | |
| tree | 4a91c1c2e9d1574dd366d7b3af28cb654f71a5db /llvm/lib | |
| parent | cceb1f2e677ae46ed830072d04777b082e88190a (diff) | |
| download | bcm5719-llvm-f8270bdb2d0465dd9ac4f33357d369eddd572a73.tar.gz bcm5719-llvm-f8270bdb2d0465dd9ac4f33357d369eddd572a73.zip | |
Make MC use Windows COFF on Windows and add tests.
llvm-svn: 109494
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/X86/X86AsmBackend.cpp | 21 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86TargetMachine.cpp | 2 |
2 files changed, 23 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/X86AsmBackend.cpp b/llvm/lib/Target/X86/X86AsmBackend.cpp index 2cf65c11f94..e572620826d 100644 --- a/llvm/lib/Target/X86/X86AsmBackend.cpp +++ b/llvm/lib/Target/X86/X86AsmBackend.cpp @@ -14,6 +14,7 @@ #include "llvm/MC/MCAssembler.h" #include "llvm/MC/MCExpr.h" #include "llvm/MC/MCObjectWriter.h" +#include "llvm/MC/MCSectionCOFF.h" #include "llvm/MC/MCSectionELF.h" #include "llvm/MC/MCSectionMachO.h" #include "llvm/MC/MachObjectWriter.h" @@ -212,6 +213,24 @@ public: : ELFX86AsmBackend(T) {} }; +class WindowsX86AsmBackend : public X86AsmBackend { +public: + WindowsX86AsmBackend(const Target &T) + : X86AsmBackend(T) { + HasAbsolutizedSet = true; + HasScatteredSymbols = true; + } + + MCObjectWriter *createObjectWriter(raw_ostream &OS) const { + return createWinCOFFObjectWriter (OS); + } + + bool isVirtualSection(const MCSection &Section) const { + const MCSectionCOFF &SE = static_cast<const MCSectionCOFF&>(Section); + return SE.getCharacteristics() & COFF::IMAGE_SCN_CNT_UNINITIALIZED_DATA; + } +}; + class DarwinX86AsmBackend : public X86AsmBackend { public: DarwinX86AsmBackend(const Target &T) @@ -290,6 +309,8 @@ TargetAsmBackend *llvm::createX86_32AsmBackend(const Target &T, switch (Triple(TT).getOS()) { case Triple::Darwin: return new DarwinX86_32AsmBackend(T); + case Triple::Win32: + return new WindowsX86AsmBackend(T); default: return new ELFX86_32AsmBackend(T); } diff --git a/llvm/lib/Target/X86/X86TargetMachine.cpp b/llvm/lib/Target/X86/X86TargetMachine.cpp index 900b516441c..0552a8e6120 100644 --- a/llvm/lib/Target/X86/X86TargetMachine.cpp +++ b/llvm/lib/Target/X86/X86TargetMachine.cpp @@ -46,6 +46,8 @@ static MCStreamer *createMCStreamer(const Target &T, const std::string &TT, bool RelaxAll) { Triple TheTriple(TT); switch (TheTriple.getOS()) { + case Triple::Win32: + return createWinCOFFStreamer(Ctx, TAB, *_Emitter, _OS); default: return createMachOStreamer(Ctx, TAB, _OS, _Emitter, RelaxAll); } |

