Chromium Code Reviews| Index: runtime/vm/stub_code_mips.cc |
| =================================================================== |
| --- runtime/vm/stub_code_mips.cc (revision 24193) |
| +++ runtime/vm/stub_code_mips.cc (working copy) |
| @@ -1489,7 +1489,8 @@ |
| // T0: function object. |
| // S5: inline cache data object. |
| -// S4: arguments descriptor array. |
| +// Cannot use function object from ICData as it may be the inlined |
| +// function and not the top-scope function. |
| void StubCode::GenerateOptimizedUsageCounterIncrement(Assembler* assembler) { |
| __ TraceSimMsg("OptimizedUsageCounterIncrement"); |
| Register ic_reg = S5; |
| @@ -1499,11 +1500,9 @@ |
| __ addiu(SP, SP, Immediate(-5 * kWordSize)); |
|
zra
2013/06/19 21:39:04
Only need 4 slots now.
srdjan
2013/06/19 22:03:49
Done.
|
| __ sw(T0, Address(SP, 4 * kWordSize)); |
| __ sw(S5, Address(SP, 3 * kWordSize)); |
| - __ sw(S4, Address(SP, 2 * kWordSize)); // Preserve. |
| __ sw(ic_reg, Address(SP, 1 * kWordSize)); // Argument. |
| __ sw(func_reg, Address(SP, 0 * kWordSize)); // Argument. |
| __ CallRuntime(kTraceICCallRuntimeEntry); |
| - __ lw(S4, Address(SP, 2 * kWordSize)); // Restore. |
| __ lw(S5, Address(SP, 3 * kWordSize)); |
| __ lw(T0, Address(SP, 4 * kWordSize)); |
| __ addiu(SP, SP, Immediate(5 * kWordSize)); // Discard argument; |
|
zra
2013/06/19 21:39:04
4
srdjan
2013/06/19 22:03:49
Done.
|
| @@ -1553,7 +1552,6 @@ |
| // Generate inline cache check for 'num_args'. |
| // RA: return address |
| // S5: Inline cache data object. |
| -// S4: Arguments descriptor array. |
| // Control flow: |
| // - If receiver is null -> jump to IC miss. |
| // - If receiver is Smi -> load Smi class. |
| @@ -1576,6 +1574,8 @@ |
| } |
| #endif // DEBUG |
| + // Load argument descriptor into S4. |
| + __ lw(S4, FieldAddress(S5, ICData::arguments_descriptor_offset())); |
| // Preserve return address, since RA is needed for subroutine call. |
| __ mov(T2, RA); |
| // Loop that checks if there is an IC data match. |
| @@ -1743,7 +1743,6 @@ |
| // cache miss handler. Stub for 1-argument check (receiver class). |
| // RA: Return address. |
| // S5: Inline cache data object. |
| -// S4: Arguments descriptor array. |
| // Inline cache data object structure: |
| // 0: function-name |
| // 1: N, number of arguments checked. |
| @@ -1850,7 +1849,6 @@ |
| // RA: return address (Dart code). |
| // S5: Inline cache data array. |
| -// S4: Arguments descriptor array. |
| void StubCode::GenerateBreakpointDynamicStub(Assembler* assembler) { |
| // Create a stub frame as we are pushing some objects on the stack before |
| // calling into the runtime. |
| @@ -1858,9 +1856,7 @@ |
| __ EnterStubFrame(); |
| __ addiu(SP, SP, Immediate(-2 * kWordSize)); |
|
zra
2013/06/19 21:39:04
Only need 1 slot now. If there's only one thing we
srdjan
2013/06/19 22:03:49
Done.
|
| __ sw(S5, Address(SP, 1 * kWordSize)); |
| - __ sw(S4, Address(SP, 0 * kWordSize)); |
| __ CallRuntime(kBreakpointDynamicHandlerRuntimeEntry); |
| - __ lw(S4, Address(SP, 0 * kWordSize)); |
| __ lw(S5, Address(SP, 1 * kWordSize)); |
| __ addiu(SP, SP, Immediate(2 * kWordSize)); |
| __ LeaveStubFrame(); |