OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 152 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
163 // LeaveInlined | 163 // LeaveInlined |
164 // Simulate (caller's environment) | 164 // Simulate (caller's environment) |
165 // Goto (target block) | 165 // Goto (target block) |
166 bool IsInlineReturnTarget() const { return is_inline_return_target_; } | 166 bool IsInlineReturnTarget() const { return is_inline_return_target_; } |
167 void MarkAsInlineReturnTarget(HBasicBlock* inlined_entry_block) { | 167 void MarkAsInlineReturnTarget(HBasicBlock* inlined_entry_block) { |
168 is_inline_return_target_ = true; | 168 is_inline_return_target_ = true; |
169 inlined_entry_block_ = inlined_entry_block; | 169 inlined_entry_block_ = inlined_entry_block; |
170 } | 170 } |
171 HBasicBlock* inlined_entry_block() { return inlined_entry_block_; } | 171 HBasicBlock* inlined_entry_block() { return inlined_entry_block_; } |
172 | 172 |
173 bool IsDeoptimizing() const { return is_deoptimizing_; } | 173 bool IsDeoptimizing() const { |
174 void MarkAsDeoptimizing() { is_deoptimizing_ = true; } | 174 return end() != NULL && end()->IsDeoptimize(); |
| 175 } |
| 176 |
| 177 void MarkUnreachable(); |
| 178 bool IsUnreachable() const { return !is_reachable_; } |
| 179 bool IsReachable() const { return is_reachable_; } |
175 | 180 |
176 bool IsLoopSuccessorDominator() const { | 181 bool IsLoopSuccessorDominator() const { |
177 return dominates_loop_successors_; | 182 return dominates_loop_successors_; |
178 } | 183 } |
179 void MarkAsLoopSuccessorDominator() { | 184 void MarkAsLoopSuccessorDominator() { |
180 dominates_loop_successors_ = true; | 185 dominates_loop_successors_ = true; |
181 } | 186 } |
182 | 187 |
183 inline Zone* zone() const; | 188 inline Zone* zone() const; |
184 | 189 |
(...skipping 23 matching lines...) Expand all Loading... |
208 // Outgoing parameter count at block exit, set during lithium translation. | 213 // Outgoing parameter count at block exit, set during lithium translation. |
209 int argument_count_; | 214 int argument_count_; |
210 // Instruction indices into the lithium code stream. | 215 // Instruction indices into the lithium code stream. |
211 int first_instruction_index_; | 216 int first_instruction_index_; |
212 int last_instruction_index_; | 217 int last_instruction_index_; |
213 ZoneList<int> deleted_phis_; | 218 ZoneList<int> deleted_phis_; |
214 HBasicBlock* parent_loop_header_; | 219 HBasicBlock* parent_loop_header_; |
215 // For blocks marked as inline return target: the block with HEnterInlined. | 220 // For blocks marked as inline return target: the block with HEnterInlined. |
216 HBasicBlock* inlined_entry_block_; | 221 HBasicBlock* inlined_entry_block_; |
217 bool is_inline_return_target_ : 1; | 222 bool is_inline_return_target_ : 1; |
218 bool is_deoptimizing_ : 1; | 223 bool is_reachable_ : 1; |
219 bool dominates_loop_successors_ : 1; | 224 bool dominates_loop_successors_ : 1; |
220 bool is_osr_entry_ : 1; | 225 bool is_osr_entry_ : 1; |
221 }; | 226 }; |
222 | 227 |
223 | 228 |
224 class HPredecessorIterator V8_FINAL BASE_EMBEDDED { | 229 class HPredecessorIterator V8_FINAL BASE_EMBEDDED { |
225 public: | 230 public: |
226 explicit HPredecessorIterator(HBasicBlock* block) | 231 explicit HPredecessorIterator(HBasicBlock* block) |
227 : predecessor_list_(block->predecessors()), current_(0) { } | 232 : predecessor_list_(block->predecessors()), current_(0) { } |
228 | 233 |
(...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
399 int maximum_environment_size() { return maximum_environment_size_; } | 404 int maximum_environment_size() { return maximum_environment_size_; } |
400 | 405 |
401 bool use_optimistic_licm() { | 406 bool use_optimistic_licm() { |
402 return use_optimistic_licm_; | 407 return use_optimistic_licm_; |
403 } | 408 } |
404 | 409 |
405 void set_use_optimistic_licm(bool value) { | 410 void set_use_optimistic_licm(bool value) { |
406 use_optimistic_licm_ = value; | 411 use_optimistic_licm_ = value; |
407 } | 412 } |
408 | 413 |
409 bool has_soft_deoptimize() { | |
410 return has_soft_deoptimize_; | |
411 } | |
412 | |
413 void set_has_soft_deoptimize(bool value) { | |
414 has_soft_deoptimize_ = value; | |
415 } | |
416 | |
417 void MarkRecursive() { | 414 void MarkRecursive() { |
418 is_recursive_ = true; | 415 is_recursive_ = true; |
419 } | 416 } |
420 | 417 |
421 bool is_recursive() const { | 418 bool is_recursive() const { |
422 return is_recursive_; | 419 return is_recursive_; |
423 } | 420 } |
424 | 421 |
425 void MarkDependsOnEmptyArrayProtoElements() { | 422 void MarkDependsOnEmptyArrayProtoElements() { |
426 // Add map dependency if not already added. | 423 // Add map dependency if not already added. |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
489 SetOncePointer<HConstant> constant_invalid_context_; | 486 SetOncePointer<HConstant> constant_invalid_context_; |
490 SetOncePointer<HArgumentsObject> arguments_object_; | 487 SetOncePointer<HArgumentsObject> arguments_object_; |
491 | 488 |
492 HOsrBuilder* osr_; | 489 HOsrBuilder* osr_; |
493 | 490 |
494 CompilationInfo* info_; | 491 CompilationInfo* info_; |
495 Zone* zone_; | 492 Zone* zone_; |
496 | 493 |
497 bool is_recursive_; | 494 bool is_recursive_; |
498 bool use_optimistic_licm_; | 495 bool use_optimistic_licm_; |
499 bool has_soft_deoptimize_; | |
500 bool depends_on_empty_array_proto_elements_; | 496 bool depends_on_empty_array_proto_elements_; |
501 int type_change_checksum_; | 497 int type_change_checksum_; |
502 int maximum_environment_size_; | 498 int maximum_environment_size_; |
503 int no_side_effects_scope_count_; | 499 int no_side_effects_scope_count_; |
504 | 500 |
505 DISALLOW_COPY_AND_ASSIGN(HGraph); | 501 DISALLOW_COPY_AND_ASSIGN(HGraph); |
506 }; | 502 }; |
507 | 503 |
508 | 504 |
509 Zone* HBasicBlock::zone() const { return graph_->zone(); } | 505 Zone* HBasicBlock::zone() const { return graph_->zone(); } |
(...skipping 1140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1650 | 1646 |
1651 | 1647 |
1652 template<> | 1648 template<> |
1653 inline HInstruction* HGraphBuilder::AddUncasted<HDeoptimize>( | 1649 inline HInstruction* HGraphBuilder::AddUncasted<HDeoptimize>( |
1654 const char* reason, Deoptimizer::BailoutType type) { | 1650 const char* reason, Deoptimizer::BailoutType type) { |
1655 if (type == Deoptimizer::SOFT) { | 1651 if (type == Deoptimizer::SOFT) { |
1656 isolate()->counters()->soft_deopts_requested()->Increment(); | 1652 isolate()->counters()->soft_deopts_requested()->Increment(); |
1657 if (FLAG_always_opt) return NULL; | 1653 if (FLAG_always_opt) return NULL; |
1658 } | 1654 } |
1659 if (current_block()->IsDeoptimizing()) return NULL; | 1655 if (current_block()->IsDeoptimizing()) return NULL; |
1660 HDeoptimize* instr = New<HDeoptimize>(reason, type); | 1656 HBasicBlock* after_deopt_block = CreateBasicBlock( |
1661 AddInstruction(instr); | 1657 current_block()->last_environment()); |
| 1658 HDeoptimize* instr = New<HDeoptimize>(reason, type, after_deopt_block); |
1662 if (type == Deoptimizer::SOFT) { | 1659 if (type == Deoptimizer::SOFT) { |
1663 isolate()->counters()->soft_deopts_inserted()->Increment(); | 1660 isolate()->counters()->soft_deopts_inserted()->Increment(); |
1664 graph()->set_has_soft_deoptimize(true); | |
1665 } | 1661 } |
1666 current_block()->MarkAsDeoptimizing(); | 1662 current_block()->Finish(instr); |
| 1663 set_current_block(after_deopt_block); |
1667 return instr; | 1664 return instr; |
1668 } | 1665 } |
1669 | 1666 |
1670 | 1667 |
1671 template<> | 1668 template<> |
1672 inline HDeoptimize* HGraphBuilder::Add<HDeoptimize>( | 1669 inline HDeoptimize* HGraphBuilder::Add<HDeoptimize>( |
1673 const char* reason, Deoptimizer::BailoutType type) { | 1670 const char* reason, Deoptimizer::BailoutType type) { |
1674 return static_cast<HDeoptimize*>(AddUncasted<HDeoptimize>(reason, type)); | 1671 return static_cast<HDeoptimize*>(AddUncasted<HDeoptimize>(reason, type)); |
1675 } | 1672 } |
1676 | 1673 |
(...skipping 799 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2476 } | 2473 } |
2477 | 2474 |
2478 private: | 2475 private: |
2479 HGraphBuilder* builder_; | 2476 HGraphBuilder* builder_; |
2480 }; | 2477 }; |
2481 | 2478 |
2482 | 2479 |
2483 } } // namespace v8::internal | 2480 } } // namespace v8::internal |
2484 | 2481 |
2485 #endif // V8_HYDROGEN_H_ | 2482 #endif // V8_HYDROGEN_H_ |
OLD | NEW |