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 "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #if V8_TARGET_ARCH_MIPS64 | 7 #if V8_TARGET_ARCH_MIPS64 |
8 | 8 |
9 // Note on Mips implementation: | 9 // Note on Mips implementation: |
10 // | 10 // |
(...skipping 3351 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3362 PrepareForBailoutForId(expr->ReturnId(), TOS_REG); | 3362 PrepareForBailoutForId(expr->ReturnId(), TOS_REG); |
3363 context()->Plug(v0); | 3363 context()->Plug(v0); |
3364 } | 3364 } |
3365 | 3365 |
3366 | 3366 |
3367 void FullCodeGenerator::EmitSuperConstructorCall(Call* expr) { | 3367 void FullCodeGenerator::EmitSuperConstructorCall(Call* expr) { |
3368 SuperCallReference* super_call_ref = | 3368 SuperCallReference* super_call_ref = |
3369 expr->expression()->AsSuperCallReference(); | 3369 expr->expression()->AsSuperCallReference(); |
3370 DCHECK_NOT_NULL(super_call_ref); | 3370 DCHECK_NOT_NULL(super_call_ref); |
3371 | 3371 |
3372 VariableProxy* new_target_proxy = super_call_ref->new_target_var(); | |
3373 VisitForStackValue(new_target_proxy); | |
3374 | |
3375 EmitLoadSuperConstructor(super_call_ref); | 3372 EmitLoadSuperConstructor(super_call_ref); |
3376 __ push(result_register()); | 3373 __ push(result_register()); |
3377 | 3374 |
3378 // Push the arguments ("left-to-right") on the stack. | 3375 // Push the arguments ("left-to-right") on the stack. |
3379 ZoneList<Expression*>* args = expr->arguments(); | 3376 ZoneList<Expression*>* args = expr->arguments(); |
3380 int arg_count = args->length(); | 3377 int arg_count = args->length(); |
3381 for (int i = 0; i < arg_count; i++) { | 3378 for (int i = 0; i < arg_count; i++) { |
3382 VisitForStackValue(args->at(i)); | 3379 VisitForStackValue(args->at(i)); |
3383 } | 3380 } |
3384 | 3381 |
3385 // Call the construct call builtin that handles allocation and | 3382 // Call the construct call builtin that handles allocation and |
3386 // constructor invocation. | 3383 // constructor invocation. |
3387 SetConstructCallPosition(expr); | 3384 SetConstructCallPosition(expr); |
3388 | 3385 |
| 3386 // Load original constructor into a4. |
| 3387 VisitForAccumulatorValue(super_call_ref->new_target_var()); |
| 3388 __ mov(a4, result_register()); |
| 3389 |
3389 // Load function and argument count into a1 and a0. | 3390 // Load function and argument count into a1 and a0. |
3390 __ li(a0, Operand(arg_count)); | 3391 __ li(a0, Operand(arg_count)); |
3391 __ ld(a1, MemOperand(sp, arg_count * kPointerSize)); | 3392 __ ld(a1, MemOperand(sp, arg_count * kPointerSize)); |
3392 | 3393 |
3393 // Record call targets in unoptimized code. | 3394 // Record call targets in unoptimized code. |
3394 if (FLAG_pretenuring_call_new) { | 3395 if (FLAG_pretenuring_call_new) { |
3395 UNREACHABLE(); | 3396 UNREACHABLE(); |
3396 /* TODO(dslomov): support pretenuring. | 3397 /* TODO(dslomov): support pretenuring. |
3397 EnsureSlotContainsAllocationSite(expr->AllocationSiteFeedbackSlot()); | 3398 EnsureSlotContainsAllocationSite(expr->AllocationSiteFeedbackSlot()); |
3398 DCHECK(expr->AllocationSiteFeedbackSlot().ToInt() == | 3399 DCHECK(expr->AllocationSiteFeedbackSlot().ToInt() == |
3399 expr->CallNewFeedbackSlot().ToInt() + 1); | 3400 expr->CallNewFeedbackSlot().ToInt() + 1); |
3400 */ | 3401 */ |
3401 } | 3402 } |
3402 | 3403 |
3403 __ li(a2, FeedbackVector()); | 3404 __ li(a2, FeedbackVector()); |
3404 __ li(a3, Operand(SmiFromSlot(expr->CallFeedbackSlot()))); | 3405 __ li(a3, Operand(SmiFromSlot(expr->CallFeedbackSlot()))); |
3405 | 3406 |
3406 CallConstructStub stub(isolate(), SUPER_CALL_RECORD_TARGET); | 3407 CallConstructStub stub(isolate(), SUPER_CALL_RECORD_TARGET); |
3407 __ Call(stub.GetCode(), RelocInfo::CONSTRUCT_CALL); | 3408 __ Call(stub.GetCode(), RelocInfo::CONSTRUCT_CALL); |
3408 | 3409 |
3409 __ Drop(1); | |
3410 | |
3411 RecordJSReturnSite(expr); | 3410 RecordJSReturnSite(expr); |
3412 | 3411 |
3413 EmitInitializeThisAfterSuper(super_call_ref, expr->CallFeedbackICSlot()); | 3412 EmitInitializeThisAfterSuper(super_call_ref, expr->CallFeedbackICSlot()); |
3414 context()->Plug(v0); | 3413 context()->Plug(v0); |
3415 } | 3414 } |
3416 | 3415 |
3417 | 3416 |
3418 void FullCodeGenerator::EmitIsSmi(CallRuntime* expr) { | 3417 void FullCodeGenerator::EmitIsSmi(CallRuntime* expr) { |
3419 ZoneList<Expression*>* args = expr->arguments(); | 3418 ZoneList<Expression*>* args = expr->arguments(); |
3420 DCHECK(args->length() == 1); | 3419 DCHECK(args->length() == 1); |
(...skipping 917 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4338 DCHECK(args->length() == 2); | 4337 DCHECK(args->length() == 2); |
4339 | 4338 |
4340 // new.target | 4339 // new.target |
4341 VisitForStackValue(args->at(0)); | 4340 VisitForStackValue(args->at(0)); |
4342 | 4341 |
4343 // .this_function | 4342 // .this_function |
4344 VisitForStackValue(args->at(1)); | 4343 VisitForStackValue(args->at(1)); |
4345 __ CallRuntime(Runtime::kGetPrototype, 1); | 4344 __ CallRuntime(Runtime::kGetPrototype, 1); |
4346 __ Push(result_register()); | 4345 __ Push(result_register()); |
4347 | 4346 |
| 4347 // Load original constructor into a4. |
| 4348 __ ld(a4, MemOperand(sp, 1 * kPointerSize)); |
| 4349 |
4348 // Check if the calling frame is an arguments adaptor frame. | 4350 // Check if the calling frame is an arguments adaptor frame. |
4349 Label adaptor_frame, args_set_up, runtime; | 4351 Label adaptor_frame, args_set_up, runtime; |
4350 __ ld(a2, MemOperand(fp, StandardFrameConstants::kCallerFPOffset)); | 4352 __ ld(a2, MemOperand(fp, StandardFrameConstants::kCallerFPOffset)); |
4351 __ ld(a3, MemOperand(a2, StandardFrameConstants::kContextOffset)); | 4353 __ ld(a3, MemOperand(a2, StandardFrameConstants::kContextOffset)); |
4352 __ Branch(&adaptor_frame, eq, a3, | 4354 __ Branch(&adaptor_frame, eq, a3, |
4353 Operand(Smi::FromInt(StackFrame::ARGUMENTS_ADAPTOR))); | 4355 Operand(Smi::FromInt(StackFrame::ARGUMENTS_ADAPTOR))); |
4354 // default constructor has no arguments, so no adaptor frame means no args. | 4356 // default constructor has no arguments, so no adaptor frame means no args. |
4355 __ mov(a0, zero_reg); | 4357 __ mov(a0, zero_reg); |
4356 __ Branch(&args_set_up); | 4358 __ Branch(&args_set_up); |
4357 | 4359 |
(...skipping 1244 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5602 reinterpret_cast<uint64_t>( | 5604 reinterpret_cast<uint64_t>( |
5603 isolate->builtins()->OsrAfterStackCheck()->entry())); | 5605 isolate->builtins()->OsrAfterStackCheck()->entry())); |
5604 return OSR_AFTER_STACK_CHECK; | 5606 return OSR_AFTER_STACK_CHECK; |
5605 } | 5607 } |
5606 | 5608 |
5607 | 5609 |
5608 } // namespace internal | 5610 } // namespace internal |
5609 } // namespace v8 | 5611 } // namespace v8 |
5610 | 5612 |
5611 #endif // V8_TARGET_ARCH_MIPS64 | 5613 #endif // V8_TARGET_ARCH_MIPS64 |
OLD | NEW |