The person who was planning to add SSE support isn't anymore, so disable
[oota-llvm.git] / lib / Target / MRegisterInfo.cpp
1 //===- MRegisterInfo.cpp - Target Register Information Implementation -----===//
2 // 
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file was developed by the LLVM research group and is distributed under
6 // the University of Illinois Open Source License. See LICENSE.TXT for details.
7 // 
8 //===----------------------------------------------------------------------===//
9 //
10 // This file implements the MRegisterInfo interface.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #include "llvm/Target/MRegisterInfo.h"
15
16 namespace llvm {
17
18 MRegisterInfo::MRegisterInfo(const MRegisterDesc *D, unsigned NR,
19                              regclass_iterator RCB, regclass_iterator RCE,
20                              int CFSO, int CFDO)
21   : Desc(D), NumRegs(NR), RegClassBegin(RCB), RegClassEnd(RCE) {
22   assert(NumRegs < FirstVirtualRegister &&
23          "Target has too many physical registers!");
24
25   PhysRegClasses = new const TargetRegisterClass*[NumRegs];
26   for (unsigned i = 0; i != NumRegs; ++i)
27     PhysRegClasses[i] = 0;
28
29   // Fill in the PhysRegClasses map
30   for (MRegisterInfo::regclass_iterator I = regclass_begin(),
31          E = regclass_end(); I != E; ++I) {
32     const TargetRegisterClass *RC = *I;
33     for (unsigned i = 0, e = RC->getNumRegs(); i != e; ++i) {
34       unsigned Reg = RC->getRegister(i);
35       assert(PhysRegClasses[Reg] == 0 && "Register in more than one class?");
36       PhysRegClasses[Reg] = RC;
37     }
38   }
39
40   CallFrameSetupOpcode   = CFSO;
41   CallFrameDestroyOpcode = CFDO;
42 }
43
44
45 MRegisterInfo::~MRegisterInfo() {
46   delete[] PhysRegClasses;
47 }
48
49 std::vector<bool> MRegisterInfo::getAllocatableSet(MachineFunction &MF) const {
50   std::vector<bool> Allocatable(NumRegs);
51   for (MRegisterInfo::regclass_iterator I = regclass_begin(),
52          E = regclass_end(); I != E; ++I) {
53     const TargetRegisterClass *RC = *I;
54     for (TargetRegisterClass::iterator I = RC->allocation_order_begin(MF),
55            E = RC->allocation_order_end(MF); I != E; ++I)
56       Allocatable[*I] = true;
57   }
58   return Allocatable;
59 }  
60
61 } // End llvm namespace