summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatt Fleming <matt@console-pimps.org>2010-08-16 18:36:14 +0000
committerMatt Fleming <matt@console-pimps.org>2010-08-16 18:36:14 +0000
commitf751d856f0cb6211a54f1e50f8fa9d55a14aa49c (patch)
tree6130eaf5e7aa3cfa834d06ef5fa8e198f75460d6
parentd83b9278970ef9b102c5eb5ad6289084cef93943 (diff)
downloadbcm5719-llvm-f751d856f0cb6211a54f1e50f8fa9d55a14aa49c.tar.gz
bcm5719-llvm-f751d856f0cb6211a54f1e50f8fa9d55a14aa49c.zip
Hookup ELF support for X86.
llvm-svn: 111173
-rw-r--r--llvm/lib/Target/X86/X86AsmBackend.cpp17
-rw-r--r--llvm/lib/Target/X86/X86TargetMachine.cpp3
2 files changed, 14 insertions, 6 deletions
diff --git a/llvm/lib/Target/X86/X86AsmBackend.cpp b/llvm/lib/Target/X86/X86AsmBackend.cpp
index 248eeac7ffb..6455a18a3fd 100644
--- a/llvm/lib/Target/X86/X86AsmBackend.cpp
+++ b/llvm/lib/Target/X86/X86AsmBackend.cpp
@@ -11,6 +11,7 @@
#include "X86.h"
#include "X86FixupKinds.h"
#include "llvm/ADT/Twine.h"
+#include "llvm/MC/ELFObjectWriter.h"
#include "llvm/MC/MCAssembler.h"
#include "llvm/MC/MCExpr.h"
#include "llvm/MC/MCObjectWriter.h"
@@ -191,10 +192,6 @@ public:
HasScatteredSymbols = true;
}
- MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
- return 0;
- }
-
bool isVirtualSection(const MCSection &Section) const {
const MCSectionELF &SE = static_cast<const MCSectionELF&>(Section);
return SE.getType() == MCSectionELF::SHT_NOBITS;;
@@ -205,12 +202,24 @@ class ELFX86_32AsmBackend : public ELFX86AsmBackend {
public:
ELFX86_32AsmBackend(const Target &T)
: ELFX86AsmBackend(T) {}
+
+ MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
+ return new ELFObjectWriter(OS, /*Is64Bit=*/false,
+ /*IsLittleEndian=*/true,
+ /*HasRelocationAddend=*/false);
+ }
};
class ELFX86_64AsmBackend : public ELFX86AsmBackend {
public:
ELFX86_64AsmBackend(const Target &T)
: ELFX86AsmBackend(T) {}
+
+ MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
+ return new ELFObjectWriter(OS, /*Is64Bit=*/true,
+ /*IsLittleEndian=*/true,
+ /*HasRelocationAddend=*/true);
+ }
};
class WindowsX86AsmBackend : public X86AsmBackend {
diff --git a/llvm/lib/Target/X86/X86TargetMachine.cpp b/llvm/lib/Target/X86/X86TargetMachine.cpp
index 560f070abdc..3c8e7f1d339 100644
--- a/llvm/lib/Target/X86/X86TargetMachine.cpp
+++ b/llvm/lib/Target/X86/X86TargetMachine.cpp
@@ -54,8 +54,7 @@ static MCStreamer *createMCStreamer(const Target &T, const std::string &TT,
case Triple::Win32:
return createWinCOFFStreamer(Ctx, TAB, *_Emitter, _OS, RelaxAll);
default:
- // FIXME: default to ELF.
- report_fatal_error("object emission not implemented for this target.");
+ return createELFStreamer(Ctx, TAB, _OS, _Emitter, RelaxAll);
}
}
OpenPOWER on IntegriCloud