From ac7798e9062f9bc371709ed445e1b3153b581e9a Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 2 Feb 2010 23:57:42 +0000 Subject: [PATCH] Hook up -filetype=obj through the MachO streamer. Here's a demo: $ cat t.ll @g = global i32 42 $ llc t.ll -o t.o -filetype=obj $ nm t.o 00000000 D _g There is still a ton of work left. Instructions are not being encoded yet apparently. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@95162 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/MC/MCStreamer.h | 2 +- lib/CodeGen/LLVMTargetMachine.cpp | 19 +++++++++++++------ tools/llc/llc.cpp | 1 + 3 files changed, 15 insertions(+), 7 deletions(-) diff --git a/include/llvm/MC/MCStreamer.h b/include/llvm/MC/MCStreamer.h index be10947969a..cfd457261ff 100644 --- a/include/llvm/MC/MCStreamer.h +++ b/include/llvm/MC/MCStreamer.h @@ -282,7 +282,7 @@ namespace llvm { /// createMachOStream - Create a machine code streamer which will generative /// Mach-O format object files. MCStreamer *createMachOStreamer(MCContext &Ctx, raw_ostream &OS, - MCCodeEmitter *CE = 0); + MCCodeEmitter *CE); /// createELFStreamer - Create a machine code streamer which will generative /// ELF format object files. diff --git a/lib/CodeGen/LLVMTargetMachine.cpp b/lib/CodeGen/LLVMTargetMachine.cpp index d255492ef8f..af33776c3a6 100644 --- a/lib/CodeGen/LLVMTargetMachine.cpp +++ b/lib/CodeGen/LLVMTargetMachine.cpp @@ -124,23 +124,30 @@ LLVMTargetMachine::addPassesToEmitFile(PassManagerBase &PM, OwningPtr AsmStreamer; switch (FileType) { - default: - case CGFT_ObjectFile: - return CGFT_ErrorOccurred; - case CGFT_AssemblyFile: { + default: return CGFT_ErrorOccurred; + case CGFT_AssemblyFile: AsmStreamer.reset(createAsmStreamer(*Context, Out, *getMCAsmInfo(), getTargetData()->isLittleEndian(), getVerboseAsm(), /*instprinter*/0, /*codeemitter*/0)); break; + case CGFT_ObjectFile: { + // Create the code emitter for the target if it exists. If not, .o file + // emission fails. + MCCodeEmitter *MCE = getTarget().createCodeEmitter(*this); + if (MCE == 0) + return CGFT_ErrorOccurred; + + AsmStreamer.reset(createMachOStreamer(*Context, Out, MCE)); + break; } } // Create the AsmPrinter, which takes ownership of Context and AsmStreamer // if successful. FunctionPass *Printer = - getTarget().createAsmPrinter(Out, *this, *Context, *AsmStreamer, - getMCAsmInfo()); + getTarget().createAsmPrinter(Out, *this, *Context, *AsmStreamer, + getMCAsmInfo()); if (Printer == 0) return CGFT_ErrorOccurred; diff --git a/tools/llc/llc.cpp b/tools/llc/llc.cpp index eebd20846ca..c7bd1c67067 100644 --- a/tools/llc/llc.cpp +++ b/tools/llc/llc.cpp @@ -360,6 +360,7 @@ int main(int argc, char **argv) { sys::Path(OutputFilename).eraseFromDisk(); return 1; case TargetMachine::CGFT_AssemblyFile: + case TargetMachine::CGFT_ObjectFile: break; }