|
4 | 4 |
|
5 | 5 | #include "src/hydrogen.h" |
6 | 6 | #include "src/hydrogen-gvn.h" |
| 7 | +#include "src/list.h" |
| 8 | +#include "src/list-inl.h" |
7 | 9 | #include "src/v8.h" |
8 | 10 |
|
9 | 11 | namespace v8 { |
@@ -654,19 +656,23 @@ SideEffects |
654 | 656 | HGlobalValueNumberingPhase::CollectSideEffectsOnPathsToDominatedBlock( |
655 | 657 | HBasicBlock* dominator, HBasicBlock* dominated) { |
656 | 658 | SideEffects side_effects; |
657 | | - for (int i = 0; i < dominated->predecessors()->length(); ++i) { |
658 | | - HBasicBlock* block = dominated->predecessors()->at(i); |
659 | | - if (dominator->block_id() < block->block_id() && |
660 | | - block->block_id() < dominated->block_id() && |
661 | | - !visited_on_paths_.Contains(block->block_id())) { |
662 | | - visited_on_paths_.Add(block->block_id()); |
663 | | - side_effects.Add(block_side_effects_[block->block_id()]); |
664 | | - if (block->IsLoopHeader()) { |
665 | | - side_effects.Add(loop_side_effects_[block->block_id()]); |
| 659 | + List<HBasicBlock*> blocks; |
| 660 | + for (;;) { |
| 661 | + for (int i = 0; i < dominated->predecessors()->length(); ++i) { |
| 662 | + HBasicBlock* block = dominated->predecessors()->at(i); |
| 663 | + if (dominator->block_id() < block->block_id() && |
| 664 | + block->block_id() < dominated->block_id() && |
| 665 | + !visited_on_paths_.Contains(block->block_id())) { |
| 666 | + visited_on_paths_.Add(block->block_id()); |
| 667 | + side_effects.Add(block_side_effects_[block->block_id()]); |
| 668 | + if (block->IsLoopHeader()) { |
| 669 | + side_effects.Add(loop_side_effects_[block->block_id()]); |
| 670 | + } |
| 671 | + blocks.Add(block); |
666 | 672 | } |
667 | | - side_effects.Add(CollectSideEffectsOnPathsToDominatedBlock( |
668 | | - dominator, block)); |
669 | 673 | } |
| 674 | + if (blocks.is_empty()) break; |
| 675 | + dominated = blocks.RemoveLast(); |
670 | 676 | } |
671 | 677 | return side_effects; |
672 | 678 | } |
|
0 commit comments