Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 | 5 |
| 6 | 6 |
| 7 #include "src/v8.h" | 7 #include "src/v8.h" |
| 8 | 8 |
| 9 #if V8_TARGET_ARCH_MIPS | 9 #if V8_TARGET_ARCH_MIPS |
| 10 | 10 |
| (...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 94 #define __ ACCESS_MASM(masm) | 94 #define __ ACCESS_MASM(masm) |
| 95 | 95 |
| 96 | 96 |
| 97 | 97 |
| 98 static void Generate_DebugBreakCallHelper(MacroAssembler* masm, | 98 static void Generate_DebugBreakCallHelper(MacroAssembler* masm, |
| 99 RegList object_regs, | 99 RegList object_regs, |
| 100 RegList non_object_regs) { | 100 RegList non_object_regs) { |
| 101 { | 101 { |
| 102 FrameScope scope(masm, StackFrame::INTERNAL); | 102 FrameScope scope(masm, StackFrame::INTERNAL); |
| 103 | 103 |
| 104 // Load padding words on stack. | |
| 105 __ li(at, Operand(Smi::FromInt(LiveEdit::kFramePaddingValue))); | |
| 106 __ Subu(sp, sp, | |
| 107 Operand(kPointerSize * LiveEdit::kFramePaddingInitialSize)); | |
| 108 for (int i = LiveEdit::kFramePaddingInitialSize - 1; i >= 0; i--) { | |
| 109 __ sw(at, MemOperand(sp, kPointerSize * i)); | |
| 110 } | |
| 111 __ li(at, Operand(Smi::FromInt(LiveEdit::kFramePaddingInitialSize))); | |
| 112 __ push(at); | |
| 113 | |
| 104 // Store the registers containing live values on the expression stack to | 114 // Store the registers containing live values on the expression stack to |
| 105 // make sure that these are correctly updated during GC. Non object values | 115 // make sure that these are correctly updated during GC. Non object values |
| 106 // are stored as a smi causing it to be untouched by GC. | 116 // are stored as a smi causing it to be untouched by GC. |
| 107 ASSERT((object_regs & ~kJSCallerSaved) == 0); | 117 ASSERT((object_regs & ~kJSCallerSaved) == 0); |
| 108 ASSERT((non_object_regs & ~kJSCallerSaved) == 0); | 118 ASSERT((non_object_regs & ~kJSCallerSaved) == 0); |
| 109 ASSERT((object_regs & non_object_regs) == 0); | 119 ASSERT((object_regs & non_object_regs) == 0); |
| 110 if ((object_regs | non_object_regs) != 0) { | 120 if ((object_regs | non_object_regs) != 0) { |
| 111 for (int i = 0; i < kNumJSCallerSaved; i++) { | 121 for (int i = 0; i < kNumJSCallerSaved; i++) { |
| 112 int r = JSCallerSavedCode(i); | 122 int r = JSCallerSavedCode(i); |
| 113 Register reg = { r }; | 123 Register reg = { r }; |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 140 if ((non_object_regs & (1 << r)) != 0) { | 150 if ((non_object_regs & (1 << r)) != 0) { |
| 141 __ srl(reg, reg, kSmiTagSize); | 151 __ srl(reg, reg, kSmiTagSize); |
| 142 } | 152 } |
| 143 if (FLAG_debug_code && | 153 if (FLAG_debug_code && |
| 144 (((object_regs |non_object_regs) & (1 << r)) == 0)) { | 154 (((object_regs |non_object_regs) & (1 << r)) == 0)) { |
| 145 __ li(reg, kDebugZapValue); | 155 __ li(reg, kDebugZapValue); |
| 146 } | 156 } |
| 147 } | 157 } |
| 148 } | 158 } |
| 149 | 159 |
| 160 // Don't bother removing padding bytes pushed on the stack | |
| 161 // as the frame is going to be restored right away. | |
| 162 | |
| 150 // Leave the internal frame. | 163 // Leave the internal frame. |
| 151 } | 164 } |
| 152 | 165 |
| 153 // Now that the break point has been handled, resume normal execution by | 166 // Now that the break point has been handled, resume normal execution by |
| 154 // jumping to the target address intended by the caller and that was | 167 // jumping to the target address intended by the caller and that was |
| 155 // overwritten by the address of DebugBreakXXX. | 168 // overwritten by the address of DebugBreakXXX. |
| 156 ExternalReference after_break_target = | 169 ExternalReference after_break_target = |
| 157 ExternalReference::debug_after_break_target_address(masm->isolate()); | 170 ExternalReference::debug_after_break_target_address(masm->isolate()); |
| 158 __ li(t9, Operand(after_break_target)); | 171 __ li(t9, Operand(after_break_target)); |
| 159 __ lw(t9, MemOperand(t9)); | 172 __ lw(t9, MemOperand(t9)); |
| (...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 283 | 296 |
| 284 | 297 |
| 285 void DebugCodegen::GenerateSlotDebugBreak(MacroAssembler* masm) { | 298 void DebugCodegen::GenerateSlotDebugBreak(MacroAssembler* masm) { |
| 286 // In the places where a debug break slot is inserted no registers can contain | 299 // In the places where a debug break slot is inserted no registers can contain |
| 287 // object pointers. | 300 // object pointers. |
| 288 Generate_DebugBreakCallHelper(masm, 0, 0); | 301 Generate_DebugBreakCallHelper(masm, 0, 0); |
| 289 } | 302 } |
| 290 | 303 |
| 291 | 304 |
| 292 void DebugCodegen::GeneratePlainReturnLiveEdit(MacroAssembler* masm) { | 305 void DebugCodegen::GeneratePlainReturnLiveEdit(MacroAssembler* masm) { |
| 293 masm->Abort(kLiveEditFrameDroppingIsNotSupportedOnMips); | 306 __ Ret(); |
| 294 } | 307 } |
| 295 | 308 |
| 296 | 309 |
| 297 void DebugCodegen::GenerateFrameDropperLiveEdit(MacroAssembler* masm) { | 310 void DebugCodegen::GenerateFrameDropperLiveEdit(MacroAssembler* masm) { |
| 298 masm->Abort(kLiveEditFrameDroppingIsNotSupportedOnMips); | 311 ExternalReference restarter_frame_function_slot = |
| 312 ExternalReference::debug_restarter_frame_function_pointer_address( | |
| 313 masm->isolate()); | |
| 314 __ li(at, Operand(restarter_frame_function_slot)); | |
| 315 __ sw(zero_reg, MemOperand(at, 0)); | |
| 316 | |
| 317 // We do not know our frame height, but set sp based on fp. | |
| 318 __ Subu(sp, fp, Operand(kPointerSize)); | |
| 319 | |
| 320 __ Pop(ra, fp, a1); // Return address, Frame, Function. | |
| 321 | |
| 322 // Load context from the function. | |
| 323 __ lw(cp, FieldMemOperand(a1, JSFunction::kContextOffset)); | |
| 324 | |
| 325 // Get function code. | |
| 326 __ lw(at, FieldMemOperand(a1, JSFunction::kSharedFunctionInfoOffset)); | |
| 327 __ lw(at, FieldMemOperand(at, SharedFunctionInfo::kCodeOffset)); | |
| 328 __ Addu(t9, at, Operand(Code::kHeaderSize - kHeapObjectTag)); | |
| 329 | |
| 330 // Re-run JSFunction, r1 is function, cp is context. | |
|
alph
2014/06/21 08:35:54
nit: s/r1/a1/
kilvadyb
2014/06/21 12:32:16
Thank you for noticing this.
Done.
| |
| 331 __ Jump(t9); | |
| 299 } | 332 } |
| 300 | 333 |
| 301 | 334 |
| 302 const bool LiveEdit::kFrameDropperSupported = false; | 335 const bool LiveEdit::kFrameDropperSupported = true; |
| 303 | 336 |
| 304 #undef __ | 337 #undef __ |
| 305 | 338 |
| 306 } } // namespace v8::internal | 339 } } // namespace v8::internal |
| 307 | 340 |
| 308 #endif // V8_TARGET_ARCH_MIPS | 341 #endif // V8_TARGET_ARCH_MIPS |
| OLD | NEW |