Chromium Code Reviews| Index: src/objects.cc |
| diff --git a/src/objects.cc b/src/objects.cc |
| index 3df88e300c3ad8f53028e452dc8f0a5a24976b73..3496e72fb2233e3c1987156999f4288785e9afbd 100644 |
| --- a/src/objects.cc |
| +++ b/src/objects.cc |
| @@ -11615,7 +11615,6 @@ void BytecodeArray::Disassemble(std::ostream& os) { |
| for (int i = 0; i < this->length(); i += bytes) { |
| interpreter::Bytecode bytecode = interpreter::Bytecodes::FromByte(get(i)); |
| bytes = interpreter::Bytecodes::Size(bytecode); |
| - |
| SNPrintF(buf, "%p : ", GetFirstBytecodeAddress() + i); |
| os << buf.start(); |
| for (int j = 0; j < bytes; j++) { |
| @@ -11625,7 +11624,26 @@ void BytecodeArray::Disassemble(std::ostream& os) { |
| for (int j = bytes; j < interpreter::Bytecodes::MaximumSize(); j++) { |
| os << " "; |
| } |
| - os << bytecode << "\n"; |
| + os << bytecode << " "; |
| + for (int j = 1; j < bytes; j++) { |
| + interpreter::OperandType op_type = |
| + interpreter::Bytecodes::GetOperandType(bytecode, j - 1); |
| + uint8_t operand = get(i + j); |
| + switch (op_type) { |
| + case interpreter::OperandType::kNone: |
|
rmcilroy
2015/07/31 09:56:19
We should never hit this case, right? If so, maybe
oth
2015/07/31 11:20:59
Done.
|
| + break; |
| + case interpreter::OperandType::kImm8: |
| + os << "#" << static_cast<int>(operand); |
| + break; |
| + case interpreter::OperandType::kReg: |
| + os << "r" << static_cast<int>(operand); |
| + break; |
| + } |
| + if (j + 1 < bytes) { |
| + os << ", "; |
| + } |
| + } |
| + os << "\n"; |
| } |
| } |