Home | History | Annotate | Download | only in BPF
      1 //===-- BPFRegisterInfo.td - BPF 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 BPF register file
     12 //===----------------------------------------------------------------------===//
     13 
     14 // Registers are identified with 4-bit ID numbers.
     15 // Ri - 64-bit integer registers
     16 class Ri<bits<16> Enc, string n> : Register<n> {
     17   let Namespace = "BPF";
     18   let HWEncoding = Enc;
     19 }
     20 
     21 // Integer registers
     22 def R0 : Ri< 0, "r0">, DwarfRegNum<[0]>;
     23 def R1 : Ri< 1, "r1">, DwarfRegNum<[1]>;
     24 def R2 : Ri< 2, "r2">, DwarfRegNum<[2]>;
     25 def R3 : Ri< 3, "r3">, DwarfRegNum<[3]>;
     26 def R4 : Ri< 4, "r4">, DwarfRegNum<[4]>;
     27 def R5 : Ri< 5, "r5">, DwarfRegNum<[5]>;
     28 def R6 : Ri< 6, "r6">, DwarfRegNum<[6]>;
     29 def R7 : Ri< 7, "r7">, DwarfRegNum<[7]>;
     30 def R8 : Ri< 8, "r8">, DwarfRegNum<[8]>;
     31 def R9 : Ri< 9, "r9">, DwarfRegNum<[9]>;
     32 def R10 : Ri<10, "r10">, DwarfRegNum<[10]>;
     33 def R11 : Ri<11, "r11">, DwarfRegNum<[11]>;
     34 
     35 // Register classes.
     36 def GPR : RegisterClass<"BPF", [i64], 64, (add R1, R2, R3, R4, R5,
     37                                            R6, R7, R8, R9, // callee saved
     38                                            R0,  // return value
     39                                            R11, // stack ptr
     40                                            R10  // frame ptr
     41                                           )>;
     42