mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-20 11:33:24 +02:00
b85740bf76
llvm-svn: 70701
66 lines
2.1 KiB
TableGen
66 lines
2.1 KiB
TableGen
//===- MSP430RegisterInfo.td - MSP430 Register defs ----------*- tblgen -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Declarations that describe the MSP430 register file
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
class MSP430Reg<bits<4> num, string n> : Register<n> {
|
|
field bits<4> Num = num;
|
|
let Namespace = "MSP430";
|
|
}
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Registers
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
def PC : MSP430Reg<0, "R0">;
|
|
def SP : MSP430Reg<1, "R1">;
|
|
def SR : MSP430Reg<2, "R2">;
|
|
def CG : MSP430Reg<3, "R3">;
|
|
def FP : MSP430Reg<4, "R4">;
|
|
def R5 : MSP430Reg<5, "R5">;
|
|
def R6 : MSP430Reg<6, "R6">;
|
|
def R7 : MSP430Reg<7, "R7">;
|
|
def R8 : MSP430Reg<8, "R8">;
|
|
def R9 : MSP430Reg<9, "R9">;
|
|
def R10 : MSP430Reg<10, "R10">;
|
|
def R11 : MSP430Reg<11, "R11">;
|
|
def R12 : MSP430Reg<12, "R12">;
|
|
def R13 : MSP430Reg<13, "R13">;
|
|
def R14 : MSP430Reg<14, "R14">;
|
|
def R15 : MSP430Reg<15, "R15">;
|
|
|
|
def MSP430Regs : RegisterClass<"MSP430", [i16], 16,
|
|
// Volatile registers
|
|
[R12, R13, R14, R15, R11, R10, R9, R8, R7, R6, R5,
|
|
// Frame pointer, sometimes allocable
|
|
FP,
|
|
// Volatile, but not allocable
|
|
PC, SP, SR, CG]>
|
|
{
|
|
let MethodProtos = [{
|
|
iterator allocation_order_end(const MachineFunction &MF) const;
|
|
}];
|
|
let MethodBodies = [{
|
|
MSP430RegsClass::iterator
|
|
MSP430RegsClass::allocation_order_end(const MachineFunction &MF) const {
|
|
const TargetMachine &TM = MF.getTarget();
|
|
const TargetRegisterInfo *RI = TM.getRegisterInfo();
|
|
// Depending on whether the function uses frame pointer or not, last 5 or 4
|
|
// registers on the list above are reserved
|
|
if (RI->hasFP(MF))
|
|
return end()-5;
|
|
else
|
|
return end()-4;
|
|
}
|
|
}];
|
|
}
|
|
|