mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-12 15:05:06 +00:00
c6ff29713d
At the time when the XCore backend was added there were some issues with with overlapping register classes but these all seem to be fixed now. Describing the register classes correctly allow us to get rid of a codegen only instruction (LDAWSP_lru6_RRegs) and it means we can disassemble ru6 instructions that use registers above r11. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@178782 91177308-0d34-0410-b5e6-96231b3b80d8
60 lines
1.9 KiB
TableGen
60 lines
1.9 KiB
TableGen
//===-- XCoreRegisterInfo.td - XCore Register defs ---------*- tablegen -*-===//
|
|
//
|
|
// 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 XCore register file
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
class XCoreReg<string n> : Register<n> {
|
|
field bits<4> Num;
|
|
let Namespace = "XCore";
|
|
}
|
|
|
|
// Registers are identified with 4-bit ID numbers.
|
|
// Ri - 32-bit integer registers
|
|
class Ri<bits<4> num, string n> : XCoreReg<n> {
|
|
let Num = num;
|
|
}
|
|
|
|
// CPU registers
|
|
def R0 : Ri< 0, "r0">, DwarfRegNum<[0]>;
|
|
def R1 : Ri< 1, "r1">, DwarfRegNum<[1]>;
|
|
def R2 : Ri< 2, "r2">, DwarfRegNum<[2]>;
|
|
def R3 : Ri< 3, "r3">, DwarfRegNum<[3]>;
|
|
def R4 : Ri< 4, "r4">, DwarfRegNum<[4]>;
|
|
def R5 : Ri< 5, "r5">, DwarfRegNum<[5]>;
|
|
def R6 : Ri< 6, "r6">, DwarfRegNum<[6]>;
|
|
def R7 : Ri< 7, "r7">, DwarfRegNum<[7]>;
|
|
def R8 : Ri< 8, "r8">, DwarfRegNum<[8]>;
|
|
def R9 : Ri< 9, "r9">, DwarfRegNum<[9]>;
|
|
def R10 : Ri<10, "r10">, DwarfRegNum<[10]>;
|
|
def R11 : Ri<11, "r11">, DwarfRegNum<[11]>;
|
|
def CP : Ri<12, "cp">, DwarfRegNum<[12]>;
|
|
def DP : Ri<13, "dp">, DwarfRegNum<[13]>;
|
|
def SP : Ri<14, "sp">, DwarfRegNum<[14]>;
|
|
def LR : Ri<15, "lr">, DwarfRegNum<[15]>;
|
|
|
|
// Register classes.
|
|
//
|
|
def GRRegs : RegisterClass<"XCore", [i32], 32,
|
|
// Return values and arguments
|
|
(add R0, R1, R2, R3,
|
|
// Callee save
|
|
R4, R5, R6, R7, R8, R9, R10,
|
|
// Not preserved across procedure calls
|
|
R11)>;
|
|
|
|
// Reserved
|
|
def RRegs : RegisterClass<"XCore", [i32], 32,
|
|
(add R0, R1, R2, R3,
|
|
R4, R5, R6, R7, R8, R9, R10,
|
|
R11, CP, DP, SP, LR)> {
|
|
let isAllocatable = 0;
|
|
}
|