Move hasFP() and few related hooks to TargetFrameInfo.
[oota-llvm.git] / lib / Target / XCore / XCoreRegisterInfo.td
1 //===- XCoreRegisterInfo.td - XCore Register defs ----------*- tablegen -*-===//
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 //===----------------------------------------------------------------------===//
11 //  Declarations that describe the XCore register file 
12 //===----------------------------------------------------------------------===//
13
14 class XCoreReg<string n> : Register<n> {
15   field bits<4> Num;
16   let Namespace = "XCore";
17 }
18
19 // Registers are identified with 4-bit ID numbers.
20 // Ri - 32-bit integer registers
21 class Ri<bits<4> num, string n> : XCoreReg<n> {
22   let Num = num;
23 }
24
25 // CPU registers
26 def R0  : Ri< 0, "r0">, DwarfRegNum<[0]>;
27 def R1  : Ri< 1, "r1">, DwarfRegNum<[1]>;
28 def R2  : Ri< 2, "r2">, DwarfRegNum<[2]>; 
29 def R3  : Ri< 3, "r3">, DwarfRegNum<[3]>;
30 def R4  : Ri< 4, "r4">, DwarfRegNum<[4]>;
31 def R5  : Ri< 5, "r5">, DwarfRegNum<[5]>; 
32 def R6  : Ri< 6, "r6">, DwarfRegNum<[6]>;
33 def R7  : Ri< 7, "r7">, DwarfRegNum<[7]>;
34 def R8  : Ri< 8, "r8">, DwarfRegNum<[8]>;
35 def R9  : Ri< 9, "r9">, DwarfRegNum<[9]>; 
36 def R10 : Ri<10, "r10">, DwarfRegNum<[10]>;
37 def R11 : Ri<11, "r11">, DwarfRegNum<[11]>;
38 def CP : Ri<12, "cp">, DwarfRegNum<[12]>; 
39 def DP : Ri<13, "dp">, DwarfRegNum<[13]>;
40 def SP : Ri<14, "sp">, DwarfRegNum<[14]>;
41 def LR : Ri<15, "lr">, DwarfRegNum<[15]>;
42
43 // Register classes.
44 //
45 def GRRegs : RegisterClass<"XCore", [i32], 32,
46   // Return values and arguments
47   [R0, R1, R2, R3,
48   // Not preserved across procedure calls
49   R11,
50   // Callee save
51   R4, R5, R6, R7, R8, R9, R10]> {
52   let MethodProtos = [{
53     iterator allocation_order_begin(const MachineFunction &MF) const;
54     iterator allocation_order_end(const MachineFunction &MF) const;
55   }];
56   let MethodBodies = [{
57     GRRegsClass::iterator
58     GRRegsClass::allocation_order_begin(const MachineFunction &MF) const {
59       return begin();
60     }
61     GRRegsClass::iterator
62     GRRegsClass::allocation_order_end(const MachineFunction &MF) const {
63       const TargetMachine &TM = MF.getTarget();
64       const TargetFrameInfo *TFI = TM.getFrameInfo();
65       if (TFI->hasFP(MF))
66         return end()-1;  // don't allocate R10
67       else
68         return end();
69     }
70   }];
71 }
72
73 def RRegs : RegisterClass<"XCore", [i32], 32,
74   // Reserved
75   [CP, DP, SP, LR]> {
76   let MethodProtos = [{
77     iterator allocation_order_begin(const MachineFunction &MF) const;
78     iterator allocation_order_end(const MachineFunction &MF) const;
79   }];
80   let MethodBodies = [{
81     RRegsClass::iterator
82     RRegsClass::allocation_order_begin(const MachineFunction &MF) const {
83       return begin();
84     }
85     RRegsClass::iterator
86     RRegsClass::allocation_order_end(const MachineFunction &MF) const {
87       // No allocatable registers
88       return begin();
89     }
90   }];
91 }