Index: src/x64/codegen-x64.cc |
=================================================================== |
--- src/x64/codegen-x64.cc (revision 4211) |
+++ src/x64/codegen-x64.cc (working copy) |
@@ -2238,8 +2238,7 @@ |
// Use the fast case closure allocation code that allocates in new |
// space for nested functions that don't need literals cloning. |
- if (false && scope()->is_function_scope() && |
- function_info->num_literals() == 0) { |
+ if (scope()->is_function_scope() && function_info->num_literals() == 0) { |
FastNewClosureStub stub; |
frame_->Push(function_info); |
Result answer = frame_->CallStub(&stub, 1); |
@@ -6361,12 +6360,12 @@ |
void FastNewClosureStub::Generate(MacroAssembler* masm) { |
- // Clone the boilerplate in new space. Set the context to the |
- // current context in rsi. |
+ // Create a new closure from the given function info in new |
+ // space. Set the context to the current context in rsi. |
Label gc; |
__ AllocateInNewSpace(JSFunction::kSize, rax, rbx, rcx, &gc, TAG_OBJECT); |
- // Get the boilerplate function from the stack. |
+ // Get the function info from the stack. |
__ movq(rdx, Operand(rsp, 1 * kPointerSize)); |
// Compute the function map in the current global context and set that |
@@ -6376,18 +6375,16 @@ |
__ movq(rcx, Operand(rcx, Context::SlotOffset(Context::FUNCTION_MAP_INDEX))); |
__ movq(FieldOperand(rax, JSObject::kMapOffset), rcx); |
- // Clone the rest of the boilerplate fields. We don't have to update |
- // the write barrier because the allocated object is in new space. |
- for (int offset = kPointerSize; |
- offset < JSFunction::kSize; |
- offset += kPointerSize) { |
- if (offset == JSFunction::kContextOffset) { |
- __ movq(FieldOperand(rax, offset), rsi); |
- } else { |
- __ movq(rbx, FieldOperand(rdx, offset)); |
- __ movq(FieldOperand(rax, offset), rbx); |
- } |
- } |
+ // Initialize the rest of the function. We don't have to update the |
+ // write barrier because the allocated object is in new space. |
+ __ LoadRoot(rbx, Heap::kEmptyFixedArrayRootIndex); |
+ __ LoadRoot(rcx, Heap::kTheHoleValueRootIndex); |
+ __ movq(FieldOperand(rax, JSObject::kPropertiesOffset), rbx); |
+ __ movq(FieldOperand(rax, JSObject::kElementsOffset), rbx); |
+ __ movq(FieldOperand(rax, JSFunction::kPrototypeOrInitialMapOffset), rcx); |
+ __ movq(FieldOperand(rax, JSFunction::kSharedFunctionInfoOffset), rdx); |
+ __ movq(FieldOperand(rax, JSFunction::kContextOffset), rsi); |
+ __ movq(FieldOperand(rax, JSFunction::kLiteralsOffset), rbx); |
// Return and remove the on-stack parameter. |
__ ret(1 * kPointerSize); |