Commit 9e13573e authored by Zhi An Ng's avatar Zhi An Ng Committed by Commit Bot

[ia32] Small cleanup of repetitive modrm decoding

Bug: v8:11074
Change-Id: I41a62490b3abe9ff00905fd9ea7e4bfff5f23a48
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2557064Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
Commit-Queue: Zhi An Ng <zhin@chromium.org>
Cr-Commit-Position: refs/heads/master@{#71390}
parent 89314801
...@@ -1816,10 +1816,12 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1816,10 +1816,12 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
case 0x0F: { case 0x0F: {
byte f0byte = data[1]; byte f0byte = data[1];
const char* f0mnem = F0Mnem(f0byte); const char* f0mnem = F0Mnem(f0byte);
int mod, regop, rm;
// Not every instruction use this, and it is safe to index data+2 as all
// instructions are at least 3 bytes with operands.
get_modrm(*(data + 2), &mod, &regop, &rm);
if (f0byte == 0x18) { if (f0byte == 0x18) {
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
const char* suffix[] = {"nta", "1", "2", "3"}; const char* suffix[] = {"nta", "1", "2", "3"};
AppendToBuffer("%s%s ", f0mnem, suffix[regop & 0x03]); AppendToBuffer("%s%s ", f0mnem, suffix[regop & 0x03]);
data += PrintRightOperand(data); data += PrintRightOperand(data);
...@@ -1847,8 +1849,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1847,8 +1849,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
data += 2; data += 2;
} else if (f0byte == 0x28) { } else if (f0byte == 0x28) {
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
AppendToBuffer("movaps %s,%s", NameOfXMMRegister(regop), AppendToBuffer("movaps %s,%s", NameOfXMMRegister(regop),
NameOfXMMRegister(rm)); NameOfXMMRegister(rm));
data++; data++;
...@@ -1856,8 +1856,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1856,8 +1856,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
data += 2; data += 2;
// movups xmm, xmm/m128 // movups xmm, xmm/m128
// movups xmm/m128, xmm // movups xmm/m128, xmm
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
AppendToBuffer("movups "); AppendToBuffer("movups ");
if (f0byte == 0x11) { if (f0byte == 0x11) {
data += PrintRightXMMOperand(data); data += PrintRightXMMOperand(data);
...@@ -1868,8 +1866,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1868,8 +1866,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
} }
} else if (f0byte == 0x2E) { } else if (f0byte == 0x2E) {
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
AppendToBuffer("ucomiss %s,", NameOfXMMRegister(regop)); AppendToBuffer("ucomiss %s,", NameOfXMMRegister(regop));
data += PrintRightXMMOperand(data); data += PrintRightXMMOperand(data);
} else if (f0byte >= 0x51 && f0byte <= 0x5F) { } else if (f0byte >= 0x51 && f0byte <= 0x5F) {
...@@ -1880,15 +1876,11 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1880,15 +1876,11 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
}; };
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
AppendToBuffer("%s %s,", pseudo_op[f0byte - 0x51], AppendToBuffer("%s %s,", pseudo_op[f0byte - 0x51],
NameOfXMMRegister(regop)); NameOfXMMRegister(regop));
data += PrintRightXMMOperand(data); data += PrintRightXMMOperand(data);
} else if (f0byte == 0x50) { } else if (f0byte == 0x50) {
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
AppendToBuffer("movmskps %s,%s", NameOfCPURegister(regop), AppendToBuffer("movmskps %s,%s", NameOfCPURegister(regop),
NameOfXMMRegister(rm)); NameOfXMMRegister(rm));
data++; data++;
...@@ -1900,8 +1892,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1900,8 +1892,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
data += PrintOperands("xadd", OPER_REG_OP_ORDER, data); data += PrintOperands("xadd", OPER_REG_OP_ORDER, data);
} else if (f0byte == 0xC2) { } else if (f0byte == 0xC2) {
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
const char* const pseudo_op[] = {"eq", "lt", "le", "unord", const char* const pseudo_op[] = {"eq", "lt", "le", "unord",
"neq", "nlt", "nle", "ord"}; "neq", "nlt", "nle", "ord"};
AppendToBuffer("cmpps %s, ", NameOfXMMRegister(regop)); AppendToBuffer("cmpps %s, ", NameOfXMMRegister(regop));
...@@ -1911,8 +1901,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1911,8 +1901,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
} else if (f0byte == 0xC6) { } else if (f0byte == 0xC6) {
// shufps xmm, xmm/m128, imm8 // shufps xmm, xmm/m128, imm8
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
int8_t imm8 = static_cast<int8_t>(data[1]); int8_t imm8 = static_cast<int8_t>(data[1]);
AppendToBuffer("shufps %s,%s,%d", NameOfXMMRegister(rm), AppendToBuffer("shufps %s,%s,%d", NameOfXMMRegister(rm),
NameOfXMMRegister(regop), static_cast<int>(imm8)); NameOfXMMRegister(regop), static_cast<int>(imm8));
...@@ -1936,8 +1924,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1936,8 +1924,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
// shld, shrd // shld, shrd
data += 2; data += 2;
AppendToBuffer("%s ", f0mnem); AppendToBuffer("%s ", f0mnem);
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
int8_t imm8 = static_cast<int8_t>(data[1]); int8_t imm8 = static_cast<int8_t>(data[1]);
data += 2; data += 2;
AppendToBuffer("%s,%s,%d", NameOfCPURegister(rm), AppendToBuffer("%s,%s,%d", NameOfCPURegister(rm),
...@@ -1946,8 +1932,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1946,8 +1932,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
// shrd_cl, shld_cl, bts // shrd_cl, shld_cl, bts
data += 2; data += 2;
AppendToBuffer("%s ", f0mnem); AppendToBuffer("%s ", f0mnem);
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
data += PrintRightOperand(data); data += PrintRightOperand(data);
if (f0byte == 0xAB) { if (f0byte == 0xAB) {
AppendToBuffer(",%s", NameOfCPURegister(regop)); AppendToBuffer(",%s", NameOfCPURegister(regop));
...@@ -1958,8 +1942,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1958,8 +1942,6 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
// cmpxchg_b // cmpxchg_b
data += 2; data += 2;
AppendToBuffer("%s ", f0mnem); AppendToBuffer("%s ", f0mnem);
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
data += PrintRightOperand(data); data += PrintRightOperand(data);
AppendToBuffer(",%s", NameOfByteCPURegister(regop)); AppendToBuffer(",%s", NameOfByteCPURegister(regop));
} else if (f0byte == 0xB1) { } else if (f0byte == 0xB1) {
...@@ -1968,22 +1950,16 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer, ...@@ -1968,22 +1950,16 @@ int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
data += PrintOperands(f0mnem, OPER_REG_OP_ORDER, data); data += PrintOperands(f0mnem, OPER_REG_OP_ORDER, data);
} else if (f0byte == 0xBC) { } else if (f0byte == 0xBC) {
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
AppendToBuffer("%s %s,", f0mnem, NameOfCPURegister(regop)); AppendToBuffer("%s %s,", f0mnem, NameOfCPURegister(regop));
data += PrintRightOperand(data); data += PrintRightOperand(data);
} else if (f0byte == 0xBD) { } else if (f0byte == 0xBD) {
data += 2; data += 2;
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
AppendToBuffer("%s %s,", f0mnem, NameOfCPURegister(regop)); AppendToBuffer("%s %s,", f0mnem, NameOfCPURegister(regop));
data += PrintRightOperand(data); data += PrintRightOperand(data);
} else if (f0byte == 0xC7) { } else if (f0byte == 0xC7) {
// cmpxchg8b // cmpxchg8b
data += 2; data += 2;
AppendToBuffer("%s ", f0mnem); AppendToBuffer("%s ", f0mnem);
int mod, regop, rm;
get_modrm(*data, &mod, &regop, &rm);
data += PrintRightOperand(data); data += PrintRightOperand(data);
} else if (f0byte == 0xAE && (data[2] & 0xF8) == 0xF0) { } else if (f0byte == 0xAE && (data[2] & 0xF8) == 0xF0) {
AppendToBuffer("mfence"); AppendToBuffer("mfence");
......
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