Commit 074320ac authored by mbrandy's avatar mbrandy Committed by Commit bot

Fix interpreter unittest for embedded constant pools.

The offset from fp to the register file is based on the frame size
-- which is one slot larger when embedded constant pools are enabled.

TEST=unittests/DecodeBytecodeAndOperands
R=rmcilroy@chromium.org, bmeurer@chromium.org, oth@chromium.org, mstarzinger@chromium.org
BUG=

Review URL: https://codereview.chromium.org/1906963002

Cr-Commit-Position: refs/heads/master@{#35735}
parent f8f551ae
...@@ -177,6 +177,20 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) { ...@@ -177,6 +177,20 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) {
}; };
#define B(Name) static_cast<uint8_t>(Bytecode::k##Name) #define B(Name) static_cast<uint8_t>(Bytecode::k##Name)
#define REG_OPERAND(i) \
(InterpreterFrameConstants::kRegisterFileFromFp / kPointerSize - (i))
#define REG8(i) static_cast<uint8_t>(REG_OPERAND(i))
#if V8_TARGET_LITTLE_ENDIAN
#define REG16(i) \
static_cast<uint8_t>(REG_OPERAND(i)), \
static_cast<uint8_t>(REG_OPERAND(i) >> 8)
#elif V8_TARGET_BIG_ENDIAN
#define REG16(i) \
static_cast<uint8_t>(REG_OPERAND(i) >> 8), \
static_cast<uint8_t>(REG_OPERAND(i))
#else
#error "Unknown Architecture"
#endif
const BytecodesAndResult cases[] = { const BytecodesAndResult cases[] = {
#if V8_TARGET_LITTLE_ENDIAN #if V8_TARGET_LITTLE_ENDIAN
{{B(LdaSmi), 0x01}, 2, 0, " LdaSmi [1]"}, {{B(LdaSmi), 0x01}, 2, 0, " LdaSmi [1]"},
...@@ -191,9 +205,9 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) { ...@@ -191,9 +205,9 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) {
6, 6,
0, 0,
"LdaSmi.ExtraWide [-100000]"}, "LdaSmi.ExtraWide [-100000]"},
{{B(Star), 0xf5}, 2, 0, " Star r5"}, {{B(Star), REG8(5)}, 2, 0, " Star r5"},
{{B(Wide), B(Star), 0x72, 0xff}, 4, 0, " Star.Wide r136"}, {{B(Wide), B(Star), REG16(136)}, 4, 0, " Star.Wide r136"},
{{B(Wide), B(Call), 0x74, 0xff, 0x73, 0xff, 0x02, 0x00, 0xb1, 0x00}, {{B(Wide), B(Call), REG16(134), REG16(135), 0x02, 0x00, 0xb1, 0x00},
10, 10,
0, 0,
"Call.Wide r134, r135, #2, [177]"}, "Call.Wide r134, r135, #2, [177]"},
...@@ -223,9 +237,9 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) { ...@@ -223,9 +237,9 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) {
6, 6,
0, 0,
"LdaSmi.ExtraWide [-100000]"}, "LdaSmi.ExtraWide [-100000]"},
{{B(Star), 0xf5}, 2, 0, " Star r5"}, {{B(Star), REG8(5)}, 2, 0, " Star r5"},
{{B(Wide), B(Star), 0xff, 0x72}, 4, 0, " Star.Wide r136"}, {{B(Wide), B(Star), REG16(136)}, 4, 0, " Star.Wide r136"},
{{B(Wide), B(Call), 0xff, 0x74, 0xff, 0x73, 0x00, 0x02, 0x00, 0xb1}, {{B(Wide), B(Call), REG16(134), REG16(135), 0x00, 0x02, 0x00, 0xb1},
10, 10,
0, 0,
"Call.Wide r134, r135, #2, [177]"}, "Call.Wide r134, r135, #2, [177]"},
...@@ -247,6 +261,9 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) { ...@@ -247,6 +261,9 @@ TEST(Bytecodes, DecodeBytecodeAndOperands) {
#endif #endif
}; };
#undef B #undef B
#undef REG_OFFSET
#undef REG
#undef REG_HI
for (size_t i = 0; i < arraysize(cases); ++i) { for (size_t i = 0; i < arraysize(cases); ++i) {
// Generate reference string by prepending formatted bytes. // Generate reference string by prepending formatted bytes.
......
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