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/interpreter-assembler.h" | 5 #include "src/interpreter/interpreter-assembler.h" |
6 | 6 |
7 #include <ostream> | 7 #include <ostream> |
8 | 8 |
9 #include "src/code-factory.h" | 9 #include "src/code-factory.h" |
10 #include "src/frames.h" | 10 #include "src/frames.h" |
(...skipping 25 matching lines...) Expand all Loading... |
36 disable_stack_check_across_call_(false), | 36 disable_stack_check_across_call_(false), |
37 stack_pointer_before_call_(nullptr) { | 37 stack_pointer_before_call_(nullptr) { |
38 accumulator_.Bind( | 38 accumulator_.Bind( |
39 Parameter(InterpreterDispatchDescriptor::kAccumulatorParameter)); | 39 Parameter(InterpreterDispatchDescriptor::kAccumulatorParameter)); |
40 context_.Bind(Parameter(InterpreterDispatchDescriptor::kContextParameter)); | 40 context_.Bind(Parameter(InterpreterDispatchDescriptor::kContextParameter)); |
41 bytecode_array_.Bind( | 41 bytecode_array_.Bind( |
42 Parameter(InterpreterDispatchDescriptor::kBytecodeArrayParameter)); | 42 Parameter(InterpreterDispatchDescriptor::kBytecodeArrayParameter)); |
43 if (FLAG_trace_ignition) { | 43 if (FLAG_trace_ignition) { |
44 TraceBytecode(Runtime::kInterpreterTraceBytecodeEntry); | 44 TraceBytecode(Runtime::kInterpreterTraceBytecodeEntry); |
45 } | 45 } |
| 46 if (FLAG_ignition_count_handler_dispatches) { |
| 47 IncrementDispatchCounter(); |
| 48 } |
46 } | 49 } |
47 | 50 |
48 InterpreterAssembler::~InterpreterAssembler() {} | 51 InterpreterAssembler::~InterpreterAssembler() {} |
49 | 52 |
50 Node* InterpreterAssembler::GetAccumulator() { return accumulator_.value(); } | 53 Node* InterpreterAssembler::GetAccumulator() { return accumulator_.value(); } |
51 | 54 |
52 void InterpreterAssembler::SetAccumulator(Node* value) { | 55 void InterpreterAssembler::SetAccumulator(Node* value) { |
53 accumulator_.Bind(value); | 56 accumulator_.Bind(value); |
54 } | 57 } |
55 | 58 |
(...skipping 547 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
603 Node* profiling_weight = | 606 Node* profiling_weight = |
604 Int32Sub(Int32Constant(kHeapObjectTag + BytecodeArray::kHeaderSize), | 607 Int32Sub(Int32Constant(kHeapObjectTag + BytecodeArray::kHeaderSize), |
605 BytecodeOffset()); | 608 BytecodeOffset()); |
606 UpdateInterruptBudget(profiling_weight); | 609 UpdateInterruptBudget(profiling_weight); |
607 | 610 |
608 Node* exit_trampoline_code_object = | 611 Node* exit_trampoline_code_object = |
609 HeapConstant(isolate()->builtins()->InterpreterExitTrampoline()); | 612 HeapConstant(isolate()->builtins()->InterpreterExitTrampoline()); |
610 DispatchToBytecodeHandler(exit_trampoline_code_object); | 613 DispatchToBytecodeHandler(exit_trampoline_code_object); |
611 } | 614 } |
612 | 615 |
| 616 void InterpreterAssembler::IncrementDispatchCounter() { |
| 617 Node* counters = ExternalConstant( |
| 618 ExternalReference::interpreter_handlers_dispatch_counters(isolate())); |
| 619 Node* counter_offset = |
| 620 IntPtrConstant(static_cast<int>(bytecode_) * sizeof(uint32_t)); |
| 621 Node* old_counter = Load(MachineType::Uint32(), counters, counter_offset); |
| 622 Node* new_counter = Int32Add(old_counter, Int32Constant(1)); |
| 623 |
| 624 if (FLAG_debug_code) { // overflow checking on counters |
| 625 CodeStubAssembler::Label after_overflow_detection(this); |
| 626 CodeStubAssembler::Label overflow_detected(this); |
| 627 CodeStubAssembler::Label end(this); |
| 628 |
| 629 Node* new_counter_is_zero = Word32Equal(new_counter, Int32Constant(0)); |
| 630 Branch(new_counter_is_zero, &overflow_detected, &after_overflow_detection); |
| 631 Bind(&overflow_detected); |
| 632 Abort(BailoutReason::kInterpreterHandlersDispatchCounterOverflow); |
| 633 Goto(&end); |
| 634 Bind(&after_overflow_detection); |
| 635 Goto(&end); |
| 636 Bind(&end); |
| 637 } |
| 638 |
| 639 StoreNoWriteBarrier(MachineRepresentation::kWord32, counters, counter_offset, |
| 640 new_counter); |
| 641 } |
| 642 |
613 void InterpreterAssembler::StackCheck() { | 643 void InterpreterAssembler::StackCheck() { |
614 CodeStubAssembler::Label end(this); | 644 CodeStubAssembler::Label end(this); |
615 CodeStubAssembler::Label ok(this); | 645 CodeStubAssembler::Label ok(this); |
616 CodeStubAssembler::Label stack_guard(this); | 646 CodeStubAssembler::Label stack_guard(this); |
617 | 647 |
618 Node* sp = LoadStackPointer(); | 648 Node* sp = LoadStackPointer(); |
619 Node* stack_limit = Load( | 649 Node* stack_limit = Load( |
620 MachineType::Pointer(), | 650 MachineType::Pointer(), |
621 ExternalConstant(ExternalReference::address_of_stack_limit(isolate()))); | 651 ExternalConstant(ExternalReference::address_of_stack_limit(isolate()))); |
622 Node* condition = UintPtrGreaterThanOrEqual(sp, stack_limit); | 652 Node* condition = UintPtrGreaterThanOrEqual(sp, stack_limit); |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
667 V8_TARGET_ARCH_S390 | 697 V8_TARGET_ARCH_S390 |
668 return true; | 698 return true; |
669 #else | 699 #else |
670 #error "Unknown Architecture" | 700 #error "Unknown Architecture" |
671 #endif | 701 #endif |
672 } | 702 } |
673 | 703 |
674 } // namespace interpreter | 704 } // namespace interpreter |
675 } // namespace internal | 705 } // namespace internal |
676 } // namespace v8 | 706 } // namespace v8 |
OLD | NEW |