OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Declares a Simulator for S390 instructions if we are not generating a native | 5 // Declares a Simulator for S390 instructions if we are not generating a native |
6 // S390 binary. This Simulator allows us to run and debug S390 code generation | 6 // S390 binary. This Simulator allows us to run and debug S390 code generation |
7 // on regular desktop machines. | 7 // on regular desktop machines. |
8 // V8 calls into generated code by "calling" the CALL_GENERATED_CODE macro, | 8 // V8 calls into generated code by "calling" the CALL_GENERATED_CODE macro, |
9 // which will start execution in the Simulator or forwards to the real entry | 9 // which will start execution in the Simulator or forwards to the real entry |
10 // on a S390 hardware platform. | 10 // on a S390 hardware platform. |
(...skipping 264 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
275 inline bool isWatchedStop(uint32_t bkpt_code); | 275 inline bool isWatchedStop(uint32_t bkpt_code); |
276 inline bool isEnabledStop(uint32_t bkpt_code); | 276 inline bool isEnabledStop(uint32_t bkpt_code); |
277 inline void EnableStop(uint32_t bkpt_code); | 277 inline void EnableStop(uint32_t bkpt_code); |
278 inline void DisableStop(uint32_t bkpt_code); | 278 inline void DisableStop(uint32_t bkpt_code); |
279 inline void IncreaseStopCounter(uint32_t bkpt_code); | 279 inline void IncreaseStopCounter(uint32_t bkpt_code); |
280 void PrintStopInfo(uint32_t code); | 280 void PrintStopInfo(uint32_t code); |
281 | 281 |
282 // Byte Reverse | 282 // Byte Reverse |
283 inline int16_t ByteReverse(int16_t hword); | 283 inline int16_t ByteReverse(int16_t hword); |
284 inline int32_t ByteReverse(int32_t word); | 284 inline int32_t ByteReverse(int32_t word); |
| 285 inline int64_t ByteReverse(int64_t dword); |
285 | 286 |
286 // Read and write memory. | 287 // Read and write memory. |
287 inline uint8_t ReadBU(intptr_t addr); | 288 inline uint8_t ReadBU(intptr_t addr); |
288 inline int8_t ReadB(intptr_t addr); | 289 inline int8_t ReadB(intptr_t addr); |
289 inline void WriteB(intptr_t addr, uint8_t value); | 290 inline void WriteB(intptr_t addr, uint8_t value); |
290 inline void WriteB(intptr_t addr, int8_t value); | 291 inline void WriteB(intptr_t addr, int8_t value); |
291 | 292 |
292 inline uint16_t ReadHU(intptr_t addr, Instruction* instr); | 293 inline uint16_t ReadHU(intptr_t addr, Instruction* instr); |
293 inline int16_t ReadH(intptr_t addr, Instruction* instr); | 294 inline int16_t ReadH(intptr_t addr, Instruction* instr); |
294 // Note: Overloaded on the sign of the value. | 295 // Note: Overloaded on the sign of the value. |
295 inline void WriteH(intptr_t addr, uint16_t value, Instruction* instr); | 296 inline void WriteH(intptr_t addr, uint16_t value, Instruction* instr); |
296 inline void WriteH(intptr_t addr, int16_t value, Instruction* instr); | 297 inline void WriteH(intptr_t addr, int16_t value, Instruction* instr); |
297 | 298 |
298 inline uint32_t ReadWU(intptr_t addr, Instruction* instr); | 299 inline uint32_t ReadWU(intptr_t addr, Instruction* instr); |
299 inline int32_t ReadW(intptr_t addr, Instruction* instr); | 300 inline int32_t ReadW(intptr_t addr, Instruction* instr); |
| 301 inline int64_t ReadW64(intptr_t addr, Instruction* instr); |
300 inline void WriteW(intptr_t addr, uint32_t value, Instruction* instr); | 302 inline void WriteW(intptr_t addr, uint32_t value, Instruction* instr); |
301 inline void WriteW(intptr_t addr, int32_t value, Instruction* instr); | 303 inline void WriteW(intptr_t addr, int32_t value, Instruction* instr); |
302 | 304 |
303 inline int64_t ReadDW(intptr_t addr); | 305 inline int64_t ReadDW(intptr_t addr); |
304 inline double ReadDouble(intptr_t addr); | 306 inline double ReadDouble(intptr_t addr); |
305 inline void WriteDW(intptr_t addr, int64_t value); | 307 inline void WriteDW(intptr_t addr, int64_t value); |
306 | 308 |
307 // S390 | 309 // S390 |
308 void Trace(Instruction* instr); | 310 void Trace(Instruction* instr); |
309 bool DecodeTwoByte(Instruction* instr); | 311 bool DecodeTwoByte(Instruction* instr); |
(...skipping 969 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1279 static inline void UnregisterCTryCatch(v8::internal::Isolate* isolate) { | 1281 static inline void UnregisterCTryCatch(v8::internal::Isolate* isolate) { |
1280 Simulator::current(isolate)->PopAddress(); | 1282 Simulator::current(isolate)->PopAddress(); |
1281 } | 1283 } |
1282 }; | 1284 }; |
1283 | 1285 |
1284 } // namespace internal | 1286 } // namespace internal |
1285 } // namespace v8 | 1287 } // namespace v8 |
1286 | 1288 |
1287 #endif // !defined(USE_SIMULATOR) | 1289 #endif // !defined(USE_SIMULATOR) |
1288 #endif // V8_S390_SIMULATOR_S390_H_ | 1290 #endif // V8_S390_SIMULATOR_S390_H_ |
OLD | NEW |