summaryrefslogtreecommitdiffstats
path: root/contrib/libs/llvm12/include/llvm/CodeGen/GlobalISel/Legalizer.h
blob: b8625d09439f40c11b0f2dd56f7c8cc80cadf69a (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
#pragma once 
 
#ifdef __GNUC__ 
#pragma GCC diagnostic push 
#pragma GCC diagnostic ignored "-Wunused-parameter" 
#endif 
 
//== llvm/CodeGen/GlobalISel/Legalizer.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 
// 
//===----------------------------------------------------------------------===// 
// 
/// \file A pass to convert the target-illegal operations created by IR -> MIR 
/// translation into ones the target expects to be able to select. This may 
/// occur in multiple phases, for example G_ADD <2 x i8> -> G_ADD <2 x i16> -> 
/// G_ADD <4 x i16>. 
/// 
/// The LegalizeHelper class is where most of the work happens, and is designed 
/// to be callable from other passes that find themselves with an illegal 
/// instruction. 
// 
//===----------------------------------------------------------------------===// 
 
#ifndef LLVM_CODEGEN_GLOBALISEL_LEGALIZEMACHINEIRPASS_H 
#define LLVM_CODEGEN_GLOBALISEL_LEGALIZEMACHINEIRPASS_H 
 
#include "llvm/CodeGen/GlobalISel/MachineIRBuilder.h" 
#include "llvm/CodeGen/MachineFunctionPass.h" 
 
namespace llvm { 
 
class MachineRegisterInfo; 
class LostDebugLocObserver; 
 
class Legalizer : public MachineFunctionPass { 
public: 
  static char ID; 
 
  struct MFResult { 
    bool Changed; 
    const MachineInstr *FailedOn; 
  }; 
 
private: 
  /// Initialize the field members using \p MF. 
  void init(MachineFunction &MF); 
 
public: 
  // Ctor, nothing fancy. 
  Legalizer(); 
 
  StringRef getPassName() const override { return "Legalizer"; } 
 
  void getAnalysisUsage(AnalysisUsage &AU) const override; 
 
  MachineFunctionProperties getRequiredProperties() const override { 
    return MachineFunctionProperties().set( 
        MachineFunctionProperties::Property::IsSSA); 
  } 
 
  MachineFunctionProperties getSetProperties() const override { 
    return MachineFunctionProperties().set( 
        MachineFunctionProperties::Property::Legalized); 
  } 
 
  MachineFunctionProperties getClearedProperties() const override { 
    return MachineFunctionProperties().set( 
        MachineFunctionProperties::Property::NoPHIs); 
  } 
 
  bool runOnMachineFunction(MachineFunction &MF) override; 
 
  static MFResult 
  legalizeMachineFunction(MachineFunction &MF, const LegalizerInfo &LI, 
                          ArrayRef<GISelChangeObserver *> AuxObservers, 
                          LostDebugLocObserver &LocObserver, 
                          MachineIRBuilder &MIRBuilder); 
}; 
} // End namespace llvm. 
 
#endif 
 
#ifdef __GNUC__ 
#pragma GCC diagnostic pop 
#endif