1 | /*===-- llvm-c/Transform/PassBuilder.h - PassBuilder for LLVM C ---*- C -*-===*\ |
2 | |* *| |
3 | |* Part of the LLVM Project, under the Apache License v2.0 with LLVM *| |
4 | |* Exceptions. *| |
5 | |* See https://llvm.org/LICENSE.txt for license information. *| |
6 | |* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception *| |
7 | |* *| |
8 | |*===----------------------------------------------------------------------===*| |
9 | |* *| |
10 | |* This header contains the LLVM-C interface into the new pass manager *| |
11 | |* *| |
12 | \*===----------------------------------------------------------------------===*/ |
13 | |
14 | #ifndef LLVM_C_TRANSFORMS_PASSBUILDER_H |
15 | #define LLVM_C_TRANSFORMS_PASSBUILDER_H |
16 | |
17 | #include "llvm-c/Error.h" |
18 | #include "llvm-c/TargetMachine.h" |
19 | #include "llvm-c/Types.h" |
20 | |
21 | /** |
22 | * @defgroup LLVMCCoreNewPM New Pass Manager |
23 | * @ingroup LLVMCCore |
24 | * |
25 | * @{ |
26 | */ |
27 | |
28 | LLVM_C_EXTERN_C_BEGIN |
29 | |
30 | /** |
31 | * A set of options passed which are attached to the Pass Manager upon run. |
32 | * |
33 | * This corresponds to an llvm::LLVMPassBuilderOptions instance |
34 | * |
35 | * The details for how the different properties of this structure are used can |
36 | * be found in the source for LLVMRunPasses |
37 | */ |
38 | typedef struct LLVMOpaquePassBuilderOptions *LLVMPassBuilderOptionsRef; |
39 | |
40 | /** |
41 | * Construct and run a set of passes over a module |
42 | * |
43 | * This function takes a string with the passes that should be used. The format |
44 | * of this string is the same as opt's -passes argument for the new pass |
45 | * manager. Individual passes may be specified, separated by commas. Full |
46 | * pipelines may also be invoked using `default<O3>` and friends. See opt for |
47 | * full reference of the Passes format. |
48 | */ |
49 | LLVMErrorRef LLVMRunPasses(LLVMModuleRef M, const char *Passes, |
50 | LLVMTargetMachineRef TM, |
51 | LLVMPassBuilderOptionsRef Options); |
52 | |
53 | /** |
54 | * Construct and run a set of passes over a function. |
55 | * |
56 | * This function behaves the same as LLVMRunPasses, but operates on a single |
57 | * function instead of an entire module. |
58 | */ |
59 | LLVMErrorRef LLVMRunPassesOnFunction(LLVMValueRef F, const char *Passes, |
60 | LLVMTargetMachineRef TM, |
61 | LLVMPassBuilderOptionsRef Options); |
62 | |
63 | /** |
64 | * Create a new set of options for a PassBuilder |
65 | * |
66 | * Ownership of the returned instance is given to the client, and they are |
67 | * responsible for it. The client should call LLVMDisposePassBuilderOptions |
68 | * to free the pass builder options. |
69 | */ |
70 | LLVMPassBuilderOptionsRef LLVMCreatePassBuilderOptions(void); |
71 | |
72 | /** |
73 | * Toggle adding the VerifierPass for the PassBuilder, ensuring all functions |
74 | * inside the module is valid. |
75 | */ |
76 | void LLVMPassBuilderOptionsSetVerifyEach(LLVMPassBuilderOptionsRef Options, |
77 | LLVMBool VerifyEach); |
78 | |
79 | /** |
80 | * Toggle debug logging when running the PassBuilder |
81 | */ |
82 | void LLVMPassBuilderOptionsSetDebugLogging(LLVMPassBuilderOptionsRef Options, |
83 | LLVMBool DebugLogging); |
84 | |
85 | /** |
86 | * Specify a custom alias analysis pipeline for the PassBuilder to be used |
87 | * instead of the default one. The string argument is not copied; the caller |
88 | * is responsible for ensuring it outlives the PassBuilderOptions instance. |
89 | */ |
90 | void LLVMPassBuilderOptionsSetAAPipeline(LLVMPassBuilderOptionsRef Options, |
91 | const char *AAPipeline); |
92 | |
93 | void LLVMPassBuilderOptionsSetLoopInterleaving( |
94 | LLVMPassBuilderOptionsRef Options, LLVMBool LoopInterleaving); |
95 | |
96 | void LLVMPassBuilderOptionsSetLoopVectorization( |
97 | LLVMPassBuilderOptionsRef Options, LLVMBool LoopVectorization); |
98 | |
99 | void LLVMPassBuilderOptionsSetSLPVectorization( |
100 | LLVMPassBuilderOptionsRef Options, LLVMBool SLPVectorization); |
101 | |
102 | void LLVMPassBuilderOptionsSetLoopUnrolling(LLVMPassBuilderOptionsRef Options, |
103 | LLVMBool LoopUnrolling); |
104 | |
105 | void LLVMPassBuilderOptionsSetForgetAllSCEVInLoopUnroll( |
106 | LLVMPassBuilderOptionsRef Options, LLVMBool ForgetAllSCEVInLoopUnroll); |
107 | |
108 | void LLVMPassBuilderOptionsSetLicmMssaOptCap(LLVMPassBuilderOptionsRef Options, |
109 | unsigned LicmMssaOptCap); |
110 | |
111 | void LLVMPassBuilderOptionsSetLicmMssaNoAccForPromotionCap( |
112 | LLVMPassBuilderOptionsRef Options, unsigned LicmMssaNoAccForPromotionCap); |
113 | |
114 | void LLVMPassBuilderOptionsSetCallGraphProfile( |
115 | LLVMPassBuilderOptionsRef Options, LLVMBool CallGraphProfile); |
116 | |
117 | void LLVMPassBuilderOptionsSetMergeFunctions(LLVMPassBuilderOptionsRef Options, |
118 | LLVMBool MergeFunctions); |
119 | |
120 | void LLVMPassBuilderOptionsSetInlinerThreshold( |
121 | LLVMPassBuilderOptionsRef Options, int Threshold); |
122 | |
123 | /** |
124 | * Dispose of a heap-allocated PassBuilderOptions instance |
125 | */ |
126 | void LLVMDisposePassBuilderOptions(LLVMPassBuilderOptionsRef Options); |
127 | |
128 | /** |
129 | * @} |
130 | */ |
131 | |
132 | LLVM_C_EXTERN_C_END |
133 | |
134 | #endif // LLVM_C_TRANSFORMS_PASSBUILDER_H |
135 | |