LLVM  8.0.1
InstCombine.h
Go to the documentation of this file.
1 //===- InstCombine.h - InstCombine pass -------------------------*- 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 /// This file provides the primary interface to the instcombine pass. This pass
12 /// is suitable for use in the new pass manager. For a pass that works with the
13 /// legacy pass manager, use \c createInstructionCombiningPass().
14 ///
15 //===----------------------------------------------------------------------===//
16 
17 #ifndef LLVM_TRANSFORMS_INSTCOMBINE_INSTCOMBINE_H
18 #define LLVM_TRANSFORMS_INSTCOMBINE_INSTCOMBINE_H
19 
20 #include "llvm/IR/Function.h"
21 #include "llvm/IR/PassManager.h"
23 
24 namespace llvm {
25 
26 class InstCombinePass : public PassInfoMixin<InstCombinePass> {
27  InstCombineWorklist Worklist;
28  bool ExpensiveCombines;
29 
30 public:
31  static StringRef name() { return "InstCombinePass"; }
32 
33  explicit InstCombinePass(bool ExpensiveCombines = true)
34  : ExpensiveCombines(ExpensiveCombines) {}
35 
37 };
38 
39 /// The legacy pass manager's instcombine pass.
40 ///
41 /// This is a basic whole-function wrapper around the instcombine utility. It
42 /// will try to combine all instructions in the function.
44  InstCombineWorklist Worklist;
45  const bool ExpensiveCombines;
46 
47 public:
48  static char ID; // Pass identification, replacement for typeid
49 
50  InstructionCombiningPass(bool ExpensiveCombines = true)
51  : FunctionPass(ID), ExpensiveCombines(ExpensiveCombines) {
53  }
54 
55  void getAnalysisUsage(AnalysisUsage &AU) const override;
56  bool runOnFunction(Function &F) override;
57 };
58 
59 //===----------------------------------------------------------------------===//
60 //
61 // InstructionCombining - Combine instructions to form fewer, simple
62 // instructions. This pass does not modify the CFG, and has a tendency to make
63 // instructions dead, so a subsequent DCE pass is useful.
64 //
65 // This pass combines things like:
66 // %Y = add int 1, %X
67 // %Z = add int 1, %Y
68 // into:
69 // %Z = add int 2, %X
70 //
71 FunctionPass *createInstructionCombiningPass(bool ExpensiveCombines = true);
72 }
73 
74 #endif
static PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
This class represents lattice values for constants.
Definition: AllocatorList.h:24
F(f)
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition: PassManager.h:366
FunctionPass * createInstructionCombiningPass(bool ExpensiveCombines=true)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
static bool runOnFunction(Function &F, bool PostInlining)
A set of analyses that are preserved following a run of a transformation pass.
Definition: PassManager.h:154
Represent the analysis usage information of a pass.
FunctionPass class - This class is used to implement most global optimizations.
Definition: Pass.h:285
The legacy pass manager&#39;s instcombine pass.
Definition: InstCombine.h:43
InstructionCombiningPass(bool ExpensiveCombines=true)
Definition: InstCombine.h:50
InstCombineWorklist - This is the worklist management logic for InstCombine.
InstCombinePass(bool ExpensiveCombines=true)
Definition: InstCombine.h:33
static StringRef name()
Definition: InstCombine.h:31
void initializeInstructionCombiningPassPass(PassRegistry &)
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:49
A container for analyses that lazily runs them and caches their results.
This header defines various interfaces for pass management in LLVM.