OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 2301 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2312 __ pop(left); | 2312 __ pop(left); |
2313 __ mov(a0, result_register()); | 2313 __ mov(a0, result_register()); |
2314 | 2314 |
2315 // Perform combined smi check on both operands. | 2315 // Perform combined smi check on both operands. |
2316 __ Or(scratch1, left, Operand(right)); | 2316 __ Or(scratch1, left, Operand(right)); |
2317 STATIC_ASSERT(kSmiTag == 0); | 2317 STATIC_ASSERT(kSmiTag == 0); |
2318 JumpPatchSite patch_site(masm_); | 2318 JumpPatchSite patch_site(masm_); |
2319 patch_site.EmitJumpIfSmi(scratch1, &smi_case); | 2319 patch_site.EmitJumpIfSmi(scratch1, &smi_case); |
2320 | 2320 |
2321 __ bind(&stub_call); | 2321 __ bind(&stub_call); |
2322 BinaryOpStub stub(op, mode); | 2322 BinaryOpICStub stub(op, mode); |
2323 CallIC(stub.GetCode(isolate()), RelocInfo::CODE_TARGET, | 2323 CallIC(stub.GetCode(isolate()), RelocInfo::CODE_TARGET, |
2324 expr->BinaryOperationFeedbackId()); | 2324 expr->BinaryOperationFeedbackId()); |
2325 patch_site.EmitPatchInfo(); | 2325 patch_site.EmitPatchInfo(); |
2326 __ jmp(&done); | 2326 __ jmp(&done); |
2327 | 2327 |
2328 __ bind(&smi_case); | 2328 __ bind(&smi_case); |
2329 // Smi case. This code works the same way as the smi-smi case in the type | 2329 // Smi case. This code works the same way as the smi-smi case in the type |
2330 // recording binary operation stub, see | 2330 // recording binary operation stub, see |
2331 // BinaryOpStub::GenerateSmiSmiOperation for comments. | |
2332 switch (op) { | 2331 switch (op) { |
2333 case Token::SAR: | 2332 case Token::SAR: |
2334 __ Branch(&stub_call); | 2333 __ Branch(&stub_call); |
2335 __ GetLeastBitsFromSmi(scratch1, right, 5); | 2334 __ GetLeastBitsFromSmi(scratch1, right, 5); |
2336 __ srav(right, left, scratch1); | 2335 __ srav(right, left, scratch1); |
2337 __ And(v0, right, Operand(~kSmiTagMask)); | 2336 __ And(v0, right, Operand(~kSmiTagMask)); |
2338 break; | 2337 break; |
2339 case Token::SHL: { | 2338 case Token::SHL: { |
2340 __ Branch(&stub_call); | 2339 __ Branch(&stub_call); |
2341 __ SmiUntag(scratch1, left); | 2340 __ SmiUntag(scratch1, left); |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2395 __ bind(&done); | 2394 __ bind(&done); |
2396 context()->Plug(v0); | 2395 context()->Plug(v0); |
2397 } | 2396 } |
2398 | 2397 |
2399 | 2398 |
2400 void FullCodeGenerator::EmitBinaryOp(BinaryOperation* expr, | 2399 void FullCodeGenerator::EmitBinaryOp(BinaryOperation* expr, |
2401 Token::Value op, | 2400 Token::Value op, |
2402 OverwriteMode mode) { | 2401 OverwriteMode mode) { |
2403 __ mov(a0, result_register()); | 2402 __ mov(a0, result_register()); |
2404 __ pop(a1); | 2403 __ pop(a1); |
2405 BinaryOpStub stub(op, mode); | 2404 BinaryOpICStub stub(op, mode); |
2406 JumpPatchSite patch_site(masm_); // unbound, signals no inlined smi code. | 2405 JumpPatchSite patch_site(masm_); // unbound, signals no inlined smi code. |
2407 CallIC(stub.GetCode(isolate()), RelocInfo::CODE_TARGET, | 2406 CallIC(stub.GetCode(isolate()), RelocInfo::CODE_TARGET, |
2408 expr->BinaryOperationFeedbackId()); | 2407 expr->BinaryOperationFeedbackId()); |
2409 patch_site.EmitPatchInfo(); | 2408 patch_site.EmitPatchInfo(); |
2410 context()->Plug(v0); | 2409 context()->Plug(v0); |
2411 } | 2410 } |
2412 | 2411 |
2413 | 2412 |
2414 void FullCodeGenerator::EmitAssignment(Expression* expr) { | 2413 void FullCodeGenerator::EmitAssignment(Expression* expr) { |
2415 // Invalid left-hand sides are rewritten by the parser to have a 'throw | 2414 // Invalid left-hand sides are rewritten by the parser to have a 'throw |
(...skipping 2051 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4467 } | 4466 } |
4468 } | 4467 } |
4469 | 4468 |
4470 __ bind(&stub_call); | 4469 __ bind(&stub_call); |
4471 __ mov(a1, v0); | 4470 __ mov(a1, v0); |
4472 __ li(a0, Operand(Smi::FromInt(count_value))); | 4471 __ li(a0, Operand(Smi::FromInt(count_value))); |
4473 | 4472 |
4474 // Record position before stub call. | 4473 // Record position before stub call. |
4475 SetSourcePosition(expr->position()); | 4474 SetSourcePosition(expr->position()); |
4476 | 4475 |
4477 BinaryOpStub stub(Token::ADD, NO_OVERWRITE); | 4476 BinaryOpICStub stub(Token::ADD, NO_OVERWRITE); |
4478 CallIC(stub.GetCode(isolate()), | 4477 CallIC(stub.GetCode(isolate()), |
4479 RelocInfo::CODE_TARGET, | 4478 RelocInfo::CODE_TARGET, |
4480 expr->CountBinOpFeedbackId()); | 4479 expr->CountBinOpFeedbackId()); |
4481 patch_site.EmitPatchInfo(); | 4480 patch_site.EmitPatchInfo(); |
4482 __ bind(&done); | 4481 __ bind(&done); |
4483 | 4482 |
4484 // Store the value returned in v0. | 4483 // Store the value returned in v0. |
4485 switch (assign_type) { | 4484 switch (assign_type) { |
4486 case VARIABLE: | 4485 case VARIABLE: |
4487 if (expr->is_postfix()) { | 4486 if (expr->is_postfix()) { |
(...skipping 490 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4978 Assembler::target_address_at(pc_immediate_load_address)) == | 4977 Assembler::target_address_at(pc_immediate_load_address)) == |
4979 reinterpret_cast<uint32_t>( | 4978 reinterpret_cast<uint32_t>( |
4980 isolate->builtins()->OsrAfterStackCheck()->entry())); | 4979 isolate->builtins()->OsrAfterStackCheck()->entry())); |
4981 return OSR_AFTER_STACK_CHECK; | 4980 return OSR_AFTER_STACK_CHECK; |
4982 } | 4981 } |
4983 | 4982 |
4984 | 4983 |
4985 } } // namespace v8::internal | 4984 } } // namespace v8::internal |
4986 | 4985 |
4987 #endif // V8_TARGET_ARCH_MIPS | 4986 #endif // V8_TARGET_ARCH_MIPS |
OLD | NEW |