LLVM  6.0.0svn
AMDGPURegisterInfo.cpp
Go to the documentation of this file.
1 //===-- AMDGPURegisterInfo.cpp - AMDGPU Register Information -------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 /// \file
11 /// \brief Parent TargetRegisterInfo class common to all hw codegen targets.
12 //
13 //===----------------------------------------------------------------------===//
14 
15 #include "AMDGPURegisterInfo.h"
16 #include "AMDGPUTargetMachine.h"
17 #include "SIRegisterInfo.h"
18 
19 using namespace llvm;
20 
22 
23 //===----------------------------------------------------------------------===//
24 // Function handling callbacks - Functions are a seldom used feature of GPUS, so
25 // they are not supported at this time.
26 //===----------------------------------------------------------------------===//
27 
28 unsigned AMDGPURegisterInfo::getSubRegFromChannel(unsigned Channel) const {
29  static const unsigned SubRegs[] = {
30  AMDGPU::sub0, AMDGPU::sub1, AMDGPU::sub2, AMDGPU::sub3, AMDGPU::sub4,
31  AMDGPU::sub5, AMDGPU::sub6, AMDGPU::sub7, AMDGPU::sub8, AMDGPU::sub9,
32  AMDGPU::sub10, AMDGPU::sub11, AMDGPU::sub12, AMDGPU::sub13, AMDGPU::sub14,
33  AMDGPU::sub15
34  };
35 
36  assert(Channel < array_lengthof(SubRegs));
37  return SubRegs[Channel];
38 }
39 
40 #define GET_REGINFO_TARGET_DESC
41 #include "AMDGPUGenRegisterInfo.inc"
42 
43 // Forced to be here by one .inc
45  const MachineFunction *MF) const {
47  switch (CC) {
48  case CallingConv::C:
49  case CallingConv::Fast:
50  case CallingConv::Cold:
51  return CSR_AMDGPU_HighRegs_SaveList;
52  default: {
53  // Dummy to not crash RegisterClassInfo.
54  static const MCPhysReg NoCalleeSavedReg = AMDGPU::NoRegister;
55  return &NoCalleeSavedReg;
56  }
57  }
58 }
59 
60 const MCPhysReg *
62  return nullptr;
63 }
64 
66  CallingConv::ID CC) const {
67  switch (CC) {
68  case CallingConv::C:
69  case CallingConv::Fast:
70  case CallingConv::Cold:
71  return CSR_AMDGPU_HighRegs_RegMask;
72  default:
73  return nullptr;
74  }
75 }
76 
78  return AMDGPU::NoRegister;
79 }
const MCPhysReg * getCalleeSavedRegs(const MachineFunction *MF) const override
Fast - This calling convention attempts to make calls as fast as possible (e.g.
Definition: CallingConv.h:43
Interface definition for SIRegisterInfo.
Compute iterated dominance frontiers using a linear time algorithm.
Definition: AllocatorList.h:24
const uint32_t * getCallPreservedMask(const MachineFunction &MF, CallingConv::ID) const override
unsigned getSubRegFromChannel(unsigned Channel) const
TargetRegisterInfo interface that is implemented by all hw codegen targets.
C - The default llvm calling convention, compatible with C.
Definition: CallingConv.h:35
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
unsigned getFrameRegister(const MachineFunction &MF) const override
const MCPhysReg * getCalleeSavedRegsViaCopy(const MachineFunction *MF) const
The AMDGPU TargetMachine interface definition for hw codgen targets.
CallingConv::ID getCallingConv() const
getCallingConv()/setCallingConv(CC) - These method get and set the calling convention of this functio...
Definition: Function.h:194
constexpr size_t array_lengthof(T(&)[N])
Find the length of an array.
Definition: STLExtras.h:720
const Function * getFunction() const
getFunction - Return the LLVM function that this machine code represents
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())