OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #ifndef VM_CONSTANTS_ARM64_H_ | 5 #ifndef VM_CONSTANTS_ARM64_H_ |
6 #define VM_CONSTANTS_ARM64_H_ | 6 #define VM_CONSTANTS_ARM64_H_ |
7 | 7 |
8 #include "platform/assert.h" | 8 #include "platform/assert.h" |
9 | 9 |
10 namespace dart { | 10 namespace dart { |
(...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 typedef VRegister FpuRegister; | 104 typedef VRegister FpuRegister; |
105 const FpuRegister FpuTMP = VTMP; | 105 const FpuRegister FpuTMP = VTMP; |
106 const int kNumberOfFpuRegisters = kNumberOfVRegisters; | 106 const int kNumberOfFpuRegisters = kNumberOfVRegisters; |
107 const FpuRegister kNoFpuRegister = kNoVRegister; | 107 const FpuRegister kNoFpuRegister = kNoVRegister; |
108 | 108 |
109 // Register aliases. | 109 // Register aliases. |
110 const Register TMP = R16; // Used as scratch register by assembler. | 110 const Register TMP = R16; // Used as scratch register by assembler. |
111 const Register TMP2 = R17; | 111 const Register TMP2 = R17; |
112 const Register CTX = R28; // Location of current context at method entry. | 112 const Register CTX = R28; // Location of current context at method entry. |
113 const Register PP = R27; // Caches object pool pointer in generated code. | 113 const Register PP = R27; // Caches object pool pointer in generated code. |
114 const Register kNoPP = kNoRegister; | |
115 const Register FPREG = FP; // Frame pointer register. | 114 const Register FPREG = FP; // Frame pointer register. |
116 const Register SPREG = R18; // Stack pointer register. | 115 const Register SPREG = R18; // Stack pointer register. |
117 const Register LRREG = LR; // Link register. | 116 const Register LRREG = LR; // Link register. |
118 const Register ICREG = R5; // IC data register. | 117 const Register ICREG = R5; // IC data register. |
119 const Register ARGS_DESC_REG = R4; // Arguments descriptor register. | 118 const Register ARGS_DESC_REG = R4; // Arguments descriptor register. |
120 const Register THR = R20; // Caches current thread in generated code. | 119 const Register THR = R20; // Caches current thread in generated code. |
121 | 120 |
122 // Exception object is passed in this register to the catch handlers when an | 121 // Exception object is passed in this register to the catch handlers when an |
123 // exception is thrown. | 122 // exception is thrown. |
124 const Register kExceptionObjectReg = R0; | 123 const Register kExceptionObjectReg = R0; |
(...skipping 943 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1068 static Instr* At(uword pc) { return reinterpret_cast<Instr*>(pc); } | 1067 static Instr* At(uword pc) { return reinterpret_cast<Instr*>(pc); } |
1069 | 1068 |
1070 private: | 1069 private: |
1071 DISALLOW_ALLOCATION(); | 1070 DISALLOW_ALLOCATION(); |
1072 DISALLOW_IMPLICIT_CONSTRUCTORS(Instr); | 1071 DISALLOW_IMPLICIT_CONSTRUCTORS(Instr); |
1073 }; | 1072 }; |
1074 | 1073 |
1075 } // namespace dart | 1074 } // namespace dart |
1076 | 1075 |
1077 #endif // VM_CONSTANTS_ARM64_H_ | 1076 #endif // VM_CONSTANTS_ARM64_H_ |
OLD | NEW |