Rename a function.
[oota-llvm.git] / lib / Target / R600 / SIRegisterInfo.cpp
1 //===-- SIRegisterInfo.cpp - SI 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 SI implementation of the TargetRegisterInfo class.
12 //
13 //===----------------------------------------------------------------------===//
14
15
16 #include "SIRegisterInfo.h"
17 #include "AMDGPUTargetMachine.h"
18
19 using namespace llvm;
20
21 SIRegisterInfo::SIRegisterInfo(AMDGPUTargetMachine &tm,
22     const TargetInstrInfo &tii)
23 : AMDGPURegisterInfo(tm, tii),
24   TM(tm),
25   TII(tii)
26   { }
27
28 BitVector SIRegisterInfo::getReservedRegs(const MachineFunction &MF) const {
29   BitVector Reserved(getNumRegs());
30   return Reserved;
31 }
32
33 const TargetRegisterClass *
34 SIRegisterInfo::getISARegClass(const TargetRegisterClass * rc) const {
35   switch (rc->getID()) {
36   case AMDGPU::GPRF32RegClassID:
37     return &AMDGPU::VReg_32RegClass;
38   default: return rc;
39   }
40 }
41
42 const TargetRegisterClass * SIRegisterInfo::getCFGStructurizerRegClass(
43                                                                    MVT VT) const {
44   switch(VT.SimpleTy) {
45     default:
46     case MVT::i32: return &AMDGPU::VReg_32RegClass;
47   }
48 }