| 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 #include <limits.h>  // For LONG_MIN, LONG_MAX. | 5 #include <limits.h>  // For LONG_MIN, LONG_MAX. | 
| 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 3220 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 3231   Call(ces.GetCode(), RelocInfo::DEBUG_BREAK); | 3231   Call(ces.GetCode(), RelocInfo::DEBUG_BREAK); | 
| 3232 } | 3232 } | 
| 3233 | 3233 | 
| 3234 | 3234 | 
| 3235 // --------------------------------------------------------------------------- | 3235 // --------------------------------------------------------------------------- | 
| 3236 // Exception handling. | 3236 // Exception handling. | 
| 3237 | 3237 | 
| 3238 void MacroAssembler::PushTryHandler(StackHandler::Kind kind, | 3238 void MacroAssembler::PushTryHandler(StackHandler::Kind kind, | 
| 3239                                     int handler_index) { | 3239                                     int handler_index) { | 
| 3240   // Adjust this code if not the case. | 3240   // Adjust this code if not the case. | 
| 3241   STATIC_ASSERT(StackHandlerConstants::kSize == 5 * kPointerSize); | 3241   STATIC_ASSERT(StackHandlerConstants::kSize == 4 * kPointerSize); | 
| 3242   STATIC_ASSERT(StackHandlerConstants::kNextOffset == 0 * kPointerSize); | 3242   STATIC_ASSERT(StackHandlerConstants::kNextOffset == 0 * kPointerSize); | 
| 3243   STATIC_ASSERT(StackHandlerConstants::kCodeOffset == 1 * kPointerSize); | 3243   STATIC_ASSERT(StackHandlerConstants::kStateOffset == 1 * kPointerSize); | 
| 3244   STATIC_ASSERT(StackHandlerConstants::kStateOffset == 2 * kPointerSize); | 3244   STATIC_ASSERT(StackHandlerConstants::kContextOffset == 2 * kPointerSize); | 
| 3245   STATIC_ASSERT(StackHandlerConstants::kContextOffset == 3 * kPointerSize); | 3245   STATIC_ASSERT(StackHandlerConstants::kFPOffset == 3 * kPointerSize); | 
| 3246   STATIC_ASSERT(StackHandlerConstants::kFPOffset == 4 * kPointerSize); |  | 
| 3247 | 3246 | 
| 3248   // For the JSEntry handler, we must preserve a0-a3 and s0. | 3247   // For the JSEntry handler, we must preserve a0-a3 and s0. | 
| 3249   // t1-t3 are available. We will build up the handler from the bottom by | 3248   // t1-t3 are available. We will build up the handler from the bottom by | 
| 3250   // pushing on the stack. | 3249   // pushing on the stack. | 
| 3251   // Set up the code object (t1) and the state (t2) for pushing. | 3250   // Set up the the state (t2) for pushing. | 
| 3252   unsigned state = | 3251   unsigned state = | 
| 3253       StackHandler::IndexField::encode(handler_index) | | 3252       StackHandler::IndexField::encode(handler_index) | | 
| 3254       StackHandler::KindField::encode(kind); | 3253       StackHandler::KindField::encode(kind); | 
| 3255   li(t1, Operand(CodeObject()), CONSTANT_SIZE); |  | 
| 3256   li(t2, Operand(state)); | 3254   li(t2, Operand(state)); | 
| 3257 | 3255 | 
| 3258   // Push the frame pointer, context, state, and code object. | 3256   // Push the frame pointer, context, and state. | 
| 3259   if (kind == StackHandler::JS_ENTRY) { | 3257   if (kind == StackHandler::JS_ENTRY) { | 
| 3260     DCHECK_EQ(static_cast<Smi*>(0), Smi::FromInt(0)); | 3258     DCHECK_EQ(static_cast<Smi*>(0), Smi::FromInt(0)); | 
| 3261     // The second zero_reg indicates no context. | 3259     // The second zero_reg indicates no context. | 
| 3262     // The first zero_reg is the NULL frame pointer. | 3260     // The first zero_reg is the NULL frame pointer. | 
| 3263     // The operands are reversed to match the order of MultiPush/Pop. | 3261     // The operands are reversed to match the order of MultiPush/Pop. | 
| 3264     Push(zero_reg, zero_reg, t2, t1); | 3262     Push(zero_reg, zero_reg, t2); | 
| 3265   } else { | 3263   } else { | 
| 3266     MultiPush(t1.bit() | t2.bit() | cp.bit() | fp.bit()); | 3264     MultiPush(t2.bit() | cp.bit() | fp.bit()); | 
| 3267   } | 3265   } | 
| 3268 | 3266 | 
| 3269   // Link the current handler as the next handler. | 3267   // Link the current handler as the next handler. | 
| 3270   li(t2, Operand(ExternalReference(Isolate::kHandlerAddress, isolate()))); | 3268   li(t2, Operand(ExternalReference(Isolate::kHandlerAddress, isolate()))); | 
| 3271   lw(t1, MemOperand(t2)); | 3269   lw(t1, MemOperand(t2)); | 
| 3272   push(t1); | 3270   push(t1); | 
| 3273   // Set this new handler as the current one. | 3271   // Set this new handler as the current one. | 
| 3274   sw(sp, MemOperand(t2)); | 3272   sw(sp, MemOperand(t2)); | 
| 3275 } | 3273 } | 
| 3276 | 3274 | 
| (...skipping 2813 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 6090   } | 6088   } | 
| 6091   if (mag.shift > 0) sra(result, result, mag.shift); | 6089   if (mag.shift > 0) sra(result, result, mag.shift); | 
| 6092   srl(at, dividend, 31); | 6090   srl(at, dividend, 31); | 
| 6093   Addu(result, result, Operand(at)); | 6091   Addu(result, result, Operand(at)); | 
| 6094 } | 6092 } | 
| 6095 | 6093 | 
| 6096 | 6094 | 
| 6097 } }  // namespace v8::internal | 6095 } }  // namespace v8::internal | 
| 6098 | 6096 | 
| 6099 #endif  // V8_TARGET_ARCH_MIPS | 6097 #endif  // V8_TARGET_ARCH_MIPS | 
| OLD | NEW | 
|---|