LLVM
22.0.0git
lib
Target
SPIRV
SPIRVLegalizerInfo.h
Go to the documentation of this file.
1
//===- SPIRVLegalizerInfo.h --- SPIR-V Legalization Rules --------*- C++ -*-==//
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 file declares the targeting of the MachineLegalizer class for SPIR-V.
10
//
11
//===----------------------------------------------------------------------===//
12
13
#ifndef LLVM_LIB_TARGET_SPIRV_SPIRVMACHINELEGALIZER_H
14
#define LLVM_LIB_TARGET_SPIRV_SPIRVMACHINELEGALIZER_H
15
16
#include "
SPIRVGlobalRegistry.h
"
17
#include "
llvm/CodeGen/GlobalISel/LegalizerInfo.h
"
18
19
namespace
llvm
{
20
21
class
LLVMContext
;
22
class
SPIRVSubtarget
;
23
24
// This class provides the information for legalizing SPIR-V instructions.
25
class
SPIRVLegalizerInfo
:
public
LegalizerInfo
{
26
const
SPIRVSubtarget
*ST;
27
SPIRVGlobalRegistry
*GR;
28
29
public
:
30
bool
legalizeCustom
(
LegalizerHelper
&Helper,
MachineInstr
&
MI
,
31
LostDebugLocObserver
&LocObserver)
const override
;
32
SPIRVLegalizerInfo
(
const
SPIRVSubtarget
&ST);
33
34
private
:
35
bool
legalizeIsFPClass(
LegalizerHelper
&Helper,
MachineInstr
&
MI
,
36
LostDebugLocObserver
&LocObserver)
const
;
37
};
38
}
// namespace llvm
39
#endif
// LLVM_LIB_TARGET_SPIRV_SPIRVMACHINELEGALIZER_H
MI
IRTranslator LLVM IR MI
Definition
IRTranslator.cpp:110
LegalizerInfo.h
Interface for Targets to specify which operations they can successfully select and how the others sho...
SPIRVGlobalRegistry.h
llvm::LLVMContext
This is an important class for using LLVM in a threaded context.
Definition
LLVMContext.h:68
llvm::LegalizerHelper
Definition
LegalizerHelper.h:49
llvm::LegalizerInfo
Definition
LegalizerInfo.h:1327
llvm::LostDebugLocObserver
Definition
LostDebugLocObserver.h:20
llvm::MachineInstr
Representation of each machine instruction.
Definition
MachineInstr.h:72
llvm::SPIRVGlobalRegistry
Definition
SPIRVGlobalRegistry.h:31
llvm::SPIRVLegalizerInfo::SPIRVLegalizerInfo
SPIRVLegalizerInfo(const SPIRVSubtarget &ST)
Definition
SPIRVLegalizerInfo.cpp:34
llvm::SPIRVLegalizerInfo::legalizeCustom
bool legalizeCustom(LegalizerHelper &Helper, MachineInstr &MI, LostDebugLocObserver &LocObserver) const override
Called for instructions with the Custom LegalizationAction.
Definition
SPIRVLegalizerInfo.cpp:365
llvm::SPIRVSubtarget
Definition
SPIRVSubtarget.h:38
llvm
This is an optimization pass for GlobalISel generic memory operations.
Definition
AddressRanges.h:18
Generated on
for LLVM by
1.14.0