LLVM
16.0.0git
lib
Target
SPIRV
SPIRVRegisterInfo.h
Go to the documentation of this file.
1
//===-- SPIRVRegisterInfo.h - SPIR-V Register Information -------*- 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 contains the SPIR-V implementation of the TargetRegisterInfo class.
10
//
11
//===----------------------------------------------------------------------===//
12
13
#ifndef LLVM_LIB_TARGET_SPIRV_SPIRVREGISTERINFO_H
14
#define LLVM_LIB_TARGET_SPIRV_SPIRVREGISTERINFO_H
15
16
#include "
llvm/CodeGen/TargetRegisterInfo.h
"
17
18
#define GET_REGINFO_HEADER
19
#include "SPIRVGenRegisterInfo.inc"
20
21
namespace
llvm
{
22
23
struct
SPIRVRegisterInfo
:
public
SPIRVGenRegisterInfo
{
24
SPIRVRegisterInfo
();
25
const
MCPhysReg
*
getCalleeSavedRegs
(
const
MachineFunction
*MF)
const override
;
26
BitVector
getReservedRegs
(
const
MachineFunction
&MF)
const override
;
27
void
eliminateFrameIndex
(
MachineBasicBlock::iterator
MI
,
int
SPAdj,
28
unsigned
FIOperandNum,
29
RegScavenger
*RS =
nullptr
)
const override
{}
30
Register
getFrameRegister
(
const
MachineFunction
&MF)
const override
{
31
return
0;
32
}
33
};
34
}
// namespace llvm
35
36
#endif // LLVM_LIB_TARGET_SPIRV_SPIRVREGISTERINFO_H
SPIRVGenRegisterInfo
MI
IRTranslator LLVM IR MI
Definition:
IRTranslator.cpp:105
llvm
This is an optimization pass for GlobalISel generic memory operations.
Definition:
AddressRanges.h:18
llvm::SPIRVRegisterInfo::SPIRVRegisterInfo
SPIRVRegisterInfo()
Definition:
SPIRVRegisterInfo.cpp:22
llvm::SPIRVRegisterInfo::getCalleeSavedRegs
const MCPhysReg * getCalleeSavedRegs(const MachineFunction *MF) const override
Definition:
SPIRVRegisterInfo.cpp:29
llvm::BitVector
Definition:
BitVector.h:75
llvm::SPIRVRegisterInfo
Definition:
SPIRVRegisterInfo.h:23
llvm::RegScavenger
Definition:
RegisterScavenging.h:34
llvm::SPIRVRegisterInfo::eliminateFrameIndex
void eliminateFrameIndex(MachineBasicBlock::iterator MI, int SPAdj, unsigned FIOperandNum, RegScavenger *RS=nullptr) const override
Definition:
SPIRVRegisterInfo.h:27
llvm::MachineFunction
Definition:
MachineFunction.h:257
llvm::Register
Wrapper class representing virtual and physical registers.
Definition:
Register.h:19
uint16_t
llvm::SPIRVRegisterInfo::getFrameRegister
Register getFrameRegister(const MachineFunction &MF) const override
Definition:
SPIRVRegisterInfo.h:30
llvm::SPIRVRegisterInfo::getReservedRegs
BitVector getReservedRegs(const MachineFunction &MF) const override
Definition:
SPIRVRegisterInfo.cpp:24
llvm::MachineInstrBundleIterator< MachineInstr >
TargetRegisterInfo.h
Generated on Sat Aug 13 2022 18:36:57 for LLVM by
1.8.17