LLVM 19.0.0git
ExtractGV.h
Go to the documentation of this file.
1//===-- ExtractGV.h -------------------------------------------------------===//
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#ifndef LLVM_TRANSFORMS_IPO_EXTRACTGV_H
10#define LLVM_TRANSFORMS_IPO_EXTRACTGV_H
11
12#include "llvm/ADT/SetVector.h"
13#include "llvm/IR/PassManager.h"
14
15namespace llvm {
16
17class ExtractGVPass : public PassInfoMixin<ExtractGVPass> {
18private:
20 bool deleteStuff;
21 bool keepConstInit;
22
23public:
24 ExtractGVPass(std::vector<GlobalValue *> &GVs, bool deleteS = true,
25 bool keepConstInit = false);
27};
28} // namespace llvm
29
30#endif // LLVM_TRANSFORMS_IPO_EXTRACTGV_H
This header defines various interfaces for pass management in LLVM.
This file implements a set that has insertion order iteration characteristics.
A container for analyses that lazily runs them and caches their results.
Definition: PassManager.h:321
PreservedAnalyses run(Module &M, ModuleAnalysisManager &)
Definition: ExtractGV.cpp:59
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: Analysis.h:109
A vector that has set insertion semantics.
Definition: SetVector.h:57
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition: PassManager.h:74