From: kmillikin@chromium.org Date: Fri, 12 Feb 2010 10:28:40 +0000 (+0000) Subject: Change the interface of CodeGenerator::InstantiateBoilerplate. X-Git-Tag: upstream/4.7.83~22500 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=85c24cee578543bf3c8e4b866923cf1f04311724;p=platform%2Fupstream%2Fv8.git Change the interface of CodeGenerator::InstantiateBoilerplate. Begin changing the interface of the virtual-frame-based code generator to avoid pushing short-lived temporaries on the frame. Review URL: http://codereview.chromium.org/600097 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@3840 ce2b1a6d-e550-0410-aec6-3dcde31c8c00 --- diff --git a/src/ia32/codegen-ia32.cc b/src/ia32/codegen-ia32.cc index 62e01f1..ee17510 100644 --- a/src/ia32/codegen-ia32.cc +++ b/src/ia32/codegen-ia32.cc @@ -3912,28 +3912,26 @@ void CodeGenerator::VisitDebuggerStatement(DebuggerStatement* node) { } -void CodeGenerator::InstantiateBoilerplate(Handle boilerplate) { +Result CodeGenerator::InstantiateBoilerplate(Handle boilerplate) { ASSERT(boilerplate->IsBoilerplate()); // The inevitable call will sync frame elements to memory anyway, so // we do it eagerly to allow us to push the arguments directly into // place. - frame_->SyncRange(0, frame_->element_count() - 1); + frame()->SyncRange(0, frame()->element_count() - 1); // Use the fast case closure allocation code that allocates in new // space for nested functions that don't need literals cloning. if (scope()->is_function_scope() && boilerplate->NumberOfLiterals() == 0) { FastNewClosureStub stub; - frame_->EmitPush(Immediate(boilerplate)); - Result answer = frame_->CallStub(&stub, 1); - frame_->Push(&answer); + frame()->EmitPush(Immediate(boilerplate)); + return frame()->CallStub(&stub, 1); } else { // Call the runtime to instantiate the function boilerplate // object. - frame_->EmitPush(esi); - frame_->EmitPush(Immediate(boilerplate)); - Result result = frame_->CallRuntime(Runtime::kNewClosure, 2); - frame_->Push(&result); + frame()->EmitPush(esi); + frame()->EmitPush(Immediate(boilerplate)); + return frame()->CallRuntime(Runtime::kNewClosure, 2); } } @@ -3946,14 +3944,16 @@ void CodeGenerator::VisitFunctionLiteral(FunctionLiteral* node) { Compiler::BuildBoilerplate(node, script(), this); // Check for stack-overflow exception. if (HasStackOverflow()) return; - InstantiateBoilerplate(boilerplate); + Result result = InstantiateBoilerplate(boilerplate); + frame()->Push(&result); } void CodeGenerator::VisitFunctionBoilerplateLiteral( FunctionBoilerplateLiteral* node) { Comment cmnt(masm_, "[ FunctionBoilerplateLiteral"); - InstantiateBoilerplate(node->boilerplate()); + Result result = InstantiateBoilerplate(node->boilerplate()); + frame()->Push(&result); } diff --git a/src/ia32/codegen-ia32.h b/src/ia32/codegen-ia32.h index 843bbf7..17e73e0 100644 --- a/src/ia32/codegen-ia32.h +++ b/src/ia32/codegen-ia32.h @@ -533,7 +533,7 @@ class CodeGenerator: public AstVisitor { void DeclareGlobals(Handle pairs); // Instantiate the function boilerplate. - void InstantiateBoilerplate(Handle boilerplate); + Result InstantiateBoilerplate(Handle boilerplate); // Support for type checks. void GenerateIsSmi(ZoneList* args);