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 #include "src/hydrogen.h" | 5 #include "src/hydrogen.h" |
6 | 6 |
7 #include <sstream> | 7 #include <sstream> |
8 | 8 |
9 #include "src/v8.h" | 9 #include "src/v8.h" |
10 | 10 |
(...skipping 4494 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4505 DCHECK(!HasStackOverflow()); | 4505 DCHECK(!HasStackOverflow()); |
4506 DCHECK(current_block() != NULL); | 4506 DCHECK(current_block() != NULL); |
4507 DCHECK(current_block()->HasPredecessor()); | 4507 DCHECK(current_block()->HasPredecessor()); |
4508 | 4508 |
4509 Scope* outer_scope = scope(); | 4509 Scope* outer_scope = scope(); |
4510 Scope* scope = stmt->scope(); | 4510 Scope* scope = stmt->scope(); |
4511 BreakAndContinueInfo break_info(stmt, outer_scope); | 4511 BreakAndContinueInfo break_info(stmt, outer_scope); |
4512 | 4512 |
4513 { BreakAndContinueScope push(&break_info, this); | 4513 { BreakAndContinueScope push(&break_info, this); |
4514 if (scope != NULL) { | 4514 if (scope != NULL) { |
4515 // Load the function object. | 4515 if (scope->ContextLocalCount() > 0) { |
4516 Scope* declaration_scope = scope->DeclarationScope(); | 4516 // Load the function object. |
4517 HInstruction* function; | 4517 Scope* declaration_scope = scope->DeclarationScope(); |
4518 HValue* outer_context = environment()->context(); | 4518 HInstruction* function; |
4519 if (declaration_scope->is_script_scope() || | 4519 HValue* outer_context = environment()->context(); |
4520 declaration_scope->is_eval_scope()) { | 4520 if (declaration_scope->is_script_scope() || |
4521 function = new(zone()) HLoadContextSlot( | 4521 declaration_scope->is_eval_scope()) { |
4522 outer_context, Context::CLOSURE_INDEX, HLoadContextSlot::kNoCheck); | 4522 function = new (zone()) |
4523 } else { | 4523 HLoadContextSlot(outer_context, Context::CLOSURE_INDEX, |
4524 function = New<HThisFunction>(); | 4524 HLoadContextSlot::kNoCheck); |
4525 } | 4525 } else { |
4526 AddInstruction(function); | 4526 function = New<HThisFunction>(); |
4527 // Allocate a block context and store it to the stack frame. | 4527 } |
4528 HInstruction* inner_context = Add<HAllocateBlockContext>( | 4528 AddInstruction(function); |
4529 outer_context, function, scope->GetScopeInfo(isolate())); | 4529 // Allocate a block context and store it to the stack frame. |
4530 HInstruction* instr = Add<HStoreFrameContext>(inner_context); | 4530 HInstruction* inner_context = Add<HAllocateBlockContext>( |
4531 set_scope(scope); | 4531 outer_context, function, scope->GetScopeInfo(isolate())); |
4532 environment()->BindContext(inner_context); | 4532 HInstruction* instr = Add<HStoreFrameContext>(inner_context); |
4533 if (instr->HasObservableSideEffects()) { | 4533 set_scope(scope); |
4534 AddSimulate(stmt->EntryId(), REMOVABLE_SIMULATE); | 4534 environment()->BindContext(inner_context); |
| 4535 if (instr->HasObservableSideEffects()) { |
| 4536 AddSimulate(stmt->EntryId(), REMOVABLE_SIMULATE); |
| 4537 } |
4535 } | 4538 } |
4536 VisitDeclarations(scope->declarations()); | 4539 VisitDeclarations(scope->declarations()); |
4537 AddSimulate(stmt->DeclsId(), REMOVABLE_SIMULATE); | 4540 AddSimulate(stmt->DeclsId(), REMOVABLE_SIMULATE); |
4538 } | 4541 } |
4539 CHECK_BAILOUT(VisitStatements(stmt->statements())); | 4542 CHECK_BAILOUT(VisitStatements(stmt->statements())); |
4540 } | 4543 } |
4541 set_scope(outer_scope); | 4544 set_scope(outer_scope); |
4542 if (scope != NULL && current_block() != NULL) { | 4545 if (scope != NULL && current_block() != NULL && |
| 4546 scope->ContextLocalCount() > 0) { |
4543 HValue* inner_context = environment()->context(); | 4547 HValue* inner_context = environment()->context(); |
4544 HValue* outer_context = Add<HLoadNamedField>( | 4548 HValue* outer_context = Add<HLoadNamedField>( |
4545 inner_context, nullptr, | 4549 inner_context, nullptr, |
4546 HObjectAccess::ForContextSlot(Context::PREVIOUS_INDEX)); | 4550 HObjectAccess::ForContextSlot(Context::PREVIOUS_INDEX)); |
4547 | 4551 |
4548 HInstruction* instr = Add<HStoreFrameContext>(outer_context); | 4552 HInstruction* instr = Add<HStoreFrameContext>(outer_context); |
4549 environment()->BindContext(outer_context); | 4553 environment()->BindContext(outer_context); |
4550 if (instr->HasObservableSideEffects()) { | 4554 if (instr->HasObservableSideEffects()) { |
4551 AddSimulate(stmt->ExitId(), REMOVABLE_SIMULATE); | 4555 AddSimulate(stmt->ExitId(), REMOVABLE_SIMULATE); |
4552 } | 4556 } |
(...skipping 8470 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
13023 if (ShouldProduceTraceOutput()) { | 13027 if (ShouldProduceTraceOutput()) { |
13024 isolate()->GetHTracer()->TraceHydrogen(name(), graph_); | 13028 isolate()->GetHTracer()->TraceHydrogen(name(), graph_); |
13025 } | 13029 } |
13026 | 13030 |
13027 #ifdef DEBUG | 13031 #ifdef DEBUG |
13028 graph_->Verify(false); // No full verify. | 13032 graph_->Verify(false); // No full verify. |
13029 #endif | 13033 #endif |
13030 } | 13034 } |
13031 | 13035 |
13032 } } // namespace v8::internal | 13036 } } // namespace v8::internal |
OLD | NEW |