OLD | NEW |
1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "test/cctest/interpreter/bytecode-expectations-printer.h" | 5 #include "test/cctest/interpreter/bytecode-expectations-printer.h" |
6 | 6 |
7 #include <iostream> | 7 #include <iostream> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "include/libplatform/libplatform.h" | 10 #include "include/libplatform/libplatform.h" |
11 #include "include/v8.h" | 11 #include "include/v8.h" |
12 | 12 |
13 #include "src/base/logging.h" | 13 #include "src/base/logging.h" |
14 #include "src/base/smart-pointers.h" | 14 #include "src/base/smart-pointers.h" |
15 #include "src/compiler.h" | 15 #include "src/compiler.h" |
| 16 #include "src/runtime/runtime.h" |
16 | 17 |
17 #include "src/interpreter/bytecode-array-iterator.h" | 18 #include "src/interpreter/bytecode-array-iterator.h" |
18 #include "src/interpreter/bytecode-generator.h" | 19 #include "src/interpreter/bytecode-generator.h" |
19 #include "src/interpreter/bytecodes.h" | 20 #include "src/interpreter/bytecodes.h" |
20 #include "src/interpreter/interpreter.h" | 21 #include "src/interpreter/interpreter.h" |
21 | 22 |
22 namespace v8 { | 23 namespace v8 { |
23 namespace internal { | 24 namespace internal { |
24 namespace interpreter { | 25 namespace interpreter { |
25 | 26 |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
87 case '\\': | 88 case '\\': |
88 stream << "\\\\"; | 89 stream << "\\\\"; |
89 break; | 90 break; |
90 default: | 91 default: |
91 stream << c; | 92 stream << c; |
92 break; | 93 break; |
93 } | 94 } |
94 } | 95 } |
95 } | 96 } |
96 | 97 |
| 98 namespace { |
| 99 i::Runtime::FunctionId IndexToFunctionId(int index) { |
| 100 return static_cast<i::Runtime::FunctionId>(index); |
| 101 } |
| 102 } // namespace |
| 103 |
97 void BytecodeExpectationsPrinter::PrintBytecodeOperand( | 104 void BytecodeExpectationsPrinter::PrintBytecodeOperand( |
98 std::ostream& stream, const BytecodeArrayIterator& bytecode_iter, | 105 std::ostream& stream, const BytecodeArrayIterator& bytecode_iter, |
99 const Bytecode& bytecode, int op_index, int parameter_count) const { | 106 const Bytecode& bytecode, int op_index, int parameter_count) const { |
100 OperandType op_type = Bytecodes::GetOperandType(bytecode, op_index); | 107 OperandType op_type = Bytecodes::GetOperandType(bytecode, op_index); |
101 OperandSize op_size = Bytecodes::GetOperandSize(bytecode, op_index); | 108 OperandSize op_size = Bytecodes::GetOperandSize(bytecode, op_index); |
102 | 109 |
103 const char* size_tag; | 110 const char* size_tag; |
104 switch (op_size) { | 111 switch (op_size) { |
105 case OperandSize::kByte: | 112 case OperandSize::kByte: |
106 size_tag = "8"; | 113 size_tag = "8"; |
(...skipping 22 matching lines...) Expand all Loading... |
129 stream << "(this)"; | 136 stream << "(this)"; |
130 } else { | 137 } else { |
131 stream << "(arg" << (parameter_index - 1) << ')'; | 138 stream << "(arg" << (parameter_index - 1) << ')'; |
132 } | 139 } |
133 } else { | 140 } else { |
134 stream << '(' << register_value.index() << ')'; | 141 stream << '(' << register_value.index() << ')'; |
135 } | 142 } |
136 } else { | 143 } else { |
137 stream << 'U' << size_tag << '('; | 144 stream << 'U' << size_tag << '('; |
138 | 145 |
139 if (Bytecodes::IsImmediateOperandType(op_type)) { | 146 if (op_index == 0 && Bytecodes::IsCallRuntime(bytecode)) { |
| 147 DCHECK_EQ(op_type, OperandType::kIdx16); |
| 148 int operand = bytecode_iter.GetIndexOperand(op_index); |
| 149 stream << "Runtime::k" |
| 150 << i::Runtime::FunctionForId(IndexToFunctionId(operand))->name; |
| 151 } else if (Bytecodes::IsImmediateOperandType(op_type)) { |
140 // We need a cast, otherwise the result is printed as char. | 152 // We need a cast, otherwise the result is printed as char. |
141 stream << static_cast<int>(bytecode_iter.GetImmediateOperand(op_index)); | 153 stream << static_cast<int>(bytecode_iter.GetImmediateOperand(op_index)); |
142 } else if (Bytecodes::IsRegisterCountOperandType(op_type)) { | 154 } else if (Bytecodes::IsRegisterCountOperandType(op_type)) { |
143 stream << bytecode_iter.GetRegisterCountOperand(op_index); | 155 stream << bytecode_iter.GetRegisterCountOperand(op_index); |
144 } else if (Bytecodes::IsIndexOperandType(op_type)) { | 156 } else if (Bytecodes::IsIndexOperandType(op_type)) { |
145 stream << bytecode_iter.GetIndexOperand(op_index); | 157 stream << bytecode_iter.GetIndexOperand(op_index); |
146 } else { | 158 } else { |
147 UNREACHABLE(); | 159 UNREACHABLE(); |
148 } | 160 } |
149 | 161 |
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
292 | 304 |
293 stream << "---\n"; | 305 stream << "---\n"; |
294 PrintCodeSnippet(stream, snippet); | 306 PrintCodeSnippet(stream, snippet); |
295 PrintBytecodeArray(stream, bytecode_array); | 307 PrintBytecodeArray(stream, bytecode_array); |
296 stream << '\n'; | 308 stream << '\n'; |
297 } | 309 } |
298 | 310 |
299 } // namespace interpreter | 311 } // namespace interpreter |
300 } // namespace internal | 312 } // namespace internal |
301 } // namespace v8 | 313 } // namespace v8 |
OLD | NEW |