Commit 7fc881f5 authored by Ng Zhi An's avatar Ng Zhi An Committed by Commit Bot

[x64] Move modrm decoding up the scope

Instead of decoding in each branch, move the decoding up in scope, since
all branches do the same decoding.

Bug: v8:10933
Change-Id: I99ef03e4271cc111428f9a243f61b26af6f85780
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2472758Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
Commit-Queue: Zhi An Ng <zhin@chromium.org>
Cr-Commit-Position: refs/heads/master@{#70542}
parent 15237298
...@@ -1865,84 +1865,72 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) { ...@@ -1865,84 +1865,72 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) {
} else if (opcode == 0x3A) { } else if (opcode == 0x3A) {
byte third_byte = *current; byte third_byte = *current;
current = data + 3; current = data + 3;
get_modrm(*current, &mod, &regop, &rm);
if (third_byte == 0x17) { if (third_byte == 0x17) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("extractps "); // reg/m32, xmm, imm8 AppendToBuffer("extractps "); // reg/m32, xmm, imm8
current += PrintRightOperand(current); current += PrintRightOperand(current);
AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 3); AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x08) { } else if (third_byte == 0x08) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("roundps %s,", NameOfXMMRegister(regop)); AppendToBuffer("roundps %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",0x%x", (*current) & 3); AppendToBuffer(",0x%x", (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x09) { } else if (third_byte == 0x09) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("roundpd %s,", NameOfXMMRegister(regop)); AppendToBuffer("roundpd %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",0x%x", (*current) & 3); AppendToBuffer(",0x%x", (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x0A) { } else if (third_byte == 0x0A) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("roundss %s,", NameOfXMMRegister(regop)); AppendToBuffer("roundss %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",0x%x", (*current) & 3); AppendToBuffer(",0x%x", (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x0B) { } else if (third_byte == 0x0B) {
get_modrm(*current, &mod, &regop, &rm);
// roundsd xmm, xmm/m64, imm8 // roundsd xmm, xmm/m64, imm8
AppendToBuffer("roundsd %s,", NameOfXMMRegister(regop)); AppendToBuffer("roundsd %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",0x%x", (*current) & 3); AppendToBuffer(",0x%x", (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x0E) { } else if (third_byte == 0x0E) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("pblendw %s,", NameOfXMMRegister(regop)); AppendToBuffer("pblendw %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",0x%x", *current); AppendToBuffer(",0x%x", *current);
current += 1; current += 1;
} else if (third_byte == 0x0F) { } else if (third_byte == 0x0F) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("palignr %s,", NameOfXMMRegister(regop)); AppendToBuffer("palignr %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",0x%x", (*current)); AppendToBuffer(",0x%x", (*current));
current += 1; current += 1;
} else if (third_byte == 0x14) { } else if (third_byte == 0x14) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("pextrb "); // reg/m32, xmm, imm8 AppendToBuffer("pextrb "); // reg/m32, xmm, imm8
current += PrintRightOperand(current); current += PrintRightOperand(current);
AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 3); AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x15) { } else if (third_byte == 0x15) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("pextrw "); // reg/m32, xmm, imm8 AppendToBuffer("pextrw "); // reg/m32, xmm, imm8
current += PrintRightOperand(current); current += PrintRightOperand(current);
AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 7); AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 7);
current += 1; current += 1;
} else if (third_byte == 0x16) { } else if (third_byte == 0x16) {
get_modrm(*current, &mod, &regop, &rm);
// reg/m32/reg/m64, xmm, imm8 // reg/m32/reg/m64, xmm, imm8
AppendToBuffer("pextr%c ", rex_w() ? 'q' : 'd'); AppendToBuffer("pextr%c ", rex_w() ? 'q' : 'd');
current += PrintRightOperand(current); current += PrintRightOperand(current);
AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 3); AppendToBuffer(",%s,%d", NameOfXMMRegister(regop), (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x20) { } else if (third_byte == 0x20) {
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("pinsrb "); // xmm, reg/m32, imm8 AppendToBuffer("pinsrb "); // xmm, reg/m32, imm8
AppendToBuffer(" %s,", NameOfXMMRegister(regop)); AppendToBuffer(" %s,", NameOfXMMRegister(regop));
current += PrintRightOperand(current); current += PrintRightOperand(current);
AppendToBuffer(",%d", (*current) & 3); AppendToBuffer(",%d", (*current) & 3);
current += 1; current += 1;
} else if (third_byte == 0x21) { } else if (third_byte == 0x21) {
get_modrm(*current, &mod, &regop, &rm);
// insertps xmm, xmm/m32, imm8 // insertps xmm, xmm/m32, imm8
AppendToBuffer("insertps %s,", NameOfXMMRegister(regop)); AppendToBuffer("insertps %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",0x%x", (*current)); AppendToBuffer(",0x%x", (*current));
current += 1; current += 1;
} else if (third_byte == 0x22) { } else if (third_byte == 0x22) {
get_modrm(*current, &mod, &regop, &rm);
// xmm, reg/m32/reg/m64, imm8 // xmm, reg/m32/reg/m64, imm8
AppendToBuffer("pinsr%c ", rex_w() ? 'q' : 'd'); AppendToBuffer("pinsr%c ", rex_w() ? 'q' : 'd');
AppendToBuffer(" %s,", NameOfXMMRegister(regop)); AppendToBuffer(" %s,", NameOfXMMRegister(regop));
...@@ -2188,12 +2176,12 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) { ...@@ -2188,12 +2176,12 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) {
} }
} else if (group_1_prefix_ == 0xF2) { } else if (group_1_prefix_ == 0xF2) {
// Beginning of instructions with prefix 0xF2. // Beginning of instructions with prefix 0xF2.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
if (opcode == 0x11 || opcode == 0x10) { if (opcode == 0x11 || opcode == 0x10) {
// MOVSD: Move scalar double-precision fp to/from/between XMM registers. // MOVSD: Move scalar double-precision fp to/from/between XMM registers.
AppendToBuffer("movsd "); AppendToBuffer("movsd ");
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
if (opcode == 0x11) { if (opcode == 0x11) {
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",%s", NameOfXMMRegister(regop)); AppendToBuffer(",%s", NameOfXMMRegister(regop));
...@@ -2202,56 +2190,40 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) { ...@@ -2202,56 +2190,40 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) {
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} }
} else if (opcode == 0x12) { } else if (opcode == 0x12) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("movddup %s,", NameOfXMMRegister(regop)); AppendToBuffer("movddup %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0x2A) { } else if (opcode == 0x2A) {
// CVTSI2SD: integer to XMM double conversion. // CVTSI2SD: integer to XMM double conversion.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop)); AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop));
current += PrintRightOperand(current); current += PrintRightOperand(current);
} else if (opcode == 0x2C) { } else if (opcode == 0x2C) {
// CVTTSD2SI: // CVTTSD2SI:
// Convert with truncation scalar double-precision FP to integer. // Convert with truncation scalar double-precision FP to integer.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("cvttsd2si%c %s,", operand_size_code(), AppendToBuffer("cvttsd2si%c %s,", operand_size_code(),
NameOfCPURegister(regop)); NameOfCPURegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0x2D) { } else if (opcode == 0x2D) {
// CVTSD2SI: Convert scalar double-precision FP to integer. // CVTSD2SI: Convert scalar double-precision FP to integer.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("cvtsd2si%c %s,", operand_size_code(), AppendToBuffer("cvtsd2si%c %s,", operand_size_code(),
NameOfCPURegister(regop)); NameOfCPURegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0x5B) { } else if (opcode == 0x5B) {
// CVTTPS2DQ: Convert packed single-precision FP values to packed signed // CVTTPS2DQ: Convert packed single-precision FP values to packed signed
// doubleword integer values // doubleword integer values
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("cvttps2dq%c %s,", operand_size_code(), AppendToBuffer("cvttps2dq%c %s,", operand_size_code(),
NameOfCPURegister(regop)); NameOfCPURegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if ((opcode & 0xF8) == 0x58 || opcode == 0x51) { } else if ((opcode & 0xF8) == 0x58 || opcode == 0x51) {
// XMM arithmetic. Mnemonic was retrieved at the start of this function. // XMM arithmetic. Mnemonic was retrieved at the start of this function.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop)); AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0x70) { } else if (opcode == 0x70) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("pshuflw %s, ", NameOfXMMRegister(regop)); AppendToBuffer("pshuflw %s, ", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(", %d", (*current) & 7); AppendToBuffer(", %d", (*current) & 7);
current += 1; current += 1;
} else if (opcode == 0xC2) { } else if (opcode == 0xC2) {
// Intel manual 2A, Table 3-18. // Intel manual 2A, Table 3-18.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
const char* const pseudo_op[] = {"cmpeqsd", "cmpltsd", "cmplesd", const char* const pseudo_op[] = {"cmpeqsd", "cmpltsd", "cmplesd",
"cmpunordsd", "cmpneqsd", "cmpnltsd", "cmpunordsd", "cmpneqsd", "cmpnltsd",
"cmpnlesd", "cmpordsd"}; "cmpnlesd", "cmpordsd"};
...@@ -2259,13 +2231,9 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) { ...@@ -2259,13 +2231,9 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) {
NameOfXMMRegister(regop), NameOfXMMRegister(rm)); NameOfXMMRegister(regop), NameOfXMMRegister(rm));
current += 2; current += 2;
} else if (opcode == 0xF0) { } else if (opcode == 0xF0) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("lddqu %s,", NameOfXMMRegister(regop)); AppendToBuffer("lddqu %s,", NameOfXMMRegister(regop));
current += PrintRightOperand(current); current += PrintRightOperand(current);
} else if (opcode == 0x7C) { } else if (opcode == 0x7C) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("haddps %s,", NameOfXMMRegister(regop)); AppendToBuffer("haddps %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else { } else {
...@@ -2273,11 +2241,11 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) { ...@@ -2273,11 +2241,11 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) {
} }
} else if (group_1_prefix_ == 0xF3) { } else if (group_1_prefix_ == 0xF3) {
// Instructions with prefix 0xF3. // Instructions with prefix 0xF3.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
if (opcode == 0x11 || opcode == 0x10) { if (opcode == 0x11 || opcode == 0x10) {
// MOVSS: Move scalar double-precision fp to/from/between XMM registers. // MOVSS: Move scalar double-precision fp to/from/between XMM registers.
AppendToBuffer("movss "); AppendToBuffer("movss ");
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
if (opcode == 0x11) { if (opcode == 0x11) {
current += PrintRightOperand(current); current += PrintRightOperand(current);
AppendToBuffer(",%s", NameOfXMMRegister(regop)); AppendToBuffer(",%s", NameOfXMMRegister(regop));
...@@ -2287,69 +2255,47 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) { ...@@ -2287,69 +2255,47 @@ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) {
} }
} else if (opcode == 0x2A) { } else if (opcode == 0x2A) {
// CVTSI2SS: integer to XMM single conversion. // CVTSI2SS: integer to XMM single conversion.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop)); AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop));
current += PrintRightOperand(current); current += PrintRightOperand(current);
} else if (opcode == 0x2C) { } else if (opcode == 0x2C) {
// CVTTSS2SI: // CVTTSS2SI:
// Convert with truncation scalar single-precision FP to dword integer. // Convert with truncation scalar single-precision FP to dword integer.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("cvttss2si%c %s,", operand_size_code(), AppendToBuffer("cvttss2si%c %s,", operand_size_code(),
NameOfCPURegister(regop)); NameOfCPURegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0x70) { } else if (opcode == 0x70) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("pshufhw %s, ", NameOfXMMRegister(regop)); AppendToBuffer("pshufhw %s, ", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(", %d", (*current) & 7); AppendToBuffer(", %d", (*current) & 7);
current += 1; current += 1;
} else if (opcode == 0x6F) { } else if (opcode == 0x6F) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("movdqu %s,", NameOfXMMRegister(regop)); AppendToBuffer("movdqu %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0x7E) { } else if (opcode == 0x7E) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("movq %s,", NameOfXMMRegister(regop)); AppendToBuffer("movq %s,", NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0x7F) { } else if (opcode == 0x7F) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("movdqu "); AppendToBuffer("movdqu ");
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
AppendToBuffer(",%s", NameOfXMMRegister(regop)); AppendToBuffer(",%s", NameOfXMMRegister(regop));
} else if ((opcode & 0xF8) == 0x58 || opcode == 0x51) { } else if ((opcode & 0xF8) == 0x58 || opcode == 0x51) {
// XMM arithmetic. Mnemonic was retrieved at the start of this function. // XMM arithmetic. Mnemonic was retrieved at the start of this function.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop)); AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop));
current += PrintRightXMMOperand(current); current += PrintRightXMMOperand(current);
} else if (opcode == 0xB8) { } else if (opcode == 0xB8) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("popcnt%c %s,", operand_size_code(), AppendToBuffer("popcnt%c %s,", operand_size_code(),
NameOfCPURegister(regop)); NameOfCPURegister(regop));
current += PrintRightOperand(current); current += PrintRightOperand(current);
} else if (opcode == 0xBC) { } else if (opcode == 0xBC) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("tzcnt%c %s,", operand_size_code(), AppendToBuffer("tzcnt%c %s,", operand_size_code(),
NameOfCPURegister(regop)); NameOfCPURegister(regop));
current += PrintRightOperand(current); current += PrintRightOperand(current);
} else if (opcode == 0xBD) { } else if (opcode == 0xBD) {
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
AppendToBuffer("lzcnt%c %s,", operand_size_code(), AppendToBuffer("lzcnt%c %s,", operand_size_code(),
NameOfCPURegister(regop)); NameOfCPURegister(regop));
current += PrintRightOperand(current); current += PrintRightOperand(current);
} else if (opcode == 0xC2) { } else if (opcode == 0xC2) {
// Intel manual 2A, Table 3-18. // Intel manual 2A, Table 3-18.
int mod, regop, rm;
get_modrm(*current, &mod, &regop, &rm);
const char* const pseudo_op[] = {"cmpeqss", "cmpltss", "cmpless", const char* const pseudo_op[] = {"cmpeqss", "cmpltss", "cmpless",
"cmpunordss", "cmpneqss", "cmpnltss", "cmpunordss", "cmpneqss", "cmpnltss",
"cmpnless", "cmpordss"}; "cmpnless", "cmpordss"};
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment