| 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_MIPS | 7 #if V8_TARGET_ARCH_MIPS |
| 8 | 8 |
| 9 // Note on Mips implementation: | 9 // Note on Mips implementation: |
| 10 // | 10 // |
| (...skipping 253 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 264 int offset = num_parameters * kPointerSize; | 264 int offset = num_parameters * kPointerSize; |
| 265 __ Addu(a2, fp, | 265 __ Addu(a2, fp, |
| 266 Operand(StandardFrameConstants::kCallerSPOffset + offset)); | 266 Operand(StandardFrameConstants::kCallerSPOffset + offset)); |
| 267 __ li(a1, Operand(Smi::FromInt(num_parameters))); | 267 __ li(a1, Operand(Smi::FromInt(num_parameters))); |
| 268 __ Push(a3, a2, a1); | 268 __ Push(a3, a2, a1); |
| 269 | 269 |
| 270 // Arguments to ArgumentsAccessStub: | 270 // Arguments to ArgumentsAccessStub: |
| 271 // function, receiver address, parameter count. | 271 // function, receiver address, parameter count. |
| 272 // The stub will rewrite receiever and parameter count if the previous | 272 // The stub will rewrite receiever and parameter count if the previous |
| 273 // stack frame was an arguments adapter frame. | 273 // stack frame was an arguments adapter frame. |
| 274 ArgumentsAccessStub::HasNewTarget has_new_target = |
| 275 IsSubclassConstructor(info->function()->kind()) |
| 276 ? ArgumentsAccessStub::HAS_NEW_TARGET |
| 277 : ArgumentsAccessStub::NO_NEW_TARGET; |
| 274 ArgumentsAccessStub::Type type; | 278 ArgumentsAccessStub::Type type; |
| 275 if (is_strict(language_mode())) { | 279 if (is_strict(language_mode())) { |
| 276 type = ArgumentsAccessStub::NEW_STRICT; | 280 type = ArgumentsAccessStub::NEW_STRICT; |
| 277 } else if (function()->has_duplicate_parameters()) { | 281 } else if (function()->has_duplicate_parameters()) { |
| 278 type = ArgumentsAccessStub::NEW_SLOPPY_SLOW; | 282 type = ArgumentsAccessStub::NEW_SLOPPY_SLOW; |
| 279 } else { | 283 } else { |
| 280 type = ArgumentsAccessStub::NEW_SLOPPY_FAST; | 284 type = ArgumentsAccessStub::NEW_SLOPPY_FAST; |
| 281 } | 285 } |
| 282 ArgumentsAccessStub stub(isolate(), type); | 286 ArgumentsAccessStub stub(isolate(), type, has_new_target); |
| 283 __ CallStub(&stub); | 287 __ CallStub(&stub); |
| 284 | 288 |
| 285 SetVar(arguments, v0, a1, a2); | 289 SetVar(arguments, v0, a1, a2); |
| 286 } | 290 } |
| 287 | 291 |
| 288 if (FLAG_trace) { | 292 if (FLAG_trace) { |
| 289 __ CallRuntime(Runtime::kTraceEnter, 0); | 293 __ CallRuntime(Runtime::kTraceEnter, 0); |
| 290 } | 294 } |
| 291 | 295 |
| 292 // Visit the declarations and body unless there is an illegal | 296 // Visit the declarations and body unless there is an illegal |
| (...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 432 #ifdef DEBUG | 436 #ifdef DEBUG |
| 433 // Add a label for checking the size of the code used for returning. | 437 // Add a label for checking the size of the code used for returning. |
| 434 Label check_exit_codesize; | 438 Label check_exit_codesize; |
| 435 masm_->bind(&check_exit_codesize); | 439 masm_->bind(&check_exit_codesize); |
| 436 #endif | 440 #endif |
| 437 // Make sure that the constant pool is not emitted inside of the return | 441 // Make sure that the constant pool is not emitted inside of the return |
| 438 // sequence. | 442 // sequence. |
| 439 { Assembler::BlockTrampolinePoolScope block_trampoline_pool(masm_); | 443 { Assembler::BlockTrampolinePoolScope block_trampoline_pool(masm_); |
| 440 // Here we use masm_-> instead of the __ macro to avoid the code coverage | 444 // Here we use masm_-> instead of the __ macro to avoid the code coverage |
| 441 // tool from instrumenting as we rely on the code size here. | 445 // tool from instrumenting as we rely on the code size here. |
| 442 int32_t sp_delta = (info_->scope()->num_parameters() + 1) * kPointerSize; | 446 int32_t arg_count = info_->scope()->num_parameters() + 1; |
| 447 if (FLAG_experimental_classes && |
| 448 IsSubclassConstructor(info_->function()->kind())) { |
| 449 arg_count++; |
| 450 } |
| 451 int32_t sp_delta = arg_count * kPointerSize; |
| 443 CodeGenerator::RecordPositions(masm_, function()->end_position() - 1); | 452 CodeGenerator::RecordPositions(masm_, function()->end_position() - 1); |
| 444 __ RecordJSReturn(); | 453 __ RecordJSReturn(); |
| 445 masm_->mov(sp, fp); | 454 masm_->mov(sp, fp); |
| 446 int no_frame_start = masm_->pc_offset(); | 455 int no_frame_start = masm_->pc_offset(); |
| 447 masm_->MultiPop(static_cast<RegList>(fp.bit() | ra.bit())); | 456 masm_->MultiPop(static_cast<RegList>(fp.bit() | ra.bit())); |
| 448 masm_->Addu(sp, sp, Operand(sp_delta)); | 457 masm_->Addu(sp, sp, Operand(sp_delta)); |
| 449 masm_->Jump(ra); | 458 masm_->Jump(ra); |
| 450 info_->AddNoFrameRange(no_frame_start, masm_->pc_offset()); | 459 info_->AddNoFrameRange(no_frame_start, masm_->pc_offset()); |
| 451 } | 460 } |
| 452 | 461 |
| (...skipping 2767 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3220 __ li(a3, Operand(SmiFromSlot(expr->CallNewFeedbackSlot()))); | 3229 __ li(a3, Operand(SmiFromSlot(expr->CallNewFeedbackSlot()))); |
| 3221 | 3230 |
| 3222 CallConstructStub stub(isolate(), RECORD_CONSTRUCTOR_TARGET); | 3231 CallConstructStub stub(isolate(), RECORD_CONSTRUCTOR_TARGET); |
| 3223 __ Call(stub.GetCode(), RelocInfo::CONSTRUCT_CALL); | 3232 __ Call(stub.GetCode(), RelocInfo::CONSTRUCT_CALL); |
| 3224 PrepareForBailoutForId(expr->ReturnId(), TOS_REG); | 3233 PrepareForBailoutForId(expr->ReturnId(), TOS_REG); |
| 3225 context()->Plug(v0); | 3234 context()->Plug(v0); |
| 3226 } | 3235 } |
| 3227 | 3236 |
| 3228 | 3237 |
| 3229 void FullCodeGenerator::EmitSuperConstructorCall(Call* expr) { | 3238 void FullCodeGenerator::EmitSuperConstructorCall(Call* expr) { |
| 3239 Comment cmnt(masm_, "[ SuperConstructorCall"); |
| 3240 Variable* new_target_var = scope()->DeclarationScope()->new_target_var(); |
| 3241 GetVar(result_register(), new_target_var); |
| 3242 __ Push(result_register()); |
| 3243 |
| 3230 SuperReference* super_ref = expr->expression()->AsSuperReference(); | 3244 SuperReference* super_ref = expr->expression()->AsSuperReference(); |
| 3231 EmitLoadSuperConstructor(super_ref); | 3245 EmitLoadSuperConstructor(super_ref); |
| 3232 __ push(result_register()); | 3246 __ push(result_register()); |
| 3233 | 3247 |
| 3234 Variable* this_var = super_ref->this_var()->var(); | 3248 Variable* this_var = super_ref->this_var()->var(); |
| 3235 | 3249 |
| 3236 GetVar(a0, this_var); | 3250 GetVar(a0, this_var); |
| 3237 __ LoadRoot(at, Heap::kTheHoleValueRootIndex); | 3251 __ LoadRoot(at, Heap::kTheHoleValueRootIndex); |
| 3238 Label uninitialized_this; | 3252 Label uninitialized_this; |
| 3239 __ Branch(&uninitialized_this, eq, a0, Operand(at)); | 3253 __ Branch(&uninitialized_this, eq, a0, Operand(at)); |
| (...skipping 23 matching lines...) Expand all Loading... |
| 3263 /* TODO(dslomov): support pretenuring. | 3277 /* TODO(dslomov): support pretenuring. |
| 3264 EnsureSlotContainsAllocationSite(expr->AllocationSiteFeedbackSlot()); | 3278 EnsureSlotContainsAllocationSite(expr->AllocationSiteFeedbackSlot()); |
| 3265 DCHECK(expr->AllocationSiteFeedbackSlot().ToInt() == | 3279 DCHECK(expr->AllocationSiteFeedbackSlot().ToInt() == |
| 3266 expr->CallNewFeedbackSlot().ToInt() + 1); | 3280 expr->CallNewFeedbackSlot().ToInt() + 1); |
| 3267 */ | 3281 */ |
| 3268 } | 3282 } |
| 3269 | 3283 |
| 3270 __ li(a2, FeedbackVector()); | 3284 __ li(a2, FeedbackVector()); |
| 3271 __ li(a3, Operand(SmiFromSlot(expr->CallFeedbackSlot()))); | 3285 __ li(a3, Operand(SmiFromSlot(expr->CallFeedbackSlot()))); |
| 3272 | 3286 |
| 3273 // TODO(dslomov): use a different stub and propagate new.target. | 3287 CallConstructStub stub(isolate(), SUPER_CALL_RECORD_TARGET); |
| 3274 CallConstructStub stub(isolate(), RECORD_CONSTRUCTOR_TARGET); | |
| 3275 __ Call(stub.GetCode(), RelocInfo::CONSTRUCT_CALL); | 3288 __ Call(stub.GetCode(), RelocInfo::CONSTRUCT_CALL); |
| 3276 | 3289 |
| 3290 __ Drop(1); |
| 3291 |
| 3277 RecordJSReturnSite(expr); | 3292 RecordJSReturnSite(expr); |
| 3278 | 3293 |
| 3279 EmitVariableAssignment(this_var, Token::INIT_CONST); | 3294 EmitVariableAssignment(this_var, Token::INIT_CONST); |
| 3280 context()->Plug(v0); | 3295 context()->Plug(v0); |
| 3281 } | 3296 } |
| 3282 | 3297 |
| 3283 | 3298 |
| 3284 void FullCodeGenerator::EmitIsSmi(CallRuntime* expr) { | 3299 void FullCodeGenerator::EmitIsSmi(CallRuntime* expr) { |
| 3285 ZoneList<Expression*>* args = expr->arguments(); | 3300 ZoneList<Expression*>* args = expr->arguments(); |
| 3286 DCHECK(args->length() == 1); | 3301 DCHECK(args->length() == 1); |
| (...skipping 2074 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5361 Assembler::target_address_at(pc_immediate_load_address)) == | 5376 Assembler::target_address_at(pc_immediate_load_address)) == |
| 5362 reinterpret_cast<uint32_t>( | 5377 reinterpret_cast<uint32_t>( |
| 5363 isolate->builtins()->OsrAfterStackCheck()->entry())); | 5378 isolate->builtins()->OsrAfterStackCheck()->entry())); |
| 5364 return OSR_AFTER_STACK_CHECK; | 5379 return OSR_AFTER_STACK_CHECK; |
| 5365 } | 5380 } |
| 5366 | 5381 |
| 5367 | 5382 |
| 5368 } } // namespace v8::internal | 5383 } } // namespace v8::internal |
| 5369 | 5384 |
| 5370 #endif // V8_TARGET_ARCH_MIPS | 5385 #endif // V8_TARGET_ARCH_MIPS |
| OLD | NEW |