OSDN Git Service

Added repe_cmpsl instruction to x86, x86_64 assemblers
authoragicsaki <agicsaki@google.com>
Fri, 31 Jul 2015 17:31:14 +0000 (10:31 -0700)
committeragicsaki <agicsaki@google.com>
Fri, 31 Jul 2015 17:31:14 +0000 (10:31 -0700)
Support for this instruction has already been added to the disassembler
in commit 124b392d.

Change-Id: I6e8401a7b814618758427f5cc6b4992e265f937c

compiler/utils/x86/assembler_x86.cc
compiler/utils/x86/assembler_x86.h
compiler/utils/x86/assembler_x86_test.cc
compiler/utils/x86_64/assembler_x86_64.cc
compiler/utils/x86_64/assembler_x86_64.h
compiler/utils/x86_64/assembler_x86_64_test.cc

index 44efc65..a614193 100644 (file)
@@ -1523,6 +1523,13 @@ void X86Assembler::repe_cmpsw() {
 }
 
 
+void X86Assembler::repe_cmpsl() {
+  AssemblerBuffer::EnsureCapacity ensured(&buffer_);
+  EmitUint8(0xF3);
+  EmitUint8(0xA7);
+}
+
+
 X86Assembler* X86Assembler::lock() {
   AssemblerBuffer::EnsureCapacity ensured(&buffer_);
   EmitUint8(0xF0);
index e2abcde..ae8d7a1 100644 (file)
@@ -466,6 +466,7 @@ class X86Assembler FINAL : public Assembler {
 
   void repne_scasw();
   void repe_cmpsw();
+  void repe_cmpsl();
 
   X86Assembler* lock();
   void cmpxchgl(const Address& address, Register reg);
index 0e8c4ae..7663580 100644 (file)
@@ -202,4 +202,10 @@ TEST_F(AssemblerX86Test, Repecmpsw) {
   DriverStr(expected, "Repecmpsw");
 }
 
+TEST_F(AssemblerX86Test, Repecmpsl) {
+  GetAssembler()->repe_cmpsl();
+  const char* expected = "repe cmpsl\n";
+  DriverStr(expected, "Repecmpsl");
+}
+
 }  // namespace art
index 93c90db..1dd4a2e 100644 (file)
@@ -2081,6 +2081,13 @@ void X86_64Assembler::repe_cmpsw() {
 }
 
 
+void X86_64Assembler::repe_cmpsl() {
+  AssemblerBuffer::EnsureCapacity ensured(&buffer_);
+  EmitUint8(0xF3);
+  EmitUint8(0xA7);
+}
+
+
 void X86_64Assembler::LoadDoubleConstant(XmmRegister dst, double value) {
   // TODO: Need to have a code constants table.
   int64_t constant = bit_cast<int64_t, double>(value);
index 0cd3197..89a5606 100644 (file)
@@ -604,6 +604,7 @@ class X86_64Assembler FINAL : public Assembler {
 
   void repne_scasw();
   void repe_cmpsw();
+  void repe_cmpsl();
 
   //
   // Macros for High-level operations.
index 2c1a6a1..e1e4c32 100644 (file)
@@ -1269,4 +1269,10 @@ TEST_F(AssemblerX86_64Test, Repecmpsw) {
   DriverStr(expected, "Repecmpsw");
 }
 
+TEST_F(AssemblerX86_64Test, Repecmpsl) {
+  GetAssembler()->repe_cmpsl();
+  const char* expected = "repe cmpsl\n";
+  DriverStr(expected, "Repecmpsl");
+}
+
 }  // namespace art