| Index: runtime/vm/stub_code_arm.cc
|
| diff --git a/runtime/vm/stub_code_arm.cc b/runtime/vm/stub_code_arm.cc
|
| index 370711b2813f9a8e45e0a84346426875585c5de2..63d035749f396bf9f418bf579a3a240db71d1330 100644
|
| --- a/runtime/vm/stub_code_arm.cc
|
| +++ b/runtime/vm/stub_code_arm.cc
|
| @@ -1994,6 +1994,8 @@ void StubCode::GenerateOptimizedIdenticalWithNumberCheckStub(
|
| // CODE_REG: target Code
|
| // R4: arguments descriptor
|
| void StubCode::GenerateMegamorphicLookupStub(Assembler* assembler) {
|
| + __ NoMonomorphicCheckedEntry();
|
| +
|
| __ LoadTaggedClassIdMayBeSmi(R0, R0);
|
| // R0: receiver cid as Smi.
|
| __ ldr(R2, FieldAddress(R9, MegamorphicCache::buckets_offset()));
|
| @@ -2028,7 +2030,7 @@ void StubCode::GenerateMegamorphicLookupStub(Assembler* assembler) {
|
| __ ldr(R4, FieldAddress(R9, MegamorphicCache::arguments_descriptor_offset()));
|
| __ ldr(R1, FieldAddress(R0, Function::entry_point_offset()));
|
| __ ldr(CODE_REG, FieldAddress(R0, Function::code_offset()));
|
| - __ Ret();
|
| + __ bx(R1);
|
|
|
| // Probe failed, check if it is a miss.
|
| __ Bind(&probe_failed);
|
| @@ -2050,6 +2052,8 @@ void StubCode::GenerateMegamorphicLookupStub(Assembler* assembler) {
|
| // CODE_REG: target Code object
|
| // R4: arguments descriptor
|
| void StubCode::GenerateICLookupThroughFunctionStub(Assembler* assembler) {
|
| + __ NoMonomorphicCheckedEntry();
|
| +
|
| Label loop, found, miss;
|
| __ ldr(R4, FieldAddress(R9, ICData::arguments_descriptor_offset()));
|
| __ ldr(R8, FieldAddress(R9, ICData::ic_data_offset()));
|
| @@ -2074,17 +2078,19 @@ void StubCode::GenerateICLookupThroughFunctionStub(Assembler* assembler) {
|
| __ LoadFromOffset(kWord, R0, R8, target_offset);
|
| __ ldr(R1, FieldAddress(R0, Function::entry_point_offset()));
|
| __ ldr(CODE_REG, FieldAddress(R0, Function::code_offset()));
|
| - __ Ret();
|
| + __ bx(R1);
|
|
|
| __ Bind(&miss);
|
| __ LoadIsolate(R2);
|
| __ ldr(CODE_REG, Address(R2, Isolate::ic_miss_code_offset()));
|
| __ ldr(R1, FieldAddress(CODE_REG, Code::entry_point_offset()));
|
| - __ Ret();
|
| + __ bx(R1);
|
| }
|
|
|
|
|
| void StubCode::GenerateICLookupThroughCodeStub(Assembler* assembler) {
|
| + __ NoMonomorphicCheckedEntry();
|
| +
|
| Label loop, found, miss;
|
| __ ldr(R4, FieldAddress(R9, ICData::arguments_descriptor_offset()));
|
| __ ldr(R8, FieldAddress(R9, ICData::ic_data_offset()));
|
| @@ -2109,13 +2115,34 @@ void StubCode::GenerateICLookupThroughCodeStub(Assembler* assembler) {
|
| const intptr_t entry_offset = ICData::EntryPointIndexFor(1) * kWordSize;
|
| __ ldr(R1, Address(R8, entry_offset));
|
| __ ldr(CODE_REG, Address(R8, code_offset));
|
| - __ Ret();
|
| + __ bx(R1);
|
|
|
| __ Bind(&miss);
|
| __ LoadIsolate(R2);
|
| __ ldr(CODE_REG, Address(R2, Isolate::ic_miss_code_offset()));
|
| __ ldr(R1, FieldAddress(CODE_REG, Code::entry_point_offset()));
|
| - __ Ret();
|
| + __ bx(R1);
|
| +}
|
| +
|
| +
|
| +// Called from switchable IC calls.
|
| +// R0: receiver
|
| +
|
| +void StubCode::GenerateMonomorphicMissStub(Assembler* assembler) {
|
| + __ EnterStubFrame();
|
| + __ Push(R0); // Preserve receiver.
|
| +
|
| + __ PushObject(Object::null_object()); // Result.
|
| + __ Push(R0); // Arg0: Receiver / stub out
|
| + __ CallRuntime(kMonomorphicMissRuntimeEntry, 1);
|
| + __ Pop(CODE_REG);
|
| + __ Pop(R9); // result = IC
|
| +
|
| + __ Pop(R0); // Restore receiver.
|
| + __ LeaveStubFrame();
|
| +
|
| + __ ldr(R1, FieldAddress(CODE_REG, Code::checked_entry_point_offset()));
|
| + __ bx(R1);
|
| }
|
|
|
|
|
|
|