summaryrefslogtreecommitdiffstats
path: root/contrib/libs/llvm12/include/llvm/CodeGen/MachinePostDominators.h
blob: 432bdc6620db16841826d61da8d616e3b717875b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#pragma once 
 
#ifdef __GNUC__ 
#pragma GCC diagnostic push 
#pragma GCC diagnostic ignored "-Wunused-parameter" 
#endif 
 
//===- llvm/CodeGen/MachinePostDominators.h ----------------------*- C++ -*-==// 
// 
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 
// See https://llvm.org/LICENSE.txt for license information. 
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 
// 
//===----------------------------------------------------------------------===// 
// 
// This file exposes interfaces to post dominance information for 
// target-specific code. 
// 
//===----------------------------------------------------------------------===// 
 
#ifndef LLVM_CODEGEN_MACHINEPOSTDOMINATORS_H 
#define LLVM_CODEGEN_MACHINEPOSTDOMINATORS_H 
 
#include "llvm/CodeGen/MachineDominators.h" 
#include "llvm/CodeGen/MachineFunctionPass.h" 
#include <memory> 
 
namespace llvm { 
 
/// 
/// MachinePostDominatorTree - an analysis pass wrapper for DominatorTree 
/// used to compute the post-dominator tree for MachineFunctions. 
/// 
class MachinePostDominatorTree : public MachineFunctionPass { 
  using PostDomTreeT = PostDomTreeBase<MachineBasicBlock>; 
  std::unique_ptr<PostDomTreeT> PDT; 
 
public: 
  static char ID; 
 
  MachinePostDominatorTree(); 
 
  PostDomTreeT &getBase() { 
    if (!PDT) 
      PDT.reset(new PostDomTreeT()); 
    return *PDT; 
  } 
 
  FunctionPass *createMachinePostDominatorTreePass(); 
 
  MachineDomTreeNode *getRootNode() const { return PDT->getRootNode(); } 
 
  MachineDomTreeNode *operator[](MachineBasicBlock *BB) const { 
    return PDT->getNode(BB); 
  } 
 
  MachineDomTreeNode *getNode(MachineBasicBlock *BB) const { 
    return PDT->getNode(BB); 
  } 
 
  bool dominates(const MachineDomTreeNode *A, 
                 const MachineDomTreeNode *B) const { 
    return PDT->dominates(A, B); 
  } 
 
  bool dominates(const MachineBasicBlock *A, const MachineBasicBlock *B) const { 
    return PDT->dominates(A, B); 
  } 
 
  bool properlyDominates(const MachineDomTreeNode *A, 
                         const MachineDomTreeNode *B) const { 
    return PDT->properlyDominates(A, B); 
  } 
 
  bool properlyDominates(const MachineBasicBlock *A, 
                         const MachineBasicBlock *B) const { 
    return PDT->properlyDominates(A, B); 
  } 
 
  bool isVirtualRoot(const MachineDomTreeNode *Node) const { 
    return PDT->isVirtualRoot(Node); 
  } 
 
  MachineBasicBlock *findNearestCommonDominator(MachineBasicBlock *A, 
                                                MachineBasicBlock *B) const { 
    return PDT->findNearestCommonDominator(A, B); 
  } 
 
  /// Returns the nearest common dominator of the given blocks. 
  /// If that tree node is a virtual root, a nullptr will be returned. 
  MachineBasicBlock * 
  findNearestCommonDominator(ArrayRef<MachineBasicBlock *> Blocks) const; 
 
  bool runOnMachineFunction(MachineFunction &MF) override; 
  void getAnalysisUsage(AnalysisUsage &AU) const override; 
  void releaseMemory() override { PDT.reset(nullptr); } 
  void verifyAnalysis() const override; 
  void print(llvm::raw_ostream &OS, const Module *M = nullptr) const override; 
}; 
} //end of namespace llvm 
 
#endif 
 
#ifdef __GNUC__ 
#pragma GCC diagnostic pop 
#endif