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 | |
478 BytecodeArrayBuilder& BytecodeArrayBuilder::Throw() { | 473 BytecodeArrayBuilder& BytecodeArrayBuilder::Throw() { |
479 Output(Bytecode::kThrow); | 474 Output(Bytecode::kThrow); |
480 return *this; | 475 return *this; |
481 } | 476 } |
482 | 477 |
483 BytecodeArrayBuilder& BytecodeArrayBuilder::ReThrow() { | 478 BytecodeArrayBuilder& BytecodeArrayBuilder::ReThrow() { |
484 Output(Bytecode::kReThrow); | 479 Output(Bytecode::kReThrow); |
485 return *this; | 480 return *this; |
486 } | 481 } |
487 | 482 |
(...skipping 466 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
954 return Bytecode::kTailCall; | 949 return Bytecode::kTailCall; |
955 default: | 950 default: |
956 UNREACHABLE(); | 951 UNREACHABLE(); |
957 } | 952 } |
958 return Bytecode::kIllegal; | 953 return Bytecode::kIllegal; |
959 } | 954 } |
960 | 955 |
961 } // namespace interpreter | 956 } // namespace interpreter |
962 } // namespace internal | 957 } // namespace internal |
963 } // namespace v8 | 958 } // namespace v8 |
OLD | NEW |