OLD | NEW |
1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 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 "src/interpreter/bytecode-array-builder.h" | 5 #include "src/interpreter/bytecode-array-builder.h" |
6 | 6 |
7 #include "src/compiler.h" | 7 #include "src/compiler.h" |
8 #include "src/globals.h" | 8 #include "src/globals.h" |
9 #include "src/interpreter/bytecode-array-writer.h" | 9 #include "src/interpreter/bytecode-array-writer.h" |
10 #include "src/interpreter/bytecode-dead-code-optimizer.h" | 10 #include "src/interpreter/bytecode-dead-code-optimizer.h" |
(...skipping 452 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
463 // A Nop could be inserted for empty statements, but since no code | 463 // A Nop could be inserted for empty statements, but since no code |
464 // is associated with these positions, instead we force the stack | 464 // is associated with these positions, instead we force the stack |
465 // check's expression position which eliminates the empty | 465 // check's expression position which eliminates the empty |
466 // statement's position. | 466 // statement's position. |
467 latest_source_info_.ForceExpressionPosition(position); | 467 latest_source_info_.ForceExpressionPosition(position); |
468 } | 468 } |
469 Output(Bytecode::kStackCheck); | 469 Output(Bytecode::kStackCheck); |
470 return *this; | 470 return *this; |
471 } | 471 } |
472 | 472 |
| 473 BytecodeArrayBuilder& BytecodeArrayBuilder::OsrPoll(int loop_depth) { |
| 474 Output(Bytecode::kOsrPoll, UnsignedOperand(loop_depth)); |
| 475 return *this; |
| 476 } |
| 477 |
473 BytecodeArrayBuilder& BytecodeArrayBuilder::Throw() { | 478 BytecodeArrayBuilder& BytecodeArrayBuilder::Throw() { |
474 Output(Bytecode::kThrow); | 479 Output(Bytecode::kThrow); |
475 return *this; | 480 return *this; |
476 } | 481 } |
477 | 482 |
478 BytecodeArrayBuilder& BytecodeArrayBuilder::ReThrow() { | 483 BytecodeArrayBuilder& BytecodeArrayBuilder::ReThrow() { |
479 Output(Bytecode::kReThrow); | 484 Output(Bytecode::kReThrow); |
480 return *this; | 485 return *this; |
481 } | 486 } |
482 | 487 |
(...skipping 466 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
949 return Bytecode::kTailCall; | 954 return Bytecode::kTailCall; |
950 default: | 955 default: |
951 UNREACHABLE(); | 956 UNREACHABLE(); |
952 } | 957 } |
953 return Bytecode::kIllegal; | 958 return Bytecode::kIllegal; |
954 } | 959 } |
955 | 960 |
956 } // namespace interpreter | 961 } // namespace interpreter |
957 } // namespace internal | 962 } // namespace internal |
958 } // namespace v8 | 963 } // namespace v8 |
OLD | NEW |