diff options
author | Calin Juravle <calin@google.com> | 2014-11-13 11:16:37 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2014-11-13 11:16:37 +0000 |
commit | d94a0a1d2868baaab49f4d2835bca086d98cf763 (patch) | |
tree | 48d0701d17445c9ae09ee521c6ac1fb9f614d3b0 /compiler/utils | |
parent | d77ae8a11e6493ac738864eae073ca4909e4d847 (diff) | |
parent | d6fb6cfb6f2d0d9595f55e8cc18d2753be5d9a13 (diff) | |
download | android_art-d94a0a1d2868baaab49f4d2835bca086d98cf763.tar.gz android_art-d94a0a1d2868baaab49f4d2835bca086d98cf763.tar.bz2 android_art-d94a0a1d2868baaab49f4d2835bca086d98cf763.zip |
Merge "[optimizing compiler] Add DIV_LONG"
Diffstat (limited to 'compiler/utils')
-rw-r--r-- | compiler/utils/x86_64/assembler_x86_64.cc | 71 | ||||
-rw-r--r-- | compiler/utils/x86_64/assembler_x86_64.h | 6 |
2 files changed, 62 insertions, 15 deletions
diff --git a/compiler/utils/x86_64/assembler_x86_64.cc b/compiler/utils/x86_64/assembler_x86_64.cc index 5d1c9af202..bd08b1ff2a 100644 --- a/compiler/utils/x86_64/assembler_x86_64.cc +++ b/compiler/utils/x86_64/assembler_x86_64.cc @@ -909,6 +909,21 @@ void X86_64Assembler::cmpl(CpuRegister reg, const Address& address) { } +void X86_64Assembler::cmpl(const Address& address, CpuRegister reg) { + AssemblerBuffer::EnsureCapacity ensured(&buffer_); + EmitOptionalRex32(reg, address); + EmitUint8(0x39); + EmitOperand(reg.LowBits(), address); +} + + +void X86_64Assembler::cmpl(const Address& address, const Immediate& imm) { + AssemblerBuffer::EnsureCapacity ensured(&buffer_); + EmitOptionalRex32(address); + EmitComplex(7, address, imm); +} + + void X86_64Assembler::cmpq(CpuRegister reg0, CpuRegister reg1) { AssemblerBuffer::EnsureCapacity ensured(&buffer_); EmitRex64(reg0, reg1); @@ -933,6 +948,14 @@ void X86_64Assembler::cmpq(CpuRegister reg, const Address& address) { } +void X86_64Assembler::cmpq(const Address& address, const Immediate& imm) { + CHECK(imm.is_int32()); // cmpq only supports 32b immediate. + AssemblerBuffer::EnsureCapacity ensured(&buffer_); + EmitRex64(address); + EmitComplex(7, address, imm); +} + + void X86_64Assembler::addl(CpuRegister dst, CpuRegister src) { AssemblerBuffer::EnsureCapacity ensured(&buffer_); EmitOptionalRex32(dst, src); @@ -949,21 +972,6 @@ void X86_64Assembler::addl(CpuRegister reg, const Address& address) { } -void X86_64Assembler::cmpl(const Address& address, CpuRegister reg) { - AssemblerBuffer::EnsureCapacity ensured(&buffer_); - EmitOptionalRex32(reg, address); - EmitUint8(0x39); - EmitOperand(reg.LowBits(), address); -} - - -void X86_64Assembler::cmpl(const Address& address, const Immediate& imm) { - AssemblerBuffer::EnsureCapacity ensured(&buffer_); - EmitOptionalRex32(address); - EmitComplex(7, address, imm); -} - - void X86_64Assembler::testl(CpuRegister reg1, CpuRegister reg2) { AssemblerBuffer::EnsureCapacity ensured(&buffer_); EmitOptionalRex32(reg1, reg2); @@ -998,6 +1006,14 @@ void X86_64Assembler::testl(CpuRegister reg, const Immediate& immediate) { } +void X86_64Assembler::testq(CpuRegister reg1, CpuRegister reg2) { + AssemblerBuffer::EnsureCapacity ensured(&buffer_); + EmitRex64(reg1, reg2); + EmitUint8(0x85); + EmitRegisterOperand(reg1.LowBits(), reg2.LowBits()); +} + + void X86_64Assembler::testq(CpuRegister reg, const Address& address) { AssemblerBuffer::EnsureCapacity ensured(&buffer_); EmitRex64(reg); @@ -1267,6 +1283,13 @@ void X86_64Assembler::cdq() { } +void X86_64Assembler::cqo() { + AssemblerBuffer::EnsureCapacity ensured(&buffer_); + EmitRex64(); + EmitUint8(0x99); +} + + void X86_64Assembler::idivl(CpuRegister reg) { AssemblerBuffer::EnsureCapacity ensured(&buffer_); EmitOptionalRex32(reg); @@ -1275,6 +1298,14 @@ void X86_64Assembler::idivl(CpuRegister reg) { } +void X86_64Assembler::idivq(CpuRegister reg) { + AssemblerBuffer::EnsureCapacity ensured(&buffer_); + EmitRex64(reg); + EmitUint8(0xF7); + EmitUint8(0xF8 | reg.LowBits()); +} + + void X86_64Assembler::imull(CpuRegister dst, CpuRegister src) { AssemblerBuffer::EnsureCapacity ensured(&buffer_); EmitOptionalRex32(dst, src); @@ -1820,10 +1851,20 @@ void X86_64Assembler::EmitOptionalRex32(XmmRegister dst, const Operand& operand) } } +void X86_64Assembler::EmitRex64() { + EmitOptionalRex(false, true, false, false, false); +} + void X86_64Assembler::EmitRex64(CpuRegister reg) { EmitOptionalRex(false, true, false, false, reg.NeedsRex()); } +void X86_64Assembler::EmitRex64(const Operand& operand) { + uint8_t rex = operand.rex(); + rex |= 0x48; // REX.W000 + EmitUint8(rex); +} + void X86_64Assembler::EmitRex64(CpuRegister dst, CpuRegister src) { EmitOptionalRex(false, true, dst.NeedsRex(), false, src.NeedsRex()); } diff --git a/compiler/utils/x86_64/assembler_x86_64.h b/compiler/utils/x86_64/assembler_x86_64.h index 285b4cfc43..b46f6f71e3 100644 --- a/compiler/utils/x86_64/assembler_x86_64.h +++ b/compiler/utils/x86_64/assembler_x86_64.h @@ -390,10 +390,12 @@ class X86_64Assembler FINAL : public Assembler { void cmpq(CpuRegister reg0, CpuRegister reg1); void cmpq(CpuRegister reg0, const Immediate& imm); void cmpq(CpuRegister reg0, const Address& address); + void cmpq(const Address& address, const Immediate& imm); void testl(CpuRegister reg1, CpuRegister reg2); void testl(CpuRegister reg, const Immediate& imm); + void testq(CpuRegister reg1, CpuRegister reg2); void testq(CpuRegister reg, const Address& address); void andl(CpuRegister dst, const Immediate& imm); @@ -432,8 +434,10 @@ class X86_64Assembler FINAL : public Assembler { void subq(CpuRegister dst, const Address& address); void cdq(); + void cqo(); void idivl(CpuRegister reg); + void idivq(CpuRegister reg); void imull(CpuRegister dst, CpuRegister src); void imull(CpuRegister reg, const Immediate& imm); @@ -669,7 +673,9 @@ class X86_64Assembler FINAL : public Assembler { void EmitOptionalRex32(XmmRegister dst, const Operand& operand); // Emit a REX.W prefix plus necessary register bit encodings. + void EmitRex64(); void EmitRex64(CpuRegister reg); + void EmitRex64(const Operand& operand); void EmitRex64(CpuRegister dst, CpuRegister src); void EmitRex64(CpuRegister dst, const Operand& operand); void EmitRex64(XmmRegister dst, CpuRegister src); |