diff options
author | Chris Lattner <sabre@nondot.org> | 2010-02-02 23:57:42 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-02-02 23:57:42 +0000 |
commit | 20bb6c0b391cad84d81120cf11330c998a97371d (patch) | |
tree | f300ce13390bc5fc38222dd3d00eb8ec4b6214cf | |
parent | 876e7f04bbe49f63030a1164b42a8e3b8004cb24 (diff) | |
download | external_llvm-20bb6c0b391cad84d81120cf11330c998a97371d.zip external_llvm-20bb6c0b391cad84d81120cf11330c998a97371d.tar.gz external_llvm-20bb6c0b391cad84d81120cf11330c998a97371d.tar.bz2 |
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
-rw-r--r-- | include/llvm/MC/MCStreamer.h | 2 | ||||
-rw-r--r-- | lib/CodeGen/LLVMTargetMachine.cpp | 19 | ||||
-rw-r--r-- | 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 be10947..cfd4572 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 d255492..af33776 100644 --- a/lib/CodeGen/LLVMTargetMachine.cpp +++ b/lib/CodeGen/LLVMTargetMachine.cpp @@ -124,23 +124,30 @@ LLVMTargetMachine::addPassesToEmitFile(PassManagerBase &PM, OwningPtr<MCStreamer> 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 eebd208..c7bd1c6 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; } |