1 //===- AMDGPULegalizerInfo ---------------------------------------*- C++ -*-==//
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
7 //===----------------------------------------------------------------------===//
9 /// This file declares the targeting of the Machinelegalizer class for
11 /// \todo This should be generated by TableGen.
12 //===----------------------------------------------------------------------===//
14 #ifndef LLVM_LIB_TARGET_AMDGPU_AMDGPUMACHINELEGALIZER_H
15 #define LLVM_LIB_TARGET_AMDGPU_AMDGPUMACHINELEGALIZER_H
17 #include "llvm/CodeGen/GlobalISel/LegalizerInfo.h"
18 #include "AMDGPUArgumentUsageInfo.h"
19 #include "SIInstrInfo.h"
23 class GCNTargetMachine
;
27 /// This class provides the information for the target register banks.
28 class AMDGPULegalizerInfo
: public LegalizerInfo
{
29 const GCNSubtarget
&ST
;
32 AMDGPULegalizerInfo(const GCNSubtarget
&ST
,
33 const GCNTargetMachine
&TM
);
35 bool legalizeCustom(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
37 GISelChangeObserver
&Observer
) const override
;
39 Register
getSegmentAperture(unsigned AddrSpace
,
40 MachineRegisterInfo
&MRI
,
41 MachineIRBuilder
&B
) const;
43 bool legalizeAddrSpaceCast(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
44 MachineIRBuilder
&B
) const;
45 bool legalizeFrint(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
46 MachineIRBuilder
&B
) const;
47 bool legalizeFceil(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
48 MachineIRBuilder
&B
) const;
49 bool legalizeIntrinsicTrunc(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
50 MachineIRBuilder
&B
) const;
51 bool legalizeITOFP(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
52 MachineIRBuilder
&B
, bool Signed
) const;
53 bool legalizeMinNumMaxNum(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
54 MachineIRBuilder
&B
) const;
55 bool legalizeExtractVectorElt(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
56 MachineIRBuilder
&B
) const;
57 bool legalizeInsertVectorElt(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
58 MachineIRBuilder
&B
) const;
59 bool legalizeSinCos(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
60 MachineIRBuilder
&B
) const;
62 bool buildPCRelGlobalAddress(
63 Register DstReg
, LLT PtrTy
, MachineIRBuilder
&B
, const GlobalValue
*GV
,
64 unsigned Offset
, unsigned GAFlags
= SIInstrInfo::MO_NONE
) const;
66 bool legalizeGlobalValue(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
67 MachineIRBuilder
&B
) const;
68 bool legalizeLoad(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
70 GISelChangeObserver
&Observer
) const;
72 bool legalizeFMad(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
73 MachineIRBuilder
&B
) const;
75 Register
getLiveInRegister(MachineRegisterInfo
&MRI
,
76 Register Reg
, LLT Ty
) const;
78 bool loadInputValue(Register DstReg
, MachineIRBuilder
&B
,
79 const ArgDescriptor
*Arg
) const;
80 bool legalizePreloadedArgIntrin(
81 MachineInstr
&MI
, MachineRegisterInfo
&MRI
, MachineIRBuilder
&B
,
82 AMDGPUFunctionArgInfo::PreloadedValue ArgType
) const;
84 bool legalizeFDIV(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
85 MachineIRBuilder
&B
) const;
86 bool legalizeFastUnsafeFDIV(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
87 MachineIRBuilder
&B
) const;
88 bool legalizeFDIVFastIntrin(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
89 MachineIRBuilder
&B
) const;
91 bool legalizeImplicitArgPtr(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
92 MachineIRBuilder
&B
) const;
93 bool legalizeIsAddrSpace(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
94 MachineIRBuilder
&B
, unsigned AddrSpace
) const;
96 Register
handleD16VData(MachineIRBuilder
&B
, MachineRegisterInfo
&MRI
,
98 bool legalizeRawBufferStore(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
99 MachineIRBuilder
&B
, bool IsFormat
) const;
100 bool legalizeIntrinsic(MachineInstr
&MI
, MachineRegisterInfo
&MRI
,
101 MachineIRBuilder
&B
) const override
;
104 } // End llvm namespace.