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 #include "vm/globals.h" | 5 #include "vm/globals.h" |
6 #if defined(TARGET_ARCH_IA32) | 6 #if defined(TARGET_ARCH_IA32) |
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 408 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
419 | 419 |
420 void Assembler::movsd(XmmRegister dst, XmmRegister src) { | 420 void Assembler::movsd(XmmRegister dst, XmmRegister src) { |
421 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 421 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
422 EmitUint8(0xF2); | 422 EmitUint8(0xF2); |
423 EmitUint8(0x0F); | 423 EmitUint8(0x0F); |
424 EmitUint8(0x11); | 424 EmitUint8(0x11); |
425 EmitXmmRegisterOperand(src, dst); | 425 EmitXmmRegisterOperand(src, dst); |
426 } | 426 } |
427 | 427 |
428 | 428 |
| 429 void Assembler::movaps(XmmRegister dst, XmmRegister src) { |
| 430 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 431 EmitUint8(0x0F); |
| 432 EmitUint8(0x28); |
| 433 EmitXmmRegisterOperand(dst, src); |
| 434 } |
| 435 |
| 436 |
429 void Assembler::addsd(XmmRegister dst, XmmRegister src) { | 437 void Assembler::addsd(XmmRegister dst, XmmRegister src) { |
430 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 438 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
431 EmitUint8(0xF2); | 439 EmitUint8(0xF2); |
432 EmitUint8(0x0F); | 440 EmitUint8(0x0F); |
433 EmitUint8(0x58); | 441 EmitUint8(0x58); |
434 EmitXmmRegisterOperand(dst, src); | 442 EmitXmmRegisterOperand(dst, src); |
435 } | 443 } |
436 | 444 |
437 | 445 |
438 void Assembler::addsd(XmmRegister dst, const Address& src) { | 446 void Assembler::addsd(XmmRegister dst, const Address& src) { |
(...skipping 1344 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1783 "eax", "ecx", "edx", "ebx", "esp", "ebp", "esi", "edi" | 1791 "eax", "ecx", "edx", "ebx", "esp", "ebp", "esi", "edi" |
1784 }; | 1792 }; |
1785 | 1793 |
1786 | 1794 |
1787 const char* Assembler::RegisterName(Register reg) { | 1795 const char* Assembler::RegisterName(Register reg) { |
1788 ASSERT((0 <= reg) && (reg < kNumberOfCpuRegisters)); | 1796 ASSERT((0 <= reg) && (reg < kNumberOfCpuRegisters)); |
1789 return cpu_reg_names[reg]; | 1797 return cpu_reg_names[reg]; |
1790 } | 1798 } |
1791 | 1799 |
1792 | 1800 |
| 1801 static const char* xmm_reg_names[kNumberOfXmmRegisters] = { |
| 1802 "xmm0", "xmm1", "xmm2", "xmm3", "xmm4", "xmm5", "xmm6", "xmm7" |
| 1803 }; |
| 1804 |
| 1805 |
| 1806 const char* Assembler::XmmRegisterName(XmmRegister reg) { |
| 1807 ASSERT((0 <= reg) && (reg < kNumberOfXmmRegisters)); |
| 1808 return xmm_reg_names[reg]; |
| 1809 } |
| 1810 |
| 1811 |
1793 } // namespace dart | 1812 } // namespace dart |
1794 | 1813 |
1795 #endif // defined TARGET_ARCH_IA32 | 1814 #endif // defined TARGET_ARCH_IA32 |
OLD | NEW |