Commit 7a63e0be authored by oth's avatar oth Committed by Commit bot

[interpreter] Use bytecode-array-iterator in BytecodeArray::Print().

BUG=v8:4280
LOG=N

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

Cr-Commit-Position: refs/heads/master@{#34752}
parent 4ebd97b4
...@@ -33,7 +33,7 @@ ...@@ -33,7 +33,7 @@
#include "src/full-codegen/full-codegen.h" #include "src/full-codegen/full-codegen.h"
#include "src/ic/ic.h" #include "src/ic/ic.h"
#include "src/identity-map.h" #include "src/identity-map.h"
#include "src/interpreter/bytecodes.h" #include "src/interpreter/bytecode-array-iterator.h"
#include "src/interpreter/source-position-table.h" #include "src/interpreter/source-position-table.h"
#include "src/isolate-inl.h" #include "src/isolate-inl.h"
#include "src/keys.h" #include "src/keys.h"
...@@ -15018,50 +15018,29 @@ void BytecodeArray::Disassemble(std::ostream& os) { ...@@ -15018,50 +15018,29 @@ void BytecodeArray::Disassemble(std::ostream& os) {
os << "Frame size " << frame_size() << "\n"; os << "Frame size " << frame_size() << "\n";
Vector<char> buf = Vector<char>::New(50); Vector<char> buf = Vector<char>::New(50);
const uint8_t* first_bytecode_address = GetFirstBytecodeAddress(); const uint8_t* base_address = GetFirstBytecodeAddress();
int bytecode_size = 0;
interpreter::SourcePositionTableIterator source_positions( interpreter::SourcePositionTableIterator source_positions(
source_position_table()); source_position_table());
interpreter::BytecodeArrayIterator iterator(handle(this));
for (int i = 0; i < this->length(); i += bytecode_size) { while (!iterator.done()) {
const uint8_t* bytecode_start = &first_bytecode_address[i]; if (!source_positions.done() &&
interpreter::Bytecode bytecode = iterator.current_offset() == source_positions.bytecode_offset()) {
interpreter::Bytecodes::FromByte(bytecode_start[0]);
bytecode_size = interpreter::Bytecodes::Size(bytecode);
if (!source_positions.done() && i == source_positions.bytecode_offset()) {
os << std::setw(5) << source_positions.source_position(); os << std::setw(5) << source_positions.source_position();
os << (source_positions.is_statement() ? " S> " : " E> "); os << (source_positions.is_statement() ? " S> " : " E> ");
source_positions.Advance(); source_positions.Advance();
} else { } else {
os << " "; os << " ";
} }
const uint8_t* current_address = base_address + iterator.current_offset();
SNPrintF(buf, "%p", bytecode_start); SNPrintF(buf, "%p", current_address);
os << buf.start() << " : "; os << buf.start() << " : ";
interpreter::Bytecodes::Decode(os, bytecode_start, parameter_count()); interpreter::Bytecodes::Decode(os, current_address, parameter_count());
if (interpreter::Bytecodes::IsJump(iterator.current_bytecode())) {
if (interpreter::Bytecodes::IsJumpConstantWide(bytecode)) { SNPrintF(buf, " (%p)", base_address + iterator.GetJumpTargetOffset());
DCHECK_EQ(bytecode_size, 3);
int index = static_cast<int>(ReadUnalignedUInt16(bytecode_start + 1));
int offset = Smi::cast(constant_pool()->get(index))->value();
SNPrintF(buf, " (%p)", bytecode_start + offset);
os << buf.start();
} else if (interpreter::Bytecodes::IsJumpConstant(bytecode)) {
DCHECK_EQ(bytecode_size, 2);
int index = static_cast<int>(bytecode_start[1]);
int offset = Smi::cast(constant_pool()->get(index))->value();
SNPrintF(buf, " (%p)", bytecode_start + offset);
os << buf.start();
} else if (interpreter::Bytecodes::IsJump(bytecode)) {
DCHECK_EQ(bytecode_size, 2);
int offset = static_cast<int8_t>(bytecode_start[1]);
SNPrintF(buf, " (%p)", bytecode_start + offset);
os << buf.start(); os << buf.start();
} }
os << std::endl; os << std::endl;
iterator.Advance();
} }
if (constant_pool()->length() > 0) { if (constant_pool()->length() > 0) {
......
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