OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 | 5 |
6 #include "src/crankshaft/hydrogen-environment-liveness.h" | 6 #include "src/crankshaft/hydrogen-environment-liveness.h" |
7 | 7 |
8 | 8 |
9 namespace v8 { | 9 namespace v8 { |
10 namespace internal { | 10 namespace internal { |
(...skipping 19 matching lines...) Expand all Loading... |
30 first_simulate_invalid_for_index_.Add( | 30 first_simulate_invalid_for_index_.Add( |
31 new(zone()) BitVector(maximum_environment_size_, zone()), zone()); | 31 new(zone()) BitVector(maximum_environment_size_, zone()), zone()); |
32 } | 32 } |
33 } | 33 } |
34 | 34 |
35 | 35 |
36 void HEnvironmentLivenessAnalysisPhase::ZapEnvironmentSlot( | 36 void HEnvironmentLivenessAnalysisPhase::ZapEnvironmentSlot( |
37 int index, HSimulate* simulate) { | 37 int index, HSimulate* simulate) { |
38 int operand_index = simulate->ToOperandIndex(index); | 38 int operand_index = simulate->ToOperandIndex(index); |
39 if (operand_index == -1) { | 39 if (operand_index == -1) { |
40 simulate->AddAssignedValue(index, graph()->GetConstantUndefined()); | 40 simulate->AddAssignedValue(index, graph()->GetConstantOptimizedOut()); |
41 } else { | 41 } else { |
42 simulate->SetOperandAt(operand_index, graph()->GetConstantUndefined()); | 42 simulate->SetOperandAt(operand_index, graph()->GetConstantOptimizedOut()); |
43 } | 43 } |
44 } | 44 } |
45 | 45 |
46 | 46 |
47 void HEnvironmentLivenessAnalysisPhase::ZapEnvironmentSlotsInSuccessors( | 47 void HEnvironmentLivenessAnalysisPhase::ZapEnvironmentSlotsInSuccessors( |
48 HBasicBlock* block, BitVector* live) { | 48 HBasicBlock* block, BitVector* live) { |
49 // When a value is live in successor A but dead in B, we must | 49 // When a value is live in successor A but dead in B, we must |
50 // explicitly zap it in B. | 50 // explicitly zap it in B. |
51 for (HSuccessorIterator it(block->end()); !it.Done(); it.Advance()) { | 51 for (HSuccessorIterator it(block->end()); !it.Done(); it.Advance()) { |
52 HBasicBlock* successor = it.Current(); | 52 HBasicBlock* successor = it.Current(); |
(...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
223 bool HEnvironmentLivenessAnalysisPhase::VerifyClosures( | 223 bool HEnvironmentLivenessAnalysisPhase::VerifyClosures( |
224 Handle<JSFunction> a, Handle<JSFunction> b) { | 224 Handle<JSFunction> a, Handle<JSFunction> b) { |
225 Heap::RelocationLock for_heap_access(isolate()->heap()); | 225 Heap::RelocationLock for_heap_access(isolate()->heap()); |
226 AllowHandleDereference for_verification; | 226 AllowHandleDereference for_verification; |
227 return a.is_identical_to(b); | 227 return a.is_identical_to(b); |
228 } | 228 } |
229 #endif | 229 #endif |
230 | 230 |
231 } // namespace internal | 231 } // namespace internal |
232 } // namespace v8 | 232 } // namespace v8 |
OLD | NEW |