OLD | NEW |
(Empty) | |
| 1 //===- subzero/src/IceRegistersX8632.h - Register information ---*- C++ -*-===// |
| 2 // |
| 3 // The Subzero Code Generator |
| 4 // |
| 5 // This file is distributed under the University of Illinois Open Source |
| 6 // License. See LICENSE.TXT for details. |
| 7 // |
| 8 //===----------------------------------------------------------------------===// |
| 9 // |
| 10 // This file declares the registers and their encodings for x86-32. |
| 11 // |
| 12 //===----------------------------------------------------------------------===// |
| 13 |
| 14 #ifndef SUBZERO_SRC_ICEREGISTERSX8632_H |
| 15 #define SUBZERO_SRC_ICEREGISTERSX8632_H |
| 16 |
| 17 #include "IceDefs.h" |
| 18 #include "IceInstX8632.def" |
| 19 |
| 20 namespace Ice { |
| 21 |
| 22 class RegX8632 { |
| 23 public: |
| 24 // An enum of every register. The enum value may not match the encoding |
| 25 // used to binary encode register operands in instructions. |
| 26 enum AllRegisters { |
| 27 #define X(val, encode, name, name16, name8, scratch, preserved, stackptr, \ |
| 28 frameptr, isI8, isInt, isFP) \ |
| 29 val, |
| 30 REGX8632_TABLE |
| 31 #undef X |
| 32 Reg_NUM, |
| 33 #define X(val, init) val init, |
| 34 REGX8632_TABLE_BOUNDS |
| 35 #undef X |
| 36 }; |
| 37 |
| 38 // An enum of GPR Registers. The enum value does match encoding used |
| 39 // to binary encode register operands in instructions. |
| 40 enum GPRRegister { |
| 41 #define X(val, encode, name, name16, name8, scratch, preserved, stackptr, \ |
| 42 frameptr, isI8, isInt, isFP) \ |
| 43 Encoded_##val encode, |
| 44 REGX8632_GPR_TABLE |
| 45 #undef X |
| 46 }; |
| 47 |
| 48 // An enum of XMM Registers. The enum value does match encoding used |
| 49 // to binary encode register operands in instructions. |
| 50 enum XmmRegister { |
| 51 #define X(val, encode, name, name16, name8, scratch, preserved, stackptr, \ |
| 52 frameptr, isI8, isInt, isFP) \ |
| 53 Encoded_##val encode, |
| 54 REGX8632_XMM_TABLE |
| 55 #undef X |
| 56 }; |
| 57 |
| 58 // An enum of Byte Registers. The enum value does match encoding used |
| 59 // to binary encode register operands in instructions. |
| 60 enum ByteRegister { |
| 61 #define X(val, encode) Encoded_##val encode, |
| 62 REGX8632_BYTEREG_TABLE |
| 63 #undef X |
| 64 }; |
| 65 |
| 66 static GPRRegister getEncodedGPR(int32_t RegNum) { |
| 67 assert(Reg_GPR_First <= RegNum && RegNum <= Reg_GPR_Last); |
| 68 return GPRRegister(RegNum - Reg_GPR_First); |
| 69 } |
| 70 |
| 71 static XmmRegister getEncodedXmm(int32_t RegNum) { |
| 72 assert(Reg_XMM_First <= RegNum && RegNum <= Reg_XMM_Last); |
| 73 return XmmRegister(RegNum - Reg_XMM_First); |
| 74 } |
| 75 |
| 76 static ByteRegister getEncodedByteReg(int32_t RegNum) { |
| 77 assert(RegNum == Reg_ah || (Reg_GPR_First <= RegNum && RegNum <= Reg_ebx)); |
| 78 if (RegNum == Reg_ah) |
| 79 return Encoded_Reg_ah; |
| 80 return ByteRegister(RegNum - Reg_GPR_First); |
| 81 } |
| 82 }; |
| 83 |
| 84 } // end of namespace Ice |
| 85 |
| 86 #endif // SUBZERO_SRC_ICEREGISTERSX8632_H |
OLD | NEW |