| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 #include "vm/intermediate_language.h" | 5 #include "vm/intermediate_language.h" |
| 6 | 6 |
| 7 #include "vm/bit_vector.h" | 7 #include "vm/bit_vector.h" |
| 8 #include "vm/constant_propagator.h" | 8 #include "vm/constant_propagator.h" |
| 9 #include "vm/cpu.h" | 9 #include "vm/cpu.h" |
| 10 #include "vm/dart_entry.h" | 10 #include "vm/dart_entry.h" |
| (...skipping 956 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 967 | 967 |
| 968 // 5. Iterate straight-line successors to record assigned variables and | 968 // 5. Iterate straight-line successors to record assigned variables and |
| 969 // find the last instruction in the block. The graph entry block consists | 969 // find the last instruction in the block. The graph entry block consists |
| 970 // of only the entry instruction, so that is the last instruction in the | 970 // of only the entry instruction, so that is the last instruction in the |
| 971 // block. | 971 // block. |
| 972 Instruction* last = this; | 972 Instruction* last = this; |
| 973 for (ForwardInstructionIterator it(this); !it.Done(); it.Advance()) { | 973 for (ForwardInstructionIterator it(this); !it.Done(); it.Advance()) { |
| 974 last = it.Current(); | 974 last = it.Current(); |
| 975 } | 975 } |
| 976 set_last_instruction(last); | 976 set_last_instruction(last); |
| 977 if (last->IsGoto()) last->AsGoto()->set_block(this); |
| 977 | 978 |
| 978 return true; | 979 return true; |
| 979 } | 980 } |
| 980 | 981 |
| 981 | 982 |
| 982 bool BlockEntryInstr::PruneUnreachable(FlowGraphBuilder* builder, | 983 bool BlockEntryInstr::PruneUnreachable(FlowGraphBuilder* builder, |
| 983 GraphEntryInstr* graph_entry, | 984 GraphEntryInstr* graph_entry, |
| 984 Instruction* parent, | 985 Instruction* parent, |
| 985 intptr_t osr_id, | 986 intptr_t osr_id, |
| 986 BitVector* block_marks) { | 987 BitVector* block_marks) { |
| (...skipping 1731 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2718 bool optimizing) const { | 2719 bool optimizing) const { |
| 2719 UNREACHABLE(); | 2720 UNREACHABLE(); |
| 2720 return NULL; | 2721 return NULL; |
| 2721 } | 2722 } |
| 2722 | 2723 |
| 2723 | 2724 |
| 2724 void TargetEntryInstr::EmitNativeCode(FlowGraphCompiler* compiler) { | 2725 void TargetEntryInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 2725 __ Bind(compiler->GetJumpLabel(this)); | 2726 __ Bind(compiler->GetJumpLabel(this)); |
| 2726 if (!compiler->is_optimizing()) { | 2727 if (!compiler->is_optimizing()) { |
| 2727 if (compiler->NeedsEdgeCounter(this)) { | 2728 if (compiler->NeedsEdgeCounter(this)) { |
| 2728 compiler->EmitEdgeCounter(); | 2729 compiler->EmitEdgeCounter(preorder_number()); |
| 2729 } | 2730 } |
| 2730 // The deoptimization descriptor points after the edge counter code for | 2731 // The deoptimization descriptor points after the edge counter code for |
| 2731 // uniformity with ARM and MIPS, where we can reuse pattern matching | 2732 // uniformity with ARM and MIPS, where we can reuse pattern matching |
| 2732 // code that matches backwards from the end of the pattern. | 2733 // code that matches backwards from the end of the pattern. |
| 2733 compiler->AddCurrentDescriptor(RawPcDescriptors::kDeopt, | 2734 compiler->AddCurrentDescriptor(RawPcDescriptors::kDeopt, |
| 2734 GetDeoptId(), | 2735 GetDeoptId(), |
| 2735 Scanner::kNoSourcePos); | 2736 Scanner::kNoSourcePos); |
| 2736 } | 2737 } |
| 2737 if (HasParallelMove()) { | 2738 if (HasParallelMove()) { |
| 2738 compiler->parallel_move_resolver()->EmitNativeCode(parallel_move()); | 2739 compiler->parallel_move_resolver()->EmitNativeCode(parallel_move()); |
| (...skipping 905 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3644 case Token::kTRUNCDIV: return 0; | 3645 case Token::kTRUNCDIV: return 0; |
| 3645 case Token::kMOD: return 1; | 3646 case Token::kMOD: return 1; |
| 3646 default: UNIMPLEMENTED(); return -1; | 3647 default: UNIMPLEMENTED(); return -1; |
| 3647 } | 3648 } |
| 3648 } | 3649 } |
| 3649 | 3650 |
| 3650 | 3651 |
| 3651 #undef __ | 3652 #undef __ |
| 3652 | 3653 |
| 3653 } // namespace dart | 3654 } // namespace dart |
| OLD | NEW |