diff options
author | Chris Lattner <sabre@nondot.org> | 2010-02-02 23:37:42 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-02-02 23:37:42 +0000 |
commit | b0d44c38077d620ff69265ec0ccd9a2c8aa39b7a (patch) | |
tree | 599bc831e1b54f8fffd45fb217e6b52519247efd /llvm/lib/CodeGen/LLVMTargetMachine.cpp | |
parent | e67d01a9a8dbf25ba502411ac7319be3e6789e0e (diff) | |
download | bcm5719-llvm-b0d44c38077d620ff69265ec0ccd9a2c8aa39b7a.tar.gz bcm5719-llvm-b0d44c38077d620ff69265ec0ccd9a2c8aa39b7a.zip |
refactor code so that LLVMTargetMachine creates the asmstreamer and
mccontext instead of having AsmPrinter do it. This allows other
types of MCStreamer's to be passed in.
llvm-svn: 95155
Diffstat (limited to 'llvm/lib/CodeGen/LLVMTargetMachine.cpp')
-rw-r--r-- | llvm/lib/CodeGen/LLVMTargetMachine.cpp | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/LLVMTargetMachine.cpp b/llvm/lib/CodeGen/LLVMTargetMachine.cpp index a4f313938d5..f4065924b1d 100644 --- a/llvm/lib/CodeGen/LLVMTargetMachine.cpp +++ b/llvm/lib/CodeGen/LLVMTargetMachine.cpp @@ -21,6 +21,9 @@ #include "llvm/CodeGen/MachineFunctionAnalysis.h" #include "llvm/Target/TargetOptions.h" #include "llvm/MC/MCAsmInfo.h" +#include "llvm/MC/MCContext.h" +#include "llvm/MC/MCStreamer.h" +#include "llvm/Target/TargetData.h" #include "llvm/Target/TargetRegistry.h" #include "llvm/Transforms/Scalar.h" #include "llvm/Support/CommandLine.h" @@ -121,10 +124,24 @@ LLVMTargetMachine::addPassesToEmitFile(PassManagerBase &PM, case CGFT_ObjectFile: return CGFT_ErrorOccurred; case CGFT_AssemblyFile: { + MCContext *Context = new MCContext(); + MCStreamer *AsmStreamer = + createAsmStreamer(*Context, Out, *getMCAsmInfo(), + getTargetData()->isLittleEndian(), + getVerboseAsm(), + /*instprinter*/0, + /*codeemitter*/0); + + // Create the AsmPrinter, which takes ownership of Context and AsmStreamer + // if successful. FunctionPass *Printer = - getTarget().createAsmPrinter(Out, *this, getMCAsmInfo(), - getVerboseAsm()); - if (Printer == 0) return CGFT_ErrorOccurred; + getTarget().createAsmPrinter(Out, *this, *Context, *AsmStreamer, + getMCAsmInfo()); + if (Printer == 0) { + delete AsmStreamer; + delete Context; + return CGFT_ErrorOccurred; + } PM.add(Printer); break; } |