| Index: src/arm/code-stubs-arm.cc
|
| diff --git a/src/arm/code-stubs-arm.cc b/src/arm/code-stubs-arm.cc
|
| index 34734453fafb6c07a0a091d51c150535faffdaf1..4eb08a1eebb0d7b0145166244f28414b497f604c 100644
|
| --- a/src/arm/code-stubs-arm.cc
|
| +++ b/src/arm/code-stubs-arm.cc
|
| @@ -77,7 +77,7 @@ void FastCloneShallowArrayStub::InitializeInterfaceDescriptor(
|
| descriptor->register_param_count_ = 3;
|
| descriptor->register_params_ = registers;
|
| descriptor->deoptimization_handler_ =
|
| - Runtime::FunctionForId(Runtime::kCreateArrayLiteral)->entry;
|
| + Runtime::FunctionForId(Runtime::kCreateArrayLiteralStubBailout)->entry;
|
| }
|
|
|
|
|
| @@ -193,7 +193,7 @@ void CompareNilICStub::InitializeInterfaceDescriptor(
|
| }
|
|
|
|
|
| -void BinaryOpStub::InitializeInterfaceDescriptor(
|
| +void BinaryOpICStub::InitializeInterfaceDescriptor(
|
| Isolate* isolate,
|
| CodeStubInterfaceDescriptor* descriptor) {
|
| static Register registers[] = { r1, r0 };
|
| @@ -693,27 +693,12 @@ void DoubleToIStub::Generate(MacroAssembler* masm) {
|
| }
|
|
|
|
|
| -bool WriteInt32ToHeapNumberStub::IsPregenerated(Isolate* isolate) {
|
| - // These variants are compiled ahead of time. See next method.
|
| - if (the_int_.is(r1) && the_heap_number_.is(r0) && scratch_.is(r2)) {
|
| - return true;
|
| - }
|
| - if (the_int_.is(r2) && the_heap_number_.is(r0) && scratch_.is(r3)) {
|
| - return true;
|
| - }
|
| - // Other register combinations are generated as and when they are needed,
|
| - // so it is unsafe to call them from stubs (we can't generate a stub while
|
| - // we are generating a stub).
|
| - return false;
|
| -}
|
| -
|
| -
|
| void WriteInt32ToHeapNumberStub::GenerateFixedRegStubsAheadOfTime(
|
| Isolate* isolate) {
|
| WriteInt32ToHeapNumberStub stub1(r1, r0, r2);
|
| WriteInt32ToHeapNumberStub stub2(r2, r0, r3);
|
| - stub1.GetCode(isolate)->set_is_pregenerated(true);
|
| - stub2.GetCode(isolate)->set_is_pregenerated(true);
|
| + stub1.GetCode(isolate);
|
| + stub2.GetCode(isolate);
|
| }
|
|
|
|
|
| @@ -1433,18 +1418,6 @@ void TranscendentalCacheStub::GenerateCallCFunction(MacroAssembler* masm,
|
| }
|
| AllowExternalCallThatCantCauseGC scope(masm);
|
| switch (type_) {
|
| - case TranscendentalCache::SIN:
|
| - __ CallCFunction(ExternalReference::math_sin_double_function(isolate),
|
| - 0, 1);
|
| - break;
|
| - case TranscendentalCache::COS:
|
| - __ CallCFunction(ExternalReference::math_cos_double_function(isolate),
|
| - 0, 1);
|
| - break;
|
| - case TranscendentalCache::TAN:
|
| - __ CallCFunction(ExternalReference::math_tan_double_function(isolate),
|
| - 0, 1);
|
| - break;
|
| case TranscendentalCache::LOG:
|
| __ CallCFunction(ExternalReference::math_log_double_function(isolate),
|
| 0, 1);
|
| @@ -1460,9 +1433,6 @@ void TranscendentalCacheStub::GenerateCallCFunction(MacroAssembler* masm,
|
| Runtime::FunctionId TranscendentalCacheStub::RuntimeFunction() {
|
| switch (type_) {
|
| // Add more cases when necessary.
|
| - case TranscendentalCache::SIN: return Runtime::kMath_sin;
|
| - case TranscendentalCache::COS: return Runtime::kMath_cos;
|
| - case TranscendentalCache::TAN: return Runtime::kMath_tan;
|
| case TranscendentalCache::LOG: return Runtime::kMath_log;
|
| default:
|
| UNIMPLEMENTED();
|
| @@ -1476,11 +1446,11 @@ void MathPowStub::Generate(MacroAssembler* masm) {
|
| const Register exponent = r2;
|
| const Register heapnumbermap = r5;
|
| const Register heapnumber = r0;
|
| - const DwVfpRegister double_base = d1;
|
| - const DwVfpRegister double_exponent = d2;
|
| - const DwVfpRegister double_result = d3;
|
| - const DwVfpRegister double_scratch = d0;
|
| - const SwVfpRegister single_scratch = s0;
|
| + const DwVfpRegister double_base = d0;
|
| + const DwVfpRegister double_exponent = d1;
|
| + const DwVfpRegister double_result = d2;
|
| + const DwVfpRegister double_scratch = d3;
|
| + const SwVfpRegister single_scratch = s6;
|
| const Register scratch = r9;
|
| const Register scratch2 = r4;
|
|
|
| @@ -1674,21 +1644,14 @@ bool CEntryStub::NeedsImmovableCode() {
|
| }
|
|
|
|
|
| -bool CEntryStub::IsPregenerated(Isolate* isolate) {
|
| - return (!save_doubles_ || isolate->fp_stubs_generated()) &&
|
| - result_size_ == 1;
|
| -}
|
| -
|
| -
|
| void CodeStub::GenerateStubsAheadOfTime(Isolate* isolate) {
|
| CEntryStub::GenerateAheadOfTime(isolate);
|
| WriteInt32ToHeapNumberStub::GenerateFixedRegStubsAheadOfTime(isolate);
|
| StoreBufferOverflowStub::GenerateFixedRegStubsAheadOfTime(isolate);
|
| StubFailureTrampolineStub::GenerateAheadOfTime(isolate);
|
| - RecordWriteStub::GenerateFixedRegStubsAheadOfTime(isolate);
|
| ArrayConstructorStubBase::GenerateStubsAheadOfTime(isolate);
|
| CreateAllocationSiteStub::GenerateAheadOfTime(isolate);
|
| - BinaryOpStub::GenerateAheadOfTime(isolate);
|
| + BinaryOpICStub::GenerateAheadOfTime(isolate);
|
| }
|
|
|
|
|
| @@ -1707,16 +1670,13 @@ void CodeStub::GenerateFPStubs(Isolate* isolate) {
|
| if (!stub.FindCodeInCache(&store_buffer_overflow_code, isolate)) {
|
| store_buffer_overflow_code = *stub.GetCode(isolate);
|
| }
|
| - save_doubles_code->set_is_pregenerated(true);
|
| - store_buffer_overflow_code->set_is_pregenerated(true);
|
| isolate->set_fp_stubs_generated(true);
|
| }
|
|
|
|
|
| void CEntryStub::GenerateAheadOfTime(Isolate* isolate) {
|
| CEntryStub stub(1, kDontSaveFPRegs);
|
| - Handle<Code> code = stub.GetCode(isolate);
|
| - code->set_is_pregenerated(true);
|
| + stub.GetCode(isolate);
|
| }
|
|
|
|
|
| @@ -2584,7 +2544,7 @@ void ArgumentsAccessStub::GenerateNewNonStrictFast(MacroAssembler* masm) {
|
| const int kAliasedOffset =
|
| Context::SlotOffset(Context::ALIASED_ARGUMENTS_BOILERPLATE_INDEX);
|
|
|
| - __ ldr(r4, MemOperand(r8, Context::SlotOffset(Context::GLOBAL_OBJECT_INDEX)));
|
| + __ ldr(r4, MemOperand(cp, Context::SlotOffset(Context::GLOBAL_OBJECT_INDEX)));
|
| __ ldr(r4, FieldMemOperand(r4, GlobalObject::kNativeContextOffset));
|
| __ cmp(r1, Operand::Zero());
|
| __ ldr(r4, MemOperand(r4, kNormalOffset), eq);
|
| @@ -2635,7 +2595,7 @@ void ArgumentsAccessStub::GenerateNewNonStrictFast(MacroAssembler* masm) {
|
| __ str(r6, FieldMemOperand(r4, FixedArray::kMapOffset));
|
| __ add(r6, r1, Operand(Smi::FromInt(2)));
|
| __ str(r6, FieldMemOperand(r4, FixedArray::kLengthOffset));
|
| - __ str(r8, FieldMemOperand(r4, FixedArray::kHeaderSize + 0 * kPointerSize));
|
| + __ str(cp, FieldMemOperand(r4, FixedArray::kHeaderSize + 0 * kPointerSize));
|
| __ add(r6, r4, Operand(r1, LSL, 1));
|
| __ add(r6, r6, Operand(kParameterMapHeaderSize));
|
| __ str(r6, FieldMemOperand(r4, FixedArray::kHeaderSize + 1 * kPointerSize));
|
| @@ -3029,7 +2989,7 @@ void RegExpExecStub::Generate(MacroAssembler* masm) {
|
|
|
| // For arguments 4 and 3 get string length, calculate start of string data and
|
| // calculate the shift of the index (0 for ASCII and 1 for two byte).
|
| - __ add(r8, subject, Operand(SeqString::kHeaderSize - kHeapObjectTag));
|
| + __ add(r7, subject, Operand(SeqString::kHeaderSize - kHeapObjectTag));
|
| __ eor(r3, r3, Operand(1));
|
| // Load the length from the original subject string from the previous stack
|
| // frame. Therefore we have to use fp, which points exactly to two pointer
|
| @@ -3040,12 +3000,12 @@ void RegExpExecStub::Generate(MacroAssembler* masm) {
|
| // Argument 4, r3: End of string data
|
| // Argument 3, r2: Start of string data
|
| // Prepare start and end index of the input.
|
| - __ add(r9, r8, Operand(r9, LSL, r3));
|
| + __ add(r9, r7, Operand(r9, LSL, r3));
|
| __ add(r2, r9, Operand(r1, LSL, r3));
|
|
|
| - __ ldr(r8, FieldMemOperand(subject, String::kLengthOffset));
|
| - __ SmiUntag(r8);
|
| - __ add(r3, r9, Operand(r8, LSL, r3));
|
| + __ ldr(r7, FieldMemOperand(subject, String::kLengthOffset));
|
| + __ SmiUntag(r7);
|
| + __ add(r3, r9, Operand(r7, LSL, r3));
|
|
|
| // Argument 2 (r1): Previous index.
|
| // Already there
|
| @@ -5347,89 +5307,13 @@ void NameDictionaryLookupStub::Generate(MacroAssembler* masm) {
|
| }
|
|
|
|
|
| -struct AheadOfTimeWriteBarrierStubList {
|
| - Register object, value, address;
|
| - RememberedSetAction action;
|
| -};
|
| -
|
| -
|
| -#define REG(Name) { kRegister_ ## Name ## _Code }
|
| -
|
| -static const AheadOfTimeWriteBarrierStubList kAheadOfTime[] = {
|
| - // Used in RegExpExecStub.
|
| - { REG(r6), REG(r4), REG(r3), EMIT_REMEMBERED_SET },
|
| - // Used in CompileArrayPushCall.
|
| - // Also used in StoreIC::GenerateNormal via GenerateDictionaryStore.
|
| - // Also used in KeyedStoreIC::GenerateGeneric.
|
| - { REG(r3), REG(r4), REG(r5), EMIT_REMEMBERED_SET },
|
| - // Used in StoreStubCompiler::CompileStoreField via GenerateStoreField.
|
| - { REG(r1), REG(r2), REG(r3), EMIT_REMEMBERED_SET },
|
| - { REG(r3), REG(r2), REG(r1), EMIT_REMEMBERED_SET },
|
| - // Used in KeyedStoreStubCompiler::CompileStoreField via GenerateStoreField.
|
| - { REG(r2), REG(r1), REG(r3), EMIT_REMEMBERED_SET },
|
| - { REG(r3), REG(r1), REG(r2), EMIT_REMEMBERED_SET },
|
| - // KeyedStoreStubCompiler::GenerateStoreFastElement.
|
| - { REG(r3), REG(r2), REG(r4), EMIT_REMEMBERED_SET },
|
| - { REG(r2), REG(r3), REG(r4), EMIT_REMEMBERED_SET },
|
| - // ElementsTransitionGenerator::GenerateMapChangeElementTransition
|
| - // and ElementsTransitionGenerator::GenerateSmiToDouble
|
| - // and ElementsTransitionGenerator::GenerateDoubleToObject
|
| - { REG(r2), REG(r3), REG(r9), EMIT_REMEMBERED_SET },
|
| - { REG(r2), REG(r3), REG(r9), OMIT_REMEMBERED_SET },
|
| - // ElementsTransitionGenerator::GenerateDoubleToObject
|
| - { REG(r6), REG(r2), REG(r0), EMIT_REMEMBERED_SET },
|
| - { REG(r2), REG(r6), REG(r9), EMIT_REMEMBERED_SET },
|
| - // StoreArrayLiteralElementStub::Generate
|
| - { REG(r5), REG(r0), REG(r6), EMIT_REMEMBERED_SET },
|
| - // FastNewClosureStub::Generate
|
| - { REG(r2), REG(r4), REG(r1), EMIT_REMEMBERED_SET },
|
| - // StringAddStub::Generate
|
| - { REG(r3), REG(r1), REG(r4), EMIT_REMEMBERED_SET },
|
| - { REG(r3), REG(r0), REG(r4), EMIT_REMEMBERED_SET },
|
| - // Null termination.
|
| - { REG(no_reg), REG(no_reg), REG(no_reg), EMIT_REMEMBERED_SET}
|
| -};
|
| -
|
| -#undef REG
|
| -
|
| -
|
| -bool RecordWriteStub::IsPregenerated(Isolate* isolate) {
|
| - for (const AheadOfTimeWriteBarrierStubList* entry = kAheadOfTime;
|
| - !entry->object.is(no_reg);
|
| - entry++) {
|
| - if (object_.is(entry->object) &&
|
| - value_.is(entry->value) &&
|
| - address_.is(entry->address) &&
|
| - remembered_set_action_ == entry->action &&
|
| - save_fp_regs_mode_ == kDontSaveFPRegs) {
|
| - return true;
|
| - }
|
| - }
|
| - return false;
|
| -}
|
| -
|
| -
|
| void StoreBufferOverflowStub::GenerateFixedRegStubsAheadOfTime(
|
| Isolate* isolate) {
|
| StoreBufferOverflowStub stub1(kDontSaveFPRegs);
|
| - stub1.GetCode(isolate)->set_is_pregenerated(true);
|
| + stub1.GetCode(isolate);
|
| // Hydrogen code stubs need stub2 at snapshot time.
|
| StoreBufferOverflowStub stub2(kSaveFPRegs);
|
| - stub2.GetCode(isolate)->set_is_pregenerated(true);
|
| -}
|
| -
|
| -
|
| -void RecordWriteStub::GenerateFixedRegStubsAheadOfTime(Isolate* isolate) {
|
| - for (const AheadOfTimeWriteBarrierStubList* entry = kAheadOfTime;
|
| - !entry->object.is(no_reg);
|
| - entry++) {
|
| - RecordWriteStub stub(entry->object,
|
| - entry->value,
|
| - entry->address,
|
| - entry->action,
|
| - kDontSaveFPRegs);
|
| - stub.GetCode(isolate)->set_is_pregenerated(true);
|
| - }
|
| + stub2.GetCode(isolate);
|
| }
|
|
|
|
|
| @@ -5738,7 +5622,6 @@ void StubFailureTailCallTrampolineStub::Generate(MacroAssembler* masm) {
|
| void ProfileEntryHookStub::MaybeCallEntryHook(MacroAssembler* masm) {
|
| if (masm->isolate()->function_entry_hook() != NULL) {
|
| PredictableCodeSizeScope predictable(masm, 4 * Assembler::kInstrSize);
|
| - AllowStubCallsScope allow_stub_calls(masm, true);
|
| ProfileEntryHookStub stub;
|
| __ push(lr);
|
| __ CallStub(&stub);
|
| @@ -5931,12 +5814,12 @@ static void ArrayConstructorStubAheadOfTimeHelper(Isolate* isolate) {
|
| for (int i = 0; i <= to_index; ++i) {
|
| ElementsKind kind = GetFastElementsKindFromSequenceIndex(i);
|
| T stub(kind);
|
| - stub.GetCode(isolate)->set_is_pregenerated(true);
|
| + stub.GetCode(isolate);
|
| if (AllocationSite::GetMode(kind) != DONT_TRACK_ALLOCATION_SITE ||
|
| (!FLAG_track_allocation_sites &&
|
| (kind == initial_kind || kind == initial_holey_kind))) {
|
| T stub1(kind, CONTEXT_CHECK_REQUIRED, DISABLE_ALLOCATION_SITES);
|
| - stub1.GetCode(isolate)->set_is_pregenerated(true);
|
| + stub1.GetCode(isolate);
|
| }
|
| }
|
| }
|
| @@ -5958,11 +5841,11 @@ void InternalArrayConstructorStubBase::GenerateStubsAheadOfTime(
|
| for (int i = 0; i < 2; i++) {
|
| // For internal arrays we only need a few things
|
| InternalArrayNoArgumentConstructorStub stubh1(kinds[i]);
|
| - stubh1.GetCode(isolate)->set_is_pregenerated(true);
|
| + stubh1.GetCode(isolate);
|
| InternalArraySingleArgumentConstructorStub stubh2(kinds[i]);
|
| - stubh2.GetCode(isolate)->set_is_pregenerated(true);
|
| + stubh2.GetCode(isolate);
|
| InternalArrayNArgumentsConstructorStub stubh3(kinds[i]);
|
| - stubh3.GetCode(isolate)->set_is_pregenerated(true);
|
| + stubh3.GetCode(isolate);
|
| }
|
| }
|
|
|
|
|