Chromium Code Reviews| 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 3569 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3580 if (FLAG_use_range) { | 3580 if (FLAG_use_range) { |
| 3581 HRangeAnalysis rangeAnalysis(this); | 3581 HRangeAnalysis rangeAnalysis(this); |
| 3582 rangeAnalysis.Analyze(); | 3582 rangeAnalysis.Analyze(); |
| 3583 } | 3583 } |
| 3584 ComputeMinusZeroChecks(); | 3584 ComputeMinusZeroChecks(); |
| 3585 | 3585 |
| 3586 // Eliminate redundant stack checks on backwards branches. | 3586 // Eliminate redundant stack checks on backwards branches. |
| 3587 HStackCheckEliminator sce(this); | 3587 HStackCheckEliminator sce(this); |
| 3588 sce.Process(); | 3588 sce.Process(); |
| 3589 | 3589 |
| 3590 if (FLAG_array_bounds_checks_elimination) EliminateRedundantBoundsChecks(); | 3590 if (FLAG_idefs) SetupInformativeDefinitions(); |
| 3591 if (FLAG_array_bounds_checks_elimination && !FLAG_idefs) | |
| 3592 EliminateRedundantBoundsChecks(); | |
|
Jakob Kummerow
2013/01/31 14:06:43
nit: {} please
Massi
2013/01/31 17:16:19
Done.
| |
| 3591 if (FLAG_array_index_dehoisting) DehoistSimpleArrayIndexComputations(); | 3593 if (FLAG_array_index_dehoisting) DehoistSimpleArrayIndexComputations(); |
| 3592 if (FLAG_dead_code_elimination) DeadCodeElimination(); | 3594 if (FLAG_dead_code_elimination) DeadCodeElimination(); |
| 3593 | 3595 |
| 3594 RestoreActualValues(); | 3596 RestoreActualValues(); |
| 3595 | 3597 |
| 3596 return true; | 3598 return true; |
| 3597 } | 3599 } |
| 3598 | 3600 |
| 3599 | 3601 |
| 3602 void HGraph::SetupInformativeDefinitionsInBlock(HBasicBlock* block) { | |
| 3603 for (int phi_index = 0; phi_index < block->phis()->length(); phi_index++) { | |
| 3604 HPhi* phi = block->phis()->at(phi_index); | |
| 3605 phi->AddInformativeDefinitions(); | |
| 3606 // We do not support phis that "redefine just one operand". | |
| 3607 ASSERT(!phi->IsInformativeDefinition()); | |
| 3608 } | |
| 3609 | |
| 3610 for (HInstruction* i = block->first(); i != NULL; i = i->next()) { | |
| 3611 i->AddInformativeDefinitions(); | |
| 3612 i->UpdateRedefinedUsesWhileSettingUpInformativeDefinitions(); | |
| 3613 } | |
| 3614 } | |
| 3615 | |
| 3616 | |
| 3617 // This method is recursive, so if its stack frame is large it could | |
| 3618 // cause a stack overflow. | |
| 3619 // To keep the individual stack frames small we do the actual work inside | |
| 3620 // SetupInformativeDefinitionsInBlock(); | |
| 3621 void HGraph::SetupInformativeDefinitionsRecursively(HBasicBlock* block) { | |
| 3622 SetupInformativeDefinitionsInBlock(block); | |
| 3623 for (int i = 0; i < block->dominated_blocks()->length(); ++i) { | |
| 3624 SetupInformativeDefinitionsRecursively(block->dominated_blocks()->at(i)); | |
| 3625 } | |
| 3626 } | |
| 3627 | |
| 3628 | |
| 3629 void HGraph::SetupInformativeDefinitions() { | |
| 3630 HPhase phase("H_Setup informative definitions", this); | |
| 3631 SetupInformativeDefinitionsRecursively(entry_block()); | |
| 3632 } | |
| 3633 | |
| 3634 | |
| 3600 // We try to "factor up" HBoundsCheck instructions towards the root of the | 3635 // We try to "factor up" HBoundsCheck instructions towards the root of the |
| 3601 // dominator tree. | 3636 // dominator tree. |
| 3602 // For now we handle checks where the index is like "exp + int32value". | 3637 // For now we handle checks where the index is like "exp + int32value". |
| 3603 // If in the dominator tree we check "exp + v1" and later (dominated) | 3638 // If in the dominator tree we check "exp + v1" and later (dominated) |
| 3604 // "exp + v2", if v2 <= v1 we can safely remove the second check, and if | 3639 // "exp + v2", if v2 <= v1 we can safely remove the second check, and if |
| 3605 // v2 > v1 we can use v2 in the 1st check and again remove the second. | 3640 // v2 > v1 we can use v2 in the 1st check and again remove the second. |
| 3606 // To do so we keep a dictionary of all checks where the key if the pair | 3641 // To do so we keep a dictionary of all checks where the key if the pair |
| 3607 // "exp, length". | 3642 // "exp, length". |
| 3608 // The class BoundsCheckKey represents this key. | 3643 // The class BoundsCheckKey represents this key. |
| 3609 class BoundsCheckKey : public ZoneObject { | 3644 class BoundsCheckKey : public ZoneObject { |
| (...skipping 6738 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 10348 } | 10383 } |
| 10349 } | 10384 } |
| 10350 | 10385 |
| 10351 #ifdef DEBUG | 10386 #ifdef DEBUG |
| 10352 if (graph_ != NULL) graph_->Verify(false); // No full verify. | 10387 if (graph_ != NULL) graph_->Verify(false); // No full verify. |
| 10353 if (allocator_ != NULL) allocator_->Verify(); | 10388 if (allocator_ != NULL) allocator_->Verify(); |
| 10354 #endif | 10389 #endif |
| 10355 } | 10390 } |
| 10356 | 10391 |
| 10357 } } // namespace v8::internal | 10392 } } // namespace v8::internal |
| OLD | NEW |