1 //===- NewPMDriver.h - Function to drive opt with the new PM ----*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 /// \file
10 ///
11 /// A single function which is called to drive the opt behavior for the new
12 /// PassManager.
13 ///
14 /// This is only in a separate TU with a header to avoid including all of the
15 /// old pass manager headers and the new pass manager headers into the same
16 /// file. Eventually all of the routines here will get folded back into
17 /// opt.cpp.
18 ///
19 //===----------------------------------------------------------------------===//
20 
21 #ifndef LLVM_TOOLS_OPT_NEWPMDRIVER_H
22 #define LLVM_TOOLS_OPT_NEWPMDRIVER_H
23 
24 namespace llvm {
25 class StringRef;
26 class LLVMContext;
27 class Module;
28 class TargetMachine;
29 class tool_output_file;
30 
31 namespace opt_tool {
32 enum OutputKind {
33   OK_NoOutput,
34   OK_OutputAssembly,
35   OK_OutputBitcode
36 };
37 enum VerifierKind {
38   VK_NoVerifier,
39   VK_VerifyInAndOut,
40   VK_VerifyEachPass
41 };
42 }
43 
44 /// \brief Driver function to run the new pass manager over a module.
45 ///
46 /// This function only exists factored away from opt.cpp in order to prevent
47 /// inclusion of the new pass manager headers and the old headers into the same
48 /// file. It's interface is consequentially somewhat ad-hoc, but will go away
49 /// when the transition finishes.
50 bool runPassPipeline(StringRef Arg0, LLVMContext &Context, Module &M,
51                      TargetMachine *TM, tool_output_file *Out,
52                      StringRef PassPipeline, opt_tool::OutputKind OK,
53                      opt_tool::VerifierKind VK,
54                      bool ShouldPreserveAssemblyUseListOrder,
55                      bool ShouldPreserveBitcodeUseListOrder);
56 }
57 
58 #endif
59