| OLD | NEW |
| 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, 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 #include "vm/globals.h" | 5 #include "vm/globals.h" |
| 6 #if defined(TARGET_ARCH_X64) | 6 #if defined(TARGET_ARCH_X64) |
| 7 | 7 |
| 8 #include "vm/assembler.h" | 8 #include "vm/assembler.h" |
| 9 #include "vm/heap.h" | 9 #include "vm/heap.h" |
| 10 #include "vm/memory_region.h" | 10 #include "vm/memory_region.h" |
| (...skipping 506 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 517 ASSERT(src <= XMM7); | 517 ASSERT(src <= XMM7); |
| 518 ASSERT(dst <= XMM7); | 518 ASSERT(dst <= XMM7); |
| 519 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 519 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 520 EmitUint8(0xF2); | 520 EmitUint8(0xF2); |
| 521 EmitUint8(0x0F); | 521 EmitUint8(0x0F); |
| 522 EmitUint8(0x5E); | 522 EmitUint8(0x5E); |
| 523 EmitXmmRegisterOperand(dst, src); | 523 EmitXmmRegisterOperand(dst, src); |
| 524 } | 524 } |
| 525 | 525 |
| 526 | 526 |
| 527 void Assembler::comisd(XmmRegister a, XmmRegister b) { |
| 528 ASSERT(a <= XMM7); |
| 529 ASSERT(b <= XMM7); |
| 530 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 531 EmitUint8(0x66); |
| 532 EmitUint8(0x0F); |
| 533 EmitUint8(0x2F); |
| 534 EmitXmmRegisterOperand(a, b); |
| 535 } |
| 536 |
| 537 |
| 527 void Assembler::xchgl(Register dst, Register src) { | 538 void Assembler::xchgl(Register dst, Register src) { |
| 528 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 539 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 529 Operand operand(src); | 540 Operand operand(src); |
| 530 EmitOperandREX(dst, operand, REX_NONE); | 541 EmitOperandREX(dst, operand, REX_NONE); |
| 531 EmitUint8(0x87); | 542 EmitUint8(0x87); |
| 532 EmitOperand(dst & 7, operand); | 543 EmitOperand(dst & 7, operand); |
| 533 } | 544 } |
| 534 | 545 |
| 535 | 546 |
| 536 void Assembler::xchgq(Register dst, Register src) { | 547 void Assembler::xchgq(Register dst, Register src) { |
| (...skipping 1005 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1542 comments.SetCommentAt(i, comments_[i]->comment()); | 1553 comments.SetCommentAt(i, comments_[i]->comment()); |
| 1543 } | 1554 } |
| 1544 | 1555 |
| 1545 return comments; | 1556 return comments; |
| 1546 } | 1557 } |
| 1547 | 1558 |
| 1548 | 1559 |
| 1549 } // namespace dart | 1560 } // namespace dart |
| 1550 | 1561 |
| 1551 #endif // defined TARGET_ARCH_X64 | 1562 #endif // defined TARGET_ARCH_X64 |
| OLD | NEW |