| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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" // NOLINT | 5 #include "vm/globals.h" // NOLINT |
| 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/code_generator.h" | 9 #include "vm/code_generator.h" |
| 10 #include "vm/cpu.h" | 10 #include "vm/cpu.h" |
| (...skipping 1753 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1764 void Assembler::sarl(Register operand, Register shifter) { | 1764 void Assembler::sarl(Register operand, Register shifter) { |
| 1765 EmitGenericShift(7, Operand(operand), shifter); | 1765 EmitGenericShift(7, Operand(operand), shifter); |
| 1766 } | 1766 } |
| 1767 | 1767 |
| 1768 | 1768 |
| 1769 void Assembler::sarl(const Address& address, Register shifter) { | 1769 void Assembler::sarl(const Address& address, Register shifter) { |
| 1770 EmitGenericShift(7, Operand(address), shifter); | 1770 EmitGenericShift(7, Operand(address), shifter); |
| 1771 } | 1771 } |
| 1772 | 1772 |
| 1773 | 1773 |
| 1774 void Assembler::shldl(Register dst, Register src) { | 1774 void Assembler::shldl(Register dst, Register src, Register shifter) { |
| 1775 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 1775 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 1776 ASSERT(shifter == ECX); |
| 1776 EmitUint8(0x0F); | 1777 EmitUint8(0x0F); |
| 1777 EmitUint8(0xA5); | 1778 EmitUint8(0xA5); |
| 1778 EmitRegisterOperand(src, dst); | 1779 EmitRegisterOperand(src, dst); |
| 1779 } | 1780 } |
| 1780 | 1781 |
| 1781 | 1782 |
| 1782 void Assembler::shldl(Register dst, Register src, const Immediate& imm) { | 1783 void Assembler::shldl(Register dst, Register src, const Immediate& imm) { |
| 1783 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 1784 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 1784 ASSERT(imm.is_int8()); | 1785 ASSERT(imm.is_int8()); |
| 1785 EmitUint8(0x0F); | 1786 EmitUint8(0x0F); |
| 1786 EmitUint8(0xA4); | 1787 EmitUint8(0xA4); |
| 1787 EmitRegisterOperand(src, dst); | 1788 EmitRegisterOperand(src, dst); |
| 1788 EmitUint8(imm.value() & 0xFF); | 1789 EmitUint8(imm.value() & 0xFF); |
| 1789 } | 1790 } |
| 1790 | 1791 |
| 1791 | 1792 |
| 1792 void Assembler::shldl(const Address& operand, Register src) { | 1793 void Assembler::shldl(const Address& operand, Register src, Register shifter) { |
| 1793 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 1794 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 1795 ASSERT(shifter == ECX); |
| 1794 EmitUint8(0x0F); | 1796 EmitUint8(0x0F); |
| 1795 EmitUint8(0xA5); | 1797 EmitUint8(0xA5); |
| 1796 EmitOperand(src, Operand(operand)); | 1798 EmitOperand(src, Operand(operand)); |
| 1797 } | 1799 } |
| 1798 | 1800 |
| 1799 | 1801 |
| 1800 void Assembler::shrdl(Register dst, Register src) { | 1802 void Assembler::shrdl(Register dst, Register src, Register shifter) { |
| 1801 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 1803 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 1804 ASSERT(shifter == ECX); |
| 1802 EmitUint8(0x0F); | 1805 EmitUint8(0x0F); |
| 1803 EmitUint8(0xAD); | 1806 EmitUint8(0xAD); |
| 1804 EmitRegisterOperand(src, dst); | 1807 EmitRegisterOperand(src, dst); |
| 1805 } | 1808 } |
| 1806 | 1809 |
| 1807 | 1810 |
| 1808 void Assembler::shrdl(Register dst, Register src, const Immediate& imm) { | 1811 void Assembler::shrdl(Register dst, Register src, const Immediate& imm) { |
| 1809 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 1812 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 1810 ASSERT(imm.is_int8()); | 1813 ASSERT(imm.is_int8()); |
| 1811 EmitUint8(0x0F); | 1814 EmitUint8(0x0F); |
| 1812 EmitUint8(0xAC); | 1815 EmitUint8(0xAC); |
| 1813 EmitRegisterOperand(src, dst); | 1816 EmitRegisterOperand(src, dst); |
| 1814 EmitUint8(imm.value() & 0xFF); | 1817 EmitUint8(imm.value() & 0xFF); |
| 1815 } | 1818 } |
| 1816 | 1819 |
| 1817 | 1820 |
| 1818 void Assembler::shrdl(const Address& dst, Register src) { | 1821 void Assembler::shrdl(const Address& dst, Register src, Register shifter) { |
| 1819 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 1822 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 1823 ASSERT(shifter == ECX); |
| 1820 EmitUint8(0x0F); | 1824 EmitUint8(0x0F); |
| 1821 EmitUint8(0xAD); | 1825 EmitUint8(0xAD); |
| 1822 EmitOperand(src, Operand(dst)); | 1826 EmitOperand(src, Operand(dst)); |
| 1823 } | 1827 } |
| 1824 | 1828 |
| 1825 | 1829 |
| 1826 void Assembler::negl(Register reg) { | 1830 void Assembler::negl(Register reg) { |
| 1827 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 1831 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
| 1828 EmitUint8(0xF7); | 1832 EmitUint8(0xF7); |
| 1829 EmitOperand(3, Operand(reg)); | 1833 EmitOperand(3, Operand(reg)); |
| (...skipping 1271 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3101 | 3105 |
| 3102 const char* Assembler::FpuRegisterName(FpuRegister reg) { | 3106 const char* Assembler::FpuRegisterName(FpuRegister reg) { |
| 3103 ASSERT((0 <= reg) && (reg < kNumberOfXmmRegisters)); | 3107 ASSERT((0 <= reg) && (reg < kNumberOfXmmRegisters)); |
| 3104 return xmm_reg_names[reg]; | 3108 return xmm_reg_names[reg]; |
| 3105 } | 3109 } |
| 3106 | 3110 |
| 3107 | 3111 |
| 3108 } // namespace dart | 3112 } // namespace dart |
| 3109 | 3113 |
| 3110 #endif // defined TARGET_ARCH_IA32 | 3114 #endif // defined TARGET_ARCH_IA32 |
| OLD | NEW |