LLVM  10.0.0svn
PartialInlining.h
Go to the documentation of this file.
1 //===- PartialInlining.h - Inline parts of functions ------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This pass performs partial inlining, typically by inlining an if statement
10 // that surrounds the body of the function.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef LLVM_TRANSFORMS_IPO_PARTIALINLINING_H
15 #define LLVM_TRANSFORMS_IPO_PARTIALINLINING_H
16 
17 #include "llvm/IR/PassManager.h"
18 
19 namespace llvm {
20 
21 class Module;
22 
23 /// Pass to remove unused function declarations.
24 class PartialInlinerPass : public PassInfoMixin<PartialInlinerPass> {
25 public:
27 };
28 
29 } // end namespace llvm
30 
31 #endif // LLVM_TRANSFORMS_IPO_PARTIALINLINING_H
This class represents lattice values for constants.
Definition: AllocatorList.h:23
A Module instance is used to store all the information related to an LLVM module. ...
Definition: Module.h:65
Pass to remove unused function declarations.
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition: PassManager.h:372
PreservedAnalyses run(Module &M, ModuleAnalysisManager &)
A set of analyses that are preserved following a run of a transformation pass.
Definition: PassManager.h:153
A container for analyses that lazily runs them and caches their results.
This header defines various interfaces for pass management in LLVM.