| OLD | NEW |
| 1 //===- subzero/src/IceRegistersX8664.h - Register information ---*- C++ -*-===// | 1 //===- subzero/src/IceRegistersX8664.h - Register information ---*- C++ -*-===// |
| 2 // | 2 // |
| 3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
| 4 // | 4 // |
| 5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
| 6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
| 7 // | 7 // |
| 8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
| 9 /// | 9 /// |
| 10 /// \file | 10 /// \file |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 72 assert(Reg_GPR_First <= RegNum && RegNum <= Reg_GPR_Last); | 72 assert(Reg_GPR_First <= RegNum && RegNum <= Reg_GPR_Last); |
| 73 return GPRRegister(RegNum - Reg_GPR_First); | 73 return GPRRegister(RegNum - Reg_GPR_First); |
| 74 } | 74 } |
| 75 | 75 |
| 76 static inline XmmRegister getEncodedXmm(int32_t RegNum) { | 76 static inline XmmRegister getEncodedXmm(int32_t RegNum) { |
| 77 assert(Reg_XMM_First <= RegNum && RegNum <= Reg_XMM_Last); | 77 assert(Reg_XMM_First <= RegNum && RegNum <= Reg_XMM_Last); |
| 78 return XmmRegister(RegNum - Reg_XMM_First); | 78 return XmmRegister(RegNum - Reg_XMM_First); |
| 79 } | 79 } |
| 80 | 80 |
| 81 static inline ByteRegister getEncodedByteReg(int32_t RegNum) { | 81 static inline ByteRegister getEncodedByteReg(int32_t RegNum) { |
| 82 // In x86-64, AH is not encodable when the REX prefix is used; the same | 82 assert(Reg_GPR_First <= RegNum && RegNum <= Reg_GPR_Last); |
| 83 // encoding is used for spl. Therefore, ah needs special handling. | |
| 84 if (RegNum == Reg_ah) | |
| 85 return Encoded_Reg_spl; | |
| 86 return ByteRegister(RegNum - Reg_GPR_First); | 83 return ByteRegister(RegNum - Reg_GPR_First); |
| 87 } | 84 } |
| 88 | 85 |
| 89 static inline GPRRegister getEncodedByteRegOrGPR(Type Ty, int32_t RegNum) { | 86 static inline GPRRegister getEncodedByteRegOrGPR(Type Ty, int32_t RegNum) { |
| 90 if (isByteSizedType(Ty)) | 87 if (isByteSizedType(Ty)) |
| 91 return GPRRegister(getEncodedByteReg(RegNum)); | 88 return GPRRegister(getEncodedByteReg(RegNum)); |
| 92 else | 89 else |
| 93 return getEncodedGPR(RegNum); | 90 return getEncodedGPR(RegNum); |
| 94 } | 91 } |
| 95 }; | 92 }; |
| 96 | 93 |
| 97 } // end of namespace Ice | 94 } // end of namespace Ice |
| 98 | 95 |
| 99 #endif // SUBZERO_SRC_ICEREGISTERSX8664_H | 96 #endif // SUBZERO_SRC_ICEREGISTERSX8664_H |
| OLD | NEW |