mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-13 21:05:16 +00:00
b48f2c2e1d
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@116805 91177308-0d34-0410-b5e6-96231b3b80d8
103 lines
3.1 KiB
TableGen
103 lines
3.1 KiB
TableGen
//===- PTXRegisterInfo.td - PTX 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 PTX register file
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
class PTXReg<string n> : Register<n> {
|
|
let Namespace = "PTX";
|
|
}
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Registers
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
def P0 : PTXReg<"p0">;
|
|
def P1 : PTXReg<"p1">;
|
|
def P2 : PTXReg<"p2">;
|
|
def P3 : PTXReg<"p3">;
|
|
def P4 : PTXReg<"p4">;
|
|
def P5 : PTXReg<"p5">;
|
|
def P6 : PTXReg<"p6">;
|
|
def P7 : PTXReg<"p7">;
|
|
def P8 : PTXReg<"p8">;
|
|
def P9 : PTXReg<"p9">;
|
|
def P10 : PTXReg<"p10">;
|
|
def P11 : PTXReg<"p11">;
|
|
def P12 : PTXReg<"p12">;
|
|
def P13 : PTXReg<"p13">;
|
|
def P14 : PTXReg<"p14">;
|
|
def P15 : PTXReg<"p15">;
|
|
def P16 : PTXReg<"p16">;
|
|
def P17 : PTXReg<"p17">;
|
|
def P18 : PTXReg<"p18">;
|
|
def P19 : PTXReg<"p19">;
|
|
def P20 : PTXReg<"p20">;
|
|
def P21 : PTXReg<"p21">;
|
|
def P22 : PTXReg<"p22">;
|
|
def P23 : PTXReg<"p23">;
|
|
def P24 : PTXReg<"p24">;
|
|
def P25 : PTXReg<"p25">;
|
|
def P26 : PTXReg<"p26">;
|
|
def P27 : PTXReg<"p27">;
|
|
def P28 : PTXReg<"p28">;
|
|
def P29 : PTXReg<"p29">;
|
|
def P30 : PTXReg<"p30">;
|
|
def P31 : PTXReg<"p31">;
|
|
|
|
def R0 : PTXReg<"r0">;
|
|
def R1 : PTXReg<"r1">;
|
|
def R2 : PTXReg<"r2">;
|
|
def R3 : PTXReg<"r3">;
|
|
def R4 : PTXReg<"r4">;
|
|
def R5 : PTXReg<"r5">;
|
|
def R6 : PTXReg<"r6">;
|
|
def R7 : PTXReg<"r7">;
|
|
def R8 : PTXReg<"r8">;
|
|
def R9 : PTXReg<"r9">;
|
|
def R10 : PTXReg<"r10">;
|
|
def R11 : PTXReg<"r11">;
|
|
def R12 : PTXReg<"r12">;
|
|
def R13 : PTXReg<"r13">;
|
|
def R14 : PTXReg<"r14">;
|
|
def R15 : PTXReg<"r15">;
|
|
def R16 : PTXReg<"r16">;
|
|
def R17 : PTXReg<"r17">;
|
|
def R18 : PTXReg<"r18">;
|
|
def R19 : PTXReg<"r19">;
|
|
def R20 : PTXReg<"r20">;
|
|
def R21 : PTXReg<"r21">;
|
|
def R22 : PTXReg<"r22">;
|
|
def R23 : PTXReg<"r23">;
|
|
def R24 : PTXReg<"r24">;
|
|
def R25 : PTXReg<"r25">;
|
|
def R26 : PTXReg<"r26">;
|
|
def R27 : PTXReg<"r27">;
|
|
def R28 : PTXReg<"r28">;
|
|
def R29 : PTXReg<"r29">;
|
|
def R30 : PTXReg<"r30">;
|
|
def R31 : PTXReg<"r31">;
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// Register classes
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
def Preds : RegisterClass<"PTX", [i1], 8,
|
|
[P0, P1, P2, P3, P4, P5, P6, P7,
|
|
P8, P9, P10, P11, P12, P13, P14, P15,
|
|
P16, P17, P18, P19, P20, P21, P22, P23,
|
|
P24, P25, P26, P27, P28, P29, P30, P31]>;
|
|
|
|
def RRegs32 : RegisterClass<"PTX", [i32], 32,
|
|
[R0, R1, R2, R3, R4, R5, R6, R7,
|
|
R8, R9, R10, R11, R12, R13, R14, R15,
|
|
R16, R17, R18, R19, R20, R21, R22, R23,
|
|
R24, R25, R26, R27, R28, R29, R30, R31]>;
|