LLVM 17.0.0git
BlockExtractor.h
Go to the documentation of this file.
1//===- BlockExtractor.h - Extracts blocks into their own functions --------===//
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 extracts the specified basic blocks from the module into their
10// own functions.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_TRANSFORMS_IPO_BLOCKEXTRACTOR_H
15#define LLVM_TRANSFORMS_IPO_BLOCKEXTRACTOR_H
16
17#include <vector>
18
20#include "llvm/IR/PassManager.h"
21
22namespace llvm {
23class BasicBlock;
24
25struct BlockExtractorPass : PassInfoMixin<BlockExtractorPass> {
26 BlockExtractorPass(std::vector<std::vector<BasicBlock *>> &&GroupsOfBlocks,
27 bool EraseFunctions);
29
30private:
31 std::vector<std::vector<BasicBlock *>> GroupsOfBlocks;
32 bool EraseFunctions;
33};
34} // namespace llvm
35
36#endif // LLVM_TRANSFORMS_IPO_BLOCKEXTRACTOR_H
This header defines various interfaces for pass management in LLVM.
This file defines the SmallVector class.
A container for analyses that lazily runs them and caches their results.
Definition: PassManager.h:620
A Module instance is used to store all the information related to an LLVM module.
Definition: Module.h:65
A set of analyses that are preserved following a run of a transformation pass.
Definition: PassManager.h:152
@ BasicBlock
Various leaf nodes.
Definition: ISDOpcodes.h:71
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition: PassManager.h:371