| 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 | 
|---|