From 998051a2211a5f86b38941de0aca241b34895e1e Mon Sep 17 00:00:00 2001 From: Devang Patel Date: Thu, 7 Sep 2006 21:41:11 +0000 Subject: Using addPassesToEmitWholeFile is not a good idea here. Use FunctionPassManager to do the job. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30160 91177308-0d34-0410-b5e6-96231b3b80d8 --- tools/lto/lto.cpp | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) (limited to 'tools') diff --git a/tools/lto/lto.cpp b/tools/lto/lto.cpp index fedd4aef71..05114b7f32 100644 --- a/tools/lto/lto.cpp +++ b/tools/lto/lto.cpp @@ -282,11 +282,24 @@ static enum LTOStatus lto_optimize(Module *M, std::ostream &Out, // Make sure everything is still good. Passes.add(createVerifierPass()); - Target.addPassesToEmitWholeFile(Passes, Out, TargetMachine::AssemblyFile, true); + FunctionPassManager *CodeGenPasses = + new FunctionPassManager(new ExistingModuleProvider(M)); + + CodeGenPasses->add(new TargetData(*Target.getTargetData())); + Target.addPassesToEmitFile(*CodeGenPasses, Out, TargetMachine::AssemblyFile, + true); // Run our queue of passes all at once now, efficiently. Passes.run(*M); + // Run the code generator, if present. + CodeGenPasses->doInitialization(); + for (Module::iterator I = M->begin(), E = M->end(); I != E; ++I) { + if (!I->isExternal()) + CodeGenPasses->run(*I); + } + CodeGenPasses->doFinalization(); + return LTO_OPT_SUCCESS; } -- cgit v1.2.3