| Index: src/ia32/code-stubs-ia32.cc
|
| diff --git a/src/ia32/code-stubs-ia32.cc b/src/ia32/code-stubs-ia32.cc
|
| index e2273f56c232b6f57f8365d411c9b0db365851ad..8ff592714f55cc8b8f35cb67e0ecba39c971d9a9 100644
|
| --- a/src/ia32/code-stubs-ia32.cc
|
| +++ b/src/ia32/code-stubs-ia32.cc
|
| @@ -22,52 +22,18 @@
|
| namespace v8 {
|
| namespace internal {
|
|
|
| +#define __ ACCESS_MASM(masm)
|
|
|
| -static void InitializeArrayConstructorDescriptor(
|
| - Isolate* isolate, CodeStubDescriptor* descriptor,
|
| - int constant_stack_parameter_count) {
|
| - // register state
|
| - // eax -- number of arguments
|
| - // edi -- function
|
| - // ebx -- allocation site with elements kind
|
| - Address deopt_handler = Runtime::FunctionForId(
|
| - Runtime::kArrayConstructor)->entry;
|
| -
|
| - if (constant_stack_parameter_count == 0) {
|
| - descriptor->Initialize(deopt_handler, constant_stack_parameter_count,
|
| - JS_FUNCTION_STUB_MODE);
|
| - } else {
|
| - descriptor->Initialize(eax, deopt_handler, constant_stack_parameter_count,
|
| - JS_FUNCTION_STUB_MODE);
|
| - }
|
| -}
|
| -
|
| -
|
| -static void InitializeInternalArrayConstructorDescriptor(
|
| - Isolate* isolate, CodeStubDescriptor* descriptor,
|
| - int constant_stack_parameter_count) {
|
| - // register state
|
| - // eax -- number of arguments
|
| - // edi -- constructor function
|
| - Address deopt_handler = Runtime::FunctionForId(
|
| - Runtime::kInternalArrayConstructor)->entry;
|
| -
|
| - if (constant_stack_parameter_count == 0) {
|
| - descriptor->Initialize(deopt_handler, constant_stack_parameter_count,
|
| - JS_FUNCTION_STUB_MODE);
|
| - } else {
|
| - descriptor->Initialize(eax, deopt_handler, constant_stack_parameter_count,
|
| - JS_FUNCTION_STUB_MODE);
|
| - }
|
| -}
|
| -
|
| -
|
| -void ArrayNArgumentsConstructorStub::InitializeDescriptor(
|
| - CodeStubDescriptor* descriptor) {
|
| - InitializeArrayConstructorDescriptor(isolate(), descriptor, -1);
|
| +void ArrayNArgumentsConstructorStub::Generate(MacroAssembler* masm) {
|
| + __ pop(ecx);
|
| + __ mov(MemOperand(esp, eax, times_4, 0), edi);
|
| + __ push(edi);
|
| + __ push(ebx);
|
| + __ push(ecx);
|
| + __ add(eax, Immediate(3));
|
| + __ TailCallRuntime(Runtime::kArrayConstructor);
|
| }
|
|
|
| -
|
| void FastArrayPushStub::InitializeDescriptor(CodeStubDescriptor* descriptor) {
|
| Address deopt_handler = Runtime::FunctionForId(Runtime::kArrayPush)->entry;
|
| descriptor->Initialize(eax, deopt_handler, -1, JS_FUNCTION_STUB_MODE);
|
| @@ -79,15 +45,6 @@ void FastFunctionBindStub::InitializeDescriptor(
|
| descriptor->Initialize(eax, deopt_handler, -1, JS_FUNCTION_STUB_MODE);
|
| }
|
|
|
| -void InternalArrayNArgumentsConstructorStub::InitializeDescriptor(
|
| - CodeStubDescriptor* descriptor) {
|
| - InitializeInternalArrayConstructorDescriptor(isolate(), descriptor, -1);
|
| -}
|
| -
|
| -
|
| -#define __ ACCESS_MASM(masm)
|
| -
|
| -
|
| void HydrogenCodeStub::GenerateLightweightMiss(MacroAssembler* masm,
|
| ExternalReference miss) {
|
| // Update the static counter each time a new code stub is generated.
|
| @@ -1782,7 +1739,7 @@ void CodeStub::GenerateStubsAheadOfTime(Isolate* isolate) {
|
| StoreBufferOverflowStub::GenerateFixedRegStubsAheadOfTime(isolate);
|
| StubFailureTrampolineStub::GenerateAheadOfTime(isolate);
|
| // It is important that the store buffer overflow stubs are generated first.
|
| - ArrayConstructorStubBase::GenerateStubsAheadOfTime(isolate);
|
| + CommonArrayConstructorStub::GenerateStubsAheadOfTime(isolate);
|
| CreateAllocationSiteStub::GenerateAheadOfTime(isolate);
|
| CreateWeakCellStub::GenerateAheadOfTime(isolate);
|
| BinaryOpICStub::GenerateAheadOfTime(isolate);
|
| @@ -4312,19 +4269,14 @@ static void ArrayConstructorStubAheadOfTimeHelper(Isolate* isolate) {
|
| }
|
| }
|
|
|
| -
|
| -void ArrayConstructorStubBase::GenerateStubsAheadOfTime(Isolate* isolate) {
|
| +void CommonArrayConstructorStub::GenerateStubsAheadOfTime(Isolate* isolate) {
|
| ArrayConstructorStubAheadOfTimeHelper<ArrayNoArgumentConstructorStub>(
|
| isolate);
|
| ArrayConstructorStubAheadOfTimeHelper<ArraySingleArgumentConstructorStub>(
|
| isolate);
|
| - ArrayConstructorStubAheadOfTimeHelper<ArrayNArgumentsConstructorStub>(
|
| - isolate);
|
| -}
|
| -
|
| + ArrayNArgumentsConstructorStub stub(isolate);
|
| + stub.GetCode();
|
|
|
| -void InternalArrayConstructorStubBase::GenerateStubsAheadOfTime(
|
| - Isolate* isolate) {
|
| ElementsKind kinds[2] = { FAST_ELEMENTS, FAST_HOLEY_ELEMENTS };
|
| for (int i = 0; i < 2; i++) {
|
| // For internal arrays we only need a few things
|
| @@ -4332,8 +4284,6 @@ void InternalArrayConstructorStubBase::GenerateStubsAheadOfTime(
|
| stubh1.GetCode();
|
| InternalArraySingleArgumentConstructorStub stubh2(isolate, kinds[i]);
|
| stubh2.GetCode();
|
| - InternalArrayNArgumentsConstructorStub stubh3(isolate, kinds[i]);
|
| - stubh3.GetCode();
|
| }
|
| }
|
|
|
| @@ -4353,13 +4303,15 @@ void ArrayConstructorStub::GenerateDispatchToArrayStub(
|
| CreateArrayDispatchOneArgument(masm, mode);
|
|
|
| __ bind(¬_one_case);
|
| - CreateArrayDispatch<ArrayNArgumentsConstructorStub>(masm, mode);
|
| + ArrayNArgumentsConstructorStub stub(masm->isolate());
|
| + __ TailCallStub(&stub);
|
| } else if (argument_count() == NONE) {
|
| CreateArrayDispatch<ArrayNoArgumentConstructorStub>(masm, mode);
|
| } else if (argument_count() == ONE) {
|
| CreateArrayDispatchOneArgument(masm, mode);
|
| } else if (argument_count() == MORE_THAN_ONE) {
|
| - CreateArrayDispatch<ArrayNArgumentsConstructorStub>(masm, mode);
|
| + ArrayNArgumentsConstructorStub stub(masm->isolate());
|
| + __ TailCallStub(&stub);
|
| } else {
|
| UNREACHABLE();
|
| }
|
| @@ -4436,7 +4388,8 @@ void ArrayConstructorStub::Generate(MacroAssembler* masm) {
|
| __ Push(edx);
|
| __ Push(ebx);
|
| __ PushReturnAddressFrom(ecx);
|
| - __ JumpToExternalReference(ExternalReference(Runtime::kNewArray, isolate()));
|
| + __ JumpToExternalReference(
|
| + ExternalReference(Runtime::kArrayConstructor, isolate()));
|
| }
|
|
|
|
|
| @@ -4471,7 +4424,7 @@ void InternalArrayConstructorStub::GenerateCase(
|
| __ TailCallStub(&stub1);
|
|
|
| __ bind(¬_one_case);
|
| - InternalArrayNArgumentsConstructorStub stubN(isolate(), kind);
|
| + ArrayNArgumentsConstructorStub stubN(isolate());
|
| __ TailCallStub(&stubN);
|
| }
|
|
|
|
|