OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, 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_ASSEMBLER_IA32_H_ | 5 #ifndef VM_ASSEMBLER_IA32_H_ |
6 #define VM_ASSEMBLER_IA32_H_ | 6 #define VM_ASSEMBLER_IA32_H_ |
7 | 7 |
8 #ifndef VM_ASSEMBLER_H_ | 8 #ifndef VM_ASSEMBLER_H_ |
9 #error Do not include assembler_ia32.h directly; use assembler.h instead. | 9 #error Do not include assembler_ia32.h directly; use assembler.h instead. |
10 #endif | 10 #endif |
(...skipping 489 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
500 void cmpxchgl(const Address& address, Register reg); | 500 void cmpxchgl(const Address& address, Register reg); |
501 | 501 |
502 /* | 502 /* |
503 * Macros for High-level operations and implemented on all architectures. | 503 * Macros for High-level operations and implemented on all architectures. |
504 */ | 504 */ |
505 | 505 |
506 void CompareRegisters(Register a, Register b); | 506 void CompareRegisters(Register a, Register b); |
507 | 507 |
508 // Issues a move instruction if 'to' is not the same as 'from'. | 508 // Issues a move instruction if 'to' is not the same as 'from'. |
509 void MoveRegister(Register to, Register from); | 509 void MoveRegister(Register to, Register from); |
| 510 void PushRegister(Register r); |
| 511 void PopRegister(Register r); |
510 | 512 |
511 void AddImmediate(Register reg, const Immediate& imm); | 513 void AddImmediate(Register reg, const Immediate& imm); |
512 | 514 |
513 void Drop(intptr_t stack_elements); | 515 void Drop(intptr_t stack_elements); |
514 | 516 |
515 void LoadObject(Register dst, const Object& object); | 517 void LoadObject(Register dst, const Object& object); |
516 void PushObject(const Object& object); | 518 void PushObject(const Object& object); |
517 void CompareObject(Register reg, const Object& object); | 519 void CompareObject(Register reg, const Object& object); |
518 void LoadDoubleConstant(XmmRegister dst, double value); | 520 void LoadDoubleConstant(XmmRegister dst, double value); |
519 | 521 |
(...skipping 132 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
652 } | 654 } |
653 | 655 |
654 | 656 |
655 inline void Assembler::EmitOperandSizeOverride() { | 657 inline void Assembler::EmitOperandSizeOverride() { |
656 EmitUint8(0x66); | 658 EmitUint8(0x66); |
657 } | 659 } |
658 | 660 |
659 } // namespace dart | 661 } // namespace dart |
660 | 662 |
661 #endif // VM_ASSEMBLER_IA32_H_ | 663 #endif // VM_ASSEMBLER_IA32_H_ |
OLD | NEW |